feat(library/tactic/apply_tactic): allow apply_tac Lua binding to take expressions as argument
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
6cc57cc4b5
commit
75cf751959
3 changed files with 9 additions and 5 deletions
|
@ -1391,8 +1391,7 @@ class parser::imp {
|
||||||
next();
|
next();
|
||||||
expr pr = parse_expr();
|
expr pr = parse_expr();
|
||||||
check_rparen_next("invalid apply command, ')' expected");
|
check_rparen_next("invalid apply command, ')' expected");
|
||||||
expr pr_type = m_env->infer_type(pr);
|
return ::lean::apply_tactic(pr);
|
||||||
return ::lean::apply_tactic(pr, pr_type);
|
|
||||||
} else {
|
} else {
|
||||||
name n = check_identifier_next("invalid apply command, identifier, '(' expr ')', or 'script-block' expected");
|
name n = check_identifier_next("invalid apply command, identifier, '(' expr ')', or 'script-block' expected");
|
||||||
optional<object> o = m_env->find_object(n);
|
optional<object> o = m_env->find_object(n);
|
||||||
|
|
|
@ -143,8 +143,9 @@ static optional<proof_state> apply_tactic(ro_environment const & env, proof_stat
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tactic apply_tactic(expr const & th, expr const & th_type, bool all) {
|
tactic apply_tactic(expr const & th, bool all) {
|
||||||
return mk_tactic01([=](ro_environment const & env, io_state const &, proof_state const & s) -> optional<proof_state> {
|
return mk_tactic01([=](ro_environment const & env, io_state const &, proof_state const & s) -> optional<proof_state> {
|
||||||
|
expr th_type = type_inferer(env)(th, context(), s.get_menv().copy());
|
||||||
return apply_tactic(env, s, th, th_type, all);
|
return apply_tactic(env, s, th, th_type, all);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -161,7 +162,11 @@ tactic apply_tactic(name const & th_name, bool all) {
|
||||||
|
|
||||||
int mk_apply_tactic(lua_State * L) {
|
int mk_apply_tactic(lua_State * L) {
|
||||||
int nargs = lua_gettop(L);
|
int nargs = lua_gettop(L);
|
||||||
return push_tactic(L, apply_tactic(to_name_ext(L, 1), nargs >= 2 ? lua_toboolean(L, 2) : true));
|
bool all = nargs >= 2 ? lua_toboolean(L, 2) : true;
|
||||||
|
if (is_expr(L, 1))
|
||||||
|
return push_tactic(L, apply_tactic(to_expr(L, 1), all));
|
||||||
|
else
|
||||||
|
return push_tactic(L, apply_tactic(to_name_ext(L, 1), all));
|
||||||
}
|
}
|
||||||
|
|
||||||
void open_apply_tactic(lua_State * L) {
|
void open_apply_tactic(lua_State * L) {
|
||||||
|
|
|
@ -7,7 +7,7 @@ Author: Leonardo de Moura
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "library/tactic/tactic.h"
|
#include "library/tactic/tactic.h"
|
||||||
namespace lean {
|
namespace lean {
|
||||||
tactic apply_tactic(expr const & th, expr const & th_type, bool all = true);
|
tactic apply_tactic(expr const & th, bool all = true);
|
||||||
tactic apply_tactic(name const & th_name, bool all = true);
|
tactic apply_tactic(name const & th_name, bool all = true);
|
||||||
void open_apply_tactic(lua_State * L);
|
void open_apply_tactic(lua_State * L);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue