acl
3.5.3.0
|
#include "../stdlib/acl_array.h"
#include "../stdlib/acl_ring.h"
#include "../stdlib/acl_vstream.h"
#include "../stdlib/acl_htable.h"
#include "../stdlib/acl_vstring.h"
#include "../stdlib/acl_iterator.h"
#include "../stdlib/acl_dbuf_pool.h"
类 | |
struct | ACL_XML_ATTR |
struct | ACL_XML_NODE |
struct | ACL_XML |
类型定义 | |
typedef struct ACL_XML | ACL_XML |
typedef struct ACL_XML_NODE | ACL_XML_NODE |
typedef struct ACL_XML_ATTR | ACL_XML_ATTR |
#define ACL_XML_F_META (ACL_XML_F_META_QM | ACL_XML_F_META_CM | ACL_XML_F_META_EM) |
#define ACL_XML_IS_CDATA | ( | x | ) | (((x)->flag & ACL_XML_F_CDATA)) |
#define ACL_XML_IS_COMMENT | ( | x | ) | (((x)->flag & ACL_XML_F_META_CM)) |
#define acl_xml_parse acl_xml_update |
typedef struct ACL_XML_ATTR ACL_XML_ATTR |
typedef struct ACL_XML_NODE ACL_XML_NODE |
ACL_API ACL_XML_ATTR* acl_xml_addElementAttr | ( | ACL_XML_NODE * | node, |
const char * | name, | ||
const char * | value | ||
) |
给 xml 节点添加属性, 如果该属性名已存在, 则用新的属性值替换其属性值, 否则 创建并添加新的属性对象
node | {ACL_XML_NODE*} xml 节点 |
name | {const char*} 属性名称 |
value | {const char*} 属性值 |
ACL_API ACL_XML* acl_xml_alloc | ( | void | ) |
创建一个 xml 对象
ACL_API ACL_XML_ATTR* acl_xml_attr_alloc | ( | ACL_XML_NODE * | node | ) |
创建 xml 节点的属性
node | {ACL_XML_NODE*} xml 节点 |
ACL_API ACL_VSTRING* acl_xml_build | ( | ACL_XML * | xml, |
ACL_VSTRING * | buf | ||
) |
将 xml 对象转成字符串内容
xml | {ACL_XML*} xml 对象 |
buf | {ACL_VSTRING*} 存储结果集的缓冲区,当该参数为空时则函数内部会 自动分配一段缓冲区,应用用完后需要释放掉;非空函数内部会直接将结果存储其中 |
ACL_API ACL_XML_NODE* acl_xml_create_node | ( | ACL_XML * | xml, |
const char * | tagname, | ||
const char * | text | ||
) |
将标签名及节点文本做为参数创建 xml 节点,该函数主要用在构建 xml 对象时
xml | {ACL_XML*} xml 对象,该对象应该是由 acl_xml_alloc 创建的 |
tagname | {const char*} 标签名,必须非空且字符串长度大于 0 |
text | {const char*} 节点的文本内容,可以为空 |
ACL_API ACL_XML_NODE* acl_xml_create_node_with_text_stream | ( | ACL_XML * | xml, |
const char * | tag, | ||
ACL_VSTREAM * | in, | ||
size_t | off, | ||
size_t | len | ||
) |
创建 xml 节点,使用文件流做为节点的文本内容项,同时会自动进行 XML 编码处理
xml | {ACL_XML*} xml 对象 |
tag | {const char*} 标签名,非 NULL 字符串 |
in | {ACL_VSTREAM *} 输入流,非 NULL 时,其中内容将做为 xml 节点的文本内容 |
off | {size_t} 当 in 为文件流时指定所拷贝内容在文件中的起始位置 |
len | {size_t} 指定从输入流中拷贝的最大数据长度,当为 0 时则一直拷贝至流结束 |
ACL_API ACL_XML* acl_xml_dbuf_alloc | ( | ACL_DBUF_POOL * | dbuf | ) |
创建一个 xml 对象,该 xml 对象及所有的内部内存分配都在该内存池上进行分配
dbuf | {ACL_DBUF_POOL*} 内存池对象,当该针对非 NULL 时,则 xml 对象 及所属节点内存在其基础上进行分配,否则,内部自动创建隶属于 xml 的内存池 |
ACL_API void acl_xml_decode_enable | ( | ACL_XML * | xml, |
int | on | ||
) |
解析 xml 对象时是否对属性值及文本值进行 xml 解码,内部缺省解码
xml | {ACL_XML*} |
on | {int} 非 0 表示进行 xml 解码 |
ACL_API void acl_xml_dump | ( | ACL_XML * | xml, |
ACL_VSTREAM * | fp | ||
) |
将 xml 对象转储于指定流中,注:该转储信息仅为调试用的数据
xml | {ACL_XML*} xml 对象 |
fp | {ACL_VSTREAM*} 流对象 |
ACL_API void acl_xml_dump2 | ( | ACL_XML * | xml, |
ACL_VSTRING * | buf | ||
) |
将 xml 对象转存于指定缓冲区中,注:该转储信息仅为调试用的数据
xml | {ACL_XML*} xml 对象 |
buf | {ACL_VSTRING*} 缓冲区, 需要用户自己分配空间 |
ACL_API void acl_xml_encode_enable | ( | ACL_XML * | xml, |
int | on | ||
) |
创建 xml 对象时是否对属性值及文本值进行 xml 编码,内部缺省编码
ACL_API void acl_xml_foreach_init | ( | ACL_XML * | xml, |
ACL_XML_NODE * | node | ||
) |
将某一个 ACL_XML_NODE 节点作为一个 XML 对象的根节点,从而可以方便地遍历出该 节点各级子节点(在遍历过程中的所有节点不含本节点自身),该遍历方式有别于单独 遍历某一个 ACL_XML_NODE 节点时仅能遍历其一级子节点的情形
xml | {ACL_XML*} xml 对象 |
node | {ACL_XML_NODE*} AXL_XML_NODE 节点 |
ACL_API int acl_xml_free | ( | ACL_XML * | xml | ) |
释放一个 xml 对象, 同时释放该对象里容纳的所有 xml 节点
xml | {ACL_XML*} xml 对象 |
ACL_API void acl_xml_free_array | ( | ACL_ARRAY * | a | ) |
ACL_API ACL_XML_ATTR* acl_xml_getAttrById | ( | ACL_XML * | xml, |
const char * | id | ||
) |
从 xml 对象中获得指定 id 值的 xml 节点元素的某个属性对象
xml | {ACL_XML*} xml 对象 |
id | {const char*} id 值 |
ACL_API const char* acl_xml_getAttrValueById | ( | ACL_XML * | xml, |
const char * | id | ||
) |
从 xml 对象中获得指定 id 值的 xml 节点元素的某个属性值
xml | {ACL_XML*} xml 对象 |
id | {const char*} id 值 |
ACL_API ACL_XML_ATTR* acl_xml_getElementAttr | ( | ACL_XML_NODE * | node, |
const char * | name | ||
) |
从 xml 节点中获得指定属性名的属性对象
node | {ACL_XML_NODE*} xml 节点 |
name | {const char*} 属性名称 |
ACL_API const char* acl_xml_getElementAttrVal | ( | ACL_XML_NODE * | node, |
const char * | name | ||
) |
从 xml 节点中获得指定属性名的属性值
node | {ACL_XML_NODE*} xml 节点 |
name | {const char*} 属性名称 |
ACL_API ACL_XML_NODE* acl_xml_getElementById | ( | ACL_XML * | xml, |
const char * | id | ||
) |
从 xml 对象中获得指定 id 值的 xml 节点元素
xml | {ACL_XML*} xml 对象 |
id | {const char*} id 值 |
ACL_API ACL_XML_NODE* acl_xml_getElementMeta | ( | ACL_XML * | xml, |
const char * | tag | ||
) |
从 xml 对象中提取有在 ? ! 等开头的节点
xml | {ACL_XML*} xml 对象 |
tag | {const char*} 标签名 |
ACL_API ACL_ARRAY* acl_xml_getElementsByAttr | ( | ACL_XML * | xml, |
const char * | name, | ||
const char * | value | ||
) |
从 xml 对象中获得所有给定属性名及属性值的 xml 节点元素集合
xml | {ACL_XML*} xml 对象 |
name | {const char*} 属性名 |
value | {const char*} 属性值 |
从 xml 对象中获得所有的与给定属性名 name 的属性值相同的 xml 节点元素集合
xml | {ACL_XML*} xml 对象 |
value | {const char*} 属性名为 name 的属性值 |
从 xml 对象中获得所有的与所给标签名相同的 xml 节点的集合
xml | {ACL_XML*} xml 对象 |
tag | {const char*} 标签名称 |
从 xml 对象中获得所有的与给定多级标签名相同的 xml 节点的集合
xml | {ACL_XML*} xml 对象 |
tags | {const char*} 多级标签名,由 '/' 分隔各级标签名,如针对 xml 数据: <root> <first> <second> <third name="test1"> text1 </third> </second> </first> <root> <first> <second> <third name="test2"> text2 </third> </second> </first> <root> <first> <second> <third name="test3"> text3 </third> </second> </first> 可以通过多级标签名:root/first/second/third 一次性查出所有符合条件的节点 |
ACL_API const char* acl_xml_getEncoding | ( | ACL_XML * | xml | ) |
获得 xml 的字符集编码格式
xml | {ACL_XML*} xml 对象 |
ACL_API ACL_XML_NODE* acl_xml_getFirstElementByTagName | ( | ACL_XML * | xml, |
const char * | tag | ||
) |
从 xml 对象中获得与所给标签名相同的 xml 第一个节点
xml | {ACL_XML*} xml 对象 |
tag | {const char*} 标签名称 |
ACL_API const char* acl_xml_getType | ( | ACL_XML * | xml | ) |
获得 xml 数据的类型,如:text/xsl
xml | {ACL_XML*} xml 对象 |
ACL_API int acl_xml_is_closure | ( | ACL_XML * | xml | ) |
判断 xml 对象是否闭合的, 即是否所解析的数据是否完整, 如果该 xml 对象里的 xml 节点元素为空, 则也认为不是闭合的
xml | {ACL_XML*} xml 对象 |
ACL_API int acl_xml_is_complete | ( | ACL_XML * | xml, |
const char * | tag | ||
) |
根据指定标签名判断 xml 解析已经完成, 当该标签与 xml 对象中 root 一级子节点 中的最后一个 xml 节点的标签相同时, 则认为 xml 解析完成, 为保证判断的正确性, 数据源应保证最外层的根节点只有一个, 即 xml->root 的一级子节点只有一个, 否则 会造成误判
xml | {ACL_XML*} xml 对象 |
tag | {const char*} 用户给定标签名, 内部在匹配时不区分大小写 |
ACL_API void acl_xml_multi_root | ( | ACL_XML * | xml, |
int | on | ||
) |
设置一个 xml 文档中是否允许有多个根 xml 节点,内部缺省支持多个根节点
xml | {ACL_XML*} xml 对象 |
on | {int} 非 0 则允许,为 0 表示不允许,当禁止有多个根 xml 节点时, 则在解析时当遇到第一个根节点结束时便返回剩余的数据 |
ACL_API ACL_XML_ATTR* acl_xml_node_add_attr | ( | ACL_XML_NODE * | node, |
const char * | name, | ||
const char * | value | ||
) |
给一个 xml 节点添加属性,该函数主要用在构建 xml 对象时
node | {ACL_XML_NODE*} 由 acl_xml_create_node 创建的节点 |
name | {const char*} 属性名,必须为非空字符串且字符串长度大于 0 |
value | {const char*} 属性值,可以为空 |
ACL_API void acl_xml_node_add_attrs | ( | ACL_XML_NODE * | node, |
... | |||
) |
给一个 xml 节点添加一组属性,该函数主要用在构建 xml 对象时
node | {ACL_XML_NODE*} 由 acl_xml_create_node 创建的节点 |
... | 一组属性,遇到 NULL 时表示结束,如: {name1}, {value1}, {name2}, {value2}, ... NULL |
ACL_API void acl_xml_node_add_child | ( | ACL_XML_NODE * | parent, |
ACL_XML_NODE * | child | ||
) |
将某个 xml 节点作为子节点加入某父 xml 节点中
parent | {ACL_XML_NODE*} 父节点 |
child | {ACL_XML_NODE*} 子节点 |
ACL_API void acl_xml_node_add_text | ( | ACL_XML_NODE * | node, |
const char * | text | ||
) |
给一个 xml 节点的文本追加内容,该函数主要用在构建 xml 对象时,在该节点的文本内容上 追加新的文本内容
node | {ACL_XML_NODE*} 由 acl_xml_create_node 创建的节点 |
text | {const char*} 文本内容 |
ACL_API ACL_XML_NODE* acl_xml_node_alloc | ( | ACL_XML * | xml | ) |
创建一个 xml 节点
xml | {ACL_XML*} xml 对象 |
ACL_API void acl_xml_node_append | ( | ACL_XML_NODE * | node1, |
ACL_XML_NODE * | node2 | ||
) |
向某个 xml 节点添加兄弟节点(该兄弟节点必须是独立的 xml 节点)
node1 | {ACL_XML_NODE*} 向本节点添加 xml 节点 |
node2 | {ACL_XML_NODE*} 新添加的兄弟 xml 节点 |
ACL_API int acl_xml_node_delete | ( | ACL_XML_NODE * | node | ) |
将某个 xml 节点及其子节点从 xml 对象中删除, 并释放该节点及其子节点所占空间 函数来释放该 xml 节点所占内存
node | {ACL_XML_NODE*} xml 节点 |
ACL_API ACL_XML_NODE* acl_xml_node_next | ( | ACL_XML_NODE * | node | ) |
获得某个 xml 节点的后一个兄弟节点
node | {ACL_XML_NODE*} xml 节点 |
ACL_API ACL_XML_NODE* acl_xml_node_parent | ( | ACL_XML_NODE * | node | ) |
获得某个 xml 节点的父节点
node | {ACL_XML_NODE*} xml 节点 |
ACL_API ACL_XML_NODE* acl_xml_node_prev | ( | ACL_XML_NODE * | node | ) |
获得某个 xml 节点的前一个兄弟节点
node | {ACL_XML_NODE*} xml 节点 |
ACL_API void acl_xml_node_set_text | ( | ACL_XML_NODE * | node, |
const char * | text | ||
) |
给一个 xml 节点添加文本内容,该函数主要用在构建 xml 对象时,当该节点之前有文本内容时 则用新文本覆盖原文本
node | {ACL_XML_NODE*} 由 acl_xml_create_node 创建的节点 |
text | {const char*} 文本内容 |
ACL_API void acl_xml_node_set_text_stream | ( | ACL_XML_NODE * | node, |
ACL_VSTREAM * | fp, | ||
size_t | off, | ||
size_t | len | ||
) |
用文件流中的内容给一个 xml 节点添加文本内容
node | {ACL_XML_NODE*} 由 acl_xml_create_node 创建的节点 |
fp | {ACL_VSTREAM*} 输入流对象 |
off | {size_t} 当 in 为文件流,指定在文件中的起始位置 |
len | {size_t} 要拷贝的最大数据长度,当为 0 时则一直拷贝至流结束 |
ACL_API int acl_xml_removeElementAttr | ( | ACL_XML_NODE * | node, |
const char * | name | ||
) |
从 xml 节点删除某个属性对象, 如果该属性为 id 属性, 则同时会从 xml->id_table 中删除
node | {ACL_XML_NODE*} xml 节点 |
name | {const char*} 属性名称 |
ACL_API void acl_xml_reset | ( | ACL_XML * | xml | ) |
重置 XML 解析器对象
xml | {ACL_XML*} xml 对象 |
ACL_API void acl_xml_slash | ( | ACL_XML * | xml, |
int | ignore | ||
) |
对于 XML 单节点的情况, 是否允许可以没有 /, 如: <test id="111">, <test id="111">, 当可以允许没有 / 则这两种写法 都是合法的,否则只有第二个写法是合法的,如果允许这种兼容性,则 会造成一定的性能损失
xml | {ACL_XML*} xml 对象 |
ignore | {int} 如果非 0 表示单节点必须有 / |
ACL_API size_t acl_xml_space | ( | ACL_XML * | xml | ) |
获得当前 xml 对象内部已经分配的内存空间大小
xml | {ACL_XML*} |
ACL_API void acl_xml_space_clear | ( | ACL_XML * | xml | ) |
将 xml 对象内部记录内存大小的变量清 0
xml | {ACL_XML*} |
ACL_API void acl_xml_tag_add | ( | const char * | tag | ) |
允许用户自己添加一些非自闭合的标签
tag | {const char*} 标签名,注意标签长度不得大于 254 个字节 |
ACL_API void acl_xml_tag_init | ( | void | ) |
初始化类似于 input, br, hr 等的自闭合标签, 形成自闭合标签树, 以便于 acl_xml_tag_selfclosed 查询该树, 检查所给标签是否是保留的自闭合标签, 该函数只能被初始化一次, 也可以不初始化
ACL_API int acl_xml_tag_leaf | ( | const char * | tag | ) |
判断标签所属 xml 节点是否是叶节点, 叶节点没有子节点
tag | {const char*} 标签名 |
ACL_API int acl_xml_tag_selfclosed | ( | const char * | tag | ) |
当调用 acl_xml_tag_init 初始化保留的自闭合标签树后, 可以调用此函数判断所给 标签是否属于自闭合标签, 如果未调用 acl_xml_tag_init, 则该函数永远返回 0 @parma tag {const char*} 标签名称
ACL_API const char* acl_xml_update | ( | ACL_XML * | xml, |
const char * | data | ||
) |
解析 xml 数据, 并持续地自动生成 xml 节点树
xml | {ACL_XML*} xml 对象 |
data | {const char*} 以 '\0' 结尾的数据字符串, 可以是完整的 xml 数据; 也可以是不完整的 xml 数据, 允许循环调用此函数, 将不完整数据持续地输入 |