]> git.stg.codes - stg.git/blobdiff - projects/stargazer/plugins/configuration/sgconfig/parser.h
Verbose test reports on failures.
[stg.git] / projects / stargazer / plugins / configuration / sgconfig / parser.h
index 2e68f8e960cd5a6f977fab9bfe1faa2ea7d82893..5dd339bd7b0e49b4ed51f87ba7761ebb5824a7d1 100644 (file)
  *    Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
  */
 
  *    Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
  */
 
-#ifndef PARSER_H
-#define PARSER_H
-
-#include "stg/message.h"
-#include "stg/tariff_conf.h"
-#include "stg/resetable.h"
-#include "stg/const.h"
+#pragma once
 
 #include <string>
 
 #include <string>
-#include <vector>
-
-class TARIFFS;
-class SETTINGS;
-class STORE;
-class ADMINS;
-class ADMIN;
-class USERS;
-class USER;
-class USER_STAT_RES;
-class USER_CONF_RES;
+#include <map>
 
 
-//-----------------------------------------------------------------------------
-class BASE_PARSER {
-public:
-    BASE_PARSER(const ADMIN & admin, const std::string & t)
-        : strError(),
-          admins(NULL),
-          users(NULL),
-          tariffs(NULL),
-          store(NULL),
-          settings(NULL),
-          currAdmin(admin),
-          depth(0),
-          tag(t)
-    {}
-    virtual ~BASE_PARSER() {}
-    virtual int Start(void *data, const char *el, const char **attr);
-    virtual int End(void *data, const char *el);
+namespace STG
+{
+struct Admin;
+}
 
 
-    virtual void Reset() { answer.clear(); depth = 0; }
+class BASE_PARSER
+{
+    public:
+        struct FACTORY
+        {
+            virtual ~FACTORY() {}
+            virtual BASE_PARSER * create(const STG::Admin & admin) = 0;
+        };
+        typedef std::map<std::string, FACTORY *> REGISTRY;
 
 
-    void SetUsers(USERS * u) { users = u; }
-    void SetAdmins(ADMINS * a) { admins = a; }
-    void SetTariffs(TARIFFS * t) { tariffs = t; }
-    void SetStore(STORE * s) { store = s; }
-    void SetStgSettings(const SETTINGS * s) { settings = s; }
+        BASE_PARSER(const STG::Admin & admin, const std::string & t)
+            : m_currAdmin(admin),
+              m_depth(0),
+              m_tag(t)
+        {}
+        virtual ~BASE_PARSER() {}
+        virtual int Start(void * data, const char * el, const char ** attr);
+        virtual int End(void * data, const char * el);
 
 
-    const std::string & GetStrError() const { return strError; }
-    const std::string & GetAnswer() const { return answer; }
-    const std::string & GetTag() const { return tag; }
-    std::string GetOpenTag() const { return "<" + tag + ">"; }
-    std::string GetCloseTag() const { return "</" + tag + ">"; }
+        const std::string & GetAnswer() const { return m_answer; }
+        const std::string & GetTag() const { return m_tag; }
+        std::string GetOpenTag() const { return "<" + m_tag + ">"; }
+        std::string GetCloseTag() const { return "</" + m_tag + ">"; }
 
 
-protected:
-    BASE_PARSER(const BASE_PARSER & rvalue);
-    BASE_PARSER & operator=(const BASE_PARSER & rvalue);
+    protected:
+        BASE_PARSER(const BASE_PARSER & rvalue);
+        BASE_PARSER & operator=(const BASE_PARSER & rvalue);
 
 
-    std::string      strError;
-    ADMINS *         admins;
-    USERS *          users;
-    TARIFFS *        tariffs;
-    STORE *          store;
-    const SETTINGS * settings;
-    const ADMIN &    currAdmin;
-    int              depth;
-    std::string      answer;
-    std::string      tag;
+        const STG::Admin & m_currAdmin;
+        size_t        m_depth;
+        std::string   m_answer;
+        std::string   m_tag;
 
 
-private:
-    virtual void CreateAnswer() = 0;
+    private:
+        virtual void CreateAnswer() = 0;
 };
 };
-//-----------------------------------------------------------------------------
-//-----------------------------------------------------------------------------
-#endif //PARSER_H