@su-record/vibe 2.9.3 → 2.9.5
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/.env.example +37 -37
- package/CLAUDE.md +190 -190
- package/LICENSE +21 -21
- package/README.ko.md +170 -170
- package/README.md +219 -219
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +294 -294
- package/agents/event/event-comms.md +78 -78
- package/agents/event/event-content.md +68 -68
- package/agents/event/event-image.md +95 -95
- package/agents/event/event-ops.md +84 -84
- package/agents/event/event-scheduler.md +69 -69
- package/agents/event/event-speaker.md +86 -86
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/junior-mentor.md +141 -141
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/qa/qa-coordinator.md +131 -131
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/teams/debug-team.md +70 -70
- package/agents/teams/dev-team.md +88 -88
- package/agents/teams/docs-team.md +80 -80
- package/agents/teams/figma/figma-analyst.md +52 -52
- package/agents/teams/figma/figma-architect.md +112 -112
- package/agents/teams/figma/figma-auditor.md +82 -82
- package/agents/teams/figma/figma-builder.md +100 -100
- package/agents/teams/figma-team.md +85 -85
- package/agents/teams/fullstack-team.md +83 -83
- package/agents/teams/lite-team.md +69 -69
- package/agents/teams/migration-team.md +78 -78
- package/agents/teams/refactor-team.md +94 -94
- package/agents/teams/research-team.md +86 -86
- package/agents/teams/review-debate-team.md +125 -125
- package/agents/teams/security-team.md +81 -81
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +102 -102
- package/agents/ui/ui-dataviz-advisor.md +69 -69
- package/agents/ui/ui-design-system-gen.md +57 -57
- package/agents/ui/ui-industry-analyzer.md +49 -49
- package/agents/ui/ui-layout-architect.md +65 -65
- package/agents/ui/ui-stack-implementer.md +68 -68
- package/agents/ui/ux-compliance-reviewer.md +81 -81
- package/agents/ui-previewer.md +258 -258
- package/commands/vibe.analyze.md +533 -533
- package/commands/vibe.docs.md +32 -32
- package/commands/vibe.event.md +163 -163
- package/commands/vibe.figma.md +584 -584
- package/commands/vibe.harness.md +177 -177
- package/commands/vibe.review.md +624 -624
- package/commands/vibe.run.md +1925 -1925
- package/commands/vibe.scaffold.md +195 -195
- package/commands/vibe.spec.md +565 -565
- package/commands/vibe.trace.md +276 -276
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +519 -519
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/codex-proxy.d.ts +10 -0
- package/dist/cli/commands/codex-proxy.d.ts.map +1 -0
- package/dist/cli/commands/codex-proxy.js +221 -0
- package/dist/cli/commands/codex-proxy.js.map +1 -0
- package/dist/cli/commands/config.js +9 -9
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/figma.js +20 -20
- package/dist/cli/commands/index.d.ts +1 -0
- package/dist/cli/commands/index.d.ts.map +1 -1
- package/dist/cli/commands/index.js +1 -0
- package/dist/cli/commands/index.js.map +1 -1
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +50 -53
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/init.js +5 -5
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/skills.js +5 -5
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/stats.js +6 -6
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +67 -53
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +18 -18
- package/dist/cli/llm/gemini-commands.js +16 -16
- package/dist/cli/llm/gpt-commands.js +19 -19
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/postinstall/constants.d.ts.map +1 -1
- package/dist/cli/postinstall/constants.js +17 -13
- package/dist/cli/postinstall/constants.js.map +1 -1
- package/dist/cli/postinstall/cursor-agents.js +32 -32
- package/dist/cli/postinstall/cursor-rules.js +83 -83
- package/dist/cli/postinstall/cursor-skills.js +743 -743
- package/dist/cli/postinstall/fs-utils.d.ts +6 -0
- package/dist/cli/postinstall/fs-utils.d.ts.map +1 -1
- package/dist/cli/postinstall/fs-utils.js +15 -0
- package/dist/cli/postinstall/fs-utils.js.map +1 -1
- package/dist/cli/postinstall/main.d.ts.map +1 -1
- package/dist/cli/postinstall/main.js +8 -8
- package/dist/cli/postinstall/main.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- package/dist/cli/types.d.ts +8 -0
- package/dist/cli/types.d.ts.map +1 -1
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/OrchestrateWorkflow.js +1 -1
- package/dist/infra/lib/PythonParser.js +108 -108
- package/dist/infra/lib/ReviewRace.js +96 -96
- package/dist/infra/lib/SkillFrontmatter.js +28 -28
- package/dist/infra/lib/SkillQualityGate.js +9 -9
- package/dist/infra/lib/SkillRepository.js +159 -159
- package/dist/infra/lib/UltraQA.js +99 -99
- package/dist/infra/lib/autonomy/AuditStore.js +41 -41
- package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
- package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
- package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
- package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
- package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
- package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
- package/dist/infra/lib/codex-proxy.d.ts +21 -0
- package/dist/infra/lib/codex-proxy.d.ts.map +1 -0
- package/dist/infra/lib/codex-proxy.js +510 -0
- package/dist/infra/lib/codex-proxy.js.map +1 -0
- package/dist/infra/lib/embedding/VectorStore.js +22 -22
- package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
- package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
- package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
- package/dist/infra/lib/evolution/InsightStore.js +90 -90
- package/dist/infra/lib/evolution/ParityTester.js +57 -57
- package/dist/infra/lib/evolution/RollbackManager.js +5 -5
- package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
- package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
- package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
- package/dist/infra/lib/evolution/UsageTracker.js +28 -28
- package/dist/infra/lib/gemini/orchestration.js +5 -5
- package/dist/infra/lib/gpt/orchestration.js +4 -4
- package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/infra/lib/memory/MemorySearch.js +57 -57
- package/dist/infra/lib/memory/MemoryStorage.js +181 -181
- package/dist/infra/lib/memory/ObservationStore.js +28 -28
- package/dist/infra/lib/memory/ReflectionStore.js +30 -30
- package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
- package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
- package/dist/infra/lib/telemetry/SkillTelemetry.test.js +4 -4
- package/dist/infra/orchestrator/AgentManager.js +12 -12
- package/dist/infra/orchestrator/AgentRegistry.js +65 -65
- package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/infra/orchestrator/parallelResearch.js +24 -24
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/memory/createMemoryTimeline.js +10 -10
- package/dist/tools/memory/getMemoryGraph.js +12 -12
- package/dist/tools/memory/getSessionContext.js +9 -9
- package/dist/tools/memory/linkMemories.js +14 -14
- package/dist/tools/memory/listMemories.js +4 -4
- package/dist/tools/memory/recallMemory.js +4 -4
- package/dist/tools/memory/saveMemory.js +4 -4
- package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
- package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
- package/dist/tools/semantic/astGrep.test.js +6 -6
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/hooks/gemini-hooks.json +73 -73
- package/hooks/hooks.json +174 -174
- package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
- package/hooks/scripts/__tests__/pre-tool-guard.test.js +286 -286
- package/hooks/scripts/__tests__/sentinel-guard.test.js +210 -210
- package/hooks/scripts/auto-commit.js +97 -97
- package/hooks/scripts/auto-format.js +64 -64
- package/hooks/scripts/auto-test.js +81 -81
- package/hooks/scripts/code-check.js +268 -268
- package/hooks/scripts/codex-detect.js +46 -46
- package/hooks/scripts/codex-review-gate.js +80 -80
- package/hooks/scripts/command-log.js +32 -32
- package/hooks/scripts/context-save.js +353 -353
- package/hooks/scripts/evolution-engine.js +91 -91
- package/hooks/scripts/figma-extract.js +635 -635
- package/hooks/scripts/figma-guard.js +220 -220
- package/hooks/scripts/figma-refine.js +315 -315
- package/hooks/scripts/figma-to-scss.js +394 -394
- package/hooks/scripts/figma-validate.js +353 -353
- package/hooks/scripts/hud-status.js +321 -321
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +572 -572
- package/hooks/scripts/post-edit.js +32 -32
- package/hooks/scripts/pr-test-gate.js +52 -52
- package/hooks/scripts/pre-tool-guard.js +214 -214
- package/hooks/scripts/prompt-dispatcher.js +185 -185
- package/hooks/scripts/sentinel-guard.js +131 -131
- package/hooks/scripts/session-start.js +177 -177
- package/hooks/scripts/skill-injector.js +83 -83
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +243 -243
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +101 -101
- package/skills/agents-md/SKILL.md +121 -121
- package/skills/agents-md/rubrics/what-to-keep.md +49 -49
- package/skills/agents-md/templates/agents-md.md +36 -36
- package/skills/arch-guard/SKILL.md +181 -181
- package/skills/arch-guard/agents/detector.md +48 -48
- package/skills/arch-guard/agents/reporter.md +48 -48
- package/skills/arch-guard/agents/rule-generator.md +49 -49
- package/skills/arch-guard/agents/violation-checker.md +51 -51
- package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
- package/skills/arch-guard/frameworks/solid.md +102 -102
- package/skills/arch-guard/scripts/check-boundaries.js +90 -90
- package/skills/arch-guard/templates/arch-rules.json +47 -47
- package/skills/arch-guard/templates/violation-report.md +53 -53
- package/skills/brand-assets/SKILL.md +147 -147
- package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
- package/skills/brand-assets/templates/brand-guide.md +161 -161
- package/skills/capability-loop/SKILL.md +272 -272
- package/skills/capability-loop/agents/capability-designer.md +61 -61
- package/skills/capability-loop/agents/failure-analyst.md +55 -55
- package/skills/capability-loop/agents/implementer.md +50 -50
- package/skills/capability-loop/agents/tester.md +53 -53
- package/skills/capability-loop/templates/capability-spec.md +118 -118
- package/skills/capability-loop/templates/failure-analysis.md +118 -118
- package/skills/characterization-test/SKILL.md +207 -207
- package/skills/characterization-test/agents/behavior-capturer.md +50 -50
- package/skills/characterization-test/agents/coverage-checker.md +54 -54
- package/skills/characterization-test/agents/reporter.md +50 -50
- package/skills/characterization-test/agents/test-writer.md +49 -49
- package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
- package/skills/characterization-test/templates/test-template.ts +101 -101
- package/skills/chub-usage/SKILL.md +139 -139
- package/skills/claude-md-guide/SKILL.md +351 -351
- package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
- package/skills/claude-md-guide/templates/claude-md.md +54 -54
- package/skills/commerce-patterns/SKILL.md +64 -64
- package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
- package/skills/commerce-patterns/templates/product-schema.md +85 -85
- package/skills/commit-push-pr/SKILL.md +77 -77
- package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
- package/skills/commit-push-pr/agents/message-writer.md +50 -50
- package/skills/commit-push-pr/agents/pr-writer.md +58 -58
- package/skills/commit-push-pr/agents/reviewer.md +52 -52
- package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
- package/skills/commit-push-pr/templates/pr-body.md +63 -63
- package/skills/context7-usage/SKILL.md +106 -106
- package/skills/context7-usage/rubrics/when-to-use.md +50 -50
- package/skills/create-prd/SKILL.md +90 -90
- package/skills/create-prd/agents/edge-case-finder.md +48 -48
- package/skills/create-prd/agents/prioritizer.md +60 -60
- package/skills/create-prd/agents/requirements-writer.md +48 -48
- package/skills/create-prd/agents/researcher.md +55 -55
- package/skills/create-prd/agents/reviewer.md +54 -54
- package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
- package/skills/create-prd/frameworks/rice-scoring.md +97 -97
- package/skills/create-prd/orchestrator.md +70 -70
- package/skills/create-prd/rubrics/completeness.md +58 -58
- package/skills/create-prd/templates/prd.md +139 -139
- package/skills/design-audit/SKILL.md +152 -152
- package/skills/design-audit/agents/a11y-auditor.md +43 -43
- package/skills/design-audit/agents/performance-auditor.md +46 -46
- package/skills/design-audit/agents/responsive-auditor.md +46 -46
- package/skills/design-audit/agents/scorer.md +47 -47
- package/skills/design-audit/agents/slop-detector.md +47 -47
- package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
- package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
- package/skills/design-audit/orchestrator.md +64 -64
- package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
- package/skills/design-audit/rubrics/scoring.md +63 -63
- package/skills/design-audit/templates/report.md +88 -88
- package/skills/design-critique/SKILL.md +139 -139
- package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
- package/skills/design-critique/templates/critique-report.md +86 -86
- package/skills/design-distill/SKILL.md +130 -130
- package/skills/design-distill/templates/design-system.md +132 -132
- package/skills/design-normalize/SKILL.md +133 -133
- package/skills/design-normalize/rubrics/token-naming.md +117 -117
- package/skills/design-normalize/templates/token-audit.md +89 -89
- package/skills/design-polish/SKILL.md +131 -131
- package/skills/design-polish/rubrics/polish-checklist.md +68 -68
- package/skills/design-polish/templates/polish-report.md +64 -64
- package/skills/design-teach/SKILL.md +182 -182
- package/skills/design-teach/rubrics/brand-personality.md +73 -73
- package/skills/design-teach/templates/design-context.json +36 -36
- package/skills/devlog/SKILL.md +143 -143
- package/skills/e2e-commerce/SKILL.md +62 -62
- package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
- package/skills/event-comms/SKILL.md +172 -172
- package/skills/event-comms/templates/email-invite.md +99 -99
- package/skills/event-comms/templates/sns-post.md +133 -133
- package/skills/event-ops/SKILL.md +207 -207
- package/skills/event-ops/rubrics/contingency.md +85 -85
- package/skills/event-ops/templates/d-day-checklist.md +65 -65
- package/skills/event-planning/SKILL.md +144 -144
- package/skills/event-planning/rubrics/timeline.md +70 -70
- package/skills/event-planning/templates/event-plan.md +91 -91
- package/skills/exec-plan/SKILL.md +149 -149
- package/skills/exec-plan/agents/decomposer.md +47 -47
- package/skills/exec-plan/agents/dependency-mapper.md +44 -44
- package/skills/exec-plan/agents/estimator.md +43 -43
- package/skills/exec-plan/agents/validator.md +55 -55
- package/skills/exec-plan/orchestrator.md +70 -70
- package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
- package/skills/exec-plan/templates/plan.md +147 -147
- package/skills/git-worktree/SKILL.md +73 -73
- package/skills/git-worktree/rubrics/when-to-use.md +55 -55
- package/skills/handoff/SKILL.md +110 -110
- package/skills/handoff/agents/context-summarizer.md +51 -51
- package/skills/handoff/agents/document-writer.md +63 -63
- package/skills/handoff/agents/state-collector.md +53 -53
- package/skills/handoff/agents/verifier.md +48 -48
- package/skills/handoff/rubrics/completeness.md +62 -62
- package/skills/handoff/templates/handoff.md +107 -107
- package/skills/parallel-research/SKILL.md +89 -89
- package/skills/parallel-research/agents/best-practices.md +43 -43
- package/skills/parallel-research/agents/codebase-patterns.md +46 -46
- package/skills/parallel-research/agents/framework-docs.md +45 -45
- package/skills/parallel-research/agents/security-advisory.md +46 -46
- package/skills/parallel-research/agents/synthesizer.md +52 -52
- package/skills/parallel-research/experts/best-practices.md +50 -50
- package/skills/parallel-research/experts/codebase-patterns.md +70 -70
- package/skills/parallel-research/experts/framework-docs.md +65 -65
- package/skills/parallel-research/experts/security-advisory.md +69 -69
- package/skills/parallel-research/orchestrator.md +65 -65
- package/skills/parallel-research/templates/synthesis.md +101 -101
- package/skills/prioritization-frameworks/SKILL.md +87 -87
- package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
- package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
- package/skills/priority-todos/SKILL.md +64 -64
- package/skills/priority-todos/rubrics/prioritization.md +70 -70
- package/skills/priority-todos/templates/todo-board.md +59 -59
- package/skills/seo-checklist/SKILL.md +58 -58
- package/skills/seo-checklist/frameworks/structured-data.md +153 -153
- package/skills/seo-checklist/rubrics/content-seo.md +42 -42
- package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
- package/skills/techdebt/SKILL.md +124 -124
- package/skills/techdebt/agents/analyzer.md +50 -50
- package/skills/techdebt/agents/fixer.md +41 -41
- package/skills/techdebt/agents/reviewer.md +47 -47
- package/skills/techdebt/agents/scanner.md +44 -44
- package/skills/techdebt/orchestrator.md +70 -70
- package/skills/techdebt/rubrics/severity.md +51 -51
- package/skills/techdebt/scripts/scan.js +90 -90
- package/skills/techdebt/templates/report.md +86 -86
- package/skills/tool-fallback/SKILL.md +104 -104
- package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
- package/skills/typescript-advanced-types/SKILL.md +67 -67
- package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
- package/skills/ui-ux-pro-max/SKILL.md +236 -236
- package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
- package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
- package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
- package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
- package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
- package/skills/ui-ux-pro-max/reference/typography.md +455 -455
- package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
- package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
- package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
- package/skills/user-personas/SKILL.md +75 -75
- package/skills/user-personas/rubrics/research-methods.md +56 -56
- package/skills/user-personas/templates/persona.md +89 -89
- package/skills/vercel-react-best-practices/SKILL.md +60 -60
- package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
- package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
- package/skills/{vibe.docs → vibe-docs}/SKILL.md +171 -171
- package/skills/{vibe.docs → vibe-docs}/templates/architecture.md +80 -80
- package/skills/{vibe.docs → vibe-docs}/templates/readme.md +84 -84
- package/skills/{vibe.docs → vibe-docs}/templates/release-notes.md +74 -74
- package/skills/{vibe.figma → vibe-figma}/SKILL.md +363 -363
- package/skills/{vibe.figma → vibe-figma}/rubrics/extraction-checklist.md +51 -51
- package/skills/{vibe.figma → vibe-figma}/templates/component-index.md +126 -126
- package/skills/{vibe.figma → vibe-figma}/templates/component-spec.md +168 -168
- package/skills/{vibe.figma → vibe-figma}/templates/figma-handoff.md +100 -100
- package/skills/{vibe.figma → vibe-figma}/templates/remapped-tree.md +277 -277
- package/skills/{vibe.figma.convert → vibe-figma-convert}/SKILL.md +235 -235
- package/skills/{vibe.figma.convert → vibe-figma-convert}/rubrics/conversion-rules.md +141 -141
- package/skills/{vibe.figma.convert → vibe-figma-convert}/templates/component.md +140 -140
- package/skills/{vibe.figma.extract → vibe-figma-extract}/SKILL.md +219 -219
- package/skills/{vibe.figma.extract → vibe-figma-extract}/rubrics/image-rules.md +157 -157
- package/skills/{vibe.interview → vibe-interview}/SKILL.md +358 -358
- package/skills/{vibe.interview → vibe-interview}/checklists/api.md +101 -101
- package/skills/{vibe.interview → vibe-interview}/checklists/feature.md +88 -88
- package/skills/{vibe.interview → vibe-interview}/checklists/library.md +95 -95
- package/skills/{vibe.interview → vibe-interview}/checklists/mobile.md +89 -89
- package/skills/{vibe.interview → vibe-interview}/checklists/webapp.md +97 -97
- package/skills/{vibe.interview → vibe-interview}/checklists/website.md +99 -99
- package/skills/{vibe.plan → vibe-plan}/SKILL.md +254 -216
- package/skills/{vibe.spec → vibe-spec}/SKILL.md +1155 -1155
- package/skills/{vibe.spec.review → vibe-spec-review}/SKILL.md +726 -726
- package/skills/video-production/SKILL.md +52 -52
- package/skills/video-production/rubrics/quality-checklist.md +58 -58
- package/skills/video-production/templates/production-plan.md +104 -104
- package/vibe/config.json +29 -29
- package/vibe/constitution.md +227 -227
- package/vibe/rules/principles/communication-guide.md +98 -98
- package/vibe/rules/principles/development-philosophy.md +52 -52
- package/vibe/rules/principles/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/performance.md +236 -236
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/git-workflow.md +237 -237
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/rules/standards/security.md +305 -305
- package/vibe/rules/writing/document-style.md +74 -74
- package/vibe/setup.sh +31 -31
- package/vibe/templates/claudemd-template.md +74 -74
- package/vibe/templates/constitution-template.md +267 -267
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/plan-template.md +194 -194
- package/vibe/templates/spec-template.md +221 -221
- package/vibe/ui-ux-data/charts.csv +26 -26
- package/vibe/ui-ux-data/colors.csv +97 -97
- package/vibe/ui-ux-data/icons.csv +101 -101
- package/vibe/ui-ux-data/landing.csv +31 -31
- package/vibe/ui-ux-data/products.csv +96 -96
- package/vibe/ui-ux-data/react-performance.csv +45 -45
- package/vibe/ui-ux-data/stacks/astro.csv +54 -54
- package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
- package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
- package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
- package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
- package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
- package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
- package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
- package/vibe/ui-ux-data/stacks/react.csv +54 -54
- package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
- package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
- package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
- package/vibe/ui-ux-data/stacks/vue.csv +50 -50
- package/vibe/ui-ux-data/styles.csv +68 -68
- package/vibe/ui-ux-data/typography.csv +57 -57
- package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
- package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
- package/vibe/ui-ux-data/version.json +31 -31
- package/vibe/ui-ux-data/web-interface.csv +31 -31
|
@@ -1,351 +1,351 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: claude-md-guide
|
|
3
|
-
tier: standard
|
|
4
|
-
description: "Guide for writing effective CLAUDE.md files from scratch. Evidence-based methodology from 40+ sources including research papers, official docs, and real-world examples. Covers 3-layer architecture, Curse of Instructions mitigation, progressive disclosure, and maintenance. Use when creating new CLAUDE.md, improving existing ones, or teaching team members how to write project instructions for AI agents."
|
|
5
|
-
triggers: [claude-md guide, write claude.md, create claude.md, claude.md 작성, 클로드 문서, project instructions, claude-md]
|
|
6
|
-
priority: 55
|
|
7
|
-
chain-next: [agents-md]
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# claude-md-guide — CLAUDE.md Writing Guide
|
|
11
|
-
|
|
12
|
-
> **Principle**: "Would the agent make a mistake without this?" → If No, delete it. If Yes, keep it.
|
|
13
|
-
|
|
14
|
-
## Why This Matters
|
|
15
|
-
|
|
16
|
-
Research shows that LLM compliance drops **exponentially** as the number of instructions increases (Curse of Instructions):
|
|
17
|
-
|
|
18
|
-
| Instructions | GPT-4o Compliance | Claude Sonnet Compliance |
|
|
19
|
-
|-------------|------------------|--------------------------|
|
|
20
|
-
| 1 | ~85% | ~90% |
|
|
21
|
-
| 5 | ~44% | ~59% |
|
|
22
|
-
| 10 | ~15% | ~44% |
|
|
23
|
-
| 15+ | ~5% | ~15% |
|
|
24
|
-
|
|
25
|
-
**Conclusion**: Every line has a cost. A short, precise CLAUDE.md is better than a long, comprehensive one.
|
|
26
|
-
|
|
27
|
-
---
|
|
28
|
-
|
|
29
|
-
## Step 1: Project Exploration — Auto-Collect
|
|
30
|
-
|
|
31
|
-
Explore the project before writing CLAUDE.md:
|
|
32
|
-
|
|
33
|
-
```
|
|
34
|
-
Glob: pattern="package.json" → Check stack and scripts
|
|
35
|
-
Glob: pattern="*.config.*" → Build/lint configuration
|
|
36
|
-
Glob: pattern="tsconfig.json" → TypeScript configuration
|
|
37
|
-
Glob: pattern=".env.example" → Environment variable structure
|
|
38
|
-
Glob: pattern="Makefile" → Build system
|
|
39
|
-
Glob: pattern="docker-compose.*" → Infrastructure structure
|
|
40
|
-
Glob: pattern="CLAUDE.md" → Check for existing file
|
|
41
|
-
Glob: pattern="AGENTS.md" → Check for compatible file
|
|
42
|
-
```
|
|
43
|
-
|
|
44
|
-
Summarize the collected information for the user, then ask about any missing context.
|
|
45
|
-
|
|
46
|
-
## Step 2: Interview — Extract Non-Discoverable Information
|
|
47
|
-
|
|
48
|
-
Only ask about information that cannot be found through auto-exploration. **One question at a time, multiple-choice when possible:**
|
|
49
|
-
|
|
50
|
-
### Question Categories
|
|
51
|
-
|
|
52
|
-
**1. Runtime Traps**
|
|
53
|
-
- Are there runtime differences not visible in the code? (e.g., Bun vs Node, ESM vs CJS)
|
|
54
|
-
- Are there bugs that only occur in certain environments?
|
|
55
|
-
|
|
56
|
-
**2. Forbidden Patterns**
|
|
57
|
-
- Are there libraries/patterns that must never be used?
|
|
58
|
-
- Are there approaches that caused problems in the past?
|
|
59
|
-
|
|
60
|
-
**3. Non-standard Conventions**
|
|
61
|
-
- Are there naming/structure rules that differ from standards?
|
|
62
|
-
- Are there special workflows agreed upon by the team?
|
|
63
|
-
|
|
64
|
-
**4. Architecture Decisions**
|
|
65
|
-
- Are there design reasons that can't be inferred from the code alone?
|
|
66
|
-
- Is there business context behind why certain patterns were chosen?
|
|
67
|
-
|
|
68
|
-
**5. Boundaries**
|
|
69
|
-
- Are there files/directories the agent must never touch?
|
|
70
|
-
- Are there areas that require approval before changes are made?
|
|
71
|
-
|
|
72
|
-
## Step 3: Structure Design — 3-Layer Architecture
|
|
73
|
-
|
|
74
|
-
Separate the collected information into 3 layers:
|
|
75
|
-
|
|
76
|
-
### Layer 1: CLAUDE.md (Project Constitution)
|
|
77
|
-
|
|
78
|
-
**Auto-loaded every session** → only universal, stable information.
|
|
79
|
-
|
|
80
|
-
```markdown
|
|
81
|
-
# {Project Name}
|
|
82
|
-
|
|
83
|
-
{1-2 sentences on what the project is. Only if the purpose isn't clear from the code.}
|
|
84
|
-
|
|
85
|
-
## Tech Stack
|
|
86
|
-
{Only what can't be inferred immediately from package.json. e.g., "Bun runtime (not Node)"}
|
|
87
|
-
|
|
88
|
-
## Commands
|
|
89
|
-
{Only what's missing from package.json scripts or non-intuitive}
|
|
90
|
-
- `npm run build && npx vitest run` — build then test (order matters)
|
|
91
|
-
|
|
92
|
-
## Conventions
|
|
93
|
-
{Only what the linter can't catch}
|
|
94
|
-
- ESM only — imports need `.js` extension
|
|
95
|
-
- {Any non-standard naming rules}
|
|
96
|
-
|
|
97
|
-
## Gotchas
|
|
98
|
-
{Things the agent will repeatedly get wrong}
|
|
99
|
-
- **{Trap title}.** {Specific do/don't explanation}
|
|
100
|
-
|
|
101
|
-
## Boundaries
|
|
102
|
-
✅ Always: {things to always do}
|
|
103
|
-
⚠️ Ask first: {things requiring approval first}
|
|
104
|
-
🚫 Never: {absolute prohibitions}
|
|
105
|
-
```
|
|
106
|
-
|
|
107
|
-
### Layer 2: SPEC.md (Per-Feature Design Document)
|
|
108
|
-
|
|
109
|
-
**Loaded only when working on a specific feature** → focus on what and why, leave how to the agent.
|
|
110
|
-
|
|
111
|
-
Storage location: `.claude/vibe/specs/YYYY-MM-DD-{topic}.md`
|
|
112
|
-
|
|
113
|
-
```markdown
|
|
114
|
-
# {Feature Name} SPEC
|
|
115
|
-
|
|
116
|
-
## Purpose (Why)
|
|
117
|
-
## Requirements (What)
|
|
118
|
-
## Success Criteria (Acceptance Criteria)
|
|
119
|
-
## Technical Constraints (Constraints)
|
|
120
|
-
## Boundaries (Out of Scope)
|
|
121
|
-
```
|
|
122
|
-
|
|
123
|
-
### Layer 3: plan.md (Execution Plan)
|
|
124
|
-
|
|
125
|
-
**Per-session task list** → 2-5 minute units, with file paths specified.
|
|
126
|
-
|
|
127
|
-
Storage location: `.claude/vibe/specs/{name}-execplan.md`
|
|
128
|
-
|
|
129
|
-
```markdown
|
|
130
|
-
# Execution Plan
|
|
131
|
-
|
|
132
|
-
## Task 1: {Title}
|
|
133
|
-
- Files: `src/foo.ts`, `src/foo.test.ts`
|
|
134
|
-
- Action: {Specific change}
|
|
135
|
-
- Verify: `npm test src/foo.test.ts`
|
|
136
|
-
|
|
137
|
-
## Task 2: ...
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
## Step 4: Writing — Apply Evidence-Based Principles
|
|
141
|
-
|
|
142
|
-
### Size Limits
|
|
143
|
-
|
|
144
|
-
| Grade | Lines | When Appropriate |
|
|
145
|
-
|-------|-------|-----------------|
|
|
146
|
-
| Optimal | 60-150 | Most projects |
|
|
147
|
-
| Acceptable | 150-200 | Complex monorepos |
|
|
148
|
-
| Warning | 200-300 | Separation needed |
|
|
149
|
-
| Danger | 300+ | Agent ignores half of it |
|
|
150
|
-
|
|
151
|
-
### Attention Distribution by Position (Lost in the Middle Effect)
|
|
152
|
-
|
|
153
|
-
LLMs focus on the **beginning and end** of a document and **ignore the middle**:
|
|
154
|
-
|
|
155
|
-
```
|
|
156
|
-
Attention: ████████░░░░░░░░████████
|
|
157
|
-
^start ^middle(↓20-40%) ^end
|
|
158
|
-
```
|
|
159
|
-
|
|
160
|
-
**Countermeasures**:
|
|
161
|
-
- **Most important rules** → place at the top of the document
|
|
162
|
-
- **Frequently violated rules** → place at the bottom (end) of the document
|
|
163
|
-
- **Background information** → place in the middle (OK if ignored)
|
|
164
|
-
|
|
165
|
-
### Include vs Exclude Checklist
|
|
166
|
-
|
|
167
|
-
**✅ Include (non-discoverable, operationally important)**
|
|
168
|
-
|
|
169
|
-
| Type | Example |
|
|
170
|
-
|------|---------|
|
|
171
|
-
| Runtime traps | "Bun runtime, not Node" |
|
|
172
|
-
| Forbidden patterns | "Never use `any`, use `unknown` + type guards" |
|
|
173
|
-
| SSOT location | "Only edit `constants.ts` for stack mapping" |
|
|
174
|
-
| Order invariants | "Build before test, always" |
|
|
175
|
-
| Non-standard commands | Compound commands, special flags |
|
|
176
|
-
| Security rules | Auth, path traversal prevention, etc. |
|
|
177
|
-
|
|
178
|
-
**❌ Exclude (discoverable or delegate to other tools)**
|
|
179
|
-
|
|
180
|
-
| Type | Reason | Alternative |
|
|
181
|
-
|------|--------|-------------|
|
|
182
|
-
| Directory structure | Discoverable via `ls` | The code itself |
|
|
183
|
-
| Tech stack list | In `package.json` | The code itself |
|
|
184
|
-
| Code style (indentation, semicolons) | Linter catches it | ESLint, Prettier |
|
|
185
|
-
| API documentation | Readable from code | Swagger, JSDoc |
|
|
186
|
-
| General best practices | LLM already knows | Unnecessary |
|
|
187
|
-
| API keys, secrets | Goes stale quickly | `.env`, vault |
|
|
188
|
-
| Per-feature detailed instructions | Move to Layer 2 | SPEC.md |
|
|
189
|
-
|
|
190
|
-
### Emphasis Techniques
|
|
191
|
-
|
|
192
|
-
Use these when important rules keep getting ignored:
|
|
193
|
-
|
|
194
|
-
```markdown
|
|
195
|
-
**IMPORTANT**: {critical rule}
|
|
196
|
-
**MUST**: {mandatory action}
|
|
197
|
-
**NEVER**: {absolute prohibition}
|
|
198
|
-
```
|
|
199
|
-
|
|
200
|
-
However, adding emphasis to every line **nullifies the emphasis**. Use only for P1 rules.
|
|
201
|
-
|
|
202
|
-
### Progressive Disclosure
|
|
203
|
-
|
|
204
|
-
Don't put everything in CLAUDE.md — reference it:
|
|
205
|
-
|
|
206
|
-
```markdown
|
|
207
|
-
# Architecture
|
|
208
|
-
See @docs/ARCHITECTURE.md for design decisions.
|
|
209
|
-
|
|
210
|
-
# Security
|
|
211
|
-
@.claude/rules/security.md
|
|
212
|
-
```
|
|
213
|
-
|
|
214
|
-
Claude Code follows `@` references and loads them only when needed.
|
|
215
|
-
|
|
216
|
-
## Step 5: Validation — Writing Quality Check
|
|
217
|
-
|
|
218
|
-
Validate the written CLAUDE.md:
|
|
219
|
-
|
|
220
|
-
### Line-by-Line Validation
|
|
221
|
-
|
|
222
|
-
4 questions for every line:
|
|
223
|
-
|
|
224
|
-
1. **Would the agent make a mistake without this?** → If No, delete
|
|
225
|
-
2. **Is it needed in every session?** → If No, move to Layer 2/3
|
|
226
|
-
3. **Can a linter/hook replace it?** → If Yes, move to linter/hook
|
|
227
|
-
4. **Is it discoverable from code?** → If Yes, delete
|
|
228
|
-
|
|
229
|
-
### Anchoring Warning
|
|
230
|
-
|
|
231
|
-
Mentioning a technology name biases the agent toward it:
|
|
232
|
-
- ❌ "We use React" → unnecessary (it's in package.json)
|
|
233
|
-
- ✅ "Never use jQuery, even for legacy code" → useful (prevents a trap)
|
|
234
|
-
|
|
235
|
-
### Token Efficiency
|
|
236
|
-
|
|
237
|
-
| Problem | Example | Improvement |
|
|
238
|
-
|---------|---------|-------------|
|
|
239
|
-
| Verbose explanation | "Please always make sure to..." | "Always:" |
|
|
240
|
-
| Duplication | Same rule repeated in different wording | State it once |
|
|
241
|
-
| Unnecessary context | "As we discussed..." | Delete |
|
|
242
|
-
|
|
243
|
-
## Step 6: Maintenance — A Living Document
|
|
244
|
-
|
|
245
|
-
### Incremental Addition Pattern
|
|
246
|
-
|
|
247
|
-
Don't try to write it perfectly from the start:
|
|
248
|
-
|
|
249
|
-
```
|
|
250
|
-
1. Start with a minimal CLAUDE.md (30-50 lines)
|
|
251
|
-
2. Observe where the agent makes mistakes
|
|
252
|
-
3. Only add rules for recurring mistakes
|
|
253
|
-
4. Clean up unnecessary lines every 2-3 weeks
|
|
254
|
-
```
|
|
255
|
-
|
|
256
|
-
### Reflection Loop (Addy Osmani Pattern)
|
|
257
|
-
|
|
258
|
-
```
|
|
259
|
-
Agent task complete
|
|
260
|
-
→ Ask "What was different from expectations?"
|
|
261
|
-
→ When a recurring pattern is found, add 1 line to CLAUDE.md
|
|
262
|
-
→ If the root cause is code structure, fix the code and don't add a rule
|
|
263
|
-
```
|
|
264
|
-
|
|
265
|
-
### Warning Signs
|
|
266
|
-
|
|
267
|
-
| Signal | Meaning | Response |
|
|
268
|
-
|--------|---------|----------|
|
|
269
|
-
| Over 300 lines | Information overload | Split or trim |
|
|
270
|
-
| Same mistake repeats | Rule is lost in noise | Emphasize or consolidate |
|
|
271
|
-
| Adding rules has no effect | File is too long | Fix root cause |
|
|
272
|
-
| Team ignores rules | Discoverable information | Delete |
|
|
273
|
-
|
|
274
|
-
---
|
|
275
|
-
|
|
276
|
-
## Quick Reference: Guide by Project Scale
|
|
277
|
-
|
|
278
|
-
### Small (fewer than 10 files)
|
|
279
|
-
|
|
280
|
-
```markdown
|
|
281
|
-
# {Project Name}
|
|
282
|
-
|
|
283
|
-
## Commands
|
|
284
|
-
- `{build}` — {description}
|
|
285
|
-
- `{test}` — {description}
|
|
286
|
-
|
|
287
|
-
## Gotchas
|
|
288
|
-
- **{Trap 1}.** {description}
|
|
289
|
-
- **{Trap 2}.** {description}
|
|
290
|
-
|
|
291
|
-
## Never
|
|
292
|
-
- 🚫 {prohibited item}
|
|
293
|
-
```
|
|
294
|
-
|
|
295
|
-
**Target: 20-30 lines**
|
|
296
|
-
|
|
297
|
-
### Medium (10-50 files)
|
|
298
|
-
|
|
299
|
-
Above + add Conventions and Boundaries sections.
|
|
300
|
-
|
|
301
|
-
**Target: 60-150 lines**
|
|
302
|
-
|
|
303
|
-
### Large (50+ files, monorepo)
|
|
304
|
-
|
|
305
|
-
Root CLAUDE.md (shared rules) + CLAUDE.md per subdirectory.
|
|
306
|
-
|
|
307
|
-
```
|
|
308
|
-
project/
|
|
309
|
-
├── CLAUDE.md ← shared (60 lines)
|
|
310
|
-
├── packages/api/CLAUDE.md ← API-specific (30 lines)
|
|
311
|
-
├── packages/web/CLAUDE.md ← web-specific (30 lines)
|
|
312
|
-
└── .claude/rules/ ← path-specific rules
|
|
313
|
-
├── security.md
|
|
314
|
-
└── testing.md
|
|
315
|
-
```
|
|
316
|
-
|
|
317
|
-
**Target: root 100 lines + each subdirectory 30 lines**
|
|
318
|
-
|
|
319
|
-
---
|
|
320
|
-
|
|
321
|
-
## Session Separation Principle
|
|
322
|
-
|
|
323
|
-
Splitting CLAUDE.md writing into separate sessions improves quality:
|
|
324
|
-
|
|
325
|
-
| Session | Goal | Output |
|
|
326
|
-
|---------|------|--------|
|
|
327
|
-
| Session 1 | Project exploration + interview | Draft |
|
|
328
|
-
| Session 2 | Validation + optimization | Final version |
|
|
329
|
-
| Ongoing | Incremental maintenance | Continuous improvement |
|
|
330
|
-
|
|
331
|
-
After writing: run `→ /agents-md` skill for optimization validation.
|
|
332
|
-
|
|
333
|
-
---
|
|
334
|
-
|
|
335
|
-
## References
|
|
336
|
-
|
|
337
|
-
### Research
|
|
338
|
-
- [Curse of Instructions: LLMs Cannot Follow Multiple Instructions at Once](https://openreview.net/forum?id=R6q67CDBCH)
|
|
339
|
-
- [Lost in the Middle: How Language Models Use Long Contexts](https://arxiv.org/abs/2307.03172)
|
|
340
|
-
- [The Instruction Hierarchy: Training LLMs to Prioritize Privileged Instructions](https://arxiv.org/html/2404.13208v1)
|
|
341
|
-
- [Context Length Alone Hurts LLM Performance Despite Perfect Retrieval](https://arxiv.org/html/2510.05381v1)
|
|
342
|
-
|
|
343
|
-
### Official Docs
|
|
344
|
-
- [Claude Code Best Practices](https://code.claude.com/docs/en/best-practices)
|
|
345
|
-
- [Using CLAUDE.md Files](https://claude.com/blog/using-claude-md-files)
|
|
346
|
-
|
|
347
|
-
### Community
|
|
348
|
-
- [Addy Osmani: AGENTS.md](https://addyosmani.com/blog/agents-md/)
|
|
349
|
-
- [HumanLayer: Writing a good CLAUDE.md](https://www.humanlayer.dev/blog/writing-a-good-claude-md)
|
|
350
|
-
- [Builder.io: CLAUDE.md Guide](https://www.builder.io/blog/claude-md-guide)
|
|
351
|
-
- [GitHub Blog: How to Write a Great agents.md](https://github.blog/ai-and-ml/github-copilot/how-to-write-a-great-agents-md-lessons-from-over-2500-repositories/)
|
|
1
|
+
---
|
|
2
|
+
name: claude-md-guide
|
|
3
|
+
tier: standard
|
|
4
|
+
description: "Guide for writing effective CLAUDE.md files from scratch. Evidence-based methodology from 40+ sources including research papers, official docs, and real-world examples. Covers 3-layer architecture, Curse of Instructions mitigation, progressive disclosure, and maintenance. Use when creating new CLAUDE.md, improving existing ones, or teaching team members how to write project instructions for AI agents."
|
|
5
|
+
triggers: [claude-md guide, write claude.md, create claude.md, claude.md 작성, 클로드 문서, project instructions, claude-md]
|
|
6
|
+
priority: 55
|
|
7
|
+
chain-next: [agents-md]
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# claude-md-guide — CLAUDE.md Writing Guide
|
|
11
|
+
|
|
12
|
+
> **Principle**: "Would the agent make a mistake without this?" → If No, delete it. If Yes, keep it.
|
|
13
|
+
|
|
14
|
+
## Why This Matters
|
|
15
|
+
|
|
16
|
+
Research shows that LLM compliance drops **exponentially** as the number of instructions increases (Curse of Instructions):
|
|
17
|
+
|
|
18
|
+
| Instructions | GPT-4o Compliance | Claude Sonnet Compliance |
|
|
19
|
+
|-------------|------------------|--------------------------|
|
|
20
|
+
| 1 | ~85% | ~90% |
|
|
21
|
+
| 5 | ~44% | ~59% |
|
|
22
|
+
| 10 | ~15% | ~44% |
|
|
23
|
+
| 15+ | ~5% | ~15% |
|
|
24
|
+
|
|
25
|
+
**Conclusion**: Every line has a cost. A short, precise CLAUDE.md is better than a long, comprehensive one.
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
## Step 1: Project Exploration — Auto-Collect
|
|
30
|
+
|
|
31
|
+
Explore the project before writing CLAUDE.md:
|
|
32
|
+
|
|
33
|
+
```
|
|
34
|
+
Glob: pattern="package.json" → Check stack and scripts
|
|
35
|
+
Glob: pattern="*.config.*" → Build/lint configuration
|
|
36
|
+
Glob: pattern="tsconfig.json" → TypeScript configuration
|
|
37
|
+
Glob: pattern=".env.example" → Environment variable structure
|
|
38
|
+
Glob: pattern="Makefile" → Build system
|
|
39
|
+
Glob: pattern="docker-compose.*" → Infrastructure structure
|
|
40
|
+
Glob: pattern="CLAUDE.md" → Check for existing file
|
|
41
|
+
Glob: pattern="AGENTS.md" → Check for compatible file
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Summarize the collected information for the user, then ask about any missing context.
|
|
45
|
+
|
|
46
|
+
## Step 2: Interview — Extract Non-Discoverable Information
|
|
47
|
+
|
|
48
|
+
Only ask about information that cannot be found through auto-exploration. **One question at a time, multiple-choice when possible:**
|
|
49
|
+
|
|
50
|
+
### Question Categories
|
|
51
|
+
|
|
52
|
+
**1. Runtime Traps**
|
|
53
|
+
- Are there runtime differences not visible in the code? (e.g., Bun vs Node, ESM vs CJS)
|
|
54
|
+
- Are there bugs that only occur in certain environments?
|
|
55
|
+
|
|
56
|
+
**2. Forbidden Patterns**
|
|
57
|
+
- Are there libraries/patterns that must never be used?
|
|
58
|
+
- Are there approaches that caused problems in the past?
|
|
59
|
+
|
|
60
|
+
**3. Non-standard Conventions**
|
|
61
|
+
- Are there naming/structure rules that differ from standards?
|
|
62
|
+
- Are there special workflows agreed upon by the team?
|
|
63
|
+
|
|
64
|
+
**4. Architecture Decisions**
|
|
65
|
+
- Are there design reasons that can't be inferred from the code alone?
|
|
66
|
+
- Is there business context behind why certain patterns were chosen?
|
|
67
|
+
|
|
68
|
+
**5. Boundaries**
|
|
69
|
+
- Are there files/directories the agent must never touch?
|
|
70
|
+
- Are there areas that require approval before changes are made?
|
|
71
|
+
|
|
72
|
+
## Step 3: Structure Design — 3-Layer Architecture
|
|
73
|
+
|
|
74
|
+
Separate the collected information into 3 layers:
|
|
75
|
+
|
|
76
|
+
### Layer 1: CLAUDE.md (Project Constitution)
|
|
77
|
+
|
|
78
|
+
**Auto-loaded every session** → only universal, stable information.
|
|
79
|
+
|
|
80
|
+
```markdown
|
|
81
|
+
# {Project Name}
|
|
82
|
+
|
|
83
|
+
{1-2 sentences on what the project is. Only if the purpose isn't clear from the code.}
|
|
84
|
+
|
|
85
|
+
## Tech Stack
|
|
86
|
+
{Only what can't be inferred immediately from package.json. e.g., "Bun runtime (not Node)"}
|
|
87
|
+
|
|
88
|
+
## Commands
|
|
89
|
+
{Only what's missing from package.json scripts or non-intuitive}
|
|
90
|
+
- `npm run build && npx vitest run` — build then test (order matters)
|
|
91
|
+
|
|
92
|
+
## Conventions
|
|
93
|
+
{Only what the linter can't catch}
|
|
94
|
+
- ESM only — imports need `.js` extension
|
|
95
|
+
- {Any non-standard naming rules}
|
|
96
|
+
|
|
97
|
+
## Gotchas
|
|
98
|
+
{Things the agent will repeatedly get wrong}
|
|
99
|
+
- **{Trap title}.** {Specific do/don't explanation}
|
|
100
|
+
|
|
101
|
+
## Boundaries
|
|
102
|
+
✅ Always: {things to always do}
|
|
103
|
+
⚠️ Ask first: {things requiring approval first}
|
|
104
|
+
🚫 Never: {absolute prohibitions}
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
### Layer 2: SPEC.md (Per-Feature Design Document)
|
|
108
|
+
|
|
109
|
+
**Loaded only when working on a specific feature** → focus on what and why, leave how to the agent.
|
|
110
|
+
|
|
111
|
+
Storage location: `.claude/vibe/specs/YYYY-MM-DD-{topic}.md`
|
|
112
|
+
|
|
113
|
+
```markdown
|
|
114
|
+
# {Feature Name} SPEC
|
|
115
|
+
|
|
116
|
+
## Purpose (Why)
|
|
117
|
+
## Requirements (What)
|
|
118
|
+
## Success Criteria (Acceptance Criteria)
|
|
119
|
+
## Technical Constraints (Constraints)
|
|
120
|
+
## Boundaries (Out of Scope)
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
### Layer 3: plan.md (Execution Plan)
|
|
124
|
+
|
|
125
|
+
**Per-session task list** → 2-5 minute units, with file paths specified.
|
|
126
|
+
|
|
127
|
+
Storage location: `.claude/vibe/specs/{name}-execplan.md`
|
|
128
|
+
|
|
129
|
+
```markdown
|
|
130
|
+
# Execution Plan
|
|
131
|
+
|
|
132
|
+
## Task 1: {Title}
|
|
133
|
+
- Files: `src/foo.ts`, `src/foo.test.ts`
|
|
134
|
+
- Action: {Specific change}
|
|
135
|
+
- Verify: `npm test src/foo.test.ts`
|
|
136
|
+
|
|
137
|
+
## Task 2: ...
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
## Step 4: Writing — Apply Evidence-Based Principles
|
|
141
|
+
|
|
142
|
+
### Size Limits
|
|
143
|
+
|
|
144
|
+
| Grade | Lines | When Appropriate |
|
|
145
|
+
|-------|-------|-----------------|
|
|
146
|
+
| Optimal | 60-150 | Most projects |
|
|
147
|
+
| Acceptable | 150-200 | Complex monorepos |
|
|
148
|
+
| Warning | 200-300 | Separation needed |
|
|
149
|
+
| Danger | 300+ | Agent ignores half of it |
|
|
150
|
+
|
|
151
|
+
### Attention Distribution by Position (Lost in the Middle Effect)
|
|
152
|
+
|
|
153
|
+
LLMs focus on the **beginning and end** of a document and **ignore the middle**:
|
|
154
|
+
|
|
155
|
+
```
|
|
156
|
+
Attention: ████████░░░░░░░░████████
|
|
157
|
+
^start ^middle(↓20-40%) ^end
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
**Countermeasures**:
|
|
161
|
+
- **Most important rules** → place at the top of the document
|
|
162
|
+
- **Frequently violated rules** → place at the bottom (end) of the document
|
|
163
|
+
- **Background information** → place in the middle (OK if ignored)
|
|
164
|
+
|
|
165
|
+
### Include vs Exclude Checklist
|
|
166
|
+
|
|
167
|
+
**✅ Include (non-discoverable, operationally important)**
|
|
168
|
+
|
|
169
|
+
| Type | Example |
|
|
170
|
+
|------|---------|
|
|
171
|
+
| Runtime traps | "Bun runtime, not Node" |
|
|
172
|
+
| Forbidden patterns | "Never use `any`, use `unknown` + type guards" |
|
|
173
|
+
| SSOT location | "Only edit `constants.ts` for stack mapping" |
|
|
174
|
+
| Order invariants | "Build before test, always" |
|
|
175
|
+
| Non-standard commands | Compound commands, special flags |
|
|
176
|
+
| Security rules | Auth, path traversal prevention, etc. |
|
|
177
|
+
|
|
178
|
+
**❌ Exclude (discoverable or delegate to other tools)**
|
|
179
|
+
|
|
180
|
+
| Type | Reason | Alternative |
|
|
181
|
+
|------|--------|-------------|
|
|
182
|
+
| Directory structure | Discoverable via `ls` | The code itself |
|
|
183
|
+
| Tech stack list | In `package.json` | The code itself |
|
|
184
|
+
| Code style (indentation, semicolons) | Linter catches it | ESLint, Prettier |
|
|
185
|
+
| API documentation | Readable from code | Swagger, JSDoc |
|
|
186
|
+
| General best practices | LLM already knows | Unnecessary |
|
|
187
|
+
| API keys, secrets | Goes stale quickly | `.env`, vault |
|
|
188
|
+
| Per-feature detailed instructions | Move to Layer 2 | SPEC.md |
|
|
189
|
+
|
|
190
|
+
### Emphasis Techniques
|
|
191
|
+
|
|
192
|
+
Use these when important rules keep getting ignored:
|
|
193
|
+
|
|
194
|
+
```markdown
|
|
195
|
+
**IMPORTANT**: {critical rule}
|
|
196
|
+
**MUST**: {mandatory action}
|
|
197
|
+
**NEVER**: {absolute prohibition}
|
|
198
|
+
```
|
|
199
|
+
|
|
200
|
+
However, adding emphasis to every line **nullifies the emphasis**. Use only for P1 rules.
|
|
201
|
+
|
|
202
|
+
### Progressive Disclosure
|
|
203
|
+
|
|
204
|
+
Don't put everything in CLAUDE.md — reference it:
|
|
205
|
+
|
|
206
|
+
```markdown
|
|
207
|
+
# Architecture
|
|
208
|
+
See @docs/ARCHITECTURE.md for design decisions.
|
|
209
|
+
|
|
210
|
+
# Security
|
|
211
|
+
@.claude/rules/security.md
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
Claude Code follows `@` references and loads them only when needed.
|
|
215
|
+
|
|
216
|
+
## Step 5: Validation — Writing Quality Check
|
|
217
|
+
|
|
218
|
+
Validate the written CLAUDE.md:
|
|
219
|
+
|
|
220
|
+
### Line-by-Line Validation
|
|
221
|
+
|
|
222
|
+
4 questions for every line:
|
|
223
|
+
|
|
224
|
+
1. **Would the agent make a mistake without this?** → If No, delete
|
|
225
|
+
2. **Is it needed in every session?** → If No, move to Layer 2/3
|
|
226
|
+
3. **Can a linter/hook replace it?** → If Yes, move to linter/hook
|
|
227
|
+
4. **Is it discoverable from code?** → If Yes, delete
|
|
228
|
+
|
|
229
|
+
### Anchoring Warning
|
|
230
|
+
|
|
231
|
+
Mentioning a technology name biases the agent toward it:
|
|
232
|
+
- ❌ "We use React" → unnecessary (it's in package.json)
|
|
233
|
+
- ✅ "Never use jQuery, even for legacy code" → useful (prevents a trap)
|
|
234
|
+
|
|
235
|
+
### Token Efficiency
|
|
236
|
+
|
|
237
|
+
| Problem | Example | Improvement |
|
|
238
|
+
|---------|---------|-------------|
|
|
239
|
+
| Verbose explanation | "Please always make sure to..." | "Always:" |
|
|
240
|
+
| Duplication | Same rule repeated in different wording | State it once |
|
|
241
|
+
| Unnecessary context | "As we discussed..." | Delete |
|
|
242
|
+
|
|
243
|
+
## Step 6: Maintenance — A Living Document
|
|
244
|
+
|
|
245
|
+
### Incremental Addition Pattern
|
|
246
|
+
|
|
247
|
+
Don't try to write it perfectly from the start:
|
|
248
|
+
|
|
249
|
+
```
|
|
250
|
+
1. Start with a minimal CLAUDE.md (30-50 lines)
|
|
251
|
+
2. Observe where the agent makes mistakes
|
|
252
|
+
3. Only add rules for recurring mistakes
|
|
253
|
+
4. Clean up unnecessary lines every 2-3 weeks
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
### Reflection Loop (Addy Osmani Pattern)
|
|
257
|
+
|
|
258
|
+
```
|
|
259
|
+
Agent task complete
|
|
260
|
+
→ Ask "What was different from expectations?"
|
|
261
|
+
→ When a recurring pattern is found, add 1 line to CLAUDE.md
|
|
262
|
+
→ If the root cause is code structure, fix the code and don't add a rule
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
### Warning Signs
|
|
266
|
+
|
|
267
|
+
| Signal | Meaning | Response |
|
|
268
|
+
|--------|---------|----------|
|
|
269
|
+
| Over 300 lines | Information overload | Split or trim |
|
|
270
|
+
| Same mistake repeats | Rule is lost in noise | Emphasize or consolidate |
|
|
271
|
+
| Adding rules has no effect | File is too long | Fix root cause |
|
|
272
|
+
| Team ignores rules | Discoverable information | Delete |
|
|
273
|
+
|
|
274
|
+
---
|
|
275
|
+
|
|
276
|
+
## Quick Reference: Guide by Project Scale
|
|
277
|
+
|
|
278
|
+
### Small (fewer than 10 files)
|
|
279
|
+
|
|
280
|
+
```markdown
|
|
281
|
+
# {Project Name}
|
|
282
|
+
|
|
283
|
+
## Commands
|
|
284
|
+
- `{build}` — {description}
|
|
285
|
+
- `{test}` — {description}
|
|
286
|
+
|
|
287
|
+
## Gotchas
|
|
288
|
+
- **{Trap 1}.** {description}
|
|
289
|
+
- **{Trap 2}.** {description}
|
|
290
|
+
|
|
291
|
+
## Never
|
|
292
|
+
- 🚫 {prohibited item}
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
**Target: 20-30 lines**
|
|
296
|
+
|
|
297
|
+
### Medium (10-50 files)
|
|
298
|
+
|
|
299
|
+
Above + add Conventions and Boundaries sections.
|
|
300
|
+
|
|
301
|
+
**Target: 60-150 lines**
|
|
302
|
+
|
|
303
|
+
### Large (50+ files, monorepo)
|
|
304
|
+
|
|
305
|
+
Root CLAUDE.md (shared rules) + CLAUDE.md per subdirectory.
|
|
306
|
+
|
|
307
|
+
```
|
|
308
|
+
project/
|
|
309
|
+
├── CLAUDE.md ← shared (60 lines)
|
|
310
|
+
├── packages/api/CLAUDE.md ← API-specific (30 lines)
|
|
311
|
+
├── packages/web/CLAUDE.md ← web-specific (30 lines)
|
|
312
|
+
└── .claude/rules/ ← path-specific rules
|
|
313
|
+
├── security.md
|
|
314
|
+
└── testing.md
|
|
315
|
+
```
|
|
316
|
+
|
|
317
|
+
**Target: root 100 lines + each subdirectory 30 lines**
|
|
318
|
+
|
|
319
|
+
---
|
|
320
|
+
|
|
321
|
+
## Session Separation Principle
|
|
322
|
+
|
|
323
|
+
Splitting CLAUDE.md writing into separate sessions improves quality:
|
|
324
|
+
|
|
325
|
+
| Session | Goal | Output |
|
|
326
|
+
|---------|------|--------|
|
|
327
|
+
| Session 1 | Project exploration + interview | Draft |
|
|
328
|
+
| Session 2 | Validation + optimization | Final version |
|
|
329
|
+
| Ongoing | Incremental maintenance | Continuous improvement |
|
|
330
|
+
|
|
331
|
+
After writing: run `→ /agents-md` skill for optimization validation.
|
|
332
|
+
|
|
333
|
+
---
|
|
334
|
+
|
|
335
|
+
## References
|
|
336
|
+
|
|
337
|
+
### Research
|
|
338
|
+
- [Curse of Instructions: LLMs Cannot Follow Multiple Instructions at Once](https://openreview.net/forum?id=R6q67CDBCH)
|
|
339
|
+
- [Lost in the Middle: How Language Models Use Long Contexts](https://arxiv.org/abs/2307.03172)
|
|
340
|
+
- [The Instruction Hierarchy: Training LLMs to Prioritize Privileged Instructions](https://arxiv.org/html/2404.13208v1)
|
|
341
|
+
- [Context Length Alone Hurts LLM Performance Despite Perfect Retrieval](https://arxiv.org/html/2510.05381v1)
|
|
342
|
+
|
|
343
|
+
### Official Docs
|
|
344
|
+
- [Claude Code Best Practices](https://code.claude.com/docs/en/best-practices)
|
|
345
|
+
- [Using CLAUDE.md Files](https://claude.com/blog/using-claude-md-files)
|
|
346
|
+
|
|
347
|
+
### Community
|
|
348
|
+
- [Addy Osmani: AGENTS.md](https://addyosmani.com/blog/agents-md/)
|
|
349
|
+
- [HumanLayer: Writing a good CLAUDE.md](https://www.humanlayer.dev/blog/writing-a-good-claude-md)
|
|
350
|
+
- [Builder.io: CLAUDE.md Guide](https://www.builder.io/blog/claude-md-guide)
|
|
351
|
+
- [GitHub Blog: How to Write a Great agents.md](https://github.blog/ai-and-ml/github-copilot/how-to-write-a-great-agents-md-lessons-from-over-2500-repositories/)
|