|
void | clear () |
|
template<int Flags> |
void | parse (Ch *text) |
|
| xml_document () |
| Constructs empty XML document. More...
|
|
void | append_attribute (xml_attribute< Ch > *attribute) |
|
void | append_node (xml_node< Ch > *child) |
|
xml_document< Ch > * | document () const |
|
xml_attribute< Ch > * | first_attribute (const Ch *name=0, std::size_t name_size=0, bool case_sensitive=true) const |
|
xml_node< Ch > * | first_node (const Ch *name=0, std::size_t name_size=0, bool case_sensitive=true) const |
|
void | insert_attribute (xml_attribute< Ch > *where, xml_attribute< Ch > *attribute) |
|
void | insert_node (xml_node< Ch > *where, xml_node< Ch > *child) |
|
xml_attribute< Ch > * | last_attribute (const Ch *name=0, std::size_t name_size=0, bool case_sensitive=true) const |
|
xml_node< Ch > * | last_node (const Ch *name=0, std::size_t name_size=0, bool case_sensitive=true) const |
|
xml_node< Ch > * | next_sibling (const Ch *name=0, std::size_t name_size=0, bool case_sensitive=true) const |
|
void | prepend_attribute (xml_attribute< Ch > *attribute) |
|
void | prepend_node (xml_node< Ch > *child) |
|
xml_node< Ch > * | previous_sibling (const Ch *name=0, std::size_t name_size=0, bool case_sensitive=true) const |
|
void | remove_all_attributes () |
| Removes all attributes of node. More...
|
|
void | remove_all_nodes () |
| Removes all child nodes (but not attributes). More...
|
|
void | remove_attribute (xml_attribute< Ch > *where) |
|
void | remove_first_attribute () |
|
void | remove_first_node () |
|
void | remove_last_attribute () |
|
void | remove_last_node () |
|
void | remove_node (xml_node< Ch > *where) |
| Removes specified child from the node. More...
|
|
node_type | type () const |
|
void | type (node_type type) |
|
| xml_node (node_type type) |
|
Ch * | name () const |
|
void | name (const Ch *name, std::size_t size) |
|
void | name (const Ch *name) |
|
std::size_t | name_size () const |
|
xml_node< Ch > * | parent () const |
|
Ch * | value () const |
|
void | value (const Ch *value, std::size_t size) |
|
void | value (const Ch *value) |
|
std::size_t | value_size () const |
|
| xml_base () |
|
xml_attribute< Ch > * | allocate_attribute (const Ch *name=0, const Ch *value=0, std::size_t name_size=0, std::size_t value_size=0) |
|
xml_node< Ch > * | allocate_node (node_type type, const Ch *name=0, const Ch *value=0, std::size_t name_size=0, std::size_t value_size=0) |
|
Ch * | allocate_string (const Ch *source=0, std::size_t size=0) |
|
void | clear () |
|
xml_node< Ch > * | clone_node (const xml_node< Ch > *source, xml_node< Ch > *result=0) |
|
| memory_pool () |
| Constructs empty pool with default allocator functions. More...
|
|
void | set_allocator (alloc_func *af, free_func *ff) |
|
| ~memory_pool () |
|
template<class Ch = char>
class rapidxml::xml_document< Ch >
This class represents root of the DOM hierarchy. It is also an xml_node and a memory_pool through public inheritance. Use parse() function to build a DOM tree from a zero-terminated XML text string. parse() function allocates memory for nodes and attributes by using functions of xml_document, which are inherited from memory_pool. To access root node of the document, use the document itself, as if it was an xml_node.
- Parameters
-
Definition at line 139 of file rapidxml.hpp.
template<class Ch = char>
template<int Flags>
Parses zero-terminated XML string according to given flags. Passed string will be modified by the parser, unless rapidxml::parse_non_destructive flag is used. The string must persist for the lifetime of the document. In case of error, rapidxml::parse_error exception will be thrown.
If you want to parse contents of a file, you must first load the file into the memory, and pass pointer to its beginning. Make sure that data is zero-terminated.
Document can be parsed into multiple times. Each new call to parse removes previous nodes and attributes (if any), but does not clear memory pool.
- Parameters
-
text | XML data to parse; pointer is non-const to denote fact that this data may be modified by the parser. |
Definition at line 1381 of file rapidxml.hpp.