@mindfoldhq/trellis 0.4.0 → 0.5.0-beta.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 (394) hide show
  1. package/dist/cli/index.js +0 -1
  2. package/dist/cli/index.js.map +1 -1
  3. package/dist/commands/init.d.ts +0 -1
  4. package/dist/commands/init.d.ts.map +1 -1
  5. package/dist/commands/init.js +2 -4
  6. package/dist/commands/init.js.map +1 -1
  7. package/dist/commands/update.d.ts +5 -0
  8. package/dist/commands/update.d.ts.map +1 -1
  9. package/dist/commands/update.js +100 -24
  10. package/dist/commands/update.js.map +1 -1
  11. package/dist/configurators/antigravity.d.ts +3 -4
  12. package/dist/configurators/antigravity.d.ts.map +1 -1
  13. package/dist/configurators/antigravity.js +17 -10
  14. package/dist/configurators/antigravity.js.map +1 -1
  15. package/dist/configurators/claude.d.ts +5 -28
  16. package/dist/configurators/claude.d.ts.map +1 -1
  17. package/dist/configurators/claude.js +30 -51
  18. package/dist/configurators/claude.js.map +1 -1
  19. package/dist/configurators/codebuddy.d.ts +6 -7
  20. package/dist/configurators/codebuddy.d.ts.map +1 -1
  21. package/dist/configurators/codebuddy.js +23 -51
  22. package/dist/configurators/codebuddy.js.map +1 -1
  23. package/dist/configurators/codex.d.ts +3 -6
  24. package/dist/configurators/codex.d.ts.map +1 -1
  25. package/dist/configurators/codex.js +29 -12
  26. package/dist/configurators/codex.js.map +1 -1
  27. package/dist/configurators/copilot.d.ts +6 -5
  28. package/dist/configurators/copilot.d.ts.map +1 -1
  29. package/dist/configurators/copilot.js +42 -13
  30. package/dist/configurators/copilot.js.map +1 -1
  31. package/dist/configurators/cursor.d.ts +6 -1
  32. package/dist/configurators/cursor.d.ts.map +1 -1
  33. package/dist/configurators/cursor.js +22 -45
  34. package/dist/configurators/cursor.js.map +1 -1
  35. package/dist/configurators/droid.d.ts +6 -1
  36. package/dist/configurators/droid.d.ts.map +1 -1
  37. package/dist/configurators/droid.js +23 -41
  38. package/dist/configurators/droid.js.map +1 -1
  39. package/dist/configurators/gemini.d.ts +8 -4
  40. package/dist/configurators/gemini.d.ts.map +1 -1
  41. package/dist/configurators/gemini.js +28 -47
  42. package/dist/configurators/gemini.js.map +1 -1
  43. package/dist/configurators/index.d.ts +1 -1
  44. package/dist/configurators/index.d.ts.map +1 -1
  45. package/dist/configurators/index.js +142 -98
  46. package/dist/configurators/index.js.map +1 -1
  47. package/dist/configurators/kilo.d.ts +3 -4
  48. package/dist/configurators/kilo.d.ts.map +1 -1
  49. package/dist/configurators/kilo.js +19 -46
  50. package/dist/configurators/kilo.js.map +1 -1
  51. package/dist/configurators/kiro.d.ts +4 -4
  52. package/dist/configurators/kiro.d.ts.map +1 -1
  53. package/dist/configurators/kiro.js +18 -14
  54. package/dist/configurators/kiro.js.map +1 -1
  55. package/dist/configurators/opencode.d.ts +3 -28
  56. package/dist/configurators/opencode.d.ts.map +1 -1
  57. package/dist/configurators/opencode.js +23 -48
  58. package/dist/configurators/opencode.js.map +1 -1
  59. package/dist/configurators/qoder.d.ts +6 -4
  60. package/dist/configurators/qoder.d.ts.map +1 -1
  61. package/dist/configurators/qoder.js +20 -47
  62. package/dist/configurators/qoder.js.map +1 -1
  63. package/dist/configurators/shared.d.ts +66 -3
  64. package/dist/configurators/shared.d.ts.map +1 -1
  65. package/dist/configurators/shared.js +251 -3
  66. package/dist/configurators/shared.js.map +1 -1
  67. package/dist/configurators/windsurf.d.ts +3 -4
  68. package/dist/configurators/windsurf.d.ts.map +1 -1
  69. package/dist/configurators/windsurf.js +17 -10
  70. package/dist/configurators/windsurf.js.map +1 -1
  71. package/dist/configurators/workflow.d.ts +0 -3
  72. package/dist/configurators/workflow.d.ts.map +1 -1
  73. package/dist/configurators/workflow.js +1 -7
  74. package/dist/configurators/workflow.js.map +1 -1
  75. package/dist/migrations/manifests/0.4.0.json +1 -1
  76. package/dist/migrations/manifests/0.5.0-beta.0.json +1644 -0
  77. package/dist/templates/claude/agents/check.md +2 -29
  78. package/dist/templates/claude/agents/research.md +70 -52
  79. package/dist/templates/claude/index.d.ts +5 -37
  80. package/dist/templates/claude/index.d.ts.map +1 -1
  81. package/dist/templates/claude/index.js +3 -42
  82. package/dist/templates/claude/index.js.map +1 -1
  83. package/dist/templates/claude/settings.json +3 -4
  84. package/dist/templates/{iflow → codebuddy}/agents/check.md +3 -30
  85. package/dist/templates/{iflow → codebuddy}/agents/implement.md +1 -1
  86. package/dist/templates/codebuddy/agents/research.md +138 -0
  87. package/dist/templates/codebuddy/index.d.ts +6 -16
  88. package/dist/templates/codebuddy/index.d.ts.map +1 -1
  89. package/dist/templates/codebuddy/index.js +6 -36
  90. package/dist/templates/codebuddy/index.js.map +1 -1
  91. package/dist/templates/codebuddy/settings.json +59 -0
  92. package/dist/templates/codex/agents/research.toml +50 -16
  93. package/dist/templates/codex/config.toml +10 -0
  94. package/dist/templates/codex/hooks/session-start.py +65 -29
  95. package/dist/templates/codex/hooks.json +11 -0
  96. package/dist/templates/codex/index.d.ts +0 -1
  97. package/dist/templates/codex/index.d.ts.map +1 -1
  98. package/dist/templates/codex/index.js +1 -8
  99. package/dist/templates/codex/index.js.map +1 -1
  100. package/dist/templates/common/commands/continue.md +51 -0
  101. package/dist/templates/common/commands/finish-work.md +32 -0
  102. package/dist/templates/common/commands/start.md +56 -0
  103. package/dist/templates/common/index.d.ts +28 -0
  104. package/dist/templates/common/index.d.ts.map +1 -0
  105. package/dist/templates/common/index.js +55 -0
  106. package/dist/templates/common/index.js.map +1 -0
  107. package/dist/templates/{codebuddy/commands/trellis → common/skills}/brainstorm.md +4 -4
  108. package/dist/templates/{opencode/commands/trellis → common/skills}/break-loop.md +4 -4
  109. package/dist/templates/common/skills/check.md +87 -0
  110. package/dist/templates/{codebuddy/commands/trellis → common/skills}/update-spec.md +18 -21
  111. package/dist/templates/copilot/hooks/session-start.py +65 -29
  112. package/dist/templates/copilot/hooks.json +8 -0
  113. package/dist/templates/cursor/agents/check.md +95 -0
  114. package/dist/templates/cursor/agents/implement.md +95 -0
  115. package/dist/templates/cursor/agents/research.md +138 -0
  116. package/dist/templates/cursor/hooks.json +24 -0
  117. package/dist/templates/cursor/index.d.ts +6 -17
  118. package/dist/templates/cursor/index.d.ts.map +1 -1
  119. package/dist/templates/cursor/index.js +6 -37
  120. package/dist/templates/cursor/index.js.map +1 -1
  121. package/dist/templates/droid/droids/check.md +95 -0
  122. package/dist/templates/droid/droids/implement.md +95 -0
  123. package/dist/templates/droid/droids/research.md +138 -0
  124. package/dist/templates/droid/index.d.ts +7 -19
  125. package/dist/templates/droid/index.d.ts.map +1 -1
  126. package/dist/templates/droid/index.js +7 -39
  127. package/dist/templates/droid/index.js.map +1 -1
  128. package/dist/templates/droid/settings.json +59 -0
  129. package/dist/templates/extract.d.ts +7 -193
  130. package/dist/templates/extract.d.ts.map +1 -1
  131. package/dist/templates/extract.js +7 -310
  132. package/dist/templates/extract.js.map +1 -1
  133. package/dist/templates/gemini/agents/check.md +95 -0
  134. package/dist/templates/gemini/agents/implement.md +95 -0
  135. package/dist/templates/gemini/agents/research.md +138 -0
  136. package/dist/templates/gemini/index.d.ts +6 -14
  137. package/dist/templates/gemini/index.d.ts.map +1 -1
  138. package/dist/templates/gemini/index.js +6 -37
  139. package/dist/templates/gemini/index.js.map +1 -1
  140. package/dist/templates/gemini/settings.json +28 -0
  141. package/dist/templates/kiro/agents/check.json +13 -0
  142. package/dist/templates/kiro/agents/implement.json +13 -0
  143. package/dist/templates/kiro/agents/research.json +21 -0
  144. package/dist/templates/kiro/index.d.ts +11 -11
  145. package/dist/templates/kiro/index.d.ts.map +1 -1
  146. package/dist/templates/kiro/index.js +11 -33
  147. package/dist/templates/kiro/index.js.map +1 -1
  148. package/dist/templates/opencode/agents/check.md +3 -30
  149. package/dist/templates/opencode/agents/implement.md +1 -1
  150. package/dist/templates/opencode/agents/research.md +1 -2
  151. package/dist/templates/opencode/plugins/inject-subagent-context.js +9 -183
  152. package/dist/templates/opencode/plugins/inject-workflow-state.js +160 -0
  153. package/dist/templates/opencode/plugins/session-start.js +71 -32
  154. package/dist/templates/qoder/agents/check.md +95 -0
  155. package/dist/templates/qoder/agents/implement.md +95 -0
  156. package/dist/templates/qoder/agents/research.md +138 -0
  157. package/dist/templates/qoder/index.d.ts +7 -10
  158. package/dist/templates/qoder/index.d.ts.map +1 -1
  159. package/dist/templates/qoder/index.js +7 -32
  160. package/dist/templates/qoder/index.js.map +1 -1
  161. package/dist/templates/qoder/settings.json +47 -0
  162. package/dist/templates/shared-hooks/index.d.ts +19 -0
  163. package/dist/templates/shared-hooks/index.d.ts.map +1 -0
  164. package/dist/templates/shared-hooks/index.js +30 -0
  165. package/dist/templates/shared-hooks/index.js.map +1 -0
  166. package/dist/templates/{iflow/hooks → shared-hooks}/inject-subagent-context.py +74 -263
  167. package/dist/templates/shared-hooks/inject-workflow-state.py +231 -0
  168. package/dist/templates/{claude/hooks → shared-hooks}/session-start.py +162 -55
  169. package/dist/templates/template-utils.d.ts +26 -0
  170. package/dist/templates/template-utils.d.ts.map +1 -0
  171. package/dist/templates/template-utils.js +60 -0
  172. package/dist/templates/template-utils.js.map +1 -0
  173. package/dist/templates/trellis/index.d.ts +1 -14
  174. package/dist/templates/trellis/index.d.ts.map +1 -1
  175. package/dist/templates/trellis/index.js +2 -27
  176. package/dist/templates/trellis/index.js.map +1 -1
  177. package/dist/templates/trellis/scripts/common/cli_adapter.py +2 -2
  178. package/dist/templates/trellis/scripts/common/config.py +126 -1
  179. package/dist/templates/trellis/scripts/common/git_context.py +25 -2
  180. package/dist/templates/trellis/scripts/common/task_context.py +3 -23
  181. package/dist/templates/trellis/scripts/common/task_store.py +0 -12
  182. package/dist/templates/trellis/scripts/common/workflow_phase.py +176 -0
  183. package/dist/templates/trellis/scripts/task.py +6 -35
  184. package/dist/templates/trellis/workflow.md +274 -297
  185. package/dist/types/ai-tools.d.ts +21 -3
  186. package/dist/types/ai-tools.d.ts.map +1 -1
  187. package/dist/types/ai-tools.js +106 -15
  188. package/dist/types/ai-tools.js.map +1 -1
  189. package/dist/types/migration.d.ts +8 -1
  190. package/dist/types/migration.d.ts.map +1 -1
  191. package/package.json +3 -2
  192. package/dist/configurators/iflow.d.ts +0 -33
  193. package/dist/configurators/iflow.d.ts.map +0 -1
  194. package/dist/configurators/iflow.js +0 -99
  195. package/dist/configurators/iflow.js.map +0 -1
  196. package/dist/templates/antigravity/index.d.ts +0 -12
  197. package/dist/templates/antigravity/index.d.ts.map +0 -1
  198. package/dist/templates/antigravity/index.js +0 -29
  199. package/dist/templates/antigravity/index.js.map +0 -1
  200. package/dist/templates/claude/agents/debug.md +0 -106
  201. package/dist/templates/claude/agents/dispatch.md +0 -213
  202. package/dist/templates/claude/agents/plan.md +0 -396
  203. package/dist/templates/claude/commands/trellis/brainstorm.md +0 -487
  204. package/dist/templates/claude/commands/trellis/break-loop.md +0 -125
  205. package/dist/templates/claude/commands/trellis/check-cross-layer.md +0 -153
  206. package/dist/templates/claude/commands/trellis/check.md +0 -25
  207. package/dist/templates/claude/commands/trellis/create-command.md +0 -154
  208. package/dist/templates/claude/commands/trellis/finish-work.md +0 -153
  209. package/dist/templates/claude/commands/trellis/integrate-skill.md +0 -219
  210. package/dist/templates/claude/commands/trellis/onboard.md +0 -358
  211. package/dist/templates/claude/commands/trellis/parallel.md +0 -192
  212. package/dist/templates/claude/commands/trellis/record-session.md +0 -62
  213. package/dist/templates/claude/commands/trellis/start.md +0 -393
  214. package/dist/templates/claude/commands/trellis/update-spec.md +0 -354
  215. package/dist/templates/claude/hooks/inject-subagent-context.py +0 -803
  216. package/dist/templates/claude/hooks/ralph-loop.py +0 -396
  217. package/dist/templates/codebuddy/commands/trellis/before-dev.md +0 -29
  218. package/dist/templates/codebuddy/commands/trellis/break-loop.md +0 -107
  219. package/dist/templates/codebuddy/commands/trellis/check-cross-layer.md +0 -153
  220. package/dist/templates/codebuddy/commands/trellis/check.md +0 -25
  221. package/dist/templates/codebuddy/commands/trellis/create-command.md +0 -154
  222. package/dist/templates/codebuddy/commands/trellis/finish-work.md +0 -143
  223. package/dist/templates/codebuddy/commands/trellis/integrate-skill.md +0 -219
  224. package/dist/templates/codebuddy/commands/trellis/onboard.md +0 -358
  225. package/dist/templates/codebuddy/commands/trellis/record-session.md +0 -61
  226. package/dist/templates/codebuddy/commands/trellis/start.md +0 -373
  227. package/dist/templates/codex/codex-skills/parallel/SKILL.md +0 -194
  228. package/dist/templates/cursor/commands/trellis-before-dev.md +0 -29
  229. package/dist/templates/cursor/commands/trellis-brainstorm.md +0 -487
  230. package/dist/templates/cursor/commands/trellis-break-loop.md +0 -107
  231. package/dist/templates/cursor/commands/trellis-check-cross-layer.md +0 -153
  232. package/dist/templates/cursor/commands/trellis-check.md +0 -25
  233. package/dist/templates/cursor/commands/trellis-create-command.md +0 -154
  234. package/dist/templates/cursor/commands/trellis-finish-work.md +0 -143
  235. package/dist/templates/cursor/commands/trellis-integrate-skill.md +0 -219
  236. package/dist/templates/cursor/commands/trellis-onboard.md +0 -358
  237. package/dist/templates/cursor/commands/trellis-record-session.md +0 -62
  238. package/dist/templates/cursor/commands/trellis-start.md +0 -373
  239. package/dist/templates/cursor/commands/trellis-update-spec.md +0 -354
  240. package/dist/templates/droid/commands/trellis/before-dev.md +0 -33
  241. package/dist/templates/droid/commands/trellis/brainstorm.md +0 -491
  242. package/dist/templates/droid/commands/trellis/break-loop.md +0 -111
  243. package/dist/templates/droid/commands/trellis/check-cross-layer.md +0 -157
  244. package/dist/templates/droid/commands/trellis/check.md +0 -29
  245. package/dist/templates/droid/commands/trellis/create-command.md +0 -158
  246. package/dist/templates/droid/commands/trellis/finish-work.md +0 -147
  247. package/dist/templates/droid/commands/trellis/integrate-skill.md +0 -223
  248. package/dist/templates/droid/commands/trellis/onboard.md +0 -362
  249. package/dist/templates/droid/commands/trellis/record-session.md +0 -66
  250. package/dist/templates/droid/commands/trellis/start.md +0 -377
  251. package/dist/templates/droid/commands/trellis/update-spec.md +0 -358
  252. package/dist/templates/gemini/commands/trellis/before-dev.toml +0 -33
  253. package/dist/templates/gemini/commands/trellis/brainstorm.toml +0 -435
  254. package/dist/templates/gemini/commands/trellis/break-loop.toml +0 -129
  255. package/dist/templates/gemini/commands/trellis/check-cross-layer.toml +0 -147
  256. package/dist/templates/gemini/commands/trellis/check.toml +0 -29
  257. package/dist/templates/gemini/commands/trellis/create-command.toml +0 -119
  258. package/dist/templates/gemini/commands/trellis/finish-work.toml +0 -133
  259. package/dist/templates/gemini/commands/trellis/integrate-skill.toml +0 -104
  260. package/dist/templates/gemini/commands/trellis/onboard.toml +0 -111
  261. package/dist/templates/gemini/commands/trellis/record-session.toml +0 -66
  262. package/dist/templates/gemini/commands/trellis/start.toml +0 -354
  263. package/dist/templates/gemini/commands/trellis/update-spec.toml +0 -132
  264. package/dist/templates/iflow/agents/debug.md +0 -106
  265. package/dist/templates/iflow/agents/dispatch.md +0 -213
  266. package/dist/templates/iflow/agents/plan.md +0 -396
  267. package/dist/templates/iflow/agents/research.md +0 -120
  268. package/dist/templates/iflow/commands/trellis/before-dev.md +0 -29
  269. package/dist/templates/iflow/commands/trellis/brainstorm.md +0 -487
  270. package/dist/templates/iflow/commands/trellis/break-loop.md +0 -125
  271. package/dist/templates/iflow/commands/trellis/check-cross-layer.md +0 -153
  272. package/dist/templates/iflow/commands/trellis/check.md +0 -25
  273. package/dist/templates/iflow/commands/trellis/create-command.md +0 -152
  274. package/dist/templates/iflow/commands/trellis/finish-work.md +0 -153
  275. package/dist/templates/iflow/commands/trellis/integrate-skill.md +0 -219
  276. package/dist/templates/iflow/commands/trellis/onboard.md +0 -358
  277. package/dist/templates/iflow/commands/trellis/parallel.md +0 -192
  278. package/dist/templates/iflow/commands/trellis/record-session.md +0 -62
  279. package/dist/templates/iflow/commands/trellis/start.md +0 -393
  280. package/dist/templates/iflow/commands/trellis/update-spec.md +0 -354
  281. package/dist/templates/iflow/hooks/ralph-loop.py +0 -395
  282. package/dist/templates/iflow/hooks/session-start.py +0 -403
  283. package/dist/templates/iflow/index.d.ts +0 -54
  284. package/dist/templates/iflow/index.d.ts.map +0 -1
  285. package/dist/templates/iflow/index.js +0 -85
  286. package/dist/templates/iflow/index.js.map +0 -1
  287. package/dist/templates/iflow/settings.json +0 -60
  288. package/dist/templates/kilo/index.d.ts +0 -16
  289. package/dist/templates/kilo/index.d.ts.map +0 -1
  290. package/dist/templates/kilo/index.js +0 -39
  291. package/dist/templates/kilo/index.js.map +0 -1
  292. package/dist/templates/kilo/workflows/before-dev.md +0 -29
  293. package/dist/templates/kilo/workflows/brainstorm.md +0 -487
  294. package/dist/templates/kilo/workflows/break-loop.md +0 -125
  295. package/dist/templates/kilo/workflows/check-cross-layer.md +0 -153
  296. package/dist/templates/kilo/workflows/check.md +0 -25
  297. package/dist/templates/kilo/workflows/create-command.md +0 -152
  298. package/dist/templates/kilo/workflows/finish-work.md +0 -129
  299. package/dist/templates/kilo/workflows/integrate-skill.md +0 -219
  300. package/dist/templates/kilo/workflows/onboard.md +0 -358
  301. package/dist/templates/kilo/workflows/parallel.md +0 -193
  302. package/dist/templates/kilo/workflows/record-session.md +0 -62
  303. package/dist/templates/kilo/workflows/start.md +0 -387
  304. package/dist/templates/kilo/workflows/update-spec.md +0 -285
  305. package/dist/templates/kiro/skills/before-dev/SKILL.md +0 -34
  306. package/dist/templates/kiro/skills/brainstorm/SKILL.md +0 -492
  307. package/dist/templates/kiro/skills/break-loop/SKILL.md +0 -130
  308. package/dist/templates/kiro/skills/check/SKILL.md +0 -30
  309. package/dist/templates/kiro/skills/check-cross-layer/SKILL.md +0 -158
  310. package/dist/templates/kiro/skills/create-command/SKILL.md +0 -101
  311. package/dist/templates/kiro/skills/finish-work/SKILL.md +0 -148
  312. package/dist/templates/kiro/skills/integrate-skill/SKILL.md +0 -221
  313. package/dist/templates/kiro/skills/onboard/SKILL.md +0 -363
  314. package/dist/templates/kiro/skills/record-session/SKILL.md +0 -67
  315. package/dist/templates/kiro/skills/start/SKILL.md +0 -351
  316. package/dist/templates/kiro/skills/update-spec/SKILL.md +0 -335
  317. package/dist/templates/opencode/agents/debug.md +0 -129
  318. package/dist/templates/opencode/agents/dispatch.md +0 -223
  319. package/dist/templates/opencode/agents/trellis-plan.md +0 -427
  320. package/dist/templates/opencode/commands/trellis/before-dev.md +0 -29
  321. package/dist/templates/opencode/commands/trellis/brainstorm.md +0 -487
  322. package/dist/templates/opencode/commands/trellis/check-cross-layer.md +0 -153
  323. package/dist/templates/opencode/commands/trellis/check.md +0 -25
  324. package/dist/templates/opencode/commands/trellis/create-command.md +0 -154
  325. package/dist/templates/opencode/commands/trellis/finish-work.md +0 -144
  326. package/dist/templates/opencode/commands/trellis/integrate-skill.md +0 -219
  327. package/dist/templates/opencode/commands/trellis/migrate-specs.md +0 -0
  328. package/dist/templates/opencode/commands/trellis/onboard.md +0 -358
  329. package/dist/templates/opencode/commands/trellis/parallel.md +0 -193
  330. package/dist/templates/opencode/commands/trellis/record-session.md +0 -62
  331. package/dist/templates/opencode/commands/trellis/start.md +0 -351
  332. package/dist/templates/opencode/commands/trellis/update-spec.md +0 -354
  333. package/dist/templates/qoder/skills/before-dev/SKILL.md +0 -34
  334. package/dist/templates/qoder/skills/brainstorm/SKILL.md +0 -492
  335. package/dist/templates/qoder/skills/break-loop/SKILL.md +0 -130
  336. package/dist/templates/qoder/skills/check/SKILL.md +0 -30
  337. package/dist/templates/qoder/skills/check-cross-layer/SKILL.md +0 -158
  338. package/dist/templates/qoder/skills/create-command/SKILL.md +0 -101
  339. package/dist/templates/qoder/skills/finish-work/SKILL.md +0 -134
  340. package/dist/templates/qoder/skills/integrate-skill/SKILL.md +0 -221
  341. package/dist/templates/qoder/skills/onboard/SKILL.md +0 -363
  342. package/dist/templates/qoder/skills/record-session/SKILL.md +0 -67
  343. package/dist/templates/qoder/skills/start/SKILL.md +0 -388
  344. package/dist/templates/qoder/skills/update-spec/SKILL.md +0 -290
  345. package/dist/templates/trellis/scripts/common/phase.py +0 -254
  346. package/dist/templates/trellis/scripts/common/registry.py +0 -335
  347. package/dist/templates/trellis/scripts/common/worktree.py +0 -305
  348. package/dist/templates/trellis/scripts/multi_agent/__init__.py +0 -5
  349. package/dist/templates/trellis/scripts/multi_agent/_bootstrap.py +0 -17
  350. package/dist/templates/trellis/scripts/multi_agent/cleanup.py +0 -398
  351. package/dist/templates/trellis/scripts/multi_agent/create_pr.py +0 -620
  352. package/dist/templates/trellis/scripts/multi_agent/plan.py +0 -213
  353. package/dist/templates/trellis/scripts/multi_agent/start.py +0 -539
  354. package/dist/templates/trellis/scripts/multi_agent/status.py +0 -76
  355. package/dist/templates/trellis/scripts/multi_agent/status_display.py +0 -542
  356. package/dist/templates/trellis/scripts/multi_agent/status_monitor.py +0 -225
  357. package/dist/templates/trellis/scripts-shell-archive/add-session.sh +0 -384
  358. package/dist/templates/trellis/scripts-shell-archive/common/developer.sh +0 -129
  359. package/dist/templates/trellis/scripts-shell-archive/common/git-context.sh +0 -263
  360. package/dist/templates/trellis/scripts-shell-archive/common/paths.sh +0 -208
  361. package/dist/templates/trellis/scripts-shell-archive/common/phase.sh +0 -150
  362. package/dist/templates/trellis/scripts-shell-archive/common/registry.sh +0 -247
  363. package/dist/templates/trellis/scripts-shell-archive/common/task-queue.sh +0 -142
  364. package/dist/templates/trellis/scripts-shell-archive/common/task-utils.sh +0 -151
  365. package/dist/templates/trellis/scripts-shell-archive/common/worktree.sh +0 -128
  366. package/dist/templates/trellis/scripts-shell-archive/create-bootstrap.sh +0 -299
  367. package/dist/templates/trellis/scripts-shell-archive/get-context.sh +0 -7
  368. package/dist/templates/trellis/scripts-shell-archive/get-developer.sh +0 -15
  369. package/dist/templates/trellis/scripts-shell-archive/init-developer.sh +0 -34
  370. package/dist/templates/trellis/scripts-shell-archive/multi-agent/cleanup.sh +0 -396
  371. package/dist/templates/trellis/scripts-shell-archive/multi-agent/create-pr.sh +0 -241
  372. package/dist/templates/trellis/scripts-shell-archive/multi-agent/plan.sh +0 -207
  373. package/dist/templates/trellis/scripts-shell-archive/multi-agent/start.sh +0 -317
  374. package/dist/templates/trellis/scripts-shell-archive/multi-agent/status.sh +0 -828
  375. package/dist/templates/trellis/scripts-shell-archive/task.sh +0 -1204
  376. package/dist/templates/trellis/worktree.yaml +0 -47
  377. package/dist/templates/windsurf/index.d.ts +0 -21
  378. package/dist/templates/windsurf/index.d.ts.map +0 -1
  379. package/dist/templates/windsurf/index.js +0 -44
  380. package/dist/templates/windsurf/index.js.map +0 -1
  381. package/dist/templates/windsurf/workflows/trellis-before-dev.md +0 -31
  382. package/dist/templates/windsurf/workflows/trellis-brainstorm.md +0 -491
  383. package/dist/templates/windsurf/workflows/trellis-break-loop.md +0 -111
  384. package/dist/templates/windsurf/workflows/trellis-check-cross-layer.md +0 -157
  385. package/dist/templates/windsurf/workflows/trellis-check.md +0 -27
  386. package/dist/templates/windsurf/workflows/trellis-create-command.md +0 -154
  387. package/dist/templates/windsurf/workflows/trellis-finish-work.md +0 -147
  388. package/dist/templates/windsurf/workflows/trellis-integrate-skill.md +0 -220
  389. package/dist/templates/windsurf/workflows/trellis-onboard.md +0 -362
  390. package/dist/templates/windsurf/workflows/trellis-record-session.md +0 -66
  391. package/dist/templates/windsurf/workflows/trellis-start.md +0 -373
  392. package/dist/templates/windsurf/workflows/trellis-update-spec.md +0 -358
  393. /package/dist/templates/{claude/commands/trellis → common/skills}/before-dev.md +0 -0
  394. /package/dist/templates/{claude/hooks → shared-hooks}/statusline.py +0 -0
