X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/9dc2984179d989f8774ea7ff6d72c81d376b5a2c..3261ecc2503f45394eb3b9df97c36b08fb14fb1d:/projects/stargazer/plugins/configuration/sgconfig/parser.h?ds=inline diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser.h b/projects/stargazer/plugins/configuration/sgconfig/parser.h index 035dae8f..4e4b9417 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser.h +++ b/projects/stargazer/plugins/configuration/sgconfig/parser.h @@ -22,16 +22,24 @@ #define PARSER_H #include +#include class ADMIN; class BASE_PARSER { public: + struct FACTORY + { + virtual BASE_PARSER * create(const ADMIN & admin) = 0; + }; + typedef std::map REGISTRY; + BASE_PARSER(const ADMIN & admin, const std::string & t) : m_currAdmin(admin), m_depth(0), - m_tag(t) + m_tag(t), + m_done(false) {} virtual ~BASE_PARSER() {} virtual int Start(void * data, const char * el, const char ** attr); @@ -42,6 +50,8 @@ class BASE_PARSER std::string GetOpenTag() const { return "<" + m_tag + ">"; } std::string GetCloseTag() const { return ""; } + bool IsDone() const { return m_done; } + protected: BASE_PARSER(const BASE_PARSER & rvalue); BASE_PARSER & operator=(const BASE_PARSER & rvalue); @@ -50,6 +60,7 @@ class BASE_PARSER size_t m_depth; std::string m_answer; std::string m_tag; + bool m_done; private: virtual void CreateAnswer() = 0;