/* 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 { unsigned m_init_num_choices; optional invoke_preprocess(); protected: virtual optional preprocess() = 0; virtual action_result next_action() = 0; action_result next_branch(expr pr); optional search_upto(unsigned depth); optional search(); public: strategy(); optional operator()() { return search(); } }; #define TryStrategy(Code) {\ flet save_state(curr_state(), curr_state());\ curr_state().clear_proof_steps();\ if (optional pf = Code) { return action_result::solved(*pf); }\ } }}