X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/df9f528d8ea5b3ba19bebcaf0324c3282edeffcc..b9bafe1042839cd7295adf84448b4d08de9f5f46:/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h b/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h index f31257df..ad9987c1 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h +++ b/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h @@ -19,21 +19,22 @@ * Author : Maxim Mamontov */ -#ifndef __STG_SGCONFIG_PARSER_TARIFFS_H__ -#define __STG_SGCONFIG_PARSER_TARIFFS_H__ +#pragma once #include "parser.h" #include "stg/tariff_conf.h" +#include "stg/common.h" #include -class TARIFFS; -class USERS; -class ADMIN; - namespace STG { + +struct Tariffs; +struct Users; +struct Admin; + namespace PARSER { @@ -43,22 +44,23 @@ class GET_TARIFFS: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(const ADMIN & admin, const TARIFFS & tariffs) - : m_admin(admin), m_tariffs(tariffs) - {} - virtual BASE_PARSER * create() { return new GET_TARIFFS(m_admin, m_tariffs); } + explicit FACTORY(const Tariffs & tariffs) : m_tariffs(tariffs) {} + BASE_PARSER * create(const Admin & admin) override { return new GET_TARIFFS(admin, m_tariffs); } + static void Register(REGISTRY & registry, const Tariffs & tariffs) + { registry[ToLower(tag)] = new FACTORY(tariffs); } private: - const ADMIN & m_admin; - const TARIFFS & m_tariffs; + const Tariffs & m_tariffs; }; - GET_TARIFFS(const ADMIN & admin, const TARIFFS & tariffs) - : BASE_PARSER(admin, "GetTariffs"), m_tariffs(tariffs) {} + static const char * tag; + + GET_TARIFFS(const Admin & admin, const Tariffs & tariffs) + : BASE_PARSER(admin, tag), m_tariffs(tariffs) {} private: - const TARIFFS & m_tariffs; + const Tariffs & m_tariffs; - void CreateAnswer(); + void CreateAnswer() override; }; class ADD_TARIFF: public BASE_PARSER @@ -67,24 +69,25 @@ class ADD_TARIFF: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(const ADMIN & admin, TARIFFS & tariffs) - : m_admin(admin), m_tariffs(tariffs) - {} - virtual BASE_PARSER * create() { return new ADD_TARIFF(m_admin, m_tariffs); } + explicit FACTORY(Tariffs & tariffs) : m_tariffs(tariffs) {} + BASE_PARSER * create(const Admin & admin) override { return new ADD_TARIFF(admin, m_tariffs); } + static void Register(REGISTRY & registry, Tariffs & tariffs) + { registry[ToLower(tag)] = new FACTORY(tariffs); } private: - const ADMIN & m_admin; - TARIFFS & m_tariffs; + Tariffs & m_tariffs; }; - ADD_TARIFF(const ADMIN & admin, TARIFFS & tariffs) - : BASE_PARSER(admin, "AddTariff"), m_tariffs(tariffs) {} - int Start(void * data, const char * el, const char ** attr); + static const char * tag; + + ADD_TARIFF(const Admin & admin, Tariffs & tariffs) + : BASE_PARSER(admin, tag), m_tariffs(tariffs) {} + int Start(void * data, const char * el, const char ** attr) override; private: std::string tariff; - TARIFFS & m_tariffs; + Tariffs & m_tariffs; - void CreateAnswer(); + void CreateAnswer() override; }; class DEL_TARIFF: public BASE_PARSER @@ -93,26 +96,27 @@ class DEL_TARIFF: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(const ADMIN & admin, TARIFFS & tariffs, const USERS & users) - : m_admin(admin), m_tariffs(tariffs), m_users(users) - {} - virtual BASE_PARSER * create() { return new DEL_TARIFF(m_admin, m_users, m_tariffs); } + FACTORY(Tariffs & tariffs, const Users & users) : m_tariffs(tariffs), m_users(users) {} + BASE_PARSER * create(const Admin & admin) override { return new DEL_TARIFF(admin, m_users, m_tariffs); } + static void Register(REGISTRY & registry, Tariffs & tariffs, const Users & users) + { registry[ToLower(tag)] = new FACTORY(tariffs, users); } private: - const ADMIN & m_admin; - TARIFFS & m_tariffs; - const USERS & m_users; + Tariffs & m_tariffs; + const Users & m_users; }; - DEL_TARIFF(const ADMIN & admin, const USERS & users, TARIFFS & tariffs) - : BASE_PARSER(admin, "DelTariff"), m_users(users), m_tariffs(tariffs) {} - int Start(void * data, const char * el, const char ** attr); + static const char * tag; + + DEL_TARIFF(const Admin & admin, const Users & users, Tariffs & tariffs) + : BASE_PARSER(admin, tag), m_users(users), m_tariffs(tariffs) {} + int Start(void * data, const char * el, const char ** attr) override; private: std::string tariff; - const USERS & m_users; - TARIFFS & m_tariffs; + const Users & m_users; + Tariffs & m_tariffs; - void CreateAnswer(); + void CreateAnswer() override; }; class CHG_TARIFF: public BASE_PARSER @@ -121,28 +125,27 @@ class CHG_TARIFF: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(const ADMIN & admin, TARIFFS & tariffs) - : m_admin(admin), m_tariffs(tariffs) - {} - virtual BASE_PARSER * create() { return new CHG_TARIFF(m_admin, m_tariffs); } + explicit FACTORY(Tariffs & tariffs) : m_tariffs(tariffs) {} + BASE_PARSER * create(const Admin & admin) override { return new CHG_TARIFF(admin, m_tariffs); } + static void Register(REGISTRY & registry, Tariffs & tariffs) + { registry[ToLower(tag)] = new FACTORY(tariffs); } private: - const ADMIN & m_admin; - TARIFFS & m_tariffs; + Tariffs & m_tariffs; }; - CHG_TARIFF(const ADMIN & admin, TARIFFS & tariffs) - : BASE_PARSER(admin, "SetTariff"), m_tariffs(tariffs) {} - int Start(void * data, const char * el, const char ** attr); + static const char * tag; + + CHG_TARIFF(const Admin & admin, Tariffs & tariffs) + : BASE_PARSER(admin, tag), m_tariffs(tariffs) {} + int Start(void * data, const char * el, const char ** attr) override; private: - TARIFF_DATA_RES td; - TARIFFS & m_tariffs; + TariffDataOpt td; + Tariffs & m_tariffs; int CheckTariffData(); - void CreateAnswer(); + void CreateAnswer() override; }; } // namespace PARSER } // namespace STG - -#endif