2023-06-06 07:40:40 +00:00
|
|
|
#pragma once
|
2023-07-02 00:59:02 +02:00
|
|
|
#include "core/enums.hpp"
|
2023-07-22 13:05:43 +02:00
|
|
|
#include "lua_module.hpp"
|
2023-06-06 07:40:40 +00:00
|
|
|
|
|
|
|
namespace big
|
|
|
|
{
|
|
|
|
class lua_manager
|
|
|
|
{
|
2023-07-02 22:32:46 +02:00
|
|
|
private:
|
2023-06-06 07:40:40 +00:00
|
|
|
std::mutex m_module_lock;
|
2023-07-02 22:32:46 +02:00
|
|
|
std::vector<std::shared_ptr<lua_module>> m_modules;
|
|
|
|
|
|
|
|
static constexpr std::chrono::seconds m_delay_between_changed_scripts_check = 3s;
|
|
|
|
std::chrono::high_resolution_clock::time_point m_wake_time_changed_scripts_check;
|
2023-06-06 07:40:40 +00:00
|
|
|
|
2023-07-03 13:01:12 +02:00
|
|
|
folder m_scripts_folder;
|
2023-12-08 09:14:57 +01:00
|
|
|
folder m_scripts_config_folder;
|
2023-07-03 13:01:12 +02:00
|
|
|
|
2023-06-06 07:40:40 +00:00
|
|
|
public:
|
2023-12-08 09:14:57 +01:00
|
|
|
lua_manager(folder scripts_folder, folder scripts_config_folder);
|
2023-06-06 07:40:40 +00:00
|
|
|
~lua_manager();
|
|
|
|
|
2023-07-01 22:40:17 +02:00
|
|
|
void load_all_modules();
|
|
|
|
void unload_all_modules();
|
|
|
|
|
|
|
|
inline auto get_module_count() const
|
|
|
|
{
|
|
|
|
return m_modules.size();
|
|
|
|
}
|
|
|
|
|
2023-07-03 13:01:12 +02:00
|
|
|
inline const folder& get_scripts_folder() const
|
|
|
|
{
|
|
|
|
return m_scripts_folder;
|
|
|
|
}
|
|
|
|
|
2023-12-08 09:14:57 +01:00
|
|
|
inline const folder& get_scripts_config_folder() const
|
|
|
|
{
|
|
|
|
return m_scripts_config_folder;
|
|
|
|
}
|
|
|
|
|
2023-07-22 13:05:43 +02:00
|
|
|
std::weak_ptr<lua_module> get_module(rage::joaat_t module_id);
|
2023-07-05 00:30:57 +02:00
|
|
|
|
2023-07-22 13:05:43 +02:00
|
|
|
bool has_gui_to_draw(rage::joaat_t tab_hash);
|
2023-07-17 14:55:42 +02:00
|
|
|
void draw_independent_gui();
|
2023-06-06 07:40:40 +00:00
|
|
|
void draw_gui(rage::joaat_t tab_hash);
|
2023-07-01 22:40:17 +02:00
|
|
|
|
2023-06-06 07:40:40 +00:00
|
|
|
void unload_module(rage::joaat_t module_id);
|
2023-07-22 13:05:43 +02:00
|
|
|
void load_module(const std::filesystem::path& module_path);
|
2023-07-01 22:40:17 +02:00
|
|
|
|
2023-07-02 22:32:46 +02:00
|
|
|
void reload_changed_scripts();
|
|
|
|
|
2023-06-06 07:40:40 +00:00
|
|
|
void handle_error(const sol::error& error, const sol::state_view& state);
|
|
|
|
|
2023-07-02 00:59:02 +02:00
|
|
|
template<menu_event menu_event_, typename Return = void, typename... Args>
|
2023-06-06 07:40:40 +00:00
|
|
|
inline std::conditional_t<std::is_void_v<Return>, void, std::optional<Return>> trigger_event(Args&&... args)
|
|
|
|
{
|
2023-07-01 22:40:17 +02:00
|
|
|
std::lock_guard guard(m_module_lock);
|
|
|
|
|
|
|
|
for (auto& module : m_modules)
|
2023-06-06 07:40:40 +00:00
|
|
|
{
|
2023-07-02 00:59:02 +02:00
|
|
|
if (auto vec = module->m_event_callbacks.find(menu_event_); vec != module->m_event_callbacks.end())
|
2023-06-06 07:40:40 +00:00
|
|
|
{
|
|
|
|
for (auto& cb : vec->second)
|
|
|
|
{
|
|
|
|
auto result = cb(args...);
|
|
|
|
|
|
|
|
if (!result.valid())
|
|
|
|
{
|
|
|
|
handle_error(result, result.lua_state());
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if constexpr (!std::is_void_v<Return>)
|
|
|
|
{
|
|
|
|
if (result.return_count() == 0)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if (!result[0].is<Return>())
|
|
|
|
continue;
|
|
|
|
|
|
|
|
return result[0].get<Return>();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if constexpr (!std::is_void_v<Return>)
|
|
|
|
return std::nullopt;
|
|
|
|
}
|
|
|
|
|
2023-07-01 22:40:17 +02:00
|
|
|
inline void for_each_module(auto func)
|
|
|
|
{
|
|
|
|
std::lock_guard guard(m_module_lock);
|
|
|
|
|
|
|
|
for (auto& module : m_modules)
|
|
|
|
{
|
|
|
|
func(module);
|
|
|
|
}
|
|
|
|
}
|
2023-06-06 07:40:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
inline lua_manager* g_lua_manager;
|
|
|
|
}
|