@opengsd/gsd-core 1.2.0-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (503) hide show
  1. package/LICENSE +21 -0
  2. package/README.ja-JP.md +870 -0
  3. package/README.ko-KR.md +861 -0
  4. package/README.md +301 -0
  5. package/README.pt-BR.md +492 -0
  6. package/README.zh-CN.md +842 -0
  7. package/agents/gsd-advisor-researcher.md +127 -0
  8. package/agents/gsd-ai-researcher.md +133 -0
  9. package/agents/gsd-assumptions-analyzer.md +105 -0
  10. package/agents/gsd-code-fixer.md +668 -0
  11. package/agents/gsd-code-reviewer.md +387 -0
  12. package/agents/gsd-codebase-mapper.md +853 -0
  13. package/agents/gsd-debug-session-manager.md +314 -0
  14. package/agents/gsd-debugger.md +1452 -0
  15. package/agents/gsd-doc-classifier.md +168 -0
  16. package/agents/gsd-doc-synthesizer.md +204 -0
  17. package/agents/gsd-doc-verifier.md +217 -0
  18. package/agents/gsd-doc-writer.md +615 -0
  19. package/agents/gsd-domain-researcher.md +153 -0
  20. package/agents/gsd-eval-auditor.md +191 -0
  21. package/agents/gsd-eval-planner.md +154 -0
  22. package/agents/gsd-executor.md +772 -0
  23. package/agents/gsd-framework-selector.md +160 -0
  24. package/agents/gsd-integration-checker.md +470 -0
  25. package/agents/gsd-intel-updater.md +342 -0
  26. package/agents/gsd-nyquist-auditor.md +203 -0
  27. package/agents/gsd-pattern-mapper.md +335 -0
  28. package/agents/gsd-phase-researcher.md +928 -0
  29. package/agents/gsd-plan-checker.md +978 -0
  30. package/agents/gsd-planner.md +1218 -0
  31. package/agents/gsd-project-researcher.md +677 -0
  32. package/agents/gsd-research-synthesizer.md +255 -0
  33. package/agents/gsd-roadmapper.md +688 -0
  34. package/agents/gsd-security-auditor.md +155 -0
  35. package/agents/gsd-ui-auditor.md +495 -0
  36. package/agents/gsd-ui-checker.md +309 -0
  37. package/agents/gsd-ui-researcher.md +380 -0
  38. package/agents/gsd-user-profiler.md +171 -0
  39. package/agents/gsd-verifier.md +917 -0
  40. package/bin/install.js +10936 -0
  41. package/bin/lib/ui-safety-gate.cjs +107 -0
  42. package/commands/gsd/add-tests.md +42 -0
  43. package/commands/gsd/ai-integration-phase.md +37 -0
  44. package/commands/gsd/audit-fix.md +34 -0
  45. package/commands/gsd/audit-milestone.md +37 -0
  46. package/commands/gsd/audit-uat.md +24 -0
  47. package/commands/gsd/autonomous.md +46 -0
  48. package/commands/gsd/capture.md +62 -0
  49. package/commands/gsd/cleanup.md +24 -0
  50. package/commands/gsd/code-review.md +59 -0
  51. package/commands/gsd/complete-milestone.md +143 -0
  52. package/commands/gsd/config.md +56 -0
  53. package/commands/gsd/debug.md +52 -0
  54. package/commands/gsd/discuss-phase.md +76 -0
  55. package/commands/gsd/docs-update.md +49 -0
  56. package/commands/gsd/eval-review.md +33 -0
  57. package/commands/gsd/execute-phase.md +64 -0
  58. package/commands/gsd/explore.md +27 -0
  59. package/commands/gsd/extract-learnings.md +23 -0
  60. package/commands/gsd/fast.md +31 -0
  61. package/commands/gsd/forensics.md +57 -0
  62. package/commands/gsd/graphify.md +199 -0
  63. package/commands/gsd/health.md +31 -0
  64. package/commands/gsd/help.md +28 -0
  65. package/commands/gsd/import.md +41 -0
  66. package/commands/gsd/inbox.md +39 -0
  67. package/commands/gsd/ingest-docs.md +42 -0
  68. package/commands/gsd/manager.md +45 -0
  69. package/commands/gsd/map-codebase.md +83 -0
  70. package/commands/gsd/milestone-summary.md +51 -0
  71. package/commands/gsd/mvp-phase.md +45 -0
  72. package/commands/gsd/new-milestone.md +45 -0
  73. package/commands/gsd/new-project.md +47 -0
  74. package/commands/gsd/ns-context.md +23 -0
  75. package/commands/gsd/ns-ideate.md +24 -0
  76. package/commands/gsd/ns-manage.md +29 -0
  77. package/commands/gsd/ns-project.md +22 -0
  78. package/commands/gsd/ns-review.md +26 -0
  79. package/commands/gsd/ns-workflow.md +28 -0
  80. package/commands/gsd/pause-work.md +43 -0
  81. package/commands/gsd/phase.md +56 -0
  82. package/commands/gsd/plan-phase.md +62 -0
  83. package/commands/gsd/plan-review-convergence.md +59 -0
  84. package/commands/gsd/pr-branch.md +26 -0
  85. package/commands/gsd/profile-user.md +46 -0
  86. package/commands/gsd/progress.md +47 -0
  87. package/commands/gsd/quick.md +174 -0
  88. package/commands/gsd/resume-work.md +30 -0
  89. package/commands/gsd/review-backlog.md +63 -0
  90. package/commands/gsd/review.md +41 -0
  91. package/commands/gsd/secure-phase.md +36 -0
  92. package/commands/gsd/settings.md +29 -0
  93. package/commands/gsd/ship.md +24 -0
  94. package/commands/gsd/sketch.md +60 -0
  95. package/commands/gsd/spec-phase.md +63 -0
  96. package/commands/gsd/spike.md +57 -0
  97. package/commands/gsd/stats.md +19 -0
  98. package/commands/gsd/surface.md +155 -0
  99. package/commands/gsd/thread.md +24 -0
  100. package/commands/gsd/ui-phase.md +35 -0
  101. package/commands/gsd/ui-review.md +33 -0
  102. package/commands/gsd/ultraplan-phase.md +34 -0
  103. package/commands/gsd/undo.md +35 -0
  104. package/commands/gsd/update.md +48 -0
  105. package/commands/gsd/validate-phase.md +36 -0
  106. package/commands/gsd/verify-work.md +39 -0
  107. package/commands/gsd/workspace.md +52 -0
  108. package/commands/gsd/workstreams.md +70 -0
  109. package/get-shit-done/bin/check-latest-version.cjs +106 -0
  110. package/get-shit-done/bin/gsd-tools.cjs +1676 -0
  111. package/get-shit-done/bin/lib/active-workstream-store.cjs +302 -0
  112. package/get-shit-done/bin/lib/adr-parser.cjs +394 -0
  113. package/get-shit-done/bin/lib/agent-command-router.cjs +65 -0
  114. package/get-shit-done/bin/lib/artifacts.cjs +53 -0
  115. package/get-shit-done/bin/lib/audit.cjs +755 -0
  116. package/get-shit-done/bin/lib/check-command-router.cjs +333 -0
  117. package/get-shit-done/bin/lib/cjs-command-router-adapter.cjs +118 -0
  118. package/get-shit-done/bin/lib/clock.cjs +96 -0
  119. package/get-shit-done/bin/lib/clusters.cjs +135 -0
  120. package/get-shit-done/bin/lib/code-review-flags.cjs +74 -0
  121. package/get-shit-done/bin/lib/command-aliases.cjs +815 -0
  122. package/get-shit-done/bin/lib/command-arg-projection.cjs +62 -0
  123. package/get-shit-done/bin/lib/command-routing-hub.cjs +388 -0
  124. package/get-shit-done/bin/lib/commands.cjs +1188 -0
  125. package/get-shit-done/bin/lib/config-schema.cjs +31 -0
  126. package/get-shit-done/bin/lib/config.cjs +728 -0
  127. package/get-shit-done/bin/lib/configuration.cjs +248 -0
  128. package/get-shit-done/bin/lib/context-utilization.cjs +47 -0
  129. package/get-shit-done/bin/lib/core.cjs +2121 -0
  130. package/get-shit-done/bin/lib/decisions.cjs +116 -0
  131. package/get-shit-done/bin/lib/docs.cjs +270 -0
  132. package/get-shit-done/bin/lib/drift.cjs +388 -0
  133. package/get-shit-done/bin/lib/fallow-runner.cjs +109 -0
  134. package/get-shit-done/bin/lib/frontmatter.cjs +389 -0
  135. package/get-shit-done/bin/lib/gap-checker.cjs +205 -0
  136. package/get-shit-done/bin/lib/graphify.cjs +592 -0
  137. package/get-shit-done/bin/lib/gsd2-import.cjs +514 -0
  138. package/get-shit-done/bin/lib/init-command-router.cjs +58 -0
  139. package/get-shit-done/bin/lib/init.cjs +2112 -0
  140. package/get-shit-done/bin/lib/install-profiles.cjs +603 -0
  141. package/get-shit-done/bin/lib/installer-migration-authoring.cjs +117 -0
  142. package/get-shit-done/bin/lib/installer-migration-report.cjs +354 -0
  143. package/get-shit-done/bin/lib/installer-migrations/000-first-time-baseline.cjs +220 -0
  144. package/get-shit-done/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +41 -0
  145. package/get-shit-done/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +80 -0
  146. package/get-shit-done/bin/lib/installer-migrations.cjs +778 -0
  147. package/get-shit-done/bin/lib/intel.cjs +708 -0
  148. package/get-shit-done/bin/lib/learnings.cjs +421 -0
  149. package/get-shit-done/bin/lib/milestone.cjs +314 -0
  150. package/get-shit-done/bin/lib/model-catalog.cjs +212 -0
  151. package/get-shit-done/bin/lib/model-profiles.cjs +31 -0
  152. package/get-shit-done/bin/lib/observability/event.cjs +82 -0
  153. package/get-shit-done/bin/lib/observability/logger.cjs +174 -0
  154. package/get-shit-done/bin/lib/observability/redaction.cjs +50 -0
  155. package/get-shit-done/bin/lib/package-identity.cjs +31 -0
  156. package/get-shit-done/bin/lib/phase-command-router.cjs +191 -0
  157. package/get-shit-done/bin/lib/phase-lifecycle.cjs +80 -0
  158. package/get-shit-done/bin/lib/phase.cjs +1607 -0
  159. package/get-shit-done/bin/lib/phases-command-router.cjs +39 -0
  160. package/get-shit-done/bin/lib/plan-scan.cjs +97 -0
  161. package/get-shit-done/bin/lib/planning-workspace.cjs +238 -0
  162. package/get-shit-done/bin/lib/profile-output.cjs +1141 -0
  163. package/get-shit-done/bin/lib/profile-pipeline.cjs +539 -0
  164. package/get-shit-done/bin/lib/project-root.cjs +112 -0
  165. package/get-shit-done/bin/lib/prompt-budget.cjs +399 -0
  166. package/get-shit-done/bin/lib/review-reviewer-selection.cjs +125 -0
  167. package/get-shit-done/bin/lib/roadmap-command-router.cjs +28 -0
  168. package/get-shit-done/bin/lib/roadmap.cjs +650 -0
  169. package/get-shit-done/bin/lib/runtime-artifact-layout.cjs +301 -0
  170. package/get-shit-done/bin/lib/runtime-homes.cjs +222 -0
  171. package/get-shit-done/bin/lib/runtime-name-policy.cjs +83 -0
  172. package/get-shit-done/bin/lib/runtime-slash.cjs +112 -0
  173. package/get-shit-done/bin/lib/schema-detect.cjs +165 -0
  174. package/get-shit-done/bin/lib/secrets.cjs +32 -0
  175. package/get-shit-done/bin/lib/security.cjs +600 -0
  176. package/get-shit-done/bin/lib/semver-compare.cjs +35 -0
  177. package/get-shit-done/bin/lib/shell-command-projection.cjs +500 -0
  178. package/get-shit-done/bin/lib/state-command-router.cjs +252 -0
  179. package/get-shit-done/bin/lib/state-document.cjs +263 -0
  180. package/get-shit-done/bin/lib/state.cjs +2038 -0
  181. package/get-shit-done/bin/lib/surface.cjs +470 -0
  182. package/get-shit-done/bin/lib/task-command-router.cjs +81 -0
  183. package/get-shit-done/bin/lib/template.cjs +228 -0
  184. package/get-shit-done/bin/lib/uat.cjs +289 -0
  185. package/get-shit-done/bin/lib/update-context.cjs +209 -0
  186. package/get-shit-done/bin/lib/validate-command-router.cjs +83 -0
  187. package/get-shit-done/bin/lib/validate.cjs +92 -0
  188. package/get-shit-done/bin/lib/verify-command-router.cjs +40 -0
  189. package/get-shit-done/bin/lib/verify.cjs +1511 -0
  190. package/get-shit-done/bin/lib/workstream-inventory-builder.cjs +74 -0
  191. package/get-shit-done/bin/lib/workstream-inventory.cjs +146 -0
  192. package/get-shit-done/bin/lib/workstream-name-policy.cjs +94 -0
  193. package/get-shit-done/bin/lib/workstream.cjs +389 -0
  194. package/get-shit-done/bin/lib/worktree-safety.cjs +985 -0
  195. package/get-shit-done/bin/shared/config-defaults.manifest.json +97 -0
  196. package/get-shit-done/bin/shared/config-schema.manifest.json +175 -0
  197. package/get-shit-done/bin/shared/model-catalog.json +122 -0
  198. package/get-shit-done/bin/shared/runtime-aliases.manifest.json +75 -0
  199. package/get-shit-done/bin/verify-reapply-patches.cjs +352 -0
  200. package/get-shit-done/contexts/dev.md +21 -0
  201. package/get-shit-done/contexts/research.md +22 -0
  202. package/get-shit-done/contexts/review.md +23 -0
  203. package/get-shit-done/references/agent-contracts.md +79 -0
  204. package/get-shit-done/references/ai-evals.md +156 -0
  205. package/get-shit-done/references/ai-frameworks.md +186 -0
  206. package/get-shit-done/references/artifact-types.md +131 -0
  207. package/get-shit-done/references/autonomous-smart-discuss.md +277 -0
  208. package/get-shit-done/references/checkpoints.md +814 -0
  209. package/get-shit-done/references/common-bug-patterns.md +114 -0
  210. package/get-shit-done/references/context-budget.md +85 -0
  211. package/get-shit-done/references/continuation-format.md +253 -0
  212. package/get-shit-done/references/debugger-philosophy.md +76 -0
  213. package/get-shit-done/references/decimal-phase-calculation.md +64 -0
  214. package/get-shit-done/references/doc-conflict-engine.md +91 -0
  215. package/get-shit-done/references/domain-probes.md +125 -0
  216. package/get-shit-done/references/execute-mvp-tdd.md +81 -0
  217. package/get-shit-done/references/executor-examples.md +110 -0
  218. package/get-shit-done/references/few-shot-examples/plan-checker.md +73 -0
  219. package/get-shit-done/references/few-shot-examples/verifier.md +109 -0
  220. package/get-shit-done/references/gate-prompts.md +100 -0
  221. package/get-shit-done/references/gates.md +70 -0
  222. package/get-shit-done/references/git-integration.md +298 -0
  223. package/get-shit-done/references/git-planning-commit.md +40 -0
  224. package/get-shit-done/references/ios-scaffold.md +123 -0
  225. package/get-shit-done/references/mandatory-initial-read.md +2 -0
  226. package/get-shit-done/references/model-profile-resolution.md +38 -0
  227. package/get-shit-done/references/model-profiles.md +245 -0
  228. package/get-shit-done/references/mvp-concepts.md +49 -0
  229. package/get-shit-done/references/phase-argument-parsing.md +61 -0
  230. package/get-shit-done/references/planner-antipatterns.md +89 -0
  231. package/get-shit-done/references/planner-chunked.md +49 -0
  232. package/get-shit-done/references/planner-gap-closure.md +62 -0
  233. package/get-shit-done/references/planner-graphify-auto-update.md +67 -0
  234. package/get-shit-done/references/planner-human-verify-mode.md +57 -0
  235. package/get-shit-done/references/planner-interface-context.md +62 -0
  236. package/get-shit-done/references/planner-mvp-mode.md +53 -0
  237. package/get-shit-done/references/planner-reviews.md +39 -0
  238. package/get-shit-done/references/planner-revision.md +87 -0
  239. package/get-shit-done/references/planner-source-audit.md +73 -0
  240. package/get-shit-done/references/planning-config.md +471 -0
  241. package/get-shit-done/references/project-skills-discovery.md +19 -0
  242. package/get-shit-done/references/questioning.md +162 -0
  243. package/get-shit-done/references/revision-loop.md +97 -0
  244. package/get-shit-done/references/scout-codebase.md +51 -0
  245. package/get-shit-done/references/skeleton-template.md +48 -0
  246. package/get-shit-done/references/sketch-interactivity.md +41 -0
  247. package/get-shit-done/references/sketch-theme-system.md +94 -0
  248. package/get-shit-done/references/sketch-tooling.md +45 -0
  249. package/get-shit-done/references/sketch-variant-patterns.md +81 -0
  250. package/get-shit-done/references/spidr-splitting.md +69 -0
  251. package/get-shit-done/references/tdd.md +330 -0
  252. package/get-shit-done/references/thinking-models-debug.md +44 -0
  253. package/get-shit-done/references/thinking-models-execution.md +50 -0
  254. package/get-shit-done/references/thinking-models-planning.md +62 -0
  255. package/get-shit-done/references/thinking-models-research.md +50 -0
  256. package/get-shit-done/references/thinking-models-verification.md +55 -0
  257. package/get-shit-done/references/thinking-partner.md +96 -0
  258. package/get-shit-done/references/ui-brand.md +160 -0
  259. package/get-shit-done/references/universal-anti-patterns.md +63 -0
  260. package/get-shit-done/references/user-profiling.md +681 -0
  261. package/get-shit-done/references/user-story-template.md +58 -0
  262. package/get-shit-done/references/verification-overrides.md +227 -0
  263. package/get-shit-done/references/verification-patterns.md +612 -0
  264. package/get-shit-done/references/verify-mvp-mode.md +85 -0
  265. package/get-shit-done/references/workstream-flag.md +111 -0
  266. package/get-shit-done/references/worktree-path-safety.md +89 -0
  267. package/get-shit-done/templates/AI-SPEC.md +246 -0
  268. package/get-shit-done/templates/DEBUG.md +169 -0
  269. package/get-shit-done/templates/README.md +77 -0
  270. package/get-shit-done/templates/SECURITY.md +61 -0
  271. package/get-shit-done/templates/UAT.md +265 -0
  272. package/get-shit-done/templates/UI-SPEC.md +100 -0
  273. package/get-shit-done/templates/VALIDATION.md +76 -0
  274. package/get-shit-done/templates/claude-md.md +145 -0
  275. package/get-shit-done/templates/codebase/architecture.md +255 -0
  276. package/get-shit-done/templates/codebase/concerns.md +310 -0
  277. package/get-shit-done/templates/codebase/conventions.md +307 -0
  278. package/get-shit-done/templates/codebase/integrations.md +280 -0
  279. package/get-shit-done/templates/codebase/stack.md +186 -0
  280. package/get-shit-done/templates/codebase/structure.md +285 -0
  281. package/get-shit-done/templates/codebase/testing.md +480 -0
  282. package/get-shit-done/templates/config.json +62 -0
  283. package/get-shit-done/templates/context.md +352 -0
  284. package/get-shit-done/templates/continue-here.md +78 -0
  285. package/get-shit-done/templates/copilot-instructions.md +7 -0
  286. package/get-shit-done/templates/debug-subagent-prompt.md +91 -0
  287. package/get-shit-done/templates/dev-preferences.md +21 -0
  288. package/get-shit-done/templates/discovery.md +146 -0
  289. package/get-shit-done/templates/discussion-log.md +63 -0
  290. package/get-shit-done/templates/milestone-archive.md +123 -0
  291. package/get-shit-done/templates/milestone.md +115 -0
  292. package/get-shit-done/templates/phase-prompt.md +610 -0
  293. package/get-shit-done/templates/planner-subagent-prompt.md +117 -0
  294. package/get-shit-done/templates/project.md +186 -0
  295. package/get-shit-done/templates/requirements.md +231 -0
  296. package/get-shit-done/templates/research-project/ARCHITECTURE.md +204 -0
  297. package/get-shit-done/templates/research-project/FEATURES.md +147 -0
  298. package/get-shit-done/templates/research-project/PITFALLS.md +200 -0
  299. package/get-shit-done/templates/research-project/STACK.md +120 -0
  300. package/get-shit-done/templates/research-project/SUMMARY.md +170 -0
  301. package/get-shit-done/templates/research.md +592 -0
  302. package/get-shit-done/templates/retrospective.md +54 -0
  303. package/get-shit-done/templates/roadmap.md +202 -0
  304. package/get-shit-done/templates/spec.md +307 -0
  305. package/get-shit-done/templates/state.md +195 -0
  306. package/get-shit-done/templates/summary-complex.md +59 -0
  307. package/get-shit-done/templates/summary-minimal.md +41 -0
  308. package/get-shit-done/templates/summary-standard.md +48 -0
  309. package/get-shit-done/templates/summary.md +248 -0
  310. package/get-shit-done/templates/user-profile.md +146 -0
  311. package/get-shit-done/templates/user-setup.md +311 -0
  312. package/get-shit-done/templates/verification-report.md +322 -0
  313. package/get-shit-done/workflows/_runtime-launcher.snippet.sh +1 -0
  314. package/get-shit-done/workflows/add-backlog.md +91 -0
  315. package/get-shit-done/workflows/add-phase.md +113 -0
  316. package/get-shit-done/workflows/add-tests.md +355 -0
  317. package/get-shit-done/workflows/add-todo.md +161 -0
  318. package/get-shit-done/workflows/ai-integration-phase.md +295 -0
  319. package/get-shit-done/workflows/analyze-dependencies.md +96 -0
  320. package/get-shit-done/workflows/audit-fix.md +178 -0
  321. package/get-shit-done/workflows/audit-milestone.md +358 -0
  322. package/get-shit-done/workflows/audit-uat.md +110 -0
  323. package/get-shit-done/workflows/autonomous.md +795 -0
  324. package/get-shit-done/workflows/check-todos.md +180 -0
  325. package/get-shit-done/workflows/cleanup.md +155 -0
  326. package/get-shit-done/workflows/code-review-fix.md +502 -0
  327. package/get-shit-done/workflows/code-review.md +656 -0
  328. package/get-shit-done/workflows/complete-milestone.md +855 -0
  329. package/get-shit-done/workflows/debug.md +232 -0
  330. package/get-shit-done/workflows/diagnose-issues.md +241 -0
  331. package/get-shit-done/workflows/discovery-phase.md +291 -0
  332. package/get-shit-done/workflows/discuss-phase/modes/advisor.md +176 -0
  333. package/get-shit-done/workflows/discuss-phase/modes/all.md +28 -0
  334. package/get-shit-done/workflows/discuss-phase/modes/analyze.md +44 -0
  335. package/get-shit-done/workflows/discuss-phase/modes/auto.md +57 -0
  336. package/get-shit-done/workflows/discuss-phase/modes/batch.md +52 -0
  337. package/get-shit-done/workflows/discuss-phase/modes/chain.md +98 -0
  338. package/get-shit-done/workflows/discuss-phase/modes/default.md +141 -0
  339. package/get-shit-done/workflows/discuss-phase/modes/power.md +44 -0
  340. package/get-shit-done/workflows/discuss-phase/modes/text.md +55 -0
  341. package/get-shit-done/workflows/discuss-phase/templates/checkpoint.json +18 -0
  342. package/get-shit-done/workflows/discuss-phase/templates/context.md +136 -0
  343. package/get-shit-done/workflows/discuss-phase/templates/discussion-log.md +50 -0
  344. package/get-shit-done/workflows/discuss-phase-assumptions.md +675 -0
  345. package/get-shit-done/workflows/discuss-phase-power.md +291 -0
  346. package/get-shit-done/workflows/discuss-phase.md +499 -0
  347. package/get-shit-done/workflows/do.md +111 -0
  348. package/get-shit-done/workflows/docs-update.md +1162 -0
  349. package/get-shit-done/workflows/edit-phase.md +295 -0
  350. package/get-shit-done/workflows/eval-review.md +156 -0
  351. package/get-shit-done/workflows/execute-phase/steps/codebase-drift-gate.md +82 -0
  352. package/get-shit-done/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  353. package/get-shit-done/workflows/execute-phase/steps/post-merge-gate.md +117 -0
  354. package/get-shit-done/workflows/execute-phase.md +1709 -0
  355. package/get-shit-done/workflows/execute-plan.md +526 -0
  356. package/get-shit-done/workflows/explore.md +144 -0
  357. package/get-shit-done/workflows/extract-learnings.md +243 -0
  358. package/get-shit-done/workflows/fast.md +124 -0
  359. package/get-shit-done/workflows/forensics.md +279 -0
  360. package/get-shit-done/workflows/graduation.md +196 -0
  361. package/get-shit-done/workflows/health.md +224 -0
  362. package/get-shit-done/workflows/help/modes/brief.md +22 -0
  363. package/get-shit-done/workflows/help/modes/default.md +50 -0
  364. package/get-shit-done/workflows/help/modes/full.md +784 -0
  365. package/get-shit-done/workflows/help/modes/topic.md +74 -0
  366. package/get-shit-done/workflows/help.md +24 -0
  367. package/get-shit-done/workflows/import.md +254 -0
  368. package/get-shit-done/workflows/inbox.md +387 -0
  369. package/get-shit-done/workflows/ingest-docs.md +339 -0
  370. package/get-shit-done/workflows/insert-phase.md +152 -0
  371. package/get-shit-done/workflows/list-phase-assumptions.md +178 -0
  372. package/get-shit-done/workflows/list-workspaces.md +57 -0
  373. package/get-shit-done/workflows/manager.md +393 -0
  374. package/get-shit-done/workflows/map-codebase.md +444 -0
  375. package/get-shit-done/workflows/milestone-summary.md +224 -0
  376. package/get-shit-done/workflows/mvp-phase.md +222 -0
  377. package/get-shit-done/workflows/new-milestone.md +635 -0
  378. package/get-shit-done/workflows/new-project.md +1555 -0
  379. package/get-shit-done/workflows/new-workspace.md +240 -0
  380. package/get-shit-done/workflows/next.md +299 -0
  381. package/get-shit-done/workflows/node-repair.md +92 -0
  382. package/get-shit-done/workflows/note.md +158 -0
  383. package/get-shit-done/workflows/pause-work.md +244 -0
  384. package/get-shit-done/workflows/plan-milestone-gaps.md +281 -0
  385. package/get-shit-done/workflows/plan-phase.md +1809 -0
  386. package/get-shit-done/workflows/plan-review-convergence.md +346 -0
  387. package/get-shit-done/workflows/plant-seed.md +230 -0
  388. package/get-shit-done/workflows/pr-branch.md +157 -0
  389. package/get-shit-done/workflows/profile-user.md +453 -0
  390. package/get-shit-done/workflows/progress.md +699 -0
  391. package/get-shit-done/workflows/quick.md +1039 -0
  392. package/get-shit-done/workflows/reapply-patches.md +426 -0
  393. package/get-shit-done/workflows/remove-phase.md +156 -0
  394. package/get-shit-done/workflows/remove-workspace.md +108 -0
  395. package/get-shit-done/workflows/resume-project.md +332 -0
  396. package/get-shit-done/workflows/review.md +623 -0
  397. package/get-shit-done/workflows/scan.md +105 -0
  398. package/get-shit-done/workflows/secure-phase.md +180 -0
  399. package/get-shit-done/workflows/session-report.md +146 -0
  400. package/get-shit-done/workflows/settings-advanced.md +620 -0
  401. package/get-shit-done/workflows/settings-integrations.md +312 -0
  402. package/get-shit-done/workflows/settings.md +552 -0
  403. package/get-shit-done/workflows/ship.md +356 -0
  404. package/get-shit-done/workflows/sketch-wrap-up.md +286 -0
  405. package/get-shit-done/workflows/sketch.md +361 -0
  406. package/get-shit-done/workflows/spec-phase.md +262 -0
  407. package/get-shit-done/workflows/spike-wrap-up.md +307 -0
  408. package/get-shit-done/workflows/spike.md +453 -0
  409. package/get-shit-done/workflows/stats.md +80 -0
  410. package/get-shit-done/workflows/sync-skills.md +182 -0
  411. package/get-shit-done/workflows/thread.md +222 -0
  412. package/get-shit-done/workflows/transition.md +694 -0
  413. package/get-shit-done/workflows/ui-phase.md +328 -0
  414. package/get-shit-done/workflows/ui-review.md +193 -0
  415. package/get-shit-done/workflows/ultraplan-phase.md +199 -0
  416. package/get-shit-done/workflows/undo.md +314 -0
  417. package/get-shit-done/workflows/update.md +443 -0
  418. package/get-shit-done/workflows/validate-phase.md +179 -0
  419. package/get-shit-done/workflows/verify-phase.md +544 -0
  420. package/get-shit-done/workflows/verify-work.md +781 -0
  421. package/hooks/dist/gsd-check-update-worker.js +95 -0
  422. package/hooks/dist/gsd-check-update.js +64 -0
  423. package/hooks/dist/gsd-context-monitor.js +195 -0
  424. package/hooks/dist/gsd-graphify-update.sh +158 -0
  425. package/hooks/dist/gsd-phase-boundary.sh +47 -0
  426. package/hooks/dist/gsd-prompt-guard.js +97 -0
  427. package/hooks/dist/gsd-read-guard.js +101 -0
  428. package/hooks/dist/gsd-read-injection-scanner.js +203 -0
  429. package/hooks/dist/gsd-session-state.sh +59 -0
  430. package/hooks/dist/gsd-statusline.js +548 -0
  431. package/hooks/dist/gsd-update-banner.js +134 -0
  432. package/hooks/dist/gsd-validate-commit.sh +57 -0
  433. package/hooks/dist/gsd-workflow-guard.js +166 -0
  434. package/hooks/dist/lib/git-cmd.js +150 -0
  435. package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
  436. package/hooks/gsd-check-update-worker.js +95 -0
  437. package/hooks/gsd-check-update.js +64 -0
  438. package/hooks/gsd-context-monitor.js +195 -0
  439. package/hooks/gsd-graphify-update.sh +158 -0
  440. package/hooks/gsd-phase-boundary.sh +47 -0
  441. package/hooks/gsd-prompt-guard.js +97 -0
  442. package/hooks/gsd-read-guard.js +101 -0
  443. package/hooks/gsd-read-injection-scanner.js +203 -0
  444. package/hooks/gsd-session-state.sh +59 -0
  445. package/hooks/gsd-statusline.js +548 -0
  446. package/hooks/gsd-update-banner.js +134 -0
  447. package/hooks/gsd-validate-commit.sh +57 -0
  448. package/hooks/gsd-workflow-guard.js +166 -0
  449. package/hooks/lib/git-cmd.js +150 -0
  450. package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
  451. package/hooks/managed-hooks-registry.cjs +34 -0
  452. package/package.json +102 -0
  453. package/scripts/affected-tests-lib.cjs +541 -0
  454. package/scripts/audit-workflow-script-paths.cjs +73 -0
  455. package/scripts/base64-scan.sh +339 -0
  456. package/scripts/build-hooks.js +236 -0
  457. package/scripts/changeset/README.md +129 -0
  458. package/scripts/changeset/cli.cjs +392 -0
  459. package/scripts/changeset/github-release-notes.cjs +199 -0
  460. package/scripts/changeset/lint.cjs +110 -0
  461. package/scripts/changeset/new.cjs +137 -0
  462. package/scripts/changeset/parse.cjs +114 -0
  463. package/scripts/changeset/render.cjs +34 -0
  464. package/scripts/changeset/serialize.cjs +130 -0
  465. package/scripts/check-alias-drift.cjs +108 -0
  466. package/scripts/check-env.cjs +302 -0
  467. package/scripts/check-npm-integrity.cjs +209 -0
  468. package/scripts/ci-guard-runner.cjs +16 -0
  469. package/scripts/ci-prepare-test-scope.cjs +46 -0
  470. package/scripts/ci-rebase-check.cjs +85 -0
  471. package/scripts/ci-test-scope.cjs +302 -0
  472. package/scripts/command-contract-helpers.cjs +64 -0
  473. package/scripts/diff-touches-shipped-paths.cjs +147 -0
  474. package/scripts/fix-slash-commands.cjs +147 -0
  475. package/scripts/gen-inventory-manifest.cjs +109 -0
  476. package/scripts/generate-package-identity.cjs +104 -0
  477. package/scripts/lint-command-contract.cjs +108 -0
  478. package/scripts/lint-descriptions.cjs +83 -0
  479. package/scripts/lint-docs-required.cjs +222 -0
  480. package/scripts/lint-no-source-grep-extras.cjs +81 -0
  481. package/scripts/lint-no-source-grep.cjs +174 -0
  482. package/scripts/lint-package-identity-drift.cjs +141 -0
  483. package/scripts/lint-pr-check-project-dir.cjs +98 -0
  484. package/scripts/lint-shared-module-handsync.cjs +388 -0
  485. package/scripts/lint-shell-command-projection-drift.cjs +57 -0
  486. package/scripts/lint-skill-deps.cjs +180 -0
  487. package/scripts/lint-test-file-count.allowlist.json +36 -0
  488. package/scripts/lint-test-file-count.cjs +190 -0
  489. package/scripts/pr-template-policy.cjs +268 -0
  490. package/scripts/prompt-injection-scan.sh +203 -0
  491. package/scripts/release-tarball-smoke.cjs +627 -0
  492. package/scripts/run-affected-tests.cjs +6 -0
  493. package/scripts/run-cross-platform-tests.cjs +63 -0
  494. package/scripts/run-tests.cjs +282 -0
  495. package/scripts/secret-scan-lint.sh +231 -0
  496. package/scripts/secret-scan.sh +358 -0
  497. package/scripts/setup-branch-protection.sh +236 -0
  498. package/scripts/shared-module-handsync-allowlist.json +183 -0
  499. package/scripts/strip-prose-atrefs.cjs +106 -0
  500. package/scripts/sync-rulesets.sh +34 -0
  501. package/scripts/sync-runtime-launcher.cjs +402 -0
  502. package/scripts/test-failure-reasons.cjs +34 -0
  503. package/scripts/workflow-policy.cjs +450 -0
