claude-code-pilot 2.0.0 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +76 -97
- package/bin/install.js +267 -250
- package/manifest.json +5 -18
- package/package.json +5 -7
- package/src/agents/build-error-resolver.md +114 -0
- package/src/agents/ccp-advisor-researcher.md +104 -0
- package/src/agents/ccp-assumptions-analyzer.md +105 -0
- package/{gsd/agents/gsd-codebase-mapper.md → src/agents/ccp-codebase-mapper.md} +7 -7
- package/{gsd/agents/gsd-debugger.md → src/agents/ccp-debugger.md} +125 -8
- package/{gsd/agents/gsd-executor.md → src/agents/ccp-executor.md} +31 -20
- package/{gsd/agents/gsd-integration-checker.md → src/agents/ccp-integration-checker.md} +2 -2
- package/{gsd/agents/gsd-nyquist-auditor.md → src/agents/ccp-nyquist-auditor.md} +3 -3
- package/{gsd/agents/gsd-phase-researcher.md → src/agents/ccp-phase-researcher.md} +127 -13
- package/{gsd/agents/gsd-plan-checker.md → src/agents/ccp-plan-checker.md} +57 -21
- package/{gsd/agents/gsd-planner.md → src/agents/ccp-planner.md} +61 -23
- package/{gsd/agents/gsd-project-researcher.md → src/agents/ccp-project-researcher.md} +33 -6
- package/{gsd/agents/gsd-research-synthesizer.md → src/agents/ccp-research-synthesizer.md} +11 -11
- package/{gsd/agents/gsd-roadmapper.md → src/agents/ccp-roadmapper.md} +39 -10
- package/src/agents/ccp-ui-auditor.md +439 -0
- package/src/agents/ccp-ui-checker.md +300 -0
- package/src/agents/ccp-ui-researcher.md +357 -0
- package/{gsd/agents/gsd-verifier.md → src/agents/ccp-verifier.md} +81 -15
- package/src/agents/cpp-build-resolver.md +90 -0
- package/src/agents/cpp-reviewer.md +72 -0
- package/src/agents/database-reviewer.md +91 -0
- package/{ecc → src}/agents/doc-updater.md +1 -1
- package/src/agents/docs-lookup.md +68 -0
- package/src/agents/flutter-reviewer.md +243 -0
- package/src/agents/gan-evaluator.md +209 -0
- package/src/agents/gan-generator.md +131 -0
- package/src/agents/gan-planner.md +99 -0
- package/src/agents/go-build-resolver.md +94 -0
- package/src/agents/go-reviewer.md +76 -0
- package/src/agents/harness-optimizer.md +35 -0
- package/src/agents/java-build-resolver.md +153 -0
- package/src/agents/java-reviewer.md +92 -0
- package/src/agents/kotlin-build-resolver.md +118 -0
- package/src/agents/kotlin-reviewer.md +159 -0
- package/src/agents/loop-operator.md +36 -0
- package/src/agents/opensource-forker.md +198 -0
- package/src/agents/opensource-packager.md +249 -0
- package/src/agents/opensource-sanitizer.md +188 -0
- package/src/agents/performance-optimizer.md +446 -0
- package/src/agents/planner.md +212 -0
- package/src/agents/python-reviewer.md +98 -0
- package/src/agents/pytorch-build-resolver.md +120 -0
- package/src/agents/refactor-cleaner.md +85 -0
- package/src/agents/rust-build-resolver.md +148 -0
- package/src/agents/rust-reviewer.md +94 -0
- package/src/agents/typescript-reviewer.md +112 -0
- package/src/available-rules/README.md +80 -0
- package/src/available-rules/cpp/coding-style.md +44 -0
- package/src/available-rules/cpp/hooks.md +39 -0
- package/src/available-rules/cpp/patterns.md +51 -0
- package/src/available-rules/cpp/security.md +51 -0
- package/src/available-rules/cpp/testing.md +44 -0
- package/src/available-rules/csharp/coding-style.md +72 -0
- package/src/available-rules/csharp/hooks.md +25 -0
- package/src/available-rules/csharp/patterns.md +50 -0
- package/src/available-rules/csharp/security.md +58 -0
- package/src/available-rules/csharp/testing.md +46 -0
- package/src/available-rules/java/coding-style.md +114 -0
- package/src/available-rules/java/hooks.md +18 -0
- package/src/available-rules/java/patterns.md +146 -0
- package/src/available-rules/java/security.md +100 -0
- package/src/available-rules/java/testing.md +131 -0
- package/src/available-rules/kotlin/hooks.md +17 -0
- package/src/available-rules/rust/coding-style.md +151 -0
- package/src/available-rules/rust/hooks.md +16 -0
- package/src/available-rules/rust/patterns.md +168 -0
- package/src/available-rules/rust/security.md +141 -0
- package/src/available-rules/rust/testing.md +154 -0
- package/src/commands/ccp/add-backlog.md +76 -0
- package/{gsd/commands-gsd → src/commands/ccp}/add-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/add-tests.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/add-todo.md +4 -4
- package/src/commands/ccp/aside.md +165 -0
- package/{gsd/commands-gsd → src/commands/ccp}/audit-milestone.md +3 -3
- package/src/commands/ccp/audit-uat.md +24 -0
- package/src/commands/ccp/autonomous.md +41 -0
- package/src/commands/ccp/build-fix.md +67 -0
- package/{gsd/commands-gsd → src/commands/ccp}/check-todos.md +3 -3
- package/{ecc/commands → src/commands/ccp}/checkpoint.md +12 -7
- package/{gsd/commands-gsd → src/commands/ccp}/cleanup.md +3 -3
- package/src/commands/ccp/code-review.md +45 -0
- package/{gsd/commands-gsd → src/commands/ccp}/complete-milestone.md +9 -9
- package/src/commands/ccp/context-budget.md +30 -0
- package/src/commands/ccp/cpp-build.md +174 -0
- package/src/commands/ccp/cpp-review.md +133 -0
- package/src/commands/ccp/cpp-test.md +252 -0
- package/{gsd/commands-gsd → src/commands/ccp}/debug.md +14 -9
- package/src/commands/ccp/discuss-phase.md +64 -0
- package/src/commands/ccp/do.md +30 -0
- package/src/commands/ccp/docs-update.md +48 -0
- package/src/commands/ccp/docs.md +32 -0
- package/src/commands/ccp/e2e.md +365 -0
- package/src/commands/ccp/eval.md +125 -0
- package/{ecc/commands → src/commands/ccp}/evolve.md +5 -5
- package/src/commands/ccp/execute-phase.md +59 -0
- package/src/commands/ccp/fast.md +30 -0
- package/src/commands/ccp/forensics.md +56 -0
- package/src/commands/ccp/go-build.md +184 -0
- package/src/commands/ccp/go-review.md +149 -0
- package/src/commands/ccp/go-test.md +269 -0
- package/src/commands/ccp/gradle-build.md +71 -0
- package/src/commands/ccp/harness-audit.md +76 -0
- package/{gsd/commands-gsd → src/commands/ccp}/health.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/help.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/insert-phase.md +3 -3
- package/src/commands/ccp/kotlin-build.md +175 -0
- package/src/commands/ccp/kotlin-review.md +141 -0
- package/src/commands/ccp/kotlin-test.md +313 -0
- package/{ecc/commands → src/commands/ccp}/learn.md +7 -2
- package/{gsd/commands-gsd → src/commands/ccp}/list-phase-assumptions.md +2 -2
- package/src/commands/ccp/manager.md +39 -0
- package/{gsd/commands-gsd → src/commands/ccp}/map-codebase.md +7 -7
- package/src/commands/ccp/milestone-summary.md +51 -0
- package/{ecc/commands → src/commands/ccp}/model-route.md +6 -1
- package/{gsd/commands-gsd → src/commands/ccp}/new-milestone.md +8 -8
- package/{gsd/commands-gsd → src/commands/ccp}/new-project.md +8 -8
- package/src/commands/ccp/next.md +24 -0
- package/src/commands/ccp/note.md +34 -0
- package/src/commands/ccp/orchestrate.md +232 -0
- package/{gsd/commands-gsd → src/commands/ccp}/pause-work.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/plan-milestone-gaps.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/plan-phase.md +9 -7
- package/src/commands/ccp/plan.md +115 -0
- package/src/commands/ccp/plant-seed.md +28 -0
- package/src/commands/ccp/pr-branch.md +25 -0
- package/src/commands/ccp/profile-user.md +46 -0
- package/{gsd/commands-gsd → src/commands/ccp}/progress.md +3 -3
- package/src/commands/ccp/prompt-optimize.md +39 -0
- package/src/commands/ccp/prune.md +25 -0
- package/src/commands/ccp/python-review.md +298 -0
- package/{ecc/commands → src/commands/ccp}/quality-gate.md +7 -2
- package/{gsd/commands-gsd → src/commands/ccp}/quick.md +10 -8
- package/src/commands/ccp/refactor-clean.md +85 -0
- package/{gsd/commands-gsd → src/commands/ccp}/remove-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/research-phase.md +17 -12
- package/{ecc/commands → src/commands/ccp}/resume-session.md +9 -8
- package/{gsd/commands-gsd → src/commands/ccp}/resume-work.md +3 -3
- package/src/commands/ccp/review-backlog.md +61 -0
- package/src/commands/ccp/review.md +37 -0
- package/src/commands/ccp/rules-distill.md +12 -0
- package/src/commands/ccp/rust-build.md +188 -0
- package/src/commands/ccp/rust-review.md +143 -0
- package/src/commands/ccp/rust-test.md +309 -0
- package/{ecc/commands → src/commands/ccp}/save-session.md +2 -1
- package/src/commands/ccp/secure-phase.md +35 -0
- package/src/commands/ccp/session-report.md +19 -0
- package/{ecc/commands → src/commands/ccp}/sessions.md +39 -34
- package/src/commands/ccp/set-profile.md +12 -0
- package/{gsd/commands-gsd → src/commands/ccp}/settings.md +5 -5
- package/src/commands/ccp/setup-pm.md +81 -0
- package/{kit/commands → src/commands/ccp}/setup-refresh.md +4 -3
- package/{kit/commands → src/commands/ccp}/setup.md +67 -40
- package/src/commands/ccp/ship.md +23 -0
- package/src/commands/ccp/skill-create.md +172 -0
- package/src/commands/ccp/skill-health.md +51 -0
- package/src/commands/ccp/stats.md +18 -0
- package/src/commands/ccp/tdd.md +329 -0
- package/src/commands/ccp/test-coverage.md +74 -0
- package/src/commands/ccp/thread.md +127 -0
- package/{kit/commands → src/commands/ccp}/tool-guide.md +2 -1
- package/src/commands/ccp/ui-phase.md +34 -0
- package/src/commands/ccp/ui-review.md +32 -0
- package/src/commands/ccp/update-codemaps.md +77 -0
- package/src/commands/ccp/update-docs.md +89 -0
- package/{gsd/commands-gsd → src/commands/ccp}/update.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/validate-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/verify-work.md +5 -5
- package/{ecc/commands → src/commands/ccp}/verify.md +5 -0
- package/src/commands/ccp/workstreams.md +68 -0
- package/{ecc → src}/examples/CLAUDE.md +4 -4
- package/{ecc → src}/examples/django-api-CLAUDE.md +5 -5
- package/{ecc → src}/examples/go-microservice-CLAUDE.md +6 -6
- package/{ecc → src}/examples/rust-api-CLAUDE.md +4 -4
- package/{ecc → src}/examples/saas-nextjs-CLAUDE.md +8 -8
- package/{gsd/hooks/gsd-context-monitor.js → src/hooks/ccp-context-monitor.js} +3 -3
- package/src/hooks/ccp-prompt-guard.js +96 -0
- package/{gsd/hooks/gsd-statusline.js → src/hooks/ccp-statusline.js} +7 -7
- package/src/hooks/ccp-workflow-guard.js +94 -0
- package/src/hooks/config-protection.js +141 -0
- package/{kit → src}/hooks/kit-check-update.js +7 -4
- package/src/hooks/mcp-health-check.js +620 -0
- package/{ecc/scripts → src}/hooks/run-with-flags-shell.sh +1 -1
- package/{ecc/scripts → src}/hooks/run-with-flags.js +74 -13
- package/src/hooks/session-end-marker.js +29 -0
- package/{ecc/scripts → src}/hooks/session-end.js +83 -40
- package/{ecc/scripts → src}/hooks/session-start.js +76 -10
- package/{ecc/scripts → src}/lib/hook-flags.js +8 -4
- package/{ecc/scripts → src}/lib/project-detect.js +2 -1
- package/{ecc/scripts → src}/lib/session-manager.d.ts +5 -1
- package/{ecc/scripts → src}/lib/session-manager.js +202 -92
- package/{ecc/scripts → src}/lib/utils.d.ts +23 -1
- package/{ecc/scripts → src}/lib/utils.js +91 -3
- package/{gsd/get-shit-done/bin/gsd-tools.cjs → src/pilot/bin/ccp-tools.cjs} +257 -86
- package/{gsd/get-shit-done → src/pilot}/bin/lib/commands.cjs +1 -1
- package/src/pilot/bin/lib/config.cjs +444 -0
- package/src/pilot/bin/lib/core.cjs +1190 -0
- package/src/pilot/bin/lib/init.cjs +1281 -0
- package/src/pilot/bin/lib/model-profiles.cjs +67 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/phase.cjs +2 -2
- package/src/pilot/bin/lib/security.cjs +382 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/state.cjs +1 -1
- package/src/pilot/bin/lib/uat.cjs +282 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/verify.cjs +10 -10
- package/{gsd/get-shit-done → src/pilot}/references/continuation-format.md +16 -16
- package/{gsd/get-shit-done → src/pilot}/references/decimal-phase-calculation.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/git-integration.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/git-planning-commit.md +4 -4
- package/src/pilot/references/mcp-servers.json +153 -0
- package/{gsd/get-shit-done → src/pilot}/references/model-profile-resolution.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/references/model-profiles.md +20 -20
- package/{gsd/get-shit-done → src/pilot}/references/phase-argument-parsing.md +4 -4
- package/{gsd/get-shit-done → src/pilot}/references/planning-config.md +15 -15
- package/{gsd/get-shit-done → src/pilot}/references/ui-brand.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/verification-patterns.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/DEBUG.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/UAT.md +3 -3
- package/src/pilot/templates/UI-SPEC.md +100 -0
- package/{gsd/get-shit-done → src/pilot}/templates/VALIDATION.md +1 -1
- package/src/pilot/templates/claude-md.md +122 -0
- package/{gsd/get-shit-done → src/pilot}/templates/codebase/architecture.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/codebase/structure.md +13 -13
- package/{gsd/get-shit-done → src/pilot}/templates/context.md +4 -4
- package/src/pilot/templates/copilot-instructions.md +7 -0
- package/{gsd/get-shit-done → src/pilot}/templates/debug-subagent-prompt.md +4 -4
- package/src/pilot/templates/dev-preferences.md +21 -0
- package/{gsd/get-shit-done → src/pilot}/templates/discovery.md +2 -2
- package/src/pilot/templates/discussion-log.md +63 -0
- package/{gsd/get-shit-done → src/pilot}/templates/phase-prompt.md +12 -12
- package/{gsd/get-shit-done → src/pilot}/templates/planner-subagent-prompt.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/templates/project.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/research.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/state.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/summary-complex.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/workflows/add-phase.md +11 -11
- package/{gsd/get-shit-done → src/pilot}/workflows/add-tests.md +15 -15
- package/{gsd/get-shit-done → src/pilot}/workflows/add-todo.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/workflows/audit-milestone.md +24 -16
- package/src/pilot/workflows/audit-uat.md +109 -0
- package/src/pilot/workflows/autonomous.md +891 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/check-todos.md +10 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/cleanup.md +3 -3
- package/{gsd/get-shit-done → src/pilot}/workflows/complete-milestone.md +19 -16
- package/{gsd/get-shit-done → src/pilot}/workflows/diagnose-issues.md +9 -4
- package/{gsd/get-shit-done → src/pilot}/workflows/discovery-phase.md +8 -8
- package/src/pilot/workflows/discuss-phase-assumptions.md +653 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/discuss-phase.md +407 -49
- package/src/pilot/workflows/do.md +104 -0
- package/src/pilot/workflows/docs-update.md +1165 -0
- package/src/pilot/workflows/execute-phase.md +821 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/execute-plan.md +79 -28
- package/src/pilot/workflows/fast.md +105 -0
- package/src/pilot/workflows/forensics.md +265 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/health.md +34 -11
- package/src/pilot/workflows/help.md +767 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/insert-phase.md +10 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/list-phase-assumptions.md +4 -4
- package/src/pilot/workflows/manager.md +362 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/map-codebase.md +27 -17
- package/src/pilot/workflows/milestone-summary.md +223 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/new-milestone.md +135 -33
- package/{gsd/get-shit-done → src/pilot}/workflows/new-project.md +152 -79
- package/src/pilot/workflows/next.md +97 -0
- package/src/pilot/workflows/node-repair.md +92 -0
- package/src/pilot/workflows/note.md +156 -0
- package/src/pilot/workflows/pause-work.md +177 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/plan-milestone-gaps.md +10 -11
- package/src/pilot/workflows/plan-phase.md +859 -0
- package/src/pilot/workflows/plant-seed.md +169 -0
- package/src/pilot/workflows/pr-branch.md +129 -0
- package/src/pilot/workflows/profile-user.md +452 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/progress.md +95 -34
- package/{gsd/get-shit-done → src/pilot}/workflows/quick.md +33 -21
- package/{gsd/get-shit-done → src/pilot}/workflows/remove-phase.md +14 -14
- package/{gsd/get-shit-done → src/pilot}/workflows/research-phase.md +18 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/resume-project.md +37 -18
- package/src/pilot/workflows/review.md +244 -0
- package/src/pilot/workflows/secure-phase.md +164 -0
- package/src/pilot/workflows/session-report.md +146 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/set-profile.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/workflows/settings.md +75 -22
- package/src/pilot/workflows/ship.md +228 -0
- package/src/pilot/workflows/stats.md +60 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/transition.md +57 -17
- package/src/pilot/workflows/ui-phase.md +302 -0
- package/src/pilot/workflows/ui-review.md +165 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/update.md +88 -58
- package/{gsd/get-shit-done → src/pilot}/workflows/validate-phase.md +24 -17
- package/{gsd/get-shit-done → src/pilot}/workflows/verify-phase.md +26 -15
- package/{gsd/get-shit-done → src/pilot}/workflows/verify-work.md +89 -37
- package/{ecc → src}/rules/common/agents.md +1 -0
- package/src/rules/common/code-review.md +124 -0
- package/{ecc → src}/rules/common/coding-style.md +21 -0
- package/src/rules/zh/README.md +108 -0
- package/src/rules/zh/agents.md +50 -0
- package/src/rules/zh/code-review.md +124 -0
- package/src/rules/zh/coding-style.md +48 -0
- package/src/rules/zh/development-workflow.md +44 -0
- package/src/rules/zh/git-workflow.md +24 -0
- package/src/rules/zh/hooks.md +30 -0
- package/src/rules/zh/patterns.md +31 -0
- package/src/rules/zh/performance.md +55 -0
- package/src/rules/zh/security.md +29 -0
- package/src/rules/zh/testing.md +29 -0
- package/src/skills/agentic-engineering/SKILL.md +63 -0
- package/src/skills/ai-first-engineering/SKILL.md +51 -0
- package/src/skills/ai-regression-testing/SKILL.md +385 -0
- package/src/skills/api-design/SKILL.md +523 -0
- package/src/skills/architecture-decision-records/SKILL.md +179 -0
- package/src/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/src/skills/autonomous-loops/SKILL.md +610 -0
- package/src/skills/backend-patterns/SKILL.md +598 -0
- package/src/skills/benchmark/SKILL.md +87 -0
- package/src/skills/blueprint/SKILL.md +90 -0
- package/src/skills/browser-qa/SKILL.md +81 -0
- package/src/skills/bun-runtime/SKILL.md +84 -0
- package/src/skills/claude-api/SKILL.md +337 -0
- package/src/skills/codebase-onboarding/SKILL.md +233 -0
- package/src/skills/coding-standards/SKILL.md +530 -0
- package/src/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/src/skills/context-budget/SKILL.md +135 -0
- package/{ecc → src}/skills/continuous-learning-v2/SKILL.md +6 -6
- package/{ecc → src}/skills/continuous-learning-v2/agents/observer-loop.sh +1 -1
- package/{ecc → src}/skills/continuous-learning-v2/agents/observer.md +1 -1
- package/src/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/src/skills/cpp-coding-standards/SKILL.md +723 -0
- package/src/skills/cpp-testing/SKILL.md +324 -0
- package/src/skills/database-migrations/SKILL.md +429 -0
- package/src/skills/deep-research/SKILL.md +155 -0
- package/src/skills/deployment-patterns/SKILL.md +427 -0
- package/src/skills/design-system/SKILL.md +82 -0
- package/src/skills/django-patterns/SKILL.md +734 -0
- package/src/skills/django-security/SKILL.md +593 -0
- package/src/skills/django-tdd/SKILL.md +729 -0
- package/src/skills/django-verification/SKILL.md +469 -0
- package/src/skills/docker-patterns/SKILL.md +364 -0
- package/src/skills/documentation-lookup/SKILL.md +90 -0
- package/src/skills/e2e-testing/SKILL.md +326 -0
- package/src/skills/eval-harness/SKILL.md +270 -0
- package/src/skills/exa-search/SKILL.md +103 -0
- package/src/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/src/skills/frontend-patterns/SKILL.md +642 -0
- package/src/skills/gan-style-harness/SKILL.md +278 -0
- package/src/skills/git-workflow/SKILL.md +715 -0
- package/src/skills/golang-patterns/SKILL.md +674 -0
- package/src/skills/golang-testing/SKILL.md +720 -0
- package/src/skills/hexagonal-architecture/SKILL.md +276 -0
- package/src/skills/iterative-retrieval/SKILL.md +211 -0
- package/src/skills/java-coding-standards/SKILL.md +147 -0
- package/src/skills/jpa-patterns/SKILL.md +151 -0
- package/src/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/src/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/src/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/src/skills/kotlin-patterns/SKILL.md +711 -0
- package/src/skills/kotlin-testing/SKILL.md +824 -0
- package/src/skills/laravel-patterns/SKILL.md +415 -0
- package/src/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/src/skills/laravel-security/SKILL.md +285 -0
- package/src/skills/laravel-tdd/SKILL.md +283 -0
- package/src/skills/laravel-verification/SKILL.md +179 -0
- package/src/skills/mcp-server-patterns/SKILL.md +67 -0
- package/src/skills/nextjs-turbopack/SKILL.md +44 -0
- package/src/skills/nuxt4-patterns/SKILL.md +100 -0
- package/src/skills/opensource-pipeline/SKILL.md +255 -0
- package/src/skills/perl-patterns/SKILL.md +504 -0
- package/src/skills/perl-security/SKILL.md +503 -0
- package/src/skills/perl-testing/SKILL.md +475 -0
- package/src/skills/postgres-patterns/SKILL.md +147 -0
- package/src/skills/project-flow-ops/SKILL.md +111 -0
- package/src/skills/project-guidelines-example/SKILL.md +349 -0
- package/src/skills/prompt-optimizer/SKILL.md +397 -0
- package/src/skills/python-patterns/SKILL.md +750 -0
- package/src/skills/python-testing/SKILL.md +816 -0
- package/src/skills/pytorch-patterns/SKILL.md +396 -0
- package/src/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/src/skills/repo-scan/SKILL.md +78 -0
- package/src/skills/rules-distill/SKILL.md +264 -0
- package/src/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/src/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/src/skills/rust-patterns/SKILL.md +499 -0
- package/src/skills/rust-testing/SKILL.md +500 -0
- package/src/skills/safety-guard/SKILL.md +69 -0
- package/src/skills/search-first/SKILL.md +161 -0
- package/src/skills/security-review/SKILL.md +495 -0
- package/src/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/src/skills/security-scan/SKILL.md +165 -0
- package/src/skills/springboot-patterns/SKILL.md +314 -0
- package/src/skills/springboot-security/SKILL.md +272 -0
- package/src/skills/springboot-tdd/SKILL.md +158 -0
- package/src/skills/springboot-verification/SKILL.md +231 -0
- package/src/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/src/skills/tdd-workflow/SKILL.md +410 -0
- package/src/skills/token-budget-advisor/SKILL.md +133 -0
- package/{ecc/skills/verification-loop-SKILL.md → src/skills/verification-loop/SKILL.md} +1 -1
- package/src/skills/workspace-surface-audit/SKILL.md +125 -0
- package/ecc/scripts/hooks/session-end-marker.js +0 -15
- package/gsd/LICENSE +0 -21
- package/gsd/commands-gsd/discuss-phase.md +0 -90
- package/gsd/commands-gsd/execute-phase.md +0 -41
- package/gsd/commands-gsd/join-discord.md +0 -18
- package/gsd/commands-gsd/reapply-patches.md +0 -123
- package/gsd/commands-gsd/set-profile.md +0 -34
- package/gsd/get-shit-done/bin/lib/config.cjs +0 -169
- package/gsd/get-shit-done/bin/lib/core.cjs +0 -492
- package/gsd/get-shit-done/bin/lib/init.cjs +0 -710
- package/gsd/get-shit-done/workflows/execute-phase.md +0 -459
- package/gsd/get-shit-done/workflows/help.md +0 -489
- package/gsd/get-shit-done/workflows/pause-work.md +0 -122
- package/gsd/get-shit-done/workflows/plan-phase.md +0 -560
- package/gsd/hooks/gsd-check-update.js +0 -81
- package/kit/CLAUDE.md +0 -43
- package/kit/commands/kit/update.md +0 -46
- package/kit/mcp.json +0 -10
- package/kit/rules/code-style.md +0 -24
- /package/{ecc → src}/agents/architect.md +0 -0
- /package/{ecc → src}/agents/code-reviewer.md +0 -0
- /package/{ecc → src}/agents/e2e-runner.md +0 -0
- /package/{ecc → src}/agents/security-reviewer.md +0 -0
- /package/{ecc → src}/agents/tdd-guide.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/testing.md +0 -0
- /package/{ecc → src}/contexts/dev.md +0 -0
- /package/{ecc → src}/contexts/research.md +0 -0
- /package/{ecc → src}/contexts/review.md +0 -0
- /package/{ecc → src}/examples/user-CLAUDE.md +0 -0
- /package/{ecc/scripts → src}/hooks/check-hook-enabled.js +0 -0
- /package/{ecc/scripts → src}/hooks/evaluate-session.js +0 -0
- /package/{ecc/scripts → src}/hooks/pre-compact.js +0 -0
- /package/{ecc/scripts → src}/hooks/suggest-compact.js +0 -0
- /package/{ecc/scripts → src}/lib/package-manager.d.ts +0 -0
- /package/{ecc/scripts → src}/lib/package-manager.js +0 -0
- /package/{ecc/scripts → src}/lib/resolve-formatter.js +0 -0
- /package/{ecc/scripts → src}/lib/session-aliases.d.ts +0 -0
- /package/{ecc/scripts → src}/lib/session-aliases.js +0 -0
- /package/{ecc/scripts → src}/lib/shell-split.js +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/frontmatter.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/milestone.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/roadmap.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/template.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/checkpoints.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/questioning.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/tdd.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/concerns.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/conventions.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/integrations.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/stack.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/testing.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/config.json +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/continue-here.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/milestone-archive.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/milestone.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/requirements.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/ARCHITECTURE.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/FEATURES.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/PITFALLS.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/STACK.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/SUMMARY.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/retrospective.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/roadmap.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary-minimal.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary-standard.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/user-setup.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/verification-report.md +0 -0
- /package/{ecc → src}/rules/common/development-workflow.md +0 -0
- /package/{ecc → src}/rules/common/git-workflow.md +0 -0
- /package/{ecc → src}/rules/common/hooks.md +0 -0
- /package/{ecc → src}/rules/common/patterns.md +0 -0
- /package/{ecc → src}/rules/common/performance.md +0 -0
- /package/{ecc → src}/rules/common/security.md +0 -0
- /package/{ecc → src}/rules/common/testing.md +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/agents/start-observer.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/config.json +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/hooks/observe.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/detect-project.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -0
- /package/{ecc → src}/skills/strategic-compact/SKILL.md +0 -0
- /package/{ecc → src}/skills/strategic-compact/suggest-compact.sh +0 -0
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: hexagonal-architecture
|
|
3
|
+
description: Design, implement, and refactor Ports & Adapters systems with clear domain boundaries, dependency inversion, and testable use-case orchestration across TypeScript, Java, Kotlin, and Go services.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Hexagonal Architecture
|
|
8
|
+
|
|
9
|
+
Hexagonal architecture (Ports and Adapters) keeps business logic independent from frameworks, transport, and persistence details. The core app depends on abstract ports, and adapters implement those ports at the edges.
|
|
10
|
+
|
|
11
|
+
## When to Use
|
|
12
|
+
|
|
13
|
+
- Building new features where long-term maintainability and testability matter.
|
|
14
|
+
- Refactoring layered or framework-heavy code where domain logic is mixed with I/O concerns.
|
|
15
|
+
- Supporting multiple interfaces for the same use case (HTTP, CLI, queue workers, cron jobs).
|
|
16
|
+
- Replacing infrastructure (database, external APIs, message bus) without rewriting business rules.
|
|
17
|
+
|
|
18
|
+
Use this skill when the request involves boundaries, domain-centric design, refactoring tightly coupled services, or decoupling application logic from specific libraries.
|
|
19
|
+
|
|
20
|
+
## Core Concepts
|
|
21
|
+
|
|
22
|
+
- **Domain model**: Business rules and entities/value objects. No framework imports.
|
|
23
|
+
- **Use cases (application layer)**: Orchestrate domain behavior and workflow steps.
|
|
24
|
+
- **Inbound ports**: Contracts describing what the application can do (commands/queries/use-case interfaces).
|
|
25
|
+
- **Outbound ports**: Contracts for dependencies the application needs (repositories, gateways, event publishers, clock, UUID, etc.).
|
|
26
|
+
- **Adapters**: Infrastructure and delivery implementations of ports (HTTP controllers, DB repositories, queue consumers, SDK wrappers).
|
|
27
|
+
- **Composition root**: Single wiring location where concrete adapters are bound to use cases.
|
|
28
|
+
|
|
29
|
+
Outbound port interfaces usually live in the application layer (or in domain only when the abstraction is truly domain-level), while infrastructure adapters implement them.
|
|
30
|
+
|
|
31
|
+
Dependency direction is always inward:
|
|
32
|
+
|
|
33
|
+
- Adapters -> application/domain
|
|
34
|
+
- Application -> port interfaces (inbound/outbound contracts)
|
|
35
|
+
- Domain -> domain-only abstractions (no framework or infrastructure dependencies)
|
|
36
|
+
- Domain -> nothing external
|
|
37
|
+
|
|
38
|
+
## How It Works
|
|
39
|
+
|
|
40
|
+
### Step 1: Model a use case boundary
|
|
41
|
+
|
|
42
|
+
Define a single use case with a clear input and output DTO. Keep transport details (Express `req`, GraphQL `context`, job payload wrappers) outside this boundary.
|
|
43
|
+
|
|
44
|
+
### Step 2: Define outbound ports first
|
|
45
|
+
|
|
46
|
+
Identify every side effect as a port:
|
|
47
|
+
|
|
48
|
+
- persistence (`UserRepositoryPort`)
|
|
49
|
+
- external calls (`BillingGatewayPort`)
|
|
50
|
+
- cross-cutting (`LoggerPort`, `ClockPort`)
|
|
51
|
+
|
|
52
|
+
Ports should model capabilities, not technologies.
|
|
53
|
+
|
|
54
|
+
### Step 3: Implement the use case with pure orchestration
|
|
55
|
+
|
|
56
|
+
Use case class/function receives ports via constructor/arguments. It validates application-level invariants, coordinates domain rules, and returns plain data structures.
|
|
57
|
+
|
|
58
|
+
### Step 4: Build adapters at the edge
|
|
59
|
+
|
|
60
|
+
- Inbound adapter converts protocol input to use-case input.
|
|
61
|
+
- Outbound adapter maps app contracts to concrete APIs/ORM/query builders.
|
|
62
|
+
- Mapping stays in adapters, not inside use cases.
|
|
63
|
+
|
|
64
|
+
### Step 5: Wire everything in a composition root
|
|
65
|
+
|
|
66
|
+
Instantiate adapters, then inject them into use cases. Keep this wiring centralized to avoid hidden service-locator behavior.
|
|
67
|
+
|
|
68
|
+
### Step 6: Test per boundary
|
|
69
|
+
|
|
70
|
+
- Unit test use cases with fake ports.
|
|
71
|
+
- Integration test adapters with real infra dependencies.
|
|
72
|
+
- E2E test user-facing flows through inbound adapters.
|
|
73
|
+
|
|
74
|
+
## Architecture Diagram
|
|
75
|
+
|
|
76
|
+
```mermaid
|
|
77
|
+
flowchart LR
|
|
78
|
+
Client["Client (HTTP/CLI/Worker)"] --> InboundAdapter["Inbound Adapter"]
|
|
79
|
+
InboundAdapter -->|"calls"| UseCase["UseCase (Application Layer)"]
|
|
80
|
+
UseCase -->|"uses"| OutboundPort["OutboundPort (Interface)"]
|
|
81
|
+
OutboundAdapter["Outbound Adapter"] -->|"implements"| OutboundPort
|
|
82
|
+
OutboundAdapter --> ExternalSystem["DB/API/Queue"]
|
|
83
|
+
UseCase --> DomainModel["DomainModel"]
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
## Suggested Module Layout
|
|
87
|
+
|
|
88
|
+
Use feature-first organization with explicit boundaries:
|
|
89
|
+
|
|
90
|
+
```text
|
|
91
|
+
src/
|
|
92
|
+
features/
|
|
93
|
+
orders/
|
|
94
|
+
domain/
|
|
95
|
+
Order.ts
|
|
96
|
+
OrderPolicy.ts
|
|
97
|
+
application/
|
|
98
|
+
ports/
|
|
99
|
+
inbound/
|
|
100
|
+
CreateOrder.ts
|
|
101
|
+
outbound/
|
|
102
|
+
OrderRepositoryPort.ts
|
|
103
|
+
PaymentGatewayPort.ts
|
|
104
|
+
use-cases/
|
|
105
|
+
CreateOrderUseCase.ts
|
|
106
|
+
adapters/
|
|
107
|
+
inbound/
|
|
108
|
+
http/
|
|
109
|
+
createOrderRoute.ts
|
|
110
|
+
outbound/
|
|
111
|
+
postgres/
|
|
112
|
+
PostgresOrderRepository.ts
|
|
113
|
+
stripe/
|
|
114
|
+
StripePaymentGateway.ts
|
|
115
|
+
composition/
|
|
116
|
+
ordersContainer.ts
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
## TypeScript Example
|
|
120
|
+
|
|
121
|
+
### Port definitions
|
|
122
|
+
|
|
123
|
+
```typescript
|
|
124
|
+
export interface OrderRepositoryPort {
|
|
125
|
+
save(order: Order): Promise<void>;
|
|
126
|
+
findById(orderId: string): Promise<Order | null>;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export interface PaymentGatewayPort {
|
|
130
|
+
authorize(input: { orderId: string; amountCents: number }): Promise<{ authorizationId: string }>;
|
|
131
|
+
}
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Use case
|
|
135
|
+
|
|
136
|
+
```typescript
|
|
137
|
+
type CreateOrderInput = {
|
|
138
|
+
orderId: string;
|
|
139
|
+
amountCents: number;
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
type CreateOrderOutput = {
|
|
143
|
+
orderId: string;
|
|
144
|
+
authorizationId: string;
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
export class CreateOrderUseCase {
|
|
148
|
+
constructor(
|
|
149
|
+
private readonly orderRepository: OrderRepositoryPort,
|
|
150
|
+
private readonly paymentGateway: PaymentGatewayPort
|
|
151
|
+
) {}
|
|
152
|
+
|
|
153
|
+
async execute(input: CreateOrderInput): Promise<CreateOrderOutput> {
|
|
154
|
+
const order = Order.create({ id: input.orderId, amountCents: input.amountCents });
|
|
155
|
+
|
|
156
|
+
const auth = await this.paymentGateway.authorize({
|
|
157
|
+
orderId: order.id,
|
|
158
|
+
amountCents: order.amountCents,
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
// markAuthorized returns a new Order instance; it does not mutate in place.
|
|
162
|
+
const authorizedOrder = order.markAuthorized(auth.authorizationId);
|
|
163
|
+
await this.orderRepository.save(authorizedOrder);
|
|
164
|
+
|
|
165
|
+
return {
|
|
166
|
+
orderId: order.id,
|
|
167
|
+
authorizationId: auth.authorizationId,
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
### Outbound adapter
|
|
174
|
+
|
|
175
|
+
```typescript
|
|
176
|
+
export class PostgresOrderRepository implements OrderRepositoryPort {
|
|
177
|
+
constructor(private readonly db: SqlClient) {}
|
|
178
|
+
|
|
179
|
+
async save(order: Order): Promise<void> {
|
|
180
|
+
await this.db.query(
|
|
181
|
+
"insert into orders (id, amount_cents, status, authorization_id) values ($1, $2, $3, $4)",
|
|
182
|
+
[order.id, order.amountCents, order.status, order.authorizationId]
|
|
183
|
+
);
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
async findById(orderId: string): Promise<Order | null> {
|
|
187
|
+
const row = await this.db.oneOrNone("select * from orders where id = $1", [orderId]);
|
|
188
|
+
return row ? Order.rehydrate(row) : null;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
### Composition root
|
|
194
|
+
|
|
195
|
+
```typescript
|
|
196
|
+
export const buildCreateOrderUseCase = (deps: { db: SqlClient; stripe: StripeClient }) => {
|
|
197
|
+
const orderRepository = new PostgresOrderRepository(deps.db);
|
|
198
|
+
const paymentGateway = new StripePaymentGateway(deps.stripe);
|
|
199
|
+
|
|
200
|
+
return new CreateOrderUseCase(orderRepository, paymentGateway);
|
|
201
|
+
};
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
## Multi-Language Mapping
|
|
205
|
+
|
|
206
|
+
Use the same boundary rules across ecosystems; only syntax and wiring style change.
|
|
207
|
+
|
|
208
|
+
- **TypeScript/JavaScript**
|
|
209
|
+
- Ports: `application/ports/*` as interfaces/types.
|
|
210
|
+
- Use cases: classes/functions with constructor/argument injection.
|
|
211
|
+
- Adapters: `adapters/inbound/*`, `adapters/outbound/*`.
|
|
212
|
+
- Composition: explicit factory/container module (no hidden globals).
|
|
213
|
+
- **Java**
|
|
214
|
+
- Packages: `domain`, `application.port.in`, `application.port.out`, `application.usecase`, `adapter.in`, `adapter.out`.
|
|
215
|
+
- Ports: interfaces in `application.port.*`.
|
|
216
|
+
- Use cases: plain classes (Spring `@Service` is optional, not required).
|
|
217
|
+
- Composition: Spring config or manual wiring class; keep wiring out of domain/use-case classes.
|
|
218
|
+
- **Kotlin**
|
|
219
|
+
- Modules/packages mirror the Java split (`domain`, `application.port`, `application.usecase`, `adapter`).
|
|
220
|
+
- Ports: Kotlin interfaces.
|
|
221
|
+
- Use cases: classes with constructor injection (Koin/Dagger/Spring/manual).
|
|
222
|
+
- Composition: module definitions or dedicated composition functions; avoid service locator patterns.
|
|
223
|
+
- **Go**
|
|
224
|
+
- Packages: `internal/<feature>/domain`, `application`, `ports`, `adapters/inbound`, `adapters/outbound`.
|
|
225
|
+
- Ports: small interfaces owned by the consuming application package.
|
|
226
|
+
- Use cases: structs with interface fields plus explicit `New...` constructors.
|
|
227
|
+
- Composition: wire in `cmd/<app>/main.go` (or dedicated wiring package), keep constructors explicit.
|
|
228
|
+
|
|
229
|
+
## Anti-Patterns to Avoid
|
|
230
|
+
|
|
231
|
+
- Domain entities importing ORM models, web framework types, or SDK clients.
|
|
232
|
+
- Use cases reading directly from `req`, `res`, or queue metadata.
|
|
233
|
+
- Returning database rows directly from use cases without domain/application mapping.
|
|
234
|
+
- Letting adapters call each other directly instead of flowing through use-case ports.
|
|
235
|
+
- Spreading dependency wiring across many files with hidden global singletons.
|
|
236
|
+
|
|
237
|
+
## Migration Playbook
|
|
238
|
+
|
|
239
|
+
1. Pick one vertical slice (single endpoint/job) with frequent change pain.
|
|
240
|
+
2. Extract a use-case boundary with explicit input/output types.
|
|
241
|
+
3. Introduce outbound ports around existing infrastructure calls.
|
|
242
|
+
4. Move orchestration logic from controllers/services into the use case.
|
|
243
|
+
5. Keep old adapters, but make them delegate to the new use case.
|
|
244
|
+
6. Add tests around the new boundary (unit + adapter integration).
|
|
245
|
+
7. Repeat slice-by-slice; avoid full rewrites.
|
|
246
|
+
|
|
247
|
+
### Refactoring Existing Systems
|
|
248
|
+
|
|
249
|
+
- **Strangler approach**: keep current endpoints, route one use case at a time through new ports/adapters.
|
|
250
|
+
- **No big-bang rewrites**: migrate per feature slice and preserve behavior with characterization tests.
|
|
251
|
+
- **Facade first**: wrap legacy services behind outbound ports before replacing internals.
|
|
252
|
+
- **Composition freeze**: centralize wiring early so new dependencies do not leak into domain/use-case layers.
|
|
253
|
+
- **Slice selection rule**: prioritize high-churn, low-blast-radius flows first.
|
|
254
|
+
- **Rollback path**: keep a reversible toggle or route switch per migrated slice until production behavior is verified.
|
|
255
|
+
|
|
256
|
+
## Testing Guidance (Same Hexagonal Boundaries)
|
|
257
|
+
|
|
258
|
+
- **Domain tests**: test entities/value objects as pure business rules (no mocks, no framework setup).
|
|
259
|
+
- **Use-case unit tests**: test orchestration with fakes/stubs for outbound ports; assert business outcomes and port interactions.
|
|
260
|
+
- **Outbound adapter contract tests**: define shared contract suites at port level and run them against each adapter implementation.
|
|
261
|
+
- **Inbound adapter tests**: verify protocol mapping (HTTP/CLI/queue payload to use-case input and output/error mapping back to protocol).
|
|
262
|
+
- **Adapter integration tests**: run against real infrastructure (DB/API/queue) for serialization, schema/query behavior, retries, and timeouts.
|
|
263
|
+
- **End-to-end tests**: cover critical user journeys through inbound adapter -> use case -> outbound adapter.
|
|
264
|
+
- **Refactor safety**: add characterization tests before extraction; keep them until new boundary behavior is stable and equivalent.
|
|
265
|
+
|
|
266
|
+
## Best Practices Checklist
|
|
267
|
+
|
|
268
|
+
- Domain and use-case layers import only internal types and ports.
|
|
269
|
+
- Every external dependency is represented by an outbound port.
|
|
270
|
+
- Validation occurs at boundaries (inbound adapter + use-case invariants).
|
|
271
|
+
- Use immutable transformations (return new values/entities instead of mutating shared state).
|
|
272
|
+
- Errors are translated across boundaries (infra errors -> application/domain errors).
|
|
273
|
+
- Composition root is explicit and easy to audit.
|
|
274
|
+
- Use cases are testable with simple in-memory fakes for ports.
|
|
275
|
+
- Refactoring starts from one vertical slice with behavior-preserving tests.
|
|
276
|
+
- Language/framework specifics stay in adapters, never in domain rules.
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: iterative-retrieval
|
|
3
|
+
description: Pattern for progressively refining context retrieval to solve the subagent context problem
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Iterative Retrieval Pattern
|
|
8
|
+
|
|
9
|
+
Solves the "context problem" in multi-agent workflows where subagents don't know what context they need until they start working.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Spawning subagents that need codebase context they cannot predict upfront
|
|
14
|
+
- Building multi-agent workflows where context is progressively refined
|
|
15
|
+
- Encountering "context too large" or "missing context" failures in agent tasks
|
|
16
|
+
- Designing RAG-like retrieval pipelines for code exploration
|
|
17
|
+
- Optimizing token usage in agent orchestration
|
|
18
|
+
|
|
19
|
+
## The Problem
|
|
20
|
+
|
|
21
|
+
Subagents are spawned with limited context. They don't know:
|
|
22
|
+
- Which files contain relevant code
|
|
23
|
+
- What patterns exist in the codebase
|
|
24
|
+
- What terminology the project uses
|
|
25
|
+
|
|
26
|
+
Standard approaches fail:
|
|
27
|
+
- **Send everything**: Exceeds context limits
|
|
28
|
+
- **Send nothing**: Agent lacks critical information
|
|
29
|
+
- **Guess what's needed**: Often wrong
|
|
30
|
+
|
|
31
|
+
## The Solution: Iterative Retrieval
|
|
32
|
+
|
|
33
|
+
A 4-phase loop that progressively refines context:
|
|
34
|
+
|
|
35
|
+
```
|
|
36
|
+
┌─────────────────────────────────────────────┐
|
|
37
|
+
│ │
|
|
38
|
+
│ ┌──────────┐ ┌──────────┐ │
|
|
39
|
+
│ │ DISPATCH │─────│ EVALUATE │ │
|
|
40
|
+
│ └──────────┘ └──────────┘ │
|
|
41
|
+
│ ▲ │ │
|
|
42
|
+
│ │ ▼ │
|
|
43
|
+
│ ┌──────────┐ ┌──────────┐ │
|
|
44
|
+
│ │ LOOP │─────│ REFINE │ │
|
|
45
|
+
│ └──────────┘ └──────────┘ │
|
|
46
|
+
│ │
|
|
47
|
+
│ Max 3 cycles, then proceed │
|
|
48
|
+
└─────────────────────────────────────────────┘
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Phase 1: DISPATCH
|
|
52
|
+
|
|
53
|
+
Initial broad query to gather candidate files:
|
|
54
|
+
|
|
55
|
+
```javascript
|
|
56
|
+
// Start with high-level intent
|
|
57
|
+
const initialQuery = {
|
|
58
|
+
patterns: ['src/**/*.ts', 'lib/**/*.ts'],
|
|
59
|
+
keywords: ['authentication', 'user', 'session'],
|
|
60
|
+
excludes: ['*.test.ts', '*.spec.ts']
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
// Dispatch to retrieval agent
|
|
64
|
+
const candidates = await retrieveFiles(initialQuery);
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
### Phase 2: EVALUATE
|
|
68
|
+
|
|
69
|
+
Assess retrieved content for relevance:
|
|
70
|
+
|
|
71
|
+
```javascript
|
|
72
|
+
function evaluateRelevance(files, task) {
|
|
73
|
+
return files.map(file => ({
|
|
74
|
+
path: file.path,
|
|
75
|
+
relevance: scoreRelevance(file.content, task),
|
|
76
|
+
reason: explainRelevance(file.content, task),
|
|
77
|
+
missingContext: identifyGaps(file.content, task)
|
|
78
|
+
}));
|
|
79
|
+
}
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
Scoring criteria:
|
|
83
|
+
- **High (0.8-1.0)**: Directly implements target functionality
|
|
84
|
+
- **Medium (0.5-0.7)**: Contains related patterns or types
|
|
85
|
+
- **Low (0.2-0.4)**: Tangentially related
|
|
86
|
+
- **None (0-0.2)**: Not relevant, exclude
|
|
87
|
+
|
|
88
|
+
### Phase 3: REFINE
|
|
89
|
+
|
|
90
|
+
Update search criteria based on evaluation:
|
|
91
|
+
|
|
92
|
+
```javascript
|
|
93
|
+
function refineQuery(evaluation, previousQuery) {
|
|
94
|
+
return {
|
|
95
|
+
// Add new patterns discovered in high-relevance files
|
|
96
|
+
patterns: [...previousQuery.patterns, ...extractPatterns(evaluation)],
|
|
97
|
+
|
|
98
|
+
// Add terminology found in codebase
|
|
99
|
+
keywords: [...previousQuery.keywords, ...extractKeywords(evaluation)],
|
|
100
|
+
|
|
101
|
+
// Exclude confirmed irrelevant paths
|
|
102
|
+
excludes: [...previousQuery.excludes, ...evaluation
|
|
103
|
+
.filter(e => e.relevance < 0.2)
|
|
104
|
+
.map(e => e.path)
|
|
105
|
+
],
|
|
106
|
+
|
|
107
|
+
// Target specific gaps
|
|
108
|
+
focusAreas: evaluation
|
|
109
|
+
.flatMap(e => e.missingContext)
|
|
110
|
+
.filter(unique)
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
### Phase 4: LOOP
|
|
116
|
+
|
|
117
|
+
Repeat with refined criteria (max 3 cycles):
|
|
118
|
+
|
|
119
|
+
```javascript
|
|
120
|
+
async function iterativeRetrieve(task, maxCycles = 3) {
|
|
121
|
+
let query = createInitialQuery(task);
|
|
122
|
+
let bestContext = [];
|
|
123
|
+
|
|
124
|
+
for (let cycle = 0; cycle < maxCycles; cycle++) {
|
|
125
|
+
const candidates = await retrieveFiles(query);
|
|
126
|
+
const evaluation = evaluateRelevance(candidates, task);
|
|
127
|
+
|
|
128
|
+
// Check if we have sufficient context
|
|
129
|
+
const highRelevance = evaluation.filter(e => e.relevance >= 0.7);
|
|
130
|
+
if (highRelevance.length >= 3 && !hasCriticalGaps(evaluation)) {
|
|
131
|
+
return highRelevance;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// Refine and continue
|
|
135
|
+
query = refineQuery(evaluation, query);
|
|
136
|
+
bestContext = mergeContext(bestContext, highRelevance);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
return bestContext;
|
|
140
|
+
}
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
## Practical Examples
|
|
144
|
+
|
|
145
|
+
### Example 1: Bug Fix Context
|
|
146
|
+
|
|
147
|
+
```
|
|
148
|
+
Task: "Fix the authentication token expiry bug"
|
|
149
|
+
|
|
150
|
+
Cycle 1:
|
|
151
|
+
DISPATCH: Search for "token", "auth", "expiry" in src/**
|
|
152
|
+
EVALUATE: Found auth.ts (0.9), tokens.ts (0.8), user.ts (0.3)
|
|
153
|
+
REFINE: Add "refresh", "jwt" keywords; exclude user.ts
|
|
154
|
+
|
|
155
|
+
Cycle 2:
|
|
156
|
+
DISPATCH: Search refined terms
|
|
157
|
+
EVALUATE: Found session-manager.ts (0.95), jwt-utils.ts (0.85)
|
|
158
|
+
REFINE: Sufficient context (2 high-relevance files)
|
|
159
|
+
|
|
160
|
+
Result: auth.ts, tokens.ts, session-manager.ts, jwt-utils.ts
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
### Example 2: Feature Implementation
|
|
164
|
+
|
|
165
|
+
```
|
|
166
|
+
Task: "Add rate limiting to API endpoints"
|
|
167
|
+
|
|
168
|
+
Cycle 1:
|
|
169
|
+
DISPATCH: Search "rate", "limit", "api" in routes/**
|
|
170
|
+
EVALUATE: No matches - codebase uses "throttle" terminology
|
|
171
|
+
REFINE: Add "throttle", "middleware" keywords
|
|
172
|
+
|
|
173
|
+
Cycle 2:
|
|
174
|
+
DISPATCH: Search refined terms
|
|
175
|
+
EVALUATE: Found throttle.ts (0.9), middleware/index.ts (0.7)
|
|
176
|
+
REFINE: Need router patterns
|
|
177
|
+
|
|
178
|
+
Cycle 3:
|
|
179
|
+
DISPATCH: Search "router", "express" patterns
|
|
180
|
+
EVALUATE: Found router-setup.ts (0.8)
|
|
181
|
+
REFINE: Sufficient context
|
|
182
|
+
|
|
183
|
+
Result: throttle.ts, middleware/index.ts, router-setup.ts
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
## Integration with Agents
|
|
187
|
+
|
|
188
|
+
Use in agent prompts:
|
|
189
|
+
|
|
190
|
+
```markdown
|
|
191
|
+
When retrieving context for this task:
|
|
192
|
+
1. Start with broad keyword search
|
|
193
|
+
2. Evaluate each file's relevance (0-1 scale)
|
|
194
|
+
3. Identify what context is still missing
|
|
195
|
+
4. Refine search criteria and repeat (max 3 cycles)
|
|
196
|
+
5. Return files with relevance >= 0.7
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
## Best Practices
|
|
200
|
+
|
|
201
|
+
1. **Start broad, narrow progressively** - Don't over-specify initial queries
|
|
202
|
+
2. **Learn codebase terminology** - First cycle often reveals naming conventions
|
|
203
|
+
3. **Track what's missing** - Explicit gap identification drives refinement
|
|
204
|
+
4. **Stop at "good enough"** - 3 high-relevance files beats 10 mediocre ones
|
|
205
|
+
5. **Exclude confidently** - Low-relevance files won't become relevant
|
|
206
|
+
|
|
207
|
+
## Related
|
|
208
|
+
|
|
209
|
+
- [The Longform Guide](https://x.com/affaanmustafa/status/2014040193557471352) - Subagent orchestration section
|
|
210
|
+
- `continuous-learning` skill - For patterns that improve over time
|
|
211
|
+
- Agent definitions bundled with ECC (manual install path: `agents/`)
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: java-coding-standards
|
|
3
|
+
description: "Java coding standards for Spring Boot services: naming, immutability, Optional usage, streams, exceptions, generics, and project layout."
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Java Coding Standards
|
|
8
|
+
|
|
9
|
+
Standards for readable, maintainable Java (17+) code in Spring Boot services.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Writing or reviewing Java code in Spring Boot projects
|
|
14
|
+
- Enforcing naming, immutability, or exception handling conventions
|
|
15
|
+
- Working with records, sealed classes, or pattern matching (Java 17+)
|
|
16
|
+
- Reviewing use of Optional, streams, or generics
|
|
17
|
+
- Structuring packages and project layout
|
|
18
|
+
|
|
19
|
+
## Core Principles
|
|
20
|
+
|
|
21
|
+
- Prefer clarity over cleverness
|
|
22
|
+
- Immutable by default; minimize shared mutable state
|
|
23
|
+
- Fail fast with meaningful exceptions
|
|
24
|
+
- Consistent naming and package structure
|
|
25
|
+
|
|
26
|
+
## Naming
|
|
27
|
+
|
|
28
|
+
```java
|
|
29
|
+
// ✅ Classes/Records: PascalCase
|
|
30
|
+
public class MarketService {}
|
|
31
|
+
public record Money(BigDecimal amount, Currency currency) {}
|
|
32
|
+
|
|
33
|
+
// ✅ Methods/fields: camelCase
|
|
34
|
+
private final MarketRepository marketRepository;
|
|
35
|
+
public Market findBySlug(String slug) {}
|
|
36
|
+
|
|
37
|
+
// ✅ Constants: UPPER_SNAKE_CASE
|
|
38
|
+
private static final int MAX_PAGE_SIZE = 100;
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
## Immutability
|
|
42
|
+
|
|
43
|
+
```java
|
|
44
|
+
// ✅ Favor records and final fields
|
|
45
|
+
public record MarketDto(Long id, String name, MarketStatus status) {}
|
|
46
|
+
|
|
47
|
+
public class Market {
|
|
48
|
+
private final Long id;
|
|
49
|
+
private final String name;
|
|
50
|
+
// getters only, no setters
|
|
51
|
+
}
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
## Optional Usage
|
|
55
|
+
|
|
56
|
+
```java
|
|
57
|
+
// ✅ Return Optional from find* methods
|
|
58
|
+
Optional<Market> market = marketRepository.findBySlug(slug);
|
|
59
|
+
|
|
60
|
+
// ✅ Map/flatMap instead of get()
|
|
61
|
+
return market
|
|
62
|
+
.map(MarketResponse::from)
|
|
63
|
+
.orElseThrow(() -> new EntityNotFoundException("Market not found"));
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
## Streams Best Practices
|
|
67
|
+
|
|
68
|
+
```java
|
|
69
|
+
// ✅ Use streams for transformations, keep pipelines short
|
|
70
|
+
List<String> names = markets.stream()
|
|
71
|
+
.map(Market::name)
|
|
72
|
+
.filter(Objects::nonNull)
|
|
73
|
+
.toList();
|
|
74
|
+
|
|
75
|
+
// ❌ Avoid complex nested streams; prefer loops for clarity
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
## Exceptions
|
|
79
|
+
|
|
80
|
+
- Use unchecked exceptions for domain errors; wrap technical exceptions with context
|
|
81
|
+
- Create domain-specific exceptions (e.g., `MarketNotFoundException`)
|
|
82
|
+
- Avoid broad `catch (Exception ex)` unless rethrowing/logging centrally
|
|
83
|
+
|
|
84
|
+
```java
|
|
85
|
+
throw new MarketNotFoundException(slug);
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
## Generics and Type Safety
|
|
89
|
+
|
|
90
|
+
- Avoid raw types; declare generic parameters
|
|
91
|
+
- Prefer bounded generics for reusable utilities
|
|
92
|
+
|
|
93
|
+
```java
|
|
94
|
+
public <T extends Identifiable> Map<Long, T> indexById(Collection<T> items) { ... }
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
## Project Structure (Maven/Gradle)
|
|
98
|
+
|
|
99
|
+
```
|
|
100
|
+
src/main/java/com/example/app/
|
|
101
|
+
config/
|
|
102
|
+
controller/
|
|
103
|
+
service/
|
|
104
|
+
repository/
|
|
105
|
+
domain/
|
|
106
|
+
dto/
|
|
107
|
+
util/
|
|
108
|
+
src/main/resources/
|
|
109
|
+
application.yml
|
|
110
|
+
src/test/java/... (mirrors main)
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
## Formatting and Style
|
|
114
|
+
|
|
115
|
+
- Use 2 or 4 spaces consistently (project standard)
|
|
116
|
+
- One public top-level type per file
|
|
117
|
+
- Keep methods short and focused; extract helpers
|
|
118
|
+
- Order members: constants, fields, constructors, public methods, protected, private
|
|
119
|
+
|
|
120
|
+
## Code Smells to Avoid
|
|
121
|
+
|
|
122
|
+
- Long parameter lists → use DTO/builders
|
|
123
|
+
- Deep nesting → early returns
|
|
124
|
+
- Magic numbers → named constants
|
|
125
|
+
- Static mutable state → prefer dependency injection
|
|
126
|
+
- Silent catch blocks → log and act or rethrow
|
|
127
|
+
|
|
128
|
+
## Logging
|
|
129
|
+
|
|
130
|
+
```java
|
|
131
|
+
private static final Logger log = LoggerFactory.getLogger(MarketService.class);
|
|
132
|
+
log.info("fetch_market slug={}", slug);
|
|
133
|
+
log.error("failed_fetch_market slug={}", slug, ex);
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
## Null Handling
|
|
137
|
+
|
|
138
|
+
- Accept `@Nullable` only when unavoidable; otherwise use `@NonNull`
|
|
139
|
+
- Use Bean Validation (`@NotNull`, `@NotBlank`) on inputs
|
|
140
|
+
|
|
141
|
+
## Testing Expectations
|
|
142
|
+
|
|
143
|
+
- JUnit 5 + AssertJ for fluent assertions
|
|
144
|
+
- Mockito for mocking; avoid partial mocks where possible
|
|
145
|
+
- Favor deterministic tests; no hidden sleeps
|
|
146
|
+
|
|
147
|
+
**Remember**: Keep code intentional, typed, and observable. Optimize for maintainability over micro-optimizations unless proven necessary.
|