cc-devflow 4.3.0 → 4.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (579) hide show
  1. package/.claude/skills/cc-act/CHANGELOG.md +70 -0
  2. package/.claude/skills/cc-act/PLAYBOOK.md +212 -0
  3. package/.claude/skills/cc-act/SKILL.md +330 -0
  4. package/.claude/skills/cc-act/assets/PR_BRIEF_TEMPLATE.md +68 -0
  5. package/.claude/skills/cc-act/assets/RELEASE_NOTE_TEMPLATE.md +29 -0
  6. package/.claude/skills/cc-act/references/closure-contract.md +49 -0
  7. package/.claude/skills/cc-act/references/git-commit-guidelines.md +83 -0
  8. package/.claude/skills/cc-act/scripts/archive-requirement.sh +49 -0
  9. package/.claude/skills/cc-act/scripts/cc-act-common.sh +245 -0
  10. package/.claude/skills/cc-act/scripts/detect-ship-target.sh +82 -0
  11. package/.claude/skills/cc-act/scripts/generate-status-report.sh +83 -0
  12. package/.claude/skills/cc-act/scripts/render-pr-brief.sh +200 -0
  13. package/.claude/skills/cc-act/scripts/sync-act-docs.sh +328 -0
  14. package/.claude/skills/cc-act/scripts/verify-act-gate.sh +63 -0
  15. package/.claude/skills/cc-check/CHANGELOG.md +78 -0
  16. package/.claude/skills/cc-check/PLAYBOOK.md +153 -0
  17. package/.claude/skills/cc-check/SKILL.md +353 -0
  18. package/.claude/skills/cc-check/assets/REPORT_CARD_TEMPLATE.json +53 -0
  19. package/.claude/skills/cc-check/references/gate-contract.md +29 -0
  20. package/.claude/skills/cc-check/references/review-contract.md +45 -0
  21. package/.claude/skills/cc-check/scripts/render-report-card.js +229 -0
  22. package/.claude/skills/cc-check/scripts/run-quality-gates.sh +86 -0
  23. package/.claude/skills/cc-check/scripts/verify-gate.sh +57 -0
  24. package/.claude/skills/cc-do/CHANGELOG.md +54 -0
  25. package/.claude/skills/cc-do/PLAYBOOK.md +119 -0
  26. package/.claude/skills/cc-do/SKILL.md +224 -0
  27. package/.claude/skills/cc-do/references/execution-recovery.md +86 -0
  28. package/.claude/skills/cc-do/references/parallel-dispatch.md +80 -0
  29. package/.claude/skills/cc-do/scripts/build-task-context.sh +184 -0
  30. package/.claude/skills/cc-do/scripts/cc-do-common.sh +79 -0
  31. package/.claude/skills/cc-do/scripts/check-task-status.sh +92 -0
  32. package/.claude/skills/cc-do/scripts/detect-file-conflicts.sh +87 -0
  33. package/.claude/skills/cc-do/scripts/mark-task-complete.sh +119 -0
  34. package/.claude/skills/cc-do/scripts/record-review-decision.sh +89 -0
  35. package/.claude/skills/cc-do/scripts/recover-workflow.sh +84 -0
  36. package/.claude/skills/cc-do/scripts/run-problem-analysis.sh +70 -0
  37. package/.claude/skills/cc-do/scripts/select-ready-tasks.sh +135 -0
  38. package/.claude/skills/cc-do/scripts/verify-task-gates.sh +94 -0
  39. package/.claude/skills/cc-do/scripts/write-task-checkpoint.sh +102 -0
  40. package/.claude/skills/cc-investigate/CHANGELOG.md +31 -0
  41. package/.claude/skills/cc-investigate/PLAYBOOK.md +49 -0
  42. package/.claude/skills/cc-investigate/SKILL.md +229 -0
  43. package/.claude/skills/cc-investigate/assets/ANALYSIS_TEMPLATE.md +56 -0
  44. package/.claude/skills/cc-investigate/assets/TASKS_TEMPLATE.md +53 -0
  45. package/.claude/skills/cc-investigate/assets/TASK_MANIFEST_TEMPLATE.json +106 -0
  46. package/.claude/skills/cc-investigate/references/investigation-contract.md +28 -0
  47. package/.claude/skills/cc-investigate/scripts/bootstrap-analysis.sh +38 -0
  48. package/.claude/skills/cc-plan/CHANGELOG.md +104 -0
  49. package/.claude/skills/cc-plan/PLAYBOOK.md +106 -0
  50. package/.claude/skills/cc-plan/SKILL.md +333 -0
  51. package/.claude/skills/cc-plan/assets/DESIGN_TEMPLATE.md +156 -0
  52. package/.claude/skills/cc-plan/assets/TASKS_TEMPLATE.md +99 -0
  53. package/.claude/skills/cc-plan/assets/TASK_MANIFEST_TEMPLATE.json +111 -0
  54. package/.claude/skills/cc-plan/assets/TINY_DESIGN_TEMPLATE.md +80 -0
  55. package/.claude/skills/cc-plan/references/planning-contract.md +82 -0
  56. package/.claude/skills/cc-plan/scripts/bump-skill-version.sh +103 -0
  57. package/.claude/skills/cc-plan/scripts/parse-task-dependencies.js +75 -0
  58. package/.claude/skills/cc-plan/scripts/validate-scope.sh +78 -0
  59. package/.claude/skills/cc-roadmap/CHANGELOG.md +119 -0
  60. package/.claude/skills/cc-roadmap/PLAYBOOK.md +136 -0
  61. package/.claude/skills/cc-roadmap/SKILL.md +267 -0
  62. package/.claude/skills/cc-roadmap/assets/BACKLOG_TEMPLATE.md +46 -0
  63. package/.claude/skills/cc-roadmap/assets/ROADMAP_TEMPLATE.md +154 -0
  64. package/.claude/skills/cc-roadmap/assets/TRACKING_TEMPLATE.json +51 -0
  65. package/.claude/skills/cc-roadmap/references/roadmap-dialogue.md +37 -0
  66. package/.claude/skills/cc-roadmap/scripts/bump-skill-version.sh +103 -0
  67. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/markdown.js +604 -0
  68. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/query.js +63 -0
  69. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/schema.js +245 -0
  70. package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/store.js +139 -0
  71. package/.claude/skills/cc-roadmap/scripts/locate-roadmap-item.sh +109 -0
  72. package/.claude/skills/cc-roadmap/scripts/roadmap-tracking.js +153 -0
  73. package/.claude/skills/cc-roadmap/scripts/sync-roadmap-progress.sh +100 -0
  74. package/.claude/skills/cc-simplify/CHANGELOG.md +10 -0
  75. package/.claude/skills/cc-simplify/SKILL.md +55 -0
  76. package/.claude/skills/cc-spec-init/CHANGELOG.md +12 -0
  77. package/.claude/skills/cc-spec-init/PLAYBOOK.md +55 -0
  78. package/.claude/skills/cc-spec-init/SKILL.md +135 -0
  79. package/.claude/skills/cc-spec-init/assets/CAPABILITY_TEMPLATE.md +64 -0
  80. package/.claude/skills/cc-spec-init/assets/CHANGE_META_TEMPLATE.json +28 -0
  81. package/.claude/skills/cc-spec-init/assets/INDEX_TEMPLATE.md +35 -0
  82. package/.claude/skills/cc-spec-init/references/spec-contract.md +22 -0
  83. package/.claude/skills/cc-spec-init/scripts/bootstrap-specs.sh +31 -0
  84. package/.claude/skills/cc-spec-init/scripts/validate-spec-links.sh +45 -0
  85. package/CHANGELOG.md +80 -4
  86. package/README.md +148 -741
  87. package/README.zh-CN.md +146 -740
  88. package/bin/adapt.js +2 -6
  89. package/bin/cc-devflow-cli.js +287 -166
  90. package/config/distributable-skills.json +24 -0
  91. package/config/schema/cc-devflow-config.schema.json +45 -0
  92. package/config/user-config.template.yml +16 -0
  93. package/docs/CLAUDE.md +10 -6
  94. package/docs/commands/README.md +19 -46
  95. package/docs/commands/README.zh-CN.md +25 -48
  96. package/docs/examples/BY-ARTIFACT.md +7 -0
  97. package/docs/examples/README.md +38 -0
  98. package/docs/examples/START-HERE.md +149 -0
  99. package/docs/examples/example-bindings.json +38 -0
  100. package/docs/examples/full-design-blocked/BACKLOG.md +45 -0
  101. package/docs/examples/full-design-blocked/README.md +55 -0
  102. package/docs/examples/full-design-blocked/ROADMAP.md +53 -0
  103. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/design.md +154 -0
  104. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/task-manifest.json +146 -0
  105. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/tasks.md +78 -0
  106. package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/review/report-card.json +52 -0
  107. package/docs/examples/full-design-blocked/roadmap-tracking.json +50 -0
  108. package/docs/examples/local-handoff/BACKLOG.md +45 -0
  109. package/docs/examples/local-handoff/README.md +56 -0
  110. package/docs/examples/local-handoff/ROADMAP.md +45 -0
  111. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/handoff/resume-index.md +39 -0
  112. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/handoff/status.md +29 -0
  113. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/design.md +71 -0
  114. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/task-manifest.json +98 -0
  115. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/tasks.md +59 -0
  116. package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/review/report-card.json +44 -0
  117. package/docs/examples/local-handoff/roadmap-tracking.json +48 -0
  118. package/docs/examples/pdca-loop/BACKLOG.md +46 -0
  119. package/docs/examples/pdca-loop/README.md +58 -0
  120. package/docs/examples/pdca-loop/ROADMAP.md +133 -0
  121. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/handoff/pr-brief.md +72 -0
  122. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/handoff/status.md +29 -0
  123. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/design.md +72 -0
  124. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/task-manifest.json +201 -0
  125. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/tasks.md +73 -0
  126. package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/review/report-card.json +44 -0
  127. package/docs/examples/pdca-loop/roadmap-tracking.json +114 -0
  128. package/docs/examples/scripts/check-example-bindings.sh +116 -0
  129. package/docs/guides/getting-started.md +94 -129
  130. package/docs/guides/getting-started.zh-CN.md +103 -84
  131. package/docs/skill-runtime-migration.md +46 -0
  132. package/docs/v4.3.0-migration-guide.md +60 -225
  133. package/lib/compiler/CLAUDE.md +55 -84
  134. package/lib/compiler/__tests__/drift.test.js +1 -1
  135. package/lib/compiler/__tests__/errors.test.js +0 -1
  136. package/lib/compiler/__tests__/integration.test.js +49 -3
  137. package/lib/compiler/__tests__/manifest.test.js +0 -156
  138. package/lib/compiler/__tests__/parser.test.js +33 -104
  139. package/lib/compiler/__tests__/schemas.test.js +30 -34
  140. package/lib/compiler/__tests__/skills-registry.test.js +114 -0
  141. package/lib/compiler/__tests__/transformer.test.js +5 -9
  142. package/lib/compiler/emitters/antigravity-emitter.js +5 -213
  143. package/lib/compiler/emitters/base-emitter.js +3 -298
  144. package/lib/compiler/emitters/codex-emitter.js +4 -202
  145. package/lib/compiler/emitters/cursor-emitter.js +3 -287
  146. package/lib/compiler/emitters/qwen-emitter.js +4 -176
  147. package/lib/compiler/index.js +65 -345
  148. package/lib/compiler/manifest.js +6 -68
  149. package/lib/compiler/parser.js +31 -63
  150. package/lib/compiler/platforms.js +32 -277
  151. package/lib/compiler/resource-copier.js +176 -6
  152. package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +3 -3
  153. package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +14 -4
  154. package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +16 -7
  155. package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +10 -15
  156. package/lib/compiler/rules-emitters/base-rules-emitter.js +5 -5
  157. package/lib/compiler/rules-emitters/cursor-rules-emitter.js +7 -12
  158. package/lib/compiler/rules-emitters/index.js +6 -3
  159. package/lib/compiler/rules-emitters/qwen-rules-emitter.js +7 -7
  160. package/lib/compiler/schemas.js +8 -4
  161. package/lib/compiler/skills-registry.js +213 -15
  162. package/lib/compiler/transformer.js +1 -1
  163. package/lib/skill-runtime/CLAUDE.md +19 -0
  164. package/lib/skill-runtime/__tests__/autopilot.test.js +210 -0
  165. package/lib/skill-runtime/__tests__/cli-bootstrap.integration.test.js +291 -0
  166. package/lib/skill-runtime/__tests__/config.test.js +161 -0
  167. package/lib/skill-runtime/__tests__/delegation.test.js +97 -0
  168. package/lib/skill-runtime/__tests__/dispatch.test.js +267 -0
  169. package/lib/skill-runtime/__tests__/intent.test.js +219 -0
  170. package/lib/skill-runtime/__tests__/lifecycle.test.js +169 -0
  171. package/lib/skill-runtime/__tests__/paths.test.js +42 -0
  172. package/lib/skill-runtime/__tests__/planner.tdd.test.js +250 -0
  173. package/lib/skill-runtime/__tests__/prepare-pr.test.js +139 -0
  174. package/lib/skill-runtime/__tests__/query.test.js +284 -0
  175. package/lib/skill-runtime/__tests__/runtime.integration.test.js +281 -0
  176. package/lib/skill-runtime/__tests__/schemas.test.js +207 -0
  177. package/lib/skill-runtime/__tests__/team-state.test.js +51 -0
  178. package/lib/skill-runtime/__tests__/worker-run.test.js +253 -0
  179. package/lib/skill-runtime/__tests__/worker.test.js +56 -0
  180. package/lib/skill-runtime/artifacts.js +93 -0
  181. package/lib/skill-runtime/config.js +379 -0
  182. package/lib/skill-runtime/delegation.js +533 -0
  183. package/lib/skill-runtime/index.js +36 -0
  184. package/lib/skill-runtime/intent.js +333 -0
  185. package/lib/skill-runtime/lifecycle.js +294 -0
  186. package/lib/skill-runtime/operations/CLAUDE.md +19 -0
  187. package/lib/skill-runtime/operations/approve.js +66 -0
  188. package/lib/skill-runtime/operations/autopilot-core.js +337 -0
  189. package/lib/skill-runtime/operations/autopilot-execution.js +307 -0
  190. package/lib/skill-runtime/operations/autopilot-shared.js +48 -0
  191. package/lib/skill-runtime/operations/autopilot.js +163 -0
  192. package/lib/skill-runtime/operations/dispatch.js +454 -0
  193. package/lib/skill-runtime/operations/init.js +64 -0
  194. package/lib/{harness → skill-runtime}/operations/janitor.js +9 -6
  195. package/lib/skill-runtime/operations/plan.js +59 -0
  196. package/lib/skill-runtime/operations/prepare-pr.js +25 -0
  197. package/lib/skill-runtime/operations/release.js +96 -0
  198. package/lib/skill-runtime/operations/resume.js +143 -0
  199. package/lib/skill-runtime/operations/snapshot.js +45 -0
  200. package/lib/skill-runtime/operations/verify.js +170 -0
  201. package/lib/skill-runtime/operations/worker-run.js +529 -0
  202. package/lib/skill-runtime/operations/worker.js +33 -0
  203. package/lib/skill-runtime/paths.js +213 -0
  204. package/lib/skill-runtime/planner.js +519 -0
  205. package/lib/skill-runtime/query.js +157 -0
  206. package/lib/skill-runtime/review.js +557 -0
  207. package/lib/skill-runtime/schemas.js +400 -0
  208. package/lib/{harness → skill-runtime}/store.js +45 -30
  209. package/lib/skill-runtime/team-state.js +122 -0
  210. package/package.json +13 -11
  211. package/.claude/CLAUDE.md +0 -125
  212. package/.claude/agents/architecture-designer.md +0 -443
  213. package/.claude/agents/bug-analyzer.md +0 -381
  214. package/.claude/agents/checklist-agent.md +0 -175
  215. package/.claude/agents/clarify-analyst.md +0 -50
  216. package/.claude/agents/code-quality-reviewer.md +0 -205
  217. package/.claude/agents/code-reviewer.md +0 -71
  218. package/.claude/agents/codex-analyzer.md +0 -39
  219. package/.claude/agents/compatibility-checker.md +0 -579
  220. package/.claude/agents/consistency-checker.md +0 -532
  221. package/.claude/agents/dev-implementer.md +0 -195
  222. package/.claude/agents/flow-researcher.md +0 -132
  223. package/.claude/agents/impact-analyzer.md +0 -440
  224. package/.claude/agents/planner.md +0 -230
  225. package/.claude/agents/prd-writer.md +0 -320
  226. package/.claude/agents/project-guidelines-generator.md +0 -1329
  227. package/.claude/agents/qa-tester.md +0 -313
  228. package/.claude/agents/release-manager.md +0 -295
  229. package/.claude/agents/security-reviewer.md +0 -314
  230. package/.claude/agents/spec-reviewer.md +0 -221
  231. package/.claude/agents/style-guide-generator.md +0 -458
  232. package/.claude/agents/tech-architect.md +0 -516
  233. package/.claude/agents/ui-designer.md +0 -485
  234. package/.claude/commands/core/architecture.md +0 -459
  235. package/.claude/commands/core/guidelines.md +0 -511
  236. package/.claude/commands/core/roadmap.md +0 -468
  237. package/.claude/commands/core/style.md +0 -83
  238. package/.claude/commands/flow/CLAUDE.md +0 -24
  239. package/.claude/commands/flow/archive.md +0 -280
  240. package/.claude/commands/flow/constitution.md +0 -82
  241. package/.claude/commands/flow/context.md +0 -150
  242. package/.claude/commands/flow/delta.md +0 -245
  243. package/.claude/commands/flow/dev.md +0 -40
  244. package/.claude/commands/flow/fix.md +0 -217
  245. package/.claude/commands/flow/ideate.md +0 -214
  246. package/.claude/commands/flow/init.md +0 -38
  247. package/.claude/commands/flow/release.md +0 -36
  248. package/.claude/commands/flow/restart.md +0 -97
  249. package/.claude/commands/flow/spec.md +0 -36
  250. package/.claude/commands/flow/status.md +0 -64
  251. package/.claude/commands/flow/update.md +0 -111
  252. package/.claude/commands/flow/upgrade.md +0 -115
  253. package/.claude/commands/flow/verify.md +0 -37
  254. package/.claude/commands/flow/workspace.md +0 -155
  255. package/.claude/commands/util/cancel-ralph.md +0 -60
  256. package/.claude/commands/util/code-review.md +0 -58
  257. package/.claude/commands/util/git-commit.md +0 -422
  258. package/.claude/commands/util/problem-analyzer.md +0 -60
  259. package/.claude/config/quality-gates.yml +0 -305
  260. package/.claude/config/quality-rules.yml +0 -161
  261. package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +0 -426
  262. package/.claude/docs/design/consistency-conflict-detection-algorithms.md +0 -658
  263. package/.claude/docs/design/intent-driven-input-design.md +0 -380
  264. package/.claude/docs/design/prd-version-management-design.md +0 -437
  265. package/.claude/docs/examples/design-inspiration-pool.md +0 -59
  266. package/.claude/docs/examples/ui-prototype-constitution-checklist.md +0 -75
  267. package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +0 -117
  268. package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +0 -99
  269. package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +0 -188
  270. package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +0 -338
  271. package/.claude/docs/guides/TEAM_MODE_GUIDE.md +0 -312
  272. package/.claude/docs/implementation-summary-v7.md +0 -449
  273. package/.claude/docs/spec-format-guide.md +0 -349
  274. package/.claude/docs/state-consolidation-design.md +0 -323
  275. package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +0 -332
  276. package/.claude/docs/templates/ATTEMPT_TEMPLATE.md +0 -156
  277. package/.claude/docs/templates/BACKLOG_TEMPLATE.md +0 -261
  278. package/.claude/docs/templates/BRAINSTORM_TEMPLATE.md +0 -148
  279. package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +0 -52
  280. package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +0 -206
  281. package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +0 -71
  282. package/.claude/docs/templates/DELTA_SPEC_TEMPLATE.md +0 -91
  283. package/.claude/docs/templates/DESIGN_DECISIONS_TEMPLATE.md +0 -151
  284. package/.claude/docs/templates/DESIGN_TEMPLATE.md +0 -157
  285. package/.claude/docs/templates/ERROR_LOG_TEMPLATE.md +0 -80
  286. package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +0 -198
  287. package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +0 -57
  288. package/.claude/docs/templates/JOURNAL_TEMPLATE.md +0 -75
  289. package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +0 -76
  290. package/.claude/docs/templates/PROPOSAL_TEMPLATE.md +0 -91
  291. package/.claude/docs/templates/RESEARCH_TEMPLATE.md +0 -276
  292. package/.claude/docs/templates/REVIEW-HIGH.md +0 -57
  293. package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +0 -198
  294. package/.claude/docs/templates/ROADMAP_TEMPLATE.md +0 -310
  295. package/.claude/docs/templates/SPEC_TEMPLATE_DELTA.md +0 -139
  296. package/.claude/docs/templates/SPEC_TEMPLATE_PROJECT.md +0 -93
  297. package/.claude/docs/templates/STYLE_TEMPLATE.md +0 -479
  298. package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +0 -373
  299. package/.claude/docs/templates/_shared/CLAUDE.md +0 -36
  300. package/.claude/docs/templates/_shared/CONSTITUTION_CHECK.md +0 -125
  301. package/.claude/docs/templates/_shared/VALIDATION_CHECKLIST.md +0 -187
  302. package/.claude/docs/templates/_shared/YAML_FRONTMATTER.md +0 -164
  303. package/.claude/docs/templates/context/dev.jsonl.template +0 -6
  304. package/.claude/docs/templates/context/epic.jsonl.template +0 -5
  305. package/.claude/docs/templates/context/prd.jsonl.template +0 -4
  306. package/.claude/docs/templates/context/research.jsonl.template +0 -4
  307. package/.claude/docs/templates/context/review.jsonl.template +0 -5
  308. package/.claude/docs/templates/context/tech.jsonl.template +0 -5
  309. package/.claude/guides/agent-guides/agent-coordination-guide.md +0 -459
  310. package/.claude/guides/project-guidelines-system.md +0 -463
  311. package/.claude/guides/technical-guides/datetime-handling-guide.md +0 -563
  312. package/.claude/guides/technical-guides/git-github-guide.md +0 -642
  313. package/.claude/guides/technical-guides/test-execution-guide.md +0 -618
  314. package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +0 -217
  315. package/.claude/guides/workflow-guides/flow-orchestrator.md +0 -48
  316. package/.claude/hooks/CLAUDE.md +0 -342
  317. package/.claude/hooks/checklist-gate.js +0 -397
  318. package/.claude/hooks/error-handling-reminder.sh +0 -12
  319. package/.claude/hooks/error-handling-reminder.ts +0 -459
  320. package/.claude/hooks/hooks.json +0 -15
  321. package/.claude/hooks/inject-agent-context.ts +0 -480
  322. package/.claude/hooks/inject-skill-context.ts +0 -359
  323. package/.claude/hooks/post-tool-use-tracker.sh +0 -280
  324. package/.claude/hooks/pre-tool-use-guardrail.sh +0 -36
  325. package/.claude/hooks/pre-tool-use-guardrail.ts +0 -342
  326. package/.claude/hooks/ralph-loop.ts +0 -931
  327. package/.claude/hooks/ralph-stop-hook.sh +0 -190
  328. package/.claude/hooks/skill-activation-prompt.sh +0 -36
  329. package/.claude/hooks/skill-activation-prompt.ts +0 -214
  330. package/.claude/hooks/state/skills-used-test-guard.json +0 -3
  331. package/.claude/hooks/task-completed-hook.ts +0 -593
  332. package/.claude/hooks/teammate-idle-hook.ts +0 -690
  333. package/.claude/hooks/types/team-types.d.ts +0 -238
  334. package/.claude/rules/devflow-conventions.md +0 -286
  335. package/.claude/rules/project-constitution.md +0 -1002
  336. package/.claude/rules/rationalization-library.md +0 -282
  337. package/.claude/schemas/constitution.schema.json +0 -43
  338. package/.claude/scripts/.claude/commands/flow/export-openspec.md +0 -221
  339. package/.claude/scripts/.claude/commands/flow/import-openspec.md +0 -171
  340. package/.claude/scripts/CLAUDE.md +0 -76
  341. package/.claude/scripts/__tests__/openspec.test.js +0 -212
  342. package/.claude/scripts/analyze-upgrade-impact.sh +0 -200
  343. package/.claude/scripts/archive-requirement.sh +0 -394
  344. package/.claude/scripts/calculate-checklist-completion.sh +0 -243
  345. package/.claude/scripts/calculate-quarter.sh +0 -206
  346. package/.claude/scripts/check-dependencies.sh +0 -409
  347. package/.claude/scripts/check-prerequisites.sh +0 -232
  348. package/.claude/scripts/check-task-status.sh +0 -288
  349. package/.claude/scripts/checklist-errors.sh +0 -131
  350. package/.claude/scripts/common.sh +0 -1102
  351. package/.claude/scripts/consolidate-research.sh +0 -182
  352. package/.claude/scripts/create-requirement.sh +0 -451
  353. package/.claude/scripts/delta-parser.ts +0 -637
  354. package/.claude/scripts/detect-file-conflicts.sh +0 -151
  355. package/.claude/scripts/export-contracts.sh +0 -117
  356. package/.claude/scripts/export-openspec.js +0 -222
  357. package/.claude/scripts/extract-data-model.sh +0 -78
  358. package/.claude/scripts/flow-context-add.sh +0 -134
  359. package/.claude/scripts/flow-context-init.sh +0 -133
  360. package/.claude/scripts/flow-context-validate.sh +0 -144
  361. package/.claude/scripts/flow-delta-apply.sh +0 -297
  362. package/.claude/scripts/flow-delta-archive.sh +0 -71
  363. package/.claude/scripts/flow-delta-create.sh +0 -202
  364. package/.claude/scripts/flow-delta-list.sh +0 -142
  365. package/.claude/scripts/flow-delta-status.sh +0 -235
  366. package/.claude/scripts/flow-quality-full.sh +0 -215
  367. package/.claude/scripts/flow-quality-quick.sh +0 -119
  368. package/.claude/scripts/flow-workspace-init.sh +0 -117
  369. package/.claude/scripts/flow-workspace-record.sh +0 -164
  370. package/.claude/scripts/generate-clarification-questions.sh +0 -377
  371. package/.claude/scripts/generate-clarification-report.sh +0 -463
  372. package/.claude/scripts/generate-quickstart.sh +0 -146
  373. package/.claude/scripts/generate-research-tasks.sh +0 -157
  374. package/.claude/scripts/generate-status-report.sh +0 -523
  375. package/.claude/scripts/generate-tech-analysis.sh +0 -46
  376. package/.claude/scripts/get-workflow-status.sh +0 -415
  377. package/.claude/scripts/import-openspec.js +0 -272
  378. package/.claude/scripts/locate-requirement-in-roadmap.sh +0 -233
  379. package/.claude/scripts/manage-constitution.sh +0 -602
  380. package/.claude/scripts/mark-task-complete.sh +0 -198
  381. package/.claude/scripts/parse-task-dependencies.js +0 -334
  382. package/.claude/scripts/populate-research-tasks.sh +0 -284
  383. package/.claude/scripts/record-quality-error.sh +0 -165
  384. package/.claude/scripts/recover-workflow.sh +0 -463
  385. package/.claude/scripts/run-clarify-scan.sh +0 -601
  386. package/.claude/scripts/run-high-review.sh +0 -62
  387. package/.claude/scripts/run-problem-analysis.sh +0 -68
  388. package/.claude/scripts/run-quality-gates.sh +0 -242
  389. package/.claude/scripts/setup-epic.sh +0 -173
  390. package/.claude/scripts/setup-ralph-loop.sh +0 -155
  391. package/.claude/scripts/sync-roadmap-progress.sh +0 -300
  392. package/.claude/scripts/sync-task-marks.sh +0 -199
  393. package/.claude/scripts/team-dev-init.sh +0 -319
  394. package/.claude/scripts/team-state-recovery.sh +0 -229
  395. package/.claude/scripts/test-clarify-scan.sh +0 -515
  396. package/.claude/scripts/update-agent-context.sh +0 -806
  397. package/.claude/scripts/validate-constitution.sh +0 -567
  398. package/.claude/scripts/validate-hooks.sh +0 -487
  399. package/.claude/scripts/validate-research.sh +0 -332
  400. package/.claude/scripts/validate-scope-boundary.sh +0 -493
  401. package/.claude/scripts/validate-scope.sh +0 -200
  402. package/.claude/scripts/verify-gate.sh +0 -269
  403. package/.claude/scripts/verify-setup.sh +0 -37
  404. package/.claude/scripts/workflow-status.ts +0 -433
  405. package/.claude/settings.json +0 -95
  406. package/.claude/skills/_reference-implementations/README.md +0 -96
  407. package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +0 -302
  408. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +0 -451
  409. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +0 -307
  410. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +0 -638
  411. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +0 -275
  412. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +0 -224
  413. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +0 -213
  414. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +0 -756
  415. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +0 -336
  416. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +0 -789
  417. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +0 -235
  418. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +0 -754
  419. package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +0 -399
  420. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +0 -331
  421. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +0 -872
  422. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +0 -502
  423. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +0 -767
  424. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +0 -502
  425. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +0 -501
  426. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +0 -406
  427. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +0 -364
  428. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +0 -428
  429. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +0 -418
  430. package/.claude/skills/attention-refresh/SKILL.md +0 -170
  431. package/.claude/skills/brainstorming/SKILL.md +0 -161
  432. package/.claude/skills/cc-devflow-orchestrator/SKILL.md +0 -169
  433. package/.claude/skills/constitution-guardian/SKILL.md +0 -306
  434. package/.claude/skills/constitution-quick-ref/SKILL.md +0 -374
  435. package/.claude/skills/debugging/SKILL.md +0 -221
  436. package/.claude/skills/file-standards/SKILL.md +0 -353
  437. package/.claude/skills/finishing-branch/SKILL.md +0 -189
  438. package/.claude/skills/flow-dev/CLAUDE.md +0 -16
  439. package/.claude/skills/flow-dev/SKILL.md +0 -94
  440. package/.claude/skills/flow-dev/assets/IMPLEMENTATION_PLAN_TEMPLATE.md +0 -71
  441. package/.claude/skills/flow-dev/context.jsonl +0 -4
  442. package/.claude/skills/flow-dev/dev-implementer.jsonl +0 -8
  443. package/.claude/skills/flow-dev/scripts/entry-gate.sh +0 -116
  444. package/.claude/skills/flow-dev/scripts/exit-gate.sh +0 -101
  445. package/.claude/skills/flow-dev/scripts/task-orchestrator.sh +0 -106
  446. package/.claude/skills/flow-fix/SKILL.md +0 -105
  447. package/.claude/skills/flow-fix/context.jsonl +0 -6
  448. package/.claude/skills/flow-fix/references/bug-analyzer.md +0 -381
  449. package/.claude/skills/flow-init/SKILL.md +0 -105
  450. package/.claude/skills/flow-init/assets/BRAINSTORM_TEMPLATE.md +0 -148
  451. package/.claude/skills/flow-init/assets/INIT_FLOW_TEMPLATE.md +0 -198
  452. package/.claude/skills/flow-init/assets/RESEARCH_TEMPLATE.md +0 -276
  453. package/.claude/skills/flow-init/context.jsonl +0 -5
  454. package/.claude/skills/flow-init/references/flow-researcher.md +0 -132
  455. package/.claude/skills/flow-init/scripts/check-prerequisites.sh +0 -240
  456. package/.claude/skills/flow-init/scripts/consolidate-research.sh +0 -182
  457. package/.claude/skills/flow-init/scripts/create-requirement.sh +0 -404
  458. package/.claude/skills/flow-init/scripts/generate-research-tasks.sh +0 -157
  459. package/.claude/skills/flow-init/scripts/populate-research-tasks.sh +0 -284
  460. package/.claude/skills/flow-init/scripts/validate-research.sh +0 -340
  461. package/.claude/skills/flow-quality/SKILL.md +0 -98
  462. package/.claude/skills/flow-quality/context.jsonl +0 -6
  463. package/.claude/skills/flow-quality/references/code-quality-reviewer.md +0 -205
  464. package/.claude/skills/flow-quality/references/qa-tester.md +0 -313
  465. package/.claude/skills/flow-quality/references/security-reviewer.md +0 -314
  466. package/.claude/skills/flow-quality/references/spec-reviewer.md +0 -221
  467. package/.claude/skills/flow-release/SKILL.md +0 -60
  468. package/.claude/skills/flow-release/context.jsonl +0 -5
  469. package/.claude/skills/flow-release/references/release-manager.md +0 -295
  470. package/.claude/skills/flow-spec/CLAUDE.md +0 -17
  471. package/.claude/skills/flow-spec/SKILL.md +0 -102
  472. package/.claude/skills/flow-spec/context.jsonl +0 -5
  473. package/.claude/skills/flow-spec/scripts/entry-gate.sh +0 -194
  474. package/.claude/skills/flow-spec/scripts/exit-gate.sh +0 -244
  475. package/.claude/skills/flow-spec/scripts/parallel-orchestrator.sh +0 -205
  476. package/.claude/skills/flow-spec/scripts/team-communication.sh +0 -353
  477. package/.claude/skills/flow-spec/scripts/team-init.sh +0 -195
  478. package/.claude/skills/flow-spec/scripts/test-team-mode.sh +0 -496
  479. package/.claude/skills/flow-spec/team-config.json +0 -165
  480. package/.claude/skills/flow-verify/CLAUDE.md +0 -10
  481. package/.claude/skills/flow-verify/SKILL.md +0 -53
  482. package/.claude/skills/flow-verify/context.jsonl +0 -5
  483. package/.claude/skills/fractal-docs/SKILL.md +0 -45
  484. package/.claude/skills/journey-checker/SKILL.md +0 -199
  485. package/.claude/skills/journey-checker/pressure-scenarios.md +0 -164
  486. package/.claude/skills/receiving-review/SKILL.md +0 -153
  487. package/.claude/skills/skill-creator/LICENSE.txt +0 -202
  488. package/.claude/skills/skill-creator/SKILL.md +0 -356
  489. package/.claude/skills/skill-creator/references/output-patterns.md +0 -82
  490. package/.claude/skills/skill-creator/references/workflows.md +0 -28
  491. package/.claude/skills/skill-creator/scripts/init_skill.py +0 -303
  492. package/.claude/skills/skill-creator/scripts/package_skill.py +0 -110
  493. package/.claude/skills/skill-creator/scripts/quick_validate.py +0 -95
  494. package/.claude/skills/skill-rules.json +0 -359
  495. package/.claude/skills/tdd/SKILL.md +0 -218
  496. package/.claude/skills/tdd-enforcer/SKILL.md +0 -192
  497. package/.claude/skills/utility/npm-release/CLAUDE.md +0 -55
  498. package/.claude/skills/utility/npm-release/SKILL.md +0 -379
  499. package/.claude/skills/utility/npm-release/references/version-decision-guide.md +0 -134
  500. package/.claude/skills/utility/npm-release/scripts/atomic-version-bump.sh +0 -95
  501. package/.claude/skills/utility/npm-release/scripts/validate-version-sync.sh +0 -82
  502. package/.claude/skills/utility/npm-release/scripts/version-decision-tree.sh +0 -44
  503. package/.claude/skills/verification/SKILL.md +0 -158
  504. package/.claude/skills/workflow.yaml +0 -219
  505. package/.claude/tests/README.md +0 -300
  506. package/.claude/tests/TODO.md +0 -69
  507. package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
  508. package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
  509. package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
  510. package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
  511. package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
  512. package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
  513. package/.claude/tests/constitution/run_all_constitution_tests.sh +0 -111
  514. package/.claude/tests/constitution/test_agent_assignment.sh +0 -207
  515. package/.claude/tests/constitution/test_article_coverage.sh +0 -201
  516. package/.claude/tests/constitution/test_template_completeness.sh +0 -150
  517. package/.claude/tests/constitution/test_version_consistency.sh +0 -120
  518. package/.claude/tests/fixtures/spec_delta_full.md +0 -16
  519. package/.claude/tests/fixtures/tasks_progress_sample.md +0 -5
  520. package/.claude/tests/run-all-tests.sh +0 -229
  521. package/.claude/tests/scripts/run.sh +0 -30
  522. package/.claude/tests/scripts/test-framework.sh +0 -128
  523. package/.claude/tests/scripts/test_check_prerequisites.sh +0 -511
  524. package/.claude/tests/scripts/test_check_prerequisites.sh.bak +0 -504
  525. package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +0 -505
  526. package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +0 -506
  527. package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +0 -507
  528. package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +0 -508
  529. package/.claude/tests/scripts/test_check_task_status.sh +0 -499
  530. package/.claude/tests/scripts/test_common.sh +0 -244
  531. package/.claude/tests/scripts/test_generate_status_report.sh +0 -71
  532. package/.claude/tests/scripts/test_mark_task_complete.sh +0 -441
  533. package/.claude/tests/scripts/test_mark_task_complete.sh.backup +0 -410
  534. package/.claude/tests/scripts/test_recover_workflow.sh +0 -304
  535. package/.claude/tests/scripts/test_setup_epic.sh +0 -437
  536. package/.claude/tests/scripts/test_sync_task_marks.sh +0 -196
  537. package/.claude/tests/scripts/test_validate_constitution.sh +0 -74
  538. package/.claude/tests/scripts/test_validate_research.sh +0 -462
  539. package/.claude/tests/slugify.bats +0 -82
  540. package/.claude/tests/test-framework.sh +0 -732
  541. package/.claude/tests/test_analyze_upgrade_impact.py +0 -34
  542. package/.claude/tests/test_consolidate_research.py +0 -48
  543. package/.claude/tests/test_export_contracts.py +0 -43
  544. package/.claude/tests/test_extract_data_model.py +0 -33
  545. package/.claude/tests/test_generate_quickstart.py +0 -50
  546. package/.claude/tests/test_generate_research_tasks.py +0 -52
  547. package/.claude/tsc-cache/70d2fc6d-2936-429b-b529-429f1aae8c88/affected-repos.txt +0 -1
  548. package/.claude/tsc-cache/70d2fc6d-2936-429b-b529-429f1aae8c88/edited-files.log +0 -2
  549. package/bin/harness.js +0 -22
  550. package/docs/commands/core-roadmap.md +0 -106
  551. package/docs/commands/core-roadmap.zh-CN.md +0 -102
  552. package/docs/commands/core-style.md +0 -53
  553. package/docs/commands/core-style.zh-CN.md +0 -53
  554. package/docs/commands/flow-init.md +0 -140
  555. package/docs/commands/flow-init.zh-CN.md +0 -169
  556. package/docs/commands/flow-new.md +0 -39
  557. package/docs/commands/flow-new.zh-CN.md +0 -39
  558. package/lib/compiler/__tests__/compile-regression.test.js +0 -103
  559. package/lib/compiler/__tests__/multi-module-emitters.test.js +0 -534
  560. package/lib/compiler/__tests__/resource-copier.test.js +0 -26
  561. package/lib/compiler/__tests__/skill-discovery.test.js +0 -72
  562. package/lib/compiler/context-expander.js +0 -179
  563. package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +0 -109
  564. package/lib/compiler/rules-emitters/codex-rules-emitter.js +0 -116
  565. package/lib/compiler/skill-discovery.js +0 -68
  566. package/lib/harness/CLAUDE.md +0 -22
  567. package/lib/harness/__tests__/planner.tdd.test.js +0 -125
  568. package/lib/harness/cli.js +0 -208
  569. package/lib/harness/index.js +0 -18
  570. package/lib/harness/operations/dispatch.js +0 -298
  571. package/lib/harness/operations/init.js +0 -48
  572. package/lib/harness/operations/pack.js +0 -100
  573. package/lib/harness/operations/plan.js +0 -83
  574. package/lib/harness/operations/release.js +0 -170
  575. package/lib/harness/operations/resume.js +0 -44
  576. package/lib/harness/operations/verify.js +0 -177
  577. package/lib/harness/planner.js +0 -272
  578. package/lib/harness/query.js +0 -126
  579. package/lib/harness/schemas.js +0 -129
