acl/lib_dict/include/dict_pool.h

179 lines
6.0 KiB
C

#ifndef __DICT_POOL_INCLUDE_H__
#define __DICT_POOL_INCLUDE_H__
#include "lib_acl.h"
#include "dict.h"
#ifdef __cplusplus
extern "C" {
#endif
typedef struct DICT_POOL DICT_POOL;
typedef struct DICT_POOL_DB DICT_POOL_DB;
/**
* 初始化,仅能被调用一次
*/
DICT_API void dict_pool_init(void);
/**
* 创建一个存储池
* @param partions {const char*} 存储分区情况的字符串数组
* @param partions_size {int} partions 分区的个数
* @param dict_type {const char*} 存储类型 (btree/hash/cdb)
* @param dict_name {const char*} 存储池名
* @param dict_size {int} 该存储池被分为几个存储分区
* @return {DICT_POOL*} 存储池的对象指针, 若为 NULL 则表示创建失败
*/
DICT_API DICT_POOL *dict_pool_new(const char **partions, int partions_size,
const char *dict_type, const char *dict_path,
const char *dict_name, int pool_size);
/**
* 关闭并释放一个存储池
* @param pool {DICT_POOL*} 某个存储池的对象指针
*/
DICT_API void dict_pool_free(DICT_POOL *pool);
/**
* 添加一个 key/value 对至一个存储池
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @param value {char*} 数据地址
* @param len {size_t} value 数据的长度大小(字节)
* @return {int} 0: OK, < 0: Error
*/
DICT_API int dict_pool_set(DICT_POOL *pool, char *key, size_t key_len, char *value, size_t len);
/**
* 从一个存储池中读取数据
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @param size {size_t*} 存储所读到数据对象的长度大小(字节)
* @param {char*} 所读到的数据地址,当为空时则表示该对象不存在,
* 注:如果返回的数据地址不为空,则调用者需在用完该返回数据对象后
* 用 acl_myfree/1 释放掉该返回的动态内存地址
*/
DICT_API char *dict_pool_get(DICT_POOL *pool, char *key, size_t key_len, size_t *size);
/**
* 从一个存储池中删除数据
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @return {int} 0: ok; != 0: error
*/
DICT_API int dict_pool_del(DICT_POOL *pool, char *key, size_t key_len);
/**
* 遍历存储中的所有数据
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @param key {char**} 如果结果非空则存储健值结果, 如果返回值不为空,
* 则释放 key 需要调用: acl_myfree/1, 否则会造成内存泄露
* @param key_size {size_t*} 若结果非空则存储健值结果的长度
* @param val {char**} 如果结果非空则存储数据结果, 如果返回值不为空,
* 则释放 val 需要调用: acl_myfree/1, 否则 会造成内存泄露
* @param val_size {size_t*} 如果结果非空则存储数据结果的长度
* @return {int} 0: 表示结果非空, != 0: 表示结果为空
*/
DICT_API int dict_pool_seq(DICT_POOL *pool, char **key, size_t *key_size,
char **val, size_t *val_size);
/**
* 重置存储遍历对象
* @param pool {DICT_POOL*} 某个存储池的对象指针
*/
DICT_API void dict_pool_seq_reset(DICT_POOL *pool);
/**
* 删除当前数据遍历光标所指的数据
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @return {int} 0: 删除OK, != 0: 不存在或删除失败
*/
DICT_API int dict_pool_seq_delcur(DICT_POOL *pool);
/**
* 根据健值从存储池中获得该健所在的存储DB
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @return {DICT_POOL_DB*} 存储DB
*/
DICT_API DICT_POOL_DB *dict_pool_db(DICT_POOL *pool, const char *key, size_t key_len);
/**
* 获得某存储DB的文件全路径
* @param pool {DICT_POOL*} 某个存储池的对象指针
* @return {const char*} 存储文件名
*/
DICT_API const char *dict_pool_db_path(DICT_POOL_DB *db);
/**
* 加锁某个存储DB
* @param {DICT_POOL_DB*} 存储DB
*/
DICT_API void dict_pool_db_lock(DICT_POOL_DB *db);
/**
* 解锁某个存储DB
* @param {DICT_POOL_DB*} 存储DB
*/
DICT_API void dict_pool_db_unlock(DICT_POOL_DB *db);
/**
* 添加或修改数据
* @param {DICT_POOL_DB*} 存储DB
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @param value {char*} 值
* @param len {size_t} value 长度
* @return {int} 0: ok; < 0: error
*/
DICT_API int dict_pool_db_set(DICT_POOL_DB *db, char *key, size_t key_len, char *value, size_t len);
/**
* 从存储DB中获得某个健所对应的值
* @param {DICT_POOL_DB*} 存储DB
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @param size {size_t*} 如果查询结果非空则存储返回结果的长度
* @return {char*} 健所对应的值, 需要用 acl_myfree()/1 释放
*/
DICT_API char *dict_pool_db_get(DICT_POOL_DB *db, char *key, size_t key_len, size_t *size);
/**
* 从存储DB中删除某个健对应的值
* @param {DICT_POOL_DB*} 存储DB
* @param key {char*} 健值地址
* @param key_len {size_t} key 的长度
* @return {int} 0: ok; != 0: error
*/
DICT_API int dict_pool_db_del(DICT_POOL_DB *db, char *key, size_t key_len);
/**
* 重置之前曾遍历的存储DB
* @param {DICT_POOL_DB*} 存储DB
*/
DICT_API void dict_pool_db_seq_reset(DICT_POOL_DB *db);
/**
* 遍历某个存储DB
* @param {DICT_POOL_DB*} 存储DB
* @param key {char**} 存储健的地址
* @param key_size {size_t*} 存储在 key 中数据的长度
* @param value {char**} 存储值的地址
* @param value_size {size_t*} 存储在 value 中数据的长度
* @return {int} 0: 表示结果非空, != 0: 表示结果为空
*/
DICT_API int dict_pool_db_seq(DICT_POOL_DB *db, char **key, size_t *key_size,
char **val, size_t *val_size);
#ifdef __cplusplus
}
#endif
#endif