refactor(splay_map): modify splay_find signature

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-10-25 10:47:15 -07:00
parent 5812dfcf44
commit 5e34f410b3
2 changed files with 16 additions and 24 deletions

View file

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

View file

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