/* Copyright (c) 2015 Microsoft Corporation. All rights reserved. Released under Apache 2.0 license as described in the file LICENSE. Author: Leonardo de Moura */ #pragma once #include "library/blast/action_result.h" #include "library/blast/options.h" #include "library/blast/blast.h" #include "util/flet.h" namespace lean { namespace blast { /** Generic strategy for synthesizing proofs using the blast framework. There are two main configuration options: 1- Preprocessing (preprocess method) 2- Next action to be performed (next_action method) */ class strategy_fn { unsigned m_init_num_choices{0}; state::proof_steps_check_point m_ps_check_point; optional invoke_preprocess(); protected: virtual action_result next_action() = 0; virtual action_result hypothesis_pre_activation(hypothesis_idx hidx) = 0; virtual action_result hypothesis_post_activation(hypothesis_idx hidx) = 0; virtual bool show_failure() const; virtual char const * get_name() const = 0; action_result activate_hypothesis(); unsigned get_initial_num_choice_points() const { return m_init_num_choices; } action_result next_branch(expr pr); optional search(); public: strategy_fn(); optional operator()() { return search(); } }; #define TryStrategy(S) { \ flet save_state(curr_state(), curr_state()); \ if (optional pf = S()) { return action_result::solved(*pf); } \ } typedef std::function()> strategy; /** \brief Strategy that always returns none_expr */ strategy fail_strategy(); strategy operator||(strategy const & s1, strategy const & s2); }}