fix(frontends/lean): fail if theorem type has metavariables after type elaboration (and before proof elaboration)

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-08-26 09:01:17 -07:00
parent 02b7f980b0
commit 44c597724b
4 changed files with 5 additions and 2 deletions

View file

@ -281,7 +281,7 @@ idempotent_image_fix (representative_map_idempotent H1 H2) b
theorem representative_map_to_quotient {A : Type} {R : A → A → Prop} {f : A → A} theorem representative_map_to_quotient {A : Type} {R : A → A → Prop} {f : A → A}
(H1 : ∀a, R a (f a)) (H2 : ∀a a', R a a' ↔ R a a ∧ R a' a' ∧ f a = f a') : (H1 : ∀a, R a (f a)) (H2 : ∀a a', R a a' ↔ R a a ∧ R a' a' ∧ f a = f a') :
is_quotient _ (fun_image f) elt_of := is_quotient R (fun_image f) elt_of :=
let abs := fun_image f in let abs := fun_image f in
intro intro
(take u : image f, (take u : image f,

View file

@ -312,6 +312,7 @@ environment definition_cmd_core(parser & p, bool is_theorem, bool _is_opaque) {
if (is_theorem) { if (is_theorem) {
auto type_pos = p.pos_of(type); auto type_pos = p.pos_of(type);
std::tie(type, new_ls) = p.elaborate_type(type); std::tie(type, new_ls) = p.elaborate_type(type);
check_no_metavar(env, real_n, type, true);
ls = append(ls, new_ls); ls = append(ls, new_ls);
expr type_as_is = p.save_pos(mk_as_is(type), type_pos); expr type_as_is = p.save_pos(mk_as_is(type), type_pos);
if (!p.collecting_info() && p.num_threads() > 1) { if (!p.collecting_info() && p.num_threads() > 1) {

View file

@ -421,7 +421,7 @@ type_checker::type_checker(environment const & env):
type_checker::~type_checker() {} type_checker::~type_checker() {}
static void check_no_metavar(environment const & env, name const & n, expr const & e, bool is_type) { void check_no_metavar(environment const & env, name const & n, expr const & e, bool is_type) {
if (has_metavar(e)) if (has_metavar(e))
throw_kernel_exception(env, e, [=](formatter const & fmt) { return pp_decl_has_metavars(fmt, n, e, is_type); }); throw_kernel_exception(env, e, [=](formatter const & fmt) { return pp_decl_has_metavars(fmt, n, e, is_type); });
} }

View file

@ -204,6 +204,8 @@ public:
typedef std::shared_ptr<type_checker> type_checker_ref; typedef std::shared_ptr<type_checker> type_checker_ref;
void check_no_metavar(environment const & env, name const & n, expr const & e, bool is_type);
/** /**
\brief Type check the given declaration, and return a certified declaration if it is type correct. \brief Type check the given declaration, and return a certified declaration if it is type correct.
Throw an exception if the declaration is type incorrect. Throw an exception if the declaration is type incorrect.