fix(library/tactic/inversion_tactic): bug at implementation_list update

This commit is contained in:
Leonardo de Moura 2015-01-04 19:56:10 -08:00
parent 7ff03e2846
commit 576c053c25

View file

@ -76,24 +76,23 @@ optional<expr> apply_eq_rec_eq(type_checker & tc, io_state const & ios, list<exp
typedef inversion::implementation_ptr implementation_ptr; typedef inversion::implementation_ptr implementation_ptr;
typedef inversion::implementation_list implementation_list; typedef inversion::implementation_list implementation_list;
static void abstract_locals(implementation_list const & imps, unsigned nlocals, expr const * locals) {
static void replace(implementation_list const & imps, unsigned sz, expr const * from, expr const * to) {
lean_assert(std::all_of(from, from+sz, is_local));
for (implementation_ptr const & imp : imps) { for (implementation_ptr const & imp : imps) {
imp->update_exprs([&](expr const & e) { return abstract_locals(e, nlocals, locals); }); imp->update_exprs([&](expr const & e) {
return instantiate_rev(abstract_locals(e, sz, from), sz, to);
});
} }
} }
static void instantiate(implementation_list const & imps, expr const & local) { static void replace(implementation_list const & imps, buffer<expr> const & from, buffer<expr> const & to) {
for (implementation_ptr const & imp : imps) { lean_assert(from.size() == to.size());
imp->update_exprs([&](expr const & e) { return instantiate(e, local); }); return replace(imps, from.size(), from.data(), to.data());
}
} }
static void abstract_locals(implementation_list const & imps, buffer<expr> const & locals) { static void replace(implementation_list const & imps, expr const & from, expr const & to) {
abstract_locals(imps, locals.size(), locals.data()); return replace(imps, 1, &from, &to);
}
static void abstract_local(implementation_list const & imps, expr const & local) {
abstract_locals(imps, 1, &local);
} }
class inversion_tac { class inversion_tac {
@ -753,7 +752,6 @@ class inversion_tac {
return unify_eqs(new_g, neqs-1); return unify_eqs(new_g, neqs-1);
} else { } else {
expr deps_g_type = Pi(deps, g_type); expr deps_g_type = Pi(deps, g_type);
abstract_locals(m_imps, deps);
level eq_rec_lvl1 = sort_level(m_tc.ensure_type(deps_g_type).first); level eq_rec_lvl1 = sort_level(m_tc.ensure_type(deps_g_type).first);
level eq_rec_lvl2 = sort_level(m_tc.ensure_type(A).first); level eq_rec_lvl2 = sort_level(m_tc.ensure_type(A).first);
expr tformer; expr tformer;
@ -767,8 +765,7 @@ class inversion_tac {
new_hyps.append(non_deps); new_hyps.append(non_deps);
expr new_type = instantiate(abstract_local(deps_g_type, rhs), lhs); expr new_type = instantiate(abstract_local(deps_g_type, rhs), lhs);
store_rename(rhs, lhs); store_rename(rhs, lhs);
abstract_local(m_imps, rhs); replace(m_imps, rhs, lhs);
instantiate(m_imps, lhs);
if (!m_proof_irrel) { if (!m_proof_irrel) {
new_type = abstract_local(new_type, eq); new_type = abstract_local(new_type, eq);
new_type = instantiate(new_type, mk_refl(m_tc, lhs)); new_type = instantiate(new_type, mk_refl(m_tc, lhs));
@ -780,8 +777,8 @@ class inversion_tac {
new_hyps.push_back(new_hyp); new_hyps.push_back(new_hyp);
new_deps.push_back(new_hyp); new_deps.push_back(new_hyp);
new_type = instantiate(binding_body(new_type), new_hyp); new_type = instantiate(binding_body(new_type), new_hyp);
instantiate(m_imps, new_hyp);
} }
replace(m_imps, deps, new_deps);
lean_assert(deps.size() == new_deps.size()); lean_assert(deps.size() == new_deps.size());
store_renames(deps, new_deps); store_renames(deps, new_deps);
expr new_mvar = mk_metavar(m_ngen.next(), Pi(new_hyps, new_type)); expr new_mvar = mk_metavar(m_ngen.next(), Pi(new_hyps, new_type));