# comet
**Repository Path**: group_agent/comet
## Basic Information
- **Project Name**: comet
- **Description**: OpenSpec + Superpowers 双星开发融合工作流
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 2
- **Forks**: 3
- **Created**: 2026-05-25
- **Last Updated**: 2026-06-02
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# @rpamis/comet
```
██████╗ ██████╗ ███╗ ███╗███████╗████████╗
██╔════╝██╔═══██╗████╗ ████║██╔════╝╚══██╔══╝
██║ ██║ ██║██╔████╔██║█████╗ ██║
██║ ██║ ██║██║╚██╔╝██║██╔══╝ ██║
╚██████╗╚██████╔╝██║ ╚═╝ ██║███████╗ ██║
╚═════╝ ╚═════╝ ╚═╝ ╚═╝╚══════╝ ╚═╝
```
> English version: [README.md](README.md)
> [Bilibili video](https://www.bilibili.com/video/BV1y4Gi6CEo1/?spm_id_from=333.1387.homepage.video_card.click&vd_source=d22726fe6b108647dbebf1c5d8817377)
**OpenSpec + Superpowers 双星开发工作流** — 从创意到归档,一条命令。
OpenSpec 处理 **WHAT**(大纲、提案、spec 生命周期、归档)。
Superpowers 处理 **HOW**(技术设计、规划、执行、收尾)。
Comet 将二者串联为五阶段自动化流水线。
## 为什么需要 Comet
OpenSpec 擅长管理需求、做提案、管理 Spec 生命周期和归档,但使用过程中 OpenSpec 的提案和 Task 没有像 Superpowers 头脑风暴那样细致。
Superpowers 在头脑风暴后会产出 Spec 文档,但这个文档通常没有进行状态化设计——做完需求之后 Spec 仅在文档上对 Task 打勾,甚至 Agent 还会忘记打勾,造成下一次断点开始时,Agent 需要重新查看文档和项目代码来核验,产生较多 Token 浪费。
**Comet 合并了两者的强项**,将核心流程整合为 5 个阶段
主入口 `/comet` 支持当前 Spec 状态检测,适用于长任务——中途完成后关闭 CC,回来只需 `/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 里的流程控制,沉淀成可测试、可复用的工具。
## 安装
```bash
npm install -g @rpamis/comet
```
## 快速开始
```bash
cd your-project
comet init
```
`comet init` 会:
1. 提示你选择 AI 平台(自动检测已有配置)
2. 选择安装范围:项目级(当前目录)或全局(用户主目录)
3. 选择 Comet 技能语言:English 或 中文
4. 安装 [OpenSpec](https://github.com/Fission-AI/OpenSpec) 技能
5. 安装 [Superpowers](https://github.com/obra/superpowers) 技能
6. 将 Comet 技能(你选择的语言)部署到所选平台
7. 在项目级安装时创建 `docs/superpowers/specs/` 和 `docs/superpowers/plans/` 工作目录
> [!TIP]
> 更新版本号
>
> 执行 `comet update` 或者 `npm install -g @rpamis/comet@latest` 即可更新到最新版本。
## 运行截图
自动安装 OpenSpec、Superpowers,一键配置开发环境
多阶段 Skill 入口,自动识别当前 Spec 阶段,核心流程自动触发,关键节点人工审核
## CLI命令
comet init [path] — 初始化 Comet 工作流
为选定的 AI 编码平台初始化 OpenSpec、Superpowers 和 Comet 技能。
| 选项 | 描述 |
|--------|-------------|
| `--yes` | 非交互模式,自动选择已检测平台(未检测到则选择全部) |
| `--scope ` | 安装范围:`project` 或 `global` |
| `--skip-existing` | 跳过已安装的组件 |
| `--overwrite` | 覆盖已安装的组件 |
| `--json` | 输出结构化 JSON |
当同一平台检测到多个已安装组件时,交互式 init 会先提供一次批量选择:全部覆盖、全部跳过,或逐项选择。
comet status [path] — 显示活跃更改和下一步命令
显示活跃更改、任务进度,以及推荐的下一步 Comet 工作流命令。
| 选项 | 描述 |
|--------|-------------|
| `--json` | 输出活跃更改,并包含 `nextCommand` |
comet doctor [path] — 诊断 Comet 安装健康状态
检查项目级/全局安装、工作目录、已安装技能、脚本和 Comet 状态文件。
| 选项 | 描述 |
|--------|-------------|
| `--json` | 输出结构化诊断结果 |
| `--scope ` | 诊断 `auto`、`project` 或 `global` 范围(默认:`auto`) |
comet update [path] — 更新 Comet 包和技能
更新 npm 包,并刷新已检测到的项目级/全局 Comet 技能。
| 选项 | 描述 |
|--------|-------------|
| `--json` | 以 JSON 输出 npm 和 skill 更新结果 |
| `--language ` | 覆盖自动检测到的 skill 语言 (`en`, `zh`) |
| `--scope ` | 仅更新 `global` 或 `project` 范围 |
| 命令 | 描述 |
|---------|-------------|
| `comet --help` | 显示帮助 |
| `comet --version` | 显示版本 |
## 支持平台
`comet init` 支持 28 个 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/` |
| 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/` |
## 技能
`comet init` 完成后,三组技能将被安装到所选平台的 `skills/` 目录:
### Comet 技能
查看 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-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 接口 |
### OpenSpec 技能
Spec 生命周期管理:propose、explore、sync、verify、archive 等。
### Superpowers 技能
开发方法论: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 同步、归档 |
### 核心原则
- **头脑风暴不可跳过** — 每个变更必须经过深度设计(hotfix/tweak 除外)
- **Delta spec 是活文档** — 在阶段 3 中可自由编辑,归档时同步
- **保持 tasks.md 同步** — 每完成一个任务就勾选
- **频繁提交** — 每个任务一个 commit,message 体现设计意图
- **先验证再归档** — `/comet-verify` 必须通过才能执行 `/comet-archive`
### 状态管理
Comet 使用解耦状态架构,YAML 文件独立管理:
| 文件 | 归属 | 用途 |
|------|-------|---------|
| `.openspec.yaml` | OpenSpec | Spec 生命周期、变更元数据 |
| `.comet.yaml` | Comet | 工作流阶段、执行模式、验证状态 |
所有状态和运行阶段都通过脚本更新,并且会在每个阶段退出前校验任务是否真实完成。相比于将复杂状态管理写在 Skill 文本中,脚本化状态机能更稳定地保障阶段流转、YAML 正确性和断点恢复;Agent 只需要通过 Comet 内置命令读取状态,就能知道当前 Spec 处于哪个阶段。
查看 .comet.yaml 关键字段
**`.comet.yaml` 关键字段:**
```yaml
workflow: full
phase: build
build_mode: subagent-driven-development
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//.comet/handoff/design-context.json
handoff_hash:
```
full workflow 初始化时 `build_mode`、`isolation` 和 `verify_mode` 可以暂时为 `null`;进入 `build → verify` 前必须完成 `build_mode` 与 `isolation` 决策并写入合法值。`verification_report` 在验证报告生成前保持 `null`,`verify-pass` 要求该报告文件存在且 `branch_status: handled`。示例中 `archived` 之后的字段是可选字段或脚本派生字段:`direct_override` 只在 full workflow 直接构建时需要,项目命令未配置时可以不存在,`handoff_context` 和 `handoff_hash` 由 `comet-handoff.sh` 在离开 design 阶段前写入。项目可在 change 或仓库根配置中设置 `build_command` / `verify_command`,guard 会优先运行并打印失败输出。
### 可靠性特性
Comet 通过自动化状态转换确保 agent 执行可靠性:
查看可靠性特性
1. **入口验证** — 每个阶段在执行前验证前置条件
- 检查文件存在、状态一致性、阶段转换
- 验证失败时输出 `[HARD STOP]` 及可操作建议
2. **自动化状态转换** — `comet-guard.sh --apply` 自动更新 `.comet.yaml`
- 所有阶段转换(open → design/build → verify → archive)使用 `guard --apply`
- 无需手动状态编辑 — 消除写入验证错误
- `comet-state.sh` 是 agent 对状态操作的专属接口
- Guard 和 archive 脚本内部使用 `comet-state.sh` 进行状态管理
3. **模式校验** — `comet-yaml-validate.sh` 确保数据完整性
- 校验必填字段和可选字段
- 校验枚举值(包括 `direct_override`)
- 校验 `design_doc`、`plan`、`handoff_context` 路径存在,并校验 `handoff_hash` 格式
- 检测未知/拼写错误字段
4. **Build 决策强制** — Guard 和状态转换同时拦截跳过关键选择
- `isolation` 必须是 `branch` 或 `worktree`
- `build_mode` 必须已选择
- full workflow 的 `build_mode: direct` 必须有 `direct_override: true`
5. **验证证据强制** — Guard 在阶段流转前强制要求验证凭证
- `verify-pass` 转换要求 `verification_report` 指向已存在的验证报告文件
- `branch_status` 必须为 `handled` 才能通过验证
- Guard 检查 `verification_report exists` 和 `branch_status=handled` 作为硬性前提
- 防止验证或分支处理被跳过时产生虚假的阶段推进
6. **归档自动化** — `comet-archive.sh` 一键处理完整归档流程
- 验证入口状态、同步 delta specs 到 main specs
- 标注设计文档和计划文档的 frontmatter
- 将变更移至归档目录并更新 `archived: true`
- 支持 `--dry-run` 预览
## 项目结构
```
your-project/
├── .claude/skills/ # 平台技能目录(Comet + OpenSpec + Superpowers)
│ ├── comet/SKILL.md
│ │ └── scripts/
│ │ ├── comet-guard.sh # 阶段转换守护(--apply 自动更新状态)
│ │ ├── comet-handoff.sh # 设计交接(OpenSpec → Superpowers 上下文追踪)
│ │ ├── comet-archive.sh # 一键归档自动化
│ │ ├── comet-yaml-validate.sh # 模式校验器
│ │ └── comet-state.sh # 统一状态管理(init/set/get/check/scale)
│ ├── comet-*/SKILL.md
│ ├── openspec-*/SKILL.md
│ └── brainstorming/SKILL.md
├── openspec/ # OpenSpec — WHAT
│ ├── config.yaml
│ └── changes/
│ └── /
│ ├── .openspec.yaml # OpenSpec 状态
│ ├── .comet.yaml # Comet 工作流状态(解耦)
│ ├── proposal.md
│ ├── design.md
│ ├── specs//spec.md
│ └── tasks.md
└── docs/superpowers/ # Superpowers — HOW
├── specs/ # 设计文档
└── plans/ # 实现计划
```
## 开发
贡献流程、提交规范、PR 流程,以及新增平台或 Skill 的说明见 [CONTRIBUTING.md](CONTRIBUTING.md)。
详见 [CHANGELOG.md](CHANGELOG.md) 了解版本历史与更新。
## 路线图
在 [Comet Roadmap](https://github.com/orgs/rpamis/projects/1) 查看开发进展与即将推出的功能。
## Star历史
[](https://star-history.com/#rpamis/comet&Date)
## License
[MIT](LICENSE.md)
## 友情链接
[LINUX DO - 新的理想型社区](https://linux.do/)