145 lines
3.4 KiB
Markdown
145 lines
3.4 KiB
Markdown
# 架构决策记录
|
||
|
||
## ADR-001: 使用 C++23 Modules 构建 LSP 服务器
|
||
|
||
**日期**: 2026-02-02
|
||
**状态**: 已采纳
|
||
|
||
### 决策
|
||
|
||
LSP 服务器核心使用 C++23 Modules (`.cppm` 文件) 而非传统头文件 (`.h/.hpp`)。
|
||
|
||
### 理由
|
||
|
||
- **编译性能**:Module 只需编译一次,后续增量编译更快
|
||
- **符号隔离**:避免头文件中的宏污染和符号冲突
|
||
- **依赖清晰**:显式 import 声明依赖关系更清晰
|
||
- **现代化**:跟进 C++ 现代化趋势
|
||
|
||
### 影响
|
||
|
||
- 需要 Clang 20+ 或 GCC 15+ 编译器
|
||
- CMake 需要 4.2+ 版本以支持 CXX_MODULE
|
||
- 第三方库需要通过 Bridge 模块封装
|
||
|
||
---
|
||
|
||
## ADR-002: 选择 Tree-sitter 作为解析器
|
||
|
||
**日期**: 2026-02-02
|
||
**状态**: 已采纳
|
||
|
||
### 决策
|
||
|
||
使用 Tree-sitter 作为 TSL 语法解析器,而非手写递归下降解析器或 ANTLR。
|
||
|
||
### 理由
|
||
|
||
- **增量解析**:Tree-sitter 原生支持增量更新,适合 IDE 场景
|
||
- **错误恢复**:能在语法错误时继续解析,提供最大可用性
|
||
- **高性能**:C 实现,解析速度快
|
||
- **生态**:被 GitHub、Neovim 等广泛使用,经过生产验证
|
||
|
||
### 影响
|
||
|
||
- 需要编写 Tree-sitter 语法文件 (`grammar.js`)
|
||
- 生成的 C 代码需要集成到构建系统
|
||
- 语法树结构受 Tree-sitter 约束
|
||
|
||
---
|
||
|
||
## ADR-003: 使用 Glaze 进行 JSON 序列化
|
||
|
||
**日期**: 2026-02-02
|
||
**状态**: 已采纳
|
||
|
||
### 决策
|
||
|
||
使用 Glaze 库处理 LSP 协议的 JSON 序列化,而非 nlohmann/json 或 rapidjson。
|
||
|
||
### 理由
|
||
|
||
- **零拷贝**:Glaze 支持零拷贝解析,性能最优
|
||
- **编译时反射**:使用 C++20 概念实现编译时序列化,无运行时开销
|
||
- **类型安全**:编译期检查 JSON 结构与 C++ 类型的匹配
|
||
- **简洁**:代码量少,维护成本低
|
||
|
||
### 影响
|
||
|
||
- 需要为 LSP 类型定义 `glz::meta` 或使用结构化绑定
|
||
- 依赖 C++20 特性
|
||
|
||
---
|
||
|
||
## ADR-004: 采用 Taskflow 实现异步处理
|
||
|
||
**日期**: 2026-02-02
|
||
**状态**: 已采纳
|
||
|
||
### 决策
|
||
|
||
使用 Taskflow 库实现请求的异步并行处理,而非 std::async 或自建线程池。
|
||
|
||
### 理由
|
||
|
||
- **任务图**:支持复杂的任务依赖关系
|
||
- **性能**:高效的工作窃取调度器
|
||
- **易用**:API 简洁,与 C++20 配合良好
|
||
- **成熟**:经过 HPC 场景验证
|
||
|
||
### 影响
|
||
|
||
- 需要正确管理任务生命周期
|
||
- 共享状态需要同步保护
|
||
|
||
---
|
||
|
||
## ADR-005: VSCode 扩展与 LSP 服务器分离
|
||
|
||
**日期**: 2026-02-02
|
||
**状态**: 已采纳
|
||
|
||
### 决策
|
||
|
||
VSCode 扩展作为纯客户端,通过 stdio 与独立的 LSP 服务器进程通信。
|
||
|
||
### 理由
|
||
|
||
- **标准协议**:遵循 LSP 标准,可复用于其他编辑器
|
||
- **独立开发**:C++ 和 TypeScript 代码库独立演进
|
||
- **调试方便**:服务器可独立启动调试
|
||
- **稳定性**:服务器崩溃不影响 VSCode 主进程
|
||
|
||
### 影响
|
||
|
||
- 需要处理进程管理和生命周期
|
||
- stdio 通信增加序列化开销
|
||
- 需要分发服务器二进制文件
|
||
|
||
---
|
||
|
||
## ADR-006: 使用 Conan 管理 C++ 依赖
|
||
|
||
**日期**: 2026-02-02
|
||
**状态**: 已采纳
|
||
|
||
### 决策
|
||
|
||
使用 Conan 2.x 作为 C++ 依赖管理工具。
|
||
|
||
### 理由
|
||
|
||
- **跨平台**:统一管理 Linux 和 Windows 依赖
|
||
- **二进制缓存**:避免重复编译第三方库
|
||
- **版本锁定**:精确控制依赖版本
|
||
- **CMake 集成**:生成 CMake 工具链文件
|
||
|
||
### 影响
|
||
|
||
- 开发者需要安装 Conan
|
||
- 需要维护 Conan profile 和配方
|
||
|
||
---
|
||
|
||
**最后更新**:2026-02-02
|