X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/750f1f62ce6576bf1ad86366a5fb8ce1c4524ccd..11c19b3afd4aa6a215d95b34de23213e113226d9:/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h?ds=inline diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h b/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h index 6425cca1..ad9987c1 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h +++ b/projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h @@ -19,8 +19,7 @@ * Author : Maxim Mamontov */ -#ifndef __STG_SGCONFIG_PARSER_TARIFFS_H__ -#define __STG_SGCONFIG_PARSER_TARIFFS_H__ +#pragma once #include "parser.h" @@ -29,12 +28,13 @@ #include -class TARIFFS; -class USERS; -class ADMIN; - namespace STG { + +struct Tariffs; +struct Users; +struct Admin; + namespace PARSER { @@ -44,23 +44,23 @@ class GET_TARIFFS: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(const TARIFFS & tariffs) : m_tariffs(tariffs) {} - virtual BASE_PARSER * create(const ADMIN & admin) { return new GET_TARIFFS(admin, m_tariffs); } - static void Register(REGISTRY & registry, const TARIFFS & 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 TARIFFS & m_tariffs; + const Tariffs & m_tariffs; }; static const char * tag; - GET_TARIFFS(const ADMIN & admin, const TARIFFS & tariffs) + 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 @@ -69,25 +69,25 @@ class ADD_TARIFF: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(TARIFFS & tariffs) : m_tariffs(tariffs) {} - virtual BASE_PARSER * create(const ADMIN & admin) { return new ADD_TARIFF(admin, m_tariffs); } - static void Register(REGISTRY & registry, TARIFFS & 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: - TARIFFS & m_tariffs; + Tariffs & m_tariffs; }; static const char * tag; - ADD_TARIFF(const ADMIN & admin, TARIFFS & tariffs) + ADD_TARIFF(const Admin & admin, Tariffs & tariffs) : BASE_PARSER(admin, tag), m_tariffs(tariffs) {} - int Start(void * data, const char * el, const char ** attr); + 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 @@ -96,27 +96,27 @@ class DEL_TARIFF: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(TARIFFS & tariffs, const USERS & users) : m_tariffs(tariffs), m_users(users) {} - virtual BASE_PARSER * create(const ADMIN & admin) { return new DEL_TARIFF(admin, m_users, m_tariffs); } - static void Register(REGISTRY & registry, TARIFFS & tariffs, const USERS & users) + 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: - TARIFFS & m_tariffs; - const USERS & m_users; + Tariffs & m_tariffs; + const Users & m_users; }; static const char * tag; - DEL_TARIFF(const ADMIN & admin, const USERS & users, TARIFFS & tariffs) + 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); + 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 @@ -125,29 +125,27 @@ class CHG_TARIFF: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(TARIFFS & tariffs) : m_tariffs(tariffs) {} - virtual BASE_PARSER * create(const ADMIN & admin) { return new CHG_TARIFF(admin, m_tariffs); } - static void Register(REGISTRY & registry, TARIFFS & 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: - TARIFFS & m_tariffs; + Tariffs & m_tariffs; }; static const char * tag; - CHG_TARIFF(const ADMIN & admin, TARIFFS & tariffs) + CHG_TARIFF(const Admin & admin, Tariffs & tariffs) : BASE_PARSER(admin, tag), m_tariffs(tariffs) {} - int Start(void * data, const char * el, const char ** attr); + 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