X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/fe33b745d83085459e8a12e7a5a29d95c74c69d1..296c906e2689b9b5dc26d2f2d3e1e2d9e1662d3b:/projects/stargazer/plugin_runner.h?ds=sidebyside diff --git a/projects/stargazer/plugin_runner.h b/projects/stargazer/plugin_runner.h index 1402d2ef..a7def6cf 100644 --- a/projects/stargazer/plugin_runner.h +++ b/projects/stargazer/plugin_runner.h @@ -19,76 +19,78 @@ * Author : Maxim Mamontov <faust@stargazer.dp.ua> */ -#ifndef PLUGIN_RUNNER_H -#define PLUGIN_RUNNER_H +#pragma once #include "stg/plugin.h" -#include "stg/module_settings.h" -#include "stg/os_int.h" #include <string> #include <stdexcept> +#include <cstdint> -class SETTINGS; -class ADMINS; -class TARIFFS; -class USERS; -class SERVICES; -class CORPORATIONS; -class TRAFFCOUNTER; -class STORE; +namespace STG +{ + +struct ModuleSettings; +struct Settings; +struct Admins; +class Tariffs; +class Users; +struct Services; +struct Corporations; +struct TraffCounter; +struct Store; //----------------------------------------------------------------------------- -class PLUGIN_RUNNER { +class PluginRunner { public: struct Error : public std::runtime_error { - Error(const std::string & msg) : runtime_error(msg) {} + explicit Error(const std::string & msg) : runtime_error(msg) {} }; - PLUGIN_RUNNER(const std::string & pluginFileName, - const MODULE_SETTINGS & ms, - ADMINS & admins, - TARIFFS & tariffs, - USERS & users, - SERVICES & services, - CORPORATIONS & corporations, - TRAFFCOUNTER & traffcounter, - STORE & store, - const SETTINGS & settings); - ~PLUGIN_RUNNER(); + PluginRunner(const std::string& pluginFileName, + const std::string& pluginName, + const ModuleSettings& ms, + Admins& admins, + Tariffs& tariffs, + Users& users, + Services& services, + Corporations& corporations, + TraffCounter& traffcounter, + Store& store, + const Settings & settings); + ~PluginRunner(); int Start(); int Stop(); - int Reload(); + int Reload(const ModuleSettings& ms); int Restart(); bool IsRunning() { return m_plugin.IsRunning(); } - const std::string & GetStrError() const { return errorStr; } - PLUGIN & GetPlugin() { return m_plugin; } - const std::string & GetFileName() const { return pluginFileName; } + const std::string& GetStrError() const { return errorStr; } + Plugin& GetPlugin() { return m_plugin; } + const std::string& GetFileName() const { return pluginFileName; } + const std::string& GetName() const { return pluginName; } uint16_t GetStartPosition() const { return m_plugin.GetStartPosition(); } uint16_t GetStopPosition() const { return m_plugin.GetStopPosition(); } private: - PLUGIN_RUNNER(const PLUGIN_RUNNER & rvalue); - PLUGIN_RUNNER & operator=(const PLUGIN_RUNNER & rvalue); - - PLUGIN & Load(const MODULE_SETTINGS & ms, - ADMINS & admins, - TARIFFS & tariffs, - USERS & users, - SERVICES & services, - CORPORATIONS & corporations, - TRAFFCOUNTER & traffcounter, - STORE & store, - const SETTINGS & settings); + Plugin & load(const ModuleSettings& ms, + Admins& admins, + Tariffs& tariffs, + Users& users, + Services& services, + Corporations& corporations, + TraffCounter& traffcounter, + Store& store, + const Settings& settings); - std::string pluginFileName; - void * libHandle; + std::string pluginFileName; + std::string pluginName; + void* libHandle; - PLUGIN & m_plugin; - std::string errorStr; + Plugin& m_plugin; + std::string errorStr; }; //----------------------------------------------------------------------------- -#endif //PLUGIN_RUNNER_H +}