fix(kernel/type_checker): memory access violation, closures (for printing error messages) had a uninteded reference to the type_checker
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
39e101d323
commit
2daad71d47
1 changed files with 18 additions and 10 deletions
|
@ -172,8 +172,11 @@ struct type_checker::imp {
|
||||||
add_cnstr(mk_eq_cnstr(e, r, j));
|
add_cnstr(mk_eq_cnstr(e, r, j));
|
||||||
return r;
|
return r;
|
||||||
} else {
|
} else {
|
||||||
throw_kernel_exception(m_env, s,
|
// We don't want m_env (i.e., this->m_env) inside the following closure,
|
||||||
[=](formatter const & fmt, options const & o) { return pp_type_expected(fmt, m_env, o, s); });
|
// because the type checker may be gone, when the closure is executed.
|
||||||
|
environment env = m_env;
|
||||||
|
throw_kernel_exception(env, s,
|
||||||
|
[=](formatter const & fmt, options const & o) { return pp_type_expected(fmt, env, o, s); });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -186,9 +189,11 @@ struct type_checker::imp {
|
||||||
return e;
|
return e;
|
||||||
} else if (is_meta(e)) {
|
} else if (is_meta(e)) {
|
||||||
buffer<expr> telescope;
|
buffer<expr> telescope;
|
||||||
if (!meta_to_telescope(e, telescope))
|
if (!meta_to_telescope(e, telescope)) {
|
||||||
throw_kernel_exception(m_env, s,
|
environment env = m_env;
|
||||||
[=](formatter const & fmt, options const & o) { return pp_function_expected(fmt, m_env, o, s); });
|
throw_kernel_exception(env, s,
|
||||||
|
[=](formatter const & fmt, options const & o) { return pp_function_expected(fmt, env, o, s); });
|
||||||
|
}
|
||||||
expr ta = mk_sort(mk_meta_univ(m_gen.next()));
|
expr ta = mk_sort(mk_meta_univ(m_gen.next()));
|
||||||
expr A = mk_metavar(m_gen.next(), mk_pi(telescope, ta));
|
expr A = mk_metavar(m_gen.next(), mk_pi(telescope, ta));
|
||||||
expr A_xs = mk_app_vars(A, telescope.size());
|
expr A_xs = mk_app_vars(A, telescope.size());
|
||||||
|
@ -208,8 +213,9 @@ struct type_checker::imp {
|
||||||
add_cnstr(mk_eq_cnstr(e, r, j));
|
add_cnstr(mk_eq_cnstr(e, r, j));
|
||||||
return r;
|
return r;
|
||||||
} else {
|
} else {
|
||||||
throw_kernel_exception(m_env, s,
|
environment env = m_env;
|
||||||
[=](formatter const & fmt, options const & o) { return pp_function_expected(fmt, m_env, o, s); });
|
throw_kernel_exception(env, s,
|
||||||
|
[=](formatter const & fmt, options const & o) { return pp_function_expected(fmt, env, o, s); });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -355,9 +361,10 @@ struct type_checker::imp {
|
||||||
expr a_type = infer_type_core(app_arg(e), infer_only);
|
expr a_type = infer_type_core(app_arg(e), infer_only);
|
||||||
delayed_justification jst([=]() { return mk_app_mismatch_jst(e, f_type, a_type); });
|
delayed_justification jst([=]() { return mk_app_mismatch_jst(e, f_type, a_type); });
|
||||||
if (!is_def_eq(a_type, binding_domain(f_type), jst)) {
|
if (!is_def_eq(a_type, binding_domain(f_type), jst)) {
|
||||||
|
environment env = m_env;
|
||||||
throw_kernel_exception(m_env, e,
|
throw_kernel_exception(m_env, e,
|
||||||
[=](formatter const & fmt, options const & o) {
|
[=](formatter const & fmt, options const & o) {
|
||||||
return pp_app_type_mismatch(fmt, m_env, o, e, binding_domain(f_type), a_type);
|
return pp_app_type_mismatch(fmt, env, o, e, binding_domain(f_type), a_type);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -370,9 +377,10 @@ struct type_checker::imp {
|
||||||
expr val_type = infer_type_core(let_value(e), infer_only);
|
expr val_type = infer_type_core(let_value(e), infer_only);
|
||||||
delayed_justification jst([=]() { return mk_let_mismatch_jst(e, val_type); });
|
delayed_justification jst([=]() { return mk_let_mismatch_jst(e, val_type); });
|
||||||
if (!is_def_eq(val_type, let_type(e), jst)) {
|
if (!is_def_eq(val_type, let_type(e), jst)) {
|
||||||
throw_kernel_exception(m_env, e,
|
environment env = m_env;
|
||||||
|
throw_kernel_exception(env, e,
|
||||||
[=](formatter const & fmt, options const & o) {
|
[=](formatter const & fmt, options const & o) {
|
||||||
return pp_def_type_mismatch(fmt, m_env, o, let_name(e), let_type(e), val_type);
|
return pp_def_type_mismatch(fmt, env, o, let_name(e), let_type(e), val_type);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue