X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/6171920df2f880303b54c19d7c5169c64b485585..e6c0bd53164bd30bbe038c80a370707847fc266c:/projects/stargazer/plugins/configuration/sgconfig/parser_message.h diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser_message.h b/projects/stargazer/plugins/configuration/sgconfig/parser_message.h index 2df1edc8..379c2b70 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser_message.h +++ b/projects/stargazer/plugins/configuration/sgconfig/parser_message.h @@ -19,21 +19,22 @@ * Author : Maxim Mamontov */ -#ifndef __STG_SGCONFIG_PARSER_USERS_H__ -#define __STG_SGCONFIG_PARSER_USERS_H__ +#pragma once #include "parser.h" #include "stg/message.h" +#include "stg/common.h" #include #include -class USERS; -class USER; - namespace STG { + +struct Users; +struct User; + namespace PARSER { @@ -43,32 +44,31 @@ class SEND_MESSAGE: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(const ADMIN & admin, USERS & users) - : m_admin(admin), m_users(users) - {} - virtual BASE_PARSER * create() { return new SEND_MESSAGE(m_admin, m_users); } + explicit FACTORY(Users & users) : m_users(users) {} + BASE_PARSER * create(const Admin & admin) override { return new SEND_MESSAGE(admin, m_users); } + static void Register(REGISTRY & registry, Users & users) + { registry[ToLower(tag)] = new FACTORY(users); } private: - const ADMIN & m_admin; - USERS & m_users; + Users & m_users; }; - SEND_MESSAGE(const ADMIN & admin, USERS & users) - : BASE_PARSER(admin, "Message"), m_users(users), m_result(res_ok), m_user(NULL) {} - int Start(void *data, const char *el, const char **attr); - int End(void *data, const char *el); + static const char * tag; + + SEND_MESSAGE(const Admin & admin, Users & users) + : BASE_PARSER(admin, tag), m_users(users), m_result(res_ok), m_user(NULL) {} + int Start(void *data, const char *el, const char **attr) override; + int End(void *data, const char *el) override; private: - USERS & m_users; + Users & m_users; std::vector m_logins; enum { res_ok, res_params_error, res_unknown } m_result; - STG_MSG m_msg; - USER * m_user; + STG::Message m_msg; + User * m_user; int ParseLogins(const char * logins); - void CreateAnswer(); + void CreateAnswer() override; }; } // namespace PARSER } // namespace STG - -#endif