X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/198f8204d13f3f0661233d910f474775a68a7337..87300676aa712b358ab98beaa5082b7a19e5d97a:/stglibs/srvconf.lib/servconf.cpp diff --git a/stglibs/srvconf.lib/servconf.cpp b/stglibs/srvconf.lib/servconf.cpp index 7848787b..2f4afaba 100644 --- a/stglibs/srvconf.lib/servconf.cpp +++ b/stglibs/srvconf.lib/servconf.cpp @@ -35,23 +35,31 @@ using namespace std; //----------------------------------------------------------------------------- int AnsRecv(void * data, list * list1) { -SERVCONF * sc = static_cast(data); +//NODE * node; +SERVCONF * sc; +char ans[ENC_MSG_LEN + 1]; +int len, done = 0; + +sc = (SERVCONF*)data; XML_ParserReset(sc->parser, NULL); XML_SetElementHandler(sc->parser, Start, End); XML_SetUserData(sc->parser, data); -char ans[ENC_MSG_LEN + 1]; -int len, done = 0; - //loop parsing list::iterator node; node = list1->begin(); +if (node == list1->end()) + { + return st_ok; + } + while (node != list1->end()) { strncpy(ans, node->c_str(), ENC_MSG_LEN); ans[ENC_MSG_LEN] = 0; + //printf("---> %s\n", ans); len = strlen(ans); if (XML_Parse(sc->parser, ans, len, done) == XML_STATUS_ERROR) @@ -59,14 +67,13 @@ while (node != list1->end()) strprintf(&sc->errorMsg, "XML parse error at line %d: %s", static_cast(XML_GetCurrentLineNumber(sc->parser)), XML_ErrorString(XML_GetErrorCode(sc->parser))); - printf("%s\n", sc->errorMsg.c_str()); return st_xml_parse_error; } ++node; } -return st_ok; +return 0; } //----------------------------------------------------------------------------- void Start(void *data, const char *el, const char **attr) @@ -85,26 +92,29 @@ sc->End(el); //----------------------------------------------------------------------------- SERVCONF::SERVCONF() : currParser(NULL), - parseDepth(0), error(0), - getUsersCallback(NULL), - getUserCallback(NULL), - authByCallback(NULL), - serverInfoCallback(NULL), + RecvUserDataCb(NULL), + RecvGetUserDataCb(NULL), + RecvServerInfoDataCb(NULL), RecvChgUserCb(NULL), - checkUserCallback(NULL), + RecvCheckUserCb(NULL), RecvSendMessageCb(NULL), - getUsersData(NULL), - getUserData(NULL), - authByData(NULL), - serverInfoData(NULL), + getUserDataDataCb(NULL), + getUserAuthByDataCb(NULL), + getUsersDataDataCb(NULL), + getServerInfoDataCb(NULL), chgUserDataCb(NULL), - checkUserData(NULL), + checkUserDataCb(NULL), sendMessageDataCb(NULL) { parser = XML_ParserCreate(NULL); } //----------------------------------------------------------------------------- +SERVCONF::~SERVCONF() +{ +XML_ParserFree(parser); +} +//----------------------------------------------------------------------------- void SERVCONF::SetServer(const char * server) { nt.SetServer(server); @@ -132,7 +142,7 @@ snprintf(request, 255, "", l); int ret; currParser = &parserGetUser; -((PARSER_GET_USER*)currParser)->SetCallback(getUserCallback, getUserData); +((PARSER_GET_USER*)currParser)->SetUserDataRecvCb(RecvGetUserDataCb, getUserDataDataCb); nt.Reset(); nt.SetRxCallback(this, AnsRecv); @@ -156,18 +166,18 @@ if ((ret = nt.Disconnect()) != st_ok) return st_ok; } //----------------------------------------------------------------------------- -int SERVCONF::AuthBy(const char * l) +int SERVCONF::GetUserAuthBy(const char * l) { char request[255]; snprintf(request, 255, "", l); +int ret; currParser = &parserAuthBy; -((PARSER_AUTH_BY*)currParser)->SetCallback(authByCallback, authByData); +((PARSER_AUTH_BY*)currParser)->SetRecvCb(RecvAuthByCb, getUserAuthByDataCb); nt.Reset(); nt.SetRxCallback(this, AnsRecv); -int ret; if ((ret = nt.Connect()) != st_ok) { errorMsg = nt.GetError(); @@ -193,7 +203,7 @@ char request[] = ""; int ret; currParser = &parserGetUsers; -((PARSER_GET_USERS*)currParser)->SetCallback(getUsersCallback, getUsersData); +((PARSER_GET_USERS*)currParser)->SetUserDataRecvCb(RecvUserDataCb, getUsersDataDataCb); nt.Reset(); nt.SetRxCallback(this, AnsRecv); @@ -250,13 +260,13 @@ if ((ret = nt.Disconnect()) != st_ok) return st_ok; } //----------------------------------------------------------------------------- -int SERVCONF::ServerInfo() +int SERVCONF::GetServerInfo() { char request[] = ""; int ret; currParser = &parserServerInfo; -((PARSER_SERVER_INFO*)currParser)->SetCallback(serverInfoCallback, serverInfoData); +((PARSER_GET_SERVER_INFO*)currParser)->SetServerInfoRecvCb(RecvServerInfoDataCb, getServerInfoDataCb); nt.Reset(); nt.SetRxCallback(this, AnsRecv); @@ -347,7 +357,7 @@ snprintf(request, 255, "", login, passw int ret; currParser = &parserCheckUser; -((PARSER_CHECK_USER*)currParser)->SetCallback(checkUserCallback, checkUserData); +((PARSER_CHECK_USER*)currParser)->SetCheckUserRecvCb(RecvCheckUserCb, checkUserDataCb); nt.Reset(); nt.SetRxCallback(this, AnsRecv); @@ -382,28 +392,28 @@ void SERVCONF::End(const char *el) currParser->ParseEnd(el); } //----------------------------------------------------------------------------- -void SERVCONF::SetGetUsersCallback(PARSER_GET_USERS::CALLBACK f, void * data) +void SERVCONF::SetUserDataRecvCb(RecvUserDataCb_t f, void * data) { -getUsersCallback = f; -getUsersData = data; +RecvUserDataCb = f; +getUsersDataDataCb = data; } //----------------------------------------------------------------------------- -void SERVCONF::SetGetUserCallback(PARSER_GET_USER::CALLBACK f, void * data) +void SERVCONF::SetGetUserDataRecvCb(RecvUserDataCb_t f, void * data) { -getUserCallback = f; -getUserData = data; +RecvGetUserDataCb = f; //GET_USER +getUserDataDataCb = data; } //----------------------------------------------------------------------------- -void SERVCONF::SetAuthByCallback(PARSER_AUTH_BY::CALLBACK f, void * data) +void SERVCONF::SetGetUserAuthByRecvCb(RecvAuthByDataCb_t f, void * data) { -authByCallback = f; -authByData = data; +RecvAuthByCb = f; +getUserAuthByDataCb = data; } //----------------------------------------------------------------------------- -void SERVCONF::SetServerInfoCallback(PARSER_SERVER_INFO::CALLBACK f, void * data) +void SERVCONF::SetServerInfoRecvCb(RecvServerInfoDataCb_t f, void * data) { -serverInfoCallback = f; -serverInfoData = data; +RecvServerInfoDataCb = f; +getServerInfoDataCb = data; } //----------------------------------------------------------------------------- void SERVCONF::SetChgUserCb(RecvChgUserCb_t f, void * data) @@ -412,10 +422,10 @@ RecvChgUserCb = f; chgUserDataCb = data; } //----------------------------------------------------------------------------- -void SERVCONF::SetCheckUserCallback(PARSER_CHECK_USER::CALLBACK f, void * data) +void SERVCONF::SetCheckUserCb(RecvCheckUserCb_t f, void * data) { -checkUserCallback = f; -checkUserData = data; +RecvCheckUserCb = f; +checkUserDataCb = data; } //----------------------------------------------------------------------------- void SERVCONF::SetSendMessageCb(RecvSendMessageCb_t f, void * data)