Add check_interrupted 'macro'

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-08-25 11:00:48 -07:00
parent ece6e6ca6a
commit 25e47a8a2f
5 changed files with 16 additions and 8 deletions

View file

@ -704,8 +704,7 @@ class pp_fn {
} }
result pp(expr const & e, unsigned depth, bool main = false) { result pp(expr const & e, unsigned depth, bool main = false) {
if (m_interrupted) check_interrupted(m_interrupted);
throw interrupted();
if (!is_atomic(e) && (m_num_steps > m_max_steps || depth > m_max_depth)) { if (!is_atomic(e) && (m_num_steps > m_max_steps || depth > m_max_depth)) {
return pp_ellipsis(); return pp_ellipsis();
} else { } else {
@ -817,6 +816,7 @@ public:
class pp_formatter_cell : public formatter_cell { class pp_formatter_cell : public formatter_cell {
frontend const & m_frontend; frontend const & m_frontend;
interruptable_ptr<pp_fn> m_pp_fn; interruptable_ptr<pp_fn> m_pp_fn;
volatile bool m_interrupted;
format pp(expr const & e, options const & opts) { format pp(expr const & e, options const & opts) {
pp_fn fn(m_frontend, opts); pp_fn fn(m_frontend, opts);
@ -830,6 +830,7 @@ class pp_formatter_cell : public formatter_cell {
bool first = true; bool first = true;
expr c2 = context_to_lambda(c, e); expr c2 = context_to_lambda(c, e);
while (is_fake_context(c2)) { while (is_fake_context(c2)) {
check_interrupted(m_interrupted);
name n1 = get_unused_name(c2); name n1 = get_unused_name(c2);
format entry = format{format(n1), space(), colon(), space(), pp(fake_context_domain(c2), opts)}; format entry = format{format(n1), space(), colon(), space(), pp(fake_context_domain(c2), opts)};
expr val = fake_context_value(c2); expr val = fake_context_value(c2);
@ -865,6 +866,7 @@ class pp_formatter_cell : public formatter_cell {
expr it1 = t; expr it1 = t;
expr it2 = v; expr it2 = v;
while (is_pi(it1) && is_lambda(it2)) { while (is_pi(it1) && is_lambda(it2)) {
check_interrupted(m_interrupted);
if (abst_domain(it1) != abst_domain(it2)) if (abst_domain(it1) != abst_domain(it2))
return pp_definition(kwd, n, t, v, opts); return pp_definition(kwd, n, t, v, opts);
it1 = abst_body(it1); it1 = abst_body(it1);
@ -901,6 +903,7 @@ class pp_formatter_cell : public formatter_cell {
public: public:
pp_formatter_cell(frontend const & fe): pp_formatter_cell(frontend const & fe):
m_frontend(fe) { m_frontend(fe) {
m_interrupted = false;
} }
virtual ~pp_formatter_cell() { virtual ~pp_formatter_cell() {
@ -920,6 +923,7 @@ public:
} else { } else {
expr c2 = context_to_lambda(c, e); expr c2 = context_to_lambda(c, e);
while (is_fake_context(c2)) { while (is_fake_context(c2)) {
check_interrupted(m_interrupted);
expr const & rest = fake_context_rest(c2); expr const & rest = fake_context_rest(c2);
name n1 = get_unused_name(rest); name n1 = get_unused_name(rest);
c2 = instantiate_with_closed(rest, mk_constant(n1)); c2 = instantiate_with_closed(rest, mk_constant(n1));
@ -952,6 +956,7 @@ public:
std::for_each(env.begin_objects(), std::for_each(env.begin_objects(),
env.end_objects(), env.end_objects(),
[&](object const & obj) { [&](object const & obj) {
check_interrupted(m_interrupted);
if (first) first = false; else r += line(); if (first) first = false; else r += line();
r += operator()(obj, opts); r += operator()(obj, opts);
}); });
@ -960,6 +965,7 @@ public:
virtual void set_interrupt(bool flag) { virtual void set_interrupt(bool flag) {
m_pp_fn.set_interrupt(flag); m_pp_fn.set_interrupt(flag);
m_interrupted = flag;
} }
}; };

View file

@ -128,8 +128,7 @@ class normalizer::imp {
/** \brief Normalize the expression \c a in a context composed of stack \c s and \c k binders. */ /** \brief Normalize the expression \c a in a context composed of stack \c s and \c k binders. */
svalue normalize(expr const & a, value_stack const & s, unsigned k) { svalue normalize(expr const & a, value_stack const & s, unsigned k) {
flet<unsigned> l(m_depth, m_depth+1); flet<unsigned> l(m_depth, m_depth+1);
if (m_interrupted) check_interrupted(m_interrupted);
throw interrupted();
if (m_depth > m_max_depth) if (m_depth > m_max_depth)
throw kernel_exception(m_env, "normalizer maximum recursion depth exceeded"); throw kernel_exception(m_env, "normalizer maximum recursion depth exceeded");
bool shared = false; bool shared = false;

View file

@ -61,8 +61,7 @@ public:
} }
expr infer_type(expr const & e, context const & ctx) { expr infer_type(expr const & e, context const & ctx) {
if (m_interrupted) check_interrupted(m_interrupted);
throw interrupted();
bool shared = false; bool shared = false;
if (is_shared(e)) { if (is_shared(e)) {
shared = true; shared = true;

View file

@ -391,8 +391,7 @@ bool metavar_env::is_simple_ho_match(expr const & e1, expr const & e2, context c
\c e2 when none of them are metavariables. \c e2 when none of them are metavariables.
*/ */
void metavar_env::unify_core(expr const & e1, expr const & e2, context const & ctx) { void metavar_env::unify_core(expr const & e1, expr const & e2, context const & ctx) {
if (m_interrupted) check_interrupted(m_interrupted);
throw interrupted();
lean_assert(!is_metavar(e1)); lean_assert(!is_metavar(e1));
lean_assert(!is_metavar(e2)); lean_assert(!is_metavar(e2));
if (e1 == e2) { if (e1 == e2) {

View file

@ -45,4 +45,9 @@ public:
virtual ~interrupted() noexcept {} virtual ~interrupted() noexcept {}
virtual char const * what() const noexcept { return "interrupted"; } virtual char const * what() const noexcept { return "interrupted"; }
}; };
/** \brief Throw interrupted exception iff flag is true. */
inline void check_interrupted(bool flag) {
if (flag)
throw interrupted();
}
} }