diff options
| author | MenTaLguY <mental@rydia.net> | 2006-01-16 02:36:01 +0000 |
|---|---|---|
| committer | mental <mental@users.sourceforge.net> | 2006-01-16 02:36:01 +0000 |
| commit | 179fa413b047bede6e32109e2ce82437c5fb8d34 (patch) | |
| tree | a5a6ac2c1708bd02288fbd8edb2ff500ff2e0916 /src/dom/xmlreader.h | |
| download | inkscape-179fa413b047bede6e32109e2ce82437c5fb8d34.tar.gz inkscape-179fa413b047bede6e32109e2ce82437c5fb8d34.zip | |
moving trunk for module inkscape
(bzr r1)
Diffstat (limited to 'src/dom/xmlreader.h')
| -rwxr-xr-x | src/dom/xmlreader.h | 129 |
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_*/ |
