cc-devflow 1.0.1

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 (277) hide show
  1. package/.claude/CLAUDE.md +83 -0
  2. package/.claude/agents/architecture-designer.md +443 -0
  3. package/.claude/agents/bug-analyzer.md +382 -0
  4. package/.claude/agents/checklist-agent.md +175 -0
  5. package/.claude/agents/clarify-analyst.md +50 -0
  6. package/.claude/agents/code-reviewer.md +71 -0
  7. package/.claude/agents/codex-analyzer.md +39 -0
  8. package/.claude/agents/compatibility-checker.md +580 -0
  9. package/.claude/agents/consistency-checker.md +532 -0
  10. package/.claude/agents/impact-analyzer.md +441 -0
  11. package/.claude/agents/planner.md +230 -0
  12. package/.claude/agents/prd-writer.md +320 -0
  13. package/.claude/agents/project-guidelines-generator.md +1329 -0
  14. package/.claude/agents/qa-tester.md +313 -0
  15. package/.claude/agents/release-manager.md +295 -0
  16. package/.claude/agents/security-reviewer.md +314 -0
  17. package/.claude/agents/style-guide-generator.md +458 -0
  18. package/.claude/agents/tech-architect.md +516 -0
  19. package/.claude/agents/ui-designer.md +485 -0
  20. package/.claude/commands/code-review-high.md +58 -0
  21. package/.claude/commands/core-architecture.md +429 -0
  22. package/.claude/commands/core-guidelines.md +486 -0
  23. package/.claude/commands/core-roadmap.md +439 -0
  24. package/.claude/commands/core-style.md +293 -0
  25. package/.claude/commands/flow-archive.md +245 -0
  26. package/.claude/commands/flow-checklist.md +260 -0
  27. package/.claude/commands/flow-clarify.md +136 -0
  28. package/.claude/commands/flow-constitution.md +82 -0
  29. package/.claude/commands/flow-dev.md +134 -0
  30. package/.claude/commands/flow-epic.md +150 -0
  31. package/.claude/commands/flow-fix.md +104 -0
  32. package/.claude/commands/flow-ideate.md +214 -0
  33. package/.claude/commands/flow-init.md +313 -0
  34. package/.claude/commands/flow-new.md +394 -0
  35. package/.claude/commands/flow-prd.md +131 -0
  36. package/.claude/commands/flow-qa.md +93 -0
  37. package/.claude/commands/flow-release.md +92 -0
  38. package/.claude/commands/flow-restart.md +98 -0
  39. package/.claude/commands/flow-status.md +64 -0
  40. package/.claude/commands/flow-tech.md +142 -0
  41. package/.claude/commands/flow-ui.md +189 -0
  42. package/.claude/commands/flow-update.md +111 -0
  43. package/.claude/commands/flow-upgrade.md +115 -0
  44. package/.claude/commands/flow-verify.md +96 -0
  45. package/.claude/commands/problem-analyzer.md +60 -0
  46. package/.claude/config/quality-rules.yml +161 -0
  47. package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +426 -0
  48. package/.claude/docs/design/consistency-conflict-detection-algorithms.md +658 -0
  49. package/.claude/docs/design/intent-driven-input-design.md +380 -0
  50. package/.claude/docs/design/prd-version-management-design.md +437 -0
  51. package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +117 -0
  52. package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +151 -0
  53. package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +188 -0
  54. package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +338 -0
  55. package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +633 -0
  56. package/.claude/docs/templates/BACKLOG_TEMPLATE.md +261 -0
  57. package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +52 -0
  58. package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +206 -0
  59. package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +71 -0
  60. package/.claude/docs/templates/EPIC_TEMPLATE.md +805 -0
  61. package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +213 -0
  62. package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +57 -0
  63. package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +148 -0
  64. package/.claude/docs/templates/PRD_TEMPLATE.md +562 -0
  65. package/.claude/docs/templates/RESEARCH_TEMPLATE.md +276 -0
  66. package/.claude/docs/templates/REVIEW-HIGH.md +57 -0
  67. package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +198 -0
  68. package/.claude/docs/templates/ROADMAP_TEMPLATE.md +310 -0
  69. package/.claude/docs/templates/STYLE_TEMPLATE.md +1266 -0
  70. package/.claude/docs/templates/TASKS_TEMPLATE.md +523 -0
  71. package/.claude/docs/templates/TECH_DESIGN_TEMPLATE.md +1019 -0
  72. package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +1436 -0
  73. package/.claude/guides/agent-guides/agent-coordination-guide.md +459 -0
  74. package/.claude/guides/project-guidelines-system.md +463 -0
  75. package/.claude/guides/technical-guides/datetime-handling-guide.md +563 -0
  76. package/.claude/guides/technical-guides/git-github-guide.md +642 -0
  77. package/.claude/guides/technical-guides/test-execution-guide.md +618 -0
  78. package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +217 -0
  79. package/.claude/guides/workflow-guides/flow-orchestrator.md +282 -0
  80. package/.claude/hooks/checklist-gate.js +397 -0
  81. package/.claude/hooks/error-handling-reminder.sh +12 -0
  82. package/.claude/hooks/error-handling-reminder.ts +459 -0
  83. package/.claude/hooks/post-tool-use-tracker.sh +280 -0
  84. package/.claude/hooks/pre-tool-use-guardrail.sh +36 -0
  85. package/.claude/hooks/pre-tool-use-guardrail.ts +342 -0
  86. package/.claude/hooks/skill-activation-prompt.sh +36 -0
  87. package/.claude/hooks/skill-activation-prompt.ts +214 -0
  88. package/.claude/hooks/state/skills-used-test-guard.json +3 -0
  89. package/.claude/rules/devflow-conventions.md +305 -0
  90. package/.claude/rules/project-constitution.md +748 -0
  91. package/.claude/schemas/constitution.schema.json +43 -0
  92. package/.claude/scripts/analyze-upgrade-impact.sh +200 -0
  93. package/.claude/scripts/archive-requirement.sh +351 -0
  94. package/.claude/scripts/calculate-checklist-completion.sh +243 -0
  95. package/.claude/scripts/calculate-quarter.sh +206 -0
  96. package/.claude/scripts/check-dependencies.sh +409 -0
  97. package/.claude/scripts/check-prerequisites.sh +232 -0
  98. package/.claude/scripts/check-task-status.sh +264 -0
  99. package/.claude/scripts/checklist-errors.sh +131 -0
  100. package/.claude/scripts/common.sh +570 -0
  101. package/.claude/scripts/consolidate-research.sh +182 -0
  102. package/.claude/scripts/create-requirement.sh +426 -0
  103. package/.claude/scripts/export-contracts.sh +117 -0
  104. package/.claude/scripts/extract-data-model.sh +78 -0
  105. package/.claude/scripts/generate-clarification-questions.sh +377 -0
  106. package/.claude/scripts/generate-clarification-report.sh +463 -0
  107. package/.claude/scripts/generate-quickstart.sh +146 -0
  108. package/.claude/scripts/generate-research-tasks.sh +157 -0
  109. package/.claude/scripts/generate-status-report.sh +523 -0
  110. package/.claude/scripts/generate-tech-analysis.sh +46 -0
  111. package/.claude/scripts/locate-requirement-in-roadmap.sh +233 -0
  112. package/.claude/scripts/manage-constitution.sh +602 -0
  113. package/.claude/scripts/mark-task-complete.sh +198 -0
  114. package/.claude/scripts/populate-research-tasks.sh +259 -0
  115. package/.claude/scripts/recover-workflow.sh +460 -0
  116. package/.claude/scripts/run-clarify-scan.sh +601 -0
  117. package/.claude/scripts/run-high-review.sh +62 -0
  118. package/.claude/scripts/run-problem-analysis.sh +68 -0
  119. package/.claude/scripts/setup-epic.sh +173 -0
  120. package/.claude/scripts/sync-roadmap-progress.sh +300 -0
  121. package/.claude/scripts/sync-task-marks.sh +199 -0
  122. package/.claude/scripts/test-clarify-scan.sh +515 -0
  123. package/.claude/scripts/update-agent-context.sh +806 -0
  124. package/.claude/scripts/validate-constitution.sh +567 -0
  125. package/.claude/scripts/validate-hooks.sh +487 -0
  126. package/.claude/scripts/validate-research.sh +332 -0
  127. package/.claude/scripts/validate-scope-boundary.sh +493 -0
  128. package/.claude/scripts/verify-setup.sh +37 -0
  129. package/.claude/settings.json +76 -0
  130. package/.claude/skills/_reference-implementations/README.md +96 -0
  131. package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +302 -0
  132. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +451 -0
  133. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +307 -0
  134. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +638 -0
  135. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +275 -0
  136. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +224 -0
  137. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +213 -0
  138. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +756 -0
  139. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +336 -0
  140. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +789 -0
  141. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +235 -0
  142. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +754 -0
  143. package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +399 -0
  144. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +331 -0
  145. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +872 -0
  146. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +502 -0
  147. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +767 -0
  148. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +502 -0
  149. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +501 -0
  150. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +406 -0
  151. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +364 -0
  152. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +428 -0
  153. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +418 -0
  154. package/.claude/skills/cc-devflow-orchestrator/SKILL.md +229 -0
  155. package/.claude/skills/constitution-guardian/SKILL.md +306 -0
  156. package/.claude/skills/devflow-constitution-quick-ref/SKILL.md +374 -0
  157. package/.claude/skills/devflow-file-standards/SKILL.md +353 -0
  158. package/.claude/skills/devflow-tdd-enforcer/SKILL.md +192 -0
  159. package/.claude/skills/skill-developer/ADVANCED.md +197 -0
  160. package/.claude/skills/skill-developer/HOOK_MECHANISMS.md +306 -0
  161. package/.claude/skills/skill-developer/PATTERNS_LIBRARY.md +152 -0
  162. package/.claude/skills/skill-developer/SKILL.md +426 -0
  163. package/.claude/skills/skill-developer/SKILL_RULES_REFERENCE.md +315 -0
  164. package/.claude/skills/skill-developer/TRIGGER_TYPES.md +305 -0
  165. package/.claude/skills/skill-developer/TROUBLESHOOTING.md +514 -0
  166. package/.claude/skills/skill-rules.json +213 -0
  167. package/.claude/tests/README.md +300 -0
  168. package/.claude/tests/TODO.md +69 -0
  169. package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
  170. package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
  171. package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
  172. package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
  173. package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
  174. package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
  175. package/.claude/tests/constitution/run_all_constitution_tests.sh +111 -0
  176. package/.claude/tests/constitution/test_agent_assignment.sh +207 -0
  177. package/.claude/tests/constitution/test_article_coverage.sh +201 -0
  178. package/.claude/tests/constitution/test_template_completeness.sh +150 -0
  179. package/.claude/tests/constitution/test_version_consistency.sh +120 -0
  180. package/.claude/tests/fixtures/spec_delta_full.md +16 -0
  181. package/.claude/tests/fixtures/tasks_progress_sample.md +5 -0
  182. package/.claude/tests/run-all-tests.sh +229 -0
  183. package/.claude/tests/scripts/run.sh +30 -0
  184. package/.claude/tests/scripts/test-framework.sh +128 -0
  185. package/.claude/tests/scripts/test_check_prerequisites.sh +511 -0
  186. package/.claude/tests/scripts/test_check_prerequisites.sh.bak +504 -0
  187. package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +505 -0
  188. package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +506 -0
  189. package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +507 -0
  190. package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +508 -0
  191. package/.claude/tests/scripts/test_check_task_status.sh +499 -0
  192. package/.claude/tests/scripts/test_common.sh +244 -0
  193. package/.claude/tests/scripts/test_generate_status_report.sh +71 -0
  194. package/.claude/tests/scripts/test_mark_task_complete.sh +441 -0
  195. package/.claude/tests/scripts/test_mark_task_complete.sh.backup +410 -0
  196. package/.claude/tests/scripts/test_recover_workflow.sh +304 -0
  197. package/.claude/tests/scripts/test_setup_epic.sh +437 -0
  198. package/.claude/tests/scripts/test_sync_task_marks.sh +196 -0
  199. package/.claude/tests/scripts/test_validate_constitution.sh +74 -0
  200. package/.claude/tests/scripts/test_validate_research.sh +462 -0
  201. package/.claude/tests/slugify.bats +82 -0
  202. package/.claude/tests/test-framework.sh +732 -0
  203. package/.claude/tests/test_analyze_upgrade_impact.py +34 -0
  204. package/.claude/tests/test_consolidate_research.py +48 -0
  205. package/.claude/tests/test_export_contracts.py +43 -0
  206. package/.claude/tests/test_extract_data_model.py +33 -0
  207. package/.claude/tests/test_generate_quickstart.py +50 -0
  208. package/.claude/tests/test_generate_research_tasks.py +52 -0
  209. package/.claude/tsc-cache/6e64f818-6398-49ca-8623-581a9af85c44/edited-files.log +1 -0
  210. package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/affected-repos.txt +1 -0
  211. package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/edited-files.log +1 -0
  212. package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/affected-repos.txt +1 -0
  213. package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/edited-files.log +1 -0
  214. package/CHANGELOG.md +507 -0
  215. package/LICENSE +21 -0
  216. package/README.md +534 -0
  217. package/README.zh-CN.md +530 -0
  218. package/bin/adapt.js +240 -0
  219. package/bin/cc-devflow-cli.js +185 -0
  220. package/bin/cc-devflow.js +78 -0
  221. package/config/adapters.yml +5 -0
  222. package/config/schema/adapters.schema.json +44 -0
  223. package/docs/CLAUDE.md +26 -0
  224. package/docs/commands/README.md +61 -0
  225. package/docs/commands/README.zh-CN.md +55 -0
  226. package/docs/commands/core-roadmap.md +106 -0
  227. package/docs/commands/core-roadmap.zh-CN.md +102 -0
  228. package/docs/commands/core-style.md +405 -0
  229. package/docs/commands/core-style.zh-CN.md +405 -0
  230. package/docs/commands/flow-init.md +134 -0
  231. package/docs/commands/flow-init.zh-CN.md +163 -0
  232. package/docs/commands/flow-new.md +274 -0
  233. package/docs/commands/flow-new.zh-CN.md +270 -0
  234. package/docs/guides/getting-started.md +204 -0
  235. package/docs/guides/getting-started.zh-CN.md +152 -0
  236. package/lib/adapters/adapter-interface.js +57 -0
  237. package/lib/adapters/claude-adapter.js +74 -0
  238. package/lib/adapters/codex-adapter.js +40 -0
  239. package/lib/adapters/config-validator.js +68 -0
  240. package/lib/adapters/logger.js +42 -0
  241. package/lib/adapters/registry.js +153 -0
  242. package/lib/compiler/CLAUDE.md +92 -0
  243. package/lib/compiler/__tests__/drift.test.js +215 -0
  244. package/lib/compiler/__tests__/errors.test.js +184 -0
  245. package/lib/compiler/__tests__/incremental.test.js +174 -0
  246. package/lib/compiler/__tests__/integration.test.js +174 -0
  247. package/lib/compiler/__tests__/manifest.test.js +233 -0
  248. package/lib/compiler/__tests__/parser.test.js +456 -0
  249. package/lib/compiler/__tests__/schemas.test.js +301 -0
  250. package/lib/compiler/__tests__/skills-registry.test.js +125 -0
  251. package/lib/compiler/__tests__/transformer.test.js +286 -0
  252. package/lib/compiler/emitters/antigravity-emitter.js +171 -0
  253. package/lib/compiler/emitters/base-emitter.js +73 -0
  254. package/lib/compiler/emitters/codex-emitter.js +52 -0
  255. package/lib/compiler/emitters/cursor-emitter.js +31 -0
  256. package/lib/compiler/emitters/index.js +50 -0
  257. package/lib/compiler/emitters/qwen-emitter.js +39 -0
  258. package/lib/compiler/errors.js +119 -0
  259. package/lib/compiler/index.js +256 -0
  260. package/lib/compiler/manifest.js +242 -0
  261. package/lib/compiler/parser.js +258 -0
  262. package/lib/compiler/platforms.js +113 -0
  263. package/lib/compiler/resource-copier.js +320 -0
  264. package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +191 -0
  265. package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +109 -0
  266. package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +123 -0
  267. package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +123 -0
  268. package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +253 -0
  269. package/lib/compiler/rules-emitters/base-rules-emitter.js +83 -0
  270. package/lib/compiler/rules-emitters/codex-rules-emitter.js +116 -0
  271. package/lib/compiler/rules-emitters/cursor-rules-emitter.js +98 -0
  272. package/lib/compiler/rules-emitters/index.js +71 -0
  273. package/lib/compiler/rules-emitters/qwen-rules-emitter.js +70 -0
  274. package/lib/compiler/schemas.js +144 -0
  275. package/lib/compiler/skills-registry.js +225 -0
  276. package/lib/compiler/transformer.js +236 -0
  277. package/package.json +50 -0
@@ -0,0 +1,642 @@
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 操作规范是确保代码质量和团队协作效率的基础。