fix(abi): 修复void类型的ABI计算缺少break语句

在scc_type_abi.c文件中,void类型的case分支缺少break语句,
导致执行流程错误地进入下一个case分支。

feat(ast): 为参数声明添加索引字段

在ast_def.h头文件中为参数声明结构体添加param_idx字段,
用于跟踪参数在函数参数列表中的位置索引。

feat(ast): 更新参数初始化函数以支持索引参数

修改scc_ast.h中的scc_ast_decl_param_init函数签名,
添加参数索引idx参数,并将该值存储到参数声明结构体中。

feat(ast2ir): 添加IR转换上下文的值使用提示选项

在ast2ir.h中为scc_ast2ir_ctx_t结构体添加hint_using_value字段,
控制参数转换时是使用值还是分配内存的方式。

fix(ast2ir): 正确处理void类型到IR的转换

当遇到大小为0的类型(如void)时,直接返回void类型,
而不是尝试匹配其他大小分支。

refactor(ast2ir): 统一基本块引用类型为value_ref

将逻辑表达式、条件语句、循环语句中的基本块引用类型
从bblock_ref_t改为value_ref_t,保持类型一致性。

fix(ast2ir): 修正函数引用空值检查

使用SCC_IR_REF_nullptr常量替代0进行函数引用的空值检查,
提高代码的可读性和正确性。

refactor(ast2ir): 简化参数处理逻辑

移除不必要的函数参数获取和命名设置逻辑,
通过递归调用scc_ast2ir_decl来处理参数声明。

feat(ast2ir): 实现参数声明到IR的转换

为参数声明添加完整的IR转换逻辑,包括类型转换、
参数引用创建和内存分配处理。

refactor(ast2ir): 更新哈希表初始化接口

适配新的哈希表初始化函数签名,添加userdata参数支持,
并初始化hint_using_value字段为false。

refactor(ir): 移除函数参数的预分配逻辑

删除IR构建器中函数参数的预分配和循环添加逻辑,
简化函数开始构建的处理流程。

refactor(ir): 更新类型哈希表键值处理

修改类型哈希表的哈希和比较函数以接受模块参数,
正确处理空引用情况并支持新的键值传递方式。

fix(ir): 修复IR转储中的字符串格式

移除IR函数转储时多余的换行符,确保输出格式正确。

refactor(ir): 更新模块哈希表初始化

适配哈希表初始化接口变更,添加userdata参数,
并为各种向量预留UID 0作为无效引用。

fix(ir): 修复模块清理中的循环起始索引

将模块清理循环的起始索引从0改为1,跳过预留的
无效引用项,避免访问空指针。

refactor(ir): 调整向量和哈希表操作顺序

调整模块中向量push和哈希表set的操作顺序,
确保数据一致性和正确的UID分配。

chore(build): 移除ir2mcode模块相关文件

移除ir2mcode相关的头文件和源文件,这些组件
将在后续重构中重新设计或替换。
This commit is contained in:
zzy
2026-04-15 14:52:11 +08:00
parent 8054f20375
commit 5a9f816ccf
38 changed files with 260 additions and 1497 deletions

View File

@@ -1,10 +1,86 @@
#include <scc_core.h>
#ifdef _WIN32
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <Windows.h>
#include <signal.h>
/// Ddghelp.h 必须在 Windows.h 后定义
#include <Dbghelp.h>
static LONG WINAPI CreateMiniDump(EXCEPTION_POINTERS *pExceptionPointers) {
HANDLE hFile = CreateFileA("crash.dmp", GENERIC_WRITE, 0, NULL,
CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
if (hFile == INVALID_HANDLE_VALUE) {
scc_fprintf(scc_stderr, "Failed to create crash.dmp\n");
return EXCEPTION_EXECUTE_HANDLER;
}
MINIDUMP_EXCEPTION_INFORMATION mei = {0};
BOOL bDumpWithException = FALSE;
if (pExceptionPointers != NULL) {
// 有异常上下文(来自 UnhandledExceptionFilter
mei.ThreadId = GetCurrentThreadId();
mei.ExceptionPointers = pExceptionPointers;
mei.ClientPointers = FALSE;
bDumpWithException = TRUE;
} else {
// 没有异常上下文(例如来自 abort 信号),捕获当前线程上下文
CONTEXT ctx = {0};
ctx.ContextFlags = CONTEXT_FULL;
RtlCaptureContext(&ctx); // 获取当前执行点寄存器状态
static EXCEPTION_POINTERS fakeEP = {0};
static EXCEPTION_RECORD fakeER = {0};
fakeER.ExceptionCode = 0xE0000001; // 自定义异常码
fakeER.ExceptionFlags = 0;
fakeER.ExceptionRecord = NULL;
fakeER.ExceptionAddress = (PVOID)ctx.Rip; // 当前指令指针
fakeER.NumberParameters = 0;
fakeEP.ExceptionRecord = &fakeER;
fakeEP.ContextRecord = &ctx;
mei.ThreadId = GetCurrentThreadId();
mei.ExceptionPointers = &fakeEP;
mei.ClientPointers = FALSE;
bDumpWithException = TRUE;
}
MINIDUMP_TYPE dumpType = (MINIDUMP_TYPE)(MiniDumpWithFullMemory);
BOOL bOK = MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(),
hFile, dumpType,
bDumpWithException ? &mei : NULL, NULL, NULL);
CloseHandle(hFile);
if (bOK)
scc_fprintf(scc_stderr, "Minidump written: crash.dmp\n");
else
scc_fprintf(scc_stderr, "MiniDumpWriteDump failed: %lu\n",
GetLastError());
return EXCEPTION_EXECUTE_HANDLER;
}
void SignalHandler(int sig) {
if (sig == SIGABRT) {
#ifdef DEV_MODE
CreateMiniDump(NULL);
#else
scc_fprintf(scc_stderr, "Press Enter to continue...");
getchar();
#endif
_exit(1);
}
}
#endif
void init_platform(void) {
#ifdef _WIN32
signal(SIGABRT, SignalHandler);
#ifdef DEV_MODE
SetUnhandledExceptionFilter(CreateMiniDump);
#endif
SetConsoleOutputCP(CP_UTF8);
SetConsoleCP(CP_UTF8);
#endif

View File

@@ -155,6 +155,7 @@ int main(int argc, const char **argv, const char **envp) {
scc_str_t pproc_predefined_macros[] = {
scc_str_from_cstr("__SCC__"),
scc_str_from_cstr("_WIN64"),
scc_str_from_cstr("_WIN32"),
scc_str_from_cstr("__x86_64__"),
};
for (usize i = 0; i < SCC_ARRLEN(pproc_predefined_macros); i += 1) {