# Snow 语言现状和下一阶段开发路线图 > 日期:2025-06-11 ## 1. 代码结构与职责 | 层次 | 主要包/目录 | 说明 | |--------|--------------------------|--------------------------------------------------------| | 词法分析 | `snow/compiler/lexer` | 扫描器(Scanner)+ `TokenFactory`,可识别关键字、运算符、数字/字符串字面量等 | | 语法分析 | `snow/compiler/parser` | Pratt 表达式解析器 + 各类语句解析器(声明、`if`、`loop`、`return`…)生成 AST | | 语义分析 | `snow/compiler/semantic` | 符号表、类型系统(`BuiltinType`/`FunctionType`)与各节点分析器 | | IR 构建 | `snow/compiler/ir` | SSA-风格中间表示、指令集、构建器 | | 后端生成 | `snow/compiler/backend` | IR ➜ VM 指令的 `*Generator` 体系、寄存器分配 | | 运行时 VM | `snow/vm` | 指令集实现(栈/寄存器/内存/控制流/函数)+ 启动器 | ### 2 编译流程 1. **Lexer** 将源码映射为 `TokenStream` 2. **Parser** 生成 AST(19 种节点) 3. **Semantic** * 类型推断 / 兼容性校验 * 符号绑定与引用解析 4. **IR** * 虚拟寄存器 + 基本块 + 统一指令(算术、比较、跳转、调用、返回…) 5. **Backend** * 线性扫描寄存器分配 * 指令生成器把 IR 转为 VM 指令 6. **VM** * 栈-基 / 寄存器混合架构 * 96 条已实现指令(按数据宽度泛化:B/S/I/L/F/D) * 运行时启动器 `VMLauncher` ## 3. 测试中存在的问题记录 | 模块 | 现状 | |----------------|---------------------------------------------------------------| | **布尔类型** | 词法已识别 `bool`,但 `BuiltinType` 中缺失;比较运算目前回落为 `int` 0/1 | | **一元/前缀运算** | VM 与 IR 有 `UnaryOperationInstruction`,Parser 未注册 `-x`, `!x` 等 | | **数组/切片/Map** | 无 AST/Type/IR 支持 | | **结构体 / 面向对象** | 无 结构体、对象 节点 | | **异常处理** | 无 try/catch 指令或语义 | | **优化 Pass** | 未见常量折叠 / 死代码删除等 | | **标准库 & I/O** | 仅语言核心,无文件/网络/控制台 API | | **测试矩阵** | 单元测试缺失,e2e 样例有限 | | **CLI/包管理** | 缺少 `snowc` 命令与包版本语义 | ## 4. 下一阶段开发路线图 > 优先级:P0 = 当前版本必须,P1 = 下一个小版本,P2 = 中长期 | 优先级 | 功能 | 关键任务 | |--------|------------------|----------------------------------------------------------------------------------------------------------------------| | **P0** | **布尔类型落地** | \* 在 `BuiltinType` 中补充 `BOOL`
\* 更新 `TokenFactory.TYPES` 映射
\* 比较/逻辑运算返回 `bool` 类型
\* VM 增加布尔专用指令或重用 `byte` | | **P0** | **一元表达式解析** | \* 实现 `UnaryOperatorParselet`(`-`, `+`, `!`)
\* 对应 `UnaryOpGenerator` 注册 | | **P1** | **数组与切片** | \* 设计 `ArrayType`(元素类型 + 维度)
\* 新增 `IndexExpressionNode`、`NewArrayNode`
\* VM 扩充 `ALOAD/ASTORE` 指令 | | **P1** | **基础标准库** | \* `print/println`, 文件读写
\* 编译期内置绑定到 VM calls | | **P1** | **测试与 CI** | \* JUnit5 单测:Lexer / Parser / Semantic / VM
\* CI/CD 自动构建、示例编译运行 | | **P2** | **结构体 / 简单面向对象** | \* 结构体 语法、记录类型布局
\* 方法调度:静态 or 虚表 | | **P2** | **优化管线** | \* 常量折叠、公共子表达式消除
\* 简易死代码清除 | | **P2** | **错误与异常系统** | \* 语法:`try … catch … end`
\* VM:展开-收缩栈,异常表 | | **P2** | **包管理 & CLI** | \* `snowc` 命令:`build`, `run`, `test`
\* 本地缓存 `.snowpkg`与包版本语义 | ## 5.1 里程碑排期 | 时间 | 目标 | |---------|----------------------------------------| | 2025-07 | 发布 **v0.2.0**:布尔类型 + 一元运算、20+ 单元测试 | | 2025-08 | 发布 **v0.3.0**:数组/切片 & 基础标准库;引入 CLI | | 2025-10 | 发布 **v0.4.0**:结构体支持、首批优化 Pass、>80% 覆盖率 | | 2026-11 | 发布 **v1.0.0**:异常系统、稳定包管理、文档完善 |