summaryrefslogtreecommitdiffstats
path: root/src/dom/xmlreader.h
diff options
context:
space:
mode:
authorMenTaLguY <mental@rydia.net>2006-01-16 02:36:01 +0000
committermental <mental@users.sourceforge.net>2006-01-16 02:36:01 +0000
commit179fa413b047bede6e32109e2ce82437c5fb8d34 (patch)
treea5a6ac2c1708bd02288fbd8edb2ff500ff2e0916 /src/dom/xmlreader.h
downloadinkscape-179fa413b047bede6e32109e2ce82437c5fb8d34.tar.gz
inkscape-179fa413b047bede6e32109e2ce82437c5fb8d34.zip
moving trunk for module inkscape
(bzr r1)
Diffstat (limited to 'src/dom/xmlreader.h')
-rwxr-xr-xsrc/dom/xmlreader.h129
1 files changed, 129 insertions, 0 deletions
diff --git a/src/dom/xmlreader.h b/src/dom/xmlreader.h
new file mode 100755
index 000000000..4b80081e2
--- /dev/null
+++ b/src/dom/xmlreader.h
@@ -0,0 +1,129 @@
+#ifndef _XMLREADER_H_
+#define _XMLREADER_H_
+
+/**
+ * Phoebe DOM Implementation.
+ *
+ * This is a C++ approximation of the W3C DOM model, which follows
+ * fairly closely the specifications in the various .idl files, copies of
+ * which are provided for reference. Most important is this one:
+ *
+ * http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/idl-definitions.html
+ *
+ * Authors:
+ * Bob Jamison
+ *
+ * Copyright (C) 2005 Bob Jamison
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+
+#include "dom.h"
+
+namespace org
+{
+namespace w3c
+{
+namespace dom
+{
+
+
+
+class XmlReader
+{
+public:
+
+ /**
+ *
+ */
+ XmlReader();
+
+ /**
+ *
+ */
+ XmlReader(bool parseAsData);
+
+ /**
+ *
+ */
+ virtual ~XmlReader();
+
+ /**
+ *
+ */
+ org::w3c::dom::Document *parse(const DOMString &buf,
+ int offset, int length);
+
+ /**
+ *
+ */
+ org::w3c::dom::Document *parse(const DOMString &buf);
+
+ /**
+ *
+ */
+ org::w3c::dom::Document *parseFile(char *fileName);
+
+
+protected:
+
+ void error(char *format, ...);
+
+ int get(int ch);
+ int peek(int ch);
+ bool match(int pos, char *str);
+
+ int skipwhite(int ch);
+ int getWord(int pos, DOMString &result);
+ int getPrefixedWord(int pos,
+ DOMString &prefix,
+ DOMString &shortWord,
+ DOMString &fullWord);
+ int getQuoted(int p, DOMString &result);
+
+ int parseVersion(int pos);
+ int parseDoctype(int pos);
+
+ int parseCDATA (int pos, CDATASection *cdata);
+ int parseComment(int pos, Comment *comment);
+ int parseText(int pos, Text *test);
+
+ int parseEntity(int pos, DOMString &buf);
+
+ int parseAttributes(int p0, Node *node, bool *quickClose);
+
+ int parseNode(int p0, Node *node, int depth);
+
+ bool keepGoing;
+ bool parseAsData;
+ int pos; //current parse position
+ int len; //length of parsed region
+ DOMString parsebuf;
+
+ DOMString loadFile(char *fileName);
+
+ int lineNr;
+ int colNr;
+
+ Document *document;
+
+};
+
+} //namespace dom
+} //namespace w3c
+} //namespace org
+
+#endif /*_XMLREADER_H_*/