feat(frontends/lean): add '[fact]' modifier for 'have' expression
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
39177ec10a
commit
4560413a92
4 changed files with 30 additions and 4 deletions
|
@ -19,6 +19,7 @@ static name g_in("in");
|
|||
static name g_colon(":");
|
||||
static name g_assign(":=");
|
||||
static name g_comma(",");
|
||||
static name g_fact("[fact]");
|
||||
static name g_from("from");
|
||||
static name g_using("using");
|
||||
static name g_by("by");
|
||||
|
@ -143,9 +144,18 @@ static expr parse_proof(parser & p, expr const & prop) {
|
|||
}
|
||||
}
|
||||
|
||||
static void parse_have_modifiers(parser & p, bool & is_fact) {
|
||||
if (p.curr_is_token(g_fact)) {
|
||||
p.next();
|
||||
is_fact = true;
|
||||
}
|
||||
}
|
||||
|
||||
static expr parse_have(parser & p, unsigned, expr const *, pos_info const & pos) {
|
||||
auto id_pos = p.pos();
|
||||
bool is_fact = false;
|
||||
name id = p.check_id_next("invalid 'have' declaration, identifier expected");
|
||||
parse_have_modifiers(p, is_fact);
|
||||
expr prop;
|
||||
if (p.curr_is_token(g_colon)) {
|
||||
p.next();
|
||||
|
@ -158,7 +168,7 @@ static expr parse_have(parser & p, unsigned, expr const *, pos_info const & pos)
|
|||
p.check_token_next(g_comma, "invalid 'have' declaration, ',' expected");
|
||||
parser::local_scope scope(p);
|
||||
expr l = p.save_pos(mk_local(id, prop), pos);
|
||||
binder_info bi = mk_contextual_info(false);
|
||||
binder_info bi = mk_contextual_info(is_fact);
|
||||
p.add_local(l, bi);
|
||||
expr body = abstract(p.parse_expr(), l);
|
||||
// remark: mk_contextual_info(false) informs the elaborator that prop should not occur inside metavariables.
|
||||
|
|
|
@ -62,7 +62,7 @@ token_table init_token_table() {
|
|||
{"+", g_plus_prec}, {g_cup, g_cup_prec}, {"->", g_arrow_prec}, {nullptr, 0}};
|
||||
|
||||
char const * commands[] = {"theorem", "axiom", "variable", "definition", "{axiom}", "{variable}", "[variable]",
|
||||
"variables", "{variables}", "[variables]", "[private]", "[inline]", "abbreviation",
|
||||
"variables", "{variables}", "[variables]", "[private]", "[inline]", "[fact]", "abbreviation",
|
||||
"evaluate", "check", "print", "end", "namespace", "section", "import",
|
||||
"abbreviation", "inductive", "record", "structure", "module", "universe",
|
||||
"precedence", "infixl", "infixr", "infix", "postfix", "notation", "exit", "set_option",
|
||||
|
|
8
tests/lean/run/have1.lean
Normal file
8
tests/lean/run/have1.lean
Normal file
|
@ -0,0 +1,8 @@
|
|||
abbreviation Bool : Type.{1} := Type.{0}
|
||||
variables a b c : Bool
|
||||
axiom Ha : a
|
||||
axiom Hb : b
|
||||
axiom Hc : c
|
||||
check have H1 : a, from Ha,
|
||||
have H2 : a, using H1, from H1,
|
||||
H2
|
8
tests/lean/run/have2.lean
Normal file
8
tests/lean/run/have2.lean
Normal file
|
@ -0,0 +1,8 @@
|
|||
abbreviation Bool : Type.{1} := Type.{0}
|
||||
variables a b c : Bool
|
||||
axiom Ha : a
|
||||
axiom Hb : b
|
||||
axiom Hc : c
|
||||
check have H1 [fact] : a, from Ha,
|
||||
have H2 : a, from H1,
|
||||
H2
|
Loading…
Reference in a new issue