claudecode/crates/tools
fengmengqi d8d77824f4 feat: 合并上游 Rust 实现,扩展 API/运行时/工具链能力
将 claw-code/rust/crates 的完整实现合并到主 workspace,涵盖
  9 个 crate 的更新与 2 个新 crate 的引入。

  API 层:
  - 用原生 Anthropic 客户端(anthropic.rs)替换 claw_provider,
    新增 prompt cache 减少重复请求开销
  - 新增 HTTP 客户端构建器统一代理配置,OpenAI 兼容端增加
    DashScope/Qwen 支持与抖动重试
  - MessageRequest 扩展 temperature/top_p 等模型调参字段
  - SSE 解析器增加 provider 上下文感知的错误信息

  运行时(~11,000 行新增):
  - 新增 bash 命令安全校验、分支锁碰撞检测、配置文件校验
  - 新增会话存储与控制面、MCP 生命周期状态机与服务端实现
  - 新增权限执行引擎、策略引擎、插件生命周期管理
  - 新增 worker 启动编排、任务/定时任务注册表、信任解析器
  - 保留 Windows cmd /C fallback

  命令/插件/工具:
  - commands 大幅重写,扩展 sandbox、doctor、plan 等 slash 命令
  - plugins 新增 PostToolUseFailure hook 与宽容加载机制
  - tools 新增 PDF 提取与 lane 补全工具

  新增 crate:mock-anthropic-service(测试)、telemetry(遥测)

  适配 claw-cli/server:ClawApiClient→AnthropicClient 重命名,
  SlashCommand::parse 返回 Result,移除 session 级 Thinking 变体,
  TokenUsage/ConversationMessage 补充序列化支持
2026-04-13 14:39:17 +08:00
..
src feat: 合并上游 Rust 实现,扩展 API/运行时/工具链能力 2026-04-13 14:39:17 +08:00
.gitignore Polish Agent defaults and ignore crate-local agent artifacts 2026-03-31 20:46:06 +00:00
Cargo.toml feat: 合并上游 Rust 实现,扩展 API/运行时/工具链能力 2026-04-13 14:39:17 +08:00
README.md feat: 添加 Web 前端及服务端 SSE 流式支持,扩展多模型兼容 2026-04-10 16:29:27 +08:00

工具规范模块 (tools)

本模块定义了 AI 代理可以使用的所有内置工具的规范 (Schema)、权限要求以及分发逻辑。

概览

tools 模块充当了 AI 认知能力与物理操作之间的桥梁,其主要职责包括:

  • 工具定义:使用 JSON Schema 定义每个工具的输入参数结构,以便 AI 正确调用。
  • 权限映射:为每个工具分配安全等级(如只读、工作区写入、完全访问)。
  • 工具注册表 (GlobalToolRegistry):统一管理内置工具和由插件提供的动态工具。
  • 分发执行:将 AI 生成的 JSON 调用分发到 runtime 模块中的具体实现。

关键特性

  • 内置工具集 (MVP Tools)
    • 系统交互bash, PowerShell, REPL
    • 文件操作read_file, write_file, edit_file
    • 搜索与发现glob_search, grep_search, ToolSearch
    • 网络与辅助WebSearch, WebFetch, Sleep
    • 高级调度Agent(启动子代理), Skill(加载专用技能), TodoWrite(任务管理)。
  • 名称归一化:支持工具别名(例如将 grep 映射为 grep_search),提高 AI 调用的稳健性。
  • 插件集成:允许 plugins 模块注册自定义工具,并确保它们与内置工具不发生命名冲突。

实现逻辑

核心结构

  • ToolSpec: 核心配置结构存储工具的元数据名称、描述、Schema、权限
  • GlobalToolRegistry: 负责维护工具列表,并提供 definitions 方法生成供 LLM 使用的工具 API 声明。
  • execute_tool: 顶级分发函数,负责将反序列化后的输入传递给底层的执行函数。

工作流程

  1. 系统初始化时,根据用户配置和加载的插件,构建 GlobalToolRegistry
  2. 将工具定义转换为 AI 模型可理解的格式(由 api 模块处理)。
  3. 当接收到 AI 的工具调用请求时,runtime::ConversationRuntime 调用 ToolExecutor
  4. ToolExecutor 委托给本模块的 execute_tool 函数。
  5. 本模块验证输入格式,并调用 runtime 提供的底层文件或进程操作 API。

使用示例 (工具定义)

use tools::{ToolSpec, mvp_tool_specs};
use serde_json::json;

// 获取所有 MVP 工具的规范
let specs = mvp_tool_specs();
for spec in specs {
    println!("工具: {}, 权限级别: {:?}", spec.name, spec.required_permission);
}