fix(library/tactic/inversion_tactic): check whether eliminator can only eliminate to Prop
fixes #571
This commit is contained in:
parent
e379034b95
commit
e1dc18f6b6
3 changed files with 27 additions and 1 deletions
|
@ -379,10 +379,16 @@ class inversion_tac {
|
||||||
name const & I_name = const_name(I);
|
name const & I_name = const_name(I);
|
||||||
expr g_type = g.get_type();
|
expr g_type = g.get_type();
|
||||||
expr cases_on;
|
expr cases_on;
|
||||||
if (m_cases_on_decl.get_num_univ_params() != m_I_decl.get_num_univ_params()) {
|
|
||||||
level g_lvl = sort_level(m_tc.ensure_type(g_type).first);
|
level g_lvl = sort_level(m_tc.ensure_type(g_type).first);
|
||||||
|
if (m_cases_on_decl.get_num_univ_params() != m_I_decl.get_num_univ_params()) {
|
||||||
cases_on = mk_constant({I_name, "cases_on"}, cons(g_lvl, const_levels(I)));
|
cases_on = mk_constant({I_name, "cases_on"}, cons(g_lvl, const_levels(I)));
|
||||||
} else {
|
} else {
|
||||||
|
if (!is_zero(g_lvl)) {
|
||||||
|
if (m_throw_tactic_exception)
|
||||||
|
throw tactic_exception(sstream() << "invalid 'cases' tactic, '" << const_name(I) << "' can only eliminate to Prop");
|
||||||
|
else
|
||||||
|
throw inversion_exception();
|
||||||
|
}
|
||||||
cases_on = mk_constant({I_name, "cases_on"}, const_levels(I));
|
cases_on = mk_constant({I_name, "cases_on"}, const_levels(I));
|
||||||
}
|
}
|
||||||
// add params
|
// add params
|
||||||
|
|
7
tests/lean/571.lean
Normal file
7
tests/lean/571.lean
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
open nat
|
||||||
|
variables (P : ℕ → Prop)
|
||||||
|
|
||||||
|
example (H : ∃n, P n) : ℕ :=
|
||||||
|
begin
|
||||||
|
cases H with n p,
|
||||||
|
end
|
13
tests/lean/571.lean.expected.out
Normal file
13
tests/lean/571.lean.expected.out
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
571.lean:6:2: error:invalid 'cases' tactic, 'Exists' can only eliminate to Prop
|
||||||
|
proof state:
|
||||||
|
P : ℕ → Prop,
|
||||||
|
H : ∃ (n : ℕ), P n
|
||||||
|
⊢ ℕ
|
||||||
|
571.lean:7:0: error: don't know how to synthesize placeholder
|
||||||
|
P : ℕ → Prop,
|
||||||
|
H : ∃ (n : ℕ), P n
|
||||||
|
⊢ ℕ
|
||||||
|
571.lean:7:0: error: failed to add declaration '14.1' to environment, value has metavariables
|
||||||
|
remark: set 'formatter.hide_full_terms' to false to see the complete term
|
||||||
|
λ (P : …) (H : …),
|
||||||
|
?M_1
|
Loading…
Reference in a new issue