Claude Code Mastery
源码位置:
restored-src/src/
版本:v2.1.88
来源:架构分析 + 源码解析 + 实战模式(三合一)
核心理念:三层架构
Claude Code 的核心是 Tool → ToolUse → Task 三层递进模型:
Tool(定义层) → 我是什么工具,有哪些接口
ToolUse(执行层) → 实际调用时的完整运行时状态
Task(封装层) → 后台任务的生命周期管理
理解这三层的区别和交互,就掌握了 Claude Code 的骨架。
快速导航
详细内容和源码引用见各 reference 文件:
| 主题 | 参考文件 |
|---|---|
| 架构全景、子系统关系、源码位置 | architecture.md |
| Tool 接口、buildTool 工厂、ToolUseContext、Zod schema | tool-internals.md |
| Task 类型、生命周期、ID 生成、LocalShellTask | task-system.md |
| AgentTool、spawn/fork/continue/stop、AgentDefinition | agent-system.md |
| Coordinator 协调原则、Synthesize-first、决策树 | coordinator.md |
| Hooks 事件类型、执行流程、匹配规则 | hooks.md |
| 权限模型、SedEdit 安全设计、isConcurrencySafe | permissions.md |
| Context 缓存、CLAUDE.md 嵌套、fork-safe 设计 | context-system.md |
| SKILL.md 格式、Tool 实现模板、命令注册、Prompt 精选 | patterns.md |
| 设计亮点、调试线索、常见问题 Q&A | design-highlights.md |
关键概念速查
Tool ≠ 函数
Tool 是包含接口定义 + 执行逻辑 + 权限检查 + UI渲染的完整对象,不是简单的函数调用。
buildTool 默认 Fail-Closed
const TOOL_DEFAULTS = {
isConcurrencySafe: () => false, // 默认不允许并发
isReadOnly: () => false, // 默认会修改
isDestructive: () => false, // 默认不破坏
checkPermissions: () => ({ behavior: 'allow' }),
}
spawn vs fork vs continue
- spawn:独立 session,新 context
- fork:复用父进程 system prompt cache,在同一 session 并行
- continue:复用已有 context 继续执行
- stop:停止但不删除 session
Coordinator 核心原则
- 永远先 Synthesize,不 delegation of understanding
- 并行是默认策略
- Worker 结果 = 内部信号,不是对话伙伴
Fork 安全三剑客
contentReplacementState、renderedSystemPrompt、messages 必须在 fork 时从父进程克隆,保证上下文一致。
SedEdit 安全关键
_simulatedSedEdit 在 inputSchema 中被 omit,模型不能自己设置这个字段——防止构造任意文件写入。
扩展开发速查
实现新 Tool 检查清单
1. inputSchema — Zod schema 定义参数
2. description() — 人类可读描述(3-10 词,无句号)
3. call() — 执行逻辑,包含错误处理
4. maxResultSizeChars — 超过→写磁盘
5. checkPermissions() — 权限逻辑,默认 allow
6. toAutoClassifierInput() — 安全分类,默认空字符串
7. renderToolResultMessage() — UI 渲染
8. isConcurrencySafe() — 并发安全,默认 false
9. isReadOnly() / isDestructive() — 操作类型
10. getPath()? — 文件路径权限检查
11. preparePermissionMatcher()? — Hook pattern 匹配
添加新 Hook 事件
- 在
src/types/hooks.ts添加事件类型 - 在相关位置调用
hooks(event, context) - 在 SKILL.md 中配置规则
Skill 触发方式
- 显式:
/skill-name - 自动发现:ToolSearch 根据
description/whenToUse匹配 - 路径过滤:
paths字段 glob 模式
Skills 加载优先级
.claude/(项目)> ~/.claude/(用户)> plugin/