feat(kernel/context): add method for remove context entries at positions [s, s+n).

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-10-22 15:52:24 -07:00
parent 3fa4eac4ef
commit 891d22b3de
2 changed files with 22 additions and 0 deletions

View file

@ -30,4 +30,20 @@ context_entry const & context::lookup(unsigned i) const {
} }
throw exception("unknown free variable"); throw exception("unknown free variable");
} }
static list<context_entry> remove_core(list<context_entry> const & l, unsigned s, unsigned n) {
if (s == 0) {
if (n > 0) {
return remove_core(tail(l), 0, n-1);
} else {
return l;
}
} else {
return cons(head(l), remove_core(tail(l), s-1, n));
}
}
context context::remove(unsigned s, unsigned n) const {
return context(remove_core(m_list, s, n));
}
} }

View file

@ -45,6 +45,12 @@ public:
iterator begin() const { return m_list.begin(); } iterator begin() const { return m_list.begin(); }
iterator end() const { return m_list.end(); } iterator end() const { return m_list.end(); }
friend bool is_eqp(context const & c1, context const & c2) { return is_eqp(c1.m_list, c2.m_list); } friend bool is_eqp(context const & c1, context const & c2) { return is_eqp(c1.m_list, c2.m_list); }
/**
\brief Return a new context where the entries at positions [s, s+n) were removed.
\pre size() >= s + n
*/
context remove(unsigned s, unsigned n) const;
}; };
/** /**