playbook/SKILLS.md

5.4 KiB
Raw Blame History

SKILLS

本文档说明如何安装、启用和使用 AI agent skills。

支持的平台:

平台 skills 目录
Codex CLI ~/.agents/skills/
Claude Code ~/.claude/skills/

用户指南

1. 启用 skills必做

Codex CLI — 在 ~/.codex/config.toml 中启用:

[features]
skills = true

修改后需要重启 codex 才会重新发现技能。

Claude Code — 在 ~/.claude/settings.json 中启用(或通过 /config 命令):

{
  “skills”: true
}

2. 安装到本机

使用统一入口 playbook.py 安装 skills通过 agents_home 指定目标平台目录:

Codex CLI

# playbook.toml
[playbook]
project_root = .

[install_skills]
mode = all
agents_home = “~/.agents

Claude Code

[install_skills]
mode = all
agents_home = “~/.claude
python scripts/playbook.py -config playbook.toml

仅安装指定 skills

[install_skills]
mode = list
skills = [style-cleanup, commit-message]
agents_home = “~/.claude   # 或 ~/.agents

[install_skills] 默认会先把已存在的 skill 目录重命名为 *.bak.<timestamp>,再复制新版本,便于手动回退。若不需要备份:

[install_skills]
mode = all
agents_home = “~/.claude
no_backup = true

如果你的项目已经把本 Playbook 部署到项目内,则在目标项目里执行:

python <playbook_root>/scripts/playbook.py -config playbook.toml

其中 <playbook_root> 默认为 docs/standards/playbook

3. 使用方式

  • 在对话中通过 $<skill-name> 直接点名触发(例如:$style-cleanup
  • Codex TUI可用 /skills 浏览与插入
  • Claude Code通过 /skills 命令或直接在对话中触发

4. 可用 Skills 清单

完整清单(含作用说明、典型场景)见 skills/README.md

5. 运行时排障

  • 不触发
    • Codex确认已启用 [features] skills = true,重启 codex
    • Claude Code确认 skills 已启用,重启 Claude Code
    • 确认 skill 已安装到对应平台目录
  • 触发错:减少不同 skill 的 description 关键词重叠;让触发词更具体(语言/工具/目录名/流程名)
  • 启动报错:通常是 YAML frontmatter 不合法或字段超长;修复后重启即可

开发者指南

目录结构

本 Playbook 以"可分发、可安装"的方式提供 skills

skills/
  <skill-name>/         # 本仓库自维护
    SKILL.md
    references/        # 可选:拆分参考文档
    templates/         # 可选:模板
    scripts/           # 可选:脚本/命令封装
  thirdparty/          # 第三方同步(不可手动修改)
    <skill-name>/
      SKILL.md
    .sources/          # 第三方来源清单

最终安装到本机后,对应路径为:

平台 路径
Codex CLI ~/.agents/skills/<skill-name>/SKILL.md
Claude Code ~/.claude/skills/<skill-name>/SKILL.md

SKILL.md 最小规范

  • 文件名必须是 SKILL.md
  • 必须包含 YAML frontmatter--- 包裹),且至少包含:
    • name非空≤100 字符,建议 kebab-case 且与目录名一致
    • description非空≤500 字符(写”用户会怎么说”的触发词;避免换行)
  • frontmatter 之外的正文可以是任意 Markdown用于工作流说明/决策树/命令/模板索引)

设计原则

把 skill 当作”可检索的工作流模块”,而不是长篇教程:

  1. 边界清晰:只写”仓库/组织特定”的流程、约束与验收标准;避免通用编程常识。
  2. description 负责检索:把团队常用说法(中英文同义词)写进 description,降低漏触发概率。
  3. SOP 化:建议包含 Inputs → Procedure → Output Contract → Success Criteria → Failure Handling。
  4. 渐进式披露:主 SKILL.md 保持精炼;大段清单/模板放 references/,引用深度 ≤ 1。
  5. 高风险低自由度:破坏性操作(删数据/重写历史/生产变更)默认先停下确认,并给回滚方案。

Playbook 权威来源(可在 skill 中引用)

  • 提交信息:docs/common/commit_message.md
  • TSLdocs/tsl/code_style.mddocs/tsl/naming.mddocs/tsl/toolchain.md
  • C++docs/cpp/code_style.mddocs/cpp/naming.mddocs/cpp/toolchain.md
  • Pythondocs/python/style_guide.mddocs/python/tooling.mddocs/python/configuration.md

若你的项目把本 Playbook 部署到项目内,文档根路径为 <playbook_root>/docs/...;其中 <playbook_root> 默认为 docs/standards/playbook,也可以按项目配置改成 custom/playbook 等自定义目录。

第三方 Skills 同步机制

本仓库通过 thirdparty/skill 分支同步第三方 skills。

来源登记

  • skills/thirdparty/.sources/:来源清单目录(*.list 文件)
  • skills/thirdparty/thirdparty-skills.yml:统一配置文件

同步流程

  1. 上游快照保存在 thirdparty/skill 分支
  2. 自动同步后,落到仓库内 skills/thirdparty/<skill-name>/
  3. 运行 [install_skills] 时,复制到目标平台 skills 目录(~/.agents/skills/~/.claude/skills/

最后更新2026-06-17