refactor(splay_map): modify splay_find signature
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
5812dfcf44
commit
5e34f410b3
2 changed files with 16 additions and 24 deletions
|
@ -65,14 +65,13 @@ expr apply_local_context(expr const & a, local_context const & lctx) {
|
||||||
|
|
||||||
expr substitution::get_subst(expr const & m) const {
|
expr substitution::get_subst(expr const & m) const {
|
||||||
lean_assert(is_metavar(m));
|
lean_assert(is_metavar(m));
|
||||||
name2expr::entry const * e = const_cast<substitution*>(this)->m_subst.splay_find(metavar_name(m));
|
auto it = const_cast<substitution*>(this)->m_subst.splay_find(metavar_name(m));
|
||||||
if (e) {
|
if (it) {
|
||||||
expr r = e->second;
|
if (has_assigned_metavar(*it, *this)) {
|
||||||
if (has_assigned_metavar(r, *this)) {
|
*it = instantiate_metavars(*it, *this);
|
||||||
r = instantiate_metavars(r, *this);
|
|
||||||
const_cast<substitution*>(this)->m_subst.insert(metavar_name(m), r);
|
|
||||||
}
|
}
|
||||||
local_context const & lctx = metavar_lctx(m);
|
local_context const & lctx = metavar_lctx(m);
|
||||||
|
expr r = *it;
|
||||||
if (lctx) {
|
if (lctx) {
|
||||||
r = apply_local_context(r, lctx);
|
r = apply_local_context(r, lctx);
|
||||||
if (has_assigned_metavar(r, *this))
|
if (has_assigned_metavar(r, *this))
|
||||||
|
@ -130,11 +129,8 @@ context metavar_env::get_context(expr const & m) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
context metavar_env::get_context(name const & m) const {
|
context metavar_env::get_context(name const & m) const {
|
||||||
auto e = const_cast<metavar_env*>(this)->m_metavar_contexts.splay_find(m);
|
auto it = const_cast<metavar_env*>(this)->m_metavar_contexts.splay_find(m);
|
||||||
if (e)
|
return it ? *it : context();
|
||||||
return e->second;
|
|
||||||
else
|
|
||||||
return context();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
expr metavar_env::get_type(expr const & m) {
|
expr metavar_env::get_type(expr const & m) {
|
||||||
|
@ -152,19 +148,19 @@ expr metavar_env::get_type(expr const & m) {
|
||||||
}
|
}
|
||||||
|
|
||||||
expr metavar_env::get_type(name const & m) {
|
expr metavar_env::get_type(name const & m) {
|
||||||
auto e = const_cast<metavar_env*>(this)->m_metavar_types.splay_find(m);
|
auto it = const_cast<metavar_env*>(this)->m_metavar_types.splay_find(m);
|
||||||
if (e) {
|
if (it) {
|
||||||
return e->second;
|
return *it;
|
||||||
} else {
|
} else {
|
||||||
expr t = mk_metavar(get_context(m));
|
expr t = mk_metavar(get_context(m));
|
||||||
m_metavar_types.insert(m, t);
|
const_cast<metavar_env*>(this)->m_metavar_types.insert(m, t);
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool metavar_env::has_type(name const & m) const {
|
bool metavar_env::has_type(name const & m) const {
|
||||||
auto e = const_cast<metavar_env*>(this)->m_metavar_types.splay_find(m);
|
auto it = const_cast<metavar_env*>(this)->m_metavar_types.splay_find(m);
|
||||||
return e;
|
return it;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool metavar_env::has_type(expr const & m) const {
|
bool metavar_env::has_type(expr const & m) const {
|
||||||
|
@ -179,12 +175,8 @@ justification metavar_env::get_justification(expr const & m) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
justification metavar_env::get_justification(name const & m) const {
|
justification metavar_env::get_justification(name const & m) const {
|
||||||
auto e = const_cast<metavar_env*>(this)->m_metavar_justifications.splay_find(m);
|
auto it = const_cast<metavar_env*>(this)->m_metavar_justifications.splay_find(m);
|
||||||
if (e) {
|
return it ? *it : justification();
|
||||||
return e->second;
|
|
||||||
} else {
|
|
||||||
return justification();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool metavar_env::is_assigned(name const & m) const {
|
bool metavar_env::is_assigned(name const & m) const {
|
||||||
|
|
|
@ -38,7 +38,7 @@ public:
|
||||||
void insert(K const & k, T const & v) { m_map.insert(mk_pair(k, v)); }
|
void insert(K const & k, T const & v) { m_map.insert(mk_pair(k, v)); }
|
||||||
entry const * find(K const & k) const { return m_map.find(mk_pair(k, T())); }
|
entry const * find(K const & k) const { return m_map.find(mk_pair(k, T())); }
|
||||||
bool contains(K const & k) const { return m_map.contains(mk_pair(k, T())); }
|
bool contains(K const & k) const { return m_map.contains(mk_pair(k, T())); }
|
||||||
entry const * splay_find(K const & k) { return m_map.splay_find(mk_pair(k, T())); }
|
T * splay_find(K const & k) { auto e = m_map.splay_find(mk_pair(k, T())); return e ? &(const_cast<T&>(e->second)) : nullptr; }
|
||||||
void erase(K const & k) { m_map.erase(mk_pair(k, T())); }
|
void erase(K const & k) { m_map.erase(mk_pair(k, T())); }
|
||||||
|
|
||||||
class ref {
|
class ref {
|
||||||
|
|
Loading…
Reference in a new issue