Classes | |
struct | _IXML_Node |
Data structure common to all types of nodes. More... | |
struct | _IXML_Document |
Data structure representing the DOM Document. More... | |
struct | _IXML_CDATASection |
Data structure representing a CDATA section node. More... | |
struct | _IXML_Element |
Data structure representing an Element node. More... | |
struct | _IXML_ATTR |
Data structure representing an Attribute node. More... | |
struct | _IXML_Text |
Data structure representing a Text node. More... | |
struct | _IXML_NodeList |
Data structure representing a list of nodes. More... | |
struct | _IXML_NamedNodeMap |
Data structure representing a list of named nodes. More... | |
Macros | |
#define | DOMString char* |
The type of DOM strings. | |
DOM Interfaces | |
The Document Object Model consists of a set of objects and interfaces for accessing and manipulating documents. IXML does not implement all the interfaces documented in the DOM2-Core recommendation but defines a subset of the most useful interfaces. A description of the supported interfaces and methods is presented in this section. For a complete discussion on the object model, the object hierarchy, etc., refer to section 1.1 of the DOM2-Core recommendation. | |
enum | IXML_NODE_TYPE { eINVALID_NODE = 0 , eELEMENT_NODE = 1 , eATTRIBUTE_NODE = 2 , eTEXT_NODE = 3 , eCDATA_SECTION_NODE = 4 , eENTITY_REFERENCE_NODE = 5 , eENTITY_NODE = 6 , ePROCESSING_INSTRUCTION_NODE = 7 , eCOMMENT_NODE = 8 , eDOCUMENT_NODE = 9 , eDOCUMENT_TYPE_NODE = 10 , eDOCUMENT_FRAGMENT_NODE = 11 , eNOTATION_NODE = 12 } |
The type of the DOM node. More... | |
enum | IXML_ERRORCODE { IXML_SUCCESS = 0 , IXML_INDEX_SIZE_ERR = 1 , IXML_DOMSTRING_SIZE_ERR = 2 , IXML_HIERARCHY_REQUEST_ERR = 3 , IXML_WRONG_DOCUMENT_ERR = 4 , IXML_INVALID_CHARACTER_ERR = 5 , IXML_NO_DATA_ALLOWED_ERR = 6 , IXML_NO_MODIFICATION_ALLOWED_ERR = 7 , IXML_NOT_FOUND_ERR = 8 , IXML_NOT_SUPPORTED_ERR = 9 , IXML_INUSE_ATTRIBUTE_ERR = 10 , IXML_INVALID_STATE_ERR = 11 , IXML_SYNTAX_ERR = 12 , IXML_INVALID_MODIFICATION_ERR = 13 , IXML_NAMESPACE_ERR = 14 , IXML_INVALID_ACCESS_ERR = 15 , IXML_NO_SUCH_FILE = 101 , IXML_INSUFFICIENT_MEMORY = 102 , IXML_FILE_DONE = 104 , IXML_INVALID_PARAMETER = 105 , IXML_FAILED = 106 , IXML_INVALID_ITEM_NUMBER = 107 } |
Error codes returned by the XML API, see the DOM spec. More... | |
typedef struct _IXML_Document * | Docptr |
The type of the DOM node. | |
typedef struct _IXML_Node * | Nodeptr |
The type of the DOM node. | |
typedef struct _IXML_Node | IXML_Node |
Data structure common to all types of nodes. | |
typedef struct _IXML_Document | IXML_Document |
Data structure representing the DOM Document. | |
typedef struct _IXML_CDATASection | IXML_CDATASection |
Data structure representing a CDATA section node. | |
typedef struct _IXML_Element | IXML_Element |
Data structure representing an Element node. | |
typedef struct _IXML_ATTR | IXML_Attr |
Data structure representing an Attribute node. | |
typedef struct _IXML_Text | IXML_Text |
Data structure representing a Text node. | |
typedef struct _IXML_NodeList | IXML_NodeList |
Data structure representing a list of nodes. | |
typedef struct _IXML_NamedNodeMap | IXML_NamedNodeMap |
Data structure representing a list of named nodes. | |
#define | DOCUMENTNODENAME "#document" |
The type of the DOM node. | |
#define | TEXTNODENAME "#text" |
The type of the DOM node. | |
#define | CDATANODENAME "#cdata-section" |
The type of the DOM node. | |
Interface Node | |
The Node interface forms the primary datatype for all other DOM objects. Every other interface is derived from this interface, inheriting its functionality. For more information, refer to DOM2-Core page 34. (Note: within the IXML library the NamedNodeMap and NodeList interfaces are the only interfaces that are not DOM objects and hence do not inherit from Node) | |
PUPNP_Api const DOMString | ixmlNode_getNodeName (IXML_Node *nodeptr) |
Returns the name of the Node, depending on what type of Node it is, in a read-only string. | |
PUPNP_Api const DOMString | ixmlNode_getNodeValue (IXML_Node *nodeptr) |
Returns the value of the Node as a string. | |
PUPNP_Api int | ixmlNode_setNodeValue (IXML_Node *nodeptr, const char *newNodeValue) |
Assigns a new value to a Node. | |
PUPNP_Api unsigned short | ixmlNode_getNodeType (IXML_Node *nodeptr) |
Retrieves the type of a Node. Note that not all possible return values are actually implemented. | |
PUPNP_Api IXML_Node * | ixmlNode_getParentNode (IXML_Node *nodeptr) |
Retrieves the parent Node for a Node. | |
PUPNP_Api IXML_NodeList * | ixmlNode_getChildNodes (IXML_Node *nodeptr) |
Retrieves the list of children of a Node in a NodeList structure. | |
PUPNP_Api IXML_Node * | ixmlNode_getFirstChild (IXML_Node *nodeptr) |
Retrieves the first child Node of a Node. | |
PUPNP_Api IXML_Node * | ixmlNode_getLastChild (IXML_Node *nodeptr) |
Retrieves the last child Node of a Node. | |
PUPNP_Api IXML_Node * | ixmlNode_getPreviousSibling (IXML_Node *nodeptr) |
Retrieves the sibling Node immediately preceding this Node. | |
PUPNP_Api IXML_Node * | ixmlNode_getNextSibling (IXML_Node *nodeptr) |
Retrieves the sibling Node immediately following this Node. | |
PUPNP_Api IXML_NamedNodeMap * | ixmlNode_getAttributes (IXML_Node *nodeptr) |
Retrieves the attributes of a Node, if it is an Element node, in a NamedNodeMap structure. | |
PUPNP_Api IXML_Document * | ixmlNode_getOwnerDocument (IXML_Node *nodeptr) |
Retrieves the document object associated with this Node. | |
PUPNP_Api const DOMString | ixmlNode_getNamespaceURI (IXML_Node *nodeptr) |
Retrieves the namespace URI for a Node as a DOMString. | |
PUPNP_Api const DOMString | ixmlNode_getPrefix (IXML_Node *nodeptr) |
Retrieves the namespace prefix, if present. | |
PUPNP_Api const DOMString | ixmlNode_getLocalName (IXML_Node *nodeptr) |
Retrieves the local name of a Node, if present. | |
PUPNP_Api int | ixmlNode_insertBefore (IXML_Node *nodeptr, IXML_Node *newChild, IXML_Node *refChild) |
Inserts a new child Node before the existing child Node. | |
PUPNP_Api int | ixmlNode_replaceChild (IXML_Node *nodeptr, IXML_Node *newChild, IXML_Node *oldChild, IXML_Node **returnNode) |
Replaces an existing child Node with a new child Node in the list of children of a Node. | |
PUPNP_Api int | ixmlNode_removeChild (IXML_Node *nodeptr, IXML_Node *oldChild, IXML_Node **returnNode) |
Removes a child from the list of children of a Node. | |
PUPNP_Api int | ixmlNode_appendChild (IXML_Node *nodeptr, IXML_Node *newChild) |
Appends a child Node to the list of children of a Node. | |
PUPNP_Api int | ixmlNode_hasChildNodes (IXML_Node *nodeptr) |
Queries whether or not a Node has children. | |
PUPNP_Api IXML_Node * | ixmlNode_cloneNode (IXML_Node *nodeptr, int deep) |
Clones a Node. | |
PUPNP_Api int | ixmlNode_hasAttributes (IXML_Node *nodeptr) |
Queries whether this Node has attributes. | |
PUPNP_Api void | ixmlNode_free (IXML_Node *nodeptr) |
Frees a Node and all Nodes in its subtree. | |
Interface Attr | |
The Attr interface represents an attribute of an Element. The document type definition (DTD) or schema usually dictate the allowable attributes and values for a particular element. For more information, refer to the Interface Attr section in the DOM2-Core. | |
PUPNP_Api void | ixmlAttr_free (IXML_Attr *attrNode) |
Frees an Attr node. | |
Interface CDATASection | |
The CDATASection is used to escape blocks of text containing characters that would otherwise be regarded as markup. CDATA sections cannot be nested. Their primary purpose is for including material such XML fragments, without needing to escape all the delimiters. For more information, refer to the Interface CDATASection section in the DOM2-Core. | |
PUPNP_Api void | ixmlCDATASection_init (IXML_CDATASection *nodeptr) |
Initializes a CDATASection node. | |
PUPNP_Api void | ixmlCDATASection_free (IXML_CDATASection *nodeptr) |
Frees a CDATASection node. | |
Interface Document | |
The Document interface represents the entire XML document. In essence, it is the root of the document tree and provides the primary interface to the elements of the document. For more information, refer to the Interface Document section in the DOM2Core. | |
PUPNP_Api void | ixmlDocument_init (IXML_Document *nodeptr) |
Initializes a Document node. | |
PUPNP_Api int | ixmlDocument_createDocumentEx (IXML_Document **doc) |
Creates a new empty Document node. | |
PUPNP_Api IXML_Document * | ixmlDocument_createDocument (void) |
Creates a new empty Document node. | |
PUPNP_Api int | ixmlDocument_createElementEx (IXML_Document *doc, const DOMString tagName, IXML_Element **rtElement) |
Creates a new Element node with the given tag name. | |
PUPNP_Api IXML_Element * | ixmlDocument_createElement (IXML_Document *doc, const DOMString tagName) |
Creates a new Element node with the given tag name. | |
PUPNP_Api int | ixmlDocument_createTextNodeEx (IXML_Document *doc, const DOMString data, IXML_Node **textNode) |
Creates a new Text node with the given data. | |
PUPNP_Api IXML_Node * | ixmlDocument_createTextNode (IXML_Document *doc, const DOMString data) |
Creates a new Text node with the given data. | |
PUPNP_Api int | ixmlDocument_createCDATASectionEx (IXML_Document *doc, const DOMString data, IXML_CDATASection **cdNode) |
Creates a new CDATASection node with given data. | |
PUPNP_Api IXML_CDATASection * | ixmlDocument_createCDATASection (IXML_Document *doc, const DOMString data) |
Creates a new CDATASection node with given data. | |
PUPNP_Api IXML_Attr * | ixmlDocument_createAttribute (IXML_Document *doc, const DOMString name) |
Creates a new Attr node with the given name. | |
PUPNP_Api int | ixmlDocument_createAttributeEx (IXML_Document *doc, const DOMString name, IXML_Attr **attrNode) |
Creates a new Attr node with the given name. | |
PUPNP_Api IXML_NodeList * | ixmlDocument_getElementsByTagName (IXML_Document *doc, const DOMString tagName) |
Returns a NodeList of all Elements that match the given tag name in the order in which they were encountered in a preorder traversal of the Document tree. | |
PUPNP_Api int | ixmlDocument_createElementNSEx (IXML_Document *doc, const DOMString namespaceURI, const DOMString qualifiedName, IXML_Element **rtElement) |
Creates a new Element node in the given qualified name and namespace URI. | |
PUPNP_Api IXML_Element * | ixmlDocument_createElementNS (IXML_Document *doc, const DOMString namespaceURI, const DOMString qualifiedName) |
Creates a new Element node in the given qualified name and namespace URI. | |
PUPNP_Api int | ixmlDocument_createAttributeNSEx (IXML_Document *doc, const DOMString namespaceURI, const DOMString qualifiedName, IXML_Attr **attrNode) |
Creates a new Attr node with the given qualified name and namespace URI. | |
PUPNP_Api IXML_Attr * | ixmlDocument_createAttributeNS (IXML_Document *doc, const DOMString namespaceURI, const DOMString qualifiedName) |
Creates a new Attribute node with the given qualified name and namespace URI. | |
PUPNP_Api IXML_NodeList * | ixmlDocument_getElementsByTagNameNS (IXML_Document *doc, const DOMString namespaceURI, const DOMString localName) |
Returns a NodeList of Elements that match the given local name and namespace URI in the order they are encountered in a preorder traversal of the Document tree. | |
PUPNP_Api IXML_Element * | ixmlDocument_getElementById (IXML_Document *doc, const DOMString tagName) |
Returns the Element whose ID matches that given id. | |
PUPNP_Api void | ixmlDocument_free (IXML_Document *doc) |
Frees a Document object and all Nodes associated with it. | |
PUPNP_Api int | ixmlDocument_importNode (IXML_Document *doc, IXML_Node *importNode, int deep, IXML_Node **rtNode) |
Imports a Node from another Document into this Document. | |
Interface Element | |
The Element interface represents an element in an XML document. Only Elements are allowed to have attributes, which are stored in the | |
PUPNP_Api void | ixmlElement_init (IXML_Element *element) |
Initializes a IXML_Element node. | |
PUPNP_Api const DOMString | ixmlElement_getTagName (IXML_Element *element) |
Returns the name of the tag as a constant string. | |
PUPNP_Api const DOMString | ixmlElement_getAttribute (IXML_Element *element, const DOMString name) |
Retrieves an attribute of an Element by name. | |
PUPNP_Api int | ixmlElement_setAttribute (IXML_Element *element, const DOMString name, const DOMString value) |
Adds a new attribute to an Element. | |
PUPNP_Api int | ixmlElement_removeAttribute (IXML_Element *element, const DOMString name) |
Removes an attribute value by name. The attribute node is not removed. | |
PUPNP_Api IXML_Attr * | ixmlElement_getAttributeNode (IXML_Element *element, const DOMString name) |
Retrieves an attribute node by name. See ixmlElement_getAttributeNodeNS to retrieve an attribute node using a qualified name or namespace URI. | |
PUPNP_Api int | ixmlElement_setAttributeNode (IXML_Element *element, IXML_Attr *newAttr, IXML_Attr **rtAttr) |
Adds a new attribute node to an Element. | |
PUPNP_Api int | ixmlElement_removeAttributeNode (IXML_Element *element, IXML_Attr *oldAttr, IXML_Attr **rtAttr) |
Removes the specified attribute node from an Element. | |
PUPNP_Api IXML_NodeList * | ixmlElement_getElementsByTagName (IXML_Element *element, const DOMString tagName) |
Returns a NodeList of all descendant Elements with a given tag name, in the order in which they are encountered in a pre-order traversal of this Element tree. | |
PUPNP_Api const DOMString | ixmlElement_getAttributeNS (IXML_Element *element, const DOMString namespaceURI, const DOMString localname) |
Retrieves an attribute value using the local name and namespace URI. | |
PUPNP_Api int | ixmlElement_setAttributeNS (IXML_Element *element, const DOMString namespaceURI, const DOMString qualifiedName, const DOMString value) |
Adds a new attribute to an Element using the local name and namespace URI. | |
PUPNP_Api int | ixmlElement_removeAttributeNS (IXML_Element *element, const DOMString namespaceURI, const DOMString localName) |
Removes an attribute using the namespace URI and local name. | |
PUPNP_Api IXML_Attr * | ixmlElement_getAttributeNodeNS (IXML_Element *element, const DOMString namespaceURI, const DOMString localName) |
Retrieves an Attr node by local name and namespace URI. | |
PUPNP_Api int | ixmlElement_setAttributeNodeNS (IXML_Element *element, IXML_Attr *newAttr, IXML_Attr **rcAttr) |
Adds a new attribute node to the element node specified. | |
PUPNP_Api IXML_NodeList * | ixmlElement_getElementsByTagNameNS (IXML_Element *element, const DOMString namespaceURI, const DOMString localName) |
Returns a NodeList of all descendant Elements with a given local name and namespace in the order in which they are encountered in the pre-order traversal of the Element tree. | |
PUPNP_Api int | ixmlElement_hasAttribute (IXML_Element *element, const DOMString name) |
Queries whether the Element has an attribute with the given name or a default value. | |
PUPNP_Api int | ixmlElement_hasAttributeNS (IXML_Element *element, const DOMString namespaceURI, const DOMString localName) |
Queries whether the Element has an attribute with the given local name and namespace URI or has a default value for that attribute. | |
PUPNP_Api void | ixmlElement_free (IXML_Element *element) |
Frees the given Element and any subtree of the Element. | |
Interface NamedNodeMap | |
A NamedNodeMap object represents a list of objects that can be accessed by name. A NamedNodeMap maintains the objects in no particular order. The Node interface uses a NamedNodeMap to maintain the attributes of a node. | |
PUPNP_Api unsigned long | ixmlNamedNodeMap_getLength (IXML_NamedNodeMap *nnMap) |
Returns the number of items contained in this NamedNodeMap. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_getNamedItem (IXML_NamedNodeMap *nnMap, const DOMString name) |
Retrieves a Node from the NamedNodeMap by name. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_setNamedItem (IXML_NamedNodeMap *nnMap, IXML_Node *arg) |
Adds a new Node to the NamedNodeMap using the Node name attribute. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_removeNamedItem (IXML_NamedNodeMap *nnMap, const DOMString name) |
Removes a Node from a NamedNodeMap specified by name. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_item (IXML_NamedNodeMap *nnMap, unsigned long index) |
Retrieves the indexth item in the map. If index is greater than or equal to the number of nodes in this map, this returns NULL. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_getNamedItemNS (IXML_NamedNodeMap *nnMap, const DOMString *namespaceURI, const DOMString localName) |
Retrieves a Node from a NamedNodeMap specified by namespace URI and local name. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_setNamedItemNS (IXML_NamedNodeMap *nnMap, IXML_Node *arg) |
Adds a new Node to the NamedNodeMap using the Node local name and namespace URI attributes. | |
PUPNP_Api IXML_Node * | ixmlNamedNodeMap_removeNamedItemNS (IXML_NamedNodeMap *nnMap, const DOMString namespaceURI, const DOMString localName) |
Removes a Node from a NamedNodeMap specified by namespace URI and local name. | |
PUPNP_Api void | ixmlNamedNodeMap_free (IXML_NamedNodeMap *nnMap) |
Frees a NamedNodeMap. | |
Interface NodeList | |
The NodeList interface abstracts an ordered collection of nodes. Note that changes to the underlying nodes will change the nodes contained in a NodeList. The DOM2-Core refers to this as being live. | |
PUPNP_Api IXML_Node * | ixmlNodeList_item (IXML_NodeList *nList, unsigned long index) |
Retrieves a Node from a NodeList specified by a numerical index. | |
PUPNP_Api unsigned long | ixmlNodeList_length (IXML_NodeList *nList) |
Returns the number of Nodes in a NodeList. | |
PUPNP_Api void | ixmlNodeList_free (IXML_NodeList *nList) |
Frees a NodeList object. | |
IXML API | |
The IXML API contains utility functions that are not part of the standard DOM interfaces. They include functions to create a DOM structure from a file or buffer, create an XML file from a DOM structure, and manipulate DOMString objects. | |
PUPNP_Api DOMString | ixmlPrintDocument (IXML_Document *doc) |
Renders a Node and all sub-elements into an XML document representation. | |
PUPNP_Api DOMString | ixmlPrintNode (IXML_Node *doc) |
Renders a Node and all sub-elements into an XML text representation. | |
PUPNP_Api DOMString | ixmlDocumenttoString (IXML_Document *doc) |
Renders a Node and all sub-elements into an XML document representation. | |
PUPNP_Api DOMString | ixmlNodetoString (IXML_Node *doc) |
Renders a Node and all sub-elements into an XML text representation. The caller is required to free the DOMString returned from this function using ixmlFreeDOMString when it is no longer required. | |
PUPNP_Api void | ixmlRelaxParser (char errorChar) |
Makes the XML parser more tolerant to malformed text. | |
PUPNP_Api IXML_Document * | ixmlParseBuffer (const char *buffer) |
Parses an XML text buffer converting it into an IXML DOM representation. | |
PUPNP_Api int | ixmlParseBufferEx (const char *buffer, IXML_Document **doc) |
Parses an XML text buffer converting it into an IXML DOM representation. | |
PUPNP_Api IXML_Document * | ixmlLoadDocument (const char *xmlFile) |
Parses an XML text file converting it into an IXML DOM representation. | |
PUPNP_Api int | ixmlLoadDocumentEx (const char *xmlFile, IXML_Document **doc) |
Parses an XML text file converting it into an IXML DOM representation. | |
PUPNP_Api DOMString | ixmlCloneDOMString (const DOMString src) |
Clones an existing DOMString. | |
PUPNP_Api void | ixmlFreeDOMString (DOMString buf) |
Frees a DOMString. | |
struct _IXML_Node |
Class Members | ||
---|---|---|
DOMString | nodeName | |
DOMString | nodeValue | |
IXML_NODE_TYPE | nodeType | |
DOMString | namespaceURI | |
DOMString | prefix | |
DOMString | localName | |
int | readOnly | |
Nodeptr | parentNode | |
Nodeptr | firstChild | |
Nodeptr | prevSibling | |
Nodeptr | nextSibling | |
Nodeptr | firstAttr | |
Docptr | ownerDocument |
struct _IXML_Document |
struct _IXML_CDATASection |
struct _IXML_Element |
struct _IXML_ATTR |
Class Members | ||
---|---|---|
IXML_Node | n | |
int | specified | |
IXML_Element * | ownerElement |
struct _IXML_Text |
struct _IXML_NodeList |
Class Members | ||
---|---|---|
IXML_Node * | nodeItem | |
struct _IXML_NodeList * | next |
struct _IXML_NamedNodeMap |
Class Members | ||
---|---|---|
IXML_Node * | nodeItem | |
struct _IXML_NamedNodeMap * | next |
#define DOCUMENTNODENAME "#document" |
#define CDATANODENAME "#cdata-section" |
typedef struct _IXML_Document* Docptr |
typedef struct _IXML_Node* Nodeptr |
enum IXML_NODE_TYPE |
enum IXML_ERRORCODE |
Returns the name of the Node, depending on what type of Node it is, in a read-only string.
Refer to the table in the DOM2-Core for a description of the node names for various interfaces.
[in] | nodeptr | Pointer to the node to retrieve the name. |
Definition at line 179 of file node.cpp.
Returns the value of the Node as a string.
Note that this string is not a copy and modifying it will modify the value of the Node.
[in] | nodeptr | Pointer to the Node to retrieve the value. |
Definition at line 296 of file node.cpp.
PUPNP_Api int ixmlNode_setNodeValue | ( | IXML_Node * | nodeptr, |
const char * | newNodeValue | ||
) |
Assigns a new value to a Node.
The newNodeValue string is duplicated and stored in the Node so that the original does not have to persist past this call.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
The Node * is not a valid pointer. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | nodeptr | The Node to which to assign a new value. |
[in] | newNodeValue | The new value of the Node. |
Definition at line 304 of file node.cpp.
PUPNP_Api unsigned short ixmlNode_getNodeType | ( | IXML_Node * | nodeptr | ) |
Retrieves the type of a Node. Note that not all possible return values are actually implemented.
[in] | nodeptr | The Node from which to retrieve the type. |
Definition at line 326 of file node.cpp.
PUPNP_Api IXML_NodeList * ixmlNode_getChildNodes | ( | IXML_Node * | nodeptr | ) |
Retrieves the list of children of a Node in a NodeList structure.
If a Node has no children, ixmlNode_getChildNodes returns a NodeList structure that contains no Nodes.
[in] | nodeptr | The Node from which to retrieve the children. |
Definition at line 1096 of file node.cpp.
PUPNP_Api IXML_NamedNodeMap * ixmlNode_getAttributes | ( | IXML_Node * | nodeptr | ) |
PUPNP_Api IXML_Document * ixmlNode_getOwnerDocument | ( | IXML_Node * | nodeptr | ) |
Retrieves the document object associated with this Node.
This owner document Node allows other Nodes to be created in the context of this document. Note that Document nodes do not have an owner document.
NULL
, if the Node does not have an owner. [in] | nodeptr | The Node from which to retrieve the owner document. |
Retrieves the namespace URI for a Node as a DOMString.
Only Nodes of type eELEMENT_NODE
or eATTRIBUTE_NODE
can have a namespace URI. Nodes created through the Document interface will only contain a namespace if created using ixmlDocument_createElementNS.
NULL
. [in] | nodeptr | The Node for which to retrieve the namespace. |
Definition at line 276 of file node.cpp.
Retrieves the namespace prefix, if present.
The prefix is the name used as an alias for the namespace URI for this element. Only Nodes of type eELEMENT_NODE
or eATTRIBUTE_NODE
can have a prefix. Nodes created through the Document interface will only contain a prefix if created using ixmlDocument_createElementNS.
NULL
. nodeptr | The Node from which to retrieve the prefix. |
Retrieves the local name of a Node, if present.
The local name is the tag name without the namespace prefix. Only Nodes of type eELEMENT_NODE
or eATTRIBUTE_NODE
can have a local name. Nodes created through the Document interface will only contain a local name if created using ixmlDocument_createElementNS.
NULL
. [in] | nodeptr | The Node from which to retrieve the local name. |
Definition at line 187 of file node.cpp.
PUPNP_Api int ixmlNode_insertBefore | ( | IXML_Node * | nodeptr, |
IXML_Node * | newChild, | ||
IXML_Node * | refChild | ||
) |
Inserts a new child Node before the existing child Node.
refChild can be NULL
, which inserts newChild at the end of the list of children. Note that the Node (or Nodes) in newChild must already be owned by the owner document (or have no owner at all) of nodeptr for insertion. If not, the Node (or Nodes) must be imported into the document using ixmlDocument_importNode. If newChild is already in the tree, it is removed first.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either nodeptr or newChild is NULL
. IXML_HIERARCHY_REQUEST_ERR:
The type of the Node does not allow children of the type of newChild. IXML_WRONG_DOCUMENT_ERR:
newChild has an owner document that does not match the owner of nodeptr. IXML_NO_MODIFICATION_ALLOWED_ERR:
nodeptr is read-only or the parent of the Node being inserted is read-only. IXML_NOT_FOUND_ERR:
refChild is not a child of nodeptr. [in] | nodeptr | The parent of the Node before which to insert the new child. |
[in] | newChild | The Node to insert into the tree. |
[in] | refChild | The reference child where the new Node should be inserted. The new Node will appear directly before the reference child. |
Definition at line 506 of file node.cpp.
PUPNP_Api int ixmlNode_replaceChild | ( | IXML_Node * | nodeptr, |
IXML_Node * | newChild, | ||
IXML_Node * | oldChild, | ||
IXML_Node ** | returnNode | ||
) |
Replaces an existing child Node with a new child Node in the list of children of a Node.
If newChild is already in the tree, it will first be removed. returnNode will contain the oldChild Node, appropriately removed from the tree (i.e. it will no longer have an owner document).
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMTER:
Either nodeptr, newChild, or oldChild is NULL
. IXML_HIERARCHY_REQUEST_ERR:
The newChild is not a type of Node that can be inserted into this tree or newChild is an ancestor of nodePtr. IXML_WRONG_DOCUMENT_ERR:
newChild was created from a different document than nodeptr. IXML_NO_MODIFICATION_ALLOWED_ERR:
nodeptr or its parent is read-only. IXML_NOT_FOUND_ERR:
oldChild is not a child of nodeptr. [in] | nodeptr | The parent of the Node which contains the child to replace. |
[in] | newChild | The child with which to replace oldChild. |
[in] | oldChild | The child to replace with newChild. |
[out] | returnNode | Pointer to a Node to place the removed oldChild Node. |
Definition at line 553 of file node.cpp.
PUPNP_Api int ixmlNode_removeChild | ( | IXML_Node * | nodeptr, |
IXML_Node * | oldChild, | ||
IXML_Node ** | returnNode | ||
) |
Removes a child from the list of children of a Node.
returnNode will contain the oldChild Node, appropriately removed from the tree (i.e. it will no longer have an owner document).
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either nodeptr or oldChild is NULL
. IXML_NO_MODIFICATION_ALLOWED_ERR:
nodeptr or its parent is read-only. IXML_NOT_FOUND_ERR:
oldChild is not among the children of nodeptr. [in] | nodeptr | The parent of the child to remove. |
[in] | oldChild | The child Node to remove. |
[out] | returnNode | Pointer to a Node to place the removed oldChild Node. |
Definition at line 588 of file node.cpp.
Appends a child Node to the list of children of a Node.
If newChild is already in the tree, it is removed first.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either nodeptr or newChild is NULL
. IXML_HIERARCHY_REQUEST_ERR:
newChild is of a type that cannot be added as a child of nodeptr or newChild is an ancestor of nodeptr. IXML_WRONG_DOCUMENT_ERR:
newChild was created from a different document than nodeptr. IXML_NO_MODIFICATION_ALLOWED_ERR:
nodeptr is a read-only Node. [in] | nodeptr | The Node in which to append the new child. |
[in] | newChild | The new child to append. |
Definition at line 611 of file node.cpp.
PUPNP_Api int ixmlNode_hasChildNodes | ( | IXML_Node * | nodeptr | ) |
Clones a Node.
The new Node does not have a parent. The deep parameter controls whether the subtree of the Node is also cloned.
For details on cloning specific types of Nodes, refer to the DOM2-Core recommendation.
NULL
. [in] | nodeptr | The Node to clone. |
[in] | deep | 1 to clone the subtree also or 0 to clone only nodeptr. |
Definition at line 1075 of file node.cpp.
PUPNP_Api int ixmlNode_hasAttributes | ( | IXML_Node * | nodeptr | ) |
PUPNP_Api void ixmlNode_free | ( | IXML_Node * | nodeptr | ) |
Frees a Node and all Nodes in its subtree.
[in] | nodeptr | The Node tree to free. Before it is freed, the handler set by ixmlSetBeforeFree will be called, the order will be top-down. |
Definition at line 120 of file node.cpp.
PUPNP_Api void ixmlAttr_free | ( | IXML_Attr * | attrNode | ) |
PUPNP_Api void ixmlCDATASection_init | ( | IXML_CDATASection * | nodeptr | ) |
PUPNP_Api void ixmlCDATASection_free | ( | IXML_CDATASection * | nodeptr | ) |
PUPNP_Api void ixmlDocument_init | ( | IXML_Document * | nodeptr | ) |
Initializes a Document node.
[in] | nodeptr | The Document node to initialize. |
Definition at line 43 of file document.cpp.
PUPNP_Api int ixmlDocument_createDocumentEx | ( | IXML_Document ** | doc | ) |
Creates a new empty Document node.
The ixmlDocument_createDocumentEx API differs from the ixmlDocument_createDocument API in that it returns an error code describing the reason for the failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [out] | doc | Pointer to a Document where the new object will be stored. |
Definition at line 155 of file document.cpp.
PUPNP_Api IXML_Document * ixmlDocument_createDocument | ( | void | ) |
Creates a new empty Document node.
NULL
on failure. Definition at line 184 of file document.cpp.
PUPNP_Api int ixmlDocument_createElementEx | ( | IXML_Document * | doc, |
const DOMString | tagName, | ||
IXML_Element ** | rtElement | ||
) |
Creates a new Element node with the given tag name.
The new Element node has a nodeName
of tagName and the localName
, prefix
, and namespaceURI
set to NULL
. To create an Element with a namespace, see ixmlDocument_createElementNS.
The ixmlDocument_createElementEx API differs from the ixmlDocument_createElement API in that it returns an error code describing the reason for failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc or tagName is NULL
. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | doc | The owner Document of the new node. |
[in] | tagName | The tag name of the new Element node. |
[out] | rtElement | Pointer to an Element where the new object will be stored. |
Definition at line 98 of file document.cpp.
PUPNP_Api IXML_Element * ixmlDocument_createElement | ( | IXML_Document * | doc, |
const DOMString | tagName | ||
) |
Creates a new Element node with the given tag name.
The new Element node has a nodeName
of tagName and the localName
, prefix
, and namespaceURI
set to NULL
. To create an Element with a namespace, see ixmlDocument_createElementNS.
NULL
, or NULL
on failure. [in] | doc | The owner Document of the new node. |
[in] | tagName | The tag name of the new Element node (case-sensitive). |
Definition at line 141 of file document.cpp.
PUPNP_Api int ixmlDocument_createTextNodeEx | ( | IXML_Document * | doc, |
const DOMString | data, | ||
IXML_Node ** | textNode | ||
) |
Creates a new Text node with the given data.
The ixmlDocument_createTextNodeEx() API differs from the ixmlDocument_createTextNode API in that it returns an error code describing the reason for failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc or data is NULL
. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | doc | The owner Document of the new node. |
[in] | data | The data to associate with the new Text node. It is stored in nodeValue field. |
[out] | textNode | A pointer to a Node where the new object will be stored. |
Definition at line 192 of file document.cpp.
PUPNP_Api IXML_Node * ixmlDocument_createTextNode | ( | IXML_Document * | doc, |
const DOMString | data | ||
) |
Creates a new Text node with the given data.
NULL
on failure. [in] | doc | The owner Document of the new node. |
[in] | data | The data to associate with the new Text node. It is stored in the nodeValue field. |
Definition at line 237 of file document.cpp.
PUPNP_Api int ixmlDocument_createCDATASectionEx | ( | IXML_Document * | doc, |
const DOMString | data, | ||
IXML_CDATASection ** | cdNode | ||
) |
Creates a new CDATASection node with given data.
The ixmlDocument_createCDATASectionEx API differs from the ixmlDocument_createCDATASection API in that it returns an error code describing the reason for failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc or data is NULL
. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | doc | The owner Document of the new node. |
[in] | data | The data to associate with the new CDATASection node. |
[out] | cdNode | A pointer to a Node where the new object will be stored. |
Definition at line 341 of file document.cpp.
PUPNP_Api IXML_CDATASection * ixmlDocument_createCDATASection | ( | IXML_Document * | doc, |
const DOMString | data | ||
) |
Creates a new CDATASection node with given data.
NULL
on failure. [in] | doc | The owner Document of the new node. |
[in] | data | The data to associate with the new CDATASection node. |
Definition at line 382 of file document.cpp.
PUPNP_Api IXML_Attr * ixmlDocument_createAttribute | ( | IXML_Document * | doc, |
const DOMString | name | ||
) |
Creates a new Attr node with the given name.
NULL
on failure.The value of the attribute is the empty string.
[in] | doc | The owner Document of the new node. |
[in] | name | The name of the new attribute. |
Definition at line 283 of file document.cpp.
PUPNP_Api int ixmlDocument_createAttributeEx | ( | IXML_Document * | doc, |
const DOMString | name, | ||
IXML_Attr ** | attrNode | ||
) |
Creates a new Attr node with the given name.
The ixmlDocument_createAttributeEx API differs from the ixmlDocument_createAttribute API in that it returns an error code describing the reason for failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc or name is NULL
. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | doc | The owner Document of the new node. |
[in] | name | The name of the new attribute. |
[out] | attrNode | A pointer to a Attr where the new object will be stored. |
Definition at line 246 of file document.cpp.
PUPNP_Api IXML_NodeList * ixmlDocument_getElementsByTagName | ( | IXML_Document * | doc, |
const DOMString | tagName | ||
) |
Returns a NodeList of all Elements that match the given tag name in the order in which they were encountered in a preorder traversal of the Document tree.
NULL
on an error. [in] | doc | The Document to search. |
[in] | tagName | The tag name to find. The special value "*" matches all tags. |
Definition at line 452 of file document.cpp.
PUPNP_Api int ixmlDocument_createElementNSEx | ( | IXML_Document * | doc, |
const DOMString | namespaceURI, | ||
const DOMString | qualifiedName, | ||
IXML_Element ** | rtElement | ||
) |
Creates a new Element node in the given qualified name and namespace URI.
The ixmlDocument_createElementNSEx API differs from the ixmlDocument_createElementNS API in that it returns an error code describing the reason for failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc, namespaceURI, or qualifiedName is NULL
. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | doc | The owner Document of the new node. |
[in] | namespaceURI | The namespace URI for the new Element. |
[in] | qualifiedName | The qualified name of the new Element. |
[out] | rtElement | A pointer to an Element where the new object will be stored. |
Definition at line 391 of file document.cpp.
PUPNP_Api IXML_Element * ixmlDocument_createElementNS | ( | IXML_Document * | doc, |
const DOMString | namespaceURI, | ||
const DOMString | qualifiedName | ||
) |
Creates a new Element node in the given qualified name and namespace URI.
NULL
on failure. [in] | doc | The owner Document of the new node. |
[in] | namespaceURI | The namespace URI for the new Element. |
[in] | qualifiedName | The qualified name of the new Element. |
Definition at line 441 of file document.cpp.
PUPNP_Api int ixmlDocument_createAttributeNSEx | ( | IXML_Document * | doc, |
const DOMString | namespaceURI, | ||
const DOMString | qualifiedName, | ||
IXML_Attr ** | attrNode | ||
) |
Creates a new Attr node with the given qualified name and namespace URI.
The ixmlDocument_createAttributeNSEx API differs from the ixmlDocument_createAttributeNS API in that it returns an error code describing the reason for failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc, namespaceURI, or qualifiedName is NULL
. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | doc | The owner Document of the new Attr. |
[in] | namespaceURI | The namespace URI for the attribute. |
[in] | qualifiedName | The qualified name of the attribute. |
[out] | attrNode | A pointer to an Attr where the new object will be stored. |
Definition at line 293 of file document.cpp.
PUPNP_Api IXML_Attr * ixmlDocument_createAttributeNS | ( | IXML_Document * | doc, |
const DOMString | namespaceURI, | ||
const DOMString | qualifiedName | ||
) |
Creates a new Attribute node with the given qualified name and namespace URI.
NULL
on failure. [in] | doc | The owner Document of the new Attribute. |
[in] | namespaceURI | The namespace URI for the attribute. |
[in] | qualifiedName | The qualified name of the attribute. |
Definition at line 330 of file document.cpp.
PUPNP_Api IXML_NodeList * ixmlDocument_getElementsByTagNameNS | ( | IXML_Document * | doc, |
const DOMString | namespaceURI, | ||
const DOMString | localName | ||
) |
Returns a NodeList of Elements that match the given local name and namespace URI in the order they are encountered in a preorder traversal of the Document tree.
Either namespaceURI or localName can be the special "*"
character, which matches any namespace or any local name respectively.
NULL
on an error. [in] | doc | The Document to search. |
[in] | namespaceURI | The namespace of the elements to find or "*" to match any namespace. |
[in] | localName | The local name of the elements to find or "*" to match any local name. |
Definition at line 465 of file document.cpp.
PUPNP_Api IXML_Element * ixmlDocument_getElementById | ( | IXML_Document * | doc, |
const DOMString | tagName | ||
) |
Returns the Element whose ID
matches that given id.
NULL
on an error. [in] | doc | The owner Document of the Element. |
[in] | tagName | The name of the Element. |
Definition at line 480 of file document.cpp.
PUPNP_Api void ixmlDocument_free | ( | IXML_Document * | doc | ) |
Frees a Document object and all Nodes associated with it.
Any Nodes extracted via any other interface function, e.g. ixmlDocument_GetElementById, become invalid after this call unless explicitly cloned.
[in] | doc | The Document to free. |
Definition at line 47 of file document.cpp.
PUPNP_Api int ixmlDocument_importNode | ( | IXML_Document * | doc, |
IXML_Node * | importNode, | ||
int | deep, | ||
IXML_Node ** | rtNode | ||
) |
Imports a Node from another Document into this Document.
The returned new Node does not a have parent node (parentNode is null): it is a clone of the original Node with the ownerDocument
set to doc. The source node is not altered or removed from the original document.
For all nodes, importing a node creates a node object owned by the importing document, with attribute values identical to the source node's nodeName and nodeType, plus the attributes related to namespaces (prefix, localName, and namespaceURI).
As in the cloneNode operation on a node, the source node is not altered.
The deep parameter controls whether all the children of the Node are imported.
Refer to the DOM2-Core recommendation for details on importing specific node types.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either doc or importNode is not a valid pointer. IXML_NOT_SUPPORTED_ERR:
importNode is a Document, which cannot be imported. IXML_FAILED:
The import operation failed because the Node to be imported could not be cloned. [in] | doc | The Document into which to import. |
[in] | importNode | The Node to import. |
[in] | deep | 1 to import all children of importNode or 0 to import only the root node. |
[out] | rtNode | A pointer to a new Node owned by doc. |
Definition at line 71 of file document.cpp.
PUPNP_Api void ixmlElement_init | ( | IXML_Element * | element | ) |
Initializes a IXML_Element node.
[in] | element | The Element to initialize. |
Definition at line 43 of file element.cpp.
PUPNP_Api const DOMString ixmlElement_getTagName | ( | IXML_Element * | element | ) |
Returns the name of the tag as a constant string.
[in] | element | The Element from which to retrieve the name. |
Definition at line 49 of file element.cpp.
PUPNP_Api const DOMString ixmlElement_getAttribute | ( | IXML_Element * | element, |
const DOMString | name | ||
) |
Retrieves an attribute of an Element by name.
[in] | element | The Element from which to retrieve the attribute. |
[in] | name | The name of the attribute to retrieve. |
Definition at line 77 of file element.cpp.
PUPNP_Api int ixmlElement_setAttribute | ( | IXML_Element * | element, |
const DOMString | name, | ||
const DOMString | value | ||
) |
Adds a new attribute to an Element.
If an attribute with the same name already exists in the element, the attribute value will be updated with the new value parameter. Otherwise, a new attribute is inserted into the element.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element, name, or value is NULL
. IXML_INVALID_CHARACTER_ERR:
name contains an illegal character. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete the operation. [in] | element | The Element on which to set the attribute. |
[in] | name | The name of the attribute. |
[in] | value | The value of the attribute. Note that this is a non-parsed string and any markup must be escaped. |
Definition at line 97 of file element.cpp.
PUPNP_Api int ixmlElement_removeAttribute | ( | IXML_Element * | element, |
const DOMString | name | ||
) |
Removes an attribute value by name. The attribute node is not removed.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element or name is NULL
. [in] | element | The Element from which to remove the attribute. |
[in] | name | The name of the attribute to remove. |
Definition at line 159 of file element.cpp.
PUPNP_Api IXML_Attr * ixmlElement_getAttributeNode | ( | IXML_Element * | element, |
const DOMString | name | ||
) |
Retrieves an attribute node by name. See ixmlElement_getAttributeNodeNS to retrieve an attribute node using a qualified name or namespace URI.
NULL
on if there is no such attribute. [in] | element | The Element from which to get the attribute node. |
[in] | name | The name of the attribute node to find. |
Definition at line 186 of file element.cpp.
PUPNP_Api int ixmlElement_setAttributeNode | ( | IXML_Element * | element, |
IXML_Attr * | newAttr, | ||
IXML_Attr ** | rtAttr | ||
) |
Adds a new attribute node to an Element.
If an attribute already exists with newAttr as a name, it will be replaced with the new one and the old one will be returned in rtAttr.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element or newAttr is NULL
. IXML_WRONG_DOCUMENT_ERR:
newAttr does not belong to the same one as element. IXML_INUSE_ATTRIBUTE_ERR:
newAttr is already an attribute of another Element. [in] | element | The Element in which to add the new attribute. |
[in] | newAttr | The new Attr to add. |
[out] | rtAttr | A pointer to an Attr where the old Attr will be stored. This will have a NULL if no prior node existed. |
Definition at line 207 of file element.cpp.
PUPNP_Api int ixmlElement_removeAttributeNode | ( | IXML_Element * | element, |
IXML_Attr * | oldAttr, | ||
IXML_Attr ** | rtAttr | ||
) |
Removes the specified attribute node from an Element.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element or oldAttr is NULL
. IXML_NOT_FOUND_ERR:
oldAttr is not among the list attributes of element. [in] | element | The Element from which to remove the attribute. |
[in] | oldAttr | The attribute to remove from the Element. |
[out] | rtAttr | A pointer to an attribute in which to place the removed attribute. |
Definition at line 301 of file element.cpp.
PUPNP_Api IXML_NodeList * ixmlElement_getElementsByTagName | ( | IXML_Element * | element, |
const DOMString | tagName | ||
) |
Returns a NodeList of all descendant Elements with a given tag name, in the order in which they are encountered in a pre-order traversal of this Element tree.
NULL
on an error. [in] | element | The Element from which to start the search. |
[in] | tagName | The name of the tag for which to search. |
Definition at line 335 of file element.cpp.
PUPNP_Api const DOMString ixmlElement_getAttributeNS | ( | IXML_Element * | element, |
const DOMString | namespaceURI, | ||
const DOMString | localname | ||
) |
Retrieves an attribute value using the local name and namespace URI.
[in] | element | The Element from which to get the attribute value. |
[in] | namespaceURI | The namespace URI of the attribute. |
[in] | localname | The local name of the attribute. |
Definition at line 346 of file element.cpp.
PUPNP_Api int ixmlElement_setAttributeNS | ( | IXML_Element * | element, |
const DOMString | namespaceURI, | ||
const DOMString | qualifiedName, | ||
const DOMString | value | ||
) |
Adds a new attribute to an Element using the local name and namespace URI.
If another attribute matches the same local name and namespace, the prefix is changed to be the prefix part of the qualifiedName
and the value is changed to value.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element, namespaceURI, qualifiedName, or value is NULL
. IXML_INVALID_CHARACTER_ERR:
qualifiedName contains an invalid character. IXML_NAMESPACE_ERR:
Either the qualifiedName or namespaceURI is malformed. Refer to the DOM2-Core for possible reasons. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exist to complete the operation. IXML_FAILED:
The operation could not be completed. [in] | element | The Element on which to set the attribute. |
[in] | namespaceURI | The namespace URI of the new attribute. |
[in] | qualifiedName | The qualified name of the attribute. |
[in] | value | The new value for the attribute. |
Definition at line 370 of file element.cpp.
PUPNP_Api int ixmlElement_removeAttributeNS | ( | IXML_Element * | element, |
const DOMString | namespaceURI, | ||
const DOMString | localName | ||
) |
Removes an attribute using the namespace URI and local name.
The replacing attribute has the same namespace URI and local name, as well as the original prefix.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element, namespaceURI, or localName is NULL
. [in] | element | The Element from which to remove the the attribute. |
[in] | namespaceURI | The namespace URI of the attribute. |
[in] | localName | The local name of the attribute. |
Definition at line 471 of file element.cpp.
PUPNP_Api IXML_Attr * ixmlElement_getAttributeNodeNS | ( | IXML_Element * | element, |
const DOMString | namespaceURI, | ||
const DOMString | localName | ||
) |
Retrieves an Attr node by local name and namespace URI.
NULL
if there is no such attribute. [in] | element | The Element from which to get the attribute. |
[in] | namespaceURI | The namespace URI of the attribute. |
[in] | localName | The local name of the attribute. |
Definition at line 501 of file element.cpp.
PUPNP_Api int ixmlElement_setAttributeNodeNS | ( | IXML_Element * | element, |
IXML_Attr * | newAttr, | ||
IXML_Attr ** | rcAttr | ||
) |
Adds a new attribute node to the element node specified.
If an attribute with the same local name and namespace URI already exists in the Element, the existing attribute node is replaced with newAttr and the old returned in rcAttr.
The function return value is an integer representing one of the following:
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
Either element or newAttr is NULL
. IXML_WRONG_DOCUMENT_ERR:
newAttr does not belong to the same document as element. IXML_INUSE_ATTRIBUTE_ERR:
newAttr already is an attribute of another Element. [in] | element | The Element in which to add the attribute node. |
[in] | newAttr | The new Attr to add. |
[out] | rcAttr | A pointer to the replaced Attr, if it exists. |
Definition at line 524 of file element.cpp.
PUPNP_Api IXML_NodeList * ixmlElement_getElementsByTagNameNS | ( | IXML_Element * | element, |
const DOMString | namespaceURI, | ||
const DOMString | localName | ||
) |
Returns a NodeList of all descendant Elements with a given local name and namespace in the order in which they are encountered in the pre-order traversal of the Element tree.
NULL
on an error. [in] | element | The Element from which to start the search. |
[in] | namespaceURI | The namespace URI of the Elements to find. The special value "*" matches all namespaces. |
[in] | localName | The local name of the Elements to find. The special value "*" matches all local names. |
Definition at line 599 of file element.cpp.
PUPNP_Api int ixmlElement_hasAttribute | ( | IXML_Element * | element, |
const DOMString | name | ||
) |
Queries whether the Element has an attribute with the given name or a default value.
1
if the Element has an attribute with this name or has a default value for that attribute, otherwise 0
. [in] | element | The Element on which to check for an attribute. |
[in] | name | The name of the attribute for which to check. |
Definition at line 613 of file element.cpp.
PUPNP_Api int ixmlElement_hasAttributeNS | ( | IXML_Element * | element, |
const DOMString | namespaceURI, | ||
const DOMString | localName | ||
) |
Queries whether the Element has an attribute with the given local name and namespace URI or has a default value for that attribute.
1
if the Element has an attribute with the given namespace and local name or has a default value for that attribute, otherwise 0
. [in] | element | The Element on which to check for the attribute. |
[in] | namespaceURI | The namespace URI of the attribute. |
[in] | localName | The local name of the attribute. |
Definition at line 632 of file element.cpp.
PUPNP_Api void ixmlElement_free | ( | IXML_Element * | element | ) |
Frees the given Element and any subtree of the Element.
[in] | element | The Element to free. |
Definition at line 654 of file element.cpp.
PUPNP_Api unsigned long ixmlNamedNodeMap_getLength | ( | IXML_NamedNodeMap * | nnMap | ) |
Returns the number of items contained in this NamedNodeMap.
[in] | nnMap | The NamedNodeMap from which to retrieve the size. |
Definition at line 116 of file namedNodeMap.cpp.
PUPNP_Api IXML_Node * ixmlNamedNodeMap_getNamedItem | ( | IXML_NamedNodeMap * | nnMap, |
const DOMString | name | ||
) |
Retrieves a Node from the NamedNodeMap by name.
[in] | nnMap | The NamedNodeMap to search. |
[in] | name | The name of the Node to find. |
Definition at line 78 of file namedNodeMap.cpp.
PUPNP_Api IXML_Node * ixmlNamedNodeMap_setNamedItem | ( | IXML_NamedNodeMap * | nnMap, |
IXML_Node * | arg | ||
) |
Adds a new Node to the NamedNodeMap using the Node name attribute.
NULL
if the Node was not in the NamedNodeMap before. nnMap | The NamedNodeMap in which to add the new Node. |
arg | The new Node to add to the NamedNodeMap. |
PUPNP_Api IXML_Node * ixmlNamedNodeMap_removeNamedItem | ( | IXML_NamedNodeMap * | nnMap, |
const DOMString | name | ||
) |
Removes a Node from a NamedNodeMap specified by name.
NULL
if it wasn't. nnMap | The NamedNodeMap from which to remove the item. |
name | The name of the item to remove. |
PUPNP_Api IXML_Node * ixmlNamedNodeMap_item | ( | IXML_NamedNodeMap * | nnMap, |
unsigned long | index | ||
) |
Retrieves the indexth item in the map. If index is greater than or equal to the number of nodes in this map, this returns NULL.
[in] | nnMap | The NamedNodeMap from which to remove the Node. |
[in] | index | The index into the map to remove. |
Definition at line 94 of file namedNodeMap.cpp.
PUPNP_Api IXML_Node * ixmlNamedNodeMap_getNamedItemNS | ( | IXML_NamedNodeMap * | nnMap, |
const DOMString * | namespaceURI, | ||
const DOMString | localName | ||
) |
Retrieves a Node from a NamedNodeMap specified by namespace URI and local name.
NULL
if it wasn't nnMap | The NamedNodeMap from which to remove the Node. |
namespaceURI | The namespace URI of the Node to remove. |
localName | The local name of the Node to remove. |
PUPNP_Api IXML_Node * ixmlNamedNodeMap_setNamedItemNS | ( | IXML_NamedNodeMap * | nnMap, |
IXML_Node * | arg | ||
) |
Adds a new Node to the NamedNodeMap using the Node local name and namespace URI attributes.
NULL
if the Node was not in the NamedNodeMap before. nnMap | The NamedNodeMap in which to add the Node. |
arg | The Node to add to the map. |
PUPNP_Api IXML_Node * ixmlNamedNodeMap_removeNamedItemNS | ( | IXML_NamedNodeMap * | nnMap, |
const DOMString | namespaceURI, | ||
const DOMString | localName | ||
) |
Removes a Node from a NamedNodeMap specified by namespace URI and local name.
NULL
if it wasn't. nnMap | The NamedNodeMap from which to remove the Node. |
namespaceURI | The namespace URI of the Node to remove. |
localName | The local name of the Node to remove. |
PUPNP_Api void ixmlNamedNodeMap_free | ( | IXML_NamedNodeMap * | nnMap | ) |
Frees a NamedNodeMap.
The Nodes inside the map are not freed, just the NamedNodeMap object.
[in] | nnMap | The NamedNodeMap to free. |
Definition at line 130 of file namedNodeMap.cpp.
PUPNP_Api IXML_Node * ixmlNodeList_item | ( | IXML_NodeList * | nList, |
unsigned long | index | ||
) |
Retrieves a Node from a NodeList specified by a numerical index.
NULL
if there was an error. [in] | nList | The NodeList from which to retrieve the Node. |
[in] | index | The index into the NodeList to retrieve. |
Definition at line 49 of file nodeList.cpp.
PUPNP_Api unsigned long ixmlNodeList_length | ( | IXML_NodeList * | nList | ) |
Returns the number of Nodes in a NodeList.
[in] | nList | The NodeList for which to retrieve the number of Nodes. |
Definition at line 116 of file nodeList.cpp.
PUPNP_Api void ixmlNodeList_free | ( | IXML_NodeList * | nList | ) |
Frees a NodeList object.
Since the underlying Nodes are references, they are not freed using this operation. This only frees the NodeList object.
[in] | nList | The NodeList to free. |
Definition at line 129 of file nodeList.cpp.
PUPNP_Api DOMString ixmlPrintDocument | ( | IXML_Document * | doc | ) |
Renders a Node and all sub-elements into an XML document representation.
The caller is required to free the DOMString returned from this function using ixmlFreeDOMString when it is no longer required.
Note that this function can be used for any Node-derived interface. The difference between ixmlPrintDocument and ixmlPrintNode is ixmlPrintDocument includes the XML prolog while ixmlPrintNode only produces XML elements. An XML document is not well formed unless it includes the prolog and at least one element.
This function introduces lots of white space to print the DOMString in readable format.
NULL
on an error. [in] | doc | The document node to print. |
Definition at line 322 of file ixml.cpp.
Renders a Node and all sub-elements into an XML text representation.
The caller is required to free the DOMString returned from this function using ixmlFreeDOMString when it is no longer required.
Note that this function can be used for any Node-derived interface. A similar ixmlPrintDocument function is defined to avoid casting when printing whole documents. This function introduces lots of white space to print the DOMString in readable format.
NULL
on an error. [in] | doc | The root of the Node tree to render to XML text. |
Definition at line 338 of file ixml.cpp.
PUPNP_Api DOMString ixmlDocumenttoString | ( | IXML_Document * | doc | ) |
Renders a Node and all sub-elements into an XML document representation.
The caller is required to free the DOMString returned from this function using ixmlFreeDOMString when it is no longer required.
Note that this function can be used for any Node-derived interface. The difference between ixmlDocumenttoString and ixmlNodetoString is ixmlDocumenttoString includes the XML prolog while ixmlNodetoString only produces XML elements. An XML document is not well formed unless it includes the prolog and at least one element.
NULL
on an error. [in] | doc | The root of the Node tree to render to XML text. |
Definition at line 352 of file ixml.cpp.
Renders a Node and all sub-elements into an XML text representation. The caller is required to free the DOMString returned from this function using ixmlFreeDOMString when it is no longer required.
Note that this function can be used for any Node-derived interface. The difference between ixmlNodetoString and ixmlDocumenttoString is ixmlNodetoString does not include the XML prolog, it only produces XML elements.
NULL
on an error. [in] | doc | The root of the Node tree to render to XML text. |
Definition at line 368 of file ixml.cpp.
PUPNP_Api void ixmlRelaxParser | ( | char | errorChar | ) |
Makes the XML parser more tolerant to malformed text.
[in] | errorChar | If errorChar is 0 (default), the parser is strict about XML encoding : invalid UTF-8 sequences or "&" entities are rejected, and the parsing aborts. |
If errorChar is not 0, the parser is relaxed: invalid UTF-8 characters are replaced by the errorChar, and invalid "&" entities are left untranslated. The parsing is then allowed to continue.
Definition at line 382 of file ixml.cpp.
PUPNP_Api IXML_Document * ixmlParseBuffer | ( | const char * | buffer | ) |
Parses an XML text buffer converting it into an IXML DOM representation.
NULL
on an error. [in] | buffer | The buffer that contains the XML text to convert to a Document. |
Definition at line 402 of file ixml.cpp.
PUPNP_Api int ixmlParseBufferEx | ( | const char * | buffer, |
IXML_Document ** | doc | ||
) |
Parses an XML text buffer converting it into an IXML DOM representation.
The ixmlParseBufferEx API differs from the ixmlParseBuffer API in that it returns an error code representing the actual failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
The buffer is not a valid pointer. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | buffer | The buffer that contains the XML text to convert to a Document. |
[out] | doc | A point to store the Document if file correctly parses or NULL on an error. |
Definition at line 390 of file ixml.cpp.
PUPNP_Api IXML_Document * ixmlLoadDocument | ( | const char * | xmlFile | ) |
PUPNP_Api int ixmlLoadDocumentEx | ( | const char * | xmlFile, |
IXML_Document ** | doc | ||
) |
Parses an XML text file converting it into an IXML DOM representation.
The ixmlLoadDocumentEx API differs from the ixmlLoadDocument API in that it returns a an error code representing the actual failure rather than just NULL
.
IXML_SUCCESS:
The operation completed successfully. IXML_INVALID_PARAMETER:
The xmlFile is not a valid pointer. IXML_INSUFFICIENT_MEMORY:
Not enough free memory exists to complete this operation. [in] | xmlFile | The filename of the XML text to convert to a Document. |
[out] | doc | A pointer to the Document if file correctly parses or NULL on an error. |
Definition at line 306 of file ixml.cpp.