#include <ixml/ixmlparser.hpp>
#include <ixml/ixmldebug.hpp>
#include <UPnPsdk/port.hpp>
#include <cassert>
#include <cstddef>
#include <cstdio>
#include <cstring>
Go to the source code of this file.
Classes | |
struct | char_info |
char_info More... | |
Macros | |
#define | LETTERTABLESIZE (sizeof(Letter) / sizeof(Letter[0])) |
The size of the letter table array. | |
#define | NAMECHARTABLESIZE (sizeof(NameChar) / sizeof(NameChar[0])) |
The name char table array size. | |
Typedefs | |
typedef struct char_info | char_info_t |
char_info | |
Functions | |
static void | Parser_freeElementStackItem (IXML_ElementStack *pItem) |
Frees one ElementStack item. | |
static void | Parser_freeNsURI (IXML_NamespaceURI *pNsURI) |
Frees namespaceURI item. | |
static void | Parser_free (Parser *xmlParser) |
Frees all temporary memory allocated by xmlparser. | |
static int | Parser_skipDocType (char **pstr) |
Skips document type declaration. | |
static int | Parser_skipString (char **pstrSrc, const char *strSkipKey) |
Skips all characters in the string until it finds the skip key. Then it skips the skip key and returns. | |
static void | Parser_skipBom (Parser *xmlParser) |
Skip UTF-8 byte order mark. | |
static void | Parser_skipWhiteSpaces (Parser *xmlParser) |
Skip white spaces. | |
static int | Parser_skipXMLDecl (Parser *xmlParser) |
Skips XML declarations. | |
static int | Parser_skipComment (char **pstrSrc) |
Skips all characters in the string until it finds the skip key. Then it skips the skip key and returns. | |
static int | Parser_skipMisc (Parser *xmlParser) |
Skip comment, PI and white space. | |
static int | Parser_skipProlog (Parser *xmlParser) |
Skip prolog. | |
static int | Parser_setLastElem (Parser *xmlParser, const char *s) |
Set the last element to be the given string. | |
static void | Parser_clearTokenBuf (Parser *xmlParser) |
Clear token buffer. | |
static int | Parser_UTF8ToInt (const char *ss, ptrdiff_t *len) |
In UTF-8, characters are encoded using sequences of 1 to 6 octets. This functions will return a UTF-8 character value and its octets number. | |
static int | Parser_isCharInTable (int c, char_info_t *tbl, int sz) |
Will determine whether character c is in the table of tbl (either Letter table or NameChar table). | |
static int | Parser_isNameChar (int c, int bNameChar) |
Check whether c (int) is in LetterTable or NameCharTable. | |
static int | Parser_isXmlChar (int c) |
see XML 1.0 (2nd Edition) 2.2. | |
static int | Parser_getChar (const char *src, ptrdiff_t *cLen) |
Returns next char value and its length. | |
static int | Parser_appendTokBufChar (Parser *xmlParser, char c) |
Appends c to token buffer. | |
static int | Parser_intToUTF8 (int c, utf8char s) |
Encodes a character to its UTF-8 character string, and return its length. | |
static int | Parser_appendTokBufStr (Parser *xmlParser, const char *s) |
Appends string s to token buffer. | |
static int | Parser_copyToken (Parser *xmlParser, const char *src, ptrdiff_t len) |
Copy string in src into xml parser token buffer. | |
static ptrdiff_t | Parser_getNextToken (Parser *xmlParser) |
Return the length of next token in tokenBuff. | |
static char * | safe_strdup (const char *s) |
Version of strdup() that handles NULL input. | |
static int | Parser_processSTag (Parser *xmlParser, IXML_Node *node) |
Processes the STag as defined by XML spec. | |
static int | Parser_skipPI (char **pSrc) |
Parser_skipPI. | |
static int | Parser_processCDSect (char **pSrc, IXML_Node *node) |
Processes CDSection as defined by XML spec. | |
static int | Parser_processContent (Parser *xmlParser, IXML_Node *node) |
Processes the CONTENT as defined in XML spec. | |
static int | Parser_processETag (Parser *xmlParser, IXML_Node *node, int *bETag) |
Process ETag as defined by XML spec. | |
static char * | Parser_getNameSpace (Parser *xmlParser, const char *prefix) |
Unimplemented function. | |
static int | Parser_addNamespace (Parser *xmlParser) |
Add a namespace definition. | |
static int | Parser_xmlNamespace (Parser *xmlParser, IXML_Node *newNode) |
Add namespace definition. | |
static int | Parser_processAttribute (Parser *xmlParser, IXML_Node *node) |
Processes attribute. | |
static int | Parser_getNextNode (Parser *xmlParser, IXML_Node *node, int *bETag) |
Get the next node. | |
static int | Parser_ElementPrefixDefined (Parser *xmlParser, IXML_Node *newNode, char **nsURI) |
Decides whether element's prefix is already defined. | |
static int | Parser_setElementNamespace (IXML_Element *newElement, const char *nsURI) |
Set element's namespace. | |
static int | isDuplicateAttribute (Parser *xmlParser, IXML_Node *newAttrNode) |
Reports whether the new attribute is the same as an existing one. | |
static int | Parser_processAttributeName (IXML_Document *rootDoc, Parser *xmlParser, IXML_Node *newNode) |
Processes the attribute name. | |
static int | Parser_pushElement (Parser *xmlParser, IXML_Node *newElement) |
Push a new element onto element stack. | |
static int | isTopLevelElement (Parser *xmlParser) |
Reports whether there is a top level element in the parser. | |
static int | Parser_hasDefaultNamespace (Parser *xmlParser, char **nsURI) |
Decide whether the current element has default namespace. | |
static int | Parser_processElementName (IXML_Document *rootDoc, Parser *xmlParser, IXML_Node *newNode) |
Processes element name. | |
static int | Parser_isValidEndElement (Parser *xmlParser, IXML_Node *newNode) |
Check if a new node->nodeName matches top of element stack. | |
static void | Parser_popElement (Parser *xmlParser) |
Remove element from element stack. | |
static int | Parser_eTagVerification (Parser *xmlParser, IXML_Node *newNode) |
Verifies endof element tag is the same as the openning element tag. | |
static int | Parser_parseDocument (IXML_Document **retDoc, Parser *xmlParser) |
Parses the xml file and returns the DOM document tree. | |
int | Parser_isValidXmlName (const DOMString name) |
Check to see whether name is a valid xml name. | |
void | Parser_setErrorChar (char c) |
Sets the error character. | |
static Parser * | Parser_init () |
Initializes a xml parser. | |
static int | Parser_readFileOrBuffer (Parser *xmlParser, const char *xmlFileName, int file) |
Read a xml file or buffer contents into xml parser. | |
int | Parser_LoadDocument (IXML_Document **retDoc, const char *xmlFileName, int file) |
Parses a xml file and return the DOM tree. | |
void | Parser_freeNodeContent (IXML_Node *nodeptr) |
Fees a node contents. | |
int | Parser_setNodePrefixAndLocalName (IXML_Node *node) |
Set the node prefix and localName as defined by the nodeName in the form of ns:name. | |
Variables | |
static char_info_t | Letter [] |
The letter table contains all characters in XML 1.0 plus ":", "_" and ideographic. | |
static char_info_t | NameChar [] |
The NameChar table contains CombiningChar, Extender, Digit, '-', '.', less '_', ':'. | |
struct char_info |
Definition at line 78 of file ixmlparser.cpp.
Class Members | ||
---|---|---|
unsigned short | l | |
unsigned short | h |
The size of the letter table array.
Definition at line 171 of file ixmlparser.cpp.
The name char table array size.
Definition at line 236 of file ixmlparser.cpp.
|
static |
Frees one ElementStack item.
[in] | pItem | The element stack item to free. |
Definition at line 241 of file ixmlparser.cpp.
|
static |
Frees namespaceURI item.
[in] | pNsURI | The name space URI item to free. |
Definition at line 262 of file ixmlparser.cpp.
|
static |
Frees all temporary memory allocated by xmlparser.
[in] | xmlParser | The XML parser. |
Definition at line 277 of file ixmlparser.cpp.
|
static |
Skips document type declaration.
[in,out] | pstr | The pointer to the skipped point. |
Definition at line 319 of file ixmlparser.cpp.
|
static |
Skips all characters in the string until it finds the skip key. Then it skips the skip key and returns.
[in,out] | pstrSrc | The pointer to the skipped point. |
[in] | strSkipKey | The skip key. |
Definition at line 361 of file ixmlparser.cpp.
|
static |
Skip UTF-8 byte order mark.
[in] | xmlParser | The XML parser. |
Definition at line 386 of file ixmlparser.cpp.
|
static |
Skip white spaces.
[in] | xmlParser | The XML parser. |
Definition at line 398 of file ixmlparser.cpp.
|
static |
Skips XML declarations.
[in,out] | xmlParser | The XML parser. |
Definition at line 410 of file ixmlparser.cpp.
|
static |
Skips all characters in the string until it finds the skip key. Then it skips the skip key and returns.
[in,out] | pstrSrc | The pointer to the skipped point. |
Definition at line 429 of file ixmlparser.cpp.
|
static |
Skip comment, PI and white space.
[in] | xmlParser | The XML parser. |
Definition at line 453 of file ixmlparser.cpp.
|
static |
Skip prolog.
[in,out] | xmlParser | The XML parser. |
Definition at line 487 of file ixmlparser.cpp.
|
static |
Set the last element to be the given string.
[in] | xmlParser | The XML parser. |
[in] | s | The string to copy from. |
Definition at line 526 of file ixmlparser.cpp.
|
static |
Clear token buffer.
[in] | xmlParser | The XML parser. |
Definition at line 544 of file ixmlparser.cpp.
|
static |
In UTF-8, characters are encoded using sequences of 1 to 6 octets. This functions will return a UTF-8 character value and its octets number.
[in] | ss | The pointer to the character to encode. |
[out] | len | The number of octets of the UTF-8 encoding of this character. |
Definition at line 556 of file ixmlparser.cpp.
|
static |
Will determine whether character c is in the table of tbl (either Letter table or NameChar table).
[in] | c | Character to check. |
[in] | tbl | Table to use. |
[in] | sz | Size of the table. |
Definition at line 623 of file ixmlparser.cpp.
|
static |
Check whether c (int) is in LetterTable or NameCharTable.
[in] | c | The character to check. |
[in] | bNameChar | 1 if you also want to check in the NameChar table. |
Definition at line 651 of file ixmlparser.cpp.
|
static |
see XML 1.0 (2nd Edition) 2.2.
[in] | c | The character to check. |
Definition at line 671 of file ixmlparser.cpp.
|
static |
Returns next char value and its length.
[in] | src | . |
[in,out] | cLen | . |
Definition at line 681 of file ixmlparser.cpp.
|
static |
Appends c to token buffer.
[in] | xmlParser | The XML parser. |
[in] | c | The character to append. |
Definition at line 797 of file ixmlparser.cpp.
|
static |
Encodes a character to its UTF-8 character string, and return its length.
[in] | c | The character to encode. |
[out] | s | The resultant UTF-8 encoded string. |
Definition at line 814 of file ixmlparser.cpp.
|
static |
Appends string s to token buffer.
[in] | xmlParser | The XML parser. |
[in] | s | The string to append. |
Definition at line 875 of file ixmlparser.cpp.
|
static |
Copy string in src into xml parser token buffer.
[in] | xmlParser | The XML parser. |
[in] | src | The string to copy from. |
[in] | len | The lenght to copy. |
Definition at line 892 of file ixmlparser.cpp.
|
static |
Return the length of next token in tokenBuff.
[in] | xmlParser | The XML parser. |
Definition at line 957 of file ixmlparser.cpp.
|
static |
Version of strdup() that handles NULL input.
[in] | s | String to be duplicated. |
Definition at line 1037 of file ixmlparser.cpp.
Processes the STag as defined by XML spec.
[in] | xmlParser | The XML parser. |
[in] | node | The Node to process. |
Definition at line 1051 of file ixmlparser.cpp.
|
static |
Parser_skipPI.
[in,out] | pSrc | The pointer to the skipped point. |
Definition at line 1115 of file ixmlparser.cpp.
|
static |
Processes CDSection as defined by XML spec.
[in] | pSrc | . |
[in] | node | The Node to process. |
Definition at line 1148 of file ixmlparser.cpp.
Processes the CONTENT as defined in XML spec.
[in] | xmlParser | The XML parser. |
[in] | node | The Node to process. |
Definition at line 1198 of file ixmlparser.cpp.
Process ETag as defined by XML spec.
[in] | xmlParser | The XML parser. |
[in] | node | The Node to process. |
[out] | bETag | . |
Definition at line 1318 of file ixmlparser.cpp.
|
static |
Unimplemented function.
Return the namespce as defined as prefix.
[in] | xmlParser | The XML parser. |
[in] | prefix | The prefix. |
Definition at line 1404 of file ixmlparser.cpp.
|
static |
Add a namespace definition.
[in] | xmlParser | The XML parser. |
Definition at line 1431 of file ixmlparser.cpp.
Add namespace definition.
[in] | xmlParser | The XML parser. |
[in] | newNode | The Node to process. |
Definition at line 1471 of file ixmlparser.cpp.
Processes attribute.
[in] | xmlParser | The XML parser. |
[in] | node | The Node to process. |
Definition at line 1598 of file ixmlparser.cpp.
Get the next node.
[in] | xmlParser | The XML parser. |
[out] | node | The XML parser. |
[out] | bETag | The XML parser. |
Definition at line 1752 of file ixmlparser.cpp.
|
static |
Decides whether element's prefix is already defined.
[in] | xmlParser | The XML parser. |
[in] | newNode | The Node to process. |
[in,out] | nsURI | The name space URI. |
Definition at line 1859 of file ixmlparser.cpp.
|
static |
Set element's namespace.
[in] | newElement | The Element Node to process. |
[in] | nsURI | The name space string. |
Definition at line 1896 of file ixmlparser.cpp.
Reports whether the new attribute is the same as an existing one.
[in] | xmlParser | The XML parser. |
[in] | newAttrNode | The node attribute to compare. |
Definition at line 1920 of file ixmlparser.cpp.
|
static |
Processes the attribute name.
[in] | rootDoc | The XML document. |
[in] | xmlParser | The XML parser. |
[in] | newNode | The Node to process. |
Definition at line 1946 of file ixmlparser.cpp.
Push a new element onto element stack.
[in] | xmlParser | The XML parser. |
[in] | newElement | The element node to push. |
Definition at line 1984 of file ixmlparser.cpp.
|
static |
Reports whether there is a top level element in the parser.
[in] | xmlParser | The XML parser. |
Definition at line 2044 of file ixmlparser.cpp.
|
static |
Decide whether the current element has default namespace.
[in] | xmlParser | The XML parser. |
[in,out] | nsURI | The name space URI. |
Definition at line 2054 of file ixmlparser.cpp.
|
static |
Processes element name.
[in] | rootDoc | The XML document. |
[in] | xmlParser | The XML parser. |
[in] | newNode | The Node to process. |
Definition at line 2078 of file ixmlparser.cpp.
Check if a new node->nodeName matches top of element stack.
[in] | xmlParser | The XML parser. |
[in] | newNode | The node. |
Definition at line 2155 of file ixmlparser.cpp.
|
static |
Remove element from element stack.
[in] | xmlParser | The XML parser. |
Definition at line 2175 of file ixmlparser.cpp.
Verifies endof element tag is the same as the openning element tag.
[in] | xmlParser | The XML parser. |
[in] | newNode | The Node to process. |
Definition at line 2200 of file ixmlparser.cpp.
|
static |
Parses the xml file and returns the DOM document tree.
[out] | retDoc | The XML document. |
[in] | xmlParser | The XML parser. |
Definition at line 2235 of file ixmlparser.cpp.
int Parser_isValidXmlName | ( | const DOMString | name | ) |
Check to see whether name is a valid xml name.
[in] | name | The string to be checked. |
Definition at line 2359 of file ixmlparser.cpp.
void Parser_setErrorChar | ( | char | c | ) |
Sets the error character.
If 'c' is 0 (default), the parser is strict about XML encoding: invalid UTF-8 sequences or "&" entities are rejected, and the parsing aborts.
If 'c' is not 0, the parser is relaxed: invalid UTF-8 characters are replaced by this character, and invalid "&" entities are left untranslated. The parsing is then allowed to continue.
[in] | c | The character to become the error character. |
Definition at line 2380 of file ixmlparser.cpp.
|
static |
Initializes a xml parser.
Definition at line 2395 of file ixmlparser.cpp.
|
static |
Read a xml file or buffer contents into xml parser.
[in] | xmlParser | The XML parser. |
[in] | xmlFileName | The file name or the buffer to copy, according to the parameter "file". |
[in] | file | 1 if you want to read from a file, 0 if xmlFileName is the buffer to copy to the parser. |
Definition at line 2413 of file ixmlparser.cpp.
int Parser_LoadDocument | ( | IXML_Document ** | retDoc, |
const char * | xmlFileName, | ||
int | file | ||
) |
Parses a xml file and return the DOM tree.
[out] | retDoc | The output document tree. |
[in] | xmlFileName | The file name or the buffer to copy, according to the parameter "file". |
[in] | file | 1 if you want to read from a file, 0 if xmlFileName is the buffer to copy to the parser. |
Definition at line 2475 of file ixmlparser.cpp.
void Parser_freeNodeContent | ( | IXML_Node * | nodeptr | ) |
Fees a node contents.
[in] | nodeptr | The Node to process. |
Definition at line 2503 of file ixmlparser.cpp.
int Parser_setNodePrefixAndLocalName | ( | IXML_Node * | node | ) |
Set the node prefix and localName as defined by the nodeName in the form of ns:name.
[in,out] | node | The Node to process. |
Definition at line 2533 of file ixmlparser.cpp.
|
static |
The letter table contains all characters in XML 1.0 plus ":", "_" and ideographic.
This table contains all the characters that an element name can start with. See XML 1.0 (2nd Edition) for more details.
Definition at line 94 of file ixmlparser.cpp.
|
static |
The NameChar table contains CombiningChar, Extender, Digit, '-', '.', less '_', ':'.
NameChar ::= Digit | '-' | '.' | CombiningChar | Extender See XML 1.0 2nd Edition
Definition at line 180 of file ixmlparser.cpp.