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,645 @@
1
+ <purpose>
2
+ Extract implementation decisions that downstream agents need — using codebase-first analysis
3
+ and assumption surfacing instead of interview-style questioning.
4
+
5
+ You are a thinking partner, not an interviewer. Analyze the codebase deeply, surface what you
6
+ believe based on evidence, and ask the user only to correct what's wrong.
7
+ </purpose>
8
+
9
+ <downstream_awareness>
10
+ **CONTEXT.md feeds into:**
11
+
12
+ 1. **mindforge-phase-researcher** — Reads CONTEXT.md to know WHAT to research
13
+ 2. **mindforge-planner** — Reads CONTEXT.md to know WHAT decisions are locked
14
+
15
+ **Your job:** Capture decisions clearly enough that downstream agents can act on them
16
+ without asking the user again. Output is identical to discuss mode — same CONTEXT.md format.
17
+ </downstream_awareness>
18
+
19
+ <philosophy>
20
+ **Assumptions mode philosophy:**
21
+
22
+ The user is a visionary, not a codebase archaeologist. They need enough context to evaluate
23
+ whether your assumptions match their intent — not to answer questions you could figure out
24
+ by reading the code.
25
+
26
+ - Read the codebase FIRST, form opinions SECOND, ask ONLY about what's genuinely unclear
27
+ - Every assumption must cite evidence (file paths, patterns found)
28
+ - Every assumption must state consequences if wrong
29
+ - Minimize user interactions: ~2-4 corrections vs ~15-20 questions
30
+ </philosophy>
31
+
32
+ <scope_guardrail>
33
+ **CRITICAL: No scope creep.**
34
+
35
+ The phase boundary comes from ROADMAP.md and is FIXED. Discussion clarifies HOW to implement
36
+ what's scoped, never WHETHER to add new capabilities.
37
+
38
+ When user suggests scope creep:
39
+ "[Feature X] would be a new capability — that's its own phase.
40
+ Want me to note it for the roadmap backlog? For now, let's focus on [phase domain]."
41
+
42
+ Capture the idea in "Deferred Ideas". Don't lose it, don't act on it.
43
+ </scope_guardrail>
44
+
45
+ <answer_validation>
46
+ **IMPORTANT: Answer validation** — After every AskUserQuestion call, check if the response
47
+ is empty or whitespace-only. If so:
48
+ 1. Retry the question once with the same parameters
49
+ 2. If still empty, present the options as a plain-text numbered list
50
+
51
+ **Text mode (`workflow.text_mode: true` in config or `--text` flag):**
52
+ When text mode is active, do not use AskUserQuestion at all. Present every question as a
53
+ plain-text numbered list and ask the user to type their choice number.
54
+ </answer_validation>
55
+
56
+ <process>
57
+
58
+ <step name="initialize" priority="first">
59
+ Phase number from argument (required).
60
+
61
+ ```bash
62
+ INIT=$(node ".agent/bin/mindforge-tools.cjs" init phase-op "${PHASE}")
63
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
64
+ ```
65
+
66
+ Parse JSON for: `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`,
67
+ `phase_slug`, `padded_phase`, `has_research`, `has_context`, `has_plans`, `has_verification`,
68
+ `plan_count`, `roadmap_exists`, `planning_exists`.
69
+
70
+ **If `phase_found` is false:**
71
+ ```
72
+ Phase [X] not found in roadmap.
73
+
74
+ Use /mindforge-progress to see available phases.
75
+ ```
76
+ Exit workflow.
77
+
78
+ **If `phase_found` is true:** Continue to check_existing.
79
+
80
+ **Auto mode** — If `--auto` is present in ARGUMENTS:
81
+ - In `check_existing`: auto-select "Update it" (if context exists) or continue without prompting
82
+ - In `present_assumptions`: skip confirmation gate, proceed directly to write CONTEXT.md
83
+ - In `correct_assumptions`: auto-select recommended option for each correction
84
+ - Log each auto-selected choice inline
85
+ - After completion, auto-advance to plan-phase
86
+ </step>
87
+
88
+ <step name="check_existing">
89
+ Check if CONTEXT.md already exists using `has_context` from init.
90
+
91
+ ```bash
92
+ ls ${phase_dir}/*-CONTEXT.md 2>/dev/null
93
+ ```
94
+
95
+ **If exists:**
96
+
97
+ **If `--auto`:** Auto-select "Update it". Log: `[auto] Context exists — updating with assumption-based analysis.`
98
+
99
+ **Otherwise:** Use AskUserQuestion:
100
+ - header: "Context"
101
+ - question: "Phase [X] already has context. What do you want to do?"
102
+ - options:
103
+ - "Update it" — Re-analyze codebase and refresh assumptions
104
+ - "View it" — Show me what's there
105
+ - "Skip" — Use existing context as-is
106
+
107
+ If "Update": Load existing, continue to load_prior_context
108
+ If "View": Display CONTEXT.md, then offer update/skip
109
+ If "Skip": Exit workflow
110
+
111
+ **If doesn't exist:**
112
+
113
+ Check `has_plans` and `plan_count` from init. **If `has_plans` is true:**
114
+
115
+ **If `--auto`:** Auto-select "Continue and replan after". Log: `[auto] Plans exist — continuing with assumption analysis, will replan after.`
116
+
117
+ **Otherwise:** Use AskUserQuestion:
118
+ - header: "Plans exist"
119
+ - question: "Phase [X] already has {plan_count} plan(s) created without user context. Your decisions here won't affect existing plans unless you replan."
120
+ - options:
121
+ - "Continue and replan after"
122
+ - "View existing plans"
123
+ - "Cancel"
124
+
125
+ If "Continue and replan after": Continue to load_prior_context.
126
+ If "View existing plans": Display plan files, then offer "Continue" / "Cancel".
127
+ If "Cancel": Exit workflow.
128
+
129
+ **If `has_plans` is false:** Continue to load_prior_context.
130
+ </step>
131
+
132
+ <step name="load_prior_context">
133
+ Read project-level and prior phase context to avoid re-asking decided questions.
134
+
135
+ **Step 1: Read project-level files**
136
+ ```bash
137
+ cat .planning/PROJECT.md 2>/dev/null
138
+ cat .planning/REQUIREMENTS.md 2>/dev/null
139
+ cat .planning/STATE.md 2>/dev/null
140
+ ```
141
+
142
+ Extract from these:
143
+ - **PROJECT.md** — Vision, principles, non-negotiables, user preferences
144
+ - **REQUIREMENTS.md** — Acceptance criteria, constraints
145
+ - **STATE.md** — Current progress, any flags
146
+
147
+ **Step 2: Read all prior CONTEXT.md files**
148
+ ```bash
149
+ find .planning/phases -name "*-CONTEXT.md" 2>/dev/null | sort
150
+ ```
151
+
152
+ For each CONTEXT.md where phase number < current phase:
153
+ - Read the `<decisions>` section — these are locked preferences
154
+ - Read `<specifics>` — particular references or "I want it like X" moments
155
+ - Note patterns (e.g., "user consistently prefers minimal UI")
156
+
157
+ **Step 3: Build internal `<prior_decisions>` context**
158
+
159
+ Structure the extracted information for use in assumption generation.
160
+
161
+ **If no prior context exists:** Continue without — expected for early phases.
162
+ </step>
163
+
164
+ <step name="cross_reference_todos">
165
+ Check if any pending todos are relevant to this phase's scope.
166
+
167
+ ```bash
168
+ TODO_MATCHES=$(node ".agent/bin/mindforge-tools.cjs" todo match-phase "${PHASE_NUMBER}")
169
+ ```
170
+
171
+ Parse JSON for: `todo_count`, `matches[]`.
172
+
173
+ **If `todo_count` is 0:** Skip silently.
174
+
175
+ **If matches found:** Present matched todos, use AskUserQuestion (multiSelect) to fold relevant ones into scope.
176
+
177
+ **For selected (folded) todos:** Store as `<folded_todos>` for CONTEXT.md `<decisions>` section.
178
+ **For unselected:** Store as `<reviewed_todos>` for CONTEXT.md `<deferred>` section.
179
+
180
+ **Auto mode (`--auto`):** Fold all todos with score >= 0.4 automatically. Log the selection.
181
+ </step>
182
+
183
+ <step name="scout_codebase">
184
+ Lightweight scan of existing code to inform assumption generation.
185
+
186
+ **Step 1: Check for existing codebase maps**
187
+ ```bash
188
+ ls .planning/codebase/*.md 2>/dev/null
189
+ ```
190
+
191
+ **If codebase maps exist:** Read relevant ones (CONVENTIONS.md, STRUCTURE.md, STACK.md). Extract reusable components, patterns, integration points. Skip to Step 3.
192
+
193
+ **Step 2: If no codebase maps, do targeted grep**
194
+
195
+ Extract key terms from phase goal, search for related files.
196
+
197
+ ```bash
198
+ grep -rl "{term1}\|{term2}" src/ app/ --include="*.ts" --include="*.tsx" 2>/dev/null | head -10
199
+ ```
200
+
201
+ Read the 3-5 most relevant files.
202
+
203
+ **Step 3: Build internal `<codebase_context>`**
204
+
205
+ Identify reusable assets, established patterns, integration points, and creative options. Store internally for use in deep_codebase_analysis.
206
+ </step>
207
+
208
+ <step name="deep_codebase_analysis">
209
+ Spawn a `mindforge-assumptions-analyzer` agent to deeply analyze the codebase for this phase. This
210
+ keeps raw file contents out of the main context window, protecting token budget.
211
+
212
+ **Resolve calibration tier (if USER-PROFILE.md exists):**
213
+
214
+ ```bash
215
+ PROFILE_PATH=".agent/mindforge/USER-PROFILE.md"
216
+ ```
217
+
218
+ If file exists at PROFILE_PATH:
219
+ - Priority 1: Read config.json > preferences.vendor_philosophy (project-level override)
220
+ - Priority 2: Read USER-PROFILE.md Vendor Choices/Philosophy rating (global)
221
+ - Priority 3: Default to "standard"
222
+
223
+ Map to calibration tier:
224
+ - conservative OR thorough-evaluator → full_maturity (more alternatives, detailed evidence)
225
+ - opinionated → minimal_decisive (fewer alternatives, decisive recommendations)
226
+ - pragmatic-fast OR any other value → standard
227
+
228
+ If no USER-PROFILE.md: calibration_tier = "standard"
229
+
230
+ **Spawn Explore subagent:**
231
+
232
+ ```
233
+ Task(subagent_type="mindforge-assumptions-analyzer", prompt="""
234
+ Analyze the codebase for Phase {PHASE}: {phase_name}.
235
+
236
+ Phase goal: {roadmap_description}
237
+ Prior decisions: {prior_decisions_summary}
238
+ Codebase scout hints: {codebase_context_summary}
239
+ Calibration: {calibration_tier}
240
+
241
+ Your job:
242
+ 1. Read ROADMAP.md phase {PHASE} description
243
+ 2. Read any prior CONTEXT.md files from earlier phases
244
+ 3. Glob/Grep for files related to: {phase_relevant_terms}
245
+ 4. Read 5-15 most relevant source files
246
+ 5. Return structured assumptions
247
+
248
+ ## Output Format
249
+
250
+ Return EXACTLY this structure:
251
+
252
+ ## Assumptions
253
+
254
+ ### [Area Name] (e.g., "Technical Approach")
255
+ - **Assumption:** [Decision statement]
256
+ - **Why this way:** [Evidence from codebase — cite file paths]
257
+ - **If wrong:** [Concrete consequence of this being wrong]
258
+ - **Confidence:** Confident | Likely | Unclear
259
+
260
+ (3-5 areas, calibrated by tier:
261
+ - full_maturity: 3-5 areas, 2-3 alternatives per Likely/Unclear item
262
+ - standard: 3-4 areas, 2 alternatives per Likely/Unclear item
263
+ - minimal_decisive: 2-3 areas, decisive single recommendation per item)
264
+
265
+ ## Needs External Research
266
+ [Topics where codebase alone is insufficient — library version compatibility,
267
+ ecosystem best practices, etc. Leave empty if codebase provides enough evidence.]
268
+ """)
269
+ ```
270
+
271
+ Parse the subagent's response. Extract:
272
+ - `assumptions[]` — each with area, statement, evidence, consequence, confidence
273
+ - `needs_research[]` — topics requiring external research (may be empty)
274
+
275
+ **Initialize canonical refs accumulator:**
276
+ - Source 1: Copy `Canonical refs:` from ROADMAP.md for this phase, expand to full paths
277
+ - Source 2: Check REQUIREMENTS.md and PROJECT.md for specs/ADRs referenced
278
+ - Source 3: Add any docs referenced in codebase scout results
279
+ </step>
280
+
281
+ <step name="external_research">
282
+ **Skip if:** `needs_research` from deep_codebase_analysis is empty.
283
+
284
+ If research topics were flagged, spawn a general-purpose research agent:
285
+
286
+ ```
287
+ Task(subagent_type="general-purpose", prompt="""
288
+ Research the following topics for Phase {PHASE}: {phase_name}.
289
+
290
+ Topics needing research:
291
+ {needs_research_content}
292
+
293
+ For each topic, return:
294
+ - **Finding:** [What you learned]
295
+ - **Source:** [URL or library docs reference]
296
+ - **Confidence impact:** [Which assumption this resolves and to what confidence level]
297
+
298
+ Use Context7 (resolve-library-id then query-docs) for library-specific questions.
299
+ Use WebSearch for ecosystem/best-practice questions.
300
+ """)
301
+ ```
302
+
303
+ Merge findings back into assumptions:
304
+ - Update confidence levels where research resolves ambiguity
305
+ - Add source attribution to affected assumptions
306
+ - Store research findings for DISCUSSION-LOG.md
307
+
308
+ **If no gaps flagged:** Skip entirely. Most phases will skip this step.
309
+ </step>
310
+
311
+ <step name="present_assumptions">
312
+ Display all assumptions grouped by area with confidence badges.
313
+
314
+ **Format for display:**
315
+
316
+ ```
317
+ ## Phase {PHASE}: {phase_name} — Assumptions
318
+
319
+ Based on codebase analysis, here's what I'd go with:
320
+
321
+ ### {Area Name}
322
+ {Confidence badge} **{Assumption statement}**
323
+ ↳ Evidence: {file paths cited}
324
+ ↳ If wrong: {consequence}
325
+
326
+ ### {Area Name 2}
327
+ ...
328
+
329
+ [If external research was done:]
330
+ ### External Research Applied
331
+ - {Topic}: {Finding} (Source: {URL})
332
+ ```
333
+
334
+ **If `--auto`:**
335
+ - If all assumptions are Confident or Likely: log assumptions, skip to write_context.
336
+ Log: `[auto] All assumptions Confident/Likely — proceeding to context capture.`
337
+ - If any assumptions are Unclear: log a warning, auto-select recommended alternative for
338
+ each Unclear item. Log: `[auto] {N} Unclear assumptions auto-resolved with recommended defaults.`
339
+ Proceed to write_context.
340
+
341
+ **Otherwise:** Use AskUserQuestion:
342
+ - header: "Assumptions"
343
+ - question: "These all look right?"
344
+ - options:
345
+ - "Yes, proceed" — Write CONTEXT.md with these assumptions as decisions
346
+ - "Let me correct some" — Select which assumptions to change
347
+
348
+ **If "Yes, proceed":** Skip to write_context.
349
+ **If "Let me correct some":** Continue to correct_assumptions.
350
+ </step>
351
+
352
+ <step name="correct_assumptions">
353
+ The assumptions are already displayed above from present_assumptions.
354
+
355
+ Present a multiSelect where each option's label is the assumption statement and description
356
+ is the "If wrong" consequence:
357
+
358
+ Use AskUserQuestion (multiSelect):
359
+ - header: "Corrections"
360
+ - question: "Which assumptions need correcting?"
361
+ - options: [one per assumption, label = assumption statement, description = "If wrong: {consequence}"]
362
+
363
+ For each selected correction, ask ONE focused question:
364
+
365
+ Use AskUserQuestion:
366
+ - header: "{Area Name}"
367
+ - question: "What should we do instead for: {assumption statement}?"
368
+ - options: [2-3 concrete alternatives describing user-visible outcomes, recommended option first]
369
+
370
+ Record each correction:
371
+ - Original assumption
372
+ - User's chosen alternative
373
+ - Reason (if provided via "Other" free text)
374
+
375
+ After all corrections processed, continue to write_context with updated assumptions.
376
+
377
+ **Auto mode:** Should not reach this step (--auto skips from present_assumptions).
378
+ </step>
379
+
380
+ <step name="write_context">
381
+ Create phase directory if needed. Write CONTEXT.md using the standard 6-section format.
382
+
383
+ **File:** `${phase_dir}/${padded_phase}-CONTEXT.md`
384
+
385
+ Map assumptions to CONTEXT.md sections:
386
+ - Assumptions → `<decisions>` (each assumption becomes a locked decision: D-01, D-02, etc.)
387
+ - Corrections → override the original assumption in `<decisions>`
388
+ - Areas where all assumptions were Confident → marked as locked decisions
389
+ - Areas with corrections → include user's chosen alternative as the decision
390
+ - Folded todos → included in `<decisions>` under "### Folded Todos"
391
+
392
+ ```markdown
393
+ # Phase {PHASE}: {phase_name} - Context
394
+
395
+ **Gathered:** {date} (assumptions mode)
396
+ **Status:** Ready for planning
397
+
398
+ <domain>
399
+ ## Phase Boundary
400
+
401
+ {Domain boundary from ROADMAP.md — clear statement of scope anchor}
402
+ </domain>
403
+
404
+ <decisions>
405
+ ## Implementation Decisions
406
+
407
+ ### {Area Name 1}
408
+ - **D-01:** {Decision — from assumption or correction}
409
+ - **D-02:** {Decision}
410
+
411
+ ### {Area Name 2}
412
+ - **D-03:** {Decision}
413
+
414
+ ### the agent's Discretion
415
+ {Any assumptions where the user confirmed "you decide" or left as-is with Likely confidence}
416
+
417
+ ### Folded Todos
418
+ {If any todos were folded into scope}
419
+ </decisions>
420
+
421
+ <canonical_refs>
422
+ ## Canonical References
423
+
424
+ **Downstream agents MUST read these before planning or implementing.**
425
+
426
+ {Accumulated canonical refs from analyze step — full relative paths}
427
+
428
+ [If no external specs: "No external specs — requirements fully captured in decisions above"]
429
+ </canonical_refs>
430
+
431
+ <code_context>
432
+ ## Existing Code Insights
433
+
434
+ ### Reusable Assets
435
+ {From codebase scout + Explore subagent findings}
436
+
437
+ ### Established Patterns
438
+ {Patterns that constrain/enable this phase}
439
+
440
+ ### Integration Points
441
+ {Where new code connects to existing system}
442
+ </code_context>
443
+
444
+ <specifics>
445
+ ## Specific Ideas
446
+
447
+ {Any particular references from corrections or user input}
448
+
449
+ [If none: "No specific requirements — open to standard approaches"]
450
+ </specifics>
451
+
452
+ <deferred>
453
+ ## Deferred Ideas
454
+
455
+ {Ideas mentioned during corrections that are out of scope}
456
+
457
+ ### Reviewed Todos (not folded)
458
+ {Todos reviewed but not folded — with reason}
459
+
460
+ [If none: "None — analysis stayed within phase scope"]
461
+ </deferred>
462
+ ```
463
+
464
+ Write file.
465
+ </step>
466
+
467
+ <step name="write_discussion_log">
468
+ Write audit trail of assumptions and corrections.
469
+
470
+ **File:** `${phase_dir}/${padded_phase}-DISCUSSION-LOG.md`
471
+
472
+ ```markdown
473
+ # Phase {PHASE}: {phase_name} - Discussion Log (Assumptions Mode)
474
+
475
+ > **Audit trail only.** Do not use as input to planning, research, or execution agents.
476
+ > Decisions captured in CONTEXT.md — this log preserves the analysis.
477
+
478
+ **Date:** {ISO date}
479
+ **Phase:** {padded_phase}-{phase_name}
480
+ **Mode:** assumptions
481
+ **Areas analyzed:** {comma-separated area names}
482
+
483
+ ## Assumptions Presented
484
+
485
+ ### {Area Name}
486
+ | Assumption | Confidence | Evidence |
487
+ |------------|-----------|----------|
488
+ | {Statement} | {Confident/Likely/Unclear} | {file paths} |
489
+
490
+ {Repeat for each area}
491
+
492
+ ## Corrections Made
493
+
494
+ {If corrections were made:}
495
+
496
+ ### {Area Name}
497
+ - **Original assumption:** {what the agent assumed}
498
+ - **User correction:** {what the user chose instead}
499
+ - **Reason:** {user's rationale, if provided}
500
+
501
+ {If no corrections: "No corrections — all assumptions confirmed."}
502
+
503
+ ## Auto-Resolved
504
+
505
+ {If --auto and Unclear items existed:}
506
+ - {Assumption}: auto-selected {recommended option}
507
+
508
+ {If not applicable: omit this section}
509
+
510
+ ## External Research
511
+
512
+ {If research was performed:}
513
+ - {Topic}: {Finding} (Source: {URL})
514
+
515
+ {If no research: omit this section}
516
+ ```
517
+
518
+ Write file.
519
+ </step>
520
+
521
+ <step name="git_commit">
522
+ Commit phase context and discussion log:
523
+
524
+ ```bash
525
+ node ".agent/bin/mindforge-tools.cjs" commit "docs(${padded_phase}): capture phase context (assumptions mode)" --files "${phase_dir}/${padded_phase}-CONTEXT.md" "${phase_dir}/${padded_phase}-DISCUSSION-LOG.md"
526
+ ```
527
+
528
+ Confirm: "Committed: docs(${padded_phase}): capture phase context (assumptions mode)"
529
+ </step>
530
+
531
+ <step name="update_state">
532
+ Update STATE.md with session info:
533
+
534
+ ```bash
535
+ node ".agent/bin/mindforge-tools.cjs" state record-session \
536
+ --stopped-at "Phase ${PHASE} context gathered (assumptions mode)" \
537
+ --resume-file "${phase_dir}/${padded_phase}-CONTEXT.md"
538
+ ```
539
+
540
+ Commit STATE.md:
541
+
542
+ ```bash
543
+ node ".agent/bin/mindforge-tools.cjs" commit "docs(state): record phase ${PHASE} context session" --files .planning/STATE.md
544
+ ```
545
+ </step>
546
+
547
+ <step name="confirm_creation">
548
+ Present summary and next steps:
549
+
550
+ ```
551
+ Created: .planning/phases/${PADDED_PHASE}-${SLUG}/${PADDED_PHASE}-CONTEXT.md
552
+
553
+ ## Decisions Captured (Assumptions Mode)
554
+
555
+ ### {Area Name}
556
+ - {Key decision} (from assumption / corrected)
557
+
558
+ {Repeat per area}
559
+
560
+ [If corrections were made:]
561
+ ## Corrections Applied
562
+ - {Area}: {original} → {corrected}
563
+
564
+ [If deferred ideas exist:]
565
+ ## Noted for Later
566
+ - {Deferred idea} — future phase
567
+
568
+ ---
569
+
570
+ ## ▶ Next Up
571
+
572
+ **Phase ${PHASE}: {phase_name}** — {Goal from ROADMAP.md}
573
+
574
+ `/mindforge-plan-phase ${PHASE}`
575
+
576
+ <sub>`/clear` first → fresh context window</sub>
577
+
578
+ ---
579
+
580
+ **Also available:**
581
+ - `/mindforge-plan-phase ${PHASE} --skip-research` — plan without research
582
+ - `/mindforge-ui-phase ${PHASE}` — generate UI design contract (if frontend work)
583
+ - Review/edit CONTEXT.md before continuing
584
+
585
+ ---
586
+ ```
587
+ </step>
588
+
589
+ <step name="auto_advance">
590
+ Check for auto-advance trigger:
591
+
592
+ 1. Parse `--auto` flag from $ARGUMENTS
593
+ 2. Sync chain flag:
594
+ ```bash
595
+ if [[ ! "$ARGUMENTS" =~ --auto ]]; then
596
+ node ".agent/bin/mindforge-tools.cjs" config-set workflow._auto_chain_active false 2>/dev/null
597
+ fi
598
+ ```
599
+ 3. Read chain flag and user preference:
600
+ ```bash
601
+ AUTO_CHAIN=$(node ".agent/bin/mindforge-tools.cjs" config-get workflow._auto_chain_active 2>/dev/null || echo "false")
602
+ AUTO_CFG=$(node ".agent/bin/mindforge-tools.cjs" config-get workflow.auto_advance 2>/dev/null || echo "false")
603
+ ```
604
+
605
+ **If `--auto` flag present AND `AUTO_CHAIN` is not true:**
606
+ ```bash
607
+ node ".agent/bin/mindforge-tools.cjs" config-set workflow._auto_chain_active true
608
+ ```
609
+
610
+ **If `--auto` flag present OR `AUTO_CHAIN` is true OR `AUTO_CFG` is true:**
611
+
612
+ Display banner:
613
+ ```
614
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
615
+ MindForge ► AUTO-ADVANCING TO PLAN
616
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
617
+
618
+ Context captured (assumptions mode). Launching plan-phase...
619
+ ```
620
+
621
+ Launch: `Skill(skill="mindforge-plan-phase", args="${PHASE} --auto")`
622
+
623
+ Handle return: PHASE COMPLETE / PLANNING COMPLETE / INCONCLUSIVE / GAPS FOUND
624
+ (identical handling to discuss-phase.md auto_advance step)
625
+
626
+ **If neither `--auto` nor config enabled:**
627
+ Route to confirm_creation step.
628
+ </step>
629
+
630
+ </process>
631
+
632
+ <success_criteria>
633
+ - Phase validated against roadmap
634
+ - Prior context loaded (no re-asking decided questions)
635
+ - Codebase deeply analyzed via Explore subagent (5-15 files read)
636
+ - Assumptions surfaced with evidence and confidence levels
637
+ - User confirmed or corrected assumptions (~2-4 interactions max)
638
+ - Scope creep redirected to deferred ideas
639
+ - CONTEXT.md captures actual decisions (identical format to discuss mode)
640
+ - CONTEXT.md includes canonical_refs with full file paths (MANDATORY)
641
+ - CONTEXT.md includes code_context from codebase analysis
642
+ - DISCUSSION-LOG.md records assumptions and corrections as audit trail
643
+ - STATE.md updated with session info
644
+ - User knows next steps
645
+ </success_criteria>