From fe448d47be02da7a7089f771634c7715f9ea66aa Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Mon, 7 Jul 2014 12:03:30 -0700 Subject: [PATCH] feat(library/unifier): improve failure report Signed-off-by: Leonardo de Moura --- src/library/unifier.cpp | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/src/library/unifier.cpp b/src/library/unifier.cpp index eb572ed1e..34c474cdb 100644 --- a/src/library/unifier.cpp +++ b/src/library/unifier.cpp @@ -275,6 +275,7 @@ struct unifier_fn { */ struct case_split { unsigned m_assumption_idx; // idx of the current assumption + justification m_jst; justification m_failed_justifications; // justifications for failed branches // snapshot of unifier's state substitution m_subst; @@ -283,8 +284,8 @@ struct unifier_fn { name_to_cnstrs m_mlvl_occs; /** \brief Save unifier's state */ - case_split(unifier_fn & u): - m_assumption_idx(u.m_next_assumption_idx), m_subst(u.m_subst), m_cnstrs(u.m_cnstrs), + case_split(unifier_fn & u, justification const & j): + m_assumption_idx(u.m_next_assumption_idx), m_jst(j), m_subst(u.m_subst), m_cnstrs(u.m_cnstrs), m_mvar_occs(u.m_mvar_occs), m_mlvl_occs(u.m_mlvl_occs) { u.m_next_assumption_idx++; u.m_tc->push(); @@ -304,7 +305,7 @@ struct unifier_fn { u.m_next_assumption_idx++; u.m_conflict = optional(); } - + justification get_jst() const { return m_jst; } virtual ~case_split() {} virtual bool next(unifier_fn & u) = 0; }; @@ -312,13 +313,13 @@ struct unifier_fn { struct lazy_constraints_case_split : public case_split { lazy_list m_tail; - lazy_constraints_case_split(unifier_fn & u, lazy_list const & tail):case_split(u), m_tail(tail) {} + lazy_constraints_case_split(unifier_fn & u, justification const & j, lazy_list const & tail):case_split(u, j), m_tail(tail) {} virtual bool next(unifier_fn & u) { return u.next_lazy_constraints_case_split(*this); } }; struct simple_case_split : public case_split { list m_tail; - simple_case_split(unifier_fn & u, list const & tail):case_split(u), m_tail(tail) {} + simple_case_split(unifier_fn & u, justification const & j, list const & tail):case_split(u, j), m_tail(tail) {} virtual bool next(unifier_fn & u) { return u.next_simple_case_split(*this); } }; @@ -725,7 +726,7 @@ struct unifier_fn { cs.restore_state(*this); lean_assert(!in_conflict()); cs.m_tail = r->second; - return process_constraints(r->first, mk_assumption_justification(cs.m_assumption_idx)); + return process_constraints(r->first, mk_composite1(cs.get_jst(), mk_assumption_justification(cs.m_assumption_idx))); } else { // update conflict update_conflict(mk_composite1(*m_conflict, cs.m_failed_justifications)); @@ -742,7 +743,7 @@ struct unifier_fn { return process_constraints(r->first, j); } else { justification a = mk_assumption_justification(m_next_assumption_idx); - add_case_split(std::unique_ptr(new lazy_constraints_case_split(*this, r->second))); + add_case_split(std::unique_ptr(new lazy_constraints_case_split(*this, j, r->second))); return process_constraints(r->first, mk_composite1(j, a)); } } else { @@ -772,7 +773,7 @@ struct unifier_fn { lean_assert(!in_conflict()); constraints c = head(cs.m_tail); cs.m_tail = tail(cs.m_tail); - return process_constraints(c, mk_assumption_justification(cs.m_assumption_idx)); + return process_constraints(c, mk_composite1(cs.get_jst(), mk_assumption_justification(cs.m_assumption_idx))); } else { // update conflict update_conflict(mk_composite1(*m_conflict, cs.m_failed_justifications)); @@ -824,7 +825,7 @@ struct unifier_fn { constraints cs2(mk_eq_cnstr(t, s, j)); justification a = mk_assumption_justification(m_next_assumption_idx); - add_case_split(std::unique_ptr(new simple_case_split(*this, list(cs2)))); + add_case_split(std::unique_ptr(new simple_case_split(*this, j, list(cs2)))); return process_constraints(cs1, a); } @@ -1124,7 +1125,7 @@ struct unifier_fn { return process_constraints(alts[0], justification()); } else { justification a = mk_assumption_justification(m_next_assumption_idx); - add_case_split(std::unique_ptr(new simple_case_split(*this, to_list(alts.begin() + 1, alts.end())))); + add_case_split(std::unique_ptr(new simple_case_split(*this, j, to_list(alts.begin() + 1, alts.end())))); return process_constraints(alts[0], a); } }