feat(library/blast/state): add mk_lambda/mk_pi for abstracting hrefs
This commit is contained in:
parent
973a5c4812
commit
a14bb86148
2 changed files with 47 additions and 0 deletions
|
@ -524,6 +524,36 @@ void state::restore_assignment(assignment_snapshot const & s) {
|
||||||
m_eassignment = s.m_eassignment;
|
m_eassignment = s.m_eassignment;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
expr state::mk_binding(bool is_lambda, unsigned num, expr const * hrefs, expr const & b) const {
|
||||||
|
expr r = abstract_locals(b, num, hrefs);
|
||||||
|
unsigned i = num;
|
||||||
|
while (i > 0) {
|
||||||
|
--i;
|
||||||
|
expr const & h = hrefs[i];
|
||||||
|
lean_assert(is_href(h));
|
||||||
|
hypothesis const * hdecl = get(h);
|
||||||
|
lean_assert(hdecl);
|
||||||
|
expr t = abstract_locals(hdecl->get_type(), i, hrefs);
|
||||||
|
if (is_lambda)
|
||||||
|
r = ::lean::mk_lambda(hdecl->get_name(), t, r);
|
||||||
|
else
|
||||||
|
r = ::lean::mk_pi(hdecl->get_name(), t, r);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
expr state::mk_lambda(list<expr> const & hrefs, expr const & b) const {
|
||||||
|
buffer<expr> tmp;
|
||||||
|
to_buffer(hrefs, tmp);
|
||||||
|
return mk_lambda(tmp, b);
|
||||||
|
}
|
||||||
|
|
||||||
|
expr state::mk_pi(list<expr> const & hrefs, expr const & b) const {
|
||||||
|
buffer<expr> tmp;
|
||||||
|
to_buffer(hrefs, tmp);
|
||||||
|
return mk_pi(tmp, b);
|
||||||
|
}
|
||||||
|
|
||||||
void initialize_state() {
|
void initialize_state() {
|
||||||
g_prefix = new name(name::mk_internal_unique_name());
|
g_prefix = new name(name::mk_internal_unique_name());
|
||||||
}
|
}
|
||||||
|
|
|
@ -133,6 +133,8 @@ class state {
|
||||||
unsigned add_metavar_decl(metavar_decl const & decl);
|
unsigned add_metavar_decl(metavar_decl const & decl);
|
||||||
goal to_goal(branch const &) const;
|
goal to_goal(branch const &) const;
|
||||||
|
|
||||||
|
expr mk_binding(bool is_lambda, unsigned num, expr const * hrefs, expr const & b) const;
|
||||||
|
|
||||||
#ifdef LEAN_DEBUG
|
#ifdef LEAN_DEBUG
|
||||||
bool check_hypothesis(expr const & e, unsigned hidx, hypothesis const & h) const;
|
bool check_hypothesis(expr const & e, unsigned hidx, hypothesis const & h) const;
|
||||||
bool check_hypothesis(unsigned hidx, hypothesis const & h) const;
|
bool check_hypothesis(unsigned hidx, hypothesis const & h) const;
|
||||||
|
@ -280,6 +282,21 @@ public:
|
||||||
|
|
||||||
unsigned get_depth() const { return m_depth; }
|
unsigned get_depth() const { return m_depth; }
|
||||||
|
|
||||||
|
expr mk_lambda(unsigned num, expr const * hrefs, expr const & b) const {
|
||||||
|
return mk_binding(false, num, hrefs, b);
|
||||||
|
}
|
||||||
|
expr mk_pi(unsigned num, expr const * hrefs, expr const & b) const {
|
||||||
|
return mk_binding(false, num, hrefs, b);
|
||||||
|
}
|
||||||
|
expr mk_lambda(buffer<expr> const & hrefs, expr const & b) const {
|
||||||
|
return mk_lambda(hrefs.size(), hrefs.data(), b);
|
||||||
|
}
|
||||||
|
expr mk_pi(buffer<expr> const & hrefs, expr const & b) const {
|
||||||
|
return mk_pi(hrefs.size(), hrefs.data(), b);
|
||||||
|
}
|
||||||
|
expr mk_lambda(list<expr> const & hrefs, expr const & b) const;
|
||||||
|
expr mk_pi(list<expr> const & hrefs, expr const & b) const;
|
||||||
|
|
||||||
#ifdef LEAN_DEBUG
|
#ifdef LEAN_DEBUG
|
||||||
bool check_invariant() const;
|
bool check_invariant() const;
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue