<img src="https://github.com/rpamis/comet/blob/master/img/title-log.png" alt="Comet logo">
██████╗ ██████╗ ███╗ ███╗███████╗████████╗
██╔════╝██╔═══██╗████╗ ████║██╔════╝╚══██╔══╝
██║ ██║ ██║██╔████╔██║█████╗ ██║
██║ ██║ ██║██║╚██╔╝██║██╔══╝ ██║
╚██████╗╚██████╔╝██║ ╚═╝ ██║███████╗ ██║
╚═════╝ ╚═════╝ ╚═╝ ╚═╝╚══════╝ ╚═╝
English version: README.md Bilibili video 抖音
OpenSpec + Superpowers 双星开发工作流 — 从创意到归档,一条命令。
OpenSpec 处理 WHAT(大纲、提案、spec 生命周期、归档)。
Superpowers 处理 HOW(技术设计、规划、执行、收尾)。
Comet 将二者串联为五阶段自动化流水线。
[!IMPORTANT] 0.3.9 —
review_mode: off|standard|thorough控制 Build/Verify 自动代码审查并支持项目级默认;init/update 改为可选依赖安装,补齐 CLI 国际化、阶段守护加固和 macOS 可执行权限。0.3.8 — 新增 Kimi Code 支持、安全的多平台
comet uninstall、子代理调度扩展、按需加载共享参考、版本更新检查和 pre-commit 格式化。0.3.7 — 新增 CodeGraph 语义索引、Beta 上下文压缩、主动式上下文压缩、Token 优化、
auto_transition、阶段守护、可选 TDD 和更稳的归档/验证流程。详见 NEWS.md。
OpenSpec 擅长管理需求、做提案、管理 Spec 生命周期和归档,但使用过程中 OpenSpec 的提案和 Task 没有像 Superpowers 头脑风暴那样细致。
Superpowers 在头脑风暴后会产出 Spec 文档,但这个文档通常没有进行状态化设计——做完需求之后 Spec 仅在文档上对 Task 打勾,甚至 Agent 还会忘记打勾,造成下一次断点开始时,Agent 需要重新查看文档和项目代码来核验,产生较多 Token 浪费。
Comet 合并了两者的强项,将核心流程整合为 5 个阶段
主入口 /comet 支持当前 Spec 状态检测,适用于长任务——中途关闭当前 AI 编码会话后,回来只需 /comet,Comet 会自动读取活跃的
Spec(多个则列出选择),动态识别当前执行到哪个阶段,继续往下执行。
同时,Comet具备Spec全生命周期管理能力,运行过程中能够将 OpenSpec 的 change/spec 制品与 Superpowers 的设计、计划文档进行关联,并自动完成交接、状态更新、校验和归档同步,把原本需要用户频繁提醒 Agent 维护文档同步和关联关系的操作自动化。
现有的 Skill 市场中有很多优秀的 Skill 项目,但普遍存在偏好性问题——用户可能只喜欢部分功能。比如同时使用 OpenSpec 和 Superpowers 时,可能只用 OpenSpec 的 Spec 管理能力,而编码上更喜欢 Superpowers 的 TDD 驱动。
长期使用 Skill 的人都知道,这些能力是可以自由组合的,但具体怎么做依然需要真正的实践。Comet 项目可以作为参考:
如何稳定触发嵌套 Skill — 不是让 Agent 依靠文档描述做了“看起来像触发了 Skill”的操作(比如根据 Skill 描述写了文件),而是真正触发 Skill(核心特征:CC 上有 Skill 触发的打印)。Comet 中会触发大量来自 OpenSpec 和 Superpowers 的能力,这段 Prompt 是怎么写的?
如何让组合 Skill 多阶段自动流转 — 不是靠人工介入。Comet 的 5 阶段流程,除必要的用户选择项外,核心流程能够自动进行 Skill 触发,同时状态机机制也能保障状态扭转的可靠性。
如何把 Spec 生命周期做成可恢复流程 — Comet 会把 OpenSpec 的 change/spec 制品与 Superpowers 的设计、计划文档关联起来,并通过
.comet.yaml 记录阶段、执行模式、验证结果和归档状态,让 Agent 中断后能够继续,而不是重新翻文档猜进度。
如何把文档同步从“用户提醒”变成自动化 — Comet 将 handoff、状态更新、校验和归档同步放进脚本化流程,减少“记得更新 design doc”“记得同步 spec”“记得归档 change”这类反复提示。
如何设计 Agent 可执行的守护条件 — Comet 的阶段退出不是简单相信 Agent 说“完成了”,而是通过 comet-guard.sh、
comet-yaml-validate.sh、comet-state.sh 等脚本检查任务、状态字段、验证证据和归档条件,满足条件后才允许推进。
如何做跨平台 Skill 分发和安装 — Comet 支持多种 AI 编码平台、项目级/全局安装、中文/英文 Skill 选择,以及平台差异化目录(例如 Antigravity 的项目级和全局路径不同),可以作为 CLI 安装器和 Skill 打包结构的参考。
如何把 shell 脚本写成 Agent 工作流基础设施 — Comet 的脚本需要兼容 macOS、Linux、Windows Git Bash,处理 hash、YAML 字段、状态机和归档流程。它展示了如何把原本容易写散在 Prompt 里的流程控制,沉淀成可测试、可复用的工具。
前置要求:
npm install -g @rpamis/comet
cd your-project
comet init
comet init 会:
npx skills add)、CodeGraph CLI。未检测到的依赖默认勾选;已存在的默认不勾,可自主选择是否升级。docs/superpowers/specs/ 和 docs/superpowers/plans/ 工作目录[!TIP] 推荐安装 Superpowers v6.0.0+ —— 相比旧版速度快约 2 倍,节省约 50% token。 后续升级 Comet 本身:执行
comet update或npm install -g @rpamis/comet@latest。
对于直接使用通用 skills CLI 的平台,可以用下面的方式安装 Comet skill 包:
npx skills add rpamis/comet

自动安装 OpenSpec、Superpowers,一键配置开发环境
多阶段 Skill 入口,自动识别当前 Spec 阶段,核心流程自动触发,关键节点人工审核
comet init [path] — 初始化 Comet 工作流
为选定的 AI 编码平台初始化 OpenSpec、Superpowers 和 Comet 技能。
| 选项 | 描述 |
|---|---|
--yes |
非交互模式,自动选择已检测平台(未检测到则选择全部) |
--scope <scope> |
安装范围:project 或 global |
--language <lang> |
技能语言:en 或 zh(跳过交互式语言选择) |
--skip-existing |
跳过已安装的组件 |
--overwrite |
覆盖已安装的组件 |
--json |
输出结构化 JSON |
当同一平台检测到多个已安装组件时,交互式 init 会先提供一次批量选择:全部覆盖、全部跳过,或逐项选择。
comet status [path] — 显示活跃更改和下一步命令
显示活跃更改、任务进度,以及推荐的下一步 Comet 工作流命令。
| 选项 | 描述 |
|---|---|
--json |
输出活跃更改,并包含 nextCommand |
comet doctor [path] — 诊断 Comet 安装健康状态
检查项目级/全局安装、工作目录、已安装技能、脚本和 Comet 状态文件。
| 选项 | 描述 |
|---|---|
--json |
输出结构化诊断结果 |
--scope <scope> |
诊断 auto、project 或 global 范围(默认:auto) |
comet update [path] — 更新 Comet 包和技能
更新 npm 包,并刷新已检测到的项目级/全局 Comet 技能。
| 选项 | 描述 |
|---|---|
--json |
以 JSON 输出 npm 和 skill 更新结果 |
--language <lang> |
覆盖自动检测到的 skill 语言 (en, zh) |
--scope <scope> |
仅更新 global 或 project 范围 |
comet uninstall [path] — 卸载 Comet 技能、规则和钩子
安全移除 Comet 分发的技能、规则和钩子,保留用户自定义的钩子和非 Comet 配置。
| 选项 | 描述 |
|---|---|
--force |
跳过确认提示 |
--scope <scope> |
仅卸载 global 或 project 范围 |
--json |
以 JSON 输出卸载结果 |
comet uninstall # 交互式 — 显示已安装目标,确认后卸载
comet uninstall --force # 非交互式 — 直接移除所有内容
comet uninstall --scope project # 仅移除项目级安装
| 命令 | 描述 |
|---|---|
comet --help |
显示帮助 |
comet --version |
显示版本 |
comet init 支持 29 个 AI 编码平台:
查看完整平台列表
| 平台 | 技能目录 | 平台 | 技能目录 |
|---|---|---|---|
| Claude Code | .claude/ |
Cursor | .cursor/ |
| Codex | .codex/ |
OpenCode | .opencode/ |
| Windsurf | .windsurf/ |
Cline | .cline/ |
| RooCode | .roo/ |
Continue | .continue/ |
| GitHub Copilot | .github/ |
Gemini CLI | .gemini/ |
| Amazon Q Developer | .amazonq/ |
Qwen Code | .qwen/ |
| Kilo Code | .kilocode/ |
Auggie | .augment/ |
| Kimi Code | .kimi-code/ |
Kiro | .kiro/ |
| Lingma | .lingma/ |
Junie | .junie/ |
| CodeBuddy | .codebuddy/ |
CoStrict | .cospec/ |
| Crush | .crush/ |
Factory Droid | .factory/ |
| iFlow | .iflow/ |
Pi | .pi/ |
| Qoder | .qoder/ |
Antigravity | .agents/ |
| Bob Shell | .bob/ |
ForgeCode | .forge/ |
| Trae | .trae/ |
部分平台的项目级目录和全局目录不同。例如 OpenCode 全局安装使用 .config/opencode,Lingma 全局安装使用 .lingma
,Antigravity 全局安装使用 .gemini/antigravity。
comet init 完成后,三组技能将被安装到所选平台的 skills/ 目录:
查看 Comet 技能列表
| 技能 | 描述 |
|---|---|
/comet |
主入口 — 自动检测阶段并分派到子命令 |
/comet-open |
阶段 1:打开变更(提案、设计、任务分解) |
/comet-design |
阶段 2:深度设计(头脑风暴、设计文档) |
/comet-build |
阶段 3:规划与构建(实现计划、代码提交) |
/comet-verify |
阶段 4:验证与完成(测试、验证报告) |
/comet-archive |
阶段 5:归档(delta spec 同步、状态标注) |
/comet-hotfix |
快捷路径:快速 bug 修复(跳过头脑风暴,不需要能力设计) |
/comet-tweak |
快捷路径:小改动(文案调整、配置调整、文档或 Prompt 优化) |
查看脚本列表
| 脚本 | 用途 |
|---|---|
comet-env.sh |
脚本发现助手 — 导出 COMET_GUARD、COMET_STATE、COMET_HANDOFF、COMET_ARCHIVE 等内置脚本路径 |
comet-guard.sh |
阶段转换守护 — 验证退出条件,--apply 自动更新 .comet.yaml |
comet-handoff.sh |
设计交接 — 从 OpenSpec 制品生成带 SHA256 追踪的确定性上下文包 |
comet-archive.sh |
一键归档 — 验证状态、同步 specs、移至归档、更新状态 |
comet-yaml-validate.sh |
模式校验器 — 校验 .comet.yaml 结构和字段值 |
comet-state.sh |
统一状态管理 — init/set/get/check/scale,agent 的专属 YAML 接口 |
comet-hook-guard.sh |
阶段写入守护 — PreToolUse hook,在 open/design/archive 阶段拦截文件写入 |
Spec 生命周期管理:propose、explore、sync、verify、archive 等。
开发方法论:brainstorming、TDD、subagent-driven development、code review、plan writing 等。
/comet
↓ auto-detect
/comet-open --> /comet-design --> /comet-build --> /comet-verify --> /comet-archive
(OpenSpec) (Superpowers) (Superpowers) (Both) (OpenSpec)
/comet-hotfix(快捷路径,跳过头脑风暴)
open --> build --> verify --> archive
/comet-tweak(快捷路径,跳过头脑风暴和完整计划)
open --> 轻量构建 --> 轻量验证 --> archive
| 阶段 | 命令 | 归属 | 产出物 |
|---|---|---|---|
| 1. Open | /comet-open |
OpenSpec | proposal.md、design.md、tasks.md |
| 2. Deep Design | /comet-design |
Superpowers | Design Doc、delta spec |
| 3. Plan & Build | /comet-build |
Superpowers | 实现计划、代码提交 |
| 4. Verify & Finish | /comet-verify |
Both | 验证报告、分支处理 |
| 5. Archive | /comet-archive |
OpenSpec | delta→main spec 同步、归档 |
/comet-verify 必须通过才能执行 /comet-archiveComet 使用解耦状态架构,YAML 文件独立管理:
| 文件 | 归属 | 用途 |
|---|---|---|
.openspec.yaml |
OpenSpec | Spec 生命周期、变更元数据 |
.comet.yaml |
Comet | 工作流阶段、执行模式、验证状态 |
所有状态和运行阶段都通过脚本更新,并且会在每个阶段退出前校验任务是否真实完成。相比于将复杂状态管理写在 Skill 文本中,脚本化状态机能更稳定地保障阶段流转、YAML 正确性和断点恢复;Agent 只需要通过 Comet 内置命令读取状态,就能知道当前 Spec 处于哪个阶段。
查看 .comet.yaml 关键字段
.comet.yaml 关键字段:
workflow: full
auto_transition: true
phase: build
build_mode: subagent-driven-development
build_pause: null
isolation: branch
verify_mode: null
design_doc: docs/superpowers/specs/YYYY-MM-DD-topic-design.md
plan: docs/superpowers/plans/YYYY-MM-DD-feature.md
verify_result: pending
verification_report: null
branch_status: pending
verified_at: null
archived: false
direct_override: false
build_command: null
verify_command: null
handoff_context: openspec/changes/<name>/.comet/handoff/design-context.json
handoff_hash: <sha256>
tdd_mode: null
subagent_dispatch: null
full workflow 初始化时 build_mode、build_pause、isolation、verify_mode、tdd_mode 和 subagent_dispatch 可以暂时为
null;进入 build → verify 前必须完成 build_mode 与 isolation 决策并写入合法值。auto_transition 控制阶段完成后是否自动触发下一个 Skill — 详见 AUTO-TRANSITION.md。build_pause 记录 build 阶段内部暂停点:
null 表示无暂停,plan-ready 表示 plan 已生成,用户在选择隔离方式和执行方式前暂停。它不是执行方式,不得写入 build_mode。
verification_report 在验证报告生成前保持 null,verify-pass 要求该报告文件存在且 branch_status: handled。示例中
archived 之后的字段是可选字段或脚本派生字段:direct_override 只在 full workflow 直接构建时需要,项目命令未配置时可以不存在,
handoff_context 和 handoff_hash 由 `comet-h
$ claude mcp add comet \
-- python -m otcore.mcp_server <graph>