@@ -1,34 +0,0 @@
1
- ---
2
- name: before-dev
3
- description: "Discovers and injects project-specific coding guidelines from .trellis/spec/ before implementation begins. Reads spec indexes, pre-development checklists, and shared thinking guides for the target package. Use when starting a new coding task, before writing any code, switching to a different package, or needing to refresh project conventions and standards."
4
- ---
5
-
6
- Read the relevant development guidelines before starting your task.
7
-
8
- Execute these steps:
9
-
10
- 1. **Discover packages and their spec layers**:
11
- ```bash
12
- python3 ./.trellis/scripts/get_context.py --mode packages
13
- ```
14
-
15
- 2. **Identify which specs apply** to your task based on:
16
- - Which package you're modifying (e.g., `cli/`, `docs-site/`)
17
- - What type of work (backend, frontend, unit-test, docs, etc.)
18
-
19
- 3. **Read the spec index** for each relevant module:
20
- ```bash
21
- cat .trellis/spec/<package>/<layer>/index.md
22
- ```
23
- Follow the **"Pre-Development Checklist"** section in the index.
24
-
25
- 4. **Read the specific guideline files** listed in the Pre-Development Checklist that are relevant to your task. The index is NOT the goal — it points you to the actual guideline files (e.g., `error-handling.md`, `conventions.md`, `mock-strategies.md`). Read those files to understand the coding standards and patterns.
26
-
27
- 5. **Always read shared guides**:
28
- ```bash
29
- cat .trellis/spec/guides/index.md
30
- ```
31
-
32
- 6. Understand the coding standards and patterns you need to follow, then proceed with your development plan.
33
-
34
- This step is **mandatory** before writing any code.
@@ -1,492 +0,0 @@
1
- ---
2
- name: brainstorm
3
- description: "Collaborative requirements discovery session optimized for AI coding workflows. Creates task directories, seeds PRDs, runs codebase research, proposes concrete implementation approaches with trade-offs, and converges on MVP scope through structured Q&A. Use when requirements are unclear, multiple implementation paths exist, trade-offs need evaluation, or a complex feature needs scoping before development."
4
- ---
5
-
6
- # Brainstorm - Requirements Discovery (AI Coding Enhanced)
7
-
8
- Guide AI through collaborative requirements discovery **before implementation**, optimized for AI coding workflows:
9
-
10
- * **Task-first** (capture ideas immediately)
11
- * **Action-before-asking** (reduce low-value questions)
12
- * **Research-first** for technical choices (avoid asking users to invent options)
13
- * **Diverge → Converge** (expand thinking, then lock MVP)
14
-
15
- ---
16
-
17
- ## When to Use
18
-
19
- Triggered from `$start` when the user describes a development task, especially when:
20
-
21
- * requirements are unclear or evolving
22
- * there are multiple valid implementation paths
23
- * trade-offs matter (UX, reliability, maintainability, cost, performance)
24
- * the user might not know the best options up front
25
-
26
- ---
27
-
28
- ## Core Principles (Non-negotiable)
29
-
30
- 1. **Task-first (capture early)**
31
- Always ensure a task exists at the start so the user's ideas are recorded immediately.
32
-
33
- 2. **Action before asking**
34
- If you can derive the answer from repo code, docs, configs, conventions, or quick research — do that first.
35
-
36
- 3. **One question per message**
37
- Never overwhelm the user with a list of questions. Ask one, update PRD, repeat.
38
-
39
- 4. **Prefer concrete options**
40
- For preference/decision questions, present 2–3 feasible, specific approaches with trade-offs.
41
-
42
- 5. **Research-first for technical choices**
43
- If the decision depends on industry conventions / similar tools / established patterns, do research first, then propose options.
44
-
45
- 6. **Diverge → Converge**
46
- After initial understanding, proactively consider future evolution, related scenarios, and failure/edge cases — then converge to an MVP with explicit out-of-scope.
47
-
48
- 7. **No meta questions**
49
- Do not ask "should I search?" or "can you paste the code so I can continue?"
50
- If you need information: search/inspect. If blocked: ask the minimal blocking question.
51
-
52
- ---
53
-
54
- ## Step 0: Ensure Task Exists (ALWAYS)
55
-
56
- Before any Q&A, ensure a task exists. If none exists, create one immediately.
57
-
58
- * Use a **temporary working title** derived from the user's message.
59
- * It's OK if the title is imperfect — refine later in PRD.
60
-
61
- ```bash
62
- TASK_DIR=$(python3 ./.trellis/scripts/task.py create "brainstorm: <short goal>" --slug <auto>)
63
- ```
64
-
65
- Create/seed `prd.md` immediately with what you know:
66
-
67
- ```markdown
68
- # brainstorm: <short goal>
69
-
70
- ## Goal
71
-
72
- <one paragraph: what + why>
73
-
74
- ## What I already know
75
-
76
- * <facts from user message>
77
- * <facts discovered from repo/docs>
78
-
79
- ## Assumptions (temporary)
80
-
81
- * <assumptions to validate>
82
-
83
- ## Open Questions
84
-
85
- * <ONLY Blocking / Preference questions; keep list short>
86
-
87
- ## Requirements (evolving)
88
-
89
- * <start with what is known>
90
-
91
- ## Acceptance Criteria (evolving)
92
-
93
- * [ ] <testable criterion>
94
-
95
- ## Definition of Done (team quality bar)
96
-
97
- * Tests added/updated (unit/integration where appropriate)
98
- * Lint / typecheck / CI green
99
- * Docs/notes updated if behavior changes
100
- * Rollout/rollback considered if risky
101
-
102
- ## Out of Scope (explicit)
103
-
104
- * <what we will not do in this task>
105
-
106
- ## Technical Notes
107
-
108
- * <files inspected, constraints, links, references>
109
- * <research notes summary if applicable>
110
- ```
111
-
112
- ---
113
-
114
- ## Step 1: Auto-Context (DO THIS BEFORE ASKING QUESTIONS)
115
-
116
- Before asking questions like "what does the code look like?", gather context yourself:
117
-
118
- ### Repo inspection checklist
119
-
120
- * Identify likely modules/files impacted
121
- * Locate existing patterns (similar features, conventions, error handling style)
122
- * Check configs, scripts, existing command definitions
123
- * Note any constraints (runtime, dependency policy, build tooling)
124
-
125
- ### Documentation checklist
126
-
127
- * Look for existing PRDs/specs/templates
128
- * Look for command usage examples, README, ADRs if any
129
-
130
- Write findings into PRD:
131
-
132
- * Add to `What I already know`
133
- * Add constraints/links to `Technical Notes`
134
-
135
- ---
136
-
137
- ## Step 2: Classify Complexity (still useful, not gating task creation)
138
-
139
- | Complexity | Criteria | Action |
140
- | ------------ | ------------------------------------------------------ | ------------------------------------------- |
141
- | **Trivial** | Single-line fix, typo, obvious change | Skip brainstorm, implement directly |
142
- | **Simple** | Clear goal, 1–2 files, scope well-defined | Ask 1 confirm question, then implement |
143
- | **Moderate** | Multiple files, some ambiguity | Light brainstorm (2–3 high-value questions) |
144
- | **Complex** | Vague goal, architectural choices, multiple approaches | Full brainstorm |
145
-
146
- > Note: Task already exists from Step 0. Classification only affects depth of brainstorming.
147
-
148
- ---
149
-
150
- ## Step 3: Question Gate (Ask ONLY high-value questions)
151
-
152
- Before asking ANY question, run the following gate:
153
-
154
- ### Gate A — Can I derive this without the user?
155
-
156
- If answer is available via:
157
-
158
- * repo inspection (code/config)
159
- * docs/specs/conventions
160
- * quick market/OSS research
161
-
162
- → **Do not ask.** Fetch it, summarize, update PRD.
163
-
164
- ### Gate B — Is this a meta/lazy question?
165
-
166
- Examples:
167
-
168
- * "Should I search?"
169
- * "Can you paste the code so I can proceed?"
170
- * "What does the code look like?" (when repo is available)
171
-
172
- → **Do not ask.** Take action.
173
-
174
- ### Gate C — What type of question is it?
175
-
176
- * **Blocking**: cannot proceed without user input
177
- * **Preference**: multiple valid choices, depends on product/UX/risk preference
178
- * **Derivable**: should be answered by inspection/research
179
-
180
- → Only ask **Blocking** or **Preference**.
181
-
182
- ---
183
-
184
- ## Step 4: Research-first Mode (Mandatory for technical choices)
185
-
186
- ### Trigger conditions (any → research-first)
187
-
188
- * The task involves selecting an approach, library, protocol, framework, template system, plugin mechanism, or CLI UX convention
189
- * The user asks for "best practice", "how others do it", "recommendation"
190
- * The user can't reasonably enumerate options
191
-
192
- ### Research steps
193
-
194
- 1. Identify 2–4 comparable tools/patterns
195
- 2. Summarize common conventions and why they exist
196
- 3. Map conventions onto our repo constraints
197
- 4. Produce **2–3 feasible approaches** for our project
198
-
199
- ### Research output format (PRD)
200
-
201
- Add a section in PRD (either within Technical Notes or as its own):
202
-
203
- ```markdown
204
- ## Research Notes
205
-
206
- ### What similar tools do
207
-
208
- * ...
209
- * ...
210
-
211
- ### Constraints from our repo/project
212
-
213
- * ...
214
-
215
- ### Feasible approaches here
216
-
217
- **Approach A: <name>** (Recommended)
218
-
219
- * How it works:
220
- * Pros:
221
- * Cons:
222
-
223
- **Approach B: <name>**
224
-
225
- * How it works:
226
- * Pros:
227
- * Cons:
228
-
229
- **Approach C: <name>** (optional)
230
-
231
- * ...
232
- ```
233
-
234
- Then ask **one** preference question:
235
-
236
- * "Which approach do you prefer: A / B / C (or other)?"
237
-
238
- ---
239
-
240
- ## Step 5: Expansion Sweep (DIVERGE) — Required after initial understanding
241
-
242
- After you can summarize the goal, proactively broaden thinking before converging.
243
-
244
- ### Expansion categories (keep to 1–2 bullets each)
245
-
246
- 1. **Future evolution**
247
-
248
- * What might this feature become in 1–3 months?
249
- * What extension points are worth preserving now?
250
-
251
- 2. **Related scenarios**
252
-
253
- * What adjacent commands/flows should remain consistent with this?
254
- * Are there parity expectations (create vs update, import vs export, etc.)?
255
-
256
- 3. **Failure & edge cases**
257
-
258
- * Conflicts, offline/network failure, retries, idempotency, compatibility, rollback
259
- * Input validation, security boundaries, permission checks
260
-
261
- ### Expansion message template (to user)
262
-
263
- ```markdown
264
- I understand you want to implement: <current goal>.
265
-
266
- Before diving into design, let me quickly diverge to consider three categories (to avoid rework later):
267
-
268
- 1. Future evolution: <1–2 bullets>
269
- 2. Related scenarios: <1–2 bullets>
270
- 3. Failure/edge cases: <1–2 bullets>
271
-
272
- For this MVP, which would you like to include (or none)?
273
-
274
- 1. Current requirement only (minimal viable)
275
- 2. Add <X> (reserve for future extension)
276
- 3. Add <Y> (improve robustness/consistency)
277
- 4. Other: describe your preference
278
- ```
279
-
280
- Then update PRD:
281
-
282
- * What's in MVP → `Requirements`
283
- * What's excluded → `Out of Scope`
284
-
285
- ---
286
-
287
- ## Step 6: Q&A Loop (CONVERGE)
288
-
289
- ### Rules
290
-
291
- * One question per message
292
- * Prefer multiple-choice when possible
293
- * After each user answer:
294
-
295
- * Update PRD immediately
296
- * Move answered items from `Open Questions` → `Requirements`
297
- * Update `Acceptance Criteria` with testable checkboxes
298
- * Clarify `Out of Scope`
299
-
300
- ### Question priority (recommended)
301
-
302
- 1. **MVP scope boundary** (what is included/excluded)
303
- 2. **Preference decisions** (after presenting concrete options)
304
- 3. **Failure/edge behavior** (only for MVP-critical paths)
305
- 4. **Success metrics & Acceptance Criteria** (what proves it works)
306
-
307
- ### Preferred question format (multiple choice)
308
-
309
- ```markdown
310
- For <topic>, which approach do you prefer?
311
-
312
- 1. **Option A** — <what it means + trade-off>
313
- 2. **Option B** — <what it means + trade-off>
314
- 3. **Option C** — <what it means + trade-off>
315
- 4. **Other** — describe your preference
316
- ```
317
-
318
- ---
319
-
320
- ## Step 7: Propose Approaches + Record Decisions (Complex tasks)
321
-
322
- After requirements are clear enough, propose 2–3 approaches (if not already done via research-first):
323
-
324
- ```markdown
325
- Based on current information, here are 2–3 feasible approaches:
326
-
327
- **Approach A: <name>** (Recommended)
328
-
329
- * How:
330
- * Pros:
331
- * Cons:
332
-
333
- **Approach B: <name>**
334
-
335
- * How:
336
- * Pros:
337
- * Cons:
338
-
339
- Which direction do you prefer?
340
- ```
341
-
342
- Record the outcome in PRD as an ADR-lite section:
343
-
344
- ```markdown
345
- ## Decision (ADR-lite)
346
-
347
- **Context**: Why this decision was needed
348
- **Decision**: Which approach was chosen
349
- **Consequences**: Trade-offs, risks, potential future improvements
350
- ```
351
-
352
- ---
353
-
354
- ## Step 8: Final Confirmation + Implementation Plan
355
-
356
- When open questions are resolved, confirm complete requirements with a structured summary:
357
-
358
- ### Final confirmation format
359
-
360
- ```markdown
361
- Here's my understanding of the complete requirements:
362
-
363
- **Goal**: <one sentence>
364
-
365
- **Requirements**:
366
-
367
- * ...
368
- * ...
369
-
370
- **Acceptance Criteria**:
371
-
372
- * [ ] ...
373
- * [ ] ...
374
-
375
- **Definition of Done**:
376
-
377
- * ...
378
-
379
- **Out of Scope**:
380
-
381
- * ...
382
-
383
- **Technical Approach**:
384
- <brief summary + key decisions>
385
-
386
- **Implementation Plan (small PRs)**:
387
-
388
- * PR1: <scaffolding + tests + minimal plumbing>
389
- * PR2: <core behavior>
390
- * PR3: <edge cases + docs + cleanup>
391
-
392
- Does this look correct? If yes, I'll proceed with implementation.
393
- ```
394
-
395
- ### Subtask Decomposition (Complex Tasks)
396
-
397
- For complex tasks with multiple independent work items, create subtasks:
398
-
399
- ```bash
400
- # Create child tasks
401
- CHILD1=$(python3 ./.trellis/scripts/task.py create "Child task 1" --slug child1 --parent "$TASK_DIR")
402
- CHILD2=$(python3 ./.trellis/scripts/task.py create "Child task 2" --slug child2 --parent "$TASK_DIR")
403
-
404
- # Or link existing tasks
405
- python3 ./.trellis/scripts/task.py add-subtask "$TASK_DIR" "$CHILD_DIR"
406
- ```
407
-
408
- ---
409
-
410
- ## PRD Target Structure (final)
411
-
412
- `prd.md` should converge to:
413
-
414
- ```markdown
415
- # <Task Title>
416
-
417
- ## Goal
418
-
419
- <why + what>
420
-
421
- ## Requirements
422
-
423
- * ...
424
-
425
- ## Acceptance Criteria
426
-
427
- * [ ] ...
428
-
429
- ## Definition of Done
430
-
431
- * ...
432
-
433
- ## Technical Approach
434
-
435
- <key design + decisions>
436
-
437
- ## Decision (ADR-lite)
438
-
439
- Context / Decision / Consequences
440
-
441
- ## Out of Scope
442
-
443
- * ...
444
-
445
- ## Technical Notes
446
-
447
- <constraints, references, files, research notes>
448
- ```
449
-
450
- ---
451
-
452
- ## Anti-Patterns (Hard Avoid)
453
-
454
- * Asking user for code/context that can be derived from repo
455
- * Asking user to choose an approach before presenting concrete options
456
- * Meta questions about whether to research
457
- * Staying narrowly on the initial request without considering evolution/edges
458
- * Letting brainstorming drift without updating PRD
459
-
460
- ---
461
-
462
- ## Integration with Start Workflow
463
-
464
- After brainstorm completes (Step 8 confirmation approved), the flow continues to the Task Workflow's **Phase 2: Prepare for Implementation**:
465
-
466
- ```text
467
- Brainstorm
468
- Step 0: Create task directory + seed PRD
469
- Step 1–7: Discover requirements, research, converge
470
- Step 8: Final confirmation → user approves
471
-
472
- Task Workflow Phase 2 (Prepare for Implementation)
473
- Code-Spec Depth Check (if applicable)
474
- → Research codebase (based on confirmed PRD)
475
- → Configure code-spec context (jsonl files)
476
- → Activate task
477
-
478
- Task Workflow Phase 3 (Execute)
479
- Implement → Check → Complete
480
- ```
481
-
482
- The task directory and PRD already exist from brainstorm, so Phase 1 of the Task Workflow is skipped entirely.
483
-
484
- ---
485
-
486
- ## Related Commands
487
-
488
- | Command | When to Use |
489
- |---------|-------------|
490
- | `$start` | Entry point that triggers brainstorm |
491
- | `$finish-work` | After implementation is complete |
492
- | `$update-spec` | If new patterns emerge during work |
@@ -1,130 +0,0 @@
1
- ---
2
- name: break-loop
3
- description: "Deep post-fix bug analysis across five dimensions: root cause categorization, fix failure analysis, prevention mechanisms, systematic expansion, and knowledge capture. Updates .trellis/spec/ guides with lessons learned to prevent recurring bugs. Use when a debugging session completes, after fixing a tricky bug, when the same class of bug keeps recurring, or when you want to capture debugging insights into project documentation."
4
- ---
5
-
6
- # Break the Loop - Deep Bug Analysis
7
-
8
- When debug is complete, use this command for deep analysis to break the "fix bug -> forget -> repeat" cycle.
9
-
10
- ---
11
-
12
- ## Analysis Framework
13
-
14
- Analyze the bug you just fixed from these 5 dimensions:
15
-
16
- ### 1. Root Cause Category
17
-
18
- Which category does this bug belong to?
19
-
20
- | Category | Characteristics | Example |
21
- |----------|-----------------|---------|
22
- | **A. Missing Spec** | No documentation on how to do it | New feature without checklist |
23
- | **B. Cross-Layer Contract** | Interface between layers unclear | API returns different format than expected |
24
- | **C. Change Propagation Failure** | Changed one place, missed others | Changed function signature, missed call sites |
25
- | **D. Test Coverage Gap** | Unit test passes, integration fails | Works alone, breaks when combined |
26
- | **E. Implicit Assumption** | Code relies on undocumented assumption | Timestamp seconds vs milliseconds |
27
-
28
- ### 2. Why Fixes Failed (if applicable)
29
-
30
- If you tried multiple fixes before succeeding, analyze each failure:
31
-
32
- - **Surface Fix**: Fixed symptom, not root cause
33
- - **Incomplete Scope**: Found root cause, didn't cover all cases
34
- - **Tool Limitation**: grep missed it, type check wasn't strict
35
- - **Mental Model**: Kept looking in same layer, didn't think cross-layer
36
-
37
- ### 3. Prevention Mechanisms
38
-
39
- What mechanisms would prevent this from happening again?
40
-
41
- | Type | Description | Example |
42
- |------|-------------|---------|
43
- | **Documentation** | Write it down so people know | Update thinking guide |
44
- | **Architecture** | Make the error impossible structurally | Type-safe wrappers |
45
- | **Compile-time** | TypeScript strict, no any | Signature change causes compile error |
46
- | **Runtime** | Monitoring, alerts, scans | Detect orphan entities |
47
- | **Test Coverage** | E2E tests, integration tests | Verify full flow |
48
- | **Code Review** | Checklist, PR template | "Did you check X?" |
49
-
50
- ### 4. Systematic Expansion
51
-
52
- What broader problems does this bug reveal?
53
-
54
- - **Similar Issues**: Where else might this problem exist?
55
- - **Design Flaw**: Is there a fundamental architecture issue?
56
- - **Process Flaw**: Is there a development process improvement?
57
- - **Knowledge Gap**: Is the team missing some understanding?
58
-
59
- ### 5. Knowledge Capture
60
-
61
- Solidify insights into the system:
62
-
63
- - [ ] Update `.trellis/spec/guides/` thinking guides
64
- - [ ] Update `.trellis/spec/backend/` or `frontend/` docs
65
- - [ ] Create issue record (if applicable)
66
- - [ ] Create feature ticket for root fix
67
- - [ ] Update check commands if needed
68
-
69
- ---
70
-
71
- ## Output Format
72
-
73
- Please output analysis in this format:
74
-
75
- ```markdown
76
- ## Bug Analysis: [Short Description]
77
-
78
- ### 1. Root Cause Category
79
- - **Category**: [A/B/C/D/E] - [Category Name]
80
- - **Specific Cause**: [Detailed description]
81
-
82
- ### 2. Why Fixes Failed (if applicable)
83
- 1. [First attempt]: [Why it failed]
84
- 2. [Second attempt]: [Why it failed]
85
- ...
86
-
87
- ### 3. Prevention Mechanisms
88
- | Priority | Mechanism | Specific Action | Status |
89
- |----------|-----------|-----------------|--------|
90
- | P0 | ... | ... | TODO/DONE |
91
-
92
- ### 4. Systematic Expansion
93
- - **Similar Issues**: [List places with similar problems]
94
- - **Design Improvement**: [Architecture-level suggestions]
95
- - **Process Improvement**: [Development process suggestions]
96
-
97
- ### 5. Knowledge Capture
98
- - [ ] [Documents to update / tickets to create]
99
- ```
100
-
101
- ---
102
-
103
- ## Core Philosophy
104
-
105
- > **The value of debugging is not in fixing the bug, but in making this class of bugs never happen again.**
106
-
107
- Three levels of insight:
108
- 1. **Tactical**: How to fix THIS bug
109
- 2. **Strategic**: How to prevent THIS CLASS of bugs
110
- 3. **Philosophical**: How to expand thinking patterns
111
-
112
- 30 minutes of analysis saves 30 hours of future debugging.
113
-
114
- ---
115
-
116
- ## After Analysis: Immediate Actions
117
-
118
- **IMPORTANT**: After completing the analysis above, you MUST immediately:
119
-
120
- 1. **Update spec/guides** - Don't just list TODOs, actually update the relevant files:
121
- - If it's a cross-platform issue → update `cross-platform-thinking-guide.md`
122
- - If it's a cross-layer issue → update `cross-layer-thinking-guide.md`
123
- - If it's a code reuse issue → update `code-reuse-thinking-guide.md`
124
- - If it's domain-specific → update `backend/*.md` or `frontend/*.md`
125
-
126
- 2. **Sync templates** - After updating `.trellis/spec/`, sync to `src/templates/markdown/spec/`
127
-
128
- 3. **Commit the spec updates** - This is the primary output, not just the analysis text
129
-
130
- > **The analysis is worthless if it stays in chat. The value is in the updated specs.**
@@ -1,30 +0,0 @@
1
- ---
2
- name: check
3
- description: "Validates recently written code against project-specific development guidelines from .trellis/spec/. Identifies changed files via git diff, discovers applicable spec modules, runs lint and typecheck, and reports guideline violations. Use when code is written and needs quality verification, to catch context drift during long sessions, or before committing changes."
4
- ---
5
-
6
- Check if the code you just wrote follows the development guidelines.
7
-
8
- Execute these steps:
9
-
10
- 1. **Identify changed files**:
11
- ```bash
12
- git diff --name-only HEAD
13
- ```
14
-
15
- 2. **Determine which spec modules apply** based on the changed file paths:
16
- ```bash
17
- python3 ./.trellis/scripts/get_context.py --mode packages
18
- ```
19
-
20
- 3. **Read the spec index** for each relevant module:
21
- ```bash
22
- cat .trellis/spec/<package>/<layer>/index.md
23
- ```
24
- Follow the **"Quality Check"** section in the index.
25
-
26
- 4. **Read the specific guideline files** referenced in the Quality Check section (e.g., `quality-guidelines.md`, `conventions.md`). The index is NOT the goal — it points you to the actual guideline files. Read those files and review your code against them.
27
-
28
- 5. **Run lint and typecheck** for the affected package.
29
-
30
- 6. **Report any violations** and fix them if found.