mirror of
https://github.com/Z3Prover/z3
synced 2025-05-07 15:55:46 +00:00
make default argument to ensure_def and mk_def explicit
- insert also macro definitions into models
This commit is contained in:
parent
c64d61bd0a
commit
f17691715b
4 changed files with 28 additions and 23 deletions
|
@ -361,7 +361,7 @@ void cmd_context::insert_macro(symbol const& s, unsigned arity, sort*const* doma
|
|||
vars.push_back(m().mk_var(i, domain[i]));
|
||||
rvars.push_back(m().mk_var(i, domain[arity - i - 1]));
|
||||
}
|
||||
recfun::promise_def d = p.ensure_def(s, arity, domain, t->get_sort());
|
||||
recfun::promise_def d = p.ensure_def(s, arity, domain, t->get_sort(), false);
|
||||
|
||||
// recursive functions have opposite calling convention from macros!
|
||||
var_subst sub(m(), true);
|
||||
|
@ -984,7 +984,7 @@ recfun::decl::plugin& cmd_context::get_recfun_plugin() {
|
|||
|
||||
recfun::promise_def cmd_context::decl_rec_fun(const symbol &name, unsigned int arity, sort *const *domain, sort *range) {
|
||||
SASSERT(logic_has_recfun());
|
||||
return get_recfun_plugin().mk_def(name, arity, domain, range);
|
||||
return get_recfun_plugin().mk_def(name, arity, domain, range, false);
|
||||
}
|
||||
|
||||
void cmd_context::insert_rec_fun(func_decl* f, expr_ref_vector const& binding, svector<symbol> const& ids, expr* rhs) {
|
||||
|
@ -1982,25 +1982,31 @@ void cmd_context::complete_model(model_ref& md) const {
|
|||
}
|
||||
}
|
||||
|
||||
for (auto kd : m_func_decls) {
|
||||
symbol const & k = kd.m_key;
|
||||
func_decls & v = kd.m_value;
|
||||
for (auto& [k, v] : m_func_decls) {
|
||||
IF_VERBOSE(12, verbose_stream() << "(model.completion " << k << ")\n"; );
|
||||
for (unsigned i = 0; i < v.get_num_entries(); i++) {
|
||||
func_decl * f = v.get_entry(i);
|
||||
if (!md->has_interpretation(f)) {
|
||||
sort * range = f->get_range();
|
||||
expr * some_val = m().get_some_value(range);
|
||||
if (f->get_arity() > 0) {
|
||||
func_interp * fi = alloc(func_interp, m(), f->get_arity());
|
||||
fi->set_else(some_val);
|
||||
md->register_decl(f, fi);
|
||||
}
|
||||
else
|
||||
md->register_decl(f, some_val);
|
||||
|
||||
if (md->has_interpretation(f))
|
||||
continue;
|
||||
macro_decls decls;
|
||||
expr* body = nullptr;
|
||||
|
||||
if (m_macros.find(k, decls))
|
||||
body = decls.find(f->get_arity(), f->get_domain());
|
||||
sort * range = f->get_range();
|
||||
if (!body)
|
||||
body = m().get_some_value(range);
|
||||
if (f->get_arity() > 0) {
|
||||
func_interp * fi = alloc(func_interp, m(), f->get_arity());
|
||||
fi->set_else(body);
|
||||
md->register_decl(f, fi);
|
||||
}
|
||||
else
|
||||
md->register_decl(f, body);
|
||||
}
|
||||
}
|
||||
verbose_stream() << *md << "\n";
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue