/* Copyright (c) 2013 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 #include "util/thread.h" #include "util/unlock_guard.h" namespace lean { /** \brief Wrapper for lua_State objects which contains all Lean bindings. */ class script_state { public: struct imp; private: std::shared_ptr m_ptr; friend script_state to_script_state(lua_State * L); mutex & get_mutex(); lua_State * get_state(); friend class data_channel; public: static void set_check_interrupt_freq(unsigned count); typedef std::weak_ptr weak_ref; script_state(); script_state(weak_ref const & r); ~script_state(); weak_ref to_weak_ref() const { return weak_ref(m_ptr); } /** \brief Execute the file with the given name. This method throws an exception if an error occurs. */ void dofile(char const * fname); /** \brief Execute the given string. This method throws an exception if an error occurs. */ void dostring(char const * str); /** \brief Import file \c fname from the LEAN_PATH. If the file was already included, then it nothing happens. */ void import(char const * fname); /** \brief Execute \c f in the using the internal Lua State. */ template typename std::result_of::type apply(F && f) { lock_guard lock(get_mutex()); return f(get_state()); } typedef void (*reg_fn)(lua_State *); // NOLINT static void register_module(reg_fn f); static void register_code(char const * code); /** \brief Auxiliary function for writing API bindings that release the lock to this object while executing \c f. */ template void exec_unprotected(F && f) { unlock_guard unlock(get_mutex()); f(); } template void exec_protected(F && f) { lock_guard lock(get_mutex()); f(); } }; /** \brief Return a reference to the script_state object that is wrapping \c L. */ script_state to_script_state(lua_State * L); }