Files
loongoffice/shell/inc/internal/xml_parser.hxx
Rüdiger Timm ab1c438e9d INTEGRATION: CWS ooo20040704 (1.2.52); FILE MERGED
2004/06/28 10:32:41 cmc 1.2.52.1: #i30801 allow using system libs if possible
2004-09-08 13:34:24 +00:00

187 lines
6.4 KiB
C++

/*************************************************************************
*
* $RCSfile: xml_parser.hxx,v $
*
* $Revision: 1.4 $
*
* last change: $Author: rt $ $Date: 2004-09-08 14:34:11 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifndef _XML_PARSER_HXX_
#define _XML_PARSER_HXX_
#ifdef SYSTEM_EXPAT
#include <expat.h>
#else
#include <external/expat/xmlparse.h>
#endif
#include <stdexcept>
//-----------------------------------------------------
class xml_parser_exception : public std::runtime_error
{
public:
xml_parser_exception(
const std::string& error_msg,
int error_code,
int line_number,
int column_number,
long byte_index) :
std::runtime_error(error_msg),
error_code_(error_code),
line_number_(line_number),
column_number_(column_number),
byte_index_(byte_index)
{}
int error_code_;
int line_number_;
int column_number_;
long byte_index_;
};
//-----------------------------------------------------
// Simple wrapper around expat, the xml parser library
// created by James Clark
//-----------------------------------------------------
class i_xml_parser_event_handler;
class xml_parser
{
public:
//########################################################
xml_parser(const XML_Char* EncodingName = 0);
//########################################################
xml_parser(const XML_Char* EncodingName, XML_Char NamespaceSeparator);
//########################################################
~xml_parser();
//########################################################
/** Parse a XML data stream
@param pXmlData
Pointer to a buffer containing the xml data
@param Length
Length of the buffer containing the xml data
@param IsFinal
Indicates whether these are the last xml data
of an xml document to parse. For very large
xml documents it may be usefull to read and
parse the document partially.
@precond XmlData must not be null
@throws SaxException
If the used Sax parser returns an error. The SaxException
contains detailed information about the error. */
void parse(const char* XmlData, size_t Length, bool IsFinal = true);
//########################################################
/** Set a document handler
@descr A document handler implements the interface i_xml_parser_event_handler.
The document handler receive notifications of various events
from the sax parser for instance "start_document".
The client is responsible for the life time management of
the given document handler, that means the document handler
instance must exist until a new one was set or until the parser
no longer exist.
@param SaxDocumentHandler
The new document handler, may be null if not interessted in
sax parser events.
@postcond currently used document handler == pSaxDocumentHandler */
void set_document_handler(i_xml_parser_event_handler* event_handler);
//########################################################
/** Returns the currently used document handler or null if
no document handler was set before. */
i_xml_parser_event_handler* get_document_handler() const;
//############################################
void set_encoding(const XML_Char* Encoding);
private:
void init();
//####################################
// callback functions
static void xml_start_element_handler(void* UserData, const XML_Char* name, const XML_Char** atts);
static void xml_end_element_handler(void* UserData, const XML_Char* name);
static void xml_character_data_handler(void* UserData, const XML_Char* s, int len);
static void xml_comment_handler(void* UserData, const XML_Char* Data);
private:
i_xml_parser_event_handler* document_handler_;
XML_Parser xml_parser_;
// prevent copy and assignment
private:
xml_parser(const xml_parser&);
xml_parser& operator=(const xml_parser&);
};
#endif