fix(frontends/lean/info_manager): suppress useless tactic type information, closes #277

This commit is contained in:
Leonardo de Moura 2014-10-29 15:49:15 -07:00
parent 88d55bfef0
commit 1c9992800f
2 changed files with 15 additions and 12 deletions

View file

@ -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);
} }
} }

View file

@ -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;