/* 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 #include "kernel/environment.h" #include "library/io_state.h" #include "library/tmp_type_context.h" #include "library/blast/state.h" namespace lean { struct projection_info; class goal; typedef std::unique_ptr tmp_type_context_ptr; namespace blast { /** \brief Return the thread local environment being used by the blast tactic. */ environment const & env(); /** \brief Return the thread local io_state being used by the blast tactic. */ io_state const & ios(); /** \brief Return the thread local current state begin processed by the blast tactic. */ state & curr_state(); /** \brief Return a thread local fresh name meant to be used to name local constants. */ name mk_fresh_local_name(); expr mk_fresh_local(expr const & type, binder_info const & bi = binder_info()); /** \brief Return true iff the given constant name is marked as reducible in env() */ bool is_reducible(name const & n); /** \brief Return a nonnull projection_info object if \c n is the name of a projection in env() */ projection_info const * get_projection_info(name const & n); /** \brief Put the given expression in weak-head-normal-form with respect to the current state being processed by the blast tactic. */ expr whnf(expr const & e); /** \brief Return the type of the given expression with respect to the current state being processed by the blast tactic. \remark: (potential side-effect) this procedure may update the meta-variable assignment associated with the current state. */ expr infer_type(expr const & e); /** \brief Return true if \c e is a Proposition */ bool is_prop(expr const & e); /** \brief Return true iff the two expressions are definitionally equal in the current state being processed by the blast tactic. \remark: (potential side-effect) this procedure may update the meta-variable assignment associated with the current state. */ bool is_def_eq(expr const & e1, expr const & e2); /** \brief Try to synthesize an element of the given type class with respect to the blast local context. */ optional mk_class_instance(expr const & e); /** \brief Display the current state of the blast tactic in the diagnostic channel. */ void display_curr_state(); /** \brief Display the given expression in the diagnostic channel. */ void display_expr(expr const & e); /** \brief Display message in the blast tactic diagnostic channel. */ void display(char const * msg); void display(sstream const & msg); /** \brief Create a local scope for saving the assignment and metavariable declarations at curr_state() */ class scope_assignment { bool m_keep; public: scope_assignment(); ~scope_assignment(); void commit(); }; /** \brief Auxiliary object for setting thread local storage associated with blast tactic. This is for debugging purposes only. It allow us to debug/test procedures that can only be invoked from blast. */ class scope_debug { struct imp; std::unique_ptr m_imp; public: scope_debug(environment const & env, io_state const & ios); ~scope_debug(); }; /** \brief Create a temporary type_context that is compatible with blast. This temporary type context can acces the type of blast hypotheses and meta-variables. */ class blast_tmp_type_context { tmp_type_context * m_ctx; public: blast_tmp_type_context(); ~blast_tmp_type_context(); tmp_type_context const * operator->() const { return m_ctx; } tmp_type_context * operator->() { return m_ctx; } tmp_type_context const & operator*() const { return *m_ctx; } tmp_type_context & operator*() { return *m_ctx; } }; } optional blast_goal(environment const & env, io_state const & ios, list const & ls, list const & ds, goal const & g); void initialize_blast(); void finalize_blast(); }