feat(frontends/lean/calc_proof_elaborator): cleanup communication between unifier and calc_proof_elaborator
This commit is contained in:
parent
018518f0cf
commit
919c4ea8ee
1 changed files with 6 additions and 1 deletions
|
@ -7,6 +7,7 @@ Author: Leonardo de Moura
|
||||||
#include "util/sexpr/option_declarations.h"
|
#include "util/sexpr/option_declarations.h"
|
||||||
#include "kernel/free_vars.h"
|
#include "kernel/free_vars.h"
|
||||||
#include "kernel/instantiate.h"
|
#include "kernel/instantiate.h"
|
||||||
|
#include "kernel/abstract.h"
|
||||||
#include "library/unifier.h"
|
#include "library/unifier.h"
|
||||||
#include "library/reducible.h"
|
#include "library/reducible.h"
|
||||||
#include "library/metavar_closure.h"
|
#include "library/metavar_closure.h"
|
||||||
|
@ -190,7 +191,6 @@ constraint mk_calc_proof_cnstr(environment const & env, options const & opts,
|
||||||
metavar_closure cls(meta);
|
metavar_closure cls(meta);
|
||||||
cls.add(meta_type);
|
cls.add(meta_type);
|
||||||
cls.mk_constraints(s, j, cs_buffer);
|
cls.mk_constraints(s, j, cs_buffer);
|
||||||
cs_buffer.push_back(mk_eq_cnstr(meta, e, j));
|
|
||||||
|
|
||||||
unifier_config new_cfg(cfg);
|
unifier_config new_cfg(cfg);
|
||||||
new_cfg.m_discard = false;
|
new_cfg.m_discard = false;
|
||||||
|
@ -204,11 +204,16 @@ constraint mk_calc_proof_cnstr(environment const & env, options const & opts,
|
||||||
// we erase internal justifications
|
// we erase internal justifications
|
||||||
return update_justification(c, j);
|
return update_justification(c, j);
|
||||||
});
|
});
|
||||||
|
expr new_e = new_s.instantiate(e);
|
||||||
if (conservative && has_expr_metavar_relaxed(new_s.instantiate_all(e)))
|
if (conservative && has_expr_metavar_relaxed(new_s.instantiate_all(e)))
|
||||||
throw_elaborator_exception("solution contains metavariables", e);
|
throw_elaborator_exception("solution contains metavariables", e);
|
||||||
if (im)
|
if (im)
|
||||||
im->instantiate(new_s);
|
im->instantiate(new_s);
|
||||||
constraints r = cls.mk_constraints(new_s, j);
|
constraints r = cls.mk_constraints(new_s, j);
|
||||||
|
buffer<expr> locals;
|
||||||
|
expr mvar = get_app_args(meta, locals);
|
||||||
|
expr val = Fun(locals, new_e);
|
||||||
|
r = cons(mk_eq_cnstr(mvar, val, j), r);
|
||||||
return append(r, postponed);
|
return append(r, postponed);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue