mindforge-cc 2.1.0 → 2.1.2

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 (236) hide show
  1. package/.agent/bin/lib/commands.cjs +959 -0
  2. package/.agent/bin/lib/config.cjs +421 -0
  3. package/.agent/bin/lib/core.cjs +1166 -0
  4. package/.agent/bin/lib/frontmatter.cjs +307 -0
  5. package/.agent/bin/lib/init.cjs +1336 -0
  6. package/.agent/bin/lib/milestone.cjs +252 -0
  7. package/.agent/bin/lib/model-profiles.cjs +68 -0
  8. package/.agent/bin/lib/phase.cjs +888 -0
  9. package/.agent/bin/lib/profile-output.cjs +952 -0
  10. package/.agent/bin/lib/profile-pipeline.cjs +539 -0
  11. package/.agent/bin/lib/roadmap.cjs +329 -0
  12. package/.agent/bin/lib/security.cjs +356 -0
  13. package/.agent/bin/lib/state.cjs +969 -0
  14. package/.agent/bin/lib/template.cjs +222 -0
  15. package/.agent/bin/lib/uat.cjs +189 -0
  16. package/.agent/bin/lib/verify.cjs +851 -0
  17. package/.agent/bin/lib/workstream.cjs +491 -0
  18. package/.agent/bin/mindforge-tools.cjs +897 -0
  19. package/.agent/file-manifest.json +219 -0
  20. package/.agent/hooks/mindforge-check-update.js +114 -0
  21. package/.agent/hooks/mindforge-context-monitor.js +156 -0
  22. package/.agent/hooks/mindforge-prompt-guard.js +96 -0
  23. package/.agent/hooks/mindforge-statusline.js +119 -0
  24. package/.agent/hooks/mindforge-workflow-guard.js +94 -0
  25. package/.agent/mindforge/discuss-phase.md +1 -1
  26. package/.agent/mindforge/help.md +1 -1
  27. package/.agent/mindforge/learn.md +3 -2
  28. package/.agent/mindforge/research.md +3 -2
  29. package/.agent/mindforge/steer.md +1 -1
  30. package/.agent/settings.json +38 -0
  31. package/.agent/skills/mindforge-add-backlog/SKILL.md +72 -0
  32. package/.agent/skills/mindforge-add-phase/SKILL.md +39 -0
  33. package/.agent/skills/mindforge-add-tests/SKILL.md +28 -0
  34. package/.agent/skills/mindforge-add-todo/SKILL.md +42 -0
  35. package/.agent/skills/mindforge-audit-milestone/SKILL.md +29 -0
  36. package/.agent/skills/mindforge-audit-uat/SKILL.md +20 -0
  37. package/.agent/skills/mindforge-autonomous/SKILL.md +33 -0
  38. package/.agent/skills/mindforge-check-todos/SKILL.md +40 -0
  39. package/.agent/skills/mindforge-cleanup/SKILL.md +19 -0
  40. package/.agent/skills/mindforge-complete-milestone/SKILL.md +131 -0
  41. package/.agent/skills/mindforge-debug/SKILL.md +163 -0
  42. package/.agent/skills/mindforge-discuss-phase/SKILL.md +54 -0
  43. package/.agent/skills/mindforge-do/SKILL.md +26 -0
  44. package/.agent/skills/mindforge-execute-phase/SKILL.md +49 -0
  45. package/.agent/skills/mindforge-fast/SKILL.md +23 -0
  46. package/.agent/skills/mindforge-forensics/SKILL.md +49 -0
  47. package/.agent/skills/mindforge-health/SKILL.md +17 -0
  48. package/.agent/skills/mindforge-help/SKILL.md +23 -0
  49. package/.agent/skills/mindforge-insert-phase/SKILL.md +28 -0
  50. package/.agent/skills/mindforge-join-discord/SKILL.md +19 -0
  51. package/.agent/skills/mindforge-list-phase-assumptions/SKILL.md +41 -0
  52. package/.agent/skills/mindforge-list-workspaces/SKILL.md +17 -0
  53. package/.agent/skills/mindforge-manager/SKILL.md +32 -0
  54. package/.agent/skills/mindforge-map-codebase/SKILL.md +64 -0
  55. package/.agent/skills/mindforge-milestone-summary/SKILL.md +44 -0
  56. package/.agent/skills/mindforge-new-milestone/SKILL.md +38 -0
  57. package/.agent/skills/mindforge-new-project/SKILL.md +36 -0
  58. package/.agent/skills/mindforge-new-workspace/SKILL.md +39 -0
  59. package/.agent/skills/mindforge-next/SKILL.md +19 -0
  60. package/.agent/skills/mindforge-note/SKILL.md +29 -0
  61. package/.agent/skills/mindforge-pause-work/SKILL.md +35 -0
  62. package/.agent/skills/mindforge-plan-milestone-gaps/SKILL.md +28 -0
  63. package/.agent/skills/mindforge-plan-phase/SKILL.md +37 -0
  64. package/.agent/skills/mindforge-plant-seed/SKILL.md +22 -0
  65. package/.agent/skills/mindforge-pr-branch/SKILL.md +21 -0
  66. package/.agent/skills/mindforge-profile-user/SKILL.md +38 -0
  67. package/.agent/skills/mindforge-progress/SKILL.md +19 -0
  68. package/.agent/skills/mindforge-quick/SKILL.md +38 -0
  69. package/.agent/skills/mindforge-reapply-patches/SKILL.md +124 -0
  70. package/.agent/skills/mindforge-remove-phase/SKILL.md +26 -0
  71. package/.agent/skills/mindforge-remove-workspace/SKILL.md +22 -0
  72. package/.agent/skills/mindforge-research-phase/SKILL.md +186 -0
  73. package/.agent/skills/mindforge-resume-work/SKILL.md +35 -0
  74. package/.agent/skills/mindforge-review/SKILL.md +31 -0
  75. package/.agent/skills/mindforge-review-backlog/SKILL.md +58 -0
  76. package/.agent/skills/mindforge-session-report/SKILL.md +16 -0
  77. package/.agent/skills/mindforge-set-profile/SKILL.md +9 -0
  78. package/.agent/skills/mindforge-settings/SKILL.md +32 -0
  79. package/.agent/skills/mindforge-ship/SKILL.md +16 -0
  80. package/.agent/skills/mindforge-stats/SKILL.md +16 -0
  81. package/.agent/skills/mindforge-thread/SKILL.md +123 -0
  82. package/.agent/skills/mindforge-ui-phase/SKILL.md +24 -0
  83. package/.agent/skills/mindforge-ui-review/SKILL.md +24 -0
  84. package/.agent/skills/mindforge-update/SKILL.md +35 -0
  85. package/.agent/skills/mindforge-validate-phase/SKILL.md +26 -0
  86. package/.agent/skills/mindforge-verify-work/SKILL.md +30 -0
  87. package/.agent/skills/mindforge-workstreams/SKILL.md +65 -0
  88. package/.agent/workflows/mindforge-add-phase.md +112 -0
  89. package/.agent/workflows/mindforge-add-tests.md +351 -0
  90. package/.agent/workflows/mindforge-add-todo.md +158 -0
  91. package/.agent/workflows/mindforge-audit-milestone.md +332 -0
  92. package/.agent/workflows/mindforge-audit-uat.md +109 -0
  93. package/.agent/workflows/mindforge-autonomous.md +815 -0
  94. package/.agent/workflows/mindforge-check-todos.md +177 -0
  95. package/.agent/workflows/mindforge-cleanup.md +152 -0
  96. package/.agent/workflows/mindforge-complete-milestone.md +766 -0
  97. package/.agent/workflows/mindforge-diagnose-issues.md +220 -0
  98. package/.agent/workflows/mindforge-discovery-phase.md +289 -0
  99. package/.agent/workflows/mindforge-discuss-phase-assumptions.md +645 -0
  100. package/.agent/workflows/mindforge-discuss-phase.md +1047 -0
  101. package/.agent/workflows/mindforge-do.md +104 -0
  102. package/.agent/workflows/mindforge-execute-phase.md +838 -0
  103. package/.agent/workflows/mindforge-execute-plan.md +509 -0
  104. package/.agent/workflows/mindforge-fast.md +105 -0
  105. package/.agent/workflows/mindforge-forensics.md +265 -0
  106. package/.agent/workflows/mindforge-health.md +181 -0
  107. package/.agent/workflows/mindforge-help.md +606 -0
  108. package/.agent/workflows/mindforge-insert-phase.md +130 -0
  109. package/.agent/workflows/mindforge-list-phase-assumptions.md +178 -0
  110. package/.agent/workflows/mindforge-list-workspaces.md +56 -0
  111. package/.agent/workflows/mindforge-manager.md +360 -0
  112. package/.agent/workflows/mindforge-map-codebase.md +370 -0
  113. package/.agent/workflows/mindforge-milestone-summary.md +223 -0
  114. package/.agent/workflows/mindforge-new-milestone.md +469 -0
  115. package/.agent/workflows/mindforge-new-project.md +1226 -0
  116. package/.agent/workflows/mindforge-new-workspace.md +237 -0
  117. package/.agent/workflows/mindforge-next.md +97 -0
  118. package/.agent/workflows/mindforge-node-repair.md +92 -0
  119. package/.agent/workflows/mindforge-note.md +156 -0
  120. package/.agent/workflows/mindforge-pause-work.md +176 -0
  121. package/.agent/workflows/mindforge-plan-milestone-gaps.md +273 -0
  122. package/.agent/workflows/mindforge-plan-phase.md +848 -0
  123. package/.agent/workflows/mindforge-plant-seed.md +169 -0
  124. package/.agent/workflows/mindforge-pr-branch.md +129 -0
  125. package/.agent/workflows/mindforge-profile-user.md +450 -0
  126. package/.agent/workflows/mindforge-progress.md +507 -0
  127. package/.agent/workflows/mindforge-quick.md +732 -0
  128. package/.agent/workflows/mindforge-remove-phase.md +155 -0
  129. package/.agent/workflows/mindforge-remove-workspace.md +90 -0
  130. package/.agent/workflows/mindforge-research-phase.md +74 -0
  131. package/.agent/workflows/mindforge-resume-project.md +325 -0
  132. package/.agent/workflows/mindforge-review.md +228 -0
  133. package/.agent/workflows/mindforge-session-report.md +146 -0
  134. package/.agent/workflows/mindforge-settings.md +283 -0
  135. package/.agent/workflows/mindforge-ship.md +228 -0
  136. package/.agent/workflows/mindforge-stats.md +60 -0
  137. package/.agent/workflows/mindforge-transition.md +671 -0
  138. package/.agent/workflows/mindforge-ui-phase.md +290 -0
  139. package/.agent/workflows/mindforge-ui-review.md +157 -0
  140. package/.agent/workflows/mindforge-update.md +323 -0
  141. package/.agent/workflows/mindforge-validate-phase.md +167 -0
  142. package/.agent/workflows/mindforge-verify-phase.md +254 -0
  143. package/.agent/workflows/mindforge-verify-work.md +623 -0
  144. package/.mindforge/personas/advisor-researcher.md +3 -3
  145. package/.mindforge/personas/debug-specialist.md +1 -1
  146. package/.mindforge/personas/debugger.md +1 -1
  147. package/.mindforge/personas/developer.md +1 -1
  148. package/.mindforge/personas/phase-researcher.md +4 -4
  149. package/.mindforge/personas/project-researcher.md +3 -3
  150. package/.mindforge/personas/research-agent.md +4 -3
  151. package/.mindforge/personas/tech-writer.md +1 -1
  152. package/.mindforge/personas/ui-researcher.md +1 -1
  153. package/.planning/ROADMAP.md +10 -0
  154. package/CHANGELOG.md +34 -0
  155. package/README.md +70 -45
  156. package/RELEASENOTES.md +26 -26
  157. package/bin/install.js +41 -41
  158. package/bin/installer-core.js +67 -26
  159. package/bin/wizard/setup-wizard.js +11 -24
  160. package/bin/wizard/theme.js +141 -0
  161. package/docs/PERSONAS.md +119 -87
  162. package/docs/References/checkpoints.md +778 -0
  163. package/docs/References/config-reference.md +81 -0
  164. package/docs/References/continuation-format.md +249 -0
  165. package/docs/References/decimal-phase-calculation.md +64 -0
  166. package/docs/References/git-integration.md +295 -0
  167. package/docs/References/git-planning-commit.md +38 -0
  168. package/docs/References/model-profile-resolution.md +36 -0
  169. package/docs/References/model-profiles.md +139 -0
  170. package/docs/References/phase-argument-parsing.md +61 -0
  171. package/docs/References/planning-config.md +202 -0
  172. package/docs/References/questioning.md +162 -0
  173. package/docs/References/tdd.md +263 -0
  174. package/docs/References/ui-brand.md +160 -0
  175. package/docs/References/user-profiling.md +681 -0
  176. package/docs/References/verification-patterns.md +612 -0
  177. package/docs/References/workstream-flag.md +58 -0
  178. package/docs/Templates/Agents/CLAUDE-MD.md +122 -0
  179. package/docs/Templates/Agents/COPILOT-INSTRUCTIONS.md +7 -0
  180. package/docs/Templates/Agents/DEBUGGER-PROMPT.md +91 -0
  181. package/docs/Templates/Agents/PLANNER-PROMPT.md +117 -0
  182. package/docs/Templates/Codebase/architecture.md +255 -0
  183. package/docs/Templates/Codebase/concerns.md +310 -0
  184. package/docs/Templates/Codebase/conventions.md +307 -0
  185. package/docs/Templates/Codebase/integrations.md +280 -0
  186. package/docs/Templates/Codebase/stack.md +186 -0
  187. package/docs/Templates/Codebase/structure.md +285 -0
  188. package/docs/Templates/Codebase/testing.md +480 -0
  189. package/docs/Templates/Execution/CONTINUE-HERE.md +78 -0
  190. package/docs/Templates/Execution/DISCUSSION-LOG.md +63 -0
  191. package/docs/Templates/Execution/PHASE-PROMPT.md +610 -0
  192. package/docs/Templates/Execution/STATE.md +176 -0
  193. package/docs/Templates/Execution/SUMMARY-COMPLEX.md +59 -0
  194. package/docs/Templates/Execution/SUMMARY-MINIMAL.md +41 -0
  195. package/docs/Templates/Execution/SUMMARY-STANDARD.md +48 -0
  196. package/docs/Templates/Execution/SUMMARY.md +248 -0
  197. package/docs/Templates/Profile/DEV-PREFERENCES.md +21 -0
  198. package/docs/Templates/Profile/USER-PROFILE.md +146 -0
  199. package/docs/Templates/Profile/USER-SETUP.md +311 -0
  200. package/docs/Templates/Project/DISCOVERY.md +146 -0
  201. package/docs/Templates/Project/MILESTONE-ARCHIVE.md +123 -0
  202. package/docs/Templates/Project/MILESTONE.md +115 -0
  203. package/docs/Templates/Project/PROJECT.md +206 -0
  204. package/docs/Templates/Project/REQUIREMENTS.md +231 -0
  205. package/docs/Templates/Project/RETROSPECTIVE.md +54 -0
  206. package/docs/Templates/Project/ROADMAP.md +202 -0
  207. package/docs/Templates/Quality/DEBUG.md +164 -0
  208. package/docs/Templates/Quality/UAT.md +280 -0
  209. package/docs/Templates/Quality/UI-SPEC.md +100 -0
  210. package/docs/Templates/Quality/VALIDATION.md +76 -0
  211. package/docs/Templates/Quality/VERIFICATION-REPORT.md +322 -0
  212. package/docs/Templates/Research/ARCHITECTURE.md +204 -0
  213. package/docs/Templates/Research/FEATURES.md +147 -0
  214. package/docs/Templates/Research/PITFALLS.md +200 -0
  215. package/docs/Templates/Research/STACK.md +120 -0
  216. package/docs/Templates/Research/SUMMARY.md +170 -0
  217. package/docs/Templates/System/CONFIG.json +43 -0
  218. package/docs/Templates/System/CONTEXT.md +352 -0
  219. package/docs/architecture/README.md +54 -42
  220. package/docs/commands-reference.md +62 -14
  221. package/docs/getting-started.md +26 -18
  222. package/docs/skills-authoring-guide.md +40 -12
  223. package/docs/tutorial.md +83 -116
  224. package/docs/user-guide.md +72 -198
  225. package/package.json +7 -2
  226. package/.mindforge/memory/knowledge-base.jsonl +0 -7
  227. package/.mindforge/memory/pattern-library.jsonl +0 -1
  228. package/.mindforge/memory/team-preferences.jsonl +0 -4
  229. package/.planning/browser-daemon.log +0 -32
  230. package/docs/mindforge-md-reference.md +0 -57
  231. package/docs/reference/config-reference.md +0 -64
  232. /package/{.mindforge/memory/decision-library.jsonl → .planning/phases/01-migrate-gsd-to-mindforge/.gitkeep} +0 -0
  233. /package/docs/{reference → References}/audit-events.md +0 -0
  234. /package/docs/{reference → References}/commands.md +0 -0
  235. /package/docs/{reference → References}/sdk-api.md +0 -0
  236. /package/docs/{reference → References}/skills-api.md +0 -0
@@ -0,0 +1,1226 @@
1
+ <purpose>
2
+ Initialize a new project through unified flow: questioning, research (optional), requirements, roadmap. This is the most leveraged moment in any project — deep questioning here means better plans, better execution, better outcomes. One workflow takes you from idea to ready-for-planning.
3
+ </purpose>
4
+
5
+ <required_reading>
6
+ Read all files referenced by the invoking prompt's execution_context before starting.
7
+ </required_reading>
8
+
9
+ <auto_mode>
10
+
11
+ ## Auto Mode Detection
12
+
13
+ Check if `--auto` flag is present in $ARGUMENTS.
14
+
15
+ **If auto mode:**
16
+
17
+ - Skip brownfield mapping offer (assume greenfield)
18
+ - Skip deep questioning (extract context from provided document)
19
+ - Config: YOLO mode is implicit (skip that question), but ask granularity/git/agents FIRST (Step 2a)
20
+ - After config: run Steps 6-9 automatically with smart defaults:
21
+ - Research: Always yes
22
+ - Requirements: Include all table stakes + features from provided document
23
+ - Requirements approval: Auto-approve
24
+ - Roadmap approval: Auto-approve
25
+
26
+ **Document requirement:**
27
+ Auto mode requires an idea document — either:
28
+
29
+ - File reference: `/mindforge-new-project --auto @prd.md`
30
+ - Pasted/written text in the prompt
31
+
32
+ If no document content provided, error:
33
+
34
+ ```
35
+ Error: --auto requires an idea document.
36
+
37
+ Usage:
38
+ /mindforge-new-project --auto @your-idea.md
39
+ /mindforge-new-project --auto [paste or write your idea here]
40
+
41
+ The document should describe what you want to build.
42
+ ```
43
+
44
+ </auto_mode>
45
+
46
+ <process>
47
+
48
+ ## 1. Setup
49
+
50
+ **MANDATORY FIRST STEP — Execute these checks before ANY user interaction:**
51
+
52
+ ```bash
53
+ INIT=$(node ".agent/bin/mindforge-tools.cjs" init new-project)
54
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
55
+ ```
56
+
57
+ Parse JSON for: `researcher_model`, `synthesizer_model`, `roadmapper_model`, `commit_docs`, `project_exists`, `has_codebase_map`, `planning_exists`, `has_existing_code`, `has_package_file`, `is_brownfield`, `needs_codebase_map`, `has_git`, `project_path`.
58
+
59
+ **If `project_exists` is true:** Error — project already initialized. Use `/mindforge-progress`.
60
+
61
+ **If `has_git` is false:** Initialize git:
62
+
63
+ ```bash
64
+ git init
65
+ ```
66
+
67
+ ## 2. Brownfield Offer
68
+
69
+ **If auto mode:** Skip to Step 4 (assume greenfield, synthesize PROJECT.md from provided document).
70
+
71
+ **If `needs_codebase_map` is true** (from init — existing code detected but no codebase map):
72
+
73
+ Use AskUserQuestion:
74
+
75
+ - header: "Codebase"
76
+ - question: "I detected existing code in this directory. Would you like to map the codebase first?"
77
+ - options:
78
+ - "Map codebase first" — Run /mindforge-map-codebase to understand existing architecture (Recommended)
79
+ - "Skip mapping" — Proceed with project initialization
80
+
81
+ **If "Map codebase first":**
82
+
83
+ ```
84
+ Run `/mindforge-map-codebase` first, then return to `/mindforge-new-project`
85
+ ```
86
+
87
+ Exit command.
88
+
89
+ **If "Skip mapping" OR `needs_codebase_map` is false:** Continue to Step 3.
90
+
91
+ ## 2a. Auto Mode Config (auto mode only)
92
+
93
+ **If auto mode:** Collect config settings upfront before processing the idea document.
94
+
95
+ YOLO mode is implicit (auto = YOLO). Ask remaining config questions:
96
+
97
+ **Round 1 — Core settings (3 questions, no Mode question):**
98
+
99
+ ```
100
+ AskUserQuestion([
101
+ {
102
+ header: "Granularity",
103
+ question: "How finely should scope be sliced into phases?",
104
+ multiSelect: false,
105
+ options: [
106
+ { label: "Coarse (Recommended)", description: "Fewer, broader phases (3-5 phases, 1-3 plans each)" },
107
+ { label: "Standard", description: "Balanced phase size (5-8 phases, 3-5 plans each)" },
108
+ { label: "Fine", description: "Many focused phases (8-12 phases, 5-10 plans each)" }
109
+ ]
110
+ },
111
+ {
112
+ header: "Execution",
113
+ question: "Run plans in parallel?",
114
+ multiSelect: false,
115
+ options: [
116
+ { label: "Parallel (Recommended)", description: "Independent plans run simultaneously" },
117
+ { label: "Sequential", description: "One plan at a time" }
118
+ ]
119
+ },
120
+ {
121
+ header: "Git Tracking",
122
+ question: "Commit planning docs to git?",
123
+ multiSelect: false,
124
+ options: [
125
+ { label: "Yes (Recommended)", description: "Planning docs tracked in version control" },
126
+ { label: "No", description: "Keep .planning/ local-only (add to .gitignore)" }
127
+ ]
128
+ }
129
+ ])
130
+ ```
131
+
132
+ **Round 2 — Workflow agents (same as Step 5):**
133
+
134
+ ```
135
+ AskUserQuestion([
136
+ {
137
+ header: "Research",
138
+ question: "Research before planning each phase? (adds tokens/time)",
139
+ multiSelect: false,
140
+ options: [
141
+ { label: "Yes (Recommended)", description: "Investigate domain, find patterns, surface gotchas" },
142
+ { label: "No", description: "Plan directly from requirements" }
143
+ ]
144
+ },
145
+ {
146
+ header: "Plan Check",
147
+ question: "Verify plans will achieve their goals? (adds tokens/time)",
148
+ multiSelect: false,
149
+ options: [
150
+ { label: "Yes (Recommended)", description: "Catch gaps before execution starts" },
151
+ { label: "No", description: "Execute plans without verification" }
152
+ ]
153
+ },
154
+ {
155
+ header: "Verifier",
156
+ question: "Verify work satisfies requirements after each phase? (adds tokens/time)",
157
+ multiSelect: false,
158
+ options: [
159
+ { label: "Yes (Recommended)", description: "Confirm deliverables match phase goals" },
160
+ { label: "No", description: "Trust execution, skip verification" }
161
+ ]
162
+ },
163
+ {
164
+ header: "AI Models",
165
+ question: "Which AI models for planning agents?",
166
+ multiSelect: false,
167
+ options: [
168
+ { label: "Balanced (Recommended)", description: "Sonnet for most agents — good quality/cost ratio" },
169
+ { label: "Quality", description: "Opus for research/roadmap — higher cost, deeper analysis" },
170
+ { label: "Budget", description: "Haiku where possible — fastest, lowest cost" },
171
+ { label: "Inherit", description: "Use the current session model for all agents (OpenCode /model)" }
172
+ ]
173
+ }
174
+ ])
175
+ ```
176
+
177
+ Create `.planning/config.json` with all settings (CLI fills in remaining defaults automatically):
178
+
179
+ ```bash
180
+ mkdir -p .planning
181
+ node ".agent/bin/mindforge-tools.cjs" config-new-project '{"mode":"yolo","granularity":"[selected]","parallelization":true|false,"commit_docs":true|false,"model_profile":"quality|balanced|budget|inherit","workflow":{"research":true|false,"plan_check":true|false,"verifier":true|false,"nyquist_validation":true|false,"auto_advance":true}}'
182
+ ```
183
+
184
+ **If commit_docs = No:** Add `.planning/` to `.gitignore`.
185
+
186
+ **Commit config.json:**
187
+
188
+ ```bash
189
+ mkdir -p .planning
190
+ node ".agent/bin/mindforge-tools.cjs" commit "chore: add project config" --files .planning/config.json
191
+ ```
192
+
193
+ **Persist auto-advance chain flag to config (survives context compaction):**
194
+
195
+ ```bash
196
+ node ".agent/bin/mindforge-tools.cjs" config-set workflow._auto_chain_active true
197
+ ```
198
+
199
+ Proceed to Step 4 (skip Steps 3 and 5).
200
+
201
+ ## 3. Deep Questioning
202
+
203
+ **If auto mode:** Skip (already handled in Step 2a). Extract project context from provided document instead and proceed to Step 4.
204
+
205
+ **Display stage banner:**
206
+
207
+ ```
208
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
209
+ MindForge ► QUESTIONING
210
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
211
+ ```
212
+
213
+ **Open the conversation:**
214
+
215
+ Ask inline (freeform, NOT AskUserQuestion):
216
+
217
+ "What do you want to build?"
218
+
219
+ Wait for their response. This gives you the context needed to ask intelligent follow-up questions.
220
+
221
+ **Research-before-questions mode:** Check if `workflow.research_before_questions` is enabled in `.planning/config.json` (or the config from init context). When enabled, before asking follow-up questions about a topic area:
222
+
223
+ 1. Do a brief web search for best practices related to what the user described
224
+ 2. Mention key findings naturally as you ask questions (e.g., "Most projects like this use X — is that what you're thinking, or something different?")
225
+ 3. This makes questions more informed without changing the conversational flow
226
+
227
+ When disabled (default), ask questions directly as before.
228
+
229
+ **Follow the thread:**
230
+
231
+ Based on what they said, ask follow-up questions that dig into their response. Use AskUserQuestion with options that probe what they mentioned — interpretations, clarifications, concrete examples.
232
+
233
+ Keep following threads. Each answer opens new threads to explore. Ask about:
234
+
235
+ - What excited them
236
+ - What problem sparked this
237
+ - What they mean by vague terms
238
+ - What it would actually look like
239
+ - What's already decided
240
+
241
+ Consult `questioning.md` for techniques:
242
+
243
+ - Challenge vagueness
244
+ - Make abstract concrete
245
+ - Surface assumptions
246
+ - Find edges
247
+ - Reveal motivation
248
+
249
+ **Check context (background, not out loud):**
250
+
251
+ As you go, mentally check the context checklist from `questioning.md`. If gaps remain, weave questions naturally. Don't suddenly switch to checklist mode.
252
+
253
+ **Decision gate:**
254
+
255
+ When you could write a clear PROJECT.md, use AskUserQuestion:
256
+
257
+ - header: "Ready?"
258
+ - question: "I think I understand what you're after. Ready to create PROJECT.md?"
259
+ - options:
260
+ - "Create PROJECT.md" — Let's move forward
261
+ - "Keep exploring" — I want to share more / ask me more
262
+
263
+ If "Keep exploring" — ask what they want to add, or identify gaps and probe naturally.
264
+
265
+ Loop until "Create PROJECT.md" selected.
266
+
267
+ ## 4. Write PROJECT.md
268
+
269
+ **If auto mode:** Synthesize from provided document. No "Ready?" gate was shown — proceed directly to commit.
270
+
271
+ Synthesize all context into `.planning/PROJECT.md` using the template from `templates/project.md`.
272
+
273
+ **For greenfield projects:**
274
+
275
+ Initialize requirements as hypotheses:
276
+
277
+ ```markdown
278
+ ## Requirements
279
+
280
+ ### Validated
281
+
282
+ (None yet — ship to validate)
283
+
284
+ ### Active
285
+
286
+ - [ ] [Requirement 1]
287
+ - [ ] [Requirement 2]
288
+ - [ ] [Requirement 3]
289
+
290
+ ### Out of Scope
291
+
292
+ - [Exclusion 1] — [why]
293
+ - [Exclusion 2] — [why]
294
+ ```
295
+
296
+ All Active requirements are hypotheses until shipped and validated.
297
+
298
+ **For brownfield projects (codebase map exists):**
299
+
300
+ Infer Validated requirements from existing code:
301
+
302
+ 1. Read `.planning/codebase/ARCHITECTURE.md` and `STACK.md`
303
+ 2. Identify what the codebase already does
304
+ 3. These become the initial Validated set
305
+
306
+ ```markdown
307
+ ## Requirements
308
+
309
+ ### Validated
310
+
311
+ - ✓ [Existing capability 1] — existing
312
+ - ✓ [Existing capability 2] — existing
313
+ - ✓ [Existing capability 3] — existing
314
+
315
+ ### Active
316
+
317
+ - [ ] [New requirement 1]
318
+ - [ ] [New requirement 2]
319
+
320
+ ### Out of Scope
321
+
322
+ - [Exclusion 1] — [why]
323
+ ```
324
+
325
+ **Key Decisions:**
326
+
327
+ Initialize with any decisions made during questioning:
328
+
329
+ ```markdown
330
+ ## Key Decisions
331
+
332
+ | Decision | Rationale | Outcome |
333
+ |----------|-----------|---------|
334
+ | [Choice from questioning] | [Why] | — Pending |
335
+ ```
336
+
337
+ **Last updated footer:**
338
+
339
+ ```markdown
340
+ ---
341
+ *Last updated: [date] after initialization*
342
+ ```
343
+
344
+ **Evolution section** (include at the end of PROJECT.md, before the footer):
345
+
346
+ ```markdown
347
+ ## Evolution
348
+
349
+ This document evolves at phase transitions and milestone boundaries.
350
+
351
+ **After each phase transition** (via `/mindforge-transition`):
352
+ 1. Requirements invalidated? → Move to Out of Scope with reason
353
+ 2. Requirements validated? → Move to Validated with phase reference
354
+ 3. New requirements emerged? → Add to Active
355
+ 4. Decisions to log? → Add to Key Decisions
356
+ 5. "What This Is" still accurate? → Update if drifted
357
+
358
+ **After each milestone** (via `/mindforge-complete-milestone`):
359
+ 1. Full review of all sections
360
+ 2. Core Value check — still the right priority?
361
+ 3. Audit Out of Scope — reasons still valid?
362
+ 4. Update Context with current state
363
+ ```
364
+
365
+ Do not compress. Capture everything gathered.
366
+
367
+ **Commit PROJECT.md:**
368
+
369
+ ```bash
370
+ mkdir -p .planning
371
+ node ".agent/bin/mindforge-tools.cjs" commit "docs: initialize project" --files .planning/PROJECT.md
372
+ ```
373
+
374
+ ## 5. Workflow Preferences
375
+
376
+ **If auto mode:** Skip — config was collected in Step 2a. Proceed to Step 5.5.
377
+
378
+ **Check for global defaults** at `~/.mindforge/defaults.json`. If the file exists, offer to use saved defaults:
379
+
380
+ ```
381
+ AskUserQuestion([
382
+ {
383
+ question: "Use your saved default settings? (from ~/.mindforge/defaults.json)",
384
+ header: "Defaults",
385
+ multiSelect: false,
386
+ options: [
387
+ { label: "Yes (Recommended)", description: "Use saved defaults, skip settings questions" },
388
+ { label: "No", description: "Configure settings manually" }
389
+ ]
390
+ }
391
+ ])
392
+ ```
393
+
394
+ If "Yes": read `~/.mindforge/defaults.json`, use those values for config.json, and skip directly to **Commit config.json** below.
395
+
396
+ If "No" or `~/.mindforge/defaults.json` doesn't exist: proceed with the questions below.
397
+
398
+ **Round 1 — Core workflow settings (4 questions):**
399
+
400
+ ```
401
+ questions: [
402
+ {
403
+ header: "Mode",
404
+ question: "How do you want to work?",
405
+ multiSelect: false,
406
+ options: [
407
+ { label: "YOLO (Recommended)", description: "Auto-approve, just execute" },
408
+ { label: "Interactive", description: "Confirm at each step" }
409
+ ]
410
+ },
411
+ {
412
+ header: "Granularity",
413
+ question: "How finely should scope be sliced into phases?",
414
+ multiSelect: false,
415
+ options: [
416
+ { label: "Coarse", description: "Fewer, broader phases (3-5 phases, 1-3 plans each)" },
417
+ { label: "Standard", description: "Balanced phase size (5-8 phases, 3-5 plans each)" },
418
+ { label: "Fine", description: "Many focused phases (8-12 phases, 5-10 plans each)" }
419
+ ]
420
+ },
421
+ {
422
+ header: "Execution",
423
+ question: "Run plans in parallel?",
424
+ multiSelect: false,
425
+ options: [
426
+ { label: "Parallel (Recommended)", description: "Independent plans run simultaneously" },
427
+ { label: "Sequential", description: "One plan at a time" }
428
+ ]
429
+ },
430
+ {
431
+ header: "Git Tracking",
432
+ question: "Commit planning docs to git?",
433
+ multiSelect: false,
434
+ options: [
435
+ { label: "Yes (Recommended)", description: "Planning docs tracked in version control" },
436
+ { label: "No", description: "Keep .planning/ local-only (add to .gitignore)" }
437
+ ]
438
+ }
439
+ ]
440
+ ```
441
+
442
+ **Round 2 — Workflow agents:**
443
+
444
+ These spawn additional agents during planning/execution. They add tokens and time but improve quality.
445
+
446
+ | Agent | When it runs | What it does |
447
+ |-------|--------------|--------------|
448
+ | **Researcher** | Before planning each phase | Investigates domain, finds patterns, surfaces gotchas |
449
+ | **Plan Checker** | After plan is created | Verifies plan actually achieves the phase goal |
450
+ | **Verifier** | After phase execution | Confirms must-haves were delivered |
451
+
452
+ All recommended for important projects. Skip for quick experiments.
453
+
454
+ ```
455
+ questions: [
456
+ {
457
+ header: "Research",
458
+ question: "Research before planning each phase? (adds tokens/time)",
459
+ multiSelect: false,
460
+ options: [
461
+ { label: "Yes (Recommended)", description: "Investigate domain, find patterns, surface gotchas" },
462
+ { label: "No", description: "Plan directly from requirements" }
463
+ ]
464
+ },
465
+ {
466
+ header: "Plan Check",
467
+ question: "Verify plans will achieve their goals? (adds tokens/time)",
468
+ multiSelect: false,
469
+ options: [
470
+ { label: "Yes (Recommended)", description: "Catch gaps before execution starts" },
471
+ { label: "No", description: "Execute plans without verification" }
472
+ ]
473
+ },
474
+ {
475
+ header: "Verifier",
476
+ question: "Verify work satisfies requirements after each phase? (adds tokens/time)",
477
+ multiSelect: false,
478
+ options: [
479
+ { label: "Yes (Recommended)", description: "Confirm deliverables match phase goals" },
480
+ { label: "No", description: "Trust execution, skip verification" }
481
+ ]
482
+ },
483
+ {
484
+ header: "AI Models",
485
+ question: "Which AI models for planning agents?",
486
+ multiSelect: false,
487
+ options: [
488
+ { label: "Balanced (Recommended)", description: "Sonnet for most agents — good quality/cost ratio" },
489
+ { label: "Quality", description: "Opus for research/roadmap — higher cost, deeper analysis" },
490
+ { label: "Budget", description: "Haiku where possible — fastest, lowest cost" },
491
+ { label: "Inherit", description: "Use the current session model for all agents (OpenCode /model)" }
492
+ ]
493
+ }
494
+ ]
495
+ ```
496
+
497
+ Create `.planning/config.json` with all settings (CLI fills in remaining defaults automatically):
498
+
499
+ ```bash
500
+ mkdir -p .planning
501
+ node ".agent/bin/mindforge-tools.cjs" config-new-project '{"mode":"[yolo|interactive]","granularity":"[selected]","parallelization":true|false,"commit_docs":true|false,"model_profile":"quality|balanced|budget|inherit","workflow":{"research":true|false,"plan_check":true|false,"verifier":true|false,"nyquist_validation":[false if granularity=coarse, true otherwise]}}'
502
+ ```
503
+
504
+ **Note:** Run `/mindforge-settings` anytime to update model profile, workflow agents, branching strategy, and other preferences.
505
+
506
+ **If commit_docs = No:**
507
+
508
+ - Set `commit_docs: false` in config.json
509
+ - Add `.planning/` to `.gitignore` (create if needed)
510
+
511
+ **If commit_docs = Yes:**
512
+
513
+ - No additional gitignore entries needed
514
+
515
+ **Commit config.json:**
516
+
517
+ ```bash
518
+ node ".agent/bin/mindforge-tools.cjs" commit "chore: add project config" --files .planning/config.json
519
+ ```
520
+
521
+ ## 5.1. Sub-Repo Detection
522
+
523
+ **Detect multi-repo workspace:**
524
+
525
+ Check for directories with their own `.git` folders (separate repos within the workspace):
526
+
527
+ ```bash
528
+ find . -maxdepth 1 -type d -not -name ".*" -not -name "node_modules" -exec test -d "{}/.git" \; -print
529
+ ```
530
+
531
+ **If sub-repos found:**
532
+
533
+ Strip the `./` prefix to get directory names (e.g., `./backend` → `backend`).
534
+
535
+ Use AskUserQuestion:
536
+
537
+ - header: "Multi-Repo Workspace"
538
+ - question: "I detected separate git repos in this workspace. Which directories contain code that MindForge should commit to?"
539
+ - multiSelect: true
540
+ - options: one option per detected directory
541
+ - "[directory name]" — Separate git repo
542
+
543
+ **If user selects one or more directories:**
544
+
545
+ - Set `planning.sub_repos` in config.json to the selected directory names array (e.g., `["backend", "frontend"]`)
546
+ - Auto-set `planning.commit_docs` to `false` (planning docs stay local in multi-repo workspaces)
547
+ - Add `.planning/` to `.gitignore` if not already present
548
+
549
+ Config changes are saved locally — no commit needed since `commit_docs` is `false` in multi-repo mode.
550
+
551
+ **If no sub-repos found or user selects none:** Continue with no changes to config.
552
+
553
+ ## 5.5. Resolve Model Profile
554
+
555
+ Use models from init: `researcher_model`, `synthesizer_model`, `roadmapper_model`.
556
+
557
+ ## 6. Research Decision
558
+
559
+ **If auto mode:** Default to "Research first" without asking.
560
+
561
+ Use AskUserQuestion:
562
+
563
+ - header: "Research"
564
+ - question: "Research the domain ecosystem before defining requirements?"
565
+ - options:
566
+ - "Research first (Recommended)" — Discover standard stacks, expected features, architecture patterns
567
+ - "Skip research" — I know this domain well, go straight to requirements
568
+
569
+ **If "Research first":**
570
+
571
+ Display stage banner:
572
+
573
+ ```
574
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
575
+ MindForge ► RESEARCHING
576
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
577
+
578
+ Researching [domain] ecosystem...
579
+ ```
580
+
581
+ Create research directory:
582
+
583
+ ```bash
584
+ mkdir -p .planning/research
585
+ ```
586
+
587
+ **Determine milestone context:**
588
+
589
+ Check if this is greenfield or subsequent milestone:
590
+
591
+ - If no "Validated" requirements in PROJECT.md → Greenfield (building from scratch)
592
+ - If "Validated" requirements exist → Subsequent milestone (adding to existing app)
593
+
594
+ Display spawning indicator:
595
+
596
+ ```
597
+ ◆ Spawning 4 researchers in parallel...
598
+ → Stack research
599
+ → Features research
600
+ → Architecture research
601
+ → Pitfalls research
602
+ ```
603
+
604
+ Spawn 4 parallel mindforge-project-researcher agents with path references:
605
+
606
+ ```
607
+ Task(prompt="<research_type>
608
+ Project Research — Stack dimension for [domain].
609
+ </research_type>
610
+
611
+ <milestone_context>
612
+ [greenfield OR subsequent]
613
+
614
+ Greenfield: Research the standard stack for building [domain] from scratch.
615
+ Subsequent: Research what's needed to add [target features] to an existing [domain] app. Don't re-research the existing system.
616
+ </milestone_context>
617
+
618
+ <question>
619
+ What's the standard 2025 stack for [domain]?
620
+ </question>
621
+
622
+ <files_to_read>
623
+ - {project_path} (Project context and goals)
624
+ </files_to_read>
625
+
626
+ <downstream_consumer>
627
+ Your STACK.md feeds into roadmap creation. Be prescriptive:
628
+ - Specific libraries with versions
629
+ - Clear rationale for each choice
630
+ - What NOT to use and why
631
+ </downstream_consumer>
632
+
633
+ <quality_gate>
634
+ - [ ] Versions are current (verify with Context7/official docs, not training data)
635
+ - [ ] Rationale explains WHY, not just WHAT
636
+ - [ ] Confidence levels assigned to each recommendation
637
+ </quality_gate>
638
+
639
+ <output>
640
+ Write to: .planning/research/STACK.md
641
+ Use template: .agent/mindforge/templates/research-project/STACK.md
642
+ </output>
643
+ ", subagent_type="mindforge-project-researcher", model="{researcher_model}", description="Stack research")
644
+
645
+ Task(prompt="<research_type>
646
+ Project Research — Features dimension for [domain].
647
+ </research_type>
648
+
649
+ <milestone_context>
650
+ [greenfield OR subsequent]
651
+
652
+ Greenfield: What features do [domain] products have? What's table stakes vs differentiating?
653
+ Subsequent: How do [target features] typically work? What's expected behavior?
654
+ </milestone_context>
655
+
656
+ <question>
657
+ What features do [domain] products have? What's table stakes vs differentiating?
658
+ </question>
659
+
660
+ <files_to_read>
661
+ - {project_path} (Project context)
662
+ </files_to_read>
663
+
664
+ <downstream_consumer>
665
+ Your FEATURES.md feeds into requirements definition. Categorize clearly:
666
+ - Table stakes (must have or users leave)
667
+ - Differentiators (competitive advantage)
668
+ - Anti-features (things to deliberately NOT build)
669
+ </downstream_consumer>
670
+
671
+ <quality_gate>
672
+ - [ ] Categories are clear (table stakes vs differentiators vs anti-features)
673
+ - [ ] Complexity noted for each feature
674
+ - [ ] Dependencies between features identified
675
+ </quality_gate>
676
+
677
+ <output>
678
+ Write to: .planning/research/FEATURES.md
679
+ Use template: .agent/mindforge/templates/research-project/FEATURES.md
680
+ </output>
681
+ ", subagent_type="mindforge-project-researcher", model="{researcher_model}", description="Features research")
682
+
683
+ Task(prompt="<research_type>
684
+ Project Research — Architecture dimension for [domain].
685
+ </research_type>
686
+
687
+ <milestone_context>
688
+ [greenfield OR subsequent]
689
+
690
+ Greenfield: How are [domain] systems typically structured? What are major components?
691
+ Subsequent: How do [target features] integrate with existing [domain] architecture?
692
+ </milestone_context>
693
+
694
+ <question>
695
+ How are [domain] systems typically structured? What are major components?
696
+ </question>
697
+
698
+ <files_to_read>
699
+ - {project_path} (Project context)
700
+ </files_to_read>
701
+
702
+ <downstream_consumer>
703
+ Your ARCHITECTURE.md informs phase structure in roadmap. Include:
704
+ - Component boundaries (what talks to what)
705
+ - Data flow (how information moves)
706
+ - Suggested build order (dependencies between components)
707
+ </downstream_consumer>
708
+
709
+ <quality_gate>
710
+ - [ ] Components clearly defined with boundaries
711
+ - [ ] Data flow direction explicit
712
+ - [ ] Build order implications noted
713
+ </quality_gate>
714
+
715
+ <output>
716
+ Write to: .planning/research/ARCHITECTURE.md
717
+ Use template: .agent/mindforge/templates/research-project/ARCHITECTURE.md
718
+ </output>
719
+ ", subagent_type="mindforge-project-researcher", model="{researcher_model}", description="Architecture research")
720
+
721
+ Task(prompt="<research_type>
722
+ Project Research — Pitfalls dimension for [domain].
723
+ </research_type>
724
+
725
+ <milestone_context>
726
+ [greenfield OR subsequent]
727
+
728
+ Greenfield: What do [domain] projects commonly get wrong? Critical mistakes?
729
+ Subsequent: What are common mistakes when adding [target features] to [domain]?
730
+ </milestone_context>
731
+
732
+ <question>
733
+ What do [domain] projects commonly get wrong? Critical mistakes?
734
+ </question>
735
+
736
+ <files_to_read>
737
+ - {project_path} (Project context)
738
+ </files_to_read>
739
+
740
+ <downstream_consumer>
741
+ Your PITFALLS.md prevents mistakes in roadmap/planning. For each pitfall:
742
+ - Warning signs (how to detect early)
743
+ - Prevention strategy (how to avoid)
744
+ - Which phase should address it
745
+ </downstream_consumer>
746
+
747
+ <quality_gate>
748
+ - [ ] Pitfalls are specific to this domain (not generic advice)
749
+ - [ ] Prevention strategies are actionable
750
+ - [ ] Phase mapping included where relevant
751
+ </quality_gate>
752
+
753
+ <output>
754
+ Write to: .planning/research/PITFALLS.md
755
+ Use template: .agent/mindforge/templates/research-project/PITFALLS.md
756
+ </output>
757
+ ", subagent_type="mindforge-project-researcher", model="{researcher_model}", description="Pitfalls research")
758
+ ```
759
+
760
+ After all 4 agents complete, spawn synthesizer to create SUMMARY.md:
761
+
762
+ ```
763
+ Task(prompt="
764
+ <task>
765
+ Synthesize research outputs into SUMMARY.md.
766
+ </task>
767
+
768
+ <files_to_read>
769
+ - .planning/research/STACK.md
770
+ - .planning/research/FEATURES.md
771
+ - .planning/research/ARCHITECTURE.md
772
+ - .planning/research/PITFALLS.md
773
+ </files_to_read>
774
+
775
+ <output>
776
+ Write to: .planning/research/SUMMARY.md
777
+ Use template: .agent/mindforge/templates/research-project/SUMMARY.md
778
+ Commit after writing.
779
+ </output>
780
+ ", subagent_type="mindforge-research-synthesizer", model="{synthesizer_model}", description="Synthesize research")
781
+ ```
782
+
783
+ Display research complete banner and key findings:
784
+
785
+ ```
786
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
787
+ MindForge ► RESEARCH COMPLETE ✓
788
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
789
+
790
+ ## Key Findings
791
+
792
+ **Stack:** [from SUMMARY.md]
793
+ **Table Stakes:** [from SUMMARY.md]
794
+ **Watch Out For:** [from SUMMARY.md]
795
+
796
+ Files: `.planning/research/`
797
+ ```
798
+
799
+ **If "Skip research":** Continue to Step 7.
800
+
801
+ ## 7. Define Requirements
802
+
803
+ Display stage banner:
804
+
805
+ ```
806
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
807
+ MindForge ► DEFINING REQUIREMENTS
808
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
809
+ ```
810
+
811
+ **Load context:**
812
+
813
+ Read PROJECT.md and extract:
814
+
815
+ - Core value (the ONE thing that must work)
816
+ - Stated constraints (budget, timeline, tech limitations)
817
+ - Any explicit scope boundaries
818
+
819
+ **If research exists:** Read research/FEATURES.md and extract feature categories.
820
+
821
+ **If auto mode:**
822
+
823
+ - Auto-include all table stakes features (users expect these)
824
+ - Include features explicitly mentioned in provided document
825
+ - Auto-defer differentiators not mentioned in document
826
+ - Skip per-category AskUserQuestion loops
827
+ - Skip "Any additions?" question
828
+ - Skip requirements approval gate
829
+ - Generate REQUIREMENTS.md and commit directly
830
+
831
+ **Present features by category (interactive mode only):**
832
+
833
+ ```
834
+ Here are the features for [domain]:
835
+
836
+ ## Authentication
837
+ **Table stakes:**
838
+ - Sign up with email/password
839
+ - Email verification
840
+ - Password reset
841
+ - Session management
842
+
843
+ **Differentiators:**
844
+ - Magic link login
845
+ - OAuth (Google, GitHub)
846
+ - 2FA
847
+
848
+ **Research notes:** [any relevant notes]
849
+
850
+ ---
851
+
852
+ ## [Next Category]
853
+ ...
854
+ ```
855
+
856
+ **If no research:** Gather requirements through conversation instead.
857
+
858
+ Ask: "What are the main things users need to be able to do?"
859
+
860
+ For each capability mentioned:
861
+
862
+ - Ask clarifying questions to make it specific
863
+ - Probe for related capabilities
864
+ - Group into categories
865
+
866
+ **Scope each category:**
867
+
868
+ For each category, use AskUserQuestion:
869
+
870
+ - header: "[Category]" (max 12 chars)
871
+ - question: "Which [category] features are in v1?"
872
+ - multiSelect: true
873
+ - options:
874
+ - "[Feature 1]" — [brief description]
875
+ - "[Feature 2]" — [brief description]
876
+ - "[Feature 3]" — [brief description]
877
+ - "None for v1" — Defer entire category
878
+
879
+ Track responses:
880
+
881
+ - Selected features → v1 requirements
882
+ - Unselected table stakes → v2 (users expect these)
883
+ - Unselected differentiators → out of scope
884
+
885
+ **Identify gaps:**
886
+
887
+ Use AskUserQuestion:
888
+
889
+ - header: "Additions"
890
+ - question: "Any requirements research missed? (Features specific to your vision)"
891
+ - options:
892
+ - "No, research covered it" — Proceed
893
+ - "Yes, let me add some" — Capture additions
894
+
895
+ **Validate core value:**
896
+
897
+ Cross-check requirements against Core Value from PROJECT.md. If gaps detected, surface them.
898
+
899
+ **Generate REQUIREMENTS.md:**
900
+
901
+ Create `.planning/REQUIREMENTS.md` with:
902
+
903
+ - v1 Requirements grouped by category (checkboxes, REQ-IDs)
904
+ - v2 Requirements (deferred)
905
+ - Out of Scope (explicit exclusions with reasoning)
906
+ - Traceability section (empty, filled by roadmap)
907
+
908
+ **REQ-ID format:** `[CATEGORY]-[NUMBER]` (AUTH-01, CONTENT-02)
909
+
910
+ **Requirement quality criteria:**
911
+
912
+ Good requirements are:
913
+
914
+ - **Specific and testable:** "User can reset password via email link" (not "Handle password reset")
915
+ - **User-centric:** "User can X" (not "System does Y")
916
+ - **Atomic:** One capability per requirement (not "User can login and manage profile")
917
+ - **Independent:** Minimal dependencies on other requirements
918
+
919
+ Reject vague requirements. Push for specificity:
920
+
921
+ - "Handle authentication" → "User can log in with email/password and stay logged in across sessions"
922
+ - "Support sharing" → "User can share post via link that opens in recipient's browser"
923
+
924
+ **Present full requirements list (interactive mode only):**
925
+
926
+ Show every requirement (not counts) for user confirmation:
927
+
928
+ ```
929
+ ## v1 Requirements
930
+
931
+ ### Authentication
932
+ - [ ] **AUTH-01**: User can create account with email/password
933
+ - [ ] **AUTH-02**: User can log in and stay logged in across sessions
934
+ - [ ] **AUTH-03**: User can log out from any page
935
+
936
+ ### Content
937
+ - [ ] **CONT-01**: User can create posts with text
938
+ - [ ] **CONT-02**: User can edit their own posts
939
+
940
+ [... full list ...]
941
+
942
+ ---
943
+
944
+ Does this capture what you're building? (yes / adjust)
945
+ ```
946
+
947
+ If "adjust": Return to scoping.
948
+
949
+ **Commit requirements:**
950
+
951
+ ```bash
952
+ node ".agent/bin/mindforge-tools.cjs" commit "docs: define v1 requirements" --files .planning/REQUIREMENTS.md
953
+ ```
954
+
955
+ ## 8. Create Roadmap
956
+
957
+ Display stage banner:
958
+
959
+ ```
960
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
961
+ MindForge ► CREATING ROADMAP
962
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
963
+
964
+ ◆ Spawning roadmapper...
965
+ ```
966
+
967
+ Spawn mindforge-roadmapper agent with path references:
968
+
969
+ ```
970
+ Task(prompt="
971
+ <planning_context>
972
+
973
+ <files_to_read>
974
+ - .planning/PROJECT.md (Project context)
975
+ - .planning/REQUIREMENTS.md (v1 Requirements)
976
+ - .planning/research/SUMMARY.md (Research findings - if exists)
977
+ - .planning/config.json (Granularity and mode settings)
978
+ </files_to_read>
979
+
980
+ </planning_context>
981
+
982
+ <instructions>
983
+ Create roadmap:
984
+ 1. Derive phases from requirements (don't impose structure)
985
+ 2. Map every v1 requirement to exactly one phase
986
+ 3. Derive 2-5 success criteria per phase (observable user behaviors)
987
+ 4. Validate 100% coverage
988
+ 5. Write files immediately (ROADMAP.md, STATE.md, update REQUIREMENTS.md traceability)
989
+ 6. Return ROADMAP CREATED with summary
990
+
991
+ Write files first, then return. This ensures artifacts persist even if context is lost.
992
+ </instructions>
993
+ ", subagent_type="mindforge-roadmapper", model="{roadmapper_model}", description="Create roadmap")
994
+ ```
995
+
996
+ **Handle roadmapper return:**
997
+
998
+ **If `## ROADMAP BLOCKED`:**
999
+
1000
+ - Present blocker information
1001
+ - Work with user to resolve
1002
+ - Re-spawn when resolved
1003
+
1004
+ **If `## ROADMAP CREATED`:**
1005
+
1006
+ Read the created ROADMAP.md and present it nicely inline:
1007
+
1008
+ ```
1009
+ ---
1010
+
1011
+ ## Proposed Roadmap
1012
+
1013
+ **[N] phases** | **[X] requirements mapped** | All v1 requirements covered ✓
1014
+
1015
+ | # | Phase | Goal | Requirements | Success Criteria |
1016
+ |---|-------|------|--------------|------------------|
1017
+ | 1 | [Name] | [Goal] | [REQ-IDs] | [count] |
1018
+ | 2 | [Name] | [Goal] | [REQ-IDs] | [count] |
1019
+ | 3 | [Name] | [Goal] | [REQ-IDs] | [count] |
1020
+ ...
1021
+
1022
+ ### Phase Details
1023
+
1024
+ **Phase 1: [Name]**
1025
+ Goal: [goal]
1026
+ Requirements: [REQ-IDs]
1027
+ Success criteria:
1028
+ 1. [criterion]
1029
+ 2. [criterion]
1030
+ 3. [criterion]
1031
+
1032
+ **Phase 2: [Name]**
1033
+ Goal: [goal]
1034
+ Requirements: [REQ-IDs]
1035
+ Success criteria:
1036
+ 1. [criterion]
1037
+ 2. [criterion]
1038
+
1039
+ [... continue for all phases ...]
1040
+
1041
+ ---
1042
+ ```
1043
+
1044
+ **If auto mode:** Skip approval gate — auto-approve and commit directly.
1045
+
1046
+ **CRITICAL: Ask for approval before committing (interactive mode only):**
1047
+
1048
+ Use AskUserQuestion:
1049
+
1050
+ - header: "Roadmap"
1051
+ - question: "Does this roadmap structure work for you?"
1052
+ - options:
1053
+ - "Approve" — Commit and continue
1054
+ - "Adjust phases" — Tell me what to change
1055
+ - "Review full file" — Show raw ROADMAP.md
1056
+
1057
+ **If "Approve":** Continue to commit.
1058
+
1059
+ **If "Adjust phases":**
1060
+
1061
+ - Get user's adjustment notes
1062
+ - Re-spawn roadmapper with revision context:
1063
+
1064
+ ```
1065
+ Task(prompt="
1066
+ <revision>
1067
+ User feedback on roadmap:
1068
+ [user's notes]
1069
+
1070
+ <files_to_read>
1071
+ - .planning/ROADMAP.md (Current roadmap to revise)
1072
+ </files_to_read>
1073
+
1074
+ Update the roadmap based on feedback. Edit files in place.
1075
+ Return ROADMAP REVISED with changes made.
1076
+ </revision>
1077
+ ", subagent_type="mindforge-roadmapper", model="{roadmapper_model}", description="Revise roadmap")
1078
+ ```
1079
+
1080
+ - Present revised roadmap
1081
+ - Loop until user approves
1082
+
1083
+ **If "Review full file":** Display raw `cat .planning/ROADMAP.md`, then re-ask.
1084
+
1085
+ **Generate or refresh project GEMINI.md before final commit:**
1086
+
1087
+ ```bash
1088
+ node ".agent/bin/mindforge-tools.cjs" generate-claude-md
1089
+ ```
1090
+
1091
+ This ensures new projects get the default MindForge workflow-enforcement guidance and current project context in `GEMINI.md`.
1092
+
1093
+ **Commit roadmap (after approval or auto mode):**
1094
+
1095
+ ```bash
1096
+ node ".agent/bin/mindforge-tools.cjs" commit "docs: create roadmap ([N] phases)" --files .planning/ROADMAP.md .planning/STATE.md .planning/REQUIREMENTS.md GEMINI.md
1097
+ ```
1098
+
1099
+ ## 9. Done
1100
+
1101
+ Present completion summary:
1102
+
1103
+ ```
1104
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
1105
+ MindForge ► PROJECT INITIALIZED ✓
1106
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
1107
+
1108
+ **[Project Name]**
1109
+
1110
+ | Artifact | Location |
1111
+ |----------------|-----------------------------|
1112
+ | Project | `.planning/PROJECT.md` |
1113
+ | Config | `.planning/config.json` |
1114
+ | Research | `.planning/research/` |
1115
+ | Requirements | `.planning/REQUIREMENTS.md` |
1116
+ | Roadmap | `.planning/ROADMAP.md` |
1117
+ | Project guide | `GEMINI.md` |
1118
+
1119
+ **[N] phases** | **[X] requirements** | Ready to build ✓
1120
+ ```
1121
+
1122
+ **If auto mode:**
1123
+
1124
+ ```
1125
+ ╔══════════════════════════════════════════╗
1126
+ ║ AUTO-ADVANCING → DISCUSS PHASE 1 ║
1127
+ ╚══════════════════════════════════════════╝
1128
+ ```
1129
+
1130
+ Exit skill and invoke SlashCommand("/mindforge-discuss-phase 1 --auto")
1131
+
1132
+ **If interactive mode:**
1133
+
1134
+ Check if Phase 1 has UI indicators (look for `**UI hint**: yes` in Phase 1 detail section of ROADMAP.md):
1135
+
1136
+ ```bash
1137
+ PHASE1_SECTION=$(node ".agent/bin/mindforge-tools.cjs" roadmap get-phase 1 2>/dev/null)
1138
+ PHASE1_HAS_UI=$(echo "$PHASE1_SECTION" | grep -qi "UI hint.*yes" && echo "true" || echo "false")
1139
+ ```
1140
+
1141
+ **If Phase 1 has UI (`PHASE1_HAS_UI` is `true`):**
1142
+
1143
+ ```
1144
+ ───────────────────────────────────────────────────────────────
1145
+
1146
+ ## ▶ Next Up
1147
+
1148
+ **Phase 1: [Phase Name]** — [Goal from ROADMAP.md]
1149
+
1150
+ /mindforge-discuss-phase 1 — gather context and clarify approach
1151
+
1152
+ <sub>/clear first → fresh context window</sub>
1153
+
1154
+ ---
1155
+
1156
+ **Also available:**
1157
+ - /mindforge-ui-phase 1 — generate UI design contract (recommended for frontend phases)
1158
+ - /mindforge-plan-phase 1 — skip discussion, plan directly
1159
+
1160
+ ───────────────────────────────────────────────────────────────
1161
+ ```
1162
+
1163
+ **If Phase 1 has no UI:**
1164
+
1165
+ ```
1166
+ ───────────────────────────────────────────────────────────────
1167
+
1168
+ ## ▶ Next Up
1169
+
1170
+ **Phase 1: [Phase Name]** — [Goal from ROADMAP.md]
1171
+
1172
+ /mindforge-discuss-phase 1 — gather context and clarify approach
1173
+
1174
+ <sub>/clear first → fresh context window</sub>
1175
+
1176
+ ---
1177
+
1178
+ **Also available:**
1179
+ - /mindforge-plan-phase 1 — skip discussion, plan directly
1180
+
1181
+ ───────────────────────────────────────────────────────────────
1182
+ ```
1183
+
1184
+ </process>
1185
+
1186
+ <output>
1187
+
1188
+ - `.planning/PROJECT.md`
1189
+ - `.planning/config.json`
1190
+ - `.planning/research/` (if research selected)
1191
+ - `STACK.md`
1192
+ - `FEATURES.md`
1193
+ - `ARCHITECTURE.md`
1194
+ - `PITFALLS.md`
1195
+ - `SUMMARY.md`
1196
+ - `.planning/REQUIREMENTS.md`
1197
+ - `.planning/ROADMAP.md`
1198
+ - `.planning/STATE.md`
1199
+ - `GEMINI.md`
1200
+
1201
+ </output>
1202
+
1203
+ <success_criteria>
1204
+
1205
+ - [ ] .planning/ directory created
1206
+ - [ ] Git repo initialized
1207
+ - [ ] Brownfield detection completed
1208
+ - [ ] Deep questioning completed (threads followed, not rushed)
1209
+ - [ ] PROJECT.md captures full context → **committed**
1210
+ - [ ] config.json has workflow mode, granularity, parallelization → **committed**
1211
+ - [ ] Research completed (if selected) — 4 parallel agents spawned → **committed**
1212
+ - [ ] Requirements gathered (from research or conversation)
1213
+ - [ ] User scoped each category (v1/v2/out of scope)
1214
+ - [ ] REQUIREMENTS.md created with REQ-IDs → **committed**
1215
+ - [ ] mindforge-roadmapper spawned with context
1216
+ - [ ] Roadmap files written immediately (not draft)
1217
+ - [ ] User feedback incorporated (if any)
1218
+ - [ ] ROADMAP.md created with phases, requirement mappings, success criteria
1219
+ - [ ] STATE.md initialized
1220
+ - [ ] REQUIREMENTS.md traceability updated
1221
+ - [ ] GEMINI.md generated with MindForge workflow guidance
1222
+ - [ ] User knows next step is `/mindforge-discuss-phase 1`
1223
+
1224
+ **Atomic commits:** Each phase commits its artifacts immediately. If context is lost, artifacts persist.
1225
+
1226
+ </success_criteria>