mirror of
https://github.com/Z3Prover/z3
synced 2025-04-24 09:35:32 +00:00
move user propagte declare to context level
declaration of user propagate functions are declared at context level instead of at solver scope.
This commit is contained in:
parent
4856581b68
commit
f0740bdf60
17 changed files with 92 additions and 324 deletions
|
@ -892,7 +892,7 @@ public:
|
|||
m_num_elim_apps = 0;
|
||||
}
|
||||
|
||||
unsigned user_propagate_register(expr* e) override {
|
||||
unsigned user_propagate_register_expr(expr* e) override {
|
||||
m_nonvars.insert(e);
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -78,7 +78,7 @@ public:
|
|||
|
||||
void operator()(goal_ref const & g, goal_ref_buffer & result) override;
|
||||
void cleanup() override;
|
||||
unsigned user_propagate_register(expr* e) override;
|
||||
unsigned user_propagate_register_expr(expr* e) override;
|
||||
void user_propagate_clear() override;
|
||||
};
|
||||
|
||||
|
@ -502,7 +502,7 @@ void reduce_args_tactic::cleanup() {
|
|||
m_imp->m_vars.append(vars);
|
||||
}
|
||||
|
||||
unsigned reduce_args_tactic::user_propagate_register(expr* e) {
|
||||
unsigned reduce_args_tactic::user_propagate_register_expr(expr* e) {
|
||||
m_imp->m_vars.push_back(e);
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -85,7 +85,7 @@ public:
|
|||
throw default_exception("tactic does not support user propagation");
|
||||
}
|
||||
|
||||
unsigned user_propagate_register(expr* e) override { return 0; }
|
||||
unsigned user_propagate_register_expr(expr* e) override { return 0; }
|
||||
virtual char const* name() const = 0;
|
||||
|
||||
protected:
|
||||
|
|
|
@ -190,9 +190,9 @@ public:
|
|||
m_t2->user_propagate_register_diseq(diseq_eh);
|
||||
}
|
||||
|
||||
unsigned user_propagate_register(expr* e) override {
|
||||
m_t1->user_propagate_register(e);
|
||||
return m_t2->user_propagate_register(e);
|
||||
unsigned user_propagate_register_expr(expr* e) override {
|
||||
m_t1->user_propagate_register_expr(e);
|
||||
return m_t2->user_propagate_register_expr(e);
|
||||
}
|
||||
|
||||
void user_propagate_clear() override {
|
||||
|
@ -204,10 +204,6 @@ public:
|
|||
m_t2->user_propagate_register_created(created_eh);
|
||||
}
|
||||
|
||||
func_decl* user_propagate_declare(symbol const& name, unsigned n, sort* const* domain, sort* range) override {
|
||||
return m_t2->user_propagate_declare(name, n, domain, range);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
tactic * and_then(tactic * t1, tactic * t2) {
|
||||
|
@ -833,7 +829,7 @@ public:
|
|||
void reset() override { m_t->reset(); }
|
||||
void set_logic(symbol const& l) override { m_t->set_logic(l); }
|
||||
void set_progress_callback(progress_callback * callback) override { m_t->set_progress_callback(callback); }
|
||||
unsigned user_propagate_register(expr* e) override { return m_t->user_propagate_register(e); }
|
||||
unsigned user_propagate_register_expr(expr* e) override { return m_t->user_propagate_register_expr(e); }
|
||||
void user_propagate_clear() override { m_t->user_propagate_clear(); }
|
||||
|
||||
protected:
|
||||
|
|
|
@ -29,6 +29,8 @@ namespace user_propagator {
|
|||
class plugin : public decl_plugin {
|
||||
public:
|
||||
|
||||
static symbol name() { return symbol("user_propagator"); }
|
||||
|
||||
enum kind_t { OP_USER_PROPAGATE };
|
||||
|
||||
virtual ~plugin() {}
|
||||
|
@ -79,19 +81,7 @@ namespace user_propagator {
|
|||
throw default_exception("user-propagators are only supported on the SMT solver");
|
||||
}
|
||||
|
||||
virtual unsigned user_propagate_register(expr* e) {
|
||||
throw default_exception("user-propagators are only supported on the SMT solver");
|
||||
}
|
||||
|
||||
/**
|
||||
* Create uninterpreted function for the user propagator.
|
||||
* When expressions using the function are assigned values, generate a callback
|
||||
* into a register_declared_eh(user_ctx, solver_ctx, declared_expr, declare_id) with arguments
|
||||
* 1. context and callback context
|
||||
* 2. declared_expr: expression using function that was declared at top.
|
||||
* 3. declared_id: a unique identifier (unique within the current scope) to track the expression.
|
||||
*/
|
||||
virtual func_decl* user_propagate_declare(symbol const& name, unsigned n, sort* const* domain, sort* range) {
|
||||
virtual unsigned user_propagate_register_expr(expr* e) {
|
||||
throw default_exception("user-propagators are only supported on the SMT solver");
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue