feat(frontends/lean/builtin_exprs): allow 'obtain' to be used in tactic mode

This commit is contained in:
Leonardo de Moura 2015-05-19 16:26:02 -07:00
parent c133d26505
commit 8ce992b077
5 changed files with 14 additions and 1 deletions

View file

@ -230,7 +230,8 @@ static expr parse_begin_end_core(parser & p, pos_info const & pos, name const &
} }
} else if (p.curr_is_token(get_match_tk()) || p.curr_is_token(get_assume_tk()) || } else if (p.curr_is_token(get_match_tk()) || p.curr_is_token(get_assume_tk()) ||
p.curr_is_token(get_take_tk()) || p.curr_is_token(get_fun_tk()) || p.curr_is_token(get_take_tk()) || p.curr_is_token(get_fun_tk()) ||
p.curr_is_token(get_calc_tk()) || p.curr_is_token(get_show_tk())) { p.curr_is_token(get_calc_tk()) || p.curr_is_token(get_show_tk()) ||
p.curr_is_token(get_obtain_tk())) {
auto pos = p.pos(); auto pos = p.pos();
expr t = p.parse_tactic_expr_arg(); expr t = p.parse_tactic_expr_arg();
t = p.mk_app(get_exact_tac_fn(), t, pos); t = p.mk_app(get_exact_tac_fn(), t, pos);

View file

@ -130,6 +130,7 @@ static name const * g_prefix_tk = nullptr;
static name const * g_notation_tk = nullptr; static name const * g_notation_tk = nullptr;
static name const * g_call_tk = nullptr; static name const * g_call_tk = nullptr;
static name const * g_calc_tk = nullptr; static name const * g_calc_tk = nullptr;
static name const * g_obtain_tk = nullptr;
static name const * g_persistent_tk = nullptr; static name const * g_persistent_tk = nullptr;
static name const * g_root_tk = nullptr; static name const * g_root_tk = nullptr;
static name const * g_fields_tk = nullptr; static name const * g_fields_tk = nullptr;
@ -264,6 +265,7 @@ void initialize_tokens() {
g_notation_tk = new name{"notation"}; g_notation_tk = new name{"notation"};
g_call_tk = new name{"call"}; g_call_tk = new name{"call"};
g_calc_tk = new name{"calc"}; g_calc_tk = new name{"calc"};
g_obtain_tk = new name{"obtain"};
g_persistent_tk = new name{"[persistent]"}; g_persistent_tk = new name{"[persistent]"};
g_root_tk = new name{"_root_"}; g_root_tk = new name{"_root_"};
g_fields_tk = new name{"fields"}; g_fields_tk = new name{"fields"};
@ -399,6 +401,7 @@ void finalize_tokens() {
delete g_notation_tk; delete g_notation_tk;
delete g_call_tk; delete g_call_tk;
delete g_calc_tk; delete g_calc_tk;
delete g_obtain_tk;
delete g_persistent_tk; delete g_persistent_tk;
delete g_root_tk; delete g_root_tk;
delete g_fields_tk; delete g_fields_tk;
@ -533,6 +536,7 @@ name const & get_prefix_tk() { return *g_prefix_tk; }
name const & get_notation_tk() { return *g_notation_tk; } name const & get_notation_tk() { return *g_notation_tk; }
name const & get_call_tk() { return *g_call_tk; } name const & get_call_tk() { return *g_call_tk; }
name const & get_calc_tk() { return *g_calc_tk; } name const & get_calc_tk() { return *g_calc_tk; }
name const & get_obtain_tk() { return *g_obtain_tk; }
name const & get_persistent_tk() { return *g_persistent_tk; } name const & get_persistent_tk() { return *g_persistent_tk; }
name const & get_root_tk() { return *g_root_tk; } name const & get_root_tk() { return *g_root_tk; }
name const & get_fields_tk() { return *g_fields_tk; } name const & get_fields_tk() { return *g_fields_tk; }

View file

@ -132,6 +132,7 @@ name const & get_prefix_tk();
name const & get_notation_tk(); name const & get_notation_tk();
name const & get_call_tk(); name const & get_call_tk();
name const & get_calc_tk(); name const & get_calc_tk();
name const & get_obtain_tk();
name const & get_persistent_tk(); name const & get_persistent_tk();
name const & get_root_tk(); name const & get_root_tk();
name const & get_fields_tk(); name const & get_fields_tk();

View file

@ -125,6 +125,7 @@ prefix prefix
notation notation notation notation
call call call call
calc calc calc calc
obtain obtain
persistent [persistent] persistent [persistent]
root _root_ root _root_
fields fields fields fields

View file

@ -0,0 +1,6 @@
example (a b : Prop) : a ∧ b → b ∧ a :=
begin
intro Hab,
obtain Ha Hb, from Hab,
show b ∧ a, from and.intro Hb Ha
end