<?xml version="1.0" encoding="iso-8859-1"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <!-- qxml.cpp --> <head> <title>Qt 4.6: QXmlReader Class Reference</title> <link href="classic.css" rel="stylesheet" type="text/css" /> </head> <body> <a name="//apple_ref/cpp/cl//QXmlReader"></a> <table border="0" cellpadding="0" cellspacing="0" width="100%"> <tr> <td align="left" valign="top" width="32"><a href="http://qt.nokia.com/"><img src="images/qt-logo.png" align="left" border="0" /></a></td> <td width="1"> </td><td class="postheader" valign="center"><a href="index.html"><font color="#004faf">Home</font></a> · <a href="classes.html"><font color="#004faf">All Classes</font></a> · <a href="functions.html"><font color="#004faf">All Functions</font></a> · <a href="overviews.html"><font color="#004faf">Overviews</font></a></td></tr></table><h1 class="title">QXmlReader Class Reference<br /><span class="small-subtitle">[<a href="qtxml.html">QtXml</a> module]</span> </h1> <p>The QXmlReader class provides an interface for XML readers (i.e. parsers). <a href="#details">More...</a></p> <pre> #include <QXmlReader></pre><p><b>This class is not part of the Qt GUI Framework Edition.</b></p> <p>Inherited by <a href="qxmlsimplereader.html">QXmlSimpleReader</a>.</p> <p><b>Note:</b> All functions in this class are <a href="threads-reentrancy.html#reentrant">reentrant</a>.</p> <ul> <li><a href="qxmlreader-members.html">List of all members, including inherited members</a></li> <li><a href="qxmlreader-obsolete.html">Obsolete members</a></li> </ul> <hr /> <a name="public-functions"></a> <h2>Public Functions</h2> <table class="alignedsummary" border="0" cellpadding="0" cellspacing="0" width="100%"> <tr><td class="memItemLeft" align="right" valign="top">virtual </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#dtor.QXmlReader">~QXmlReader</a></b> ()</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual QXmlDTDHandler * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#DTDHandler">DTDHandler</a></b> () const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual QXmlContentHandler * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#contentHandler">contentHandler</a></b> () const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual QXmlDeclHandler * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#declHandler">declHandler</a></b> () const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual QXmlEntityResolver * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#entityResolver">entityResolver</a></b> () const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual QXmlErrorHandler * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#errorHandler">errorHandler</a></b> () const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual bool </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#feature">feature</a></b> ( const QString & <i>name</i>, bool * <i>ok</i> = 0 ) const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual bool </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#hasFeature">hasFeature</a></b> ( const QString & <i>name</i> ) const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual bool </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#hasProperty">hasProperty</a></b> ( const QString & <i>name</i> ) const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual QXmlLexicalHandler * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#lexicalHandler">lexicalHandler</a></b> () const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual bool </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#parse">parse</a></b> ( const QXmlInputSource * <i>input</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void * </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#property">property</a></b> ( const QString & <i>name</i>, bool * <i>ok</i> = 0 ) const = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setContentHandler">setContentHandler</a></b> ( QXmlContentHandler * <i>handler</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setDTDHandler">setDTDHandler</a></b> ( QXmlDTDHandler * <i>handler</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setDeclHandler">setDeclHandler</a></b> ( QXmlDeclHandler * <i>handler</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setEntityResolver">setEntityResolver</a></b> ( QXmlEntityResolver * <i>handler</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setErrorHandler">setErrorHandler</a></b> ( QXmlErrorHandler * <i>handler</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setFeature">setFeature</a></b> ( const QString & <i>name</i>, bool <i>value</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setLexicalHandler">setLexicalHandler</a></b> ( QXmlLexicalHandler * <i>handler</i> ) = 0</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><b><a href="qxmlreader.html#setProperty">setProperty</a></b> ( const QString & <i>name</i>, void * <i>value</i> ) = 0</td></tr> </table> <a name="details"></a> <hr /> <h2>Detailed Description</h2> <p>The QXmlReader class provides an interface for XML readers (i.e. parsers).</p> <p>This abstract class provides an interface for all of Qt's XML readers. Currently there is only one implementation of a reader included in Qt's XML module: <a href="qxmlsimplereader.html">QXmlSimpleReader</a>. In future releases there might be more readers with different properties available (e.g. a validating parser).</p> <p>The design of the XML classes follows the <a href="http://www.saxproject.org/">SAX2 Java interface</a>, with the names adapted to fit Qt naming conventions. It should be very easy for anybody who has worked with SAX2 to get started with the Qt XML classes.</p> <p>All readers use the class <a href="qxmlinputsource.html">QXmlInputSource</a> to read the input document. Since you are normally interested in particular content in the XML document, the reader reports the content through special handler classes (<a href="qxmldtdhandler.html">QXmlDTDHandler</a>, <a href="qxmldeclhandler.html">QXmlDeclHandler</a>, <a href="qxmlcontenthandler.html">QXmlContentHandler</a>, <a href="qxmlentityresolver.html">QXmlEntityResolver</a>, <a href="qxmlerrorhandler.html">QXmlErrorHandler</a> and <a href="qxmllexicalhandler.html">QXmlLexicalHandler</a>), which you must subclass, if you want to process the contents.</p> <p>Since the handler classes only describe interfaces you must implement all the functions. We provide the <a href="qxmldefaulthandler.html">QXmlDefaultHandler</a> class to make this easier: it implements a default behavior (do nothing) for all functions, so you can subclass it and just implement the functions you are interested in.</p> <p>Features and properties of the reader can be set with <a href="qxmlreader.html#setFeature">setFeature</a>() and <a href="qxmlreader.html#setProperty">setProperty</a>() respectively. You can set the reader to use your own subclasses with <a href="qxmlreader.html#setEntityResolver">setEntityResolver</a>(), <a href="qxmlreader.html#setDTDHandler">setDTDHandler</a>(), <a href="qxmlreader.html#setContentHandler">setContentHandler</a>(), <a href="qxmlreader.html#setErrorHandler">setErrorHandler</a>(), <a href="qxmlreader.html#setLexicalHandler">setLexicalHandler</a>() and <a href="qxmlreader.html#setDeclHandler">setDeclHandler</a>(). The parse itself is started with a call to <a href="qxmlreader.html#parse">parse</a>().</p> <p>See also <a href="qxmlsimplereader.html">QXmlSimpleReader</a>.</p> <hr /> <h2>Member Function Documentation</h2> <a name="//apple_ref/cpp/instm/QXmlReader/~QXmlReader"></a> <h3 class="fn"><a name="dtor.QXmlReader"></a>QXmlReader::~QXmlReader () <tt> [virtual]</tt></h3> <p>Destroys the reader.</p> <a name="//apple_ref/cpp/instm/QXmlReader/DTDHandler"></a> <h3 class="fn"><a name="DTDHandler"></a><a href="qxmldtdhandler.html">QXmlDTDHandler</a> * QXmlReader::DTDHandler () const <tt> [pure virtual]</tt></h3> <p>Returns the DTD handler or 0 if none was set.</p> <p>See also <a href="qxmlreader.html#setDTDHandler">setDTDHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/contentHandler"></a> <h3 class="fn"><a name="contentHandler"></a><a href="qxmlcontenthandler.html">QXmlContentHandler</a> * QXmlReader::contentHandler () const <tt> [pure virtual]</tt></h3> <p>Returns the content handler or 0 if none was set.</p> <p>See also <a href="qxmlreader.html#setContentHandler">setContentHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/declHandler"></a> <h3 class="fn"><a name="declHandler"></a><a href="qxmldeclhandler.html">QXmlDeclHandler</a> * QXmlReader::declHandler () const <tt> [pure virtual]</tt></h3> <p>Returns the declaration handler or 0 if none was set.</p> <p>See also <a href="qxmlreader.html#setDeclHandler">setDeclHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/entityResolver"></a> <h3 class="fn"><a name="entityResolver"></a><a href="qxmlentityresolver.html">QXmlEntityResolver</a> * QXmlReader::entityResolver () const <tt> [pure virtual]</tt></h3> <p>Returns the entity resolver or 0 if none was set.</p> <p>See also <a href="qxmlreader.html#setEntityResolver">setEntityResolver</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/errorHandler"></a> <h3 class="fn"><a name="errorHandler"></a><a href="qxmlerrorhandler.html">QXmlErrorHandler</a> * QXmlReader::errorHandler () const <tt> [pure virtual]</tt></h3> <p>Returns the error handler or 0 if none is set.</p> <p>See also <a href="qxmlreader.html#setErrorHandler">setErrorHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/feature"></a> <h3 class="fn"><a name="feature"></a>bool QXmlReader::feature ( const <a href="qstring.html">QString</a> & <i>name</i>, bool * <i>ok</i> = 0 ) const <tt> [pure virtual]</tt></h3> <p>If the reader has the feature called <i>name</i>, the feature's value is returned. If no such feature exists the return value is undefined.</p> <p>If <i>ok</i> is not 0: <tt>*</tt><i>ok</i> is set to true if the reader has the feature called <i>name</i>; otherwise <tt>*</tt><i>ok</i> is set to false.</p> <p>See also <a href="qxmlreader.html#setFeature">setFeature</a>() and <a href="qxmlreader.html#hasFeature">hasFeature</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/hasFeature"></a> <h3 class="fn"><a name="hasFeature"></a>bool QXmlReader::hasFeature ( const <a href="qstring.html">QString</a> & <i>name</i> ) const <tt> [pure virtual]</tt></h3> <p>Returns <tt>true</tt> if the reader has the feature called <i>name</i>; otherwise returns false.</p> <p>See also <a href="qxmlreader.html#feature">feature</a>() and <a href="qxmlreader.html#setFeature">setFeature</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/hasProperty"></a> <h3 class="fn"><a name="hasProperty"></a>bool QXmlReader::hasProperty ( const <a href="qstring.html">QString</a> & <i>name</i> ) const <tt> [pure virtual]</tt></h3> <p>Returns true if the reader has the property <i>name</i>; otherwise returns false.</p> <p>See also <a href="qxmlreader.html#property">property</a>() and <a href="qxmlreader.html#setProperty">setProperty</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/lexicalHandler"></a> <h3 class="fn"><a name="lexicalHandler"></a><a href="qxmllexicalhandler.html">QXmlLexicalHandler</a> * QXmlReader::lexicalHandler () const <tt> [pure virtual]</tt></h3> <p>Returns the lexical handler or 0 if none was set.</p> <p>See also <a href="qxmlreader.html#setLexicalHandler">setLexicalHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/parse"></a> <h3 class="fn"><a name="parse"></a>bool QXmlReader::parse ( const <a href="qxmlinputsource.html">QXmlInputSource</a> * <i>input</i> ) <tt> [pure virtual]</tt></h3> <p>Reads an XML document from <i>input</i> and parses it. Returns true if the parsing was successful; otherwise returns false.</p> <a name="//apple_ref/cpp/instm/QXmlReader/property"></a> <h3 class="fn"><a name="property"></a>void * QXmlReader::property ( const <a href="qstring.html">QString</a> & <i>name</i>, bool * <i>ok</i> = 0 ) const <tt> [pure virtual]</tt></h3> <p>If the reader has the property <i>name</i>, this function returns the value of the property; otherwise the return value is undefined.</p> <p>If <i>ok</i> is not 0: if the reader has the <i>name</i> property <tt>*</tt><i>ok</i> is set to true; otherwise <tt>*</tt><i>ok</i> is set to false.</p> <p>See also <a href="qxmlreader.html#setProperty">setProperty</a>() and <a href="qxmlreader.html#hasProperty">hasProperty</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setContentHandler"></a> <h3 class="fn"><a name="setContentHandler"></a>void QXmlReader::setContentHandler ( <a href="qxmlcontenthandler.html">QXmlContentHandler</a> * <i>handler</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the content handler to <i>handler</i>.</p> <p>See also <a href="qxmlreader.html#contentHandler">contentHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setDTDHandler"></a> <h3 class="fn"><a name="setDTDHandler"></a>void QXmlReader::setDTDHandler ( <a href="qxmldtdhandler.html">QXmlDTDHandler</a> * <i>handler</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the DTD handler to <i>handler</i>.</p> <p>See also <a href="qxmlreader.html#DTDHandler">DTDHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setDeclHandler"></a> <h3 class="fn"><a name="setDeclHandler"></a>void QXmlReader::setDeclHandler ( <a href="qxmldeclhandler.html">QXmlDeclHandler</a> * <i>handler</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the declaration handler to <i>handler</i>.</p> <p>See also <a href="qxmlreader.html#declHandler">declHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setEntityResolver"></a> <h3 class="fn"><a name="setEntityResolver"></a>void QXmlReader::setEntityResolver ( <a href="qxmlentityresolver.html">QXmlEntityResolver</a> * <i>handler</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the entity resolver to <i>handler</i>.</p> <p>See also <a href="qxmlreader.html#entityResolver">entityResolver</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setErrorHandler"></a> <h3 class="fn"><a name="setErrorHandler"></a>void QXmlReader::setErrorHandler ( <a href="qxmlerrorhandler.html">QXmlErrorHandler</a> * <i>handler</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the error handler to <i>handler</i>. Clears the error handler if <i>handler</i> is 0.</p> <p>See also <a href="qxmlreader.html#errorHandler">errorHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setFeature"></a> <h3 class="fn"><a name="setFeature"></a>void QXmlReader::setFeature ( const <a href="qstring.html">QString</a> & <i>name</i>, bool <i>value</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the feature called <i>name</i> to the given <i>value</i>. If the reader doesn't have the feature nothing happens.</p> <p>See also <a href="qxmlreader.html#feature">feature</a>() and <a href="qxmlreader.html#hasFeature">hasFeature</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setLexicalHandler"></a> <h3 class="fn"><a name="setLexicalHandler"></a>void QXmlReader::setLexicalHandler ( <a href="qxmllexicalhandler.html">QXmlLexicalHandler</a> * <i>handler</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the lexical handler to <i>handler</i>.</p> <p>See also <a href="qxmlreader.html#lexicalHandler">lexicalHandler</a>().</p> <a name="//apple_ref/cpp/instm/QXmlReader/setProperty"></a> <h3 class="fn"><a name="setProperty"></a>void QXmlReader::setProperty ( const <a href="qstring.html">QString</a> & <i>name</i>, void * <i>value</i> ) <tt> [pure virtual]</tt></h3> <p>Sets the property <i>name</i> to <i>value</i>. If the reader doesn't have the property nothing happens.</p> <p>See also <a href="qxmlreader.html#property">property</a>() and <a href="qxmlreader.html#hasProperty">hasProperty</a>().</p> <p /><address><hr /><div align="center"> <table width="100%" cellspacing="0" border="0"><tr class="address"> <td width="40%" align="left">Copyright © 2010 Nokia Corporation and/or its subsidiary(-ies)</td> <td width="20%" align="center"><a href="trademarks.html">Trademarks</a></td> <td width="40%" align="right"><div align="right">Qt 4.6.3</div></td> </tr></table></div></address></body> </html>