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,157 @@
1
+ #!/usr/bin/env bash
2
+ # shellcheck disable=SC2312
3
+
4
+ set -euo pipefail
5
+
6
+ usage() {
7
+ cat <<'USAGE'
8
+ Usage: .claude/scripts/generate-research-tasks.sh <requirement-dir>
9
+
10
+ Scans the requirement directory for "NEEDS CLARIFICATION" markers and technology
11
+ choices, then writes research/tasks.json with structured tasks ready for agents.
12
+ USAGE
13
+ }
14
+
15
+ if [[ "${1:-}" == "-h" || "${1:-}" == "--help" ]]; then
16
+ usage
17
+ exit 0
18
+ fi
19
+
20
+ if [[ $# -lt 1 ]]; then
21
+ echo "Error: requirement directory is required." >&2
22
+ usage
23
+ exit 1
24
+ fi
25
+
26
+ REQ_DIR="$1"
27
+ if [[ ! -d "$REQ_DIR" ]]; then
28
+ echo "Error: requirement directory '$REQ_DIR' does not exist." >&2
29
+ exit 1
30
+ fi
31
+
32
+ python3 - "$REQ_DIR" <<'PY'
33
+ from __future__ import annotations
34
+
35
+ import json
36
+ import os
37
+ import re
38
+ import sys
39
+ from datetime import datetime, timezone
40
+ from pathlib import Path
41
+ from typing import List, Dict
42
+
43
+ req_dir = Path(sys.argv[1]).resolve()
44
+ research_dir = req_dir / "research"
45
+ research_dir.mkdir(exist_ok=True, parents=True)
46
+ tasks_path = research_dir / "tasks.json"
47
+
48
+ def to_relative(p: Path) -> str:
49
+ try:
50
+ return str(p.relative_to(req_dir))
51
+ except ValueError:
52
+ return str(p)
53
+
54
+ def detect_feature_name() -> str:
55
+ readme = req_dir / "README.md"
56
+ if readme.exists():
57
+ for line in readme.read_text(encoding="utf-8").splitlines():
58
+ line = line.strip("# ").strip()
59
+ if line:
60
+ return line
61
+ return req_dir.name
62
+
63
+ def collect_unknowns() -> List[Dict[str, str]]:
64
+ pattern = re.compile(r"NEEDS CLARIFICATION", re.IGNORECASE)
65
+ unknowns = []
66
+ for path in req_dir.rglob("*.md"):
67
+ if path.name in {"research.md", "ui_design_strategy.md"}:
68
+ continue
69
+ rel = to_relative(path)
70
+ for idx, line in enumerate(path.read_text(encoding="utf-8", errors="ignore").splitlines(), start=1):
71
+ if pattern.search(line):
72
+ topic = line.split("NEEDS CLARIFICATION", 1)[0]
73
+ topic = topic.replace("-", " ").replace("*", " ").replace("•", " ")
74
+ topic = topic.split(":")[-1].strip()
75
+ if not topic:
76
+ topic = "unspecified topic"
77
+ payload = {
78
+ "topic": re.sub(r"\s+", " ", topic).strip(),
79
+ "source": f"{rel}:{idx}",
80
+ }
81
+ if payload not in unknowns:
82
+ unknowns.append(payload)
83
+ return unknowns
84
+
85
+ def collect_technologies() -> List[Dict[str, str]]:
86
+ tech_entries = []
87
+ bold_line = re.compile(r"^\s*[-*]\s*\*\*(?P<label>[^*]+)\*\*:\s*(?P<value>.+)$")
88
+ for filename in ("plan.md", "PLAN.md", "TECH_DESIGN.md"):
89
+ file_path = req_dir / filename
90
+ if not file_path.exists():
91
+ continue
92
+ for line in file_path.read_text(encoding="utf-8", errors="ignore").splitlines():
93
+ match = bold_line.match(line)
94
+ if match:
95
+ label = match.group("label").strip()
96
+ value = match.group("value").strip()
97
+ entry = {"label": label, "value": value}
98
+ if entry not in tech_entries:
99
+ tech_entries.append(entry)
100
+ return tech_entries
101
+
102
+ feature_name = detect_feature_name()
103
+ unknowns = collect_unknowns()
104
+ technologies = collect_technologies()
105
+
106
+ tasks: List[Dict[str, object]] = []
107
+
108
+ counter = 1
109
+ def next_id() -> str:
110
+ global counter
111
+ ident = f"R{counter:03}"
112
+ counter += 1
113
+ return ident
114
+
115
+ for unknown in unknowns:
116
+ tasks.append(
117
+ {
118
+ "id": next_id(),
119
+ "type": "clarification",
120
+ "prompt": f"Research {unknown['topic']} for {feature_name}",
121
+ "source": unknown["source"],
122
+ "status": "open",
123
+ "decision": "", # 新增: 空字段,等待填充
124
+ "rationale": "", # 新增: 空字段,等待填充
125
+ "alternatives": "", # 新增: 空字段,等待填充
126
+ }
127
+ )
128
+
129
+ for tech in technologies:
130
+ label = tech["label"]
131
+ value = tech["value"]
132
+ # strip trailing notes after parentheses to keep prompt concise
133
+ prompt_value = value.split(";")[0].strip()
134
+ tasks.append(
135
+ {
136
+ "id": next_id(),
137
+ "type": "best_practices",
138
+ "prompt": f"Find best practices for {prompt_value} in the context of {feature_name}",
139
+ "source": f"Tech-Choice:{label}",
140
+ "status": "open",
141
+ "decision": "", # 新增: 空字段,等待填充
142
+ "rationale": "", # 新增: 空字段,等待填充
143
+ "alternatives": "", # 新增: 空字段,等待填充
144
+ }
145
+ )
146
+
147
+ data = {
148
+ "feature": feature_name,
149
+ "generatedAt": datetime.now(timezone.utc).isoformat(),
150
+ "requirementDir": str(req_dir),
151
+ "tasks": tasks,
152
+ }
153
+
154
+ tasks_path.write_text(json.dumps(data, indent=2, ensure_ascii=False) + "\n", encoding="utf-8")
155
+
156
+ print(f"Generated {len(tasks)} research task(s) for {feature_name} → {tasks_path}")
157
+ PY
@@ -0,0 +1,523 @@
1
+ #!/usr/bin/env bash
2
+ # generate-status-report.sh - 生成跨需求状态报告
3
+ # 基于 spec-kit 原则,提供跨需求的开发状态总览
4
+
5
+ set -euo pipefail
6
+
7
+ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
8
+ source "$SCRIPT_DIR/common.sh"
9
+
10
+ # 颜色定义
11
+ RED='\033[0;31m'
12
+ GREEN='\033[0;32m'
13
+ YELLOW='\033[0;33m'
14
+ BLUE='\033[0;34m'
15
+ CYAN='\033[0;36m'
16
+ BOLD='\033[1m'
17
+ NC='\033[0m' # No Color
18
+
19
+ # 使用说明
20
+ usage() {
21
+ cat << EOF
22
+ 用法: $0 [选项]
23
+
24
+ 生成跨需求状态报告,展示所有需求的开发进度和状态。
25
+
26
+ 选项:
27
+ -h, --help 显示此帮助信息
28
+ -o, --output FILE 输出报告到文件 (默认: 输出到标准输出)
29
+ -f, --format FORMAT 输出格式: text|markdown|json (默认: text)
30
+ -s, --status STATUS 过滤特定状态: initialized|prd|epic|dev|qa|release|all (默认: all)
31
+ -v, --verbose 详细模式,显示更多信息
32
+ --no-color 禁用颜色输出
33
+
34
+ 示例:
35
+ $0 # 生成所有需求的文本报告
36
+ $0 -o status.md -f markdown # 生成Markdown格式报告
37
+ $0 -s dev # 只显示开发中的需求
38
+ $0 -f json -o status.json # 生成JSON格式报告
39
+
40
+ EOF
41
+ exit 0
42
+ }
43
+
44
+ # 解析命令行参数
45
+ OUTPUT_FILE=""
46
+ FORMAT="text"
47
+ FILTER_STATUS="all"
48
+ VERBOSE=false
49
+ NO_COLOR=false
50
+
51
+ while [[ $# -gt 0 ]]; do
52
+ case $1 in
53
+ -h|--help)
54
+ usage
55
+ ;;
56
+ -o|--output)
57
+ OUTPUT_FILE="$2"
58
+ shift 2
59
+ ;;
60
+ -f|--format)
61
+ FORMAT="$2"
62
+ shift 2
63
+ ;;
64
+ -s|--status)
65
+ FILTER_STATUS="$2"
66
+ shift 2
67
+ ;;
68
+ -v|--verbose)
69
+ VERBOSE=true
70
+ shift
71
+ ;;
72
+ --no-color)
73
+ NO_COLOR=true
74
+ shift
75
+ ;;
76
+ *)
77
+ echo "错误: 未知参数 $1" >&2
78
+ usage
79
+ ;;
80
+ esac
81
+ done
82
+
83
+ # 如果禁用颜色,清空颜色变量
84
+ if [[ "$NO_COLOR" == "true" || -n "$OUTPUT_FILE" ]]; then
85
+ RED=''
86
+ GREEN=''
87
+ YELLOW=''
88
+ BLUE=''
89
+ CYAN=''
90
+ BOLD=''
91
+ NC=''
92
+ fi
93
+
94
+ # 验证格式
95
+ if [[ ! "$FORMAT" =~ ^(text|markdown|json)$ ]]; then
96
+ echo "错误: 无效的格式 '$FORMAT',必须是 text, markdown 或 json" >&2
97
+ exit 1
98
+ fi
99
+
100
+ # 验证状态过滤器
101
+ if [[ ! "$FILTER_STATUS" =~ ^(all|initialized|prd|epic|dev|qa|release)$ ]]; then
102
+ echo "错误: 无效的状态 '$FILTER_STATUS'" >&2
103
+ exit 1
104
+ fi
105
+
106
+ # 获取需求目录
107
+ REPO_ROOT=$(get_repo_root)
108
+ REQUIREMENTS_DIR="$REPO_ROOT/devflow/requirements"
109
+
110
+ if [[ ! -d "$REQUIREMENTS_DIR" ]]; then
111
+ echo "错误: 需求目录不存在: $REQUIREMENTS_DIR" >&2
112
+ exit 1
113
+ fi
114
+
115
+ # 阶段显示名称映射
116
+ get_phase_display_name() {
117
+ local phase="$1"
118
+ case "$phase" in
119
+ initialized) echo "初始化" ;;
120
+ planning) echo "规划中" ;;
121
+ prd_generation_in_progress) echo "PRD生成中" ;;
122
+ prd_complete) echo "PRD完成" ;;
123
+ epic_planning) echo "Epic规划" ;;
124
+ epic_complete) echo "Epic完成" ;;
125
+ development) echo "开发中" ;;
126
+ dev_complete) echo "开发完成" ;;
127
+ qa) echo "质量保证" ;;
128
+ qa_complete) echo "QA完成" ;;
129
+ release) echo "发布中" ;;
130
+ release_complete) echo "发布完成" ;;
131
+ completed) echo "已完成" ;;
132
+ *) echo "$phase" ;;
133
+ esac
134
+ }
135
+
136
+ # 阶段进度百分比
137
+ get_phase_percentage() {
138
+ local phase="$1"
139
+ case "$phase" in
140
+ initialized|planning) echo "0" ;;
141
+ prd_generation_in_progress) echo "10" ;;
142
+ prd_complete|epic_planning) echo "20" ;;
143
+ epic_complete) echo "30" ;;
144
+ development) echo "40" ;;
145
+ dev_complete) echo "70" ;;
146
+ qa) echo "80" ;;
147
+ qa_complete) echo "90" ;;
148
+ release|release_complete) echo "95" ;;
149
+ completed) echo "100" ;;
150
+ *) echo "0" ;;
151
+ esac
152
+ }
153
+
154
+ # 收集所有需求信息
155
+ collect_requirements() {
156
+ local requirements=()
157
+
158
+ for req_dir in "$REQUIREMENTS_DIR"/*; do
159
+ if [[ ! -d "$req_dir" ]]; then
160
+ continue
161
+ fi
162
+
163
+ local req_id=$(basename "$req_dir")
164
+ local status_file="$req_dir/orchestration_status.json"
165
+
166
+ if [[ ! -f "$status_file" ]]; then
167
+ continue
168
+ fi
169
+
170
+ # 读取状态文件
171
+ local status=$(jq -r '.status // "unknown"' "$status_file" 2>/dev/null || echo "unknown")
172
+ local phase=$(jq -r '.phase // "unknown"' "$status_file" 2>/dev/null || echo "unknown")
173
+ local title=$(jq -r '.title // ""' "$status_file" 2>/dev/null || echo "")
174
+ local updated_at=$(jq -r '.updatedAt // ""' "$status_file" 2>/dev/null || echo "")
175
+
176
+ # 状态过滤
177
+ if [[ "$FILTER_STATUS" != "all" ]]; then
178
+ # 简化状态匹配逻辑
179
+ local simplified_status="$phase"
180
+ case "$phase" in
181
+ initialized|planning) simplified_status="initialized" ;;
182
+ prd_*|epic_planning) simplified_status="prd" ;;
183
+ epic_complete) simplified_status="epic" ;;
184
+ development|dev_complete) simplified_status="dev" ;;
185
+ qa*) simplified_status="qa" ;;
186
+ release*|completed) simplified_status="release" ;;
187
+ esac
188
+
189
+ if [[ "$simplified_status" != "$FILTER_STATUS" ]]; then
190
+ continue
191
+ fi
192
+ fi
193
+
194
+ # 统计任务进度
195
+ local tasks_total=0
196
+ local tasks_completed=0
197
+ local tasks_file="$req_dir/TASKS.md"
198
+
199
+ if [[ -f "$tasks_file" ]]; then
200
+ # 统计任务总数 (以 ## TASK 开头的行)
201
+ tasks_total=$(grep -c "^## TASK" "$tasks_file" 2>/dev/null || echo "0")
202
+
203
+ # 统计已完成任务 (检查 .completed 标记文件)
204
+ local tasks_dir="$req_dir/tasks"
205
+ if [[ -d "$tasks_dir" ]]; then
206
+ tasks_completed=$(find "$tasks_dir" -name "*.completed" -type f 2>/dev/null | wc -l | tr -d ' ')
207
+ fi
208
+ fi
209
+
210
+ # 计算进度百分比
211
+ local progress_percent=$(get_phase_percentage "$phase")
212
+ if [[ $tasks_total -gt 0 ]]; then
213
+ # 开发阶段使用任务完成度计算更精确的百分比
214
+ if [[ "$phase" == "development" ]]; then
215
+ progress_percent=$((30 + (tasks_completed * 40 / tasks_total)))
216
+ fi
217
+ fi
218
+
219
+ # 添加到结果数组
220
+ requirements+=("$req_id|$title|$status|$phase|$updated_at|$tasks_completed|$tasks_total|$progress_percent")
221
+ done
222
+
223
+ printf '%s\n' "${requirements[@]}"
224
+ }
225
+
226
+ # 文本格式输出
227
+ output_text() {
228
+ local requirements=("$@")
229
+ local total=${#requirements[@]}
230
+
231
+ echo -e "${BOLD}${CYAN}═══════════════════════════════════════════════════════════════${NC}"
232
+ echo -e "${BOLD}${CYAN} CC-DevFlow 需求开发状态报告${NC}"
233
+ echo -e "${BOLD}${CYAN}═══════════════════════════════════════════════════════════════${NC}"
234
+ echo ""
235
+ echo -e "生成时间: $(get_beijing_time_full)"
236
+ echo -e "需求总数: ${BOLD}$total${NC}"
237
+ echo ""
238
+
239
+ if [[ $total -eq 0 ]]; then
240
+ echo -e "${YELLOW}没有找到符合条件的需求${NC}"
241
+ return
242
+ fi
243
+
244
+ # 统计各阶段需求数量
245
+ local count_init=0 count_prd=0 count_epic=0 count_dev=0 count_qa=0 count_release=0
246
+
247
+ for req_data in "${requirements[@]}"; do
248
+ IFS='|' read -r req_id title status phase updated_at tasks_completed tasks_total progress_percent <<< "$req_data"
249
+
250
+ case "$phase" in
251
+ initialized|planning) ((count_init++)) ;;
252
+ prd_*|epic_planning) ((count_prd++)) ;;
253
+ epic_complete) ((count_epic++)) ;;
254
+ development|dev_complete) ((count_dev++)) ;;
255
+ qa*) ((count_qa++)) ;;
256
+ release*|completed) ((count_release++)) ;;
257
+ esac
258
+ done
259
+
260
+ echo -e "${BOLD}阶段分布:${NC}"
261
+ echo -e " 初始化阶段: $count_init"
262
+ echo -e " PRD阶段: $count_prd"
263
+ echo -e " Epic阶段: $count_epic"
264
+ echo -e " 开发阶段: $count_dev"
265
+ echo -e " QA阶段: $count_qa"
266
+ echo -e " 发布/完成: $count_release"
267
+ echo ""
268
+ echo -e "${BOLD}${CYAN}───────────────────────────────────────────────────────────────${NC}"
269
+ echo ""
270
+
271
+ # 输出每个需求的详细信息
272
+ for req_data in "${requirements[@]}"; do
273
+ IFS='|' read -r req_id title status phase updated_at tasks_completed tasks_total progress_percent <<< "$req_data"
274
+
275
+ local phase_display=$(get_phase_display_name "$phase")
276
+ local progress_bar=$(generate_progress_bar "$progress_percent")
277
+
278
+ # 根据阶段选择颜色
279
+ local color="$CYAN"
280
+ case "$phase" in
281
+ initialized|planning) color="$YELLOW" ;;
282
+ *complete|completed) color="$GREEN" ;;
283
+ development|dev_*) color="$BLUE" ;;
284
+ esac
285
+
286
+ echo -e "${BOLD}${color}${req_id}${NC}: ${title:-无标题}"
287
+ echo -e " 阶段: ${phase_display}"
288
+ echo -e " 进度: $progress_bar ${progress_percent}%"
289
+
290
+ if [[ $tasks_total -gt 0 ]]; then
291
+ echo -e " 任务: ${tasks_completed}/${tasks_total} 已完成"
292
+ fi
293
+
294
+ if [[ -n "$updated_at" ]]; then
295
+ echo -e " 更新时间: ${updated_at}"
296
+ fi
297
+
298
+ if [[ "$VERBOSE" == "true" ]]; then
299
+ echo -e " 状态: ${status}"
300
+ local req_dir="$REQUIREMENTS_DIR/$req_id"
301
+
302
+ # 检查关键文件
303
+ local files_status=""
304
+ [[ -f "$req_dir/PRD.md" ]] && files_status+="PRD "
305
+ [[ -f "$req_dir/EPIC.md" ]] && files_status+="Epic "
306
+ [[ -f "$req_dir/TASKS.md" ]] && files_status+="Tasks "
307
+ [[ -f "$req_dir/TEST_REPORT.md" ]] && files_status+="TestReport "
308
+ [[ -f "$req_dir/SECURITY_REPORT.md" ]] && files_status+="SecurityReport "
309
+
310
+ if [[ -n "$files_status" ]]; then
311
+ echo -e " 文档: ${files_status}"
312
+ fi
313
+ fi
314
+
315
+ echo ""
316
+ done
317
+
318
+ echo -e "${BOLD}${CYAN}═══════════════════════════════════════════════════════════════${NC}"
319
+ }
320
+
321
+ # Markdown格式输出
322
+ output_markdown() {
323
+ local requirements=("$@")
324
+ local total=${#requirements[@]}
325
+
326
+ echo "# CC-DevFlow 需求开发状态报告"
327
+ echo ""
328
+ echo "**生成时间**: $(get_beijing_time_full)"
329
+ echo ""
330
+ echo "**需求总数**: $total"
331
+ echo ""
332
+
333
+ if [[ $total -eq 0 ]]; then
334
+ echo "> 没有找到符合条件的需求"
335
+ return
336
+ fi
337
+
338
+ # 统计各阶段需求数量
339
+ local count_init=0 count_prd=0 count_epic=0 count_dev=0 count_qa=0 count_release=0
340
+
341
+ for req_data in "${requirements[@]}"; do
342
+ IFS='|' read -r req_id title status phase updated_at tasks_completed tasks_total progress_percent <<< "$req_data"
343
+
344
+ case "$phase" in
345
+ initialized|planning) ((count_init++)) ;;
346
+ prd_*|epic_planning) ((count_prd++)) ;;
347
+ epic_complete) ((count_epic++)) ;;
348
+ development|dev_complete) ((count_dev++)) ;;
349
+ qa*) ((count_qa++)) ;;
350
+ release*|completed) ((count_release++)) ;;
351
+ esac
352
+ done
353
+
354
+ echo "## 阶段分布"
355
+ echo ""
356
+ echo "| 阶段 | 数量 |"
357
+ echo "|------|------|"
358
+ echo "| 初始化阶段 | $count_init |"
359
+ echo "| PRD阶段 | $count_prd |"
360
+ echo "| Epic阶段 | $count_epic |"
361
+ echo "| 开发阶段 | $count_dev |"
362
+ echo "| QA阶段 | $count_qa |"
363
+ echo "| 发布/完成 | $count_release |"
364
+ echo ""
365
+
366
+ echo "## 需求详情"
367
+ echo ""
368
+ echo "| 需求ID | 标题 | 阶段 | 进度 | 任务进度 | 最后更新 |"
369
+ echo "|--------|------|------|------|----------|----------|"
370
+
371
+ for req_data in "${requirements[@]}"; do
372
+ IFS='|' read -r req_id title status phase updated_at tasks_completed tasks_total progress_percent <<< "$req_data"
373
+
374
+ local phase_display=$(get_phase_display_name "$phase")
375
+ local tasks_display="-"
376
+
377
+ if [[ $tasks_total -gt 0 ]]; then
378
+ tasks_display="${tasks_completed}/${tasks_total}"
379
+ fi
380
+
381
+ local updated_display="${updated_at:-N/A}"
382
+
383
+ echo "| **$req_id** | ${title:-无标题} | $phase_display | ${progress_percent}% | $tasks_display | $updated_display |"
384
+ done
385
+
386
+ echo ""
387
+
388
+ if [[ "$VERBOSE" == "true" ]]; then
389
+ echo "## 详细信息"
390
+ echo ""
391
+
392
+ for req_data in "${requirements[@]}"; do
393
+ IFS='|' read -r req_id title status phase updated_at tasks_completed tasks_total progress_percent <<< "$req_data"
394
+
395
+ local phase_display=$(get_phase_display_name "$phase")
396
+
397
+ echo "### $req_id: ${title:-无标题}"
398
+ echo ""
399
+ echo "- **阶段**: $phase_display"
400
+ echo "- **进度**: ${progress_percent}%"
401
+
402
+ if [[ $tasks_total -gt 0 ]]; then
403
+ echo "- **任务**: ${tasks_completed}/${tasks_total} 已完成"
404
+ fi
405
+
406
+ echo "- **最后更新**: ${updated_at:-N/A}"
407
+ echo "- **状态**: $status"
408
+
409
+ local req_dir="$REQUIREMENTS_DIR/$req_id"
410
+ echo "- **文档**:"
411
+ [[ -f "$req_dir/PRD.md" ]] && echo " - ✅ PRD.md"
412
+ [[ -f "$req_dir/EPIC.md" ]] && echo " - ✅ EPIC.md"
413
+ [[ -f "$req_dir/TASKS.md" ]] && echo " - ✅ TASKS.md"
414
+ [[ -f "$req_dir/TEST_REPORT.md" ]] && echo " - ✅ TEST_REPORT.md"
415
+ [[ -f "$req_dir/SECURITY_REPORT.md" ]] && echo " - ✅ SECURITY_REPORT.md"
416
+
417
+ echo ""
418
+ done
419
+ fi
420
+ }
421
+
422
+ # JSON格式输出
423
+ output_json() {
424
+ local requirements=("$@")
425
+
426
+ echo "{"
427
+ echo " \"generated_at\": \"$(get_beijing_time_iso)\","
428
+ echo " \"total_requirements\": ${#requirements[@]},"
429
+ echo " \"requirements\": ["
430
+
431
+ local first=true
432
+ for req_data in "${requirements[@]}"; do
433
+ IFS='|' read -r req_id title status phase updated_at tasks_completed tasks_total progress_percent <<< "$req_data"
434
+
435
+ if [[ "$first" == "true" ]]; then
436
+ first=false
437
+ else
438
+ echo ","
439
+ fi
440
+
441
+ echo " {"
442
+ echo " \"id\": \"$req_id\","
443
+ echo " \"title\": \"${title:-}\","
444
+ echo " \"status\": \"$status\","
445
+ echo " \"phase\": \"$phase\","
446
+ echo " \"phase_display\": \"$(get_phase_display_name "$phase")\","
447
+ echo " \"progress_percent\": $progress_percent,"
448
+ echo " \"tasks\": {"
449
+ echo " \"total\": $tasks_total,"
450
+ echo " \"completed\": $tasks_completed"
451
+ echo " },"
452
+ echo " \"updated_at\": \"${updated_at:-}\""
453
+
454
+ if [[ "$VERBOSE" == "true" ]]; then
455
+ local req_dir="$REQUIREMENTS_DIR/$req_id"
456
+ echo " ,"
457
+ echo " \"documents\": {"
458
+ echo " \"prd\": $([ -f "$req_dir/PRD.md" ] && echo "true" || echo "false"),"
459
+ echo " \"epic\": $([ -f "$req_dir/EPIC.md" ] && echo "true" || echo "false"),"
460
+ echo " \"tasks\": $([ -f "$req_dir/TASKS.md" ] && echo "true" || echo "false"),"
461
+ echo " \"test_report\": $([ -f "$req_dir/TEST_REPORT.md" ] && echo "true" || echo "false"),"
462
+ echo " \"security_report\": $([ -f "$req_dir/SECURITY_REPORT.md" ] && echo "true" || echo "false")"
463
+ echo " }"
464
+ fi
465
+
466
+ echo -n " }"
467
+ done
468
+
469
+ echo ""
470
+ echo " ]"
471
+ echo "}"
472
+ }
473
+
474
+ # 生成进度条
475
+ generate_progress_bar() {
476
+ local percent=$1
477
+ local bar_length=20
478
+ local filled=$((percent * bar_length / 100))
479
+ local empty=$((bar_length - filled))
480
+
481
+ local bar="["
482
+ for ((i=0; i<filled; i++)); do bar+="█"; done
483
+ for ((i=0; i<empty; i++)); do bar+="░"; done
484
+ bar+="]"
485
+
486
+ echo "$bar"
487
+ }
488
+
489
+ # 主逻辑
490
+ main() {
491
+ # 收集需求信息
492
+ local requirements_data=$(collect_requirements)
493
+
494
+ if [[ -z "$requirements_data" ]]; then
495
+ requirements_data=()
496
+ else
497
+ mapfile -t requirements_data <<< "$requirements_data"
498
+ fi
499
+
500
+ # 根据格式输出
501
+ local output=""
502
+ case "$FORMAT" in
503
+ text)
504
+ output=$(output_text "${requirements_data[@]}")
505
+ ;;
506
+ markdown)
507
+ output=$(output_markdown "${requirements_data[@]}")
508
+ ;;
509
+ json)
510
+ output=$(output_json "${requirements_data[@]}")
511
+ ;;
512
+ esac
513
+
514
+ # 输出到文件或标准输出
515
+ if [[ -n "$OUTPUT_FILE" ]]; then
516
+ echo "$output" > "$OUTPUT_FILE"
517
+ echo -e "${GREEN}报告已生成: $OUTPUT_FILE${NC}" >&2
518
+ else
519
+ echo "$output"
520
+ fi
521
+ }
522
+
523
+ main