fix(kernel/converter): bug in is_def_eq

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-06-16 14:09:12 -07:00
parent f1e3449aae
commit 21c54755a9
3 changed files with 41 additions and 3 deletions

View file

@ -279,15 +279,16 @@ struct default_converter : public converter {
expr_kind k = t.kind(); expr_kind k = t.kind();
buffer<expr> subst; buffer<expr> subst;
do { do {
expr var_t_type = instantiate(binding_domain(t), subst.size(), subst.data()); expr var_t_type = instantiate_rev(binding_domain(t), subst.size(), subst.data());
expr var_s_type = instantiate(binding_domain(s), subst.size(), subst.data()); expr var_s_type = instantiate_rev(binding_domain(s), subst.size(), subst.data());
if (!is_def_eq(var_t_type, var_s_type, c, jst)) if (!is_def_eq(var_t_type, var_s_type, c, jst))
return false; return false;
subst.push_back(mk_local(c.mk_fresh_name(), binding_name(s), var_s_type)); subst.push_back(mk_local(c.mk_fresh_name(), binding_name(s), var_s_type));
t = binding_body(t); t = binding_body(t);
s = binding_body(s); s = binding_body(s);
} while (t.kind() == k && s.kind() == k); } while (t.kind() == k && s.kind() == k);
return is_def_eq(instantiate(t, subst.size(), subst.data()), instantiate(s, subst.size(), subst.data()), c, jst); return is_def_eq(instantiate_rev(t, subst.size(), subst.data()),
instantiate_rev(s, subst.size(), subst.data()), c, jst);
} }
/** \brief This is an auxiliary method for is_def_eq. It handles the "easy cases". */ /** \brief This is an auxiliary method for is_def_eq. It handles the "easy cases". */

24
tests/lean/bug1.lean Normal file
View file

@ -0,0 +1,24 @@
definition [inline] bool : Type.{1} := Type.{0}
definition [inline] and (p q : bool) : bool := ∀ c : bool, (p → q → c) → c
infixl `∧` 25 := and
variable a : bool
-- Error
theorem and_intro (p q : bool) (H1 : p) (H2 : q) : a
:= fun (c : bool) (H : p -> q -> c), H H1 H2
-- Error
theorem and_intro (p q : bool) (H1 : p) (H2 : q) : p ∧ p
:= fun (c : bool) (H : p -> q -> c), H H1 H2
-- Error
theorem and_intro (p q : bool) (H1 : p) (H2 : q) : q ∧ p
:= fun (c : bool) (H : p -> q -> c), H H1 H2
-- Correct
theorem and_intro (p q : bool) (H1 : p) (H2 : q) : p ∧ q
:= fun (c : bool) (H : p -> q -> c), H H1 H2
check and_intro

View file

@ -0,0 +1,13 @@
bug1.lean:9:7: error: type mismatch at definition 'and_intro', expected type
Pi (p : bool) (q : bool) (H1 : p) (H2 : q), a
given type:
Pi (p : bool) (q : bool) (H1 : p) (H2 : q) (c : bool) (H : p -> q -> c), c
bug1.lean:13:7: error: type mismatch at definition 'and_intro', expected type
Pi (p : bool) (q : bool) (H1 : p) (H2 : q), (and p p)
given type:
Pi (p : bool) (q : bool) (H1 : p) (H2 : q) (c : bool) (H : p -> q -> c), c
bug1.lean:17:7: error: type mismatch at definition 'and_intro', expected type
Pi (p : bool) (q : bool) (H1 : p) (H2 : q), (and q p)
given type:
Pi (p : bool) (q : bool) (H1 : p) (H2 : q) (c : bool) (H : p -> q -> c), c
and_intro : Pi (p : bool) (q : bool) (H1 : p) (H2 : q), (and p q)