From 2ac3eef044245a6ca23f1feea70c435ac1fa28dd Mon Sep 17 00:00:00 2001 From: zhengshuxin Date: Wed, 22 Mar 2023 17:20:21 +0800 Subject: [PATCH] Optimize htable module --- lib_acl/include/stdlib/acl_htable.h | 18 +- lib_acl/lib_acl.rc | 8 +- lib_acl/lib_acl_vc2017.rc | 8 +- lib_acl/lib_acl_vc2019.rc | 8 +- lib_acl/samples/cache2/test.sh | 0 lib_acl/src/init/acl_init.c | 2 +- lib_acl/src/stdlib/common/acl_htable.c | 454 ++++++++++++++----------- lib_acl_cpp/lib_acl_cpp_vc2003.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2008.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2010.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2012.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2013.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2015.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2017.rc | 8 +- lib_acl_cpp/lib_acl_cpp_vc2019.rc | 8 +- packaging/acl-libs.spec | 5 +- unit_test/stdlib/test_avl.c | 9 +- unit_test/stdlib/test_htable.c | 10 +- 18 files changed, 327 insertions(+), 259 deletions(-) mode change 100644 => 100755 lib_acl/samples/cache2/test.sh diff --git a/lib_acl/include/stdlib/acl_htable.h b/lib_acl/include/stdlib/acl_htable.h index 299e2f7e1..4c318978d 100644 --- a/lib_acl/include/stdlib/acl_htable.h +++ b/lib_acl/include/stdlib/acl_htable.h @@ -146,14 +146,12 @@ ACL_API ACL_HTABLE_INFO *acl_htable_enter(ACL_HTABLE *table, * @param key 键, 在函数内部会复制此 key 键 * @param value 用户自己的特定数据项(可以由类型硬转化而来, 但是此数据项必须 * 不能堆栈变量) - * @param callback 如果该函数指针不为空,则当添加成功后便调用该函数 - * @param arg callback 的参数之一 - * @return {int} 0 表示 添加成功,-1 表示添加失败 + * @return 所分配的哈希表项的指针, == NULL: 表示内部分配内存出错, 为严重的错误 * 注:如果在添加时该哈希争键存在,则返回已经存在的哈希项,使用者应该通过调用 * acl_htable_last_errno() 来查看是否重复添加同一个键值(ACL_HTABLE_STAT_DUPLEX_KEY) */ -ACL_API int acl_htable_enter_r(ACL_HTABLE *table, const char *key, void *value, - void (*callback)(ACL_HTABLE_INFO *ht, void *arg), void *arg); +ACL_API ACL_HTABLE_INFO *acl_htable_enter_r(ACL_HTABLE *table, + const char *key, void *value); /** * 由所给的 key 键查寻某一特定哈希项 @@ -169,13 +167,10 @@ ACL_API ACL_HTABLE_INFO *acl_htable_locate(ACL_HTABLE *table, const char *key); * 函数内部会自动保证互斥操作 * @param table 哈希表指针 * @param key 键 - * @param callback 查到所要求的键值后如果该指针非空则调用之 - * @param arg callback 参数之一 * @return 不为空指针: 表示查到了对应于 key 键的哈希项 * 为空: 表示未查到对应于 key 键的哈希项 */ -ACL_API int acl_htable_locate_r(ACL_HTABLE *table, const char *key, - void (*callback)(ACL_HTABLE_INFO *ht, void *arg), void *arg); +ACL_API ACL_HTABLE_INFO *acl_htable_locate_r(ACL_HTABLE *table, const char *key); /** * 由所给的 key 键查寻用户的数据项 @@ -191,13 +186,10 @@ ACL_API void *acl_htable_find(ACL_HTABLE *table, const char *key); * 函数内部会自动保证互斥操作 * @param table 哈希表指针 * @param key 键 - * @param callback 当查到所要求的键值后,如果该函数指针不为空则调用之 - * @param arg callback 的参数之一 * @return 不为空: 表示查到了对应于 key 键的数据项, 用户可以根据用户自己的 * 数据类型进行转换; 为空: 表示未查到对应于 key 键的数据项 */ -ACL_API int acl_htable_find_r(ACL_HTABLE *table, const char *key, - void (*callback)(void *value, void *arg), void *arg); +ACL_API void *acl_htable_find_r(ACL_HTABLE *table, const char *key); /** * 根据所给的 key 键删除某一哈希项 diff --git a/lib_acl/lib_acl.rc b/lib_acl/lib_acl.rc index f4a89ff00..cdd12cf7a 100644 --- a/lib_acl/lib_acl.rc +++ b/lib_acl/lib_acl.rc @@ -52,8 +52,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN BEGIN VALUE "Comments", "本库为跨平台的C库,包括了网络通讯,服务器框架等功能" VALUE "FileDescription", "acl 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl" VALUE "LegalCopyright", "zsx (C) 2022" VALUE "OriginalFilename", "lib_acl.lib" VALUE "ProductName", " acl 库" - VALUE "ProductVersion", "3, 6, 1, 1" + VALUE "ProductVersion", "3, 6, 1, 2" END END BLOCK "VarFileInfo" diff --git a/lib_acl/lib_acl_vc2017.rc b/lib_acl/lib_acl_vc2017.rc index 85d356e9f..f6b3df075 100644 --- a/lib_acl/lib_acl_vc2017.rc +++ b/lib_acl/lib_acl_vc2017.rc @@ -52,8 +52,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN BEGIN VALUE "Comments", "本库为跨平台的C库,包括了网络通讯,服务器框架等功能" VALUE "FileDescription", "acl 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl" VALUE "LegalCopyright", "zsx (C) 2022" VALUE "OriginalFilename", "lib_acl.lib" VALUE "ProductName", " acl 库" - VALUE "ProductVersion", "3, 6, 1, 1" + VALUE "ProductVersion", "3, 6, 1, 2" END END BLOCK "VarFileInfo" diff --git a/lib_acl/lib_acl_vc2019.rc b/lib_acl/lib_acl_vc2019.rc index 85d356e9f..f6b3df075 100644 --- a/lib_acl/lib_acl_vc2019.rc +++ b/lib_acl/lib_acl_vc2019.rc @@ -52,8 +52,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN BEGIN VALUE "Comments", "本库为跨平台的C库,包括了网络通讯,服务器框架等功能" VALUE "FileDescription", "acl 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl" VALUE "LegalCopyright", "zsx (C) 2022" VALUE "OriginalFilename", "lib_acl.lib" VALUE "ProductName", " acl 库" - VALUE "ProductVersion", "3, 6, 1, 1" + VALUE "ProductVersion", "3, 6, 1, 2" END END BLOCK "VarFileInfo" diff --git a/lib_acl/samples/cache2/test.sh b/lib_acl/samples/cache2/test.sh old mode 100644 new mode 100755 diff --git a/lib_acl/src/init/acl_init.c b/lib_acl/src/init/acl_init.c index 111effd62..4653e3e43 100644 --- a/lib_acl/src/init/acl_init.c +++ b/lib_acl/src/init/acl_init.c @@ -25,7 +25,7 @@ #include "init.h" -static char *version = "3.6.1-1 20230321-10:42"; +static char *version = "3.6.1-2 20230322-15:35"; const char *acl_version(void) { diff --git a/lib_acl/src/stdlib/common/acl_htable.c b/lib_acl/src/stdlib/common/acl_htable.c index 91beefb74..75d7ab666 100644 --- a/lib_acl/src/stdlib/common/acl_htable.c +++ b/lib_acl/src/stdlib/common/acl_htable.c @@ -46,7 +46,7 @@ static void *htable_iter_head(ACL_ITER *iter, ACL_HTABLE *table) iter->data = NULL; iter->key = NULL; } - return (iter->ptr); + return iter->ptr; } /* htable_iter_next */ @@ -61,7 +61,7 @@ static void *htable_iter_next(ACL_ITER *iter, ACL_HTABLE *table) if (ptr != NULL) { iter->data = ptr->value; iter->key = ptr->key.c_key; - return (iter->ptr); + return iter->ptr; } } @@ -79,7 +79,7 @@ static void *htable_iter_next(ACL_ITER *iter, ACL_HTABLE *table) iter->data = NULL; iter->key = NULL; } - return (iter->ptr); + return iter->ptr; } /* htable_iter_tail */ @@ -108,7 +108,7 @@ static void *htable_iter_tail(ACL_ITER *iter, ACL_HTABLE *table) iter->data = NULL; iter->key = NULL; } - return (iter->ptr); + return iter->ptr; } /* htable_iter_prev */ @@ -123,7 +123,7 @@ static void *htable_iter_prev(ACL_ITER *iter, ACL_HTABLE *table) if (ptr != NULL) { iter->data = ptr->value; iter->key = ptr->key.c_key; - return (iter->ptr); + return iter->ptr; } } @@ -141,14 +141,14 @@ static void *htable_iter_prev(ACL_ITER *iter, ACL_HTABLE *table) iter->data = NULL; iter->key = NULL; } - return (iter->ptr); + return iter->ptr; } /* htable_iter_info */ static ACL_HTABLE_INFO *htable_iter_info(ACL_ITER *iter, struct ACL_HTABLE *table acl_unused) { - return (iter->ptr ? (ACL_HTABLE_INFO*) iter->ptr : NULL); + return iter->ptr ? (ACL_HTABLE_INFO*) iter->ptr : NULL; } /* __def_hash_fn - hash a string */ @@ -192,23 +192,27 @@ static int htable_size(ACL_HTABLE *table, unsigned size) size |= 1; - if (table->slice) + if (table->slice) { table->data = h = (ACL_HTABLE_INFO **) acl_slice_pool_alloc(__FILE__, __LINE__, table->slice, size * sizeof(ACL_HTABLE_INFO *)); - else + } else { table->data = h = (ACL_HTABLE_INFO **) acl_mymalloc(size * sizeof(ACL_HTABLE_INFO *)); - if(table->data == NULL) - return(-1); + } + + if(table->data == NULL) { + return -1; + } table->size = size; table->used = 0; - while (size-- > 0) + while (size-- > 0) { *h++ = 0; + } - return(0); + return 0; } /* htable_grow - extend existing table */ @@ -224,8 +228,9 @@ static int htable_grow(ACL_HTABLE *table) unsigned n; ret = htable_size(table, 2 * old_size); - if (ret < 0) - return(-1); + if (ret < 0) { + return -1; + } while (old_size-- > 0) { for (ht = *h0++; ht; ht = next) { @@ -236,11 +241,13 @@ static int htable_grow(ACL_HTABLE *table) } } - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, old_entries); - else + } else { acl_myfree(old_entries); - return(0); + } + + return 0; } #define _RWLOCK_TYPE acl_pthread_mutex_t @@ -257,44 +264,48 @@ static int __init_table_rwlock(ACL_HTABLE *table, int enable) int ret; if (enable && table->rwlock == NULL) { - if (table->slice) + if (table->slice) { table->rwlock = acl_slice_pool_calloc(__FILE__, __LINE__, - table->slice, 1, sizeof(_RWLOCK_TYPE)); - else + table->slice, 1, sizeof(_RWLOCK_TYPE)); + } else { table->rwlock = acl_mycalloc(1, sizeof(_RWLOCK_TYPE)); + } + if (table->rwlock == NULL) { - acl_msg_error("%s(%s): calloc error(%s)", - __FILE__, myname, acl_last_strerror(tbuf, sizeof(tbuf))); - return (-1); + acl_msg_error("%s(%s): calloc error(%s)", __FILE__, + myname, acl_last_strerror(tbuf, sizeof(tbuf))); + return -1; } ret = _RWLOCK_INIT(table->rwlock, NULL); if (ret) { - acl_msg_error("%s(%d): init rwlock error(%s)", - __FILE__, __LINE__, acl_strerror(ret, tbuf, sizeof(tbuf))); - if (table->slice) + acl_msg_error("%s(%d): init rwlock error(%s)", __FILE__, + __LINE__, acl_strerror(ret, tbuf, sizeof(tbuf))); + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table->rwlock); - else + } else { acl_myfree(table->rwlock); - return (-1); + } + return -1; } } else if (!enable && table->rwlock) { _RWLOCK_DESTROY(table->rwlock); - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table->rwlock); - else + } else { acl_myfree(table->rwlock); + } table->rwlock = NULL; } - return (0); + return 0; } /* acl_htable_create - create initial hash table */ ACL_HTABLE *acl_htable_create(int size, unsigned int flag) { - return (acl_htable_create3(size, flag, NULL)); + return acl_htable_create3(size, flag, NULL); } ACL_HTABLE *acl_htable_create3(int size, unsigned int flag, ACL_SLICE_POOL *slice) @@ -305,13 +316,15 @@ ACL_HTABLE *acl_htable_create3(int size, unsigned int flag, ACL_SLICE_POOL *slic if (slice) { table = (ACL_HTABLE *) acl_slice_pool_calloc(__FILE__, __LINE__, slice, 1, sizeof(ACL_HTABLE)); - if (table == NULL) - return (NULL); + if (table == NULL) { + return NULL; + } table->slice = slice; } else { table = (ACL_HTABLE *) acl_mycalloc(1, sizeof(ACL_HTABLE)); - if (table == NULL) - return (NULL); + if (table == NULL) { + return NULL; + } table->slice = NULL; } @@ -320,10 +333,11 @@ ACL_HTABLE *acl_htable_create3(int size, unsigned int flag, ACL_SLICE_POOL *slic ret = htable_size(table, size < 13 ? 13 : size); if(ret < 0) { - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table); - else + } else { acl_myfree(table); + } return(NULL); } @@ -338,40 +352,39 @@ ACL_HTABLE *acl_htable_create3(int size, unsigned int flag, ACL_SLICE_POOL *slic if ((flag & ACL_HTABLE_FLAG_USE_LOCK)) { ret = __init_table_rwlock(table, 1); if (ret < 0) { - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table); - else + } else { acl_myfree(table); - return (NULL); + } + return NULL; } - } else + } else { table->rwlock = NULL; + } - return (table); + return table; } #ifdef ACL_BCB_COMPILER static void LOCK_TABLE_READ(const ACL_HTABLE *table) { if (table->rwlock && _RWLOCK_RDLOCK(table->rwlock) != 0) { - acl_msg_fatal("%s(%d): read lock error", - __FILE__, __LINE__); + acl_msg_fatal("%s(%d): read lock error", __FILE__, __LINE__); } } static void LOCK_TABLE_WRITE(const ACL_HTABLE *table) { if (table->rwlock && _RWLOCK_WRLOCK(table->rwlock) != 0) { - acl_msg_fatal("%s(%d): write lock error", - __FILE__, __LINE__); + acl_msg_fatal("%s(%d): write lock error", __FILE__, __LINE__); } } static void UNLOCK_TABLE(const ACL_HTABLE *table) { if (table->rwlock && _RWLOCK_UNLOCK(table->rwlock) != 0) { - acl_msg_fatal("%s(%d): unlock error", - __FILE__, __LINE__); + acl_msg_fatal("%s(%d): unlock error", __FILE__, __LINE__); } } #else @@ -379,7 +392,7 @@ static void UNLOCK_TABLE(const ACL_HTABLE *table) int _ret; \ if (_table->rwlock && (_ret = _RWLOCK_RDLOCK(_table->rwlock))) { \ acl_msg_fatal("%s(%d): read lock error(%s)", \ - __FILE__, __LINE__, strerror(_ret)); \ + __FILE__, __LINE__, strerror(_ret)); \ } \ } while (0) @@ -387,7 +400,7 @@ static void UNLOCK_TABLE(const ACL_HTABLE *table) int _ret; \ if (_table->rwlock && (_ret = _RWLOCK_WRLOCK(_table->rwlock))) { \ acl_msg_fatal("%s(%d): write lock error(%s)", \ - __FILE__, __LINE__, strerror(_ret)); \ + __FILE__, __LINE__, strerror(_ret)); \ } \ } while (0) @@ -395,7 +408,7 @@ static void UNLOCK_TABLE(const ACL_HTABLE *table) int _ret; \ if (_table->rwlock && (_ret = _RWLOCK_UNLOCK(_table->rwlock))) { \ acl_msg_fatal("%s(%d): unlock error(%s)", \ - __FILE__, __LINE__, strerror(_ret)); \ + __FILE__, __LINE__, strerror(_ret)); \ } \ } while (0) #endif @@ -405,24 +418,28 @@ void acl_htable_ctl(ACL_HTABLE *table, int name, ...) const char *myname = "acl_htable_ctl"; va_list ap; - if (table == NULL) + if (table == NULL) { return; + } va_start(ap, name); for (; name != ACL_HTABLE_CTL_END; name = va_arg(ap, int)) { switch (name) { case ACL_HTABLE_CTL_HASH_FN: table->hash_fn = va_arg(ap, ACL_HASH_FN); - if (table->hash_fn == NULL) + if (table->hash_fn == NULL) { table->hash_fn = __def_hash_fn; + } break; case ACL_HTABLE_CTL_RWLOCK: - if (__init_table_rwlock(table, va_arg(ap, int)) < 0) + if (__init_table_rwlock(table, va_arg(ap, int)) < 0) { acl_msg_fatal("%s: init rwlock error", myname); + } break; default: acl_msg_fatal("%s: bad name %d", myname, name); + break; } } va_end(ap); @@ -430,15 +447,17 @@ void acl_htable_ctl(ACL_HTABLE *table, int name, ...) int acl_htable_errno(ACL_HTABLE *table) { - if (table == NULL) - return (ACL_HTABLE_STAT_INVAL); - return (table->status); + if (table == NULL) { + return ACL_HTABLE_STAT_INVAL; + } + return table->status; } void acl_htable_set_errno(ACL_HTABLE *table, int error) { - if (table) + if (table) { table->status = error; + } } #define STREQ(x,y) (x == y || (x[0] == y[0] && strcmp(x,y) == 0)) @@ -455,27 +474,29 @@ ACL_HTABLE_INFO *acl_htable_enter(ACL_HTABLE *table, const char *key_in, void *v const char *key; #undef RETURN -#define RETURN(x) do \ -{ \ +#define RETURN(x) do { \ if (keybuf) { \ - if (table->slice) \ + if (table->slice) { \ acl_slice_pool_free(__FILE__, __LINE__, keybuf); \ - else \ + } else { \ acl_myfree(keybuf); \ + } \ } \ return (x); \ } while (0) if ((table->flag & ACL_HTABLE_FLAG_KEY_LOWER)) { - if (table->slice) + if (table->slice) { keybuf = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key_in); - else + } else { keybuf = acl_mystrdup(key_in); + } acl_lowercase(keybuf); key = keybuf; - } else + } else { key = key_in; + } table->status = ACL_HTABLE_STAT_OK; hash = table->hash_fn(key, strlen(key)); @@ -498,30 +519,34 @@ ACL_HTABLE_INFO *acl_htable_enter(ACL_HTABLE *table, const char *key_in, void *v } } - if (table->slice) + if (table->slice) { ht = (ACL_HTABLE_INFO*) acl_slice_pool_alloc(__FILE__, __LINE__, table->slice, sizeof(ACL_HTABLE_INFO)); - else + } else { ht = (ACL_HTABLE_INFO *) acl_mymalloc(sizeof(ACL_HTABLE_INFO)); + } + if (ht == NULL) { acl_msg_error("%s(%d): alloc error", myname, __LINE__); RETURN (NULL); } - if ((table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) + if ((table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) { ht->key.c_key = key; - else { - if (table->slice) + } else { + if (table->slice) { ht->key.key = acl_slice_pool_strdup(__FILE__, __LINE__, - table->slice, key); - else + table->slice, key); + } else { ht->key.key = acl_mystrdup(key); + } if (ht->key.key == NULL) { acl_msg_error("%s(%d): alloc error", myname, __LINE__); - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, ht); - else + } else { acl_myfree(ht); + } RETURN (NULL); } } @@ -532,8 +557,8 @@ ACL_HTABLE_INFO *acl_htable_enter(ACL_HTABLE *table, const char *key_in, void *v RETURN (ht); } -int acl_htable_enter_r(ACL_HTABLE *table, const char *key_in, void *value, - void (*callback)(ACL_HTABLE_INFO *ht, void *arg), void *arg) +ACL_HTABLE_INFO *acl_htable_enter_r(ACL_HTABLE *table, + const char *key_in, void *value) { const char *myname = "acl_htable_enter_r"; ACL_HTABLE_INFO *ht; @@ -543,27 +568,29 @@ int acl_htable_enter_r(ACL_HTABLE *table, const char *key_in, void *value, const char *key; #undef RETURN -#define RETURN(x) do \ -{ \ +#define RETURN(x) do { \ if (keybuf) { \ - if (table->slice) \ + if (table->slice) { \ acl_slice_pool_free(__FILE__, __LINE__, keybuf); \ - else \ + } else { \ acl_myfree(keybuf); \ + } \ } \ return (x); \ } while (0) if ((table->flag & ACL_HTABLE_FLAG_KEY_LOWER)) { - if (table->slice) + if (table->slice) { keybuf = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key_in); - else + } else { keybuf = acl_mystrdup(key_in); + } acl_lowercase(keybuf); key = keybuf; - } else + } else { key = key_in; + } hash = table->hash_fn(key, strlen(key)); @@ -574,7 +601,7 @@ int acl_htable_enter_r(ACL_HTABLE *table, const char *key_in, void *value, ret = htable_grow(table); if(ret < 0) { UNLOCK_TABLE(table); - RETURN (-1); + RETURN (NULL); } } @@ -585,37 +612,33 @@ int acl_htable_enter_r(ACL_HTABLE *table, const char *key_in, void *value, acl_msg_info("%s(%d): duplex key(%s) exist", myname, __LINE__, key); table->status = ACL_HTABLE_STAT_DUPLEX_KEY; - if (callback) - callback(ht, arg); UNLOCK_TABLE(table); - RETURN (0); + RETURN (ht); } } - if (table->slice) + if (table->slice) { ht = (ACL_HTABLE_INFO*) acl_slice_pool_alloc(__FILE__, __LINE__, table->slice, sizeof(ACL_HTABLE_INFO)); - else + } else { ht = (ACL_HTABLE_INFO *) acl_mymalloc(sizeof(ACL_HTABLE_INFO)); + } - if ((table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) + if ((table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) { ht->key.c_key = key; - else if (table->slice) + } else if (table->slice) { ht->key.key = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key); - else + } else { ht->key.key = acl_mystrdup(key); + } ht->hash = hash; ht->value = value; htable_link(table, ht, n); - if (callback) - callback(ht, arg); - UNLOCK_TABLE(table); - - RETURN (0); + RETURN (ht); } /* acl_htable_find - lookup value */ @@ -626,8 +649,7 @@ void *acl_htable_find(ACL_HTABLE *table, const char *key) return ht != NULL ? ht->value : NULL; } -int acl_htable_find_r(ACL_HTABLE *table, const char *key_in, - void (*callback)(void *value, void *arg), void *arg) +void *acl_htable_find_r(ACL_HTABLE *table, const char *key_in) { ACL_HTABLE_INFO *ht; unsigned n; @@ -635,27 +657,29 @@ int acl_htable_find_r(ACL_HTABLE *table, const char *key_in, const char *key; #undef RETURN -#define RETURN(x) do \ -{ \ +#define RETURN(x) do { \ if (keybuf) { \ - if (table->slice) \ + if (table->slice) { \ acl_slice_pool_free(__FILE__, __LINE__, keybuf); \ - else \ + } else { \ acl_myfree(keybuf); \ + } \ } \ return (x); \ } while (0) if ((table->flag & ACL_HTABLE_FLAG_KEY_LOWER)) { - if (table->slice) + if (table->slice) { keybuf = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key_in); - else + } else { keybuf = acl_mystrdup(key_in); + } acl_lowercase(keybuf); key = keybuf; - } else + } else { key = key_in; + } n = table->hash_fn(key, strlen(key)); @@ -665,16 +689,15 @@ int acl_htable_find_r(ACL_HTABLE *table, const char *key_in, for (ht = table->data[n]; ht; ht = ht->next) { if (STREQ(key, ht->key.c_key)) { - if (callback) - callback(ht->value, arg); + void *value = ht->value; if (!(table->flag & ACL_HTABLE_FLAG_MSLOOK)) { UNLOCK_TABLE(table); - RETURN (0); + RETURN (value); } if (ht == table->data[n]) { UNLOCK_TABLE(table); - RETURN (0); + RETURN (value); } if (ht->next) { ht->prev->next = ht->next; @@ -688,13 +711,12 @@ int acl_htable_find_r(ACL_HTABLE *table, const char *key_in, table->data[n] = ht; UNLOCK_TABLE(table); - RETURN (0); + RETURN (value); } } UNLOCK_TABLE(table); - - RETURN (-1); + RETURN (NULL); } /* acl_htable_locate - lookup entry */ @@ -707,27 +729,29 @@ ACL_HTABLE_INFO *acl_htable_locate(ACL_HTABLE *table, const char *key_in) const char *key; #undef RETURN -#define RETURN(x) do \ -{ \ +#define RETURN(x) do { \ if (keybuf) { \ - if (table->slice) \ + if (table->slice) { \ acl_slice_pool_free(__FILE__, __LINE__, keybuf); \ - else \ + } else { \ acl_myfree(keybuf); \ + } \ } \ return (x); \ } while (0) if ((table->flag & ACL_HTABLE_FLAG_KEY_LOWER)) { - if (table->slice) + if (table->slice) { keybuf = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key_in); - else + } else { keybuf = acl_mystrdup(key_in); + } acl_lowercase(keybuf); key = keybuf; - } else + } else { key = key_in; + } n = table->hash_fn(key, strlen(key)); @@ -735,10 +759,12 @@ ACL_HTABLE_INFO *acl_htable_locate(ACL_HTABLE *table, const char *key_in) for (ht = table->data[n]; ht; ht = ht->next) { if (STREQ(key, ht->key.c_key)) { - if (!(table->flag & ACL_HTABLE_FLAG_MSLOOK)) + if (!(table->flag & ACL_HTABLE_FLAG_MSLOOK)) { RETURN (ht); - if (ht == table->data[n]) + } + if (ht == table->data[n]) { RETURN (ht); + } if (ht->next) { ht->prev->next = ht->next; ht->next->prev = ht->prev; @@ -756,8 +782,7 @@ ACL_HTABLE_INFO *acl_htable_locate(ACL_HTABLE *table, const char *key_in) RETURN (NULL); } -int acl_htable_locate_r(ACL_HTABLE *table, const char *key_in, - void (*callback)(ACL_HTABLE_INFO *ht, void *arg), void *arg) +ACL_HTABLE_INFO *acl_htable_locate_r(ACL_HTABLE *table, const char *key_in) { ACL_HTABLE_INFO *ht; unsigned n; @@ -765,8 +790,7 @@ int acl_htable_locate_r(ACL_HTABLE *table, const char *key_in, const char *key; #undef RETURN -#define RETURN(x) do \ -{ \ +#define RETURN(x) do { \ if (keybuf) { \ if (table->slice) \ acl_slice_pool_free(__FILE__, __LINE__, keybuf); \ @@ -777,15 +801,17 @@ int acl_htable_locate_r(ACL_HTABLE *table, const char *key_in, } while (0) if ((table->flag & ACL_HTABLE_FLAG_KEY_LOWER)) { - if (table->slice) + if (table->slice) { keybuf = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key_in); - else + } else { keybuf = acl_mystrdup(key_in); + } acl_lowercase(keybuf); key = keybuf; - } else + } else { key = key_in; + } n = table->hash_fn(key, strlen(key)); @@ -795,16 +821,14 @@ int acl_htable_locate_r(ACL_HTABLE *table, const char *key_in, for (ht = table->data[n]; ht; ht = ht->next) { if (STREQ(key, ht->key.c_key)) { - if (callback) - callback(ht, arg); UNLOCK_TABLE(table); - RETURN (0); + RETURN (ht); } } UNLOCK_TABLE(table); - RETURN (-1); + RETURN (NULL); } void acl_htable_delete_entry(ACL_HTABLE *table, ACL_HTABLE_INFO *ht, @@ -812,24 +836,32 @@ void acl_htable_delete_entry(ACL_HTABLE *table, ACL_HTABLE_INFO *ht, { ACL_HTABLE_INFO **h = table->data + ht->hash % table->size; - if (ht->next) + if (ht->next) { ht->next->prev = ht->prev; - if (ht->prev) + } + if (ht->prev) { ht->prev->next = ht->next; - else + } else { *h = ht->next; + } + if (!(table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) { - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, ht->key.key); - else + } else { acl_myfree(ht->key.key); + } } - if (free_fn && ht->value) + + if (free_fn && ht->value) { (*free_fn) (ht->value); - if (table->slice) + } + + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, ht); - else + } else { acl_myfree(ht); + } table->used--; } @@ -845,27 +877,29 @@ int acl_htable_delete(ACL_HTABLE *table, const char *key_in, const char *key; #undef RETURN -#define RETURN(x) do \ -{ \ +#define RETURN(x) do { \ if (keybuf) { \ - if (table->slice) \ + if (table->slice) { \ acl_slice_pool_free(__FILE__, __LINE__, keybuf); \ - else \ + } else { \ acl_myfree(keybuf); \ + } \ } \ return (x); \ } while (0) if ((table->flag & ACL_HTABLE_FLAG_KEY_LOWER)) { - if (table->slice) + if (table->slice) { keybuf = acl_slice_pool_strdup(__FILE__, __LINE__, table->slice, key_in); - else + } else { keybuf = acl_mystrdup(key_in); + } acl_lowercase(keybuf); key = keybuf; - } else + } else { key = key_in; + } n = table->hash_fn(key, strlen(key)); @@ -899,38 +933,47 @@ void acl_htable_free(ACL_HTABLE *table, void (*free_fn) (void *)) for (ht = *h++; ht; ht = next) { next = ht->next; if (!(table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) { - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, ht->key.key); - else + } else { acl_myfree(ht->key.key); + } } - if (free_fn && ht->value) + + if (free_fn && ht->value) { (*free_fn) (ht->value); - if (table->slice) + } + + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, ht); - else + } else { acl_myfree(ht); + } } } - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table->data); - else + } else { acl_myfree(table->data); + } + table->data = 0; if (table->rwlock) { _RWLOCK_DESTROY(table->rwlock); - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table->rwlock); - else + } else { acl_myfree(table->rwlock); + } } - if (table->slice) + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table); - else + } else { acl_myfree(table); + } } int acl_htable_reset(ACL_HTABLE *table, void (*free_fn) (void *)) @@ -949,27 +992,36 @@ int acl_htable_reset(ACL_HTABLE *table, void (*free_fn) (void *)) for (ht = *h++; ht; ht = next) { next = ht->next; if (!(table->flag & ACL_HTABLE_FLAG_KEY_REUSE)) { - if (table->slice) - acl_slice_pool_free(__FILE__, __LINE__, ht->key.key); - else + if (table->slice) { + acl_slice_pool_free(__FILE__, __LINE__, + ht->key.key); + } else { acl_myfree(ht->key.key); + } } - if (free_fn && ht->value) + + if (free_fn && ht->value) { (*free_fn) (ht->value); - if (table->slice) + } + + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, ht); - else + } else { acl_myfree(ht); + } } } - if (table->slice) + + if (table->slice) { acl_slice_pool_free(__FILE__, __LINE__, table->data); - else + } else { acl_myfree(table->data); + } + ret = htable_size(table, table->init_size < 13 ? 13 : table->init_size); UNLOCK_TABLE(table); - return (ret); + return ret; } const ACL_HTABLE_INFO *acl_htable_iter_head(ACL_HTABLE *table, ACL_HTABLE_ITER *iter) @@ -986,15 +1038,16 @@ const ACL_HTABLE_INFO *acl_htable_iter_head(ACL_HTABLE *table, ACL_HTABLE_ITER * } } - return (iter->ptr); + return iter->ptr; } const ACL_HTABLE_INFO *acl_htable_iter_next(ACL_HTABLE_ITER *iter) { if (iter->ptr) { iter->ptr = iter->ptr->next; - if (iter->ptr != NULL) - return (iter->ptr); + if (iter->ptr != NULL) { + return iter->ptr; + } } for (iter->i++; iter->i < iter->size; iter->i++) { @@ -1004,7 +1057,7 @@ const ACL_HTABLE_INFO *acl_htable_iter_next(ACL_HTABLE_ITER *iter) } } - return (iter->ptr); + return iter->ptr; } const ACL_HTABLE_INFO *acl_htable_iter_tail(ACL_HTABLE *table, ACL_HTABLE_ITER *iter) @@ -1021,15 +1074,16 @@ const ACL_HTABLE_INFO *acl_htable_iter_tail(ACL_HTABLE *table, ACL_HTABLE_ITER * } } - return (iter->ptr); + return iter->ptr; } const ACL_HTABLE_INFO *acl_htable_iter_prev(ACL_HTABLE_ITER *iter) { if (iter->ptr) { iter->ptr = iter->ptr->next; - if (iter->ptr != NULL) - return (iter->ptr); + if (iter->ptr != NULL) { + return iter->ptr; + } } for (iter->i--; iter->i >= 0; iter->i--) { @@ -1039,7 +1093,7 @@ const ACL_HTABLE_INFO *acl_htable_iter_prev(ACL_HTABLE_ITER *iter) } } - return (iter->ptr); + return iter->ptr; } /* acl_htable_walk - iterate over hash table */ @@ -1051,31 +1105,35 @@ void acl_htable_walk(ACL_HTABLE *table, void (*action)(ACL_HTABLE_INFO *, void * ACL_HTABLE_INFO *ht; LOCK_TABLE_READ(table); - while (i-- > 0) - for (ht = *h++; ht; ht = ht->next) + while (i-- > 0) { + for (ht = *h++; ht; ht = ht->next) { (*action) (ht, arg); + } + } UNLOCK_TABLE(table); } int acl_htable_size(const ACL_HTABLE *table) { - if (table) - return (table->size); - else - return (0); + if (table) { + return table->size; + } else { + return 0; + } } int acl_htable_used(const ACL_HTABLE *table) { - if (table) - return (table->used); - else - return (0); + if (table) { + return table->used; + } else { + return 0; + } } ACL_HTABLE_INFO **acl_htable_data(ACL_HTABLE *table) { - return ((ACL_HTABLE_INFO**) table->data); + return (ACL_HTABLE_INFO**) table->data; } /* acl_htable_list - list all table members */ @@ -1089,14 +1147,17 @@ ACL_HTABLE_INFO **acl_htable_list(const ACL_HTABLE *table) if (table != 0) { list = (ACL_HTABLE_INFO **) acl_mymalloc(sizeof(*list) * (table->used + 1)); - for (i = 0; i < table->size; i++) - for (member = table->data[i]; member != 0; member = member->next) + for (i = 0; i < table->size; i++) { + for (member = table->data[i]; member != 0; member = member->next) { list[count++] = member; + } + } } else { list = (ACL_HTABLE_INFO **) acl_mymalloc(sizeof(*list)); } + list[count] = 0; - return (list); + return list; } void acl_htable_stat(const ACL_HTABLE *table) @@ -1109,10 +1170,12 @@ void acl_htable_stat(const ACL_HTABLE *table) for(i = 0; i < table->size; i++) { count = 0; member = table->data[i]; - for(; member != 0; member = member->next) + for(; member != 0; member = member->next) { count++; - if(count > 0) + } + if(count > 0) { printf("chains[%d]: count[%d]\n", i, count); + } } printf("hash stat all values for each key:\n"); @@ -1120,8 +1183,9 @@ void acl_htable_stat(const ACL_HTABLE *table) member = table->data[i]; if(member) { printf("chains[%d]: ", i); - for(; member != 0; member = member->next) + for(; member != 0; member = member->next) { printf("[%s]", member->key.c_key); + } printf("\n"); } } diff --git a/lib_acl_cpp/lib_acl_cpp_vc2003.rc b/lib_acl_cpp/lib_acl_cpp_vc2003.rc index c1110d493..1d59f5b9d 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2003.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2003.rc @@ -53,8 +53,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -71,12 +71,12 @@ BEGIN BEGIN VALUE "CompanyName", "zsx" VALUE "FileDescription", "acl_cpp 库" - VALUE "FileVersion", "3, 6, 1, 1" + VALUE "FileVersion", "3, 6, 1, 2" VALUE "InternalName", "lib_acl_" VALUE "LegalCopyright", "acl_cpp (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", "acl_cpp 库" - VALUE "ProductVersion", "3, 6, 1, 1" + VALUE "ProductVersion", "3, 6, 1, 2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2008.rc b/lib_acl_cpp/lib_acl_cpp_vc2008.rc index 6cd439dcb..786376f9d 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2008.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2008.rc @@ -53,8 +53,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -71,12 +71,12 @@ BEGIN BEGIN VALUE "CompanyName", "zsx" VALUE "FileDescription", "acl_cpp 库" - VALUE "FileVersion", "3, 6, 1, 1" + VALUE "FileVersion", "3, 6, 1, 2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "acl_cpp (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", "acl_cpp 库" - VALUE "ProductVersion", "3, 6, 1, 1" + VALUE "ProductVersion", "3, 6, 1, 2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2010.rc b/lib_acl_cpp/lib_acl_cpp_vc2010.rc index 7da4ed888..928ecbcec 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2010.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2010.rc @@ -51,8 +51,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN VALUE "Comments", "通用的C++库" VALUE "CompanyName", "zsx" VALUE "FileDescription", "lib_acl_cpp 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "版权所有 (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", " lib_acl_cpp 库" - VALUE "ProductVersion", "3.6.1.1" + VALUE "ProductVersion", "3.6.1.2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2012.rc b/lib_acl_cpp/lib_acl_cpp_vc2012.rc index 805753630..b8232ab58 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2012.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2012.rc @@ -51,8 +51,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN VALUE "Comments", "通用的C++库" VALUE "CompanyName", "zsx" VALUE "FileDescription", "lib_acl_cpp 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "版权所有 (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", " lib_acl_cpp 库" - VALUE "ProductVersion", "3.6.1.1" + VALUE "ProductVersion", "3.6.1.2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2013.rc b/lib_acl_cpp/lib_acl_cpp_vc2013.rc index 1a8e0a60b..834395e64 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2013.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2013.rc @@ -51,8 +51,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN VALUE "Comments", "通用的C++库" VALUE "CompanyName", "zsx" VALUE "FileDescription", "lib_acl_cpp 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "版权所有 (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", " lib_acl_cpp 库" - VALUE "ProductVersion", "3.6.1.1" + VALUE "ProductVersion", "3.6.1.2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2015.rc b/lib_acl_cpp/lib_acl_cpp_vc2015.rc index 6ada4d896..daf20ea10 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2015.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2015.rc @@ -51,8 +51,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN VALUE "Comments", "通用的C++库" VALUE "CompanyName", "zsx" VALUE "FileDescription", "lib_acl_cpp 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "版权所有 (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", " lib_acl_cpp 库" - VALUE "ProductVersion", "3.6.1.1" + VALUE "ProductVersion", "3.6.1.2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2017.rc b/lib_acl_cpp/lib_acl_cpp_vc2017.rc index 412973f84..e8bb8e0b9 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2017.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2017.rc @@ -51,8 +51,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN VALUE "Comments", "通用的C++库" VALUE "CompanyName", "zsx" VALUE "FileDescription", "lib_acl_cpp 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "版权所有 (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", " lib_acl_cpp 库" - VALUE "ProductVersion", "3.6.1.1" + VALUE "ProductVersion", "3.6.1.2" END END BLOCK "VarFileInfo" diff --git a/lib_acl_cpp/lib_acl_cpp_vc2019.rc b/lib_acl_cpp/lib_acl_cpp_vc2019.rc index 3b6c82ee4..a57405407 100644 --- a/lib_acl_cpp/lib_acl_cpp_vc2019.rc +++ b/lib_acl_cpp/lib_acl_cpp_vc2019.rc @@ -51,8 +51,8 @@ END // VS_VERSION_INFO VERSIONINFO - FILEVERSION 3,6,1,1 - PRODUCTVERSION 3,6,1,1 + FILEVERSION 3,6,1,2 + PRODUCTVERSION 3,6,1,2 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -70,12 +70,12 @@ BEGIN VALUE "Comments", "通用的C++库" VALUE "CompanyName", "zsx" VALUE "FileDescription", "lib_acl_cpp 库" - VALUE "FileVersion", "3.6.1.1" + VALUE "FileVersion", "3.6.1.2" VALUE "InternalName", "lib_acl_cpp" VALUE "LegalCopyright", "版权所有 (C) 2022" VALUE "OriginalFilename", "lib_acl_cpp.lib" VALUE "ProductName", " lib_acl_cpp 库" - VALUE "ProductVersion", "3.6.1.1" + VALUE "ProductVersion", "3.6.1.2" END END BLOCK "VarFileInfo" diff --git a/packaging/acl-libs.spec b/packaging/acl-libs.spec index 2151398ca..ca5e3b7a0 100644 --- a/packaging/acl-libs.spec +++ b/packaging/acl-libs.spec @@ -1,4 +1,4 @@ -%define release_id 1 +%define release_id 2 Summary: The powerful c/c++ library Name: acl-libs @@ -45,6 +45,9 @@ rm -rf %{buildroot} %changelog +* Wed Mar 22 2023 shuxin.zheng shuxin.zheng@qq.com 3.6.1-2-20230322.15 +- bugfix: fixed one bug in fiber_mutex module where some resouce collision maybe happen. + * Tue Mar 21 2023 shuxin.zheng shuxin.zheng@qq.com 3.6.1-1-20230321.10 - optimize: optimize fiber's performance by reducing the number of calling getting time; - optimize: optimize fiber's performance by using clock_gettimeofday replacing gettimeofday; diff --git a/unit_test/stdlib/test_avl.c b/unit_test/stdlib/test_avl.c index 89d586a79..f4830bfcf 100644 --- a/unit_test/stdlib/test_avl.c +++ b/unit_test/stdlib/test_avl.c @@ -24,7 +24,14 @@ static int compare_fn(const void *v1, const void *v2) { const MY_TYPE *m1 = (const MY_TYPE*) v1, *m2 = (const MY_TYPE*) v2; - return (strcmp(m1->name, m2->name)); + int ret = strcmp(m1->name, m2->name); + if (ret < 0) { + return -1; + } else if (ret > 0) { + return 1; + } else { + return 0; + } } int test_avl_create(AUT_LINE *test_line acl_unused, void *arg acl_unused) diff --git a/unit_test/stdlib/test_htable.c b/unit_test/stdlib/test_htable.c index 18232c6c5..5fe67cc18 100644 --- a/unit_test/stdlib/test_htable.c +++ b/unit_test/stdlib/test_htable.c @@ -156,14 +156,16 @@ static void __htable_rwlock_fn(void *arg) */ ACL_SAFE_STRNCPY(thr_ctx->key, key, sizeof(thr_ctx->key)); - if (acl_htable_enter_r(ctx->table, key, (char *) thr_ctx, NULL, NULL) == -1) + if (acl_htable_enter_r(ctx->table, key, (char *) thr_ctx) == NULL) { acl_msg_fatal("insert into htable error(%s), key(%s)", strerror(errno), key); + } printf("search key: %s\n", key); - thr_ctx = (__THR_CTX *) acl_htable_find(ctx->table, key); - if (thr_ctx == NULL) + thr_ctx = (__THR_CTX *) acl_htable_find_r(ctx->table, key); + if (thr_ctx == NULL) { acl_msg_fatal("%s: not find key(%s)", myname, key); + } printf("ok, add and find, key=%s\n", key); } @@ -180,7 +182,7 @@ int test_htable_rwlock(AUT_LINE *test_line, void *arg acl_unused) hash_fn = __get_hash_fn(ptr); __rwlock_ctx.test_line = test_line; - __rwlock_ctx.table = acl_htable_create(10, 0); + __rwlock_ctx.table = acl_htable_create(10, ACL_HTABLE_FLAG_USE_LOCK); acl_htable_ctl(__rwlock_ctx.table, ACL_HTABLE_CTL_RWLOCK, TRUE,