diff options
Diffstat (limited to 'server/src/templateheaderparser.h')
-rw-r--r-- | server/src/templateheaderparser.h | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/server/src/templateheaderparser.h b/server/src/templateheaderparser.h new file mode 100644 index 0000000..522f56d --- /dev/null +++ b/server/src/templateheaderparser.h @@ -0,0 +1,62 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set et sw=2 ts=2: */ +/*************************************************************************** + * templateheaderparser.h + * + * Thu Jul 30 08:53:26 CEST 2009 + * Copyright 2009 Bent Bisballe Nyeng + * deva@aasimon.org + ****************************************************************************/ + +/* + * This file is part of Pracro. + * + * Pracro is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * Pracro is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Pracro; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#ifndef __PRACRO_TEMPLATEHEADERPARSER_H__ +#define __PRACRO_TEMPLATEHEADERPARSER_H__ + +#include "saxparser.h" +#include "template.h" + +class TemplateHeaderParser : public SAXParser { +public: + TemplateHeaderParser(std::string templatefile); + ~TemplateHeaderParser(); + + void startTag(std::string name, std::map< std::string, std::string> attributes); + void parseError(char *buf, size_t len, std::string error, int lineno); + + /** + * Get a pointer to the parsed template. + * NOTE: The allocated memory for the template is owned by the parser, and will be + * freed upon parser deletion. + * @return A pointer to the template or NULL on error. + */ + Template *getTemplate(); + +protected: + int readData(char *data, size_t size); + +private: + int fd; + Template *t; + + std::string file; + // Error callback function. + void error(const char* fmt, ...); +}; + +#endif/*__PRACRO_TEMPLATEHEADERPARSER_H__*/ |