2 * This program is free software; you can redistribute it and/or modify
3 * it under the terms of the GNU General Public License as published by
4 * the Free Software Foundation; either version 2 of the License, or
5 * (at your option) any later version.
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
12 * You should have received a copy of the GNU General Public License
13 * along with this program; if not, write to the Free Software
14 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 * Author : Maxim Mamontov <faust@stargazer.dp.ua>
21 #include "get_service.h"
23 #include "parsers/property.h"
25 #include "stg/common.h"
31 GET_SERVICE::PARSER::PARSER(CALLBACK f, void * d, const std::string & e)
38 AddParser(propertyParsers, "name", info.name);
39 AddParser(propertyParsers, "comment", info.comment, "koi8-ru", GetEncodedValue);
40 AddParser(propertyParsers, "cost", info.cost);
41 AddParser(propertyParsers, "payDay", info.payDay);
43 //-----------------------------------------------------------------------------
44 GET_SERVICE::PARSER::~PARSER()
46 PROPERTY_PARSERS::iterator it(propertyParsers.begin());
47 while (it != propertyParsers.end())
48 delete (it++)->second;
50 //-----------------------------------------------------------------------------
51 int GET_SERVICE::PARSER::ParseStart(const char * el, const char ** attr)
55 ParseService(el, attr);
57 if (depth == 2 && parsingAnswer)
58 ParseServiceParams(el, attr);
62 //-----------------------------------------------------------------------------
63 void GET_SERVICE::PARSER::ParseEnd(const char * /*el*/)
66 if (depth == 0 && parsingAnswer)
69 callback(error.empty(), error, info, data);
71 parsingAnswer = false;
74 //-----------------------------------------------------------------------------
75 void GET_SERVICE::PARSER::ParseService(const char * el, const char ** attr)
77 if (strcasecmp(el, "service") == 0)
79 if (attr && attr[0] && attr[1])
81 if (strcasecmp(attr[1], "error") == 0)
83 if (attr[2] && attr[3])
86 error = "Service not found.";
95 //-----------------------------------------------------------------------------
96 void GET_SERVICE::PARSER::ParseServiceParams(const char * el, const char ** attr)
98 if (!TryParse(propertyParsers, ToLower(el), attr, encoding))
99 error = "Invalid parameter.";