153 lines
4.1 KiB
Markdown
153 lines
4.1 KiB
Markdown
# 架构设计
|
||
|
||
## 整体架构
|
||
|
||
```mermaid
|
||
graph TB
|
||
Client["fa:fa-desktop 客户端 (VSCode / Vim / ...)"]
|
||
|
||
Client -->|"LSP stdio"| Core
|
||
|
||
subgraph Server["LSP Server (C++23)"]
|
||
|
||
subgraph Core["Core"]
|
||
direction LR
|
||
S["Server"] ~~~ D["Dispatcher"] ~~~ A["AsyncExecutor"]
|
||
end
|
||
|
||
subgraph Provider["Provider"]
|
||
direction LR
|
||
P1["Completion"] ~~~ P2["Definition"] ~~~ P3["CodeAction"] ~~~ P4["..."]
|
||
end
|
||
|
||
subgraph Manager["Manager"]
|
||
direction LR
|
||
M1["Document"] ~~~ M2["Parser"] ~~~ M3["Symbol"] ~~~ M4["EventBus"]
|
||
end
|
||
|
||
subgraph Language["Language"]
|
||
direction LR
|
||
L1["AST"] ~~~ L2["Semantic"] ~~~ L3["Symbol"]
|
||
end
|
||
|
||
subgraph Bridge["Bridge"]
|
||
direction LR
|
||
B1["Glaze"] ~~~ B2["Tree-sitter"] ~~~ B3["Taskflow"] ~~~ B4["spdlog"]
|
||
end
|
||
|
||
Core --> Provider & Manager
|
||
Provider --> Manager & Language
|
||
Manager --> Language & Bridge
|
||
Language --> Bridge
|
||
end
|
||
```
|
||
|
||
## 核心模块
|
||
|
||
### Core - 核心服务
|
||
|
||
**职责**:处理 LSP 协议通信,分发请求,管理服务器生命周期
|
||
|
||
**关键文件**:
|
||
|
||
- `src/core/server.cppm` - 服务器主循环,stdio 读写
|
||
- `src/core/dispatcher.cppm` - 请求分发器,路由到对应 Provider
|
||
|
||
### Manager - 状态管理
|
||
|
||
**职责**:管理文档、符号、解析结果等核心状态
|
||
|
||
**关键文件**:
|
||
|
||
- `src/manager/document.cppm` - 文档管理,维护打开的文件内容
|
||
- `src/manager/parser.cppm` - 解析管理,维护语法树缓存
|
||
- `src/manager/symbol.cppm` - 符号管理,维护符号索引
|
||
- `src/manager/event_bus.cppm` - 事件总线,模块间解耦通信
|
||
- `src/manager/manager_hub.cppm` - 管理器集线器,统一访问入口
|
||
|
||
### Provider - LSP 功能提供者
|
||
|
||
**职责**:实现具体的 LSP 功能(补全、跳转、悬停等)
|
||
|
||
**关键目录**:
|
||
|
||
- `src/provider/completion_item/` - 代码补全
|
||
- `src/provider/code_action/` - 代码操作
|
||
- `src/provider/code_lens/` - 代码透镜
|
||
- `src/provider/text_document/` - 文档相关 (悬停、跳转定义、引用等)
|
||
- `src/provider/inlay_hint/` - 内联提示
|
||
- `src/provider/document_link/` - 文档链接
|
||
- `src/provider/call_hierarchy/` - 调用层次
|
||
- `src/provider/type_hierarchy/` - 类型层次
|
||
- `src/provider/workspace_symbol/` - 工作区符号搜索
|
||
|
||
### Language - 语言分析
|
||
|
||
**职责**:TSL 语言的语法和语义分析
|
||
|
||
**关键目录**:
|
||
|
||
- `src/language/ast/` - 抽象语法树访问和遍历
|
||
- `src/language/semantic/` - 语义分析
|
||
- `src/language/symbol/` - 符号定义和类型
|
||
- `src/language/keyword/` - 关键字定义
|
||
|
||
### Bridge - 第三方库桥接
|
||
|
||
**职责**:封装第三方库,提供 C++ Module 接口
|
||
|
||
**关键文件**:
|
||
|
||
- `src/bridge/glaze.cppm` - JSON 序列化
|
||
- `src/bridge/spdlog.cppm` - 日志
|
||
- `src/bridge/taskflow.cppm` - 并行任务
|
||
- `src/bridge/tree_sitter.cppm` - 语法解析
|
||
- `src/bridge/win32_stdio.cppm` - Windows stdio 支持
|
||
|
||
### Protocol - LSP 协议
|
||
|
||
**职责**:定义 LSP 协议的类型和序列化
|
||
|
||
**关键文件**:
|
||
|
||
- `src/protocol/types.cppm` - 基础类型定义
|
||
- `src/protocol/protocol.cppm` - 协议聚合模块
|
||
|
||
## 关键约束
|
||
|
||
- **C++ Modules**:使用 `.cppm` 文件,需要 Clang 20+ 或 GCC 15+
|
||
- **异步处理**:所有耗时操作必须通过 `AsyncExecutor` 异步执行
|
||
- **增量解析**:使用 Tree-sitter 保证编辑时的响应性能
|
||
- **JSON 序列化**:使用 Glaze 库实现零拷贝 JSON 解析
|
||
|
||
## 扩展点
|
||
|
||
### 添加新的 LSP Provider
|
||
|
||
**步骤**:
|
||
|
||
1. 在 `src/provider/` 下创建新目录
|
||
2. 继承 `ProviderBase` 基类
|
||
3. 实现 `handle()` 方法处理请求
|
||
4. 在 `Dispatcher` 中注册路由
|
||
|
||
### 添加新的语义分析
|
||
|
||
**步骤**:
|
||
|
||
1. 在 `src/language/semantic/` 添加分析模块
|
||
2. 定义访问 AST 的逻辑
|
||
3. 在 `SymbolManager` 中集成
|
||
|
||
### 添加新的代码补全类型
|
||
|
||
**步骤**:
|
||
|
||
1. 在 `src/provider/completion_item/` 添加新的补全源
|
||
2. 实现补全逻辑,返回 `CompletionItem` 列表
|
||
3. 在主 completion provider 中注册
|
||
|
||
---
|
||
|
||
**最后更新**:2026-02-02
|