X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/7df336e60c959c440b2c330f7a7ca9b0251db2a1..0907aa4037b12b6b88ee24495d4577a064d4f8db:/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 6a5f8f4e..3f75993a 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_SEND_MESSAGE_H__ -#define __STG_SGCONFIG_PARSER_SEND_MESSAGE_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,27 +44,27 @@ class SEND_MESSAGE: public BASE_PARSER class FACTORY : public BASE_PARSER::FACTORY { public: - FACTORY(USERS & users) : m_users(users) {} - virtual BASE_PARSER * create(const ADMIN & admin) { return new SEND_MESSAGE(admin, m_users); } - static void Register(REGISTRY & registry, USERS & users) - { registry[tag] = new FACTORY(users); } + explicit FACTORY(Users & users) : m_users(users) {} + virtual BASE_PARSER * create(const Admin & admin) { return new SEND_MESSAGE(admin, m_users); } + static void Register(REGISTRY & registry, Users & users) + { registry[ToLower(tag)] = new FACTORY(users); } private: - USERS & m_users; + Users & m_users; }; static const char * tag; - SEND_MESSAGE(const ADMIN & admin, USERS & users) + 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); int End(void *data, const char *el); 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(); @@ -71,5 +72,3 @@ class SEND_MESSAGE: public BASE_PARSER } // namespace PARSER } // namespace STG - -#endif