aiw 6.0.1

AIW (AI Warden) - Universal AI CLI management platform with intelligent process tracking, semantic memory, and provider coordination.
Documentation
# 项目代码审查报告

**审查日期**: 2025-11-14
**审查目标**: 检查重复实现和列举所有CLI/MCP方法

---

## ✅ 重复实现检查

### 结论:**未发现重复实现**

#### 检查的关键模块

1. **Registry系统**   - `unified_registry.rs` - 统一注册表(主实现)
   - `registry_factory.rs` - Registry工厂(创建CLI/MCP注册表)
   - `registry.rs` - 工具函数(注释明确说明已避免重复)
   - `InstanceRegistry` (models.rs) - 实例元数据(不同用途)

2. **Storage系统**   - 只有一个 `TaskStorage` trait
   - 测试中有 `LegacyInProcessStorage`,但仅用于性能对比测试

3. **Config系统**   - 各模块有独立的config.rs(用途不同):
     - `src/config.rs` - 全局配置
     - `src/provider/config.rs` - Provider配置
     - `src/memory/config.rs` - Memory配置
     - `src/hooks/config.rs` - Hooks配置
     - `src/sync/sync_config.rs` - 同步配置

4. **遗留代码标记**   - 所有"legacy"/"old"标记都在测试代码中
   - 用于向后兼容性测试和性能对比
   - **没有废弃的生产代码**

---

## 📋 CLI 命令列表

### 主命令(13个)

| 命令 | 说明 | 参数 |
|------|------|------|
| `dashboard` | 显示Dashboard(默认) | - |
| `status` | 显示任务状态 | `--tui` |
| `provider` | Provider管理TUI | - |
| `push` | 推送目录到Google Drive | `[DIR...]` |
| `pull` | 从Google Drive拉取 | - |
| `reset` | 重置同步状态 | - |
| `list` | 列出远程文件 | - |
| `wait` | 等待所有任务完成 | `--timeout`, `--verbose` |
| `pwait` | 等待指定进程任务 | `<PID>` |
| `examples` | 显示使用示例 | - |
| `help` | 显示帮助信息 | `[COMMAND]` |
| `update` | 更新/安装AI CLI工具 | `[TOOL]` |
| `mcp` | 启动MCP服务器 | `--transport`, `--log-level` |

### 子命令

#### Hooks子命令
- `hooks handle` - 处理Claude Code hook事件

#### External子命令(AI CLI选择器)
- `claude [ARGS]` - 启动Claude CLI
- `codex [ARGS]` - 启动Codex CLI
- `gemini [ARGS]` - 启动Gemini CLI

---

## 🔌 MCP 方法列表

### MCP Tools (7个)

| 工具名 | 文件位置 | 功能描述 | 参数 |
|--------|---------|---------|------|
| `intelligent_route` | `src/mcp/mod.rs:104` | Route user request to best MCP tool | `user_request`, `decision_mode`, `execution_mode`, `max_candidates`, `session_id`, `metadata` |
| `get_method_schema` | `src/mcp/mod.rs:182` | Return JSON schema for a given MCP tool | `mcp_server`, `tool_name` |
| `search_history` | `src/mcp/mod.rs:197` | Search conversation history using semantic similarity | `query`, `limit` |
| `execute_tool` | `src/mcp/mod.rs:298` | Execute a specific MCP tool with confirmed parameters | `mcp_server`, `tool_name`, `arguments`, `session_id` |
| `start_concurrent_tasks` | `src/mcp/mod.rs:313` | Launch multiple AI CLI tasks concurrently | `tasks` (array of TaskSpec) |
| `get_task_command` | `src/mcp/mod.rs:374` | Get command string to launch single AI CLI task | `ai_type`, `task`, `provider` (optional) |
| `get_session_todos` | `src/mcp/mod.rs:409` | Get uncompleted TODO items for a session | `session_id` |

### MCP 核心方法

| 方法 | 实现位置 | 说明 |
|------|---------|------|
| `initialize` | `src/mcp/mod.rs` (inherited from rmcp) | 初始化MCP连接,检测客户端能力 |
| `list_tools` | `src/mcp/mod.rs:250` | 列出基础工具+动态注册工具 |
| `call_tool` | `src/mcp/mod.rs:271` | 调用工具(代理到真实MCP服务器) |

### 动态工具管理 (DynamicToolManager)

| 方法 | 位置 | 功能 |
|------|------|------|
| `register_tool` | `src/mcp/dynamic_tools.rs:26` | 注册工具到主AI |
| `unregister_tool` | `src/mcp/dynamic_tools.rs:47` | 取消注册工具 |
| `list_tools` | `src/mcp/dynamic_tools.rs:57` | 列出所有动态工具 |
| `get_server` | `src/mcp/dynamic_tools.rs:67` | 获取工具对应的MCP服务器 |
| `has_tool` | `src/mcp/dynamic_tools.rs:76` | 检查工具是否已注册 |
| `clear` | `src/mcp/dynamic_tools.rs:81` | 清除所有动态工具 |

---

## 🎯 架构清晰度评估

### ✅ 优点

1. **模块职责明确**
   - CLI命令:`src/commands/`
   - MCP服务器:`src/mcp/`
   - MCP路由:`src/mcp_routing/`
   - 各模块独立,耦合度低

2. **无重复实现**
   - Registry系统统一
   - Storage trait单一
   - 配置按模块分离

3. **清晰的演进路径**
   - `unified_registry` 明确说明避免重复
   - 测试中保留legacy对比,用于验证新实现性能

4. **文档完整**
   - 所有模块都有顶部注释
   - 关键函数有说明

### 📊 统计数据

- **总文件数**: 98个Rust文件
- **CLI命令**: 13个主命令 + 1个hooks子命令 + AI CLI选择器
- **MCP工具**: 4个对外工具
- **MCP内部方法**: 3个核心方法 + 6个动态管理方法
- **重复实现**: 0

---

## 💡 建议

### 1. 无需优化
当前代码结构清晰,没有发现需要合并或删除的重复实现。

### 2. 继续保持
- 模块化设计
- 测试覆盖(包括向后兼容测试)
- 清晰的注释说明

### 3. 文档同步
- ✅ SPEC文档已与实现同步
- ✅ AUDIT_REPORT.md 反映当前状态
- ✅ README.md 已更新

---

**审查结论**: 🟢 **代码库健康,无重复实现,架构清晰**