2003-09-11 10:26:53 +00:00
|
|
|
#ifndef ARABICA_DOCUMENTHANDLER_H
|
|
|
|
#define ARABICA_DOCUMENTHANDLER_H
|
2002-06-21 11:16:28 +00:00
|
|
|
// SAX document handler.
|
|
|
|
// $Id$
|
|
|
|
|
2007-09-04 22:55:47 +00:00
|
|
|
#include <SAX/ArabicaConfig.hpp>
|
2003-09-09 11:14:48 +00:00
|
|
|
|
2007-09-05 09:49:18 +00:00
|
|
|
namespace Arabica
|
|
|
|
{
|
2002-06-21 11:16:28 +00:00
|
|
|
namespace SAX
|
|
|
|
{
|
|
|
|
|
2007-09-05 22:08:51 +00:00
|
|
|
template<class string_type, class string_adaptor> class Locator;
|
|
|
|
template<class string_type, class string_adaptor> class AttributeList;
|
2002-06-21 11:16:28 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Receive notification of general document events.
|
|
|
|
*
|
|
|
|
* This is the main interface that most SAX applications
|
|
|
|
* implement: if the application needs to be informed of basic parsing
|
|
|
|
* events, it implements this interface and registers an instance with
|
|
|
|
* the SAX parser using the setDocumentHandler method. The parser
|
|
|
|
* uses the instance to report basic document-related events like
|
|
|
|
* the start and end of elements and character data.
|
|
|
|
*
|
|
|
|
* The order of events in this interface is very important, and
|
|
|
|
* mirrors the order of information in the document itself. For
|
|
|
|
* example, all of an element's content (character data, processing
|
|
|
|
* instructions, and/or subelements) will appear, in order, between
|
|
|
|
* the startElement event and the corresponding endElement event.
|
|
|
|
*
|
|
|
|
* Application writers who do not want to implement the entire
|
|
|
|
* interface can derive a class from HandlerBase, which implements
|
|
|
|
* the default functionality; parser writers can instantiate
|
|
|
|
* HandlerBase to obtain a default handler. The application can find
|
|
|
|
* the location of any document event using the Locator interface
|
|
|
|
* supplied by the Parser through the setDocumentLocator method.
|
|
|
|
*
|
|
|
|
* @author Jez Higgins, jez@jezuk.co.uk
|
|
|
|
* @version 0.1
|
2007-09-05 12:57:07 +00:00
|
|
|
* @see Parser#setDocumentHandler
|
|
|
|
* @see Locator
|
|
|
|
* @see HandlerBase
|
2002-06-21 11:16:28 +00:00
|
|
|
*/
|
2007-09-05 22:08:51 +00:00
|
|
|
template<class string_type, class string_adaptor>
|
2007-09-05 12:57:07 +00:00
|
|
|
class DocumentHandler
|
2002-06-21 11:16:28 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
typedef string_type stringT;
|
2007-09-05 22:08:51 +00:00
|
|
|
typedef Locator<string_type, string_adaptor> LocatorT;
|
|
|
|
typedef AttributeList<string_type, string_adaptor> AttributeListT;
|
2002-06-21 11:16:28 +00:00
|
|
|
|
2007-09-05 12:57:07 +00:00
|
|
|
virtual ~DocumentHandler() { }
|
2002-06-21 11:16:28 +00:00
|
|
|
|
|
|
|
virtual void setDocumentLocator(const LocatorT& locator) = 0;
|
|
|
|
|
|
|
|
virtual void startDocument() = 0;
|
|
|
|
virtual void endDocument() = 0;
|
|
|
|
|
|
|
|
virtual void startElement(const stringT& name,
|
|
|
|
const AttributeListT& atts) = 0;
|
|
|
|
virtual void endElement(const stringT& name) = 0;
|
|
|
|
|
|
|
|
virtual void characters(const stringT& ch) = 0;
|
|
|
|
|
|
|
|
virtual void ignorableWhitespace(const stringT& ch) = 0;
|
|
|
|
|
|
|
|
virtual void processingInstruction(const stringT& target,
|
|
|
|
const stringT& data) = 0;
|
2007-09-05 12:57:07 +00:00
|
|
|
}; // class DocumentHandler
|
2002-06-21 11:16:28 +00:00
|
|
|
|
2007-09-05 09:49:18 +00:00
|
|
|
} // namespace SAX
|
|
|
|
} // namespace Arabica
|
2002-06-21 11:16:28 +00:00
|
|
|
|
|
|
|
#endif
|
|
|
|
// end of file
|