summaryrefslogtreecommitdiffstats
path: root/addon/xmlparse/main.cpp
diff options
context:
space:
mode:
authorDimitri van Heesch <dimitri@stack.nl>2001-08-19 18:13:14 (GMT)
committerDimitri van Heesch <dimitri@stack.nl>2001-08-19 18:13:14 (GMT)
commit8f7c9d9ba3b6c4e87c87deb6775d4bf642939e77 (patch)
tree3ff0575884709cdc92f9e462441672f3549ab054 /addon/xmlparse/main.cpp
parentb5cbb79d114ed13945bc882ac8eef1c2be967bbf (diff)
downloadDoxygen-8f7c9d9ba3b6c4e87c87deb6775d4bf642939e77.zip
Doxygen-8f7c9d9ba3b6c4e87c87deb6775d4bf642939e77.tar.gz
Doxygen-8f7c9d9ba3b6c4e87c87deb6775d4bf642939e77.tar.bz2
Release-1.2.9-20010819
Diffstat (limited to 'addon/xmlparse/main.cpp')
-rw-r--r--addon/xmlparse/main.cpp60
1 files changed, 48 insertions, 12 deletions
diff --git a/addon/xmlparse/main.cpp b/addon/xmlparse/main.cpp
index 7fdb60a..3575c16 100644
--- a/addon/xmlparse/main.cpp
+++ b/addon/xmlparse/main.cpp
@@ -21,6 +21,13 @@
#include <qdict.h>
#include <qlist.h>
+//#define USE_DOM
+#define USE_SAX
+
+#ifdef USE_DOM
+#include <qdom.h>
+#endif
+
class ErrorHandler : public QXmlErrorHandler
{
public:
@@ -55,18 +62,47 @@ int main(int argc,char **argv)
exit(1);
}
- //for (;;)
- //{
- QFile xmlFile(argv[1]);
- MainHandler handler;
- ErrorHandler errorHandler;
- QXmlInputSource source( xmlFile );
- QXmlSimpleReader reader;
- reader.setContentHandler( &handler );
- reader.setErrorHandler( &errorHandler );
- reader.parse( source );
- //}
-
+ QFile xmlFile(argv[1]);
+ if (!xmlFile.open( IO_ReadOnly ))
+ {
+ qFatal("Could not read %s",argv[1] );
+ }
+
+#ifdef USE_SAX
+ MainHandler handler;
+ ErrorHandler errorHandler;
+ QXmlInputSource source( xmlFile );
+ QXmlSimpleReader reader;
+ reader.setContentHandler( &handler );
+ reader.setErrorHandler( &errorHandler );
+ reader.parse( source );
+#endif
+
+#ifdef USE_DOM
+ QDomDocument doc;
+ doc.setContent( &xmlFile );
+
+ QDomElement de = doc.documentElement();
+
+ printf("docElem=%s\n",de.tagName().data());
+
+ QDomNode n = de.firstChild();
+ while( !n.isNull() )
+ {
+ QDomElement e = n.toElement(); // try to convert the node to an element.
+ if( !e.isNull() )
+ { // the node was really an element.
+ printf("direct child %s id=%s kind=%s\n",
+ e.tagName().data(),
+ e.attribute("id").data(),
+ e.attribute("kind").data()
+ );
+ }
+ n = n.nextSibling();
+ }
+
+#endif
+
return 0;
}