fix(library/tactic): memory leak that only happens when compiling with clang++
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
6891f48c67
commit
15f270d9f3
4 changed files with 8 additions and 8 deletions
|
@ -69,7 +69,7 @@ format proof_state::pp(environment const & env, formatter const & fmt, options c
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
goals map_goals(proof_state const & s, std::function<optional<goal>(name const & gn, goal const & g)> const & f) {
|
goals map_goals(proof_state const & s, std::function<optional<goal>(name const & gn, goal const & g)> f) {
|
||||||
return map_filter(s.get_goals(), [=](std::pair<name, goal> const & in, std::pair<name, goal> & out) -> bool {
|
return map_filter(s.get_goals(), [=](std::pair<name, goal> const & in, std::pair<name, goal> & out) -> bool {
|
||||||
check_interrupted();
|
check_interrupted();
|
||||||
optional<goal> new_goal = f(in.first, in.second);
|
optional<goal> new_goal = f(in.first, in.second);
|
||||||
|
|
|
@ -80,7 +80,7 @@ proof_state to_proof_state(environment const & env, expr const & mvar, options c
|
||||||
/** \brief Try to extract a proof from the given proof state */
|
/** \brief Try to extract a proof from the given proof state */
|
||||||
optional<expr> to_proof(proof_state const & s);
|
optional<expr> to_proof(proof_state const & s);
|
||||||
|
|
||||||
goals map_goals(proof_state const & s, std::function<optional<goal>(name const & gn, goal const & g)> const & f);
|
goals map_goals(proof_state const & s, std::function<optional<goal>(name const & gn, goal const & g)> f);
|
||||||
io_state_stream const & operator<<(io_state_stream const & out, proof_state const & s);
|
io_state_stream const & operator<<(io_state_stream const & out, proof_state const & s);
|
||||||
|
|
||||||
UDATA_DEFS_CORE(goals)
|
UDATA_DEFS_CORE(goals)
|
||||||
|
|
|
@ -18,7 +18,7 @@ Author: Leonardo de Moura
|
||||||
#include "library/io_state_stream.h"
|
#include "library/io_state_stream.h"
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
tactic tactic01(std::function<optional<proof_state>(environment const &, io_state const & ios, proof_state const &)> const & f) {
|
tactic tactic01(std::function<optional<proof_state>(environment const &, io_state const & ios, proof_state const &)> f) {
|
||||||
return tactic([=](environment const & env, io_state const & ios, proof_state const & s) {
|
return tactic([=](environment const & env, io_state const & ios, proof_state const & s) {
|
||||||
return mk_proof_state_seq([=]() {
|
return mk_proof_state_seq([=]() {
|
||||||
auto r = f(env, ios, s);
|
auto r = f(env, ios, s);
|
||||||
|
@ -30,7 +30,7 @@ tactic tactic01(std::function<optional<proof_state>(environment const &, io_stat
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
tactic tactic1(std::function<proof_state(environment const &, io_state const & ios, proof_state const &)> const & f) {
|
tactic tactic1(std::function<proof_state(environment const &, io_state const & ios, proof_state const &)> f) {
|
||||||
return tactic([=](environment const & env, io_state const & ios, proof_state const & s) {
|
return tactic([=](environment const & env, io_state const & ios, proof_state const & s) {
|
||||||
return mk_proof_state_seq([=]() {
|
return mk_proof_state_seq([=]() {
|
||||||
auto r = f(env, ios, s);
|
auto r = f(env, ios, s);
|
||||||
|
|
|
@ -24,8 +24,8 @@ inline optional<tactic> some_tactic(tactic && t) { return optional<tactic>(std::
|
||||||
|
|
||||||
template<typename F> inline proof_state_seq mk_proof_state_seq(F && f) { return mk_lazy_list<proof_state>(std::forward<F>(f)); }
|
template<typename F> inline proof_state_seq mk_proof_state_seq(F && f) { return mk_lazy_list<proof_state>(std::forward<F>(f)); }
|
||||||
|
|
||||||
tactic tactic01(std::function<optional<proof_state>(environment const &, io_state const & ios, proof_state const &)> const & f);
|
tactic tactic01(std::function<optional<proof_state>(environment const &, io_state const & ios, proof_state const &)> f);
|
||||||
tactic tactic1(std::function<proof_state(environment const &, io_state const & ios, proof_state const &)> const & f);
|
tactic tactic1(std::function<proof_state(environment const &, io_state const & ios, proof_state const &)> f);
|
||||||
|
|
||||||
/** \brief Return a "do nothing" tactic (aka skip). */
|
/** \brief Return a "do nothing" tactic (aka skip). */
|
||||||
tactic id_tactic();
|
tactic id_tactic();
|
||||||
|
@ -115,9 +115,9 @@ typedef std::function<bool(environment const & env, io_state const & ios, proof_
|
||||||
\brief Return a tactic that applies the predicate \c p to the input state.
|
\brief Return a tactic that applies the predicate \c p to the input state.
|
||||||
If \c p returns true, then applies \c t1. Otherwise, applies \c t2.
|
If \c p returns true, then applies \c t1. Otherwise, applies \c t2.
|
||||||
*/
|
*/
|
||||||
tactic cond(proof_state_pred const & p, tactic const & t1, tactic const & t2);
|
tactic cond(proof_state_pred p, tactic const & t1, tactic const & t2);
|
||||||
/** \brief Syntax-sugar for cond(p, t, id_tactic()) */
|
/** \brief Syntax-sugar for cond(p, t, id_tactic()) */
|
||||||
inline tactic when(proof_state_pred const & p, tactic const & t) { return cond(p, t, id_tactic()); }
|
inline tactic when(proof_state_pred p, tactic const & t) { return cond(p, t, id_tactic()); }
|
||||||
/**
|
/**
|
||||||
\brief Return a tactic that applies \c t only to the goal named \c gname.
|
\brief Return a tactic that applies \c t only to the goal named \c gname.
|
||||||
The tactic fails if the input state does not have a goal named \c gname.
|
The tactic fails if the input state does not have a goal named \c gname.
|
||||||
|
|
Loading…
Reference in a new issue