acl/lib_acl_cpp/include/acl_cpp/stdlib/xml2.hpp

302 lines
5.4 KiB
C++

#pragma once
#include "acl_cpp/acl_cpp_define.hpp"
#include <vector>
#include <list>
#include "acl_cpp/stdlib/string.hpp"
#include "acl_cpp/stdlib/xml.hpp"
struct ACL_XML2;
struct ACL_XML2_NODE;
struct ACL_XML2_ATTR;
namespace acl {
class xml2;
class xml2_node;
class ACL_CPP_API xml2_attr : public xml_attr
{
public:
/**
* @override
* @return {const char*}
*/
const char* get_name() const;
/**
* @override
* @return {const char*}
*/
const char* get_value() const;
protected:
friend class xml2_node;
xml2_attr(xml_node* node, ACL_XML2_ATTR* attr);
~xml2_attr(void) {}
private:
ACL_XML2_ATTR* attr_;
};
class ACL_CPP_API xml2_node : public xml_node
{
public:
/**
* @override
*/
const char* tag_name(void) const;
/**
* @override
*/
const char* id(void) const;
/**
* @override
*/
const char* text(void) const;
/**
* @override
*/
const char* attr_value(const char* name) const;
/**
* @override
*/
const xml_attr* first_attr(void) const;
/**
* @override
*/
const xml_attr* next_attr(void) const;
/**
* @override
*/
xml_node& add_attr(const char* name, const char* value);
/**
* @override
*/
xml_node& set_text(const char* str);
/**
* @override
*/
xml_node& add_child(xml_node* child, bool return_child = false);
/**
* @override
*/
xml_node& get_parent(void) const;
/**
* @override
*/
xml_node* first_child(void);
/**
* @override
*/
xml_node* next_child(void);
/**
* @override
*/
int depth(void) const;
/**
* @override
*/
int children_count(void) const;
public:
void set_xml2_node(ACL_XML2_NODE* node);
ACL_XML2_NODE* get_xml_node(void) const;
xml_node& set_parent(xml_node* node);
protected:
friend class xml2;
xml2_node(xml* xml_ptr, ACL_XML2_NODE* node);
~xml2_node(void);
private:
ACL_XML2_NODE *node_;
ACL_ITER* child_iter_;
ACL_ITER* attr_iter_;
xml_node* parent_;
xml2_node* parent_internal_;
};
class fstream;
class ACL_CPP_API xml2 : public xml
{
public:
/**
* 构造函数,使 xml 对象树创建在指定的内存块上
* @param addr {char*} 内存映射的地址或内存地址,解析过程中产生的数据
* 将存储于该内存区域中
* @param size {size_t} addr 内存空间大小,当解析产生的数据超过此值
* 时则解析过程停止,所以必须保证该空间大小足够用
* @param data {const char*} 非空时自动调用解析过程
*/
xml2(char* addr, size_t size, const char* data = NULL);
/**
* 构造函数,使 xml 对象树创建在指定内存映射文件上
* @param filepath {const char*} 内存映射文件名
* @param size {size_t} 内存映射文件的最大大小,即内存映射文件在自动
* 增长时不应超过此大小
* @param data {const char*} 非空时自动调用解析过程
* @param block {size_t} 内存映射文件创建时的初始大小
* @param keep_open {bool} 打开的内存映射文件的句柄是否一直保持打开
* 状态,这样可以提高文件增长时的效率
*/
xml2(const char* filepath, size_t size, const char* data = NULL,
size_t block = 8192, bool keep_open = true);
/**
* 构造函数,使 xml 对象树创建在指定内存映射文件上
* @param fp {fstream&} 内存映射文件句柄,该文件句柄应在本 xml 对象
* 释放前一直保持打开状态,即 fp 必须在 xml 对象释放后才可以关闭
* @param size {size_t} 内存映射文件的最大大小,即内存映射文件在自动
* 增长时不应超过此大小
* @param data {const char*} 非空时自动调用解析过程
* @param block {size_t} 内存映射文件创建时的初始大小
*/
xml2(fstream& fp, size_t size, const char* data = NULL,
size_t block = 8192);
/**
* 构造函数,使 xml 对象树创建在指定内存映射文件上
* @param fd {ACL_FILE_HANDLE} 内存映射文件句柄,该文件句柄应在本 xml
* 对象释放前一直保持打开状态,即 fp 必须在 xml 对象释放后才可以关闭
* @param size {size_t} 内存映射文件的最大大小,即内存映射文件在自动
* 增长时不应超过此大小
* @param data {const char*} 非空时自动调用解析过程
* @param block {size_t} 内存映射文件创建时的初始大小
*/
#if defined(_WIN32) || defined(_WIN64)
xml2(void* fd, size_t size, const char* data = NULL,
size_t block = 8192);
#else
xml2(int fd, size_t size, const char* data = NULL,
size_t block = 8192);
#endif
~xml2(void);
/**
* @override
*/
xml& ignore_slash(bool on);
/**
* @override
*/
xml& xml_decode(bool on);
/**
* @override
*/
void update(const char* data);
/**
* @override
*/
void reset(void);
/**
* @override
*/
const string& getText(void);
/**
* @override
*/
const std::vector<xml_node*>&
getElementsByTagName(const char* tag) const;
/**
* @override
*/
const xml_node* getFirstElementByTag(const char* tag) const;
/**
* @override
*/
const std::vector<xml_node*>&
getElementsByTags(const char* tags) const;
/**
* @override
*/
const xml_node* getFirstElementByTags(const char* tags) const;
/**
* @override
*/
const std::vector<xml_node*>&
getElementsByName(const char* value) const;
/**
* @override
*/
const std::vector<xml_node*>& getElementsByAttr(
const char* name, const char* value) const;
/**
* @override
*/
const xml_node* getElementById(const char* id) const;
/**
* @override
*/
xml_node& create_node(const char* tag, const char* text = NULL);
/**
* @override
*/
xml_node& get_root(void);
/**
* @override
*/
xml_node* first_node(void);
/**
* @override
*/
xml_node* next_node(void);
/**
* @override
*/
void build_xml(string& out) const;
/**
* @override
*/
const char* to_string(size_t* len) const;
public:
ACL_XML2* get_xml2(void) const
{
return xml_;
}
private:
ACL_XML2* xml_;
ACL_ITER* iter_;
xml2_node* root_;
};
} // namespace acl