feat(frontends/lean): improve 'type mismatch' error position, and annotate 'have'-expressions

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-07-25 09:44:40 -07:00
parent 022a151cf7
commit a59eec39b8
5 changed files with 5 additions and 5 deletions

View file

@ -265,7 +265,7 @@ static expr parse_have_core(parser & p, pos_info const & pos, optional<expr> con
// remark: mk_contextual_info(false) informs the elaborator that prop should not occur inside metavariables. // remark: mk_contextual_info(false) informs the elaborator that prop should not occur inside metavariables.
body = abstract(body, l); body = abstract(body, l);
expr r = p.save_pos(mk_lambda(id, prop, body, bi), pos); expr r = p.save_pos(mk_lambda(id, prop, body, bi), pos);
return p.save_pos(mk_app(r, proof), pos); return p.save_pos(mk_have_annotation(p.mk_app(r, proof, pos)), pos);
} }
static expr parse_have(parser & p, unsigned, expr const *, pos_info const & pos) { static expr parse_have(parser & p, unsigned, expr const *, pos_info const & pos) {

View file

@ -806,7 +806,7 @@ public:
// rely on unification hints to solve this constraint // rely on unification hints to solve this constraint
add_cnstr(mk_eq_cnstr(a_type, d_type, j.get())); add_cnstr(mk_eq_cnstr(a_type, d_type, j.get()));
} else { } else {
throw_kernel_exception(m_env, a, [=](formatter const & fmt) { return pp_app_type_mismatch(fmt, e, d_type, a_type); }); throw_kernel_exception(m_env, r, [=](formatter const & fmt) { return pp_app_type_mismatch(fmt, e, d_type, a_type); });
} }
} }
} }

View file

@ -1,4 +1,4 @@
crash.lean:6:0: error: type mismatch at application crash.lean:8:12: error: type mismatch at application
(λ (H' : not P), _) H (λ (H' : not P), _) H
expected type: expected type:
not P not P

View file

@ -13,7 +13,7 @@ let and_intro : ∀ (p q : Prop),
in and_intro : in and_intro :
∀ (p q : Prop), ∀ (p q : Prop),
p → q → (λ (p q : Prop), ∀ (c : Prop), (p → q → c) → c) p q p → q → (λ (p q : Prop), ∀ (c : Prop), (p → q → c) → c) p q
let1.lean:17:20: error: type mismatch at application let1.lean:16:10: error: type mismatch at application
(λ (and_intro : ∀ (p q : Prop), p → q → (λ (p q : Prop), ∀ (c : Prop), (p → q → c) → c) q p), (λ (and_intro : ∀ (p q : Prop), p → q → (λ (p q : Prop), ∀ (c : Prop), (p → q → c) → c) q p),
let and_elim_left : ∀ (p q : Prop), let and_elim_left : ∀ (p q : Prop),
(λ (p q : Prop), ∀ (c : Prop), (p → q → c) → c) p q → p := (λ (p q : Prop), ∀ (c : Prop), (p → q → c) → c) p q → p :=

View file

@ -1,5 +1,5 @@
ite (and p q) (f x) y : N ite (and p q) (f x) y : N
t10.lean:14:22: error: type mismatch at application t10.lean:14:6: error: type mismatch at application
ite (and p q) q ite (and p q) q
expected type: expected type:
N N