添加了完整的scc_ir2mcode实现,将MIR指令转换为机器码, 同时修复了头文件中的函数命名错误(scc_mir2sccf改为scc_ir2sccf)。 BREAKING CHANGE: 函数名从scc_mir2sccf更改为scc_ir2sccf fix(vec): 修复向量循环和内存释放问题 修改了scc_vec_foreach宏使用+= 1避免潜在的编译器警告, 并添加了空指针检查以防止重复释放内存导致的崩溃。 refactor(hashtable): 优化哈希表接口设计 将scc_hashtable_get参数改为const类型,提供更好的只读访问安全性。 test: 添加break/continue和goto语句测试用例 新增18_break_continue.c和19_goto.c测试用例, 并对齐expect.toml文件格式以便于维护。
135 lines
4.1 KiB
C
135 lines
4.1 KiB
C
/**
|
||
* @file hashtable.h
|
||
* @brief 开放寻址法哈希表实现
|
||
*
|
||
* 提供基于向量容器的哈希表实现,支持动态扩容和墓碑机制
|
||
*/
|
||
|
||
#ifndef __SCC_HASHTABLE_H__
|
||
#define __SCC_HASHTABLE_H__
|
||
|
||
#include <scc_core.h>
|
||
|
||
/**
|
||
* @enum hp_entry_state_t
|
||
* @brief 哈希表条目状态标识
|
||
*/
|
||
typedef enum scc_hashtable_entry_state {
|
||
ENTRY_EMPTY, /**< 空槽位(从未使用过) */
|
||
ENTRY_ACTIVE, /**< 有效条目(包含键值对) */
|
||
ENTRY_TOMBSTONE /**< 墓碑标记(已删除条目) */
|
||
} scc_hashtable_entry_state_t;
|
||
|
||
/**
|
||
* @struct scc_hashtable_entry_t
|
||
* @brief 哈希表条目结构
|
||
*
|
||
* @note key/value内存由调用者管理,哈希表不负责其生命周期
|
||
*/
|
||
typedef struct scc_hashtable_entry {
|
||
const void *key; /**< 键指针(不可变) */
|
||
void *value; /**< 值指针 */
|
||
u32 hash; /**< 预计算的哈希值(避免重复计算) */
|
||
scc_hashtable_entry_state_t state; /**< 当前条目状态 */
|
||
} scc_hashtable_entry_t;
|
||
|
||
typedef u32 (*scc_hashtable_hash_func_t)(const void *key, void *userdata);
|
||
typedef int (*scc_hashtable_equal_func_t)(const void *key1, const void *key2,
|
||
void *userdata);
|
||
|
||
/**
|
||
* @struct scc_hashtable_t
|
||
* @brief 哈希表主体结构
|
||
*
|
||
* 使用开放寻址法实现,采用墓碑标记处理删除操作
|
||
*/
|
||
typedef struct scc_hashtable {
|
||
void *userdata;
|
||
SCC_VEC(scc_hashtable_entry_t) entries; /**< 条目存储容器 */
|
||
u32 count; /**< 有效条目数量(不含墓碑) */
|
||
u32 tombstone_count; /**< 墓碑条目数量 */
|
||
/**
|
||
* @brief 哈希函数指针
|
||
* @param key 键指针
|
||
* @return 32位无符号哈希值
|
||
*/
|
||
scc_hashtable_hash_func_t hash_func;
|
||
/**
|
||
* @brief 键比较函数指针
|
||
* @param key1 第一个键指针
|
||
* @param key2 第二个键指针
|
||
* @return 相同返回0,不同返回非0
|
||
*/
|
||
scc_hashtable_equal_func_t cmp_func;
|
||
} scc_hashtable_t;
|
||
|
||
/**
|
||
* @brief 初始化哈希表结构
|
||
* @param ht 哈希表实例指针
|
||
*
|
||
* @warning 必须设置hash_func和key_cmp后才能使用
|
||
*/
|
||
void scc_hashtable_init(scc_hashtable_t *ht,
|
||
scc_hashtable_hash_func_t hash_func,
|
||
scc_hashtable_equal_func_t cmp_func, void *userdata);
|
||
|
||
void scc_hashtable_cstr_init(scc_hashtable_t *ht);
|
||
void scc_hashtable_usize_init(scc_hashtable_t *ht);
|
||
|
||
/**
|
||
* @brief 插入/更新键值对
|
||
* @param ht 哈希表实例指针
|
||
* @param key 键指针
|
||
* @param value 值指针
|
||
* @return 被替换的旧值指针(无替换返回nullptr)
|
||
*/
|
||
void *scc_hashtable_set(scc_hashtable_t *ht, const void *key, void *value);
|
||
|
||
/**
|
||
* @brief 查找键对应值
|
||
* @param ht 哈希表实例指针
|
||
* @param key 查找键指针
|
||
* @return 找到返回值指针,未找到返回nullptr
|
||
*/
|
||
void *scc_hashtable_get(const scc_hashtable_t *ht, const void *key);
|
||
|
||
/**
|
||
* @brief 删除键值对
|
||
* @param ht 哈希表实例指针
|
||
* @param key 要删除的键指针
|
||
* @return 被删除的值指针(不存在返回nullptr)
|
||
*
|
||
* @note 实际采用墓碑标记方式删除
|
||
*/
|
||
void *scc_hashtable_del(scc_hashtable_t *ht, const void *key);
|
||
|
||
/**
|
||
* @brief 销毁哈希表
|
||
* @param ht 哈希表实例指针
|
||
*
|
||
* @note 仅释放哈希表内部内存,不会释放key/value内存
|
||
*/
|
||
void scc_hashtable_drop(scc_hashtable_t *ht);
|
||
|
||
/**
|
||
* @typedef scc_hashtable_iter_fn
|
||
* @brief 哈希表迭代回调函数类型
|
||
* @param key 当前键指针
|
||
* @param value 当前值指针
|
||
* @param context 用户上下文指针
|
||
* @return 返回非0停止迭代
|
||
*/
|
||
typedef int (*scc_hashtable_iter_fn)(const void *key, void *value,
|
||
void *context);
|
||
|
||
/**
|
||
* @brief 遍历哈希表所有有效条目
|
||
* @param ht 哈希表实例指针
|
||
* @param iter_func 迭代回调函数
|
||
* @param context 用户上下文指针
|
||
*/
|
||
void scc_hashtable_foreach(scc_hashtable_t *ht, scc_hashtable_iter_fn iter_func,
|
||
void *context);
|
||
|
||
#endif /* __SCC_HASHTABLE_H__ */
|