Home | All Classes | Main Classes | Annotated | Grouped Classes | Functions |
The QXmlSimpleReader class provides an implementation of a simple XML reader (parser). More...
All the functions in this class are reentrant when Qt is built with thread support.
#include <qxml.h>
Inherits QXmlReader.
This XML reader is sufficient for simple parsing tasks. The reader:
Documents are parsed with a call to parse().
See also XML.
If incremental is TRUE, the parser does not return FALSE when it reaches the end of the input without reaching the end of the XML file. Instead it stores the state of the parser so that parsing can be continued at a later stage when more data is available. You can use the function parseContinue() to continue with parsing. This class stores a pointer to the input source input and the parseContinue() function tries to read from that input souce. This means that you should not delete the input source input until you've finished your calls to parseContinue(). If you call this function with incremental TRUE whilst an incremental parse is in progress a new parsing session will be started and the previous session lost.
If incremental is FALSE, this function behaves like the normal parse function, i.e. it returns FALSE when the end of input is reached without reaching the end of the XML file and the parsing cannot be continued.
See also parseContinue() and QSocket.
Examples: xml/tagreader-with-features/tagreader.cpp and xml/tagreader/tagreader.cpp.
Returns FALSE if a parsing error occurs; otherwise returns TRUE.
If the input source returns an empty string for the function QXmlInputSource::data(), then this means that the end of the XML file has been reached; this is quite important, especially if you want to use the reader to parse more than one XML file.
The case of the end of the XML file being reached without having finished parsing is not considered to be an error: you can continue parsing at a later stage by calling this function again when there is more data available to parse.
This function assumes that the end of the XML document is reached if the QXmlInputSource::next() function returns QXmlInputSource::EndOfDocument. If the parser has not finished parsing when it encounters this symbol, it is an error and FALSE is returned.
See also parse() and QXmlInputSource::next().
If the feature is not recognized, it is ignored.
The following features are supported:
Feature | Notes |
---|---|
http://xml.org/sax/features/namespaces | If this feature is TRUE, namespace processing is performed. |
http://xml.org/sax/features/namespace-prefixes | If this feature is TRUE, the the original prefixed names and attributes used for namespace declarations are reported. |
http://trolltech.com/xml/features/report-whitespace-only-CharData | If this feature is TRUE, CharData that only contain whitespace are not ignored, but are reported via QXmlContentHandler::characters(). |
http://trolltech.com/xml/features/report-start-end-entity | If this feature is TRUE, the parser reports QXmlContentHandler::startEntity() and QXmlContentHandler::endEntity() events. So character data might be reported in chunks. If this feature is FALSE, the parser does not report those events, but rather silently substitutes the entities and reports the character data in one chunk. |
** $Id: qt/tagreader.cpp 3.3.7 edited Aug 31 2005 $
reader.setFeature( "http://xml.org/sax/features/namespace-prefixes", TRUE );
(Code taken from xml/tagreader-with-features/tagreader.cpp)
See also feature() and hasFeature().
Example: xml/tagreader-with-features/tagreader.cpp.
Reimplemented from QXmlReader.
This file is part of the Qt toolkit. Copyright © 1995-2005 Trolltech. All Rights Reserved.
Copyright © 2005 Trolltech | Trademarks | Qt 3.3.7
|