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.
- package/.claude/CLAUDE.md +83 -0
- package/.claude/agents/architecture-designer.md +443 -0
- package/.claude/agents/bug-analyzer.md +382 -0
- package/.claude/agents/checklist-agent.md +175 -0
- package/.claude/agents/clarify-analyst.md +50 -0
- package/.claude/agents/code-reviewer.md +71 -0
- package/.claude/agents/codex-analyzer.md +39 -0
- package/.claude/agents/compatibility-checker.md +580 -0
- package/.claude/agents/consistency-checker.md +532 -0
- package/.claude/agents/impact-analyzer.md +441 -0
- package/.claude/agents/planner.md +230 -0
- package/.claude/agents/prd-writer.md +320 -0
- package/.claude/agents/project-guidelines-generator.md +1329 -0
- package/.claude/agents/qa-tester.md +313 -0
- package/.claude/agents/release-manager.md +295 -0
- package/.claude/agents/security-reviewer.md +314 -0
- package/.claude/agents/style-guide-generator.md +458 -0
- package/.claude/agents/tech-architect.md +516 -0
- package/.claude/agents/ui-designer.md +485 -0
- package/.claude/commands/code-review-high.md +58 -0
- package/.claude/commands/core-architecture.md +429 -0
- package/.claude/commands/core-guidelines.md +486 -0
- package/.claude/commands/core-roadmap.md +439 -0
- package/.claude/commands/core-style.md +293 -0
- package/.claude/commands/flow-archive.md +245 -0
- package/.claude/commands/flow-checklist.md +260 -0
- package/.claude/commands/flow-clarify.md +136 -0
- package/.claude/commands/flow-constitution.md +82 -0
- package/.claude/commands/flow-dev.md +134 -0
- package/.claude/commands/flow-epic.md +150 -0
- package/.claude/commands/flow-fix.md +104 -0
- package/.claude/commands/flow-ideate.md +214 -0
- package/.claude/commands/flow-init.md +313 -0
- package/.claude/commands/flow-new.md +394 -0
- package/.claude/commands/flow-prd.md +131 -0
- package/.claude/commands/flow-qa.md +93 -0
- package/.claude/commands/flow-release.md +92 -0
- package/.claude/commands/flow-restart.md +98 -0
- package/.claude/commands/flow-status.md +64 -0
- package/.claude/commands/flow-tech.md +142 -0
- package/.claude/commands/flow-ui.md +189 -0
- package/.claude/commands/flow-update.md +111 -0
- package/.claude/commands/flow-upgrade.md +115 -0
- package/.claude/commands/flow-verify.md +96 -0
- package/.claude/commands/problem-analyzer.md +60 -0
- package/.claude/config/quality-rules.yml +161 -0
- package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +426 -0
- package/.claude/docs/design/consistency-conflict-detection-algorithms.md +658 -0
- package/.claude/docs/design/intent-driven-input-design.md +380 -0
- package/.claude/docs/design/prd-version-management-design.md +437 -0
- package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +117 -0
- package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +151 -0
- package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +188 -0
- package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +338 -0
- package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +633 -0
- package/.claude/docs/templates/BACKLOG_TEMPLATE.md +261 -0
- package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +52 -0
- package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +206 -0
- package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +71 -0
- package/.claude/docs/templates/EPIC_TEMPLATE.md +805 -0
- package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +213 -0
- package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +57 -0
- package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +148 -0
- package/.claude/docs/templates/PRD_TEMPLATE.md +562 -0
- package/.claude/docs/templates/RESEARCH_TEMPLATE.md +276 -0
- package/.claude/docs/templates/REVIEW-HIGH.md +57 -0
- package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +198 -0
- package/.claude/docs/templates/ROADMAP_TEMPLATE.md +310 -0
- package/.claude/docs/templates/STYLE_TEMPLATE.md +1266 -0
- package/.claude/docs/templates/TASKS_TEMPLATE.md +523 -0
- package/.claude/docs/templates/TECH_DESIGN_TEMPLATE.md +1019 -0
- package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +1436 -0
- package/.claude/guides/agent-guides/agent-coordination-guide.md +459 -0
- package/.claude/guides/project-guidelines-system.md +463 -0
- package/.claude/guides/technical-guides/datetime-handling-guide.md +563 -0
- package/.claude/guides/technical-guides/git-github-guide.md +642 -0
- package/.claude/guides/technical-guides/test-execution-guide.md +618 -0
- package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +217 -0
- package/.claude/guides/workflow-guides/flow-orchestrator.md +282 -0
- package/.claude/hooks/checklist-gate.js +397 -0
- package/.claude/hooks/error-handling-reminder.sh +12 -0
- package/.claude/hooks/error-handling-reminder.ts +459 -0
- package/.claude/hooks/post-tool-use-tracker.sh +280 -0
- package/.claude/hooks/pre-tool-use-guardrail.sh +36 -0
- package/.claude/hooks/pre-tool-use-guardrail.ts +342 -0
- package/.claude/hooks/skill-activation-prompt.sh +36 -0
- package/.claude/hooks/skill-activation-prompt.ts +214 -0
- package/.claude/hooks/state/skills-used-test-guard.json +3 -0
- package/.claude/rules/devflow-conventions.md +305 -0
- package/.claude/rules/project-constitution.md +748 -0
- package/.claude/schemas/constitution.schema.json +43 -0
- package/.claude/scripts/analyze-upgrade-impact.sh +200 -0
- package/.claude/scripts/archive-requirement.sh +351 -0
- package/.claude/scripts/calculate-checklist-completion.sh +243 -0
- package/.claude/scripts/calculate-quarter.sh +206 -0
- package/.claude/scripts/check-dependencies.sh +409 -0
- package/.claude/scripts/check-prerequisites.sh +232 -0
- package/.claude/scripts/check-task-status.sh +264 -0
- package/.claude/scripts/checklist-errors.sh +131 -0
- package/.claude/scripts/common.sh +570 -0
- package/.claude/scripts/consolidate-research.sh +182 -0
- package/.claude/scripts/create-requirement.sh +426 -0
- package/.claude/scripts/export-contracts.sh +117 -0
- package/.claude/scripts/extract-data-model.sh +78 -0
- package/.claude/scripts/generate-clarification-questions.sh +377 -0
- package/.claude/scripts/generate-clarification-report.sh +463 -0
- package/.claude/scripts/generate-quickstart.sh +146 -0
- package/.claude/scripts/generate-research-tasks.sh +157 -0
- package/.claude/scripts/generate-status-report.sh +523 -0
- package/.claude/scripts/generate-tech-analysis.sh +46 -0
- package/.claude/scripts/locate-requirement-in-roadmap.sh +233 -0
- package/.claude/scripts/manage-constitution.sh +602 -0
- package/.claude/scripts/mark-task-complete.sh +198 -0
- package/.claude/scripts/populate-research-tasks.sh +259 -0
- package/.claude/scripts/recover-workflow.sh +460 -0
- package/.claude/scripts/run-clarify-scan.sh +601 -0
- package/.claude/scripts/run-high-review.sh +62 -0
- package/.claude/scripts/run-problem-analysis.sh +68 -0
- package/.claude/scripts/setup-epic.sh +173 -0
- package/.claude/scripts/sync-roadmap-progress.sh +300 -0
- package/.claude/scripts/sync-task-marks.sh +199 -0
- package/.claude/scripts/test-clarify-scan.sh +515 -0
- package/.claude/scripts/update-agent-context.sh +806 -0
- package/.claude/scripts/validate-constitution.sh +567 -0
- package/.claude/scripts/validate-hooks.sh +487 -0
- package/.claude/scripts/validate-research.sh +332 -0
- package/.claude/scripts/validate-scope-boundary.sh +493 -0
- package/.claude/scripts/verify-setup.sh +37 -0
- package/.claude/settings.json +76 -0
- package/.claude/skills/_reference-implementations/README.md +96 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +302 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +451 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +307 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +638 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +275 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +224 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +213 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +756 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +336 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +789 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +235 -0
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +754 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +399 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +331 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +872 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +502 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +767 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +502 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +501 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +406 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +364 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +428 -0
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +418 -0
- package/.claude/skills/cc-devflow-orchestrator/SKILL.md +229 -0
- package/.claude/skills/constitution-guardian/SKILL.md +306 -0
- package/.claude/skills/devflow-constitution-quick-ref/SKILL.md +374 -0
- package/.claude/skills/devflow-file-standards/SKILL.md +353 -0
- package/.claude/skills/devflow-tdd-enforcer/SKILL.md +192 -0
- package/.claude/skills/skill-developer/ADVANCED.md +197 -0
- package/.claude/skills/skill-developer/HOOK_MECHANISMS.md +306 -0
- package/.claude/skills/skill-developer/PATTERNS_LIBRARY.md +152 -0
- package/.claude/skills/skill-developer/SKILL.md +426 -0
- package/.claude/skills/skill-developer/SKILL_RULES_REFERENCE.md +315 -0
- package/.claude/skills/skill-developer/TRIGGER_TYPES.md +305 -0
- package/.claude/skills/skill-developer/TROUBLESHOOTING.md +514 -0
- package/.claude/skills/skill-rules.json +213 -0
- package/.claude/tests/README.md +300 -0
- package/.claude/tests/TODO.md +69 -0
- package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/constitution/run_all_constitution_tests.sh +111 -0
- package/.claude/tests/constitution/test_agent_assignment.sh +207 -0
- package/.claude/tests/constitution/test_article_coverage.sh +201 -0
- package/.claude/tests/constitution/test_template_completeness.sh +150 -0
- package/.claude/tests/constitution/test_version_consistency.sh +120 -0
- package/.claude/tests/fixtures/spec_delta_full.md +16 -0
- package/.claude/tests/fixtures/tasks_progress_sample.md +5 -0
- package/.claude/tests/run-all-tests.sh +229 -0
- package/.claude/tests/scripts/run.sh +30 -0
- package/.claude/tests/scripts/test-framework.sh +128 -0
- package/.claude/tests/scripts/test_check_prerequisites.sh +511 -0
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak +504 -0
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +505 -0
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +506 -0
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +507 -0
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +508 -0
- package/.claude/tests/scripts/test_check_task_status.sh +499 -0
- package/.claude/tests/scripts/test_common.sh +244 -0
- package/.claude/tests/scripts/test_generate_status_report.sh +71 -0
- package/.claude/tests/scripts/test_mark_task_complete.sh +441 -0
- package/.claude/tests/scripts/test_mark_task_complete.sh.backup +410 -0
- package/.claude/tests/scripts/test_recover_workflow.sh +304 -0
- package/.claude/tests/scripts/test_setup_epic.sh +437 -0
- package/.claude/tests/scripts/test_sync_task_marks.sh +196 -0
- package/.claude/tests/scripts/test_validate_constitution.sh +74 -0
- package/.claude/tests/scripts/test_validate_research.sh +462 -0
- package/.claude/tests/slugify.bats +82 -0
- package/.claude/tests/test-framework.sh +732 -0
- package/.claude/tests/test_analyze_upgrade_impact.py +34 -0
- package/.claude/tests/test_consolidate_research.py +48 -0
- package/.claude/tests/test_export_contracts.py +43 -0
- package/.claude/tests/test_extract_data_model.py +33 -0
- package/.claude/tests/test_generate_quickstart.py +50 -0
- package/.claude/tests/test_generate_research_tasks.py +52 -0
- package/.claude/tsc-cache/6e64f818-6398-49ca-8623-581a9af85c44/edited-files.log +1 -0
- package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/affected-repos.txt +1 -0
- package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/edited-files.log +1 -0
- package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/affected-repos.txt +1 -0
- package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/edited-files.log +1 -0
- package/CHANGELOG.md +507 -0
- package/LICENSE +21 -0
- package/README.md +534 -0
- package/README.zh-CN.md +530 -0
- package/bin/adapt.js +240 -0
- package/bin/cc-devflow-cli.js +185 -0
- package/bin/cc-devflow.js +78 -0
- package/config/adapters.yml +5 -0
- package/config/schema/adapters.schema.json +44 -0
- package/docs/CLAUDE.md +26 -0
- package/docs/commands/README.md +61 -0
- package/docs/commands/README.zh-CN.md +55 -0
- package/docs/commands/core-roadmap.md +106 -0
- package/docs/commands/core-roadmap.zh-CN.md +102 -0
- package/docs/commands/core-style.md +405 -0
- package/docs/commands/core-style.zh-CN.md +405 -0
- package/docs/commands/flow-init.md +134 -0
- package/docs/commands/flow-init.zh-CN.md +163 -0
- package/docs/commands/flow-new.md +274 -0
- package/docs/commands/flow-new.zh-CN.md +270 -0
- package/docs/guides/getting-started.md +204 -0
- package/docs/guides/getting-started.zh-CN.md +152 -0
- package/lib/adapters/adapter-interface.js +57 -0
- package/lib/adapters/claude-adapter.js +74 -0
- package/lib/adapters/codex-adapter.js +40 -0
- package/lib/adapters/config-validator.js +68 -0
- package/lib/adapters/logger.js +42 -0
- package/lib/adapters/registry.js +153 -0
- package/lib/compiler/CLAUDE.md +92 -0
- package/lib/compiler/__tests__/drift.test.js +215 -0
- package/lib/compiler/__tests__/errors.test.js +184 -0
- package/lib/compiler/__tests__/incremental.test.js +174 -0
- package/lib/compiler/__tests__/integration.test.js +174 -0
- package/lib/compiler/__tests__/manifest.test.js +233 -0
- package/lib/compiler/__tests__/parser.test.js +456 -0
- package/lib/compiler/__tests__/schemas.test.js +301 -0
- package/lib/compiler/__tests__/skills-registry.test.js +125 -0
- package/lib/compiler/__tests__/transformer.test.js +286 -0
- package/lib/compiler/emitters/antigravity-emitter.js +171 -0
- package/lib/compiler/emitters/base-emitter.js +73 -0
- package/lib/compiler/emitters/codex-emitter.js +52 -0
- package/lib/compiler/emitters/cursor-emitter.js +31 -0
- package/lib/compiler/emitters/index.js +50 -0
- package/lib/compiler/emitters/qwen-emitter.js +39 -0
- package/lib/compiler/errors.js +119 -0
- package/lib/compiler/index.js +256 -0
- package/lib/compiler/manifest.js +242 -0
- package/lib/compiler/parser.js +258 -0
- package/lib/compiler/platforms.js +113 -0
- package/lib/compiler/resource-copier.js +320 -0
- package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +191 -0
- package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +109 -0
- package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +123 -0
- package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +123 -0
- package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +253 -0
- package/lib/compiler/rules-emitters/base-rules-emitter.js +83 -0
- package/lib/compiler/rules-emitters/codex-rules-emitter.js +116 -0
- package/lib/compiler/rules-emitters/cursor-rules-emitter.js +98 -0
- package/lib/compiler/rules-emitters/index.js +71 -0
- package/lib/compiler/rules-emitters/qwen-rules-emitter.js +70 -0
- package/lib/compiler/schemas.js +144 -0
- package/lib/compiler/skills-registry.js +225 -0
- package/lib/compiler/transformer.js +236 -0
- package/package.json +50 -0
|
@@ -0,0 +1,493 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# ============================================================================
|
|
3
|
+
# validate-scope-boundary.sh - 验证需求文档的边界合规性 (需求不扩散检查)
|
|
4
|
+
# ============================================================================
|
|
5
|
+
#
|
|
6
|
+
# 用途: 检查 PRD, EPIC, TASKS 文档是否遵循需求不扩散原则
|
|
7
|
+
#
|
|
8
|
+
# 使用:
|
|
9
|
+
# ./validate-scope-boundary.sh REQ-123
|
|
10
|
+
# ./validate-scope-boundary.sh REQ-123 --strict # 严格模式 (失败则退出)
|
|
11
|
+
# ./validate-scope-boundary.sh --all # 验证所有需求
|
|
12
|
+
#
|
|
13
|
+
# 检查项:
|
|
14
|
+
# 1. PRD 需求不扩散验证
|
|
15
|
+
# - [NEEDS CLARIFICATION] 标记是否已解决
|
|
16
|
+
# - 用户故事是否有优先级 (P1, P2, P3)
|
|
17
|
+
# - 用户故事是否有 Independent Test 标准
|
|
18
|
+
# - 是否包含技术实现细节 (API, database, framework)
|
|
19
|
+
#
|
|
20
|
+
# 2. EPIC Phase -1 闸门验证
|
|
21
|
+
# - Simplicity Gate 是否执行
|
|
22
|
+
# - Anti-Abstraction Gate 是否执行
|
|
23
|
+
# - Integration-First Gate 是否执行
|
|
24
|
+
# - Complexity Tracking 表格是否填写 (如有违规)
|
|
25
|
+
#
|
|
26
|
+
# 3. TASKS 用户故事组织验证
|
|
27
|
+
# - 任务是否按用户故事组织 (Phase 3+)
|
|
28
|
+
# - 任务是否有 [US#] 标签
|
|
29
|
+
# - 是否有 Foundational Phase
|
|
30
|
+
# - 是否有 Checkpoint 验证点
|
|
31
|
+
#
|
|
32
|
+
# 输出:
|
|
33
|
+
# - 通过: 退出码 0
|
|
34
|
+
# - 失败: 退出码 1
|
|
35
|
+
# - 警告: 退出码 2
|
|
36
|
+
# ============================================================================
|
|
37
|
+
|
|
38
|
+
set -euo pipefail
|
|
39
|
+
|
|
40
|
+
# ================================================================
|
|
41
|
+
# 颜色定义
|
|
42
|
+
# ================================================================
|
|
43
|
+
readonly RED='\033[0;31m'
|
|
44
|
+
readonly GREEN='\033[0;32m'
|
|
45
|
+
readonly YELLOW='\033[1;33m'
|
|
46
|
+
readonly BLUE='\033[0;34m'
|
|
47
|
+
readonly NC='\033[0m' # No Color
|
|
48
|
+
|
|
49
|
+
# ================================================================
|
|
50
|
+
# 全局变量
|
|
51
|
+
# ================================================================
|
|
52
|
+
STRICT_MODE=false
|
|
53
|
+
VALIDATE_ALL=false
|
|
54
|
+
ERRORS=0
|
|
55
|
+
WARNINGS=0
|
|
56
|
+
REPO_ROOT=""
|
|
57
|
+
REQ_ID=""
|
|
58
|
+
|
|
59
|
+
# ================================================================
|
|
60
|
+
# 辅助函数
|
|
61
|
+
# ================================================================
|
|
62
|
+
|
|
63
|
+
print_error() {
|
|
64
|
+
echo -e "${RED}✗ ERROR${NC}: $*" >&2
|
|
65
|
+
((ERRORS++))
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
print_warning() {
|
|
69
|
+
echo -e "${YELLOW}⚠ WARNING${NC}: $*"
|
|
70
|
+
((WARNINGS++))
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
print_success() {
|
|
74
|
+
echo -e "${GREEN}✓ PASS${NC}: $*"
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
print_info() {
|
|
78
|
+
echo -e "${BLUE}ℹ INFO${NC}: $*"
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
get_repo_root() {
|
|
82
|
+
if git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
|
|
83
|
+
git rev-parse --show-toplevel
|
|
84
|
+
else
|
|
85
|
+
pwd
|
|
86
|
+
fi
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
# ================================================================
|
|
90
|
+
# PRD 验证函数
|
|
91
|
+
# ================================================================
|
|
92
|
+
|
|
93
|
+
validate_prd_anti_expansion() {
|
|
94
|
+
local prd_file="$1"
|
|
95
|
+
local req_id="$2"
|
|
96
|
+
|
|
97
|
+
print_info "验证 PRD 需求不扩散: $req_id"
|
|
98
|
+
|
|
99
|
+
if [[ ! -f "$prd_file" ]]; then
|
|
100
|
+
print_error "PRD 文件不存在: $prd_file"
|
|
101
|
+
return 1
|
|
102
|
+
fi
|
|
103
|
+
|
|
104
|
+
local prd_content
|
|
105
|
+
prd_content=$(cat "$prd_file")
|
|
106
|
+
|
|
107
|
+
# 检查1: 未解决的 [NEEDS CLARIFICATION] 标记
|
|
108
|
+
local clarifications
|
|
109
|
+
clarifications=$(echo "$prd_content" | grep -c "\[NEEDS CLARIFICATION" || true)
|
|
110
|
+
|
|
111
|
+
if [[ $clarifications -gt 0 ]]; then
|
|
112
|
+
print_warning "PRD 包含 $clarifications 个未解决的 [NEEDS CLARIFICATION] 标记"
|
|
113
|
+
echo "$prd_content" | grep -n "\[NEEDS CLARIFICATION" | head -5
|
|
114
|
+
else
|
|
115
|
+
print_success "PRD 无未解决的澄清标记"
|
|
116
|
+
fi
|
|
117
|
+
|
|
118
|
+
# 检查2: 用户故事优先级
|
|
119
|
+
local stories_without_priority
|
|
120
|
+
stories_without_priority=$(echo "$prd_content" | \
|
|
121
|
+
grep "^### Story" | \
|
|
122
|
+
grep -v "Priority: P[0-9]" | \
|
|
123
|
+
wc -l | tr -d ' ')
|
|
124
|
+
|
|
125
|
+
if [[ $stories_without_priority -gt 0 ]]; then
|
|
126
|
+
print_error "PRD 有 $stories_without_priority 个用户故事缺少优先级标记"
|
|
127
|
+
else
|
|
128
|
+
print_success "PRD 所有用户故事都有优先级"
|
|
129
|
+
fi
|
|
130
|
+
|
|
131
|
+
# 检查3: Independent Test 标准
|
|
132
|
+
local stories_without_independent_test
|
|
133
|
+
stories_without_independent_test=$(echo "$prd_content" | \
|
|
134
|
+
grep "^### Story" -A 10 | \
|
|
135
|
+
grep -c "^### Story" || true)
|
|
136
|
+
|
|
137
|
+
local independent_test_count
|
|
138
|
+
independent_test_count=$(echo "$prd_content" | \
|
|
139
|
+
grep -c "\*\*Independent Test\*\*" || true)
|
|
140
|
+
|
|
141
|
+
if [[ $independent_test_count -lt $stories_without_independent_test ]]; then
|
|
142
|
+
print_error "PRD 有用户故事缺少 Independent Test 标准"
|
|
143
|
+
else
|
|
144
|
+
print_success "PRD 所有用户故事都有 Independent Test 标准"
|
|
145
|
+
fi
|
|
146
|
+
|
|
147
|
+
# 检查4: 技术实现细节 (不应出现在 PRD)
|
|
148
|
+
local tech_keywords=("API endpoint" "database schema" "REST API" "GraphQL" "PostgreSQL" "MongoDB" "React component" "Vue component")
|
|
149
|
+
local found_tech_details=false
|
|
150
|
+
|
|
151
|
+
for keyword in "${tech_keywords[@]}"; do
|
|
152
|
+
if echo "$prd_content" | grep -iq "$keyword"; then
|
|
153
|
+
print_warning "PRD 包含技术实现细节: '$keyword' (应该只描述 WHAT 和 WHY,不是 HOW)"
|
|
154
|
+
found_tech_details=true
|
|
155
|
+
fi
|
|
156
|
+
done
|
|
157
|
+
|
|
158
|
+
if [[ "$found_tech_details" == "false" ]]; then
|
|
159
|
+
print_success "PRD 未包含技术实现细节"
|
|
160
|
+
fi
|
|
161
|
+
|
|
162
|
+
# 检查5: 需求不扩散验证清单
|
|
163
|
+
if echo "$prd_content" | grep -q "### 需求不扩散验证"; then
|
|
164
|
+
print_success "PRD 包含需求不扩散验证清单"
|
|
165
|
+
else
|
|
166
|
+
print_warning "PRD 缺少需求不扩散验证清单"
|
|
167
|
+
fi
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
# ================================================================
|
|
171
|
+
# EPIC 验证函数
|
|
172
|
+
# ================================================================
|
|
173
|
+
|
|
174
|
+
validate_epic_phase_minus_one() {
|
|
175
|
+
local epic_file="$1"
|
|
176
|
+
local req_id="$2"
|
|
177
|
+
|
|
178
|
+
print_info "验证 EPIC Phase -1 闸门: $req_id"
|
|
179
|
+
|
|
180
|
+
if [[ ! -f "$epic_file" ]]; then
|
|
181
|
+
print_error "EPIC 文件不存在: $epic_file"
|
|
182
|
+
return 1
|
|
183
|
+
fi
|
|
184
|
+
|
|
185
|
+
local epic_content
|
|
186
|
+
epic_content=$(cat "$epic_file")
|
|
187
|
+
|
|
188
|
+
# 检查1: Phase -1 章节是否存在
|
|
189
|
+
if echo "$epic_content" | grep -q "## Phase -1.*Pre-Implementation Gates"; then
|
|
190
|
+
print_success "EPIC 包含 Phase -1 宪法闸门章节"
|
|
191
|
+
else
|
|
192
|
+
print_error "EPIC 缺少 Phase -1 宪法闸门章节"
|
|
193
|
+
return 1
|
|
194
|
+
fi
|
|
195
|
+
|
|
196
|
+
# 检查2: Simplicity Gate
|
|
197
|
+
if echo "$epic_content" | grep -q "### Simplicity Gate"; then
|
|
198
|
+
print_success "EPIC 包含 Simplicity Gate"
|
|
199
|
+
|
|
200
|
+
# 检查项目数量限制
|
|
201
|
+
if echo "$epic_content" | grep -q "≤3 个项目"; then
|
|
202
|
+
print_success "Simplicity Gate: 检查项目数量限制"
|
|
203
|
+
else
|
|
204
|
+
print_warning "Simplicity Gate: 缺少项目数量限制检查"
|
|
205
|
+
fi
|
|
206
|
+
|
|
207
|
+
# 检查 NO FUTURE-PROOFING
|
|
208
|
+
if echo "$epic_content" | grep -q "NO FUTURE-PROOFING"; then
|
|
209
|
+
print_success "Simplicity Gate: 检查未来优化预留"
|
|
210
|
+
else
|
|
211
|
+
print_warning "Simplicity Gate: 缺少未来优化检查"
|
|
212
|
+
fi
|
|
213
|
+
else
|
|
214
|
+
print_error "EPIC 缺少 Simplicity Gate"
|
|
215
|
+
fi
|
|
216
|
+
|
|
217
|
+
# 检查3: Anti-Abstraction Gate
|
|
218
|
+
if echo "$epic_content" | grep -q "### Anti-Abstraction Gate"; then
|
|
219
|
+
print_success "EPIC 包含 Anti-Abstraction Gate"
|
|
220
|
+
|
|
221
|
+
# 检查 Framework Trust
|
|
222
|
+
if echo "$epic_content" | grep -q "Framework Trust"; then
|
|
223
|
+
print_success "Anti-Abstraction Gate: 检查框架直接使用"
|
|
224
|
+
else
|
|
225
|
+
print_warning "Anti-Abstraction Gate: 缺少框架使用检查"
|
|
226
|
+
fi
|
|
227
|
+
else
|
|
228
|
+
print_error "EPIC 缺少 Anti-Abstraction Gate"
|
|
229
|
+
fi
|
|
230
|
+
|
|
231
|
+
# 检查4: Integration-First Gate
|
|
232
|
+
if echo "$epic_content" | grep -q "### Integration-First Gate"; then
|
|
233
|
+
print_success "EPIC 包含 Integration-First Gate"
|
|
234
|
+
|
|
235
|
+
# 检查 Contracts Defined First
|
|
236
|
+
if echo "$epic_content" | grep -q "Contracts Defined First"; then
|
|
237
|
+
print_success "Integration-First Gate: 检查契约优先定义"
|
|
238
|
+
else
|
|
239
|
+
print_warning "Integration-First Gate: 缺少契约定义检查"
|
|
240
|
+
fi
|
|
241
|
+
else
|
|
242
|
+
print_error "EPIC 缺少 Integration-First Gate"
|
|
243
|
+
fi
|
|
244
|
+
|
|
245
|
+
# 检查5: Complexity Tracking 表格
|
|
246
|
+
if echo "$epic_content" | grep -q "### Complexity Tracking"; then
|
|
247
|
+
print_success "EPIC 包含 Complexity Tracking 表格"
|
|
248
|
+
|
|
249
|
+
# 检查是否有违规记录
|
|
250
|
+
local violations
|
|
251
|
+
violations=$(echo "$epic_content" | \
|
|
252
|
+
sed -n '/### Complexity Tracking/,/^---/p' | \
|
|
253
|
+
grep "^|" | \
|
|
254
|
+
grep -v "违规项" | \
|
|
255
|
+
grep -v "^| --" | \
|
|
256
|
+
wc -l | tr -d ' ')
|
|
257
|
+
|
|
258
|
+
if [[ $violations -gt 1 ]]; then
|
|
259
|
+
print_warning "EPIC 记录了 $((violations - 1)) 个宪法违规项"
|
|
260
|
+
fi
|
|
261
|
+
else
|
|
262
|
+
print_warning "EPIC 缺少 Complexity Tracking 表格"
|
|
263
|
+
fi
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
# ================================================================
|
|
267
|
+
# TASKS 验证函数
|
|
268
|
+
# ================================================================
|
|
269
|
+
|
|
270
|
+
validate_tasks_story_organization() {
|
|
271
|
+
local tasks_file="$1"
|
|
272
|
+
local req_id="$2"
|
|
273
|
+
|
|
274
|
+
print_info "验证 TASKS 用户故事组织: $req_id"
|
|
275
|
+
|
|
276
|
+
if [[ ! -f "$tasks_file" ]]; then
|
|
277
|
+
print_error "TASKS 文件不存在: $tasks_file"
|
|
278
|
+
return 1
|
|
279
|
+
fi
|
|
280
|
+
|
|
281
|
+
local tasks_content
|
|
282
|
+
tasks_content=$(cat "$tasks_file")
|
|
283
|
+
|
|
284
|
+
# 检查1: Foundational Phase 是否存在
|
|
285
|
+
if echo "$tasks_content" | grep -q "## Phase 2.*Foundational"; then
|
|
286
|
+
print_success "TASKS 包含 Foundational Phase (阻塞性前置条件)"
|
|
287
|
+
else
|
|
288
|
+
print_error "TASKS 缺少 Foundational Phase"
|
|
289
|
+
fi
|
|
290
|
+
|
|
291
|
+
# 检查2: 用户故事阶段 (Phase 3+)
|
|
292
|
+
local user_story_phases
|
|
293
|
+
user_story_phases=$(echo "$tasks_content" | \
|
|
294
|
+
grep "^## Phase [3-9].*User Story" | \
|
|
295
|
+
wc -l | tr -d ' ')
|
|
296
|
+
|
|
297
|
+
if [[ $user_story_phases -gt 0 ]]; then
|
|
298
|
+
print_success "TASKS 包含 $user_story_phases 个用户故事阶段"
|
|
299
|
+
else
|
|
300
|
+
print_error "TASKS 缺少用户故事组织结构 (应该从 Phase 3 开始)"
|
|
301
|
+
fi
|
|
302
|
+
|
|
303
|
+
# 检查3: [US#] 标签
|
|
304
|
+
local tasks_with_us_label
|
|
305
|
+
tasks_with_us_label=$(echo "$tasks_content" | \
|
|
306
|
+
grep "^\- \[ \].*\[US[0-9]\]" | \
|
|
307
|
+
wc -l | tr -d ' ')
|
|
308
|
+
|
|
309
|
+
if [[ $tasks_with_us_label -gt 0 ]]; then
|
|
310
|
+
print_success "TASKS 包含 $tasks_with_us_label 个带 [US#] 标签的任务"
|
|
311
|
+
else
|
|
312
|
+
print_warning "TASKS 缺少 [US#] 标签 (建议所有任务都标记所属用户故事)"
|
|
313
|
+
fi
|
|
314
|
+
|
|
315
|
+
# 检查4: Independent Test 标准
|
|
316
|
+
local independent_test_count
|
|
317
|
+
independent_test_count=$(echo "$tasks_content" | \
|
|
318
|
+
grep -c "\*\*Independent Test\*\*" || true)
|
|
319
|
+
|
|
320
|
+
if [[ $independent_test_count -ge $user_story_phases ]]; then
|
|
321
|
+
print_success "TASKS 每个用户故事都有 Independent Test 标准"
|
|
322
|
+
else
|
|
323
|
+
print_warning "TASKS 有用户故事缺少 Independent Test 标准"
|
|
324
|
+
fi
|
|
325
|
+
|
|
326
|
+
# 检查5: Checkpoint 验证点
|
|
327
|
+
local checkpoint_count
|
|
328
|
+
checkpoint_count=$(echo "$tasks_content" | \
|
|
329
|
+
grep -c "\*\*Checkpoint\*\*" || true)
|
|
330
|
+
|
|
331
|
+
if [[ $checkpoint_count -ge $user_story_phases ]]; then
|
|
332
|
+
print_success "TASKS 每个用户故事都有 Checkpoint 验证点"
|
|
333
|
+
else
|
|
334
|
+
print_warning "TASKS 有用户故事缺少 Checkpoint 验证点"
|
|
335
|
+
fi
|
|
336
|
+
|
|
337
|
+
# 检查6: Implementation Strategy
|
|
338
|
+
if echo "$tasks_content" | grep -q "## Implementation Strategy"; then
|
|
339
|
+
print_success "TASKS 包含 Implementation Strategy (MVP First, Incremental Delivery)"
|
|
340
|
+
else
|
|
341
|
+
print_warning "TASKS 缺少 Implementation Strategy 章节"
|
|
342
|
+
fi
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
# ================================================================
|
|
346
|
+
# 主验证函数
|
|
347
|
+
# ================================================================
|
|
348
|
+
|
|
349
|
+
validate_requirement() {
|
|
350
|
+
local req_id="$1"
|
|
351
|
+
local req_dir="$REPO_ROOT/devflow/requirements/$req_id"
|
|
352
|
+
|
|
353
|
+
echo ""
|
|
354
|
+
echo "========================================================================"
|
|
355
|
+
echo "验证需求: $req_id"
|
|
356
|
+
echo "========================================================================"
|
|
357
|
+
|
|
358
|
+
if [[ ! -d "$req_dir" ]]; then
|
|
359
|
+
print_error "需求目录不存在: $req_dir"
|
|
360
|
+
return 1
|
|
361
|
+
fi
|
|
362
|
+
|
|
363
|
+
local local_errors=0
|
|
364
|
+
local local_warnings=0
|
|
365
|
+
|
|
366
|
+
# 验证 PRD
|
|
367
|
+
if [[ -f "$req_dir/PRD.md" ]]; then
|
|
368
|
+
validate_prd_anti_expansion "$req_dir/PRD.md" "$req_id" || ((local_errors++))
|
|
369
|
+
else
|
|
370
|
+
print_warning "PRD.md 不存在,跳过 PRD 验证"
|
|
371
|
+
fi
|
|
372
|
+
|
|
373
|
+
echo ""
|
|
374
|
+
|
|
375
|
+
# 验证 EPIC
|
|
376
|
+
if [[ -f "$req_dir/EPIC.md" ]]; then
|
|
377
|
+
validate_epic_phase_minus_one "$req_dir/EPIC.md" "$req_id" || ((local_errors++))
|
|
378
|
+
else
|
|
379
|
+
print_warning "EPIC.md 不存在,跳过 EPIC 验证"
|
|
380
|
+
fi
|
|
381
|
+
|
|
382
|
+
echo ""
|
|
383
|
+
|
|
384
|
+
# 验证 TASKS
|
|
385
|
+
if [[ -f "$req_dir/TASKS.md" ]]; then
|
|
386
|
+
validate_tasks_story_organization "$req_dir/TASKS.md" "$req_id" || ((local_errors++))
|
|
387
|
+
else
|
|
388
|
+
print_warning "TASKS.md 不存在,跳过 TASKS 验证"
|
|
389
|
+
fi
|
|
390
|
+
|
|
391
|
+
echo ""
|
|
392
|
+
echo "------------------------------------------------------------------------"
|
|
393
|
+
echo "验证结果: $req_id"
|
|
394
|
+
echo "------------------------------------------------------------------------"
|
|
395
|
+
|
|
396
|
+
if [[ $local_errors -eq 0 && $WARNINGS -eq 0 ]]; then
|
|
397
|
+
print_success "需求 $req_id 完全符合需求不扩散原则"
|
|
398
|
+
elif [[ $local_errors -eq 0 ]]; then
|
|
399
|
+
print_warning "需求 $req_id 有 $WARNINGS 个警告,但总体符合需求不扩散原则"
|
|
400
|
+
else
|
|
401
|
+
print_error "需求 $req_id 有 $local_errors 个错误,不符合需求不扩散原则"
|
|
402
|
+
fi
|
|
403
|
+
|
|
404
|
+
return $local_errors
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
# ================================================================
|
|
408
|
+
# 主函数
|
|
409
|
+
# ================================================================
|
|
410
|
+
|
|
411
|
+
main() {
|
|
412
|
+
REPO_ROOT=$(get_repo_root)
|
|
413
|
+
|
|
414
|
+
# 解析参数
|
|
415
|
+
if [[ $# -eq 0 ]]; then
|
|
416
|
+
echo "用法: $0 <REQ-ID> [--strict]"
|
|
417
|
+
echo " $0 --all [--strict]"
|
|
418
|
+
echo ""
|
|
419
|
+
echo "示例:"
|
|
420
|
+
echo " $0 REQ-123"
|
|
421
|
+
echo " $0 REQ-123 --strict"
|
|
422
|
+
echo " $0 --all"
|
|
423
|
+
exit 1
|
|
424
|
+
fi
|
|
425
|
+
|
|
426
|
+
# 检查参数
|
|
427
|
+
while [[ $# -gt 0 ]]; do
|
|
428
|
+
case "$1" in
|
|
429
|
+
--strict)
|
|
430
|
+
STRICT_MODE=true
|
|
431
|
+
shift
|
|
432
|
+
;;
|
|
433
|
+
--all)
|
|
434
|
+
VALIDATE_ALL=true
|
|
435
|
+
shift
|
|
436
|
+
;;
|
|
437
|
+
REQ-*)
|
|
438
|
+
REQ_ID="$1"
|
|
439
|
+
shift
|
|
440
|
+
;;
|
|
441
|
+
*)
|
|
442
|
+
echo "未知参数: $1"
|
|
443
|
+
exit 1
|
|
444
|
+
;;
|
|
445
|
+
esac
|
|
446
|
+
done
|
|
447
|
+
|
|
448
|
+
# 执行验证
|
|
449
|
+
if [[ "$VALIDATE_ALL" == "true" ]]; then
|
|
450
|
+
print_info "验证所有需求文档..."
|
|
451
|
+
|
|
452
|
+
local req_dirs
|
|
453
|
+
req_dirs=$(find "$REPO_ROOT/devflow/requirements" -maxdepth 1 -type d -name "REQ-*" 2>/dev/null || true)
|
|
454
|
+
|
|
455
|
+
if [[ -z "$req_dirs" ]]; then
|
|
456
|
+
print_warning "未找到任何需求目录"
|
|
457
|
+
exit 0
|
|
458
|
+
fi
|
|
459
|
+
|
|
460
|
+
for req_dir in $req_dirs; do
|
|
461
|
+
local req_id
|
|
462
|
+
req_id=$(basename "$req_dir")
|
|
463
|
+
validate_requirement "$req_id" || true
|
|
464
|
+
done
|
|
465
|
+
else
|
|
466
|
+
validate_requirement "$REQ_ID"
|
|
467
|
+
fi
|
|
468
|
+
|
|
469
|
+
# 输出总结
|
|
470
|
+
echo ""
|
|
471
|
+
echo "========================================================================"
|
|
472
|
+
echo "验证总结"
|
|
473
|
+
echo "========================================================================"
|
|
474
|
+
echo "错误: $ERRORS"
|
|
475
|
+
echo "警告: $WARNINGS"
|
|
476
|
+
|
|
477
|
+
if [[ $ERRORS -eq 0 && $WARNINGS -eq 0 ]]; then
|
|
478
|
+
print_success "所有检查通过 ✓"
|
|
479
|
+
exit 0
|
|
480
|
+
elif [[ $ERRORS -eq 0 ]]; then
|
|
481
|
+
print_warning "有 $WARNINGS 个警告,但整体符合要求"
|
|
482
|
+
exit 0
|
|
483
|
+
else
|
|
484
|
+
print_error "有 $ERRORS 个错误,不符合需求不扩散原则"
|
|
485
|
+
if [[ "$STRICT_MODE" == "true" ]]; then
|
|
486
|
+
exit 1
|
|
487
|
+
else
|
|
488
|
+
exit 2
|
|
489
|
+
fi
|
|
490
|
+
fi
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
main "$@"
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
set -e
|
|
3
|
+
|
|
4
|
+
# ============================================================
|
|
5
|
+
# 安装验证 | Verify Setup
|
|
6
|
+
# ============================================================
|
|
7
|
+
# 目标:
|
|
8
|
+
# - 确认 .claude 结构完整
|
|
9
|
+
# - 给出最小可用性检查
|
|
10
|
+
# ============================================================
|
|
11
|
+
|
|
12
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
13
|
+
CLAUDE_DIR="$(cd "$SCRIPT_DIR/.." && pwd)"
|
|
14
|
+
|
|
15
|
+
require_dir() {
|
|
16
|
+
local target="$1"
|
|
17
|
+
if [[ ! -d "$target" ]]; then
|
|
18
|
+
echo "ERROR: Missing directory: $target" >&2
|
|
19
|
+
exit 1
|
|
20
|
+
fi
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
require_file() {
|
|
24
|
+
local target="$1"
|
|
25
|
+
if [[ ! -f "$target" ]]; then
|
|
26
|
+
echo "ERROR: Missing file: $target" >&2
|
|
27
|
+
exit 1
|
|
28
|
+
fi
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
require_dir "$CLAUDE_DIR/commands"
|
|
32
|
+
require_dir "$CLAUDE_DIR/skills"
|
|
33
|
+
require_dir "$CLAUDE_DIR/scripts"
|
|
34
|
+
require_file "$CLAUDE_DIR/commands/flow-new.md"
|
|
35
|
+
require_file "$CLAUDE_DIR/skills/cc-devflow-orchestrator/SKILL.md"
|
|
36
|
+
|
|
37
|
+
echo "cc-devflow setup OK."
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
{
|
|
2
|
+
"enableAllProjectMcpServers": true,
|
|
3
|
+
"permissions": {
|
|
4
|
+
"allow": [
|
|
5
|
+
"Bash(git status)",
|
|
6
|
+
"Bash(git diff:*)",
|
|
7
|
+
"Bash(git add:*)",
|
|
8
|
+
"Bash(git switch:*)",
|
|
9
|
+
"Bash(git checkout:*)",
|
|
10
|
+
"Bash(git commit:*)",
|
|
11
|
+
"Bash(git push:*)",
|
|
12
|
+
"Bash(gh pr:*)",
|
|
13
|
+
"Bash(npm run dev)",
|
|
14
|
+
"Bash(npm run test:watch)",
|
|
15
|
+
"Bash(npm run test)",
|
|
16
|
+
"Bash(npm run typecheck)",
|
|
17
|
+
"Bash(mkdir:*)",
|
|
18
|
+
"Bash(echo:*)"
|
|
19
|
+
],
|
|
20
|
+
"ask": [
|
|
21
|
+
"Bash(git merge:*)",
|
|
22
|
+
"Bash(gh pr merge:*)",
|
|
23
|
+
"Bash(gh pr create:*)"
|
|
24
|
+
],
|
|
25
|
+
"deny": [
|
|
26
|
+
"Read(./.env)",
|
|
27
|
+
"Read(./.env.*)",
|
|
28
|
+
"Read(./secrets/**)",
|
|
29
|
+
"Bash(rm -rf:*)"
|
|
30
|
+
]
|
|
31
|
+
},
|
|
32
|
+
"hooks": {
|
|
33
|
+
"UserPromptSubmit": [
|
|
34
|
+
{
|
|
35
|
+
"hooks": [
|
|
36
|
+
{
|
|
37
|
+
"type": "command",
|
|
38
|
+
"command": "$CLAUDE_PROJECT_DIR/.claude/hooks/skill-activation-prompt.sh"
|
|
39
|
+
}
|
|
40
|
+
]
|
|
41
|
+
}
|
|
42
|
+
],
|
|
43
|
+
"PostToolUse": [
|
|
44
|
+
{
|
|
45
|
+
"matcher": "Edit|MultiEdit|Write",
|
|
46
|
+
"hooks": [
|
|
47
|
+
{
|
|
48
|
+
"type": "command",
|
|
49
|
+
"command": "$CLAUDE_PROJECT_DIR/.claude/hooks/post-tool-use-tracker.sh"
|
|
50
|
+
}
|
|
51
|
+
]
|
|
52
|
+
}
|
|
53
|
+
],
|
|
54
|
+
"PreToolUse": [
|
|
55
|
+
{
|
|
56
|
+
"matcher": "Edit|Write",
|
|
57
|
+
"hooks": [
|
|
58
|
+
{
|
|
59
|
+
"type": "command",
|
|
60
|
+
"command": "$CLAUDE_PROJECT_DIR/.claude/hooks/pre-tool-use-guardrail.sh"
|
|
61
|
+
}
|
|
62
|
+
]
|
|
63
|
+
}
|
|
64
|
+
],
|
|
65
|
+
"Stop": [
|
|
66
|
+
{
|
|
67
|
+
"hooks": [
|
|
68
|
+
{
|
|
69
|
+
"type": "command",
|
|
70
|
+
"command": "$CLAUDE_PROJECT_DIR/.claude/hooks/error-handling-reminder.sh"
|
|
71
|
+
}
|
|
72
|
+
]
|
|
73
|
+
}
|
|
74
|
+
]
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
# Reference Implementations
|
|
2
|
+
|
|
3
|
+
**这些是参考实现,不会被 Claude Code 激活为 skills。**
|
|
4
|
+
|
|
5
|
+
## 用途
|
|
6
|
+
|
|
7
|
+
这些参考实现的作用是:
|
|
8
|
+
|
|
9
|
+
1. **为 `project-guidelines-generator` agent 提供学习样本**
|
|
10
|
+
- Agent 会读取这些文件,学习结构和模式
|
|
11
|
+
- 理解如何组织 SKILL.md 和 resources/
|
|
12
|
+
- 提取最佳实践和代码示例
|
|
13
|
+
|
|
14
|
+
2. **展示特定技术栈的最佳实践**
|
|
15
|
+
- `frontend-react-mui/`: React 18 + Material-UI v7 + TanStack Query/Router
|
|
16
|
+
- `backend-express-prisma/`: Express + Prisma + TypeScript
|
|
17
|
+
|
|
18
|
+
3. **作为生成其他技术栈 guidelines 的模板**
|
|
19
|
+
- Vue + Vuetify → 适配自 frontend-react-mui
|
|
20
|
+
- Django + SQLAlchemy → 适配自 backend-express-prisma
|
|
21
|
+
|
|
22
|
+
## 生成的技能位置
|
|
23
|
+
|
|
24
|
+
实际激活的技能位于:
|
|
25
|
+
- `.claude/skills/frontend-guidelines/` - 根据项目技术栈生成的前端指南
|
|
26
|
+
- `.claude/skills/backend-guidelines/` - 根据项目技术栈生成的后端指南
|
|
27
|
+
|
|
28
|
+
## 如何使用
|
|
29
|
+
|
|
30
|
+
运行以下命令生成适配你项目的开发指南:
|
|
31
|
+
|
|
32
|
+
```bash
|
|
33
|
+
# 生成前端指南
|
|
34
|
+
/core-guidelines --frontend
|
|
35
|
+
|
|
36
|
+
# 生成后端指南
|
|
37
|
+
/core-guidelines --backend
|
|
38
|
+
|
|
39
|
+
# 自动检测并生成(可能生成 1 或 2 个)
|
|
40
|
+
/core-guidelines
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## 技术栈映射
|
|
44
|
+
|
|
45
|
+
### Frontend Reference (React + MUI)
|
|
46
|
+
- **Framework**: React 18
|
|
47
|
+
- **UI Library**: Material-UI v7
|
|
48
|
+
- **Data Fetching**: TanStack Query (useSuspenseQuery)
|
|
49
|
+
- **Routing**: TanStack Router
|
|
50
|
+
- **State Management**: React Context + Query Cache
|
|
51
|
+
- **Styling**: MUI sx prop + styled-components
|
|
52
|
+
- **TypeScript**: Strict mode
|
|
53
|
+
|
|
54
|
+
### Backend Reference (Express + Prisma)
|
|
55
|
+
- **Runtime**: Node.js
|
|
56
|
+
- **Framework**: Express
|
|
57
|
+
- **ORM**: Prisma
|
|
58
|
+
- **Database**: MySQL (but Prisma supports多种)
|
|
59
|
+
- **Architecture**: Layered (Routes → Controllers → Services → Repositories)
|
|
60
|
+
- **Validation**: Zod schemas
|
|
61
|
+
- **Error Tracking**: Sentry
|
|
62
|
+
- **TypeScript**: Strict mode
|
|
63
|
+
|
|
64
|
+
## 维护
|
|
65
|
+
|
|
66
|
+
这些参考实现来自 `claude-code-infrastructure-showcase` 项目。
|
|
67
|
+
|
|
68
|
+
如需更新:
|
|
69
|
+
```bash
|
|
70
|
+
# 从 showcase 复制最新版本
|
|
71
|
+
cp -r claude-code-infrastructure-showcase/.claude/skills/frontend-dev-guidelines \
|
|
72
|
+
.claude/skills/_reference-implementations/frontend-react-mui
|
|
73
|
+
|
|
74
|
+
cp -r claude-code-infrastructure-showcase/.claude/skills/backend-dev-guidelines \
|
|
75
|
+
.claude/skills/_reference-implementations/backend-express-prisma
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
## 架构哲学
|
|
79
|
+
|
|
80
|
+
**为什么不直接激活这些 skills?**
|
|
81
|
+
|
|
82
|
+
因为:
|
|
83
|
+
1. **技术栈特定性**:这些是 React+MUI 和 Express+Prisma 的最佳实践,不适用于所有项目
|
|
84
|
+
2. **职责分明**:前端和后端应该是独立的 skills,各自有清晰的激活边界
|
|
85
|
+
3. **动态适配**:每个项目应该有适合自己技术栈的 guidelines
|
|
86
|
+
|
|
87
|
+
**生成系统的优势**:
|
|
88
|
+
- ✅ 自动检测项目技术栈
|
|
89
|
+
- ✅ 获取官方最新文档(Context7 MCP)
|
|
90
|
+
- ✅ 适配不同框架(React/Vue/Angular, Express/Django/FastAPI)
|
|
91
|
+
- ✅ 职责分明(frontend-guidelines vs backend-guidelines)
|
|
92
|
+
- ✅ 保持最佳实践(从参考实现学习模式)
|
|
93
|
+
|
|
94
|
+
---
|
|
95
|
+
|
|
96
|
+
**Remember**: Template is code, generation is compilation.
|