@mindfoldhq/trellis 0.4.0 → 0.5.0-beta.10

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 (427) 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 +10 -1
  4. package/dist/commands/init.d.ts.map +1 -1
  5. package/dist/commands/init.js +382 -120
  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 +178 -61
  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 +146 -100
  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 +7 -25
  56. package/dist/configurators/opencode.d.ts.map +1 -1
  57. package/dist/configurators/opencode.js +57 -56
  58. package/dist/configurators/opencode.js.map +1 -1
  59. package/dist/configurators/qoder.d.ts +6 -3
  60. package/dist/configurators/qoder.d.ts.map +1 -1
  61. package/dist/configurators/qoder.js +27 -46
  62. package/dist/configurators/qoder.js.map +1 -1
  63. package/dist/configurators/shared.d.ts +68 -3
  64. package/dist/configurators/shared.d.ts.map +1 -1
  65. package/dist/configurators/shared.js +274 -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 +1646 -0
  77. package/dist/migrations/manifests/0.5.0-beta.1.json +9 -0
  78. package/dist/migrations/manifests/0.5.0-beta.2.json +9 -0
  79. package/dist/migrations/manifests/0.5.0-beta.3.json +9 -0
  80. package/dist/migrations/manifests/0.5.0-beta.4.json +9 -0
  81. package/dist/migrations/manifests/0.5.0-beta.5.json +222 -0
  82. package/dist/migrations/manifests/0.5.0-beta.6.json +9 -0
  83. package/dist/migrations/manifests/0.5.0-beta.7.json +9 -0
  84. package/dist/migrations/manifests/0.5.0-beta.8.json +9 -0
  85. package/dist/migrations/manifests/0.5.0-beta.9.json +48 -0
  86. package/dist/templates/claude/agents/{check.md → trellis-check.md} +3 -31
  87. package/dist/templates/claude/agents/{implement.md → trellis-implement.md} +1 -2
  88. package/dist/templates/claude/agents/trellis-research.md +137 -0
  89. package/dist/templates/claude/index.d.ts +5 -37
  90. package/dist/templates/claude/index.d.ts.map +1 -1
  91. package/dist/templates/claude/index.js +3 -42
  92. package/dist/templates/claude/index.js.map +1 -1
  93. package/dist/templates/claude/settings.json +6 -4
  94. package/dist/templates/{iflow/agents/check.md → codebuddy/agents/trellis-check.md} +3 -31
  95. package/dist/templates/{iflow/agents/implement.md → codebuddy/agents/trellis-implement.md} +1 -2
  96. package/dist/templates/codebuddy/agents/trellis-research.md +137 -0
  97. package/dist/templates/codebuddy/index.d.ts +6 -16
  98. package/dist/templates/codebuddy/index.d.ts.map +1 -1
  99. package/dist/templates/codebuddy/index.js +6 -36
  100. package/dist/templates/codebuddy/index.js.map +1 -1
  101. package/dist/templates/codebuddy/settings.json +59 -0
  102. package/dist/templates/codex/agents/trellis-check.toml +38 -0
  103. package/dist/templates/codex/agents/{implement.toml → trellis-implement.toml} +1 -1
  104. package/dist/templates/codex/agents/trellis-research.toml +60 -0
  105. package/dist/templates/codex/config.toml +10 -0
  106. package/dist/templates/codex/hooks/session-start.py +65 -29
  107. package/dist/templates/codex/hooks.json +11 -0
  108. package/dist/templates/codex/index.d.ts +0 -1
  109. package/dist/templates/codex/index.d.ts.map +1 -1
  110. package/dist/templates/codex/index.js +1 -8
  111. package/dist/templates/codex/index.js.map +1 -1
  112. package/dist/templates/codex/skills/start/SKILL.md +1 -1
  113. package/dist/templates/common/commands/continue.md +51 -0
  114. package/dist/templates/common/commands/finish-work.md +32 -0
  115. package/dist/templates/common/commands/start.md +56 -0
  116. package/dist/templates/common/index.d.ts +28 -0
  117. package/dist/templates/common/index.d.ts.map +1 -0
  118. package/dist/templates/common/index.js +55 -0
  119. package/dist/templates/common/index.js.map +1 -0
  120. package/dist/templates/{droid/commands/trellis → common/skills}/brainstorm.md +51 -12
  121. package/dist/templates/{iflow/commands/trellis → common/skills}/break-loop.md +4 -4
  122. package/dist/templates/common/skills/check.md +87 -0
  123. package/dist/templates/{codebuddy/commands/trellis → common/skills}/update-spec.md +18 -21
  124. package/dist/templates/copilot/hooks/session-start.py +65 -29
  125. package/dist/templates/copilot/hooks.json +8 -0
  126. package/dist/templates/copilot/prompts/start.prompt.md +13 -16
  127. package/dist/templates/cursor/agents/trellis-check.md +94 -0
  128. package/dist/templates/cursor/agents/trellis-implement.md +94 -0
  129. package/dist/templates/cursor/agents/trellis-research.md +137 -0
  130. package/dist/templates/cursor/hooks.json +24 -0
  131. package/dist/templates/cursor/index.d.ts +6 -17
  132. package/dist/templates/cursor/index.d.ts.map +1 -1
  133. package/dist/templates/cursor/index.js +6 -37
  134. package/dist/templates/cursor/index.js.map +1 -1
  135. package/dist/templates/droid/droids/trellis-check.md +94 -0
  136. package/dist/templates/droid/droids/trellis-implement.md +94 -0
  137. package/dist/templates/droid/droids/trellis-research.md +137 -0
  138. package/dist/templates/droid/index.d.ts +7 -19
  139. package/dist/templates/droid/index.d.ts.map +1 -1
  140. package/dist/templates/droid/index.js +7 -39
  141. package/dist/templates/droid/index.js.map +1 -1
  142. package/dist/templates/droid/settings.json +59 -0
  143. package/dist/templates/extract.d.ts +7 -193
  144. package/dist/templates/extract.d.ts.map +1 -1
  145. package/dist/templates/extract.js +7 -310
  146. package/dist/templates/extract.js.map +1 -1
  147. package/dist/templates/gemini/agents/trellis-check.md +94 -0
  148. package/dist/templates/gemini/agents/trellis-implement.md +94 -0
  149. package/dist/templates/gemini/agents/trellis-research.md +137 -0
  150. package/dist/templates/gemini/index.d.ts +6 -14
  151. package/dist/templates/gemini/index.d.ts.map +1 -1
  152. package/dist/templates/gemini/index.js +6 -37
  153. package/dist/templates/gemini/index.js.map +1 -1
  154. package/dist/templates/gemini/settings.json +28 -0
  155. package/dist/templates/kiro/agents/trellis-check.json +13 -0
  156. package/dist/templates/kiro/agents/trellis-implement.json +13 -0
  157. package/dist/templates/kiro/agents/trellis-research.json +21 -0
  158. package/dist/templates/kiro/index.d.ts +11 -11
  159. package/dist/templates/kiro/index.d.ts.map +1 -1
  160. package/dist/templates/kiro/index.js +11 -33
  161. package/dist/templates/kiro/index.js.map +1 -1
  162. package/dist/templates/opencode/agents/{check.md → trellis-check.md} +3 -30
  163. package/dist/templates/opencode/agents/{implement.md → trellis-implement.md} +1 -1
  164. package/dist/templates/opencode/agents/{research.md → trellis-research.md} +1 -2
  165. package/dist/templates/opencode/plugins/inject-subagent-context.js +18 -190
  166. package/dist/templates/opencode/plugins/inject-workflow-state.js +172 -0
  167. package/dist/templates/opencode/plugins/session-start.js +76 -39
  168. package/dist/templates/qoder/agents/trellis-check.md +94 -0
  169. package/dist/templates/qoder/agents/trellis-implement.md +94 -0
  170. package/dist/templates/qoder/agents/trellis-research.md +137 -0
  171. package/dist/templates/qoder/index.d.ts +7 -10
  172. package/dist/templates/qoder/index.d.ts.map +1 -1
  173. package/dist/templates/qoder/index.js +7 -32
  174. package/dist/templates/qoder/index.js.map +1 -1
  175. package/dist/templates/qoder/settings.json +47 -0
  176. package/dist/templates/shared-hooks/index.d.ts +19 -0
  177. package/dist/templates/shared-hooks/index.d.ts.map +1 -0
  178. package/dist/templates/shared-hooks/index.js +30 -0
  179. package/dist/templates/shared-hooks/index.js.map +1 -0
  180. package/dist/templates/{iflow/hooks → shared-hooks}/inject-subagent-context.py +77 -266
  181. package/dist/templates/shared-hooks/inject-workflow-state.py +244 -0
  182. package/dist/templates/{claude/hooks → shared-hooks}/session-start.py +172 -55
  183. package/dist/templates/template-utils.d.ts +26 -0
  184. package/dist/templates/template-utils.d.ts.map +1 -0
  185. package/dist/templates/template-utils.js +60 -0
  186. package/dist/templates/template-utils.js.map +1 -0
  187. package/dist/templates/trellis/config.yaml +6 -0
  188. package/dist/templates/trellis/index.d.ts +1 -15
  189. package/dist/templates/trellis/index.d.ts.map +1 -1
  190. package/dist/templates/trellis/index.js +2 -29
  191. package/dist/templates/trellis/index.js.map +1 -1
  192. package/dist/templates/trellis/scripts/common/cli_adapter.py +31 -8
  193. package/dist/templates/trellis/scripts/common/config.py +126 -1
  194. package/dist/templates/trellis/scripts/common/git_context.py +25 -2
  195. package/dist/templates/trellis/scripts/common/task_context.py +23 -28
  196. package/dist/templates/trellis/scripts/common/task_store.py +0 -12
  197. package/dist/templates/trellis/scripts/common/types.py +0 -2
  198. package/dist/templates/trellis/scripts/common/workflow_phase.py +176 -0
  199. package/dist/templates/trellis/scripts/task.py +13 -35
  200. package/dist/templates/trellis/workflow.md +283 -298
  201. package/dist/types/ai-tools.d.ts +30 -3
  202. package/dist/types/ai-tools.d.ts.map +1 -1
  203. package/dist/types/ai-tools.js +119 -15
  204. package/dist/types/ai-tools.js.map +1 -1
  205. package/dist/types/migration.d.ts +8 -1
  206. package/dist/types/migration.d.ts.map +1 -1
  207. package/dist/utils/project-detector.d.ts +2 -0
  208. package/dist/utils/project-detector.d.ts.map +1 -1
  209. package/dist/utils/project-detector.js +120 -11
  210. package/dist/utils/project-detector.js.map +1 -1
  211. package/dist/utils/task-json.d.ts +46 -0
  212. package/dist/utils/task-json.d.ts.map +1 -0
  213. package/dist/utils/task-json.js +49 -0
  214. package/dist/utils/task-json.js.map +1 -0
  215. package/package.json +3 -2
  216. package/dist/configurators/iflow.d.ts +0 -33
  217. package/dist/configurators/iflow.d.ts.map +0 -1
  218. package/dist/configurators/iflow.js +0 -99
  219. package/dist/configurators/iflow.js.map +0 -1
  220. package/dist/templates/antigravity/index.d.ts +0 -12
  221. package/dist/templates/antigravity/index.d.ts.map +0 -1
  222. package/dist/templates/antigravity/index.js +0 -29
  223. package/dist/templates/antigravity/index.js.map +0 -1
  224. package/dist/templates/claude/agents/debug.md +0 -106
  225. package/dist/templates/claude/agents/dispatch.md +0 -213
  226. package/dist/templates/claude/agents/plan.md +0 -396
  227. package/dist/templates/claude/agents/research.md +0 -120
  228. package/dist/templates/claude/commands/trellis/brainstorm.md +0 -487
  229. package/dist/templates/claude/commands/trellis/break-loop.md +0 -125
  230. package/dist/templates/claude/commands/trellis/check-cross-layer.md +0 -153
  231. package/dist/templates/claude/commands/trellis/check.md +0 -25
  232. package/dist/templates/claude/commands/trellis/create-command.md +0 -154
  233. package/dist/templates/claude/commands/trellis/finish-work.md +0 -153
  234. package/dist/templates/claude/commands/trellis/integrate-skill.md +0 -219
  235. package/dist/templates/claude/commands/trellis/onboard.md +0 -358
  236. package/dist/templates/claude/commands/trellis/parallel.md +0 -192
  237. package/dist/templates/claude/commands/trellis/record-session.md +0 -62
  238. package/dist/templates/claude/commands/trellis/start.md +0 -393
  239. package/dist/templates/claude/commands/trellis/update-spec.md +0 -354
  240. package/dist/templates/claude/hooks/inject-subagent-context.py +0 -803
  241. package/dist/templates/claude/hooks/ralph-loop.py +0 -396
  242. package/dist/templates/codebuddy/commands/trellis/before-dev.md +0 -29
  243. package/dist/templates/codebuddy/commands/trellis/brainstorm.md +0 -487
  244. package/dist/templates/codebuddy/commands/trellis/break-loop.md +0 -107
  245. package/dist/templates/codebuddy/commands/trellis/check-cross-layer.md +0 -153
  246. package/dist/templates/codebuddy/commands/trellis/check.md +0 -25
  247. package/dist/templates/codebuddy/commands/trellis/create-command.md +0 -154
  248. package/dist/templates/codebuddy/commands/trellis/finish-work.md +0 -143
  249. package/dist/templates/codebuddy/commands/trellis/integrate-skill.md +0 -219
  250. package/dist/templates/codebuddy/commands/trellis/onboard.md +0 -358
  251. package/dist/templates/codebuddy/commands/trellis/record-session.md +0 -61
  252. package/dist/templates/codebuddy/commands/trellis/start.md +0 -373
  253. package/dist/templates/codex/agents/check.toml +0 -23
  254. package/dist/templates/codex/agents/research.toml +0 -26
  255. package/dist/templates/codex/codex-skills/parallel/SKILL.md +0 -194
  256. package/dist/templates/cursor/commands/trellis-before-dev.md +0 -29
  257. package/dist/templates/cursor/commands/trellis-brainstorm.md +0 -487
  258. package/dist/templates/cursor/commands/trellis-break-loop.md +0 -107
  259. package/dist/templates/cursor/commands/trellis-check-cross-layer.md +0 -153
  260. package/dist/templates/cursor/commands/trellis-check.md +0 -25
  261. package/dist/templates/cursor/commands/trellis-create-command.md +0 -154
  262. package/dist/templates/cursor/commands/trellis-finish-work.md +0 -143
  263. package/dist/templates/cursor/commands/trellis-integrate-skill.md +0 -219
  264. package/dist/templates/cursor/commands/trellis-onboard.md +0 -358
  265. package/dist/templates/cursor/commands/trellis-record-session.md +0 -62
  266. package/dist/templates/cursor/commands/trellis-start.md +0 -373
  267. package/dist/templates/cursor/commands/trellis-update-spec.md +0 -354
  268. package/dist/templates/droid/commands/trellis/before-dev.md +0 -33
  269. package/dist/templates/droid/commands/trellis/break-loop.md +0 -111
  270. package/dist/templates/droid/commands/trellis/check-cross-layer.md +0 -157
  271. package/dist/templates/droid/commands/trellis/check.md +0 -29
  272. package/dist/templates/droid/commands/trellis/create-command.md +0 -158
  273. package/dist/templates/droid/commands/trellis/finish-work.md +0 -147
  274. package/dist/templates/droid/commands/trellis/integrate-skill.md +0 -223
  275. package/dist/templates/droid/commands/trellis/onboard.md +0 -362
  276. package/dist/templates/droid/commands/trellis/record-session.md +0 -66
  277. package/dist/templates/droid/commands/trellis/start.md +0 -377
  278. package/dist/templates/droid/commands/trellis/update-spec.md +0 -358
  279. package/dist/templates/gemini/commands/trellis/before-dev.toml +0 -33
  280. package/dist/templates/gemini/commands/trellis/brainstorm.toml +0 -435
  281. package/dist/templates/gemini/commands/trellis/break-loop.toml +0 -129
  282. package/dist/templates/gemini/commands/trellis/check-cross-layer.toml +0 -147
  283. package/dist/templates/gemini/commands/trellis/check.toml +0 -29
  284. package/dist/templates/gemini/commands/trellis/create-command.toml +0 -119
  285. package/dist/templates/gemini/commands/trellis/finish-work.toml +0 -133
  286. package/dist/templates/gemini/commands/trellis/integrate-skill.toml +0 -104
  287. package/dist/templates/gemini/commands/trellis/onboard.toml +0 -111
  288. package/dist/templates/gemini/commands/trellis/record-session.toml +0 -66
  289. package/dist/templates/gemini/commands/trellis/start.toml +0 -354
  290. package/dist/templates/gemini/commands/trellis/update-spec.toml +0 -132
  291. package/dist/templates/iflow/agents/debug.md +0 -106
  292. package/dist/templates/iflow/agents/dispatch.md +0 -213
  293. package/dist/templates/iflow/agents/plan.md +0 -396
  294. package/dist/templates/iflow/agents/research.md +0 -120
  295. package/dist/templates/iflow/commands/trellis/before-dev.md +0 -29
  296. package/dist/templates/iflow/commands/trellis/brainstorm.md +0 -487
  297. package/dist/templates/iflow/commands/trellis/check-cross-layer.md +0 -153
  298. package/dist/templates/iflow/commands/trellis/check.md +0 -25
  299. package/dist/templates/iflow/commands/trellis/create-command.md +0 -152
  300. package/dist/templates/iflow/commands/trellis/finish-work.md +0 -153
  301. package/dist/templates/iflow/commands/trellis/integrate-skill.md +0 -219
  302. package/dist/templates/iflow/commands/trellis/onboard.md +0 -358
  303. package/dist/templates/iflow/commands/trellis/parallel.md +0 -192
  304. package/dist/templates/iflow/commands/trellis/record-session.md +0 -62
  305. package/dist/templates/iflow/commands/trellis/start.md +0 -393
  306. package/dist/templates/iflow/commands/trellis/update-spec.md +0 -354
  307. package/dist/templates/iflow/hooks/ralph-loop.py +0 -395
  308. package/dist/templates/iflow/hooks/session-start.py +0 -403
  309. package/dist/templates/iflow/index.d.ts +0 -54
  310. package/dist/templates/iflow/index.d.ts.map +0 -1
  311. package/dist/templates/iflow/index.js +0 -85
  312. package/dist/templates/iflow/index.js.map +0 -1
  313. package/dist/templates/iflow/settings.json +0 -60
  314. package/dist/templates/kilo/index.d.ts +0 -16
  315. package/dist/templates/kilo/index.d.ts.map +0 -1
  316. package/dist/templates/kilo/index.js +0 -39
  317. package/dist/templates/kilo/index.js.map +0 -1
  318. package/dist/templates/kilo/workflows/before-dev.md +0 -29
  319. package/dist/templates/kilo/workflows/brainstorm.md +0 -487
  320. package/dist/templates/kilo/workflows/break-loop.md +0 -125
  321. package/dist/templates/kilo/workflows/check-cross-layer.md +0 -153
  322. package/dist/templates/kilo/workflows/check.md +0 -25
  323. package/dist/templates/kilo/workflows/create-command.md +0 -152
  324. package/dist/templates/kilo/workflows/finish-work.md +0 -129
  325. package/dist/templates/kilo/workflows/integrate-skill.md +0 -219
  326. package/dist/templates/kilo/workflows/onboard.md +0 -358
  327. package/dist/templates/kilo/workflows/parallel.md +0 -193
  328. package/dist/templates/kilo/workflows/record-session.md +0 -62
  329. package/dist/templates/kilo/workflows/start.md +0 -387
  330. package/dist/templates/kilo/workflows/update-spec.md +0 -285
  331. package/dist/templates/kiro/skills/before-dev/SKILL.md +0 -34
  332. package/dist/templates/kiro/skills/brainstorm/SKILL.md +0 -492
  333. package/dist/templates/kiro/skills/break-loop/SKILL.md +0 -130
  334. package/dist/templates/kiro/skills/check/SKILL.md +0 -30
  335. package/dist/templates/kiro/skills/check-cross-layer/SKILL.md +0 -158
  336. package/dist/templates/kiro/skills/create-command/SKILL.md +0 -101
  337. package/dist/templates/kiro/skills/finish-work/SKILL.md +0 -148
  338. package/dist/templates/kiro/skills/integrate-skill/SKILL.md +0 -221
  339. package/dist/templates/kiro/skills/onboard/SKILL.md +0 -363
  340. package/dist/templates/kiro/skills/record-session/SKILL.md +0 -67
  341. package/dist/templates/kiro/skills/start/SKILL.md +0 -351
  342. package/dist/templates/kiro/skills/update-spec/SKILL.md +0 -335
  343. package/dist/templates/markdown/spec/backend/directory-structure.md +0 -292
  344. package/dist/templates/markdown/spec/backend/index.md +0 -40
  345. package/dist/templates/markdown/spec/backend/script-conventions.md +0 -742
  346. package/dist/templates/markdown/spec/guides/code-reuse-thinking-guide.md +0 -118
  347. package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md +0 -394
  348. package/dist/templates/opencode/agents/debug.md +0 -129
  349. package/dist/templates/opencode/agents/dispatch.md +0 -223
  350. package/dist/templates/opencode/agents/trellis-plan.md +0 -427
  351. package/dist/templates/opencode/commands/trellis/before-dev.md +0 -29
  352. package/dist/templates/opencode/commands/trellis/brainstorm.md +0 -487
  353. package/dist/templates/opencode/commands/trellis/break-loop.md +0 -125
  354. package/dist/templates/opencode/commands/trellis/check-cross-layer.md +0 -153
  355. package/dist/templates/opencode/commands/trellis/check.md +0 -25
  356. package/dist/templates/opencode/commands/trellis/create-command.md +0 -154
  357. package/dist/templates/opencode/commands/trellis/finish-work.md +0 -144
  358. package/dist/templates/opencode/commands/trellis/integrate-skill.md +0 -219
  359. package/dist/templates/opencode/commands/trellis/migrate-specs.md +0 -0
  360. package/dist/templates/opencode/commands/trellis/onboard.md +0 -358
  361. package/dist/templates/opencode/commands/trellis/parallel.md +0 -193
  362. package/dist/templates/opencode/commands/trellis/record-session.md +0 -62
  363. package/dist/templates/opencode/commands/trellis/start.md +0 -351
  364. package/dist/templates/opencode/commands/trellis/update-spec.md +0 -354
  365. package/dist/templates/qoder/skills/before-dev/SKILL.md +0 -34
  366. package/dist/templates/qoder/skills/brainstorm/SKILL.md +0 -492
  367. package/dist/templates/qoder/skills/break-loop/SKILL.md +0 -130
  368. package/dist/templates/qoder/skills/check/SKILL.md +0 -30
  369. package/dist/templates/qoder/skills/check-cross-layer/SKILL.md +0 -158
  370. package/dist/templates/qoder/skills/create-command/SKILL.md +0 -101
  371. package/dist/templates/qoder/skills/finish-work/SKILL.md +0 -134
  372. package/dist/templates/qoder/skills/integrate-skill/SKILL.md +0 -221
  373. package/dist/templates/qoder/skills/onboard/SKILL.md +0 -363
  374. package/dist/templates/qoder/skills/record-session/SKILL.md +0 -67
  375. package/dist/templates/qoder/skills/start/SKILL.md +0 -388
  376. package/dist/templates/qoder/skills/update-spec/SKILL.md +0 -290
  377. package/dist/templates/trellis/scripts/common/phase.py +0 -254
  378. package/dist/templates/trellis/scripts/common/registry.py +0 -335
  379. package/dist/templates/trellis/scripts/common/worktree.py +0 -305
  380. package/dist/templates/trellis/scripts/create_bootstrap.py +0 -298
  381. package/dist/templates/trellis/scripts/multi_agent/__init__.py +0 -5
  382. package/dist/templates/trellis/scripts/multi_agent/_bootstrap.py +0 -17
  383. package/dist/templates/trellis/scripts/multi_agent/cleanup.py +0 -398
  384. package/dist/templates/trellis/scripts/multi_agent/create_pr.py +0 -620
  385. package/dist/templates/trellis/scripts/multi_agent/plan.py +0 -213
  386. package/dist/templates/trellis/scripts/multi_agent/start.py +0 -539
  387. package/dist/templates/trellis/scripts/multi_agent/status.py +0 -76
  388. package/dist/templates/trellis/scripts/multi_agent/status_display.py +0 -542
  389. package/dist/templates/trellis/scripts/multi_agent/status_monitor.py +0 -225
  390. package/dist/templates/trellis/scripts-shell-archive/add-session.sh +0 -384
  391. package/dist/templates/trellis/scripts-shell-archive/common/developer.sh +0 -129
  392. package/dist/templates/trellis/scripts-shell-archive/common/git-context.sh +0 -263
  393. package/dist/templates/trellis/scripts-shell-archive/common/paths.sh +0 -208
  394. package/dist/templates/trellis/scripts-shell-archive/common/phase.sh +0 -150
  395. package/dist/templates/trellis/scripts-shell-archive/common/registry.sh +0 -247
  396. package/dist/templates/trellis/scripts-shell-archive/common/task-queue.sh +0 -142
  397. package/dist/templates/trellis/scripts-shell-archive/common/task-utils.sh +0 -151
  398. package/dist/templates/trellis/scripts-shell-archive/common/worktree.sh +0 -128
  399. package/dist/templates/trellis/scripts-shell-archive/create-bootstrap.sh +0 -299
  400. package/dist/templates/trellis/scripts-shell-archive/get-context.sh +0 -7
  401. package/dist/templates/trellis/scripts-shell-archive/get-developer.sh +0 -15
  402. package/dist/templates/trellis/scripts-shell-archive/init-developer.sh +0 -34
  403. package/dist/templates/trellis/scripts-shell-archive/multi-agent/cleanup.sh +0 -396
  404. package/dist/templates/trellis/scripts-shell-archive/multi-agent/create-pr.sh +0 -241
  405. package/dist/templates/trellis/scripts-shell-archive/multi-agent/plan.sh +0 -207
  406. package/dist/templates/trellis/scripts-shell-archive/multi-agent/start.sh +0 -317
  407. package/dist/templates/trellis/scripts-shell-archive/multi-agent/status.sh +0 -828
  408. package/dist/templates/trellis/scripts-shell-archive/task.sh +0 -1204
  409. package/dist/templates/trellis/worktree.yaml +0 -47
  410. package/dist/templates/windsurf/index.d.ts +0 -21
  411. package/dist/templates/windsurf/index.d.ts.map +0 -1
  412. package/dist/templates/windsurf/index.js +0 -44
  413. package/dist/templates/windsurf/index.js.map +0 -1
  414. package/dist/templates/windsurf/workflows/trellis-before-dev.md +0 -31
  415. package/dist/templates/windsurf/workflows/trellis-brainstorm.md +0 -491
  416. package/dist/templates/windsurf/workflows/trellis-break-loop.md +0 -111
  417. package/dist/templates/windsurf/workflows/trellis-check-cross-layer.md +0 -157
  418. package/dist/templates/windsurf/workflows/trellis-check.md +0 -27
  419. package/dist/templates/windsurf/workflows/trellis-create-command.md +0 -154
  420. package/dist/templates/windsurf/workflows/trellis-finish-work.md +0 -147
  421. package/dist/templates/windsurf/workflows/trellis-integrate-skill.md +0 -220
  422. package/dist/templates/windsurf/workflows/trellis-onboard.md +0 -362
  423. package/dist/templates/windsurf/workflows/trellis-record-session.md +0 -66
  424. package/dist/templates/windsurf/workflows/trellis-start.md +0 -373
  425. package/dist/templates/windsurf/workflows/trellis-update-spec.md +0 -358
  426. /package/dist/templates/{claude/commands/trellis → common/skills}/before-dev.md +0 -0
  427. /package/dist/templates/{claude/hooks → shared-hooks}/statusline.py +0 -0