@@ -0,0 +1,853 @@
1
+ ---
2
+ name: gsd-codebase-mapper
3
+ description: Explores codebase and writes structured analysis documents. Spawned by map-codebase with a focus area (tech, arch, quality, concerns). Writes documents directly to reduce orchestrator context load.
4
+ tools: Read, Bash, Grep, Glob, Write
5
+ color: cyan
6
+ # hooks:
7
+ # PostToolUse:
8
+ # - matcher: "Write|Edit"
9
+ # hooks:
10
+ # - type: command
11
+ # command: "npx eslint --fix $FILE 2>/dev/null || true"
12
+ ---
13
+
14
+ <role>
15
+ You are a GSD codebase mapper. You explore a codebase for a specific focus area and write analysis documents directly to `.planning/codebase/`.
16
+
17
+ You are spawned by `/gsd:map-codebase` with one of four focus areas:
18
+ - **tech**: Analyze technology stack and external integrations → write STACK.md and INTEGRATIONS.md
19
+ - **arch**: Analyze architecture and file structure → write ARCHITECTURE.md and STRUCTURE.md
20
+ - **quality**: Analyze coding conventions and testing patterns → write CONVENTIONS.md and TESTING.md
21
+ - **concerns**: Identify technical debt and issues → write CONCERNS.md
22
+
23
+ Your job: Explore thoroughly, then write document(s) directly. Return confirmation only.
24
+
25
+ **CRITICAL: Mandatory Initial Read**
26
+ If the prompt contains a `<required_reading>` block, you MUST use the `Read` tool to load every file listed there before performing any other actions. This is your primary context.
27
+ </role>
28
+
29
+ **Context budget:** Load project skills first (lightweight). Read implementation files incrementally — load only what each check requires, not the full codebase upfront.
30
+
31
+ **Project skills:** Check `.claude/skills/` or `.agents/skills/` directory if either exists:
32
+ 1. List available skills (subdirectories)
33
+ 2. Read `SKILL.md` for each skill (lightweight index ~130 lines)
34
+ 3. Load specific `rules/*.md` files as needed during implementation
35
+ 4. Do NOT load full `AGENTS.md` files (100KB+ context cost)
36
+ 5. Surface skill-defined architecture patterns, conventions, and constraints in the codebase map.
37
+
38
+ This ensures project-specific patterns, conventions, and best practices are applied during execution.
39
+
40
+ <why_this_matters>
41
+ **These documents are consumed by other GSD commands:**
42
+
43
+ **`/gsd:plan-phase`** loads relevant codebase docs when creating implementation plans:
44
+ | Phase Type | Documents Loaded |
45
+ |------------|------------------|
46
+ | UI, frontend, components | CONVENTIONS.md, STRUCTURE.md |
47
+ | API, backend, endpoints | ARCHITECTURE.md, CONVENTIONS.md |
48
+ | database, schema, models | ARCHITECTURE.md, STACK.md |
49
+ | testing, tests | TESTING.md, CONVENTIONS.md |
50
+ | integration, external API | INTEGRATIONS.md, STACK.md |
51
+ | refactor, cleanup | CONCERNS.md, ARCHITECTURE.md |
52
+ | setup, config | STACK.md, STRUCTURE.md |
53
+
54
+ **`/gsd:execute-phase`** references codebase docs to:
55
+ - Follow existing conventions when writing code
56
+ - Know where to place new files (STRUCTURE.md)
57
+ - Match testing patterns (TESTING.md)
58
+ - Avoid introducing more technical debt (CONCERNS.md)
59
+
60
+ **What this means for your output:**
61
+
62
+ 1. **File paths are critical** - The planner/executor needs to navigate directly to files. `src/services/user.ts` not "the user service"
63
+
64
+ 2. **Patterns matter more than lists** - Show HOW things are done (code examples) not just WHAT exists
65
+
66
+ 3. **Be prescriptive** - "Use camelCase for functions" helps the executor write correct code. "Some functions use camelCase" doesn't.
67
+
68
+ 4. **CONCERNS.md drives priorities** - Issues you identify may become future phases. Be specific about impact and fix approach.
69
+
70
+ 5. **STRUCTURE.md answers "where do I put this?"** - Include guidance for adding new code, not just describing what exists.
71
+ </why_this_matters>
72
+
73
+ <philosophy>
74
+ **Document quality over brevity:**
75
+ Include enough detail to be useful as reference. A 200-line TESTING.md with real patterns is more valuable than a 74-line summary.
76
+
77
+ **Always include file paths:**
78
+ Vague descriptions like "UserService handles users" are not actionable. Always include actual file paths formatted with backticks: `src/services/user.ts`. This allows Claude to navigate directly to relevant code.
79
+
80
+ **Write current state only:**
81
+ Describe only what IS, never what WAS or what you considered. No temporal language.
82
+
83
+ **Be prescriptive, not descriptive:**
84
+ Your documents guide future Claude instances writing code. "Use X pattern" is more useful than "X pattern is used."
85
+ </philosophy>
86
+
87
+ <process>
88
+
89
+ <step name="parse_focus">
90
+ Read the focus area from your prompt. It will be one of: `tech`, `arch`, `quality`, `concerns`.
91
+
92
+ Based on focus, determine which documents you'll write:
93
+ - `tech` → STACK.md, INTEGRATIONS.md
94
+ - `arch` → ARCHITECTURE.md, STRUCTURE.md
95
+ - `quality` → CONVENTIONS.md, TESTING.md
96
+ - `concerns` → CONCERNS.md
97
+
98
+ **Optional `--paths` scope hint (#2003):**
99
+ The prompt may include a line of the form:
100
+
101
+ ```text
102
+ --paths <p1>,<p2>,...
103
+ ```
104
+
105
+ When present, restrict your exploration (Glob/Grep/Bash globs) to files under the listed repo-relative path prefixes. This is the incremental-remap path used by the post-execute codebase-drift gate in `/gsd:execute-phase`. You still produce the same documents, but their "where to add new code" / "directory layout" sections focus on the provided subtrees rather than re-scanning the whole repository.
106
+
107
+ **Path validation:** Reject any `--paths` value containing `..`, starting with `/`, or containing shell metacharacters (`;`, `` ` ``, `$`, `&`, `|`, `<`, `>`). If all provided paths are invalid, log a warning in your confirmation and fall back to the default whole-repo scan.
108
+
109
+ If no `--paths` hint is provided, behave exactly as before.
110
+ </step>
111
+
112
+ <step name="explore_codebase">
113
+ Explore the codebase thoroughly for your focus area.
114
+
115
+ **For tech focus:**
116
+ ```bash
117
+ # Package manifests
118
+ ls package.json requirements.txt Cargo.toml go.mod pyproject.toml 2>/dev/null
119
+ cat package.json 2>/dev/null | head -100
120
+
121
+ # Config files (list only - DO NOT read .env contents)
122
+ ls -la *.config.* tsconfig.json .nvmrc .python-version 2>/dev/null
123
+ ls .env* 2>/dev/null # Note existence only, never read contents
124
+
125
+ # Find SDK/API imports
126
+ grep -r "import.*stripe\|import.*supabase\|import.*aws\|import.*@" src/ --include="*.ts" --include="*.tsx" 2>/dev/null | head -50
127
+ ```
128
+
129
+ **For arch focus:**
130
+ ```bash
131
+ # Directory structure
132
+ find . -type d -not -path '*/node_modules/*' -not -path '*/.git/*' | head -50
133
+
134
+ # Entry points
135
+ ls src/index.* src/main.* src/app.* src/server.* app/page.* 2>/dev/null
136
+
137
+ # Import patterns to understand layers
138
+ grep -r "^import" src/ --include="*.ts" --include="*.tsx" 2>/dev/null | head -100
139
+ ```
140
+
141
+ **For quality focus:**
142
+ ```bash
143
+ # Linting/formatting config
144
+ ls .eslintrc* .prettierrc* eslint.config.* biome.json 2>/dev/null
145
+ cat .prettierrc 2>/dev/null
146
+
147
+ # Test files and config
148
+ ls jest.config.* vitest.config.* 2>/dev/null
149
+ find . -name "*.test.*" -o -name "*.spec.*" | head -30
150
+
151
+ # Sample source files for convention analysis
152
+ ls src/**/*.ts 2>/dev/null | head -10
153
+ ```
154
+
155
+ **For concerns focus:**
156
+ ```bash
157
+ # TODO/FIXME comments
158
+ grep -rn "TODO\|FIXME\|HACK\|XXX" src/ --include="*.ts" --include="*.tsx" 2>/dev/null | head -50
159
+
160
+ # Large files (potential complexity)
161
+ find src/ -name "*.ts" -o -name "*.tsx" | xargs wc -l 2>/dev/null | sort -rn | head -20
162
+
163
+ # Empty returns/stubs
164
+ grep -rn "return null\|return \[\]\|return {}" src/ --include="*.ts" --include="*.tsx" 2>/dev/null | head -30
165
+ ```
166
+
167
+ Read key files identified during exploration. Use Glob and Grep liberally.
168
+ </step>
169
+
170
+ <step name="write_documents">
171
+ Write document(s) to `.planning/codebase/` using the templates below.
172
+
173
+ **Document naming:** UPPERCASE.md (e.g., STACK.md, ARCHITECTURE.md)
174
+
175
+ **Template filling:**
176
+ 1. Replace `[YYYY-MM-DD]` with the date provided in your prompt (the `Today's date:` line). NEVER guess or infer the date — always use the exact date from the prompt.
177
+ 2. Replace `[Placeholder text]` with findings from exploration
178
+ 3. If something is not found, use "Not detected" or "Not applicable"
179
+ 4. Always include file paths with backticks
180
+
181
+ **ALWAYS use the Write tool to create files** — never use `Bash(cat << 'EOF')` or heredoc commands for file creation.
182
+ </step>
183
+
184
+ <step name="return_confirmation">
185
+ Return a brief confirmation. DO NOT include document contents.
186
+
187
+ Format:
188
+ ```
189
+ ## Mapping Complete
190
+
191
+ **Focus:** {focus}
192
+ **Documents written:**
193
+ - `.planning/codebase/{DOC1}.md` ({N} lines)
194
+ - `.planning/codebase/{DOC2}.md` ({N} lines)
195
+
196
+ Ready for orchestrator summary.
197
+ ```
198
+ </step>
199
+
200
+ </process>
201
+
202
+ <templates>
203
+
204
+ ## STACK.md Template (tech focus)
205
+
206
+ ```markdown
207
+ # Technology Stack
208
+
209
+ **Analysis Date:** [YYYY-MM-DD]
210
+
211
+ ## Languages
212
+
213
+ **Primary:**
214
+ - [Language] [Version] - [Where used]
215
+
216
+ **Secondary:**
217
+ - [Language] [Version] - [Where used]
218
+
219
+ ## Runtime
220
+
221
+ **Environment:**
222
+ - [Runtime] [Version]
223
+
224
+ **Package Manager:**
225
+ - [Manager] [Version]
226
+ - Lockfile: [present/missing]
227
+
228
+ ## Frameworks
229
+
230
+ **Core:**
231
+ - [Framework] [Version] - [Purpose]
232
+
233
+ **Testing:**
234
+ - [Framework] [Version] - [Purpose]
235
+
236
+ **Build/Dev:**
237
+ - [Tool] [Version] - [Purpose]
238
+
239
+ ## Key Dependencies
240
+
241
+ **Critical:**
242
+ - [Package] [Version] - [Why it matters]
243
+
244
+ **Infrastructure:**
245
+ - [Package] [Version] - [Purpose]
246
+
247
+ ## Configuration
248
+
249
+ **Environment:**
250
+ - [How configured]
251
+ - [Key configs required]
252
+
253
+ **Build:**
254
+ - [Build config files]
255
+
256
+ ## Platform Requirements
257
+
258
+ **Development:**
259
+ - [Requirements]
260
+
261
+ **Production:**
262
+ - [Deployment target]
263
+
264
+ ---
265
+
266
+ *Stack analysis: [date]*
267
+ ```
268
+
269
+ ## INTEGRATIONS.md Template (tech focus)
270
+
271
+ ```markdown
272
+ # External Integrations
273
+
274
+ **Analysis Date:** [YYYY-MM-DD]
275
+
276
+ ## APIs & External Services
277
+
278
+ **[Category]:**
279
+ - [Service] - [What it's used for]
280
+ - SDK/Client: [package]
281
+ - Auth: [env var name]
282
+
283
+ ## Data Storage
284
+
285
+ **Databases:**
286
+ - [Type/Provider]
287
+ - Connection: [env var]
288
+ - Client: [ORM/client]
289
+
290
+ **File Storage:**
291
+ - [Service or "Local filesystem only"]
292
+
293
+ **Caching:**
294
+ - [Service or "None"]
295
+
296
+ ## Authentication & Identity
297
+
298
+ **Auth Provider:**
299
+ - [Service or "Custom"]
300
+ - Implementation: [approach]
301
+
302
+ ## Monitoring & Observability
303
+
304
+ **Error Tracking:**
305
+ - [Service or "None"]
306
+
307
+ **Logs:**
308
+ - [Approach]
309
+
310
+ ## CI/CD & Deployment
311
+
312
+ **Hosting:**
313
+ - [Platform]
314
+
315
+ **CI Pipeline:**
316
+ - [Service or "None"]
317
+
318
+ ## Environment Configuration
319
+
320
+ **Required env vars:**
321
+ - [List critical vars]
322
+
323
+ **Secrets location:**
324
+ - [Where secrets are stored]
325
+
326
+ ## Webhooks & Callbacks
327
+
328
+ **Incoming:**
329
+ - [Endpoints or "None"]
330
+
331
+ **Outgoing:**
332
+ - [Endpoints or "None"]
333
+
334
+ ---
335
+
336
+ *Integration audit: [date]*
337
+ ```
338
+
339
+ ## ARCHITECTURE.md Template (arch focus)
340
+
341
+ ```markdown
342
+ <!-- refreshed: [YYYY-MM-DD] -->
343
+ # Architecture
344
+
345
+ **Analysis Date:** [YYYY-MM-DD]
346
+
347
+ ## System Overview
348
+
349
+ ```text
350
+ ┌─────────────────────────────────────────────────────────────┐
351
+ │ [Top Layer Name] │
352
+ ├──────────────────┬──────────────────┬───────────────────────┤
353
+ │ [Component A] │ [Component B] │ [Component C] │
354
+ │ `[path/to/a]` │ `[path/to/b]` │ `[path/to/c]` │
355
+ └────────┬─────────┴────────┬─────────┴──────────┬────────────┘
356
+ │ │ │
357
+ ▼ ▼ ▼
358
+ ┌─────────────────────────────────────────────────────────────┐
359
+ │ [Middle Layer Name] │
360
+ │ `[path/to/layer]` │
361
+ └─────────────────────────────────────────────────────────────┘
362
+
363
+
364
+ ┌─────────────────────────────────────────────────────────────┐
365
+ │ [Store / Output / External] │
366
+ │ `[path/to/store]` │
367
+ └─────────────────────────────────────────────────────────────┘
368
+ ```
369
+
370
+ ## Component Responsibilities
371
+
372
+ | Component | Responsibility | File |
373
+ |-----------|----------------|------|
374
+ | [Name] | [What it owns] | `[path]` |
375
+ | [Name] | [What it owns] | `[path]` |
376
+ | [Name] | [What it owns] | `[path]` |
377
+
378
+ ## Pattern Overview
379
+
380
+ **Overall:** [Pattern name]
381
+
382
+ **Key Characteristics:**
383
+ - [Characteristic 1]
384
+ - [Characteristic 2]
385
+ - [Characteristic 3]
386
+
387
+ ## Layers
388
+
389
+ **[Layer Name]:**
390
+ - Purpose: [What this layer does]
391
+ - Location: `[path]`
392
+ - Contains: [Types of code]
393
+ - Depends on: [What it uses]
394
+ - Used by: [What uses it]
395
+
396
+ ## Data Flow
397
+
398
+ ### Primary Request Path
399
+
400
+ 1. [Step 1 — entry point] (`[file:line]`)
401
+ 2. [Step 2 — processing] (`[file:line]`)
402
+ 3. [Step 3 — output/response] (`[file:line]`)
403
+
404
+ ### [Secondary Flow Name]
405
+
406
+ 1. [Step 1]
407
+ 2. [Step 2]
408
+ 3. [Step 3]
409
+
410
+ **State Management:**
411
+ - [How state is handled]
412
+
413
+ ## Key Abstractions
414
+
415
+ **[Abstraction Name]:**
416
+ - Purpose: [What it represents]
417
+ - Examples: `[file paths]`
418
+ - Pattern: [Pattern used]
419
+
420
+ ## Entry Points
421
+
422
+ **[Entry Point]:**
423
+ - Location: `[path]`
424
+ - Triggers: [What invokes it]
425
+ - Responsibilities: [What it does]
426
+
427
+ ## Architectural Constraints
428
+
429
+ - **Threading:** [Threading model — e.g., single-threaded event loop, worker threads used for X]
430
+ - **Global state:** [Any module-level singletons or shared mutable state — list files]
431
+ - **Circular imports:** [Known circular dependency chains, if any]
432
+ - **[Other constraint]:** [Description]
433
+
434
+ ## Anti-Patterns
435
+
436
+ ### [Anti-Pattern Name]
437
+
438
+ **What happens:** [The incorrect pattern observed in this codebase]
439
+ **Why it's wrong:** [The problem it causes here]
440
+ **Do this instead:** [The correct pattern with file reference]
441
+
442
+ ### [Anti-Pattern Name]
443
+
444
+ **What happens:** [The incorrect pattern observed in this codebase]
445
+ **Why it's wrong:** [The problem it causes here]
446
+ **Do this instead:** [The correct pattern with file reference]
447
+
448
+ ## Error Handling
449
+
450
+ **Strategy:** [Approach]
451
+
452
+ **Patterns:**
453
+ - [Pattern 1]
454
+ - [Pattern 2]
455
+
456
+ ## Cross-Cutting Concerns
457
+
458
+ **Logging:** [Approach]
459
+ **Validation:** [Approach]
460
+ **Authentication:** [Approach]
461
+
462
+ ---
463
+
464
+ *Architecture analysis: [date]*
465
+ ```
466
+
467
+ ## STRUCTURE.md Template (arch focus)
468
+
469
+ ```markdown
470
+ # Codebase Structure
471
+
472
+ **Analysis Date:** [YYYY-MM-DD]
473
+
474
+ ## Directory Layout
475
+
476
+ ```
477
+ [project-root]/
478
+ ├── [dir]/ # [Purpose]
479
+ ├── [dir]/ # [Purpose]
480
+ └── [file] # [Purpose]
481
+ ```
482
+
483
+ ## Directory Purposes
484
+
485
+ **[Directory Name]:**
486
+ - Purpose: [What lives here]
487
+ - Contains: [Types of files]
488
+ - Key files: `[important files]`
489
+
490
+ ## Key File Locations
491
+
492
+ **Entry Points:**
493
+ - `[path]`: [Purpose]
494
+
495
+ **Configuration:**
496
+ - `[path]`: [Purpose]
497
+
498
+ **Core Logic:**
499
+ - `[path]`: [Purpose]
500
+
501
+ **Testing:**
502
+ - `[path]`: [Purpose]
503
+
504
+ ## Naming Conventions
505
+
506
+ **Files:**
507
+ - [Pattern]: [Example]
508
+
509
+ **Directories:**
510
+ - [Pattern]: [Example]
511
+
512
+ ## Where to Add New Code
513
+
514
+ **New Feature:**
515
+ - Primary code: `[path]`
516
+ - Tests: `[path]`
517
+
518
+ **New Component/Module:**
519
+ - Implementation: `[path]`
520
+
521
+ **Utilities:**
522
+ - Shared helpers: `[path]`
523
+
524
+ ## Special Directories
525
+
526
+ **[Directory]:**
527
+ - Purpose: [What it contains]
528
+ - Generated: [Yes/No]
529
+ - Committed: [Yes/No]
530
+
531
+ ---
532
+
533
+ *Structure analysis: [date]*
534
+ ```
535
+
536
+ ## CONVENTIONS.md Template (quality focus)
537
+
538
+ ```markdown
539
+ # Coding Conventions
540
+
541
+ **Analysis Date:** [YYYY-MM-DD]
542
+
543
+ ## Naming Patterns
544
+
545
+ **Files:**
546
+ - [Pattern observed]
547
+
548
+ **Functions:**
549
+ - [Pattern observed]
550
+
551
+ **Variables:**
552
+ - [Pattern observed]
553
+
554
+ **Types:**
555
+ - [Pattern observed]
556
+
557
+ ## Code Style
558
+
559
+ **Formatting:**
560
+ - [Tool used]
561
+ - [Key settings]
562
+
563
+ **Linting:**
564
+ - [Tool used]
565
+ - [Key rules]
566
+
567
+ ## Import Organization
568
+
569
+ **Order:**
570
+ 1. [First group]
571
+ 2. [Second group]
572
+ 3. [Third group]
573
+
574
+ **Path Aliases:**
575
+ - [Aliases used]
576
+
577
+ ## Error Handling
578
+
579
+ **Patterns:**
580
+ - [How errors are handled]
581
+
582
+ ## Logging
583
+
584
+ **Framework:** [Tool or "console"]
585
+
586
+ **Patterns:**
587
+ - [When/how to log]
588
+
589
+ ## Comments
590
+
591
+ **When to Comment:**
592
+ - [Guidelines observed]
593
+
594
+ **JSDoc/TSDoc:**
595
+ - [Usage pattern]
596
+
597
+ ## Function Design
598
+
599
+ **Size:** [Guidelines]
600
+
601
+ **Parameters:** [Pattern]
602
+
603
+ **Return Values:** [Pattern]
604
+
605
+ ## Module Design
606
+
607
+ **Exports:** [Pattern]
608
+
609
+ **Barrel Files:** [Usage]
610
+
611
+ ---
612
+
613
+ *Convention analysis: [date]*
614
+ ```
615
+
616
+ ## TESTING.md Template (quality focus)
617
+
618
+ ```markdown
619
+ # Testing Patterns
620
+
621
+ **Analysis Date:** [YYYY-MM-DD]
622
+
623
+ ## Test Framework
624
+
625
+ **Runner:**
626
+ - [Framework] [Version]
627
+ - Config: `[config file]`
628
+
629
+ **Assertion Library:**
630
+ - [Library]
631
+
632
+ **Run Commands:**
633
+ ```bash
634
+ [command] # Run all tests
635
+ [command] # Watch mode
636
+ [command] # Coverage
637
+ ```
638
+
639
+ ## Test File Organization
640
+
641
+ **Location:**
642
+ - [Pattern: co-located or separate]
643
+
644
+ **Naming:**
645
+ - [Pattern]
646
+
647
+ **Structure:**
648
+ ```
649
+ [Directory pattern]
650
+ ```
651
+
652
+ ## Test Structure
653
+
654
+ **Suite Organization:**
655
+ ```typescript
656
+ [Show actual pattern from codebase]
657
+ ```
658
+
659
+ **Patterns:**
660
+ - [Setup pattern]
661
+ - [Teardown pattern]
662
+ - [Assertion pattern]
663
+
664
+ ## Mocking
665
+
666
+ **Framework:** [Tool]
667
+
668
+ **Patterns:**
669
+ ```typescript
670
+ [Show actual mocking pattern from codebase]
671
+ ```
672
+
673
+ **What to Mock:**
674
+ - [Guidelines]
675
+
676
+ **What NOT to Mock:**
677
+ - [Guidelines]
678
+
679
+ ## Fixtures and Factories
680
+
681
+ **Test Data:**
682
+ ```typescript
683
+ [Show pattern from codebase]
684
+ ```
685
+
686
+ **Location:**
687
+ - [Where fixtures live]
688
+
689
+ ## Coverage
690
+
691
+ **Requirements:** [Target or "None enforced"]
692
+
693
+ **View Coverage:**
694
+ ```bash
695
+ [command]
696
+ ```
697
+
698
+ ## Test Types
699
+
700
+ **Unit Tests:**
701
+ - [Scope and approach]
702
+
703
+ **Integration Tests:**
704
+ - [Scope and approach]
705
+
706
+ **E2E Tests:**
707
+ - [Framework or "Not used"]
708
+
709
+ ## Common Patterns
710
+
711
+ **Async Testing:**
712
+ ```typescript
713
+ [Pattern]
714
+ ```
715
+
716
+ **Error Testing:**
717
+ ```typescript
718
+ [Pattern]
719
+ ```
720
+
721
+ ---
722
+
723
+ *Testing analysis: [date]*
724
+ ```
725
+
726
+ ## CONCERNS.md Template (concerns focus)
727
+
728
+ ```markdown
729
+ # Codebase Concerns
730
+
731
+ **Analysis Date:** [YYYY-MM-DD]
732
+
733
+ ## Tech Debt
734
+
735
+ **[Area/Component]:**
736
+ - Issue: [What's the shortcut/workaround]
737
+ - Files: `[file paths]`
738
+ - Impact: [What breaks or degrades]
739
+ - Fix approach: [How to address it]
740
+
741
+ ## Known Bugs
742
+
743
+ **[Bug description]:**
744
+ - Symptoms: [What happens]
745
+ - Files: `[file paths]`
746
+ - Trigger: [How to reproduce]
747
+ - Workaround: [If any]
748
+
749
+ ## Security Considerations
750
+
751
+ **[Area]:**
752
+ - Risk: [What could go wrong]
753
+ - Files: `[file paths]`
754
+ - Current mitigation: [What's in place]
755
+ - Recommendations: [What should be added]
756
+
757
+ ## Performance Bottlenecks
758
+
759
+ **[Slow operation]:**
760
+ - Problem: [What's slow]
761
+ - Files: `[file paths]`
762
+ - Cause: [Why it's slow]
763
+ - Improvement path: [How to speed up]
764
+
765
+ ## Fragile Areas
766
+
767
+ **[Component/Module]:**
768
+ - Files: `[file paths]`
769
+ - Why fragile: [What makes it break easily]
770
+ - Safe modification: [How to change safely]
771
+ - Test coverage: [Gaps]
772
+
773
+ ## Scaling Limits
774
+
775
+ **[Resource/System]:**
776
+ - Current capacity: [Numbers]
777
+ - Limit: [Where it breaks]
778
+ - Scaling path: [How to increase]
779
+
780
+ ## Dependencies at Risk
781
+
782
+ **[Package]:**
783
+ - Risk: [What's wrong]
784
+ - Impact: [What breaks]
785
+ - Migration plan: [Alternative]
786
+
787
+ ## Missing Critical Features
788
+
789
+ **[Feature gap]:**
790
+ - Problem: [What's missing]
791
+ - Blocks: [What can't be done]
792
+
793
+ ## Test Coverage Gaps
794
+
795
+ **[Untested area]:**
796
+ - What's not tested: [Specific functionality]
797
+ - Files: `[file paths]`
798
+ - Risk: [What could break unnoticed]
799
+ - Priority: [High/Medium/Low]
800
+
801
+ ---
802
+
803
+ *Concerns audit: [date]*
804
+ ```
805
+
806
+ </templates>
807
+
808
+ <forbidden_files>
809
+ **NEVER read or quote contents from these files (even if they exist):**
810
+
811
+ - `.env`, `.env.*`, `*.env` - Environment variables with secrets
812
+ - `credentials.*`, `secrets.*`, `*secret*`, `*credential*` - Credential files
813
+ - `*.pem`, `*.key`, `*.p12`, `*.pfx`, `*.jks` - Certificates and private keys
814
+ - `id_rsa*`, `id_ed25519*`, `id_dsa*` - SSH private keys
815
+ - `.npmrc`, `.pypirc`, `.netrc` - Package manager auth tokens
816
+ - `config/secrets/*`, `.secrets/*`, `secrets/` - Secret directories
817
+ - `*.keystore`, `*.truststore` - Java keystores
818
+ - `serviceAccountKey.json`, `*-credentials.json` - Cloud service credentials
819
+ - `docker-compose*.yml` sections with passwords - May contain inline secrets
820
+ - Any file in `.gitignore` that appears to contain secrets
821
+
822
+ **If you encounter these files:**
823
+ - Note their EXISTENCE only: "`.env` file present - contains environment configuration"
824
+ - NEVER quote their contents, even partially
825
+ - NEVER include values like `API_KEY=...` or `sk-...` in any output
826
+
827
+ **Why this matters:** Your output gets committed to git. Leaked secrets = security incident.
828
+ </forbidden_files>
829
+
830
+ <critical_rules>
831
+
832
+ **WRITE DOCUMENTS DIRECTLY.** Do not return findings to orchestrator. The whole point is reducing context transfer.
833
+
834
+ **ALWAYS INCLUDE FILE PATHS.** Every finding needs a file path in backticks. No exceptions.
835
+
836
+ **USE THE TEMPLATES.** Fill in the template structure. Don't invent your own format.
837
+
838
+ **BE THOROUGH.** Explore deeply. Read actual files. Don't guess. **But respect <forbidden_files>.**
839
+
840
+ **RETURN ONLY CONFIRMATION.** Your response should be ~10 lines max. Just confirm what was written.
841
+
842
+ **DO NOT COMMIT.** The orchestrator handles git operations.
843
+
844
+ </critical_rules>
845
+
846
+ <success_criteria>
847
+ - [ ] Focus area parsed correctly
848
+ - [ ] Codebase explored thoroughly for focus area
849
+ - [ ] All documents for focus area written to `.planning/codebase/`
850
+ - [ ] Documents follow template structure
851
+ - [ ] File paths included throughout documents
852
+ - [ ] Confirmation returned (not document contents)
853
+ </success_criteria>