@@ -1,642 +0,0 @@
1
- # Git & GitHub 操作指南
2
-
3
- > **类型**: 技术操作指南 (Technical Guide)
4
- > **适用**: 所有Git分支管理和GitHub平台交互操作
5
- > **前置规则**: 遵循 Constitution 和 Core Patterns
6
-
7
- ---
8
-
9
- ## 📋 指南概述
10
-
11
- 本指南整合了Git分支管理和GitHub平台交互的所有操作规范,确保代码管理的一致性、可追踪性和安全性。
12
-
13
- ---
14
-
15
- ## 🌿 Git 分支管理
16
-
17
- ### 分支命名规范
18
-
19
- ```bash
20
- # 需求功能分支
21
- feature/REQ-{id}-{title-slug}
22
- 例如: feature/REQ-123-支持用户下单
23
-
24
- # Epic 分支 (大型功能)
25
- epic/REQ-{id}-{epic-name-slug}
26
- 例如: epic/REQ-100-用户管理系统
27
-
28
- # 修复分支
29
- fix/REQ-{id}-{issue-slug}
30
- 例如: fix/REQ-125-修复支付bug
31
-
32
- # 热修复分支
33
- hotfix/REQ-{id}-{critical-issue-slug}
34
- 例如: hotfix/REQ-130-修复安全漏洞
35
- ```
36
-
37
- **分支类型定义**:
38
- - `feature/`: 新功能开发
39
- - `epic/`: 大型功能集合
40
- - `fix/`: Bug 修复
41
- - `hotfix/`: 生产环境紧急修复
42
- - `docs/`: 文档更新
43
- - `refactor/`: 代码重构
44
-
45
- ### 分支创建前检查
46
-
47
- ```bash
48
- # 分支创建前的必要检查
49
- pre_branch_check() {
50
- local req_id="$1"
51
- local title="$2"
52
- local branch_type="${3:-feature}"
53
-
54
- echo "🔍 执行分支创建前检查..."
55
-
56
- # 1. 检查工作目录状态
57
- if ! git diff --quiet; then
58
- echo "❌ 工作目录有未提交的更改,请先提交或暂存"
59
- git status --porcelain
60
- return 1
61
- fi
62
-
63
- # 2. 检查是否在主分支
64
- local current_branch=$(git rev-parse --abbrev-ref HEAD)
65
- if [ "$current_branch" != "main" ] && [ "$current_branch" != "master" ]; then
66
- echo "❌ 当前不在主分支,当前分支: $current_branch"
67
- return 1
68
- fi
69
-
70
- # 3. 检查分支是否已存在
71
- local branch_name="${branch_type}/REQ-${req_id}-$(echo "$title" | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9\-]//g')"
72
- if git show-ref --verify --quiet "refs/heads/$branch_name"; then
73
- echo "❌ 分支已存在: $branch_name"
74
- return 1
75
- fi
76
-
77
- # 4. 更新主分支
78
- git fetch origin
79
- git merge --ff-only origin/main
80
-
81
- echo "✅ 分支创建前检查通过"
82
- return 0
83
- }
84
- ```
85
-
86
- ### 标准分支创建流程
87
-
88
- ```bash
89
- # 创建需求分支
90
- create_requirement_branch() {
91
- local req_id="$1"
92
- local title="$2"
93
- local branch_type="${3:-feature}"
94
-
95
- # 执行前置检查
96
- if ! pre_branch_check "$req_id" "$title" "$branch_type"; then
97
- return 1
98
- fi
99
-
100
- # 生成分支名
101
- local branch_name="${branch_type}/REQ-${req_id}-$(echo "$title" | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9\-]//g')"
102
-
103
- echo "🌿 创建分支: $branch_name"
104
-
105
- # 创建并切换到新分支
106
- if git checkout -b "$branch_name"; then
107
- echo "✅ 分支创建成功"
108
-
109
- # 创建分支信息文件
110
- create_branch_info "$req_id" "$title" "$branch_name"
111
-
112
- # 推送到远程
113
- git push -u origin "$branch_name"
114
- else
115
- echo "❌ 分支创建失败"
116
- return 1
117
- fi
118
- }
119
- ```
120
-
121
- ### 提交规范
122
-
123
- **提交消息格式**:
124
- ```bash
125
- {type}({req_id}): {description} - {details}
126
-
127
- # 例如:
128
- feat(REQ-123): 实现用户登录接口 - 添加JWT认证和密码加密
129
- fix(REQ-124): 修复订单状态更新bug - 处理并发更新冲突
130
- docs(REQ-125): 更新API文档 - 添加新增接口的说明
131
- ```
132
-
133
- **提交类型**:
134
- - `feat`: 新功能
135
- - `fix`: Bug修复
136
- - `docs`: 文档更新
137
- - `style`: 代码格式调整
138
- - `refactor`: 代码重构
139
- - `test`: 测试相关
140
- - `chore`: 构建、配置等杂务
141
-
142
- **标准提交函数**:
143
- ```bash
144
- commit_with_standard() {
145
- local req_id="$1"
146
- local type="$2"
147
- local description="$3"
148
- local details="$4"
149
-
150
- # 验证提交类型
151
- case "$type" in
152
- feat|fix|docs|style|refactor|test|chore)
153
- ;;
154
- *)
155
- echo "❌ 无效的提交类型: $type"
156
- return 1
157
- ;;
158
- esac
159
-
160
- # 构建提交消息
161
- local commit_msg="${type}(${req_id}): ${description}"
162
- if [ -n "$details" ]; then
163
- commit_msg="${commit_msg} - ${details}"
164
- fi
165
-
166
- # 执行提交
167
- git commit -m "$commit_msg"
168
- }
169
- ```
170
-
171
- ### 分支同步
172
-
173
- ```bash
174
- # 与主分支同步
175
- sync_with_main() {
176
- echo "🔄 与主分支同步..."
177
-
178
- # 获取最新的主分支
179
- git fetch origin main
180
-
181
- # 尝试合并
182
- if git merge origin/main; then
183
- echo "✅ 同步完成,无冲突"
184
- return 0
185
- else
186
- echo "⚠️ 检测到冲突,需要手动解决"
187
- echo "冲突文件:"
188
- git diff --name-only --diff-filter=U
189
- return 1
190
- fi
191
- }
192
- ```
193
-
194
- ### 分支清理
195
-
196
- ```bash
197
- # 清理已合并的分支
198
- cleanup_merged_branches() {
199
- echo "🧹 清理已合并的分支..."
200
-
201
- # 获取已合并的分支列表
202
- local merged_branches=$(git branch --merged main | grep -E "feature/|fix/|epic/")
203
-
204
- if [ -z "$merged_branches" ]; then
205
- echo "ℹ️ 没有需要清理的分支"
206
- return 0
207
- fi
208
-
209
- # 删除本地和远程分支
210
- echo "$merged_branches" | while read -r branch; do
211
- if [ -n "$branch" ]; then
212
- git branch -d "$branch"
213
- git push origin --delete "$branch" 2>/dev/null || true
214
- fi
215
- done
216
-
217
- echo "✅ 分支清理完成"
218
- }
219
- ```
220
-
221
- ---
222
-
223
- ## 🔗 GitHub 平台交互
224
-
225
- ### 核心原则
226
-
227
- #### 1. 仓库保护检查 (强制执行)
228
-
229
- **在执行任何创建/修改 Issues 或 PRs 的操作之前,必须进行仓库保护检查**
230
-
231
- ```bash
232
- # 仓库保护检查 - 防止在模板仓库上进行写操作
233
- check_repository_protection() {
234
- local operation="$1"
235
-
236
- echo "🔍 检查仓库保护状态..."
237
-
238
- # 获取远程仓库信息
239
- local remote_url=$(git config --get remote.origin.url)
240
- if [ -z "$remote_url" ]; then
241
- echo "❌ 未找到远程仓库配置"
242
- return 1
243
- fi
244
-
245
- # 提取仓库名称
246
- local repo_name=$(echo "$remote_url" | sed -E 's|.*[:/]([^/]+/[^/]+)\.git.*|\1|')
247
-
248
- # 检查是否为模板仓库
249
- if gh api "repos/$repo_name" --jq '.is_template' 2>/dev/null | grep -q "true"; then
250
- echo "❌ 禁止在模板仓库上执行写操作: $operation"
251
- echo " 仓库: $repo_name"
252
- echo ""
253
- echo "💡 解决方案:"
254
- echo " 1. 从模板创建新仓库"
255
- echo " 2. 在新仓库中执行操作"
256
- return 1
257
- fi
258
-
259
- # 检查是否为只读仓库
260
- if gh api "repos/$repo_name" --jq '.permissions.push' 2>/dev/null | grep -q "false"; then
261
- echo "❌ 没有推送权限: $repo_name"
262
- return 1
263
- fi
264
-
265
- echo "✅ 仓库保护检查通过"
266
- return 0
267
- }
268
-
269
- # 必须在所有写操作前调用
270
- require_repo_protection_check() {
271
- local operation="$1"
272
-
273
- case "$operation" in
274
- "gh issue create"|"gh issue edit"|"gh pr create"|"gh pr merge")
275
- if ! check_repository_protection "$operation"; then
276
- exit 1
277
- fi
278
- ;;
279
- esac
280
- }
281
- ```
282
-
283
- #### 2. 身份验证处理
284
-
285
- **不预先检查认证状态,直接运行命令并处理失败**
286
-
287
- ```bash
288
- # GitHub 认证检查和处理
289
- handle_github_auth() {
290
- local command="$1"
291
- shift
292
- local args=("$@")
293
-
294
- # 直接执行命令
295
- if gh "$command" "${args[@]}"; then
296
- return 0
297
- else
298
- local exit_code=$?
299
-
300
- # 分析失败原因
301
- case $exit_code in
302
- 4)
303
- echo "❌ GitHub 操作失败: 认证问题"
304
- echo "💡 解决方案: 运行 'gh auth login' 重新认证"
305
- ;;
306
- 1)
307
- echo "❌ GitHub 操作失败: 一般错误"
308
- echo "💡 检查命令参数和网络连接"
309
- ;;
310
- esac
311
-
312
- return $exit_code
313
- fi
314
- }
315
- ```
316
-
317
- ### 标准 Issue 操作
318
-
319
- #### 获取 Issue 详情
320
- ```bash
321
- get_issue_details() {
322
- local issue_number="$1"
323
-
324
- if [ -z "$issue_number" ]; then
325
- echo "❌ Issue 编号不能为空"
326
- return 1
327
- fi
328
-
329
- handle_github_auth "issue" "view" "$issue_number" "--json" "title,body,state,labels"
330
- }
331
- ```
332
-
333
- #### 创建 Issue
334
- ```bash
335
- create_issue() {
336
- local title="$1"
337
- local body="$2"
338
- local labels="$3"
339
-
340
- require_repo_protection_check "gh issue create"
341
-
342
- if [ -z "$title" ]; then
343
- echo "❌ Issue 标题不能为空"
344
- return 1
345
- fi
346
-
347
- local cmd_args=("--title" "$title")
348
- [ -n "$body" ] && cmd_args+=("--body" "$body")
349
- [ -n "$labels" ] && cmd_args+=("--label" "$labels")
350
-
351
- handle_github_auth "issue" "create" "${cmd_args[@]}"
352
- }
353
- ```
354
-
355
- #### 更新 Issue
356
- ```bash
357
- update_issue() {
358
- local issue_number="$1"
359
- local field="$2"
360
- local value="$3"
361
-
362
- require_repo_protection_check "gh issue edit"
363
-
364
- case "$field" in
365
- "title")
366
- handle_github_auth "issue" "edit" "$issue_number" "--title" "$value"
367
- ;;
368
- "state")
369
- if [ "$value" = "closed" ]; then
370
- handle_github_auth "issue" "close" "$issue_number"
371
- else
372
- handle_github_auth "issue" "reopen" "$issue_number"
373
- fi
374
- ;;
375
- "labels")
376
- handle_github_auth "issue" "edit" "$issue_number" "--add-label" "$value"
377
- ;;
378
- esac
379
- }
380
- ```
381
-
382
- ### 标准 Pull Request 操作
383
-
384
- #### 创建 Pull Request
385
- ```bash
386
- create_pull_request() {
387
- local title="$1"
388
- local body="$2"
389
- local base_branch="${3:-main}"
390
-
391
- require_repo_protection_check "gh pr create"
392
-
393
- # 获取当前分支
394
- local head_branch=$(git rev-parse --abbrev-ref HEAD)
395
-
396
- # 确保当前分支已推送
397
- if ! git ls-remote --heads origin "$head_branch" | grep -q "$head_branch"; then
398
- git push -u origin "$head_branch"
399
- fi
400
-
401
- local cmd_args=("--title" "$title" "--base" "$base_branch" "--head" "$head_branch")
402
- [ -n "$body" ] && cmd_args+=("--body" "$body")
403
-
404
- handle_github_auth "pr" "create" "${cmd_args[@]}"
405
- }
406
- ```
407
-
408
- #### 合并前检查
409
- ```bash
410
- pre_merge_check() {
411
- local req_id="$1"
412
-
413
- echo "🔍 执行合并前检查..."
414
-
415
- # 1. 检查未提交的更改
416
- if ! git diff --quiet; then
417
- echo "❌ 存在未提交的更改"
418
- return 1
419
- fi
420
-
421
- # 2. 运行质量闸
422
- if ! .claude/hooks/pre-push-guard.sh; then
423
- echo "❌ 质量闸检查失败"
424
- return 1
425
- fi
426
-
427
- # 3. 检查必要文件
428
- local required_files=(
429
- "devflow/requirements/${req_id}/PRD.md"
430
- "devflow/requirements/${req_id}/EPIC.md"
431
- )
432
-
433
- for file in "${required_files[@]}"; do
434
- if [ ! -f "$file" ]; then
435
- echo "❌ 缺少必要文件: $file"
436
- return 1
437
- fi
438
- done
439
-
440
- echo "✅ 合并前检查通过"
441
- return 0
442
- }
443
- ```
444
-
445
- #### 合并 Pull Request
446
- ```bash
447
- merge_pull_request() {
448
- local pr_number="$1"
449
- local merge_method="${2:-squash}" # squash, merge, rebase
450
-
451
- require_repo_protection_check "gh pr merge"
452
-
453
- # 检查 PR 状态
454
- local pr_state=$(gh pr view "$pr_number" --json state --jq .state)
455
- if [ "$pr_state" != "OPEN" ]; then
456
- echo "❌ PR 状态不是 OPEN: $pr_state"
457
- return 1
458
- fi
459
-
460
- # 检查 CI 状态
461
- local ci_status=$(gh pr checks "$pr_number" --json state --jq '.[].state')
462
- if echo "$ci_status" | grep -q "FAILURE"; then
463
- echo "❌ CI 检查失败,无法合并"
464
- return 1
465
- fi
466
-
467
- # 执行合并
468
- case "$merge_method" in
469
- "squash") handle_github_auth "pr" "merge" "$pr_number" "--squash" "--delete-branch" ;;
470
- "merge") handle_github_auth "pr" "merge" "$pr_number" "--merge" "--delete-branch" ;;
471
- "rebase") handle_github_auth "pr" "merge" "$pr_number" "--rebase" "--delete-branch" ;;
472
- esac
473
- }
474
- ```
475
-
476
- ### 批量操作
477
-
478
- ```bash
479
- # 批量处理 Issues
480
- batch_process_issues() {
481
- local action="$1"
482
- local filter="$2"
483
- shift 2
484
- local args=("$@")
485
-
486
- # 获取匹配的 Issues
487
- local issues=$(gh issue list --json number,title --jq '.[] | select(.title | contains("'"$filter"'")) | .number')
488
-
489
- if [ -z "$issues" ]; then
490
- echo "ℹ️ 没有找到匹配的 Issues"
491
- return 0
492
- fi
493
-
494
- # 显示列表并确认
495
- echo "找到 $(echo "$issues" | wc -l) 个匹配的 Issues"
496
- read -p "确认执行批量操作 '$action'? (y/N): " confirm
497
-
498
- if [ "$confirm" != "y" ]; then
499
- return 0
500
- fi
501
-
502
- # 执行批量操作
503
- echo "$issues" | while read -r issue_num; do
504
- case "$action" in
505
- "close") handle_github_auth "issue" "close" "$issue_num" ;;
506
- "label") handle_github_auth "issue" "edit" "$issue_num" "--add-label" "${args[0]}" ;;
507
- esac
508
- sleep 1 # 避免 API 限流
509
- done
510
-
511
- echo "✅ 批量操作完成"
512
- }
513
- ```
514
-
515
- ### 仓库健康检查
516
-
517
- ```bash
518
- check_repository_health() {
519
- echo "🏥 检查仓库健康状态..."
520
-
521
- # 获取仓库信息
522
- local repo_info=$(handle_github_auth "repo" "view" "--json" "name,defaultBranch,visibility")
523
- echo "$repo_info" | jq -r '"名称: \(.name)\n默认分支: \(.defaultBranch)\n可见性: \(.visibility)"'
524
-
525
- # 检查分支保护
526
- local default_branch=$(echo "$repo_info" | jq -r '.defaultBranch')
527
- if gh api "repos/:owner/:repo/branches/$default_branch/protection" >/dev/null 2>&1; then
528
- echo "✅ 主分支已设置保护规则"
529
- else
530
- echo "⚠️ 主分支未设置保护规则"
531
- fi
532
-
533
- # 检查工作流
534
- local workflow_count=$(find .github/workflows -name "*.yml" 2>/dev/null | wc -l)
535
- if [ "$workflow_count" -gt 0 ]; then
536
- echo "✅ 找到 $workflow_count 个工作流文件"
537
- fi
538
-
539
- echo "✅ 仓库健康检查完成"
540
- }
541
- ```
542
-
543
- ### API 优化
544
-
545
- ```bash
546
- # 使用 --json 获取结构化输出
547
- get_structured_data() {
548
- local command="$1"
549
- local fields="$2"
550
- shift 2
551
- local args=("$@")
552
-
553
- handle_github_auth "$command" "${args[@]}" "--json" "$fields"
554
- }
555
-
556
- # 检查 API 速率限制
557
- check_rate_limit() {
558
- local rate_limit_info=$(gh api rate_limit --jq '.rate')
559
- local remaining=$(echo "$rate_limit_info" | jq -r '.remaining')
560
- local limit=$(echo "$rate_limit_info" | jq -r '.limit')
561
-
562
- echo "📊 GitHub API 使用情况: $remaining/$limit"
563
-
564
- if [ "$remaining" -lt 100 ]; then
565
- echo "⚠️ API 速率限制即将达到"
566
- return 1
567
- fi
568
-
569
- return 0
570
- }
571
- ```
572
-
573
- ---
574
-
575
- ## 📊 分支状态管理
576
-
577
- ### 状态文件格式
578
- ```yaml
579
- # devflow/requirements/REQ-123/branch-info.yml
580
- branch_info:
581
- req_id: "REQ-123"
582
- title: "支持用户下单"
583
- branch_name: "feature/REQ-123-支持用户下单"
584
- created_at: "2024-01-24T10:30:00Z"
585
- base_branch: "main"
586
- status: "active" # active, merged, closed, deleted
587
- pr_url: "https://github.com/owner/repo/pull/123"
588
-
589
- commits:
590
- - hash: "abc123def"
591
- message: "feat(REQ-123): 实现用户下单接口"
592
- time: "2024-01-24T14:20:00Z"
593
- ```
594
-
595
- ---
596
-
597
- ## ⚠️ 重要注意事项
598
-
599
- ### 安全要求
600
- - **始终**在写操作前检查远程仓库来源
601
- - 使用 `--json` 获取结构化输出用于解析
602
- - 保持操作原子性 - 一个命令完成一个动作
603
- - 不要预检查速率限制
604
-
605
- ### 操作清单
606
- 在执行 GitHub 写操作前必须确认:
607
- - [ ] 已执行仓库保护检查
608
- - [ ] 确认操作权限
609
- - [ ] 验证目标分支/Issue/PR 存在
610
- - [ ] 检查 CI 状态(PR 合并时)
611
-
612
- ### 禁止操作
613
- - ❌ 在模板仓库上创建 Issues 或 PRs
614
- - ❌ 在没有推送权限的仓库上执行写操作
615
- - ❌ 自动重试失败的认证操作
616
- - ❌ 忽略 CI 失败强制合并 PR
617
-
618
- ---
619
-
620
- ## 🎯 最佳实践
621
-
622
- ### 分支生命周期管理
623
- - 及时创建功能分支
624
- - 定期同步主分支
625
- - 小而频繁的提交
626
- - 及时清理已合并分支
627
-
628
- ### 冲突预防
629
- - 每日同步主分支
630
- - 避免修改共享文件
631
- - 使用原子性提交
632
- - 及时沟通变更计划
633
-
634
- ### 提交质量
635
- - 描述性的提交消息
636
- - 逻辑相关的更改组合
637
- - 避免大型提交
638
- - 包含适当的测试
639
-
640
- ---
641
-
642
- **重要提醒**: 严格遵循 Git 和 GitHub 操作规范是确保代码质量和团队协作效率的基础。