fix(frontends/lean/elaborator): error localization for 'expr_to_tactic' failures
This commit is contained in:
parent
6fcba192b2
commit
2c330e704e
2 changed files with 6 additions and 5 deletions
|
@ -901,7 +901,7 @@ optional<expr> elaborator::get_pre_tactic_for(substitution & subst, expr const &
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
optional<tactic> elaborator::pre_tactic_to_tactic(expr const & pre_tac, expr const & mvar) {
|
optional<tactic> elaborator::pre_tactic_to_tactic(expr const & pre_tac) {
|
||||||
try {
|
try {
|
||||||
bool relax = m_relax_main_opaque;
|
bool relax = m_relax_main_opaque;
|
||||||
auto fn = [=](goal const & g, name_generator const & ngen, expr const & e) {
|
auto fn = [=](goal const & g, name_generator const & ngen, expr const & e) {
|
||||||
|
@ -914,7 +914,8 @@ optional<tactic> elaborator::pre_tactic_to_tactic(expr const & pre_tac, expr con
|
||||||
return optional<tactic>(expr_to_tactic(env(), fn, pre_tac, pip()));
|
return optional<tactic>(expr_to_tactic(env(), fn, pre_tac, pip()));
|
||||||
} catch (expr_to_tactic_exception & ex) {
|
} catch (expr_to_tactic_exception & ex) {
|
||||||
auto out = regular(env(), ios());
|
auto out = regular(env(), ios());
|
||||||
display_error_pos(out, pip(), mvar);
|
flycheck_error err(out);
|
||||||
|
display_error_pos(out, pip(), ex.get_expr());
|
||||||
out << " " << ex.what();
|
out << " " << ex.what();
|
||||||
out << pp_indent_expr(out.get_formatter(), pre_tac) << endl << "failed at:"
|
out << pp_indent_expr(out.get_formatter(), pre_tac) << endl << "failed at:"
|
||||||
<< pp_indent_expr(out.get_formatter(), ex.get_expr()) << endl;
|
<< pp_indent_expr(out.get_formatter(), ex.get_expr()) << endl;
|
||||||
|
@ -924,7 +925,7 @@ optional<tactic> elaborator::pre_tactic_to_tactic(expr const & pre_tac, expr con
|
||||||
|
|
||||||
optional<tactic> elaborator::get_local_tactic_hint(substitution & subst, expr const & mvar, name_set & visited) {
|
optional<tactic> elaborator::get_local_tactic_hint(substitution & subst, expr const & mvar, name_set & visited) {
|
||||||
if (auto pre_tac = get_pre_tactic_for(subst, mvar, visited)) {
|
if (auto pre_tac = get_pre_tactic_for(subst, mvar, visited)) {
|
||||||
return pre_tactic_to_tactic(*pre_tac, mvar);
|
return pre_tactic_to_tactic(*pre_tac);
|
||||||
} else {
|
} else {
|
||||||
return optional<tactic>();
|
return optional<tactic>();
|
||||||
}
|
}
|
||||||
|
@ -990,7 +991,7 @@ void elaborator::solve_unassigned_mvar(substitution & subst, expr mvar, name_set
|
||||||
} else if (m_use_tactic_hints) {
|
} else if (m_use_tactic_hints) {
|
||||||
// using tactic_hints
|
// using tactic_hints
|
||||||
for (expr const & pre_tac : get_tactic_hints(env())) {
|
for (expr const & pre_tac : get_tactic_hints(env())) {
|
||||||
if (auto tac = pre_tactic_to_tactic(pre_tac, mvar)) {
|
if (auto tac = pre_tactic_to_tactic(pre_tac)) {
|
||||||
bool show_failure = false;
|
bool show_failure = false;
|
||||||
if (try_using(subst, mvar, ps, *tac, show_failure))
|
if (try_using(subst, mvar, ps, *tac, show_failure))
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -123,7 +123,7 @@ class elaborator : public coercion_info_manager {
|
||||||
unify_result_seq solve(constraint_seq const & cs);
|
unify_result_seq solve(constraint_seq const & cs);
|
||||||
void display_unsolved_proof_state(expr const & mvar, proof_state const & ps, char const * msg);
|
void display_unsolved_proof_state(expr const & mvar, proof_state const & ps, char const * msg);
|
||||||
optional<expr> get_pre_tactic_for(substitution & subst, expr const & mvar, name_set & visited);
|
optional<expr> get_pre_tactic_for(substitution & subst, expr const & mvar, name_set & visited);
|
||||||
optional<tactic> pre_tactic_to_tactic(expr const & pre_tac, expr const & mvar);
|
optional<tactic> pre_tactic_to_tactic(expr const & pre_tac);
|
||||||
optional<tactic> get_local_tactic_hint(substitution & subst, expr const & mvar, name_set & visited);
|
optional<tactic> get_local_tactic_hint(substitution & subst, expr const & mvar, name_set & visited);
|
||||||
bool try_using(substitution & subst, expr const & mvar, proof_state const & ps, tactic const & tac,
|
bool try_using(substitution & subst, expr const & mvar, proof_state const & ps, tactic const & tac,
|
||||||
bool show_failure);
|
bool show_failure);
|
||||||
|
|
Loading…
Reference in a new issue