Add check_interrupted 'macro'
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
ece6e6ca6a
commit
25e47a8a2f
5 changed files with 16 additions and 8 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue