feat(library/definitional/no_confusion): add [unfold] hint to no_confusion
This commit is contained in:
parent
26574e29a9
commit
6ffbb05118
2 changed files with 6 additions and 0 deletions
|
@ -15,6 +15,7 @@ Author: Leonardo de Moura
|
||||||
#include "library/util.h"
|
#include "library/util.h"
|
||||||
#include "library/reducible.h"
|
#include "library/reducible.h"
|
||||||
#include "library/constants.h"
|
#include "library/constants.h"
|
||||||
|
#include "library/normalize.h"
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
static void throw_corrupted(name const & n) {
|
static void throw_corrupted(name const & n) {
|
||||||
|
@ -201,6 +202,7 @@ environment mk_no_confusion(environment const & env, name const & n) {
|
||||||
no_confusion_type_args.push_back(P);
|
no_confusion_type_args.push_back(P);
|
||||||
no_confusion_type_args.push_back(v1);
|
no_confusion_type_args.push_back(v1);
|
||||||
no_confusion_type_args.push_back(v1);
|
no_confusion_type_args.push_back(v1);
|
||||||
|
unsigned unfold_hint_idx = no_confusion_type_args.size();
|
||||||
expr no_confusion_type_app = mk_app(mk_constant(no_confusion_type_decl.get_name(), ls), no_confusion_type_args);
|
expr no_confusion_type_app = mk_app(mk_constant(no_confusion_type_decl.get_name(), ls), no_confusion_type_args);
|
||||||
expr type_former = Fun(type_former_args, no_confusion_type_app);
|
expr type_former = Fun(type_former_args, no_confusion_type_app);
|
||||||
// create cases_on
|
// create cases_on
|
||||||
|
@ -273,6 +275,7 @@ environment mk_no_confusion(environment const & env, name const & n) {
|
||||||
use_conv_opt);
|
use_conv_opt);
|
||||||
new_env = module::add(new_env, check(new_env, new_d));
|
new_env = module::add(new_env, check(new_env, new_d));
|
||||||
new_env = set_reducible(new_env, no_confusion_name, reducible_status::Reducible);
|
new_env = set_reducible(new_env, no_confusion_name, reducible_status::Reducible);
|
||||||
|
new_env = add_unfold_hint(new_env, no_confusion_name, unfold_hint_idx);
|
||||||
return add_protected(new_env, no_confusion_name);
|
return add_protected(new_env, no_confusion_name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,6 +41,9 @@ expr normalize(type_checker & tc, expr const & e, std::function<bool(expr const&
|
||||||
Of course, kernel opaque constants are not unfolded.
|
Of course, kernel opaque constants are not unfolded.
|
||||||
*/
|
*/
|
||||||
environment add_unfold_hint(environment const & env, name const & n, list<unsigned> const & idxs, bool persistent = true);
|
environment add_unfold_hint(environment const & env, name const & n, list<unsigned> const & idxs, bool persistent = true);
|
||||||
|
inline environment add_unfold_hint(environment const & env, name const & n, unsigned idx, bool persistent = true) {
|
||||||
|
return add_unfold_hint(env, n, to_list(idx), persistent);
|
||||||
|
}
|
||||||
environment erase_unfold_hint(environment const & env, name const & n, bool persistent = true);
|
environment erase_unfold_hint(environment const & env, name const & n, bool persistent = true);
|
||||||
/** \brief Retrieve the hint added with the procedure add_unfold_hint. */
|
/** \brief Retrieve the hint added with the procedure add_unfold_hint. */
|
||||||
list<unsigned> has_unfold_hint(environment const & env, name const & d);
|
list<unsigned> has_unfold_hint(environment const & env, name const & d);
|
||||||
|
|
Loading…
Reference in a new issue