feat(ir): 启用LIR模块并重构HIR组件结构

- 在cbuild.toml中启用lir依赖项,取消注释相关配置
- 重构libs/README.md文档,添加详细的库说明和层级结构
- 重命名头文件以统一命名规范:ast_def.h → scc_ast_def.h,
  ast_dump.h → scc_ast_dump.h, hir相关文件添加scc前缀
- 更新include路径以匹配新的文件命名
- 在cfg模块中添加symbol ID类型和linkage枚举,完善符号表功能
- 实现cfg模块中的符号添加、查找和获取功能
- 修改HIR中meta字段替换原有的attribute字段,更新相关访问宏
- 修复HIR构建器中的函数元数据访问错误
- 为LIR模块创建完整的头文件结构,包括指令定义、转换器等组件
This commit is contained in:
zzy
2026-04-21 20:35:37 +08:00
parent 0fbfb36262
commit e850b5c981
30 changed files with 1588 additions and 2627 deletions

View File

@@ -40,8 +40,10 @@ scc_cfg_func_t *scc_cfg_module_unsafe_get_func(scc_cfg_module_t *module,
scc_cfg_bblock_id_t scc_cfg_module_add_bblock(scc_cfg_module_t *module,
const scc_cfg_bblock_t *bblock) {
scc_cfg_func_id_t id = scc_vec_size(module->bblocks);
scc_vec_push(module->bblocks, *bblock);
scc_cfg_bblock_id_t id = scc_vec_size(module->bblocks);
scc_cfg_bblock_t bblock_ = *bblock;
bblock_.id = id;
scc_vec_push(module->bblocks, bblock_);
Assert(id != SCC_CFG_ID_nullptr);
return id;
}
@@ -57,11 +59,30 @@ scc_cfg_bblock_t *scc_cfg_module_unsafe_get_bblock(scc_cfg_module_t *module,
return &scc_vec_at(module->bblocks, id);
}
void scc_cfg_module_add_symbol(scc_cfg_module_t *module,
const scc_cfg_symbol_t *symbol) {}
scc_cfg_id_t scc_cfg_module_lookup_symbol(const scc_cfg_module_t *module,
const char *name) {
return 0;
scc_cfg_symbol_id_t scc_cfg_module_add_symbol(scc_cfg_module_t *module,
const scc_cfg_symbol_t *symbol) {
scc_cfg_func_id_t id = scc_vec_size(module->symbols);
scc_vec_push(module->symbols, *symbol);
Assert(id != SCC_CFG_ID_nullptr);
scc_hashtable_set(&module->symbol_map, symbol->name, (void *)(usize)id);
return id;
}
scc_cfg_symbol_t *scc_cfg_module_unsafe_get_symbol(scc_cfg_module_t *module,
scc_cfg_symbol_id_t id) {
if (id == SCC_CFG_ID_nullptr) {
Panic("nullptr symbol id");
}
if (id >= scc_vec_size(module->bblocks)) {
Panic("invalid symbol id");
}
return &scc_vec_at(module->symbols, id);
}
scc_cfg_symbol_id_t scc_cfg_module_lookup_symbol(const scc_cfg_module_t *module,
const char *name) {
return (scc_cfg_symbol_id_t)(usize)scc_hashtable_get(&module->symbol_map,
name);
}
void scc_cfg_bblock_add_pred(scc_cfg_bblock_t *bb,