3b7bab1e1b
5 阶段编译流水线: 词法分析 → 语法分析(Pratt) → 语义分析(类型推断) → LLVM IR → .exe 模块: - lexer: 手写状态机, 40 种 Token, // 和 /* */ 注释 - parser: Pratt 表达式解析(9 级优先级) + 递归下降语句/函数 - ast: 14 种节点类型 + 工厂函数 - sema: 作用域链符号表 + 类型推断 + 类型检查 - codegen: AST → LLVM-C API, print_i64/f64/bool 内建 - driver: 命令行 + 流水线串联 + 错误报告 - util: Arena bump allocator (8MB) 测试: 65 单元测试(词法41+语法15+语义9) + 5 集成测试 全部通过 语言特性: i64/f64/bool/void, let不可变变量, if/else, while, 递归函数
1.4 KiB
1.4 KiB
安全策略
报告漏洞
如果你发现安全漏洞,请不要在公开 Issue 中报告。请通过以下方式私下报告:
- GitHub: 在 Security Advisories 页面提交
- 邮件: 联系项目维护者
我们会在 48 小时内确认收到报告,并在 7 天内提供初步评估和修复计划。
安全最佳实践
作为用户
- 仅从 Releases 页面下载编译好的二进制文件
- 编译的
.l源文件在当前目录生成.o和.exe文件 - 不要编译不可信来源的
.l源文件
作为开发者
- 永远不要在源代码中硬编码密钥或凭据
- 所有外部输入(源文件)在系统边界验证
- Arena 分配失败时逐层返回 NULL,不做静默回退
vsnprintf缓冲区用完时检查返回值strtoll/strtod解析 Token 值前检查长度边界
已知限制
- v0.1 不支持沙箱或权限控制 — 编译出的可执行文件具有当前用户的所有权限
print_*内建函数直接调用printf,format string 为硬编码常量,无注入风险- 不支持文件 I/O、网络、外部 FFI 调用(v0.1 语言能力有限,攻击面极小)
支持版本
| 版本 | 支持状态 |
|---|---|
| v0.1.x | 活跃开发中 |
v0.1 处于早期开发阶段,API 和语言语法可能发生破坏性变更。生产环境请勿使用。