feat(frontends/lean/inductive_cmd): improve notation for declaring 'empty' inductive datatypes
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
a5b9a7b296
commit
a450ad5a95
3 changed files with 15 additions and 9 deletions
|
@ -152,8 +152,7 @@ notation `Ω` `(` A `,` a `)` := loop_space A a
|
||||||
definition loop2d_space (A : Type) (a : A) := (refl a) = (refl a)
|
definition loop2d_space (A : Type) (a : A) := (refl a) = (refl a)
|
||||||
notation `Ω²` `(` A `,` a `)` := loop2d_space A a
|
notation `Ω²` `(` A `,` a `)` := loop2d_space A a
|
||||||
|
|
||||||
inductive empty : Type :=
|
inductive empty : Type
|
||||||
-- empty
|
|
||||||
|
|
||||||
theorem empty_elim (c : Type) (H : empty) : c
|
theorem empty_elim (c : Type) (H : empty) : c
|
||||||
:= empty_rec (λ e, c) H
|
:= empty_rec (λ e, c) H
|
||||||
|
|
|
@ -3,8 +3,7 @@
|
||||||
-- Authors: Leonardo de Moura, Jeremy Avigad
|
-- Authors: Leonardo de Moura, Jeremy Avigad
|
||||||
definition Prop [inline] := Type.{0}
|
definition Prop [inline] := Type.{0}
|
||||||
|
|
||||||
inductive false : Prop :=
|
inductive false : Prop
|
||||||
-- No constructors
|
|
||||||
|
|
||||||
theorem false_elim (c : Prop) (H : false) : c
|
theorem false_elim (c : Prop) (H : false) : c
|
||||||
:= false_rec c H
|
:= false_rec c H
|
||||||
|
|
|
@ -279,17 +279,25 @@ struct inductive_cmd_fn {
|
||||||
name d_name = parse_decl_name();
|
name d_name = parse_decl_name();
|
||||||
parse_inductive_univ_params();
|
parse_inductive_univ_params();
|
||||||
expr d_type = parse_datatype_type();
|
expr d_type = parse_datatype_type();
|
||||||
m_p.check_token_next(g_assign, "invalid inductive declaration, ':=' expected");
|
bool empty_type = true;
|
||||||
|
if (m_p.curr_is_token(g_assign)) {
|
||||||
|
empty_type = false;
|
||||||
|
m_p.next();
|
||||||
|
}
|
||||||
level_param_names d_lvls;
|
level_param_names d_lvls;
|
||||||
std::tie(d_type, d_lvls) = elaborate_inductive_type(d_type);
|
std::tie(d_type, d_lvls) = elaborate_inductive_type(d_type);
|
||||||
if (!m_first) {
|
if (!m_first) {
|
||||||
check_params(d_type, *first_d_type);
|
check_params(d_type, *first_d_type);
|
||||||
check_levels(d_lvls, *first_d_lvls);
|
check_levels(d_lvls, *first_d_lvls);
|
||||||
}
|
}
|
||||||
|
if (empty_type) {
|
||||||
|
decls.push_back(inductive_decl(d_name, d_type, list<intro_rule>()));
|
||||||
|
} else {
|
||||||
buffer<expr> params;
|
buffer<expr> params;
|
||||||
add_params_to_local_scope(d_type, params);
|
add_params_to_local_scope(d_type, params);
|
||||||
auto d_intro_rules = parse_intro_rules(params);
|
auto d_intro_rules = parse_intro_rules(params);
|
||||||
decls.push_back(inductive_decl(d_name, d_type, d_intro_rules));
|
decls.push_back(inductive_decl(d_name, d_type, d_intro_rules));
|
||||||
|
}
|
||||||
if (!m_p.curr_is_token(g_with)) {
|
if (!m_p.curr_is_token(g_with)) {
|
||||||
m_levels.append(m_explict_levels);
|
m_levels.append(m_explict_levels);
|
||||||
for (auto l : d_lvls) m_levels.push_back(l);
|
for (auto l : d_lvls) m_levels.push_back(l);
|
||||||
|
|
Loading…
Reference in a new issue