fix(frontends/lean/info_manager): suppress useless tactic type information, closes #277
This commit is contained in:
parent
88d55bfef0
commit
1c9992800f
2 changed files with 15 additions and 12 deletions
|
@ -126,21 +126,12 @@ optional<expr> elaborator::mvar_to_meta(expr const & mvar) {
|
||||||
return none_expr();
|
return none_expr();
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool is_tactic_type(expr const & e) {
|
|
||||||
expr const * it = &e;
|
|
||||||
while (is_pi(*it)) {
|
|
||||||
it = &binding_body(*it);
|
|
||||||
}
|
|
||||||
return *it == get_tactic_type() || *it == get_tactic_expr_type() || *it == get_tactic_expr_list_type();
|
|
||||||
}
|
|
||||||
|
|
||||||
/** \brief Store the pair (pos(e), type(r)) in the info_data if m_info_manager is available. */
|
/** \brief Store the pair (pos(e), type(r)) in the info_data if m_info_manager is available. */
|
||||||
void elaborator::save_type_data(expr const & e, expr const & r) {
|
void elaborator::save_type_data(expr const & e, expr const & r) {
|
||||||
if (!m_no_info && infom() && pip() &&
|
if (!m_no_info && infom() && pip() &&
|
||||||
(is_constant(e) || is_local(e) || is_placeholder(e) || is_as_atomic(e) || is_consume_args(e))) {
|
(is_constant(e) || is_local(e) || is_placeholder(e) || is_as_atomic(e) || is_consume_args(e))) {
|
||||||
if (auto p = pip()->get_pos_info(e)) {
|
if (auto p = pip()->get_pos_info(e)) {
|
||||||
expr t = m_tc[m_relax_main_opaque]->infer(r).first;
|
expr t = m_tc[m_relax_main_opaque]->infer(r).first;
|
||||||
if (!is_tactic_type(t))
|
|
||||||
m_pre_info_data.add_type_info(p->first, p->second, t);
|
m_pre_info_data.add_type_info(p->first, p->second, t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -160,7 +151,6 @@ void elaborator::save_extra_type_data(expr const & e, expr const & r) {
|
||||||
if (!m_no_info && infom() && pip()) {
|
if (!m_no_info && infom() && pip()) {
|
||||||
if (auto p = pip()->get_pos_info(e)) {
|
if (auto p = pip()->get_pos_info(e)) {
|
||||||
expr t = m_tc[m_relax_main_opaque]->infer(r).first;
|
expr t = m_tc[m_relax_main_opaque]->infer(r).first;
|
||||||
if (!is_tactic_type(t))
|
|
||||||
m_pre_info_data.add_extra_type_info(p->first, p->second, r, t);
|
m_pre_info_data.add_extra_type_info(p->first, p->second, r, t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,6 +12,7 @@ Author: Leonardo de Moura
|
||||||
#include "library/choice.h"
|
#include "library/choice.h"
|
||||||
#include "library/scoped_ext.h"
|
#include "library/scoped_ext.h"
|
||||||
#include "library/tactic/proof_state.h"
|
#include "library/tactic/proof_state.h"
|
||||||
|
#include "library/tactic/expr_to_tactic.h"
|
||||||
#include "frontends/lean/info_manager.h"
|
#include "frontends/lean/info_manager.h"
|
||||||
#include "frontends/lean/pp_options.h"
|
#include "frontends/lean/pp_options.h"
|
||||||
|
|
||||||
|
@ -351,7 +352,17 @@ struct info_manager::imp {
|
||||||
m_env_info.insert(env_info(l, m_iteration, env, o));
|
m_env_info.insert(env_info(l, m_iteration, env, o));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool is_tactic_type(expr const & e) {
|
||||||
|
expr const * it = &e;
|
||||||
|
while (is_pi(*it)) {
|
||||||
|
it = &binding_body(*it);
|
||||||
|
}
|
||||||
|
return *it == get_tactic_type() || *it == get_tactic_expr_type() || *it == get_tactic_expr_list_type();
|
||||||
|
}
|
||||||
|
|
||||||
void add_type_info(unsigned l, unsigned c, expr const & e) {
|
void add_type_info(unsigned l, unsigned c, expr const & e) {
|
||||||
|
if (is_tactic_type(e))
|
||||||
|
return;
|
||||||
lock_guard<mutex> lc(m_mutex);
|
lock_guard<mutex> lc(m_mutex);
|
||||||
if (m_block_new_info)
|
if (m_block_new_info)
|
||||||
return;
|
return;
|
||||||
|
@ -360,6 +371,8 @@ struct info_manager::imp {
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_extra_type_info(unsigned l, unsigned c, expr const & e, expr const & t) {
|
void add_extra_type_info(unsigned l, unsigned c, expr const & e, expr const & t) {
|
||||||
|
if (is_tactic_type(t))
|
||||||
|
return;
|
||||||
lock_guard<mutex> lc(m_mutex);
|
lock_guard<mutex> lc(m_mutex);
|
||||||
if (m_block_new_info)
|
if (m_block_new_info)
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in a new issue