name: rust-symbol-analyzer description: “使用LSP符号分析Rust项目结构。触发词:/symbols, project structure, list structs, list traits, list functions, 符号分析, 项目结构, 列出所有, 有哪些struct” argument-hint: “[file.rs] [–type struct|trait|fn|mod]” allowed-tools: [“LSP”, “Read”, “Glob”]
Rust 符号分析器
通过检查Rust代码库中的符号来分析项目结构。
使用方法
/rust-symbol-analyzer [file.rs] [--type struct|trait|fn|mod]
示例:
/rust-symbol-analyzer- 分析整个项目/rust-symbol-analyzer src/lib.rs- 分析单个文件/rust-symbol-analyzer --type trait- 列出项目中所有trait
LSP操作
1. 文档符号(单个文件)
获取文件中所有符号及其层次结构。
LSP(
operation: "documentSymbol",
filePath: "src/lib.rs",
line: 1,
character: 1
)
返回: 模块、结构体、函数等的嵌套结构。
2. 工作区符号(整个项目)
在整个工作区中搜索符号。
LSP(
operation: "workspaceSymbol",
filePath: "src/lib.rs",
line: 1,
character: 1
)
注意: 查询隐含在操作上下文中。
工作流程
用户: "这个项目的结构是什么?"
│
▼
[1] 查找所有Rust文件
Glob("**/*.rs")
│
▼
[2] 从每个关键文件获取符号
LSP(documentSymbol) 用于 lib.rs, main.rs
│
▼
[3] 按类型分类
│
▼
[4] 生成结构可视化
输出格式
项目概览
## 项目结构: my-project
### 模块
├── src/
│ ├── lib.rs (根模块)
│ ├── config/
│ │ ├── mod.rs
│ │ └── parser.rs
│ ├── handlers/
│ │ ├── mod.rs
│ │ ├── auth.rs
│ │ └── api.rs
│ └── models/
│ ├── mod.rs
│ ├── user.rs
│ └── order.rs
└── tests/
└── integration.rs
按符号类型
## 按类型分类的符号
### 结构体 (12)
| 名称 | 位置 | 字段 | 派生 |
|------|----------|--------|---------|
| Config | src/config.rs:10 | 5 | Debug, Clone |
| User | src/models/user.rs:8 | 4 | Debug, Serialize |
| Order | src/models/order.rs:15 | 6 | Debug, Serialize |
| ... | | | |
### 特质 (4)
| 名称 | 位置 | 方法 | 实现者 |
|------|----------|---------|--------------|
| Handler | src/handlers/mod.rs:5 | 3 | AuthHandler, ApiHandler |
| Repository | src/db/mod.rs:12 | 5 | UserRepo, OrderRepo |
| ... | | | |
### 函数 (25)
| 名称 | 位置 | 可见性 | 异步 |
|------|----------|------------|-------|
| main | src/main.rs:10 | pub | 是 |
| parse_config | src/config.rs:45 | pub | 否 |
| ... | | | |
### 枚举 (6)
| 名称 | 位置 | 变体 |
|------|----------|----------|
| Error | src/error.rs:5 | 8 |
| Status | src/models/order.rs:5 | 4 |
| ... | | | |
单文件分析
## src/handlers/auth.rs
### 符号层次结构
mod auth
├── struct AuthHandler
│ ├── 字段: config: Config
│ ├── 字段: db: Pool
│ └── impl AuthHandler
│ ├── fn new(config, db) -> Self
│ ├── fn authenticate(&self, token) -> Result<User>
│ └── fn refresh_token(&self, user) -> Result<Token>
├── struct Token
│ ├── 字段: value: String
│ └── 字段: expires: DateTime
├── enum AuthError
│ ├── InvalidToken
│ ├── Expired
│ └── Unauthorized
└── impl Handler for AuthHandler
├── fn handle(&self, req) -> Response
└── fn name(&self) -> &str
分析功能
复杂度指标
## 复杂度分析
| 文件 | 结构体 | 函数 | 行数 | 复杂度 |
|------|---------|-----------|-------|------------|
| src/handlers/auth.rs | 2 | 8 | 150 | 中等 |
| src/models/user.rs | 3 | 12 | 200 | 高 |
| src/config.rs | 1 | 3 | 50 | 低 |
**热点:** 复杂度高的文件可能需要重构
- src/handlers/api.rs (15个函数, 300行)
依赖分析
## 内部依赖
auth.rs
├── 从以下导入: config.rs, models/user.rs, db/mod.rs
└── 被以下导入: main.rs, handlers/mod.rs
user.rs
├── 从以下导入: (无 - 叶子模块)
└── 被以下导入: auth.rs, api.rs, tests/
符号类型
| 类型 | 图标 | LSP种类 |
|---|---|---|
| 模块 | 📦 | Module |
| 结构体 | 🏗️ | Struct |
| 枚举 | 🔢 | Enum |
| 特质 | 📜 | Interface |
| 函数 | ⚡ | Function |
| 方法 | 🔧 | Method |
| 常量 | 🔒 | Constant |
| 字段 | 📎 | Field |
常见查询
| 用户说 | 分析 |
|---|---|
| “这个项目中有哪些结构体?” | workspaceSymbol + 过滤 |
| “显示src/lib.rs的结构” | documentSymbol |
| “查找所有异步函数” | workspaceSymbol + 异步过滤 |
| “列出公共API” | documentSymbol + pub过滤 |
相关技能
| 何时使用 | 参见 |
|---|---|
| 导航到符号 | rust-code-navigator |
| 调用关系 | rust-call-graph |
| 特质实现 | rust-trait-explorer |
| 安全重构 | rust-refactor-helper |