]> git.stg.codes - stg.git/blobdiff - projects/stargazer/plugins/configuration/sgconfig/parser_tariffs.h
Check if we can use C++17 with XMLRPC-C.
[stg.git] / projects / stargazer / plugins / configuration / sgconfig / parser_tariffs.h
index f31257df06277a2ee53ee5746b89ba744aa14665..ad9987c1be6a1195b04028dad2b89b3d2e727100 100644 (file)
  *    Author : Maxim Mamontov <faust@stargazer.dp.ua>
  */
 
-#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 <string>
 
-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