@@ -1,29 +0,0 @@
1
- Read the relevant development guidelines before starting your task.
2
-
3
- Execute these steps:
4
-
5
- 1. **Discover packages and their spec layers**:
6
- ```bash
7
- python3 ./.trellis/scripts/get_context.py --mode packages
8
- ```
9
-
10
- 2. **Identify which specs apply** to your task based on:
11
- - Which package you're modifying (e.g., `cli/`, `docs-site/`)
12
- - What type of work (backend, frontend, unit-test, docs, etc.)
13
-
14
- 3. **Read the spec index** for each relevant module:
15
- ```bash
16
- cat .trellis/spec/<package>/<layer>/index.md
17
- ```
18
- Follow the **"Pre-Development Checklist"** section in the index.
19
-
20
- 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.
21
-
22
- 5. **Always read shared guides**:
23
- ```bash
24
- cat .trellis/spec/guides/index.md
25
- ```
26
-
27
- 6. Understand the coding standards and patterns you need to follow, then proceed with your development plan.
28
-
29
- This step is **mandatory** before writing any code.
@@ -1,487 +0,0 @@
1
- # Brainstorm - Requirements Discovery (AI Coding Enhanced)
2
-
3
- Guide AI through collaborative requirements discovery **before implementation**, optimized for AI coding workflows:
4
-
5
- * **Task-first** (capture ideas immediately)
6
- * **Action-before-asking** (reduce low-value questions)
7
- * **Research-first** for technical choices (avoid asking users to invent options)
8
- * **Diverge → Converge** (expand thinking, then lock MVP)
9
-
10
- ---
11
-
12
- ## When to Use
13
-
14
- Triggered from `/trellis:start` when the user describes a development task, especially when:
15
-
16
- * requirements are unclear or evolving
17
- * there are multiple valid implementation paths
18
- * trade-offs matter (UX, reliability, maintainability, cost, performance)
19
- * the user might not know the best options up front
20
-
21
- ---
22
-
23
- ## Core Principles (Non-negotiable)
24
-
25
- 1. **Task-first (capture early)**
26
- Always ensure a task exists at the start so the user's ideas are recorded immediately.
27
-
28
- 2. **Action before asking**
29
- If you can derive the answer from repo code, docs, configs, conventions, or quick research — do that first.
30
-
31
- 3. **One question per message**
32
- Never overwhelm the user with a list of questions. Ask one, update PRD, repeat.
33
-
34
- 4. **Prefer concrete options**
35
- For preference/decision questions, present 2–3 feasible, specific approaches with trade-offs.
36
-
37
- 5. **Research-first for technical choices**
38
- If the decision depends on industry conventions / similar tools / established patterns, do research first, then propose options.
39
-
40
- 6. **Diverge → Converge**
41
- After initial understanding, proactively consider future evolution, related scenarios, and failure/edge cases — then converge to an MVP with explicit out-of-scope.
42
-
43
- 7. **No meta questions**
44
- Do not ask "should I search?" or "can you paste the code so I can continue?"
45
- If you need information: search/inspect. If blocked: ask the minimal blocking question.
46
-
47
- ---
48
-
49
- ## Step 0: Ensure Task Exists (ALWAYS)
50
-
51
- Before any Q&A, ensure a task exists. If none exists, create one immediately.
52
-
53
- * Use a **temporary working title** derived from the user's message.
54
- * It's OK if the title is imperfect — refine later in PRD.
55
-
56
- ```bash
57
- TASK_DIR=$(python3 ./.trellis/scripts/task.py create "brainstorm: <short goal>" --slug <auto>)
58
- ```
59
-
60
- Create/seed `prd.md` immediately with what you know:
61
-
62
- ```markdown
63
- # brainstorm: <short goal>
64
-
65
- ## Goal
66
-
67
- <one paragraph: what + why>
68
-
69
- ## What I already know
70
-
71
- * <facts from user message>
72
- * <facts discovered from repo/docs>
73
-
74
- ## Assumptions (temporary)
75
-
76
- * <assumptions to validate>
77
-
78
- ## Open Questions
79
-
80
- * <ONLY Blocking / Preference questions; keep list short>
81
-
82
- ## Requirements (evolving)
83
-
84
- * <start with what is known>
85
-
86
- ## Acceptance Criteria (evolving)
87
-
88
- * [ ] <testable criterion>
89
-
90
- ## Definition of Done (team quality bar)
91
-
92
- * Tests added/updated (unit/integration where appropriate)
93
- * Lint / typecheck / CI green
94
- * Docs/notes updated if behavior changes
95
- * Rollout/rollback considered if risky
96
-
97
- ## Out of Scope (explicit)
98
-
99
- * <what we will not do in this task>
100
-
101
- ## Technical Notes
102
-
103
- * <files inspected, constraints, links, references>
104
- * <research notes summary if applicable>
105
- ```
106
-
107
- ---
108
-
109
- ## Step 1: Auto-Context (DO THIS BEFORE ASKING QUESTIONS)
110
-
111
- Before asking questions like "what does the code look like?", gather context yourself:
112
-
113
- ### Repo inspection checklist
114
-
115
- * Identify likely modules/files impacted
116
- * Locate existing patterns (similar features, conventions, error handling style)
117
- * Check configs, scripts, existing command definitions
118
- * Note any constraints (runtime, dependency policy, build tooling)
119
-
120
- ### Documentation checklist
121
-
122
- * Look for existing PRDs/specs/templates
123
- * Look for command usage examples, README, ADRs if any
124
-
125
- Write findings into PRD:
126
-
127
- * Add to `What I already know`
128
- * Add constraints/links to `Technical Notes`
129
-
130
- ---
131
-
132
- ## Step 2: Classify Complexity (still useful, not gating task creation)
133
-
134
- | Complexity | Criteria | Action |
135
- | ------------ | ------------------------------------------------------ | ------------------------------------------- |
136
- | **Trivial** | Single-line fix, typo, obvious change | Skip brainstorm, implement directly |
137
- | **Simple** | Clear goal, 1–2 files, scope well-defined | Ask 1 confirm question, then implement |
138
- | **Moderate** | Multiple files, some ambiguity | Light brainstorm (2–3 high-value questions) |
139
- | **Complex** | Vague goal, architectural choices, multiple approaches | Full brainstorm |
140
-
141
- > Note: Task already exists from Step 0. Classification only affects depth of brainstorming.
142
-
143
- ---
144
-
145
- ## Step 3: Question Gate (Ask ONLY high-value questions)
146
-
147
- Before asking ANY question, run the following gate:
148
-
149
- ### Gate A — Can I derive this without the user?
150
-
151
- If answer is available via:
152
-
153
- * repo inspection (code/config)
154
- * docs/specs/conventions
155
- * quick market/OSS research
156
-
157
- → **Do not ask.** Fetch it, summarize, update PRD.
158
-
159
- ### Gate B — Is this a meta/lazy question?
160
-
161
- Examples:
162
-
163
- * "Should I search?"
164
- * "Can you paste the code so I can proceed?"
165
- * "What does the code look like?" (when repo is available)
166
-
167
- → **Do not ask.** Take action.
168
-
169
- ### Gate C — What type of question is it?
170
-
171
- * **Blocking**: cannot proceed without user input
172
- * **Preference**: multiple valid choices, depends on product/UX/risk preference
173
- * **Derivable**: should be answered by inspection/research
174
-
175
- → Only ask **Blocking** or **Preference**.
176
-
177
- ---
178
-
179
- ## Step 4: Research-first Mode (Mandatory for technical choices)
180
-
181
- ### Trigger conditions (any → research-first)
182
-
183
- * The task involves selecting an approach, library, protocol, framework, template system, plugin mechanism, or CLI UX convention
184
- * The user asks for "best practice", "how others do it", "recommendation"
185
- * The user can't reasonably enumerate options
186
-
187
- ### Research steps
188
-
189
- 1. Identify 2–4 comparable tools/patterns
190
- 2. Summarize common conventions and why they exist
191
- 3. Map conventions onto our repo constraints
192
- 4. Produce **2–3 feasible approaches** for our project
193
-
194
- ### Research output format (PRD)
195
-
196
- Add a section in PRD (either within Technical Notes or as its own):
197
-
198
- ```markdown
199
- ## Research Notes
200
-
201
- ### What similar tools do
202
-
203
- * ...
204
- * ...
205
-
206
- ### Constraints from our repo/project
207
-
208
- * ...
209
-
210
- ### Feasible approaches here
211
-
212
- **Approach A: <name>** (Recommended)
213
-
214
- * How it works:
215
- * Pros:
216
- * Cons:
217
-
218
- **Approach B: <name>**
219
-
220
- * How it works:
221
- * Pros:
222
- * Cons:
223
-
224
- **Approach C: <name>** (optional)
225
-
226
- * ...
227
- ```
228
-
229
- Then ask **one** preference question:
230
-
231
- * "Which approach do you prefer: A / B / C (or other)?"
232
-
233
- ---
234
-
235
- ## Step 5: Expansion Sweep (DIVERGE) — Required after initial understanding
236
-
237
- After you can summarize the goal, proactively broaden thinking before converging.
238
-
239
- ### Expansion categories (keep to 1–2 bullets each)
240
-
241
- 1. **Future evolution**
242
-
243
- * What might this feature become in 1–3 months?
244
- * What extension points are worth preserving now?
245
-
246
- 2. **Related scenarios**
247
-
248
- * What adjacent commands/flows should remain consistent with this?
249
- * Are there parity expectations (create vs update, import vs export, etc.)?
250
-
251
- 3. **Failure & edge cases**
252
-
253
- * Conflicts, offline/network failure, retries, idempotency, compatibility, rollback
254
- * Input validation, security boundaries, permission checks
255
-
256
- ### Expansion message template (to user)
257
-
258
- ```markdown
259
- I understand you want to implement: <current goal>.
260
-
261
- Before diving into design, let me quickly diverge to consider three categories (to avoid rework later):
262
-
263
- 1. Future evolution: <1–2 bullets>
264
- 2. Related scenarios: <1–2 bullets>
265
- 3. Failure/edge cases: <1–2 bullets>
266
-
267
- For this MVP, which would you like to include (or none)?
268
-
269
- 1. Current requirement only (minimal viable)
270
- 2. Add <X> (reserve for future extension)
271
- 3. Add <Y> (improve robustness/consistency)
272
- 4. Other: describe your preference
273
- ```
274
-
275
- Then update PRD:
276
-
277
- * What's in MVP → `Requirements`
278
- * What's excluded → `Out of Scope`
279
-
280
- ---
281
-
282
- ## Step 6: Q&A Loop (CONVERGE)
283
-
284
- ### Rules
285
-
286
- * One question per message
287
- * Prefer multiple-choice when possible
288
- * After each user answer:
289
-
290
- * Update PRD immediately
291
- * Move answered items from `Open Questions` → `Requirements`
292
- * Update `Acceptance Criteria` with testable checkboxes
293
- * Clarify `Out of Scope`
294
-
295
- ### Question priority (recommended)
296
-
297
- 1. **MVP scope boundary** (what is included/excluded)
298
- 2. **Preference decisions** (after presenting concrete options)
299
- 3. **Failure/edge behavior** (only for MVP-critical paths)
300
- 4. **Success metrics & Acceptance Criteria** (what proves it works)
301
-
302
- ### Preferred question format (multiple choice)
303
-
304
- ```markdown
305
- For <topic>, which approach do you prefer?
306
-
307
- 1. **Option A** — <what it means + trade-off>
308
- 2. **Option B** — <what it means + trade-off>
309
- 3. **Option C** — <what it means + trade-off>
310
- 4. **Other** — describe your preference
311
- ```
312
-
313
- ---
314
-
315
- ## Step 7: Propose Approaches + Record Decisions (Complex tasks)
316
-
317
- After requirements are clear enough, propose 2–3 approaches (if not already done via research-first):
318
-
319
- ```markdown
320
- Based on current information, here are 2–3 feasible approaches:
321
-
322
- **Approach A: <name>** (Recommended)
323
-
324
- * How:
325
- * Pros:
326
- * Cons:
327
-
328
- **Approach B: <name>**
329
-
330
- * How:
331
- * Pros:
332
- * Cons:
333
-
334
- Which direction do you prefer?
335
- ```
336
-
337
- Record the outcome in PRD as an ADR-lite section:
338
-
339
- ```markdown
340
- ## Decision (ADR-lite)
341
-
342
- **Context**: Why this decision was needed
343
- **Decision**: Which approach was chosen
344
- **Consequences**: Trade-offs, risks, potential future improvements
345
- ```
346
-
347
- ---
348
-
349
- ## Step 8: Final Confirmation + Implementation Plan
350
-
351
- When open questions are resolved, confirm complete requirements with a structured summary:
352
-
353
- ### Final confirmation format
354
-
355
- ```markdown
356
- Here's my understanding of the complete requirements:
357
-
358
- **Goal**: <one sentence>
359
-
360
- **Requirements**:
361
-
362
- * ...
363
- * ...
364
-
365
- **Acceptance Criteria**:
366
-
367
- * [ ] ...
368
- * [ ] ...
369
-
370
- **Definition of Done**:
371
-
372
- * ...
373
-
374
- **Out of Scope**:
375
-
376
- * ...
377
-
378
- **Technical Approach**:
379
- <brief summary + key decisions>
380
-
381
- **Implementation Plan (small PRs)**:
382
-
383
- * PR1: <scaffolding + tests + minimal plumbing>
384
- * PR2: <core behavior>
385
- * PR3: <edge cases + docs + cleanup>
386
-
387
- Does this look correct? If yes, I'll proceed with implementation.
388
- ```
389
-
390
- ### Subtask Decomposition (Complex Tasks)
391
-
392
- For complex tasks with multiple independent work items, create subtasks:
393
-
394
- ```bash
395
- # Create child tasks
396
- CHILD1=$(python3 ./.trellis/scripts/task.py create "Child task 1" --slug child1 --parent "$TASK_DIR")
397
- CHILD2=$(python3 ./.trellis/scripts/task.py create "Child task 2" --slug child2 --parent "$TASK_DIR")
398
-
399
- # Or link existing tasks
400
- python3 ./.trellis/scripts/task.py add-subtask "$TASK_DIR" "$CHILD_DIR"
401
- ```
402
-
403
- ---
404
-
405
- ## PRD Target Structure (final)
406
-
407
- `prd.md` should converge to:
408
-
409
- ```markdown
410
- # <Task Title>
411
-
412
- ## Goal
413
-
414
- <why + what>
415
-
416
- ## Requirements
417
-
418
- * ...
419
-
420
- ## Acceptance Criteria
421
-
422
- * [ ] ...
423
-
424
- ## Definition of Done
425
-
426
- * ...
427
-
428
- ## Technical Approach
429
-
430
- <key design + decisions>
431
-
432
- ## Decision (ADR-lite)
433
-
434
- Context / Decision / Consequences
435
-
436
- ## Out of Scope
437
-
438
- * ...
439
-
440
- ## Technical Notes
441
-
442
- <constraints, references, files, research notes>
443
- ```
444
-
445
- ---
446
-
447
- ## Anti-Patterns (Hard Avoid)
448
-
449
- * Asking user for code/context that can be derived from repo
450
- * Asking user to choose an approach before presenting concrete options
451
- * Meta questions about whether to research
452
- * Staying narrowly on the initial request without considering evolution/edges
453
- * Letting brainstorming drift without updating PRD
454
-
455
- ---
456
-
457
- ## Integration with Start Workflow
458
-
459
- After brainstorm completes (Step 8 confirmation approved), the flow continues to the Task Workflow's **Phase 2: Prepare for Implementation**:
460
-
461
- ```text
462
- Brainstorm
463
- Step 0: Create task directory + seed PRD
464
- Step 1–7: Discover requirements, research, converge
465
- Step 8: Final confirmation → user approves
466
-
467
- Task Workflow Phase 2 (Prepare for Implementation)
468
- Code-Spec Depth Check (if applicable)
469
- → Research codebase (based on confirmed PRD)
470
- → Configure code-spec context (jsonl files)
471
- → Activate task
472
-
473
- Task Workflow Phase 3 (Execute)
474
- Implement → Check → Complete
475
- ```
476
-
477
- The task directory and PRD already exist from brainstorm, so Phase 1 of the Task Workflow is skipped entirely.
478
-
479
- ---
480
-
481
- ## Related Commands
482
-
483
- | Command | When to Use |
484
- |---------|-------------|
485
- | `/trellis:start` | Entry point that triggers brainstorm |
486
- | `/trellis:finish-work` | After implementation is complete |
487
- | `/trellis:update-spec` | If new patterns emerge during work |
@@ -1,153 +0,0 @@
1
- # Cross-Layer Check
2
-
3
- Check if your changes considered all dimensions. Most bugs come from "didn't think of it", not lack of technical skill.
4
-
5
- > **Note**: This is a **post-implementation** safety net. Ideally, read the [Pre-Implementation Checklist](.trellis/spec/guides/pre-implementation-checklist.md) **before** writing code.
6
-
7
- ---
8
-
9
- ## Related Documents
10
-
11
- | Document | Purpose | Timing |
12
- |----------|---------|--------|
13
- | [Pre-Implementation Checklist](.trellis/spec/guides/pre-implementation-checklist.md) | Questions before coding | **Before** writing code |
14
- | [Code Reuse Thinking Guide](.trellis/spec/guides/code-reuse-thinking-guide.md) | Pattern recognition | During implementation |
15
- | **`/trellis:check-cross-layer`** (this) | Verification check | **After** implementation |
16
-
17
- ---
18
-
19
- ## Execution Steps
20
-
21
- ### 1. Identify Change Scope
22
-
23
- ```bash
24
- git status
25
- git diff --name-only
26
- ```
27
-
28
- ### 2. Select Applicable Check Dimensions
29
-
30
- Based on your change type, execute relevant checks below:
31
-
32
- ---
33
-
34
- ## Dimension A: Cross-Layer Data Flow (Required when 3+ layers)
35
-
36
- **Trigger**: Changes involve 3 or more layers
37
-
38
- | Layer | Common Locations |
39
- |-------|------------------|
40
- | API/Routes | `routes/`, `api/`, `handlers/`, `controllers/` |
41
- | Service/Business Logic | `services/`, `lib/`, `core/`, `domain/` |
42
- | Database/Storage | `db/`, `models/`, `repositories/`, `schema/` |
43
- | UI/Presentation | `components/`, `views/`, `templates/`, `pages/` |
44
- | Utility | `utils/`, `helpers/`, `common/` |
45
-
46
- **Checklist**:
47
- - [ ] Read flow: Database -> Service -> API -> UI
48
- - [ ] Write flow: UI -> API -> Service -> Database
49
- - [ ] Types/schemas correctly passed between layers?
50
- - [ ] Errors properly propagated to caller?
51
- - [ ] Loading/pending states handled at each layer?
52
-
53
- **Detailed Guide**: `.trellis/spec/guides/cross-layer-thinking-guide.md`
54
-
55
- ---
56
-
57
- ## Dimension B: Code Reuse (Required when modifying constants/config)
58
-
59
- **Trigger**:
60
- - Modifying UI constants (label, icon, color)
61
- - Modifying any hardcoded value
62
- - Seeing similar code in multiple places
63
- - Creating a new utility/helper function
64
- - Just finished batch modifications across files
65
-
66
- **Checklist**:
67
- - [ ] Search first: How many places define this value?
68
- ```bash
69
- # Search in source files (adjust extensions for your project)
70
- grep -r "value-to-change" src/
71
- ```
72
- - [ ] If 2+ places define same value -> Should extract to shared constant
73
- - [ ] After modification, all usage sites updated?
74
- - [ ] If creating utility: Does similar utility already exist?
75
-
76
- **Detailed Guide**: `.trellis/spec/guides/code-reuse-thinking-guide.md`
77
-
78
- ---
79
-
80
- ## Dimension B2: New Utility Functions
81
-
82
- **Trigger**: About to create a new utility/helper function
83
-
84
- **Checklist**:
85
- - [ ] Search for existing similar utilities first
86
- ```bash
87
- grep -r "functionNamePattern" src/
88
- ```
89
- - [ ] If similar exists, can you extend it instead?
90
- - [ ] If creating new, is it in the right location (shared vs domain-specific)?
91
-
92
- ---
93
-
94
- ## Dimension B3: After Batch Modifications
95
-
96
- **Trigger**: Just modified similar patterns in multiple files
97
-
98
- **Checklist**:
99
- - [ ] Did you check ALL files with similar patterns?
100
- ```bash
101
- grep -r "patternYouChanged" src/
102
- ```
103
- - [ ] Any files missed that should also be updated?
104
- - [ ] Should this pattern be abstracted to prevent future duplication?
105
-
106
- ---
107
-
108
- ## Dimension C: Import/Dependency Paths (Required when creating new files)
109
-
110
- **Trigger**: Creating new source files
111
-
112
- **Checklist**:
113
- - [ ] Using correct import paths (relative vs absolute)?
114
- - [ ] No circular dependencies?
115
- - [ ] Consistent with project's module organization?
116
-
117
- ---
118
-
119
- ## Dimension D: Same-Layer Consistency
120
-
121
- **Trigger**:
122
- - Modifying display logic or formatting
123
- - Same domain concept used in multiple places
124
-
125
- **Checklist**:
126
- - [ ] Search for other places using same concept
127
- ```bash
128
- grep -r "ConceptName" src/
129
- ```
130
- - [ ] Are these usages consistent?
131
- - [ ] Should they share configuration/constants?
132
-
133
- ---
134
-
135
- ## Common Issues Quick Reference
136
-
137
- | Issue | Root Cause | Prevention |
138
- |-------|------------|------------|
139
- | Changed one place, missed others | Didn't search impact scope | `grep` before changing |
140
- | Data lost at some layer | Didn't check data flow | Trace data source to destination |
141
- | Type/schema mismatch | Cross-layer types inconsistent | Use shared type definitions |
142
- | UI/output inconsistent | Same concept in multiple places | Extract shared constants |
143
- | Similar utility exists | Didn't search first | Search before creating |
144
- | Batch fix incomplete | Didn't verify all occurrences | grep after fixing |
145
-
146
- ---
147
-
148
- ## Output
149
-
150
- Report:
151
- 1. Which dimensions your changes involve
152
- 2. Check results for each dimension
153
- 3. Issues found and fix suggestions
@@ -1,25 +0,0 @@
1
- Check if the code you just wrote follows the development guidelines.
2
-
3
- Execute these steps:
4
-
5
- 1. **Identify changed files**:
6
- ```bash
7
- git diff --name-only HEAD
8
- ```
9
-
10
- 2. **Determine which spec modules apply** based on the changed file paths:
11
- ```bash
12
- python3 ./.trellis/scripts/get_context.py --mode packages
13
- ```
14
-
15
- 3. **Read the spec index** for each relevant module:
16
- ```bash
17
- cat .trellis/spec/<package>/<layer>/index.md
18
- ```
19
- Follow the **"Quality Check"** section in the index.
20
-
21
- 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.
22
-
23
- 5. **Run lint and typecheck** for the affected package.
24
-
25
- 6. **Report any violations** and fix them if found.