@ibotor/smart-trellis 0.5.19

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 (520) hide show
  1. package/LICENSE +235 -0
  2. package/README.md +263 -0
  3. package/bin/smart-trellis.js +3 -0
  4. package/bin/trellis.js +3 -0
  5. package/dist/cli/index.d.ts +3 -0
  6. package/dist/cli/index.d.ts.map +1 -0
  7. package/dist/cli/index.js +132 -0
  8. package/dist/cli/index.js.map +1 -0
  9. package/dist/cli/smart.d.ts +2 -0
  10. package/dist/cli/smart.d.ts.map +1 -0
  11. package/dist/cli/smart.js +41 -0
  12. package/dist/cli/smart.js.map +1 -0
  13. package/dist/commands/init.d.ts +56 -0
  14. package/dist/commands/init.d.ts.map +1 -0
  15. package/dist/commands/init.js +1466 -0
  16. package/dist/commands/init.js.map +1 -0
  17. package/dist/commands/smart-init.d.ts +22 -0
  18. package/dist/commands/smart-init.d.ts.map +1 -0
  19. package/dist/commands/smart-init.js +122 -0
  20. package/dist/commands/smart-init.js.map +1 -0
  21. package/dist/commands/uninstall.d.ts +27 -0
  22. package/dist/commands/uninstall.d.ts.map +1 -0
  23. package/dist/commands/uninstall.js +339 -0
  24. package/dist/commands/uninstall.js.map +1 -0
  25. package/dist/commands/update.d.ts +72 -0
  26. package/dist/commands/update.d.ts.map +1 -0
  27. package/dist/commands/update.js +1926 -0
  28. package/dist/commands/update.js.map +1 -0
  29. package/dist/configurators/antigravity.d.ts +7 -0
  30. package/dist/configurators/antigravity.d.ts.map +1 -0
  31. package/dist/configurators/antigravity.js +19 -0
  32. package/dist/configurators/antigravity.js.map +1 -0
  33. package/dist/configurators/claude.d.ts +9 -0
  34. package/dist/configurators/claude.d.ts.map +1 -0
  35. package/dist/configurators/claude.js +72 -0
  36. package/dist/configurators/claude.js.map +1 -0
  37. package/dist/configurators/codebuddy.d.ts +10 -0
  38. package/dist/configurators/codebuddy.d.ts.map +1 -0
  39. package/dist/configurators/codebuddy.js +30 -0
  40. package/dist/configurators/codebuddy.js.map +1 -0
  41. package/dist/configurators/codex.d.ts +8 -0
  42. package/dist/configurators/codex.d.ts.map +1 -0
  43. package/dist/configurators/codex.js +85 -0
  44. package/dist/configurators/codex.js.map +1 -0
  45. package/dist/configurators/copilot.d.ts +10 -0
  46. package/dist/configurators/copilot.d.ts.map +1 -0
  47. package/dist/configurators/copilot.js +51 -0
  48. package/dist/configurators/copilot.js.map +1 -0
  49. package/dist/configurators/cursor.d.ts +10 -0
  50. package/dist/configurators/cursor.d.ts.map +1 -0
  51. package/dist/configurators/cursor.js +29 -0
  52. package/dist/configurators/cursor.js.map +1 -0
  53. package/dist/configurators/droid.d.ts +10 -0
  54. package/dist/configurators/droid.d.ts.map +1 -0
  55. package/dist/configurators/droid.js +30 -0
  56. package/dist/configurators/droid.js.map +1 -0
  57. package/dist/configurators/gemini.d.ts +16 -0
  58. package/dist/configurators/gemini.d.ts.map +1 -0
  59. package/dist/configurators/gemini.js +38 -0
  60. package/dist/configurators/gemini.js.map +1 -0
  61. package/dist/configurators/index.d.ts +65 -0
  62. package/dist/configurators/index.d.ts.map +1 -0
  63. package/dist/configurators/index.js +367 -0
  64. package/dist/configurators/index.js.map +1 -0
  65. package/dist/configurators/kilo.d.ts +7 -0
  66. package/dist/configurators/kilo.d.ts.map +1 -0
  67. package/dist/configurators/kilo.js +19 -0
  68. package/dist/configurators/kilo.js.map +1 -0
  69. package/dist/configurators/kiro.d.ts +8 -0
  70. package/dist/configurators/kiro.d.ts.map +1 -0
  71. package/dist/configurators/kiro.js +24 -0
  72. package/dist/configurators/kiro.js.map +1 -0
  73. package/dist/configurators/opencode.d.ts +14 -0
  74. package/dist/configurators/opencode.d.ts.map +1 -0
  75. package/dist/configurators/opencode.js +96 -0
  76. package/dist/configurators/opencode.js.map +1 -0
  77. package/dist/configurators/pi.d.ts +3 -0
  78. package/dist/configurators/pi.d.ts.map +1 -0
  79. package/dist/configurators/pi.js +45 -0
  80. package/dist/configurators/pi.js.map +1 -0
  81. package/dist/configurators/qoder.d.ts +11 -0
  82. package/dist/configurators/qoder.d.ts.map +1 -0
  83. package/dist/configurators/qoder.js +31 -0
  84. package/dist/configurators/qoder.js.map +1 -0
  85. package/dist/configurators/shared.d.ts +178 -0
  86. package/dist/configurators/shared.d.ts.map +1 -0
  87. package/dist/configurators/shared.js +538 -0
  88. package/dist/configurators/shared.js.map +1 -0
  89. package/dist/configurators/windsurf.d.ts +7 -0
  90. package/dist/configurators/windsurf.d.ts.map +1 -0
  91. package/dist/configurators/windsurf.js +19 -0
  92. package/dist/configurators/windsurf.js.map +1 -0
  93. package/dist/configurators/workflow.d.ts +29 -0
  94. package/dist/configurators/workflow.d.ts.map +1 -0
  95. package/dist/configurators/workflow.js +163 -0
  96. package/dist/configurators/workflow.js.map +1 -0
  97. package/dist/constants/paths.d.ts +70 -0
  98. package/dist/constants/paths.d.ts.map +1 -0
  99. package/dist/constants/paths.js +79 -0
  100. package/dist/constants/paths.js.map +1 -0
  101. package/dist/constants/version.d.ts +9 -0
  102. package/dist/constants/version.d.ts.map +1 -0
  103. package/dist/constants/version.js +15 -0
  104. package/dist/constants/version.js.map +1 -0
  105. package/dist/index.d.ts +10 -0
  106. package/dist/index.d.ts.map +1 -0
  107. package/dist/index.js +10 -0
  108. package/dist/index.js.map +1 -0
  109. package/dist/migrations/index.d.ts +62 -0
  110. package/dist/migrations/index.d.ts.map +1 -0
  111. package/dist/migrations/index.js +187 -0
  112. package/dist/migrations/index.js.map +1 -0
  113. package/dist/migrations/manifests/0.1.9.json +30 -0
  114. package/dist/migrations/manifests/0.2.0.json +49 -0
  115. package/dist/migrations/manifests/0.2.12.json +9 -0
  116. package/dist/migrations/manifests/0.2.13.json +9 -0
  117. package/dist/migrations/manifests/0.2.14.json +175 -0
  118. package/dist/migrations/manifests/0.2.15.json +33 -0
  119. package/dist/migrations/manifests/0.3.0-beta.0.json +297 -0
  120. package/dist/migrations/manifests/0.3.0-beta.1.json +9 -0
  121. package/dist/migrations/manifests/0.3.0-beta.10.json +9 -0
  122. package/dist/migrations/manifests/0.3.0-beta.11.json +9 -0
  123. package/dist/migrations/manifests/0.3.0-beta.12.json +9 -0
  124. package/dist/migrations/manifests/0.3.0-beta.13.json +9 -0
  125. package/dist/migrations/manifests/0.3.0-beta.14.json +9 -0
  126. package/dist/migrations/manifests/0.3.0-beta.15.json +9 -0
  127. package/dist/migrations/manifests/0.3.0-beta.16.json +9 -0
  128. package/dist/migrations/manifests/0.3.0-beta.2.json +9 -0
  129. package/dist/migrations/manifests/0.3.0-beta.3.json +9 -0
  130. package/dist/migrations/manifests/0.3.0-beta.4.json +9 -0
  131. package/dist/migrations/manifests/0.3.0-beta.5.json +9 -0
  132. package/dist/migrations/manifests/0.3.0-beta.6.json +9 -0
  133. package/dist/migrations/manifests/0.3.0-beta.7.json +11 -0
  134. package/dist/migrations/manifests/0.3.0-beta.8.json +9 -0
  135. package/dist/migrations/manifests/0.3.0-beta.9.json +9 -0
  136. package/dist/migrations/manifests/0.3.0-rc.0.json +9 -0
  137. package/dist/migrations/manifests/0.3.0-rc.1.json +9 -0
  138. package/dist/migrations/manifests/0.3.0-rc.2.json +9 -0
  139. package/dist/migrations/manifests/0.3.0-rc.3.json +9 -0
  140. package/dist/migrations/manifests/0.3.0-rc.4.json +9 -0
  141. package/dist/migrations/manifests/0.3.0-rc.5.json +9 -0
  142. package/dist/migrations/manifests/0.3.0-rc.6.json +9 -0
  143. package/dist/migrations/manifests/0.3.0.json +11 -0
  144. package/dist/migrations/manifests/0.3.1.json +9 -0
  145. package/dist/migrations/manifests/0.3.10.json +9 -0
  146. package/dist/migrations/manifests/0.3.2.json +9 -0
  147. package/dist/migrations/manifests/0.3.3.json +9 -0
  148. package/dist/migrations/manifests/0.3.4.json +21 -0
  149. package/dist/migrations/manifests/0.3.5.json +9 -0
  150. package/dist/migrations/manifests/0.3.6.json +9 -0
  151. package/dist/migrations/manifests/0.3.7.json +9 -0
  152. package/dist/migrations/manifests/0.3.8.json +9 -0
  153. package/dist/migrations/manifests/0.3.9.json +9 -0
  154. package/dist/migrations/manifests/0.4.0-beta.1.json +228 -0
  155. package/dist/migrations/manifests/0.4.0-beta.10.json +9 -0
  156. package/dist/migrations/manifests/0.4.0-beta.2.json +9 -0
  157. package/dist/migrations/manifests/0.4.0-beta.3.json +9 -0
  158. package/dist/migrations/manifests/0.4.0-beta.4.json +9 -0
  159. package/dist/migrations/manifests/0.4.0-beta.5.json +9 -0
  160. package/dist/migrations/manifests/0.4.0-beta.6.json +9 -0
  161. package/dist/migrations/manifests/0.4.0-beta.7.json +9 -0
  162. package/dist/migrations/manifests/0.4.0-beta.8.json +34 -0
  163. package/dist/migrations/manifests/0.4.0-beta.9.json +9 -0
  164. package/dist/migrations/manifests/0.4.0-rc.0.json +9 -0
  165. package/dist/migrations/manifests/0.4.0-rc.1.json +9 -0
  166. package/dist/migrations/manifests/0.4.0.json +9 -0
  167. package/dist/migrations/manifests/0.5.0-beta.0.json +1646 -0
  168. package/dist/migrations/manifests/0.5.0-beta.1.json +9 -0
  169. package/dist/migrations/manifests/0.5.0-beta.10.json +9 -0
  170. package/dist/migrations/manifests/0.5.0-beta.11.json +9 -0
  171. package/dist/migrations/manifests/0.5.0-beta.12.json +9 -0
  172. package/dist/migrations/manifests/0.5.0-beta.13.json +9 -0
  173. package/dist/migrations/manifests/0.5.0-beta.14.json +9 -0
  174. package/dist/migrations/manifests/0.5.0-beta.15.json +116 -0
  175. package/dist/migrations/manifests/0.5.0-beta.16.json +9 -0
  176. package/dist/migrations/manifests/0.5.0-beta.17.json +9 -0
  177. package/dist/migrations/manifests/0.5.0-beta.18.json +9 -0
  178. package/dist/migrations/manifests/0.5.0-beta.19.json +9 -0
  179. package/dist/migrations/manifests/0.5.0-beta.2.json +9 -0
  180. package/dist/migrations/manifests/0.5.0-beta.3.json +9 -0
  181. package/dist/migrations/manifests/0.5.0-beta.4.json +9 -0
  182. package/dist/migrations/manifests/0.5.0-beta.5.json +222 -0
  183. package/dist/migrations/manifests/0.5.0-beta.6.json +9 -0
  184. package/dist/migrations/manifests/0.5.0-beta.7.json +9 -0
  185. package/dist/migrations/manifests/0.5.0-beta.8.json +9 -0
  186. package/dist/migrations/manifests/0.5.0-beta.9.json +48 -0
  187. package/dist/migrations/manifests/0.5.0-rc.0.json +9 -0
  188. package/dist/migrations/manifests/0.5.0-rc.1.json +9 -0
  189. package/dist/migrations/manifests/0.5.0-rc.2.json +9 -0
  190. package/dist/migrations/manifests/0.5.0-rc.3.json +9 -0
  191. package/dist/migrations/manifests/0.5.0-rc.4.json +9 -0
  192. package/dist/migrations/manifests/0.5.0-rc.5.json +9 -0
  193. package/dist/migrations/manifests/0.5.0-rc.6.json +9 -0
  194. package/dist/migrations/manifests/0.5.0-rc.7.json +9 -0
  195. package/dist/migrations/manifests/0.5.0.json +9 -0
  196. package/dist/migrations/manifests/0.5.1.json +9 -0
  197. package/dist/migrations/manifests/0.5.10.json +9 -0
  198. package/dist/migrations/manifests/0.5.11.json +16 -0
  199. package/dist/migrations/manifests/0.5.12.json +9 -0
  200. package/dist/migrations/manifests/0.5.13.json +9 -0
  201. package/dist/migrations/manifests/0.5.14.json +9 -0
  202. package/dist/migrations/manifests/0.5.15.json +9 -0
  203. package/dist/migrations/manifests/0.5.16.json +9 -0
  204. package/dist/migrations/manifests/0.5.17.json +9 -0
  205. package/dist/migrations/manifests/0.5.18.json +9 -0
  206. package/dist/migrations/manifests/0.5.19.json +9 -0
  207. package/dist/migrations/manifests/0.5.2.json +9 -0
  208. package/dist/migrations/manifests/0.5.3.json +9 -0
  209. package/dist/migrations/manifests/0.5.4.json +9 -0
  210. package/dist/migrations/manifests/0.5.5.json +9 -0
  211. package/dist/migrations/manifests/0.5.6.json +9 -0
  212. package/dist/migrations/manifests/0.5.7.json +16 -0
  213. package/dist/migrations/manifests/0.5.8.json +9 -0
  214. package/dist/migrations/manifests/0.5.9.json +9 -0
  215. package/dist/migrations/manifests/0.6.0-beta.0.json +16 -0
  216. package/dist/migrations/manifests/0.6.0-beta.1.json +9 -0
  217. package/dist/migrations/manifests/0.6.0-beta.10.json +9 -0
  218. package/dist/migrations/manifests/0.6.0-beta.11.json +9 -0
  219. package/dist/migrations/manifests/0.6.0-beta.12.json +9 -0
  220. package/dist/migrations/manifests/0.6.0-beta.13.json +9 -0
  221. package/dist/migrations/manifests/0.6.0-beta.14.json +9 -0
  222. package/dist/migrations/manifests/0.6.0-beta.15.json +9 -0
  223. package/dist/migrations/manifests/0.6.0-beta.16.json +9 -0
  224. package/dist/migrations/manifests/0.6.0-beta.17.json +9 -0
  225. package/dist/migrations/manifests/0.6.0-beta.18.json +16 -0
  226. package/dist/migrations/manifests/0.6.0-beta.19.json +9 -0
  227. package/dist/migrations/manifests/0.6.0-beta.2.json +9 -0
  228. package/dist/migrations/manifests/0.6.0-beta.20.json +9 -0
  229. package/dist/migrations/manifests/0.6.0-beta.21.json +9 -0
  230. package/dist/migrations/manifests/0.6.0-beta.3.json +9 -0
  231. package/dist/migrations/manifests/0.6.0-beta.4.json +9 -0
  232. package/dist/migrations/manifests/0.6.0-beta.5.json +9 -0
  233. package/dist/migrations/manifests/0.6.0-beta.6.json +16 -0
  234. package/dist/migrations/manifests/0.6.0-beta.7.json +9 -0
  235. package/dist/migrations/manifests/0.6.0-beta.8.json +9 -0
  236. package/dist/migrations/manifests/0.6.0-beta.9.json +9 -0
  237. package/dist/templates/claude/agents/trellis-check.md +109 -0
  238. package/dist/templates/claude/agents/trellis-implement.md +109 -0
  239. package/dist/templates/claude/agents/trellis-research.md +137 -0
  240. package/dist/templates/claude/index.d.ts +22 -0
  241. package/dist/templates/claude/index.d.ts.map +1 -0
  242. package/dist/templates/claude/index.js +46 -0
  243. package/dist/templates/claude/index.js.map +1 -0
  244. package/dist/templates/claude/settings.json +73 -0
  245. package/dist/templates/codebuddy/agents/trellis-check.md +109 -0
  246. package/dist/templates/codebuddy/agents/trellis-implement.md +109 -0
  247. package/dist/templates/codebuddy/agents/trellis-research.md +137 -0
  248. package/dist/templates/codebuddy/index.d.ts +15 -0
  249. package/dist/templates/codebuddy/index.d.ts.map +1 -0
  250. package/dist/templates/codebuddy/index.js +15 -0
  251. package/dist/templates/codebuddy/index.js.map +1 -0
  252. package/dist/templates/codebuddy/settings.json +59 -0
  253. package/dist/templates/codex/agents/trellis-check.toml +84 -0
  254. package/dist/templates/codex/agents/trellis-implement.toml +65 -0
  255. package/dist/templates/codex/agents/trellis-research.toml +73 -0
  256. package/dist/templates/codex/config.toml +28 -0
  257. package/dist/templates/codex/hooks/session-start.py +481 -0
  258. package/dist/templates/codex/hooks.json +15 -0
  259. package/dist/templates/codex/index.d.ts +39 -0
  260. package/dist/templates/codex/index.d.ts.map +1 -0
  261. package/dist/templates/codex/index.js +85 -0
  262. package/dist/templates/codex/index.js.map +1 -0
  263. package/dist/templates/codex/skills/before-dev/SKILL.md +34 -0
  264. package/dist/templates/codex/skills/brainstorm/SKILL.md +500 -0
  265. package/dist/templates/codex/skills/break-loop/SKILL.md +130 -0
  266. package/dist/templates/codex/skills/check/SKILL.md +30 -0
  267. package/dist/templates/codex/skills/check-cross-layer/SKILL.md +158 -0
  268. package/dist/templates/codex/skills/create-command/SKILL.md +101 -0
  269. package/dist/templates/codex/skills/finish-work/SKILL.md +90 -0
  270. package/dist/templates/codex/skills/improve-ut/SKILL.md +69 -0
  271. package/dist/templates/codex/skills/integrate-skill/SKILL.md +221 -0
  272. package/dist/templates/codex/skills/onboard/SKILL.md +363 -0
  273. package/dist/templates/codex/skills/record-session/SKILL.md +67 -0
  274. package/dist/templates/codex/skills/start/SKILL.md +354 -0
  275. package/dist/templates/codex/skills/update-spec/SKILL.md +335 -0
  276. package/dist/templates/common/bundled-skills/trellis-meta/SKILL.md +73 -0
  277. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/add-project-local-conventions.md +83 -0
  278. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-agents.md +54 -0
  279. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-context-loading.md +81 -0
  280. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-hooks.md +57 -0
  281. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-skills-or-commands.md +78 -0
  282. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-spec-structure.md +83 -0
  283. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-task-lifecycle.md +90 -0
  284. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-workflow.md +64 -0
  285. package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/overview.md +55 -0
  286. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/context-injection.md +68 -0
  287. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/generated-files.md +80 -0
  288. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/overview.md +51 -0
  289. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/spec-system.md +102 -0
  290. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/task-system.md +101 -0
  291. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/workflow.md +75 -0
  292. package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/workspace-memory.md +71 -0
  293. package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/agents.md +79 -0
  294. package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/hooks-and-settings.md +69 -0
  295. package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/overview.md +59 -0
  296. package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/platform-map.md +74 -0
  297. package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/skills-and-commands.md +83 -0
  298. package/dist/templates/common/bundled-skills/trellis-spec-bootstarp/SKILL.md +41 -0
  299. package/dist/templates/common/bundled-skills/trellis-spec-bootstarp/references/mcp-setup.md +90 -0
  300. package/dist/templates/common/bundled-skills/trellis-spec-bootstarp/references/repository-analysis.md +59 -0
  301. package/dist/templates/common/bundled-skills/trellis-spec-bootstarp/references/spec-task-planning.md +61 -0
  302. package/dist/templates/common/bundled-skills/trellis-spec-bootstarp/references/spec-writing.md +70 -0
  303. package/dist/templates/common/commands/continue.md +55 -0
  304. package/dist/templates/common/commands/finish-work.md +66 -0
  305. package/dist/templates/common/commands/start.md +58 -0
  306. package/dist/templates/common/index.d.ts +48 -0
  307. package/dist/templates/common/index.d.ts.map +1 -0
  308. package/dist/templates/common/index.js +104 -0
  309. package/dist/templates/common/index.js.map +1 -0
  310. package/dist/templates/common/skills/before-dev.md +29 -0
  311. package/dist/templates/common/skills/brainstorm.md +543 -0
  312. package/dist/templates/common/skills/break-loop.md +125 -0
  313. package/dist/templates/common/skills/check.md +87 -0
  314. package/dist/templates/common/skills/update-spec.md +351 -0
  315. package/dist/templates/copilot/hooks/session-start.py +454 -0
  316. package/dist/templates/copilot/hooks.json +19 -0
  317. package/dist/templates/copilot/index.d.ts +23 -0
  318. package/dist/templates/copilot/index.d.ts.map +1 -0
  319. package/dist/templates/copilot/index.js +54 -0
  320. package/dist/templates/copilot/index.js.map +1 -0
  321. package/dist/templates/copilot/prompts/before-dev.prompt.md +33 -0
  322. package/dist/templates/copilot/prompts/brainstorm.prompt.md +499 -0
  323. package/dist/templates/copilot/prompts/break-loop.prompt.md +129 -0
  324. package/dist/templates/copilot/prompts/check-cross-layer.prompt.md +157 -0
  325. package/dist/templates/copilot/prompts/check.prompt.md +29 -0
  326. package/dist/templates/copilot/prompts/create-command.prompt.md +116 -0
  327. package/dist/templates/copilot/prompts/finish-work.prompt.md +99 -0
  328. package/dist/templates/copilot/prompts/integrate-skill.prompt.md +223 -0
  329. package/dist/templates/copilot/prompts/onboard.prompt.md +362 -0
  330. package/dist/templates/copilot/prompts/parallel.prompt.md +196 -0
  331. package/dist/templates/copilot/prompts/record-session.prompt.md +66 -0
  332. package/dist/templates/copilot/prompts/start.prompt.md +397 -0
  333. package/dist/templates/copilot/prompts/update-spec.prompt.md +358 -0
  334. package/dist/templates/cursor/agents/trellis-check.md +108 -0
  335. package/dist/templates/cursor/agents/trellis-implement.md +108 -0
  336. package/dist/templates/cursor/agents/trellis-research.md +136 -0
  337. package/dist/templates/cursor/hooks.json +24 -0
  338. package/dist/templates/cursor/index.d.ts +13 -0
  339. package/dist/templates/cursor/index.d.ts.map +1 -0
  340. package/dist/templates/cursor/index.js +13 -0
  341. package/dist/templates/cursor/index.js.map +1 -0
  342. package/dist/templates/droid/droids/trellis-check.md +101 -0
  343. package/dist/templates/droid/droids/trellis-implement.md +101 -0
  344. package/dist/templates/droid/droids/trellis-research.md +137 -0
  345. package/dist/templates/droid/index.d.ts +15 -0
  346. package/dist/templates/droid/index.d.ts.map +1 -0
  347. package/dist/templates/droid/index.js +15 -0
  348. package/dist/templates/droid/index.js.map +1 -0
  349. package/dist/templates/droid/settings.json +59 -0
  350. package/dist/templates/extract.d.ts +40 -0
  351. package/dist/templates/extract.d.ts.map +1 -0
  352. package/dist/templates/extract.js +106 -0
  353. package/dist/templates/extract.js.map +1 -0
  354. package/dist/templates/gemini/agents/trellis-check.md +101 -0
  355. package/dist/templates/gemini/agents/trellis-implement.md +101 -0
  356. package/dist/templates/gemini/agents/trellis-research.md +136 -0
  357. package/dist/templates/gemini/index.d.ts +13 -0
  358. package/dist/templates/gemini/index.d.ts.map +1 -0
  359. package/dist/templates/gemini/index.js +13 -0
  360. package/dist/templates/gemini/index.js.map +1 -0
  361. package/dist/templates/gemini/settings.json +28 -0
  362. package/dist/templates/kiro/agents/trellis-check.json +26 -0
  363. package/dist/templates/kiro/agents/trellis-implement.json +26 -0
  364. package/dist/templates/kiro/agents/trellis-research.json +30 -0
  365. package/dist/templates/kiro/index.d.ts +18 -0
  366. package/dist/templates/kiro/index.d.ts.map +1 -0
  367. package/dist/templates/kiro/index.js +18 -0
  368. package/dist/templates/kiro/index.js.map +1 -0
  369. package/dist/templates/markdown/agents.md +21 -0
  370. package/dist/templates/markdown/gitignore.txt +15 -0
  371. package/dist/templates/markdown/index.d.ts +27 -0
  372. package/dist/templates/markdown/index.d.ts.map +1 -0
  373. package/dist/templates/markdown/index.js +52 -0
  374. package/dist/templates/markdown/index.js.map +1 -0
  375. package/dist/templates/markdown/spec/backend/database-guidelines.md.txt +51 -0
  376. package/dist/templates/markdown/spec/backend/directory-structure.md.txt +54 -0
  377. package/dist/templates/markdown/spec/backend/error-handling.md.txt +51 -0
  378. package/dist/templates/markdown/spec/backend/index.md.txt +38 -0
  379. package/dist/templates/markdown/spec/backend/logging-guidelines.md.txt +51 -0
  380. package/dist/templates/markdown/spec/backend/quality-guidelines.md.txt +51 -0
  381. package/dist/templates/markdown/spec/frontend/component-guidelines.md.txt +59 -0
  382. package/dist/templates/markdown/spec/frontend/directory-structure.md.txt +54 -0
  383. package/dist/templates/markdown/spec/frontend/hook-guidelines.md.txt +51 -0
  384. package/dist/templates/markdown/spec/frontend/index.md.txt +39 -0
  385. package/dist/templates/markdown/spec/frontend/quality-guidelines.md.txt +51 -0
  386. package/dist/templates/markdown/spec/frontend/state-management.md.txt +51 -0
  387. package/dist/templates/markdown/spec/frontend/type-safety.md.txt +51 -0
  388. package/dist/templates/markdown/spec/guides/code-reuse-thinking-guide.md.txt +105 -0
  389. package/dist/templates/markdown/spec/guides/cross-layer-thinking-guide.md.txt +162 -0
  390. package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md.txt +595 -0
  391. package/dist/templates/markdown/spec/guides/index.md.txt +79 -0
  392. package/dist/templates/markdown/workspace-index.md +125 -0
  393. package/dist/templates/markdown/worktree.yaml.txt +58 -0
  394. package/dist/templates/opencode/agents/trellis-check.md +116 -0
  395. package/dist/templates/opencode/agents/trellis-implement.md +117 -0
  396. package/dist/templates/opencode/agents/trellis-research.md +145 -0
  397. package/dist/templates/opencode/lib/session-utils.js +432 -0
  398. package/dist/templates/opencode/lib/trellis-context.js +381 -0
  399. package/dist/templates/opencode/package.json +5 -0
  400. package/dist/templates/opencode/plugins/inject-subagent-context.js +497 -0
  401. package/dist/templates/opencode/plugins/inject-workflow-state.js +162 -0
  402. package/dist/templates/opencode/plugins/session-start.js +101 -0
  403. package/dist/templates/pi/agents/trellis-check.md +36 -0
  404. package/dist/templates/pi/agents/trellis-implement.md +41 -0
  405. package/dist/templates/pi/agents/trellis-research.md +25 -0
  406. package/dist/templates/pi/extensions/trellis/index.ts.txt +1172 -0
  407. package/dist/templates/pi/index.d.ts +5 -0
  408. package/dist/templates/pi/index.d.ts.map +1 -0
  409. package/dist/templates/pi/index.js +12 -0
  410. package/dist/templates/pi/index.js.map +1 -0
  411. package/dist/templates/pi/settings.json +21 -0
  412. package/dist/templates/qoder/agents/trellis-check.md +102 -0
  413. package/dist/templates/qoder/agents/trellis-implement.md +102 -0
  414. package/dist/templates/qoder/agents/trellis-research.md +137 -0
  415. package/dist/templates/qoder/index.d.ts +15 -0
  416. package/dist/templates/qoder/index.d.ts.map +1 -0
  417. package/dist/templates/qoder/index.js +15 -0
  418. package/dist/templates/qoder/index.js.map +1 -0
  419. package/dist/templates/qoder/settings.json +47 -0
  420. package/dist/templates/shared-hooks/index.d.ts +50 -0
  421. package/dist/templates/shared-hooks/index.d.ts.map +1 -0
  422. package/dist/templates/shared-hooks/index.js +88 -0
  423. package/dist/templates/shared-hooks/index.js.map +1 -0
  424. package/dist/templates/shared-hooks/inject-shell-session-context.py +183 -0
  425. package/dist/templates/shared-hooks/inject-subagent-context.py +749 -0
  426. package/dist/templates/shared-hooks/inject-workflow-state.py +387 -0
  427. package/dist/templates/shared-hooks/session-start.py +797 -0
  428. package/dist/templates/template-utils.d.ts +26 -0
  429. package/dist/templates/template-utils.d.ts.map +1 -0
  430. package/dist/templates/template-utils.js +60 -0
  431. package/dist/templates/template-utils.js.map +1 -0
  432. package/dist/templates/trellis/config.yaml +90 -0
  433. package/dist/templates/trellis/gitignore.txt +32 -0
  434. package/dist/templates/trellis/index.d.ts +52 -0
  435. package/dist/templates/trellis/index.d.ts.map +1 -0
  436. package/dist/templates/trellis/index.js +97 -0
  437. package/dist/templates/trellis/index.js.map +1 -0
  438. package/dist/templates/trellis/scripts/__init__.py +5 -0
  439. package/dist/templates/trellis/scripts/add_session.py +547 -0
  440. package/dist/templates/trellis/scripts/common/__init__.py +92 -0
  441. package/dist/templates/trellis/scripts/common/active_task.py +626 -0
  442. package/dist/templates/trellis/scripts/common/cli_adapter.py +811 -0
  443. package/dist/templates/trellis/scripts/common/config.py +445 -0
  444. package/dist/templates/trellis/scripts/common/developer.py +190 -0
  445. package/dist/templates/trellis/scripts/common/git.py +31 -0
  446. package/dist/templates/trellis/scripts/common/git_context.py +106 -0
  447. package/dist/templates/trellis/scripts/common/io.py +37 -0
  448. package/dist/templates/trellis/scripts/common/log.py +45 -0
  449. package/dist/templates/trellis/scripts/common/packages_context.py +238 -0
  450. package/dist/templates/trellis/scripts/common/paths.py +447 -0
  451. package/dist/templates/trellis/scripts/common/safe_commit.py +285 -0
  452. package/dist/templates/trellis/scripts/common/session_context.py +821 -0
  453. package/dist/templates/trellis/scripts/common/task_context.py +223 -0
  454. package/dist/templates/trellis/scripts/common/task_queue.py +188 -0
  455. package/dist/templates/trellis/scripts/common/task_store.py +697 -0
  456. package/dist/templates/trellis/scripts/common/task_utils.py +274 -0
  457. package/dist/templates/trellis/scripts/common/tasks.py +112 -0
  458. package/dist/templates/trellis/scripts/common/trellis_config.py +131 -0
  459. package/dist/templates/trellis/scripts/common/types.py +110 -0
  460. package/dist/templates/trellis/scripts/common/workflow_phase.py +215 -0
  461. package/dist/templates/trellis/scripts/get_context.py +16 -0
  462. package/dist/templates/trellis/scripts/get_developer.py +26 -0
  463. package/dist/templates/trellis/scripts/hooks/linear_sync.py +243 -0
  464. package/dist/templates/trellis/scripts/init_developer.py +51 -0
  465. package/dist/templates/trellis/scripts/task.py +500 -0
  466. package/dist/templates/trellis/tasks/.gitkeep +0 -0
  467. package/dist/templates/trellis/workflow.md +690 -0
  468. package/dist/types/ai-tools.d.ts +95 -0
  469. package/dist/types/ai-tools.d.ts.map +1 -0
  470. package/dist/types/ai-tools.js +280 -0
  471. package/dist/types/ai-tools.js.map +1 -0
  472. package/dist/types/migration.d.ts +125 -0
  473. package/dist/types/migration.d.ts.map +1 -0
  474. package/dist/types/migration.js +8 -0
  475. package/dist/types/migration.js.map +1 -0
  476. package/dist/utils/compare-versions.d.ts +12 -0
  477. package/dist/utils/compare-versions.d.ts.map +1 -0
  478. package/dist/utils/compare-versions.js +86 -0
  479. package/dist/utils/compare-versions.js.map +1 -0
  480. package/dist/utils/cwd-guard.d.ts +38 -0
  481. package/dist/utils/cwd-guard.d.ts.map +1 -0
  482. package/dist/utils/cwd-guard.js +62 -0
  483. package/dist/utils/cwd-guard.js.map +1 -0
  484. package/dist/utils/file-writer.d.ts +36 -0
  485. package/dist/utils/file-writer.d.ts.map +1 -0
  486. package/dist/utils/file-writer.js +203 -0
  487. package/dist/utils/file-writer.js.map +1 -0
  488. package/dist/utils/manifest-prune.d.ts +61 -0
  489. package/dist/utils/manifest-prune.d.ts.map +1 -0
  490. package/dist/utils/manifest-prune.js +136 -0
  491. package/dist/utils/manifest-prune.js.map +1 -0
  492. package/dist/utils/posix.d.ts +13 -0
  493. package/dist/utils/posix.d.ts.map +1 -0
  494. package/dist/utils/posix.js +15 -0
  495. package/dist/utils/posix.js.map +1 -0
  496. package/dist/utils/project-detector.d.ts +46 -0
  497. package/dist/utils/project-detector.d.ts.map +1 -0
  498. package/dist/utils/project-detector.js +666 -0
  499. package/dist/utils/project-detector.js.map +1 -0
  500. package/dist/utils/proxy.d.ts +25 -0
  501. package/dist/utils/proxy.d.ts.map +1 -0
  502. package/dist/utils/proxy.js +60 -0
  503. package/dist/utils/proxy.js.map +1 -0
  504. package/dist/utils/task-json.d.ts +46 -0
  505. package/dist/utils/task-json.d.ts.map +1 -0
  506. package/dist/utils/task-json.js +49 -0
  507. package/dist/utils/task-json.js.map +1 -0
  508. package/dist/utils/template-fetcher.d.ts +150 -0
  509. package/dist/utils/template-fetcher.d.ts.map +1 -0
  510. package/dist/utils/template-fetcher.js +907 -0
  511. package/dist/utils/template-fetcher.js.map +1 -0
  512. package/dist/utils/template-hash.d.ts +123 -0
  513. package/dist/utils/template-hash.d.ts.map +1 -0
  514. package/dist/utils/template-hash.js +334 -0
  515. package/dist/utils/template-hash.js.map +1 -0
  516. package/dist/utils/uninstall-scrubbers.d.ts +66 -0
  517. package/dist/utils/uninstall-scrubbers.d.ts.map +1 -0
  518. package/dist/utils/uninstall-scrubbers.js +342 -0
  519. package/dist/utils/uninstall-scrubbers.js.map +1 -0
  520. package/package.json +89 -0
@@ -0,0 +1,358 @@
1
+ ---
2
+ description: "Trellis Copilot prompt: Update Code-Spec - Capture Executable Contracts"
3
+ ---
4
+
5
+ # Update Code-Spec - Capture Executable Contracts
6
+
7
+ When you learn something valuable (from debugging, implementing, or discussion), use this command to update the relevant code-spec documents.
8
+
9
+ **Timing**: After completing a task, fixing a bug, or discovering a new pattern
10
+
11
+ ---
12
+
13
+ ## Code-Spec First Rule (CRITICAL)
14
+
15
+ In this project, "spec" for implementation work means **code-spec**:
16
+ - Executable contracts (not principle-only text)
17
+ - Concrete signatures, payload fields, env keys, and boundary behavior
18
+ - Testable validation/error behavior
19
+
20
+ If the change touches infra or cross-layer contracts, code-spec depth is mandatory.
21
+
22
+ ### Mandatory Triggers
23
+
24
+ Apply code-spec depth when the change includes any of:
25
+ - New/changed command or API signature
26
+ - Cross-layer request/response contract change
27
+ - Database schema/migration change
28
+ - Infra integration (storage, queue, cache, secrets, env wiring)
29
+
30
+ ### Mandatory Output (7 Sections)
31
+
32
+ For triggered tasks, include all sections below:
33
+ 1. Scope / Trigger
34
+ 2. Signatures (command/API/DB)
35
+ 3. Contracts (request/response/env)
36
+ 4. Validation & Error Matrix
37
+ 5. Good/Base/Bad Cases
38
+ 6. Tests Required (with assertion points)
39
+ 7. Wrong vs Correct (at least one pair)
40
+
41
+ ---
42
+
43
+ ## When to Update Code-Specs
44
+
45
+ | Trigger | Example | Target Spec |
46
+ |---------|---------|-------------|
47
+ | **Implemented a feature** | Added template download with giget | Relevant `backend/` or `frontend/` file |
48
+ | **Made a design decision** | Used type field + mapping table for extensibility | Relevant code-spec + "Design Decisions" section |
49
+ | **Fixed a bug** | Found a subtle issue with error handling | `backend/error-handling.md` |
50
+ | **Discovered a pattern** | Found a better way to structure code | Relevant `backend/` or `frontend/` file |
51
+ | **Hit a gotcha** | Learned that X must be done before Y | Relevant code-spec + "Common Mistakes" section |
52
+ | **Established a convention** | Team agreed on naming pattern | `quality-guidelines.md` |
53
+ | **New thinking trigger** | "Don't forget to check X before doing Y" | `guides/*.md` (as a checklist item, not detailed rules) |
54
+
55
+ **Key Insight**: Code-spec updates are NOT just for problems. Every feature implementation contains design decisions and contracts that future AI/developers need to execute safely.
56
+
57
+ ---
58
+
59
+ ## Spec Structure Overview
60
+
61
+ ```
62
+ .trellis/spec/
63
+ ├── backend/ # Backend coding standards
64
+ �? ├── index.md # Overview and links
65
+ �? └── *.md # Topic-specific guidelines
66
+ ├── frontend/ # Frontend coding standards
67
+ �? ├── index.md # Overview and links
68
+ �? └── *.md # Topic-specific guidelines
69
+ └── guides/ # Thinking checklists (NOT coding specs!)
70
+ ├── index.md # Guide index
71
+ └── *.md # Topic-specific guides
72
+ ```
73
+
74
+ ### CRITICAL: Code-Spec vs Guide - Know the Difference
75
+
76
+ | Type | Location | Purpose | Content Style |
77
+ |------|----------|---------|---------------|
78
+ | **Code-Spec** | `backend/*.md`, `frontend/*.md` | Tell AI "how to implement safely" | Signatures, contracts, matrices, cases, test points |
79
+ | **Guide** | `guides/*.md` | Help AI "what to think about" | Checklists, questions, pointers to specs |
80
+
81
+ **Decision Rule**: Ask yourself:
82
+
83
+ - "This is **how to write** the code" �?Put in `backend/` or `frontend/`
84
+ - "This is **what to consider** before writing" �?Put in `guides/`
85
+
86
+ **Example**:
87
+
88
+ | Learning | Wrong Location | Correct Location |
89
+ |----------|----------------|------------------|
90
+ | "Use `reconfigure()` not `TextIOWrapper` for Windows stdout" | �?`guides/cross-platform-thinking-guide.md` | �?`backend/script-conventions.md` |
91
+ | "Remember to check encoding when writing cross-platform code" | �?`backend/script-conventions.md` | �?`guides/cross-platform-thinking-guide.md` |
92
+
93
+ **Guides should be short checklists that point to specs**, not duplicate the detailed rules.
94
+
95
+ ---
96
+
97
+ ## Update Process
98
+
99
+ ### Step 1: Identify What You Learned
100
+
101
+ Answer these questions:
102
+
103
+ 1. **What did you learn?** (Be specific)
104
+ 2. **Why is it important?** (What problem does it prevent?)
105
+ 3. **Where does it belong?** (Which spec file?)
106
+
107
+ ### Step 2: Classify the Update Type
108
+
109
+ | Type | Description | Action |
110
+ |------|-------------|--------|
111
+ | **Design Decision** | Why we chose approach X over Y | Add to "Design Decisions" section |
112
+ | **Project Convention** | How we do X in this project | Add to relevant section with examples |
113
+ | **New Pattern** | A reusable approach discovered | Add to "Patterns" section |
114
+ | **Forbidden Pattern** | Something that causes problems | Add to "Anti-patterns" or "Don't" section |
115
+ | **Common Mistake** | Easy-to-make error | Add to "Common Mistakes" section |
116
+ | **Convention** | Agreed-upon standard | Add to relevant section |
117
+ | **Gotcha** | Non-obvious behavior | Add warning callout |
118
+
119
+ ### Step 3: Read the Target Code-Spec
120
+
121
+ Before editing, read the current code-spec to:
122
+ - Understand existing structure
123
+ - Avoid duplicating content
124
+ - Find the right section for your update
125
+
126
+ ```bash
127
+ cat .trellis/spec/<category>/<file>.md
128
+ ```
129
+
130
+ ### Step 4: Make the Update
131
+
132
+ Follow these principles:
133
+
134
+ 1. **Be Specific**: Include concrete examples, not just abstract rules
135
+ 2. **Explain Why**: State the problem this prevents
136
+ 3. **Show Contracts**: Add signatures, payload fields, and error behavior
137
+ 4. **Show Code**: Add code snippets for key patterns
138
+ 5. **Keep it Short**: One concept per section
139
+
140
+ ### Step 5: Update the Index (if needed)
141
+
142
+ If you added a new section or the code-spec status changed, update the category's `index.md`.
143
+
144
+ ---
145
+
146
+ ## Update Templates
147
+
148
+ ### Mandatory Template for Infra/Cross-Layer Work
149
+
150
+ ```markdown
151
+ ## Scenario: <name>
152
+
153
+ ### 1. Scope / Trigger
154
+ - Trigger: <why this requires code-spec depth>
155
+
156
+ ### 2. Signatures
157
+ - Backend command/API/DB signature(s)
158
+
159
+ ### 3. Contracts
160
+ - Request fields (name, type, constraints)
161
+ - Response fields (name, type, constraints)
162
+ - Environment keys (required/optional)
163
+
164
+ ### 4. Validation & Error Matrix
165
+ - <condition> -> <error>
166
+
167
+ ### 5. Good/Base/Bad Cases
168
+ - Good: ...
169
+ - Base: ...
170
+ - Bad: ...
171
+
172
+ ### 6. Tests Required
173
+ - Unit/Integration/E2E with assertion points
174
+
175
+ ### 7. Wrong vs Correct
176
+ #### Wrong
177
+ ...
178
+ #### Correct
179
+ ...
180
+ ```
181
+
182
+ ### Adding a Design Decision
183
+
184
+ ```markdown
185
+ ### Design Decision: [Decision Name]
186
+
187
+ **Context**: What problem were we solving?
188
+
189
+ **Options Considered**:
190
+ 1. Option A - brief description
191
+ 2. Option B - brief description
192
+
193
+ **Decision**: We chose Option X because...
194
+
195
+ **Example**:
196
+ \`\`\`typescript
197
+ // How it's implemented
198
+ code example
199
+ \`\`\`
200
+
201
+ **Extensibility**: How to extend this in the future...
202
+ ```
203
+
204
+ ### Adding a Project Convention
205
+
206
+ ```markdown
207
+ ### Convention: [Convention Name]
208
+
209
+ **What**: Brief description of the convention.
210
+
211
+ **Why**: Why we do it this way in this project.
212
+
213
+ **Example**:
214
+ \`\`\`typescript
215
+ // How to follow this convention
216
+ code example
217
+ \`\`\`
218
+
219
+ **Related**: Links to related conventions or specs.
220
+ ```
221
+
222
+ ### Adding a New Pattern
223
+
224
+ ```markdown
225
+ ### Pattern Name
226
+
227
+ **Problem**: What problem does this solve?
228
+
229
+ **Solution**: Brief description of the approach.
230
+
231
+ **Example**:
232
+ \`\`\`
233
+ // Good
234
+ code example
235
+
236
+ // Bad
237
+ code example
238
+ \`\`\`
239
+
240
+ **Why**: Explanation of why this works better.
241
+ ```
242
+
243
+ ### Adding a Forbidden Pattern
244
+
245
+ ```markdown
246
+ ### Don't: Pattern Name
247
+
248
+ **Problem**:
249
+ \`\`\`
250
+ // Don't do this
251
+ bad code example
252
+ \`\`\`
253
+
254
+ **Why it's bad**: Explanation of the issue.
255
+
256
+ **Instead**:
257
+ \`\`\`
258
+ // Do this instead
259
+ good code example
260
+ \`\`\`
261
+ ```
262
+
263
+ ### Adding a Common Mistake
264
+
265
+ ```markdown
266
+ ### Common Mistake: Description
267
+
268
+ **Symptom**: What goes wrong
269
+
270
+ **Cause**: Why this happens
271
+
272
+ **Fix**: How to correct it
273
+
274
+ **Prevention**: How to avoid it in the future
275
+ ```
276
+
277
+ ### Adding a Gotcha
278
+
279
+ ```markdown
280
+ > **Warning**: Brief description of the non-obvious behavior.
281
+ >
282
+ > Details about when this happens and how to handle it.
283
+ ```
284
+
285
+ ---
286
+
287
+ ## Interactive Mode
288
+
289
+ If you're unsure what to update, answer these prompts:
290
+
291
+ 1. **What did you just finish?**
292
+ - [ ] Fixed a bug
293
+ - [ ] Implemented a feature
294
+ - [ ] Refactored code
295
+ - [ ] Had a discussion about approach
296
+
297
+ 2. **What did you learn or decide?**
298
+ - Design decision (why X over Y)
299
+ - Project convention (how we do X)
300
+ - Non-obvious behavior (gotcha)
301
+ - Better approach (pattern)
302
+
303
+ 3. **Would future AI/developers need to know this?**
304
+ - To understand how the code works �?Yes, update spec
305
+ - To maintain or extend the feature �?Yes, update spec
306
+ - To avoid repeating mistakes �?Yes, update spec
307
+ - Purely one-off implementation detail �?Maybe skip
308
+
309
+ 4. **Which area does it relate to?**
310
+ - [ ] Backend code
311
+ - [ ] Frontend code
312
+ - [ ] Cross-layer data flow
313
+ - [ ] Code organization/reuse
314
+ - [ ] Quality/testing
315
+
316
+ ---
317
+
318
+ ## Quality Checklist
319
+
320
+ Before finishing your code-spec update:
321
+
322
+ - [ ] Is the content specific and actionable?
323
+ - [ ] Did you include a code example?
324
+ - [ ] Did you explain WHY, not just WHAT?
325
+ - [ ] Did you include executable signatures/contracts?
326
+ - [ ] Did you include validation and error matrix?
327
+ - [ ] Did you include Good/Base/Bad cases?
328
+ - [ ] Did you include required tests with assertion points?
329
+ - [ ] Is it in the right code-spec file?
330
+ - [ ] Does it duplicate existing content?
331
+ - [ ] Would a new team member understand it?
332
+
333
+ ---
334
+
335
+ ## Relationship to Other Commands
336
+
337
+ ```
338
+ Development Flow:
339
+ Learn something �?/ �?Knowledge captured
340
+ �? �?
341
+ / ←──────────────────── Future sessions benefit
342
+ (deep bug analysis)
343
+ ```
344
+
345
+ - `/` - Analyzes bugs deeply, often reveals spec updates needed
346
+ - `/` - Actually makes the updates (this command)
347
+ - `/` - Reminds you to check if specs need updates
348
+
349
+ ---
350
+
351
+ ## Core Philosophy
352
+
353
+ > **Code-specs are living documents. Every debugging session, every "aha moment" is an opportunity to make the implementation contract clearer.**
354
+
355
+ The goal is **institutional memory**:
356
+ - What one person learns, everyone benefits from
357
+ - What AI learns in one session, persists to future sessions
358
+ - Mistakes become documented guardrails
@@ -0,0 +1,108 @@
1
+ ---
2
+ name: trellis-check
3
+ description: Trellis quality check agent. Use this exact agent for Trellis task verification, check.jsonl context injection, and self-fixing code review. Do not use generic/default/generalPurpose agents for Trellis checks.
4
+ tools: Read, Write, Edit, Bash, Glob, Grep, mcp__exa__web_search_exa, mcp__exa__get_code_context_exa
5
+ ---
6
+ # Check Agent
7
+
8
+ You are the Check Agent in the Trellis workflow.
9
+
10
+ ## Recursion Guard
11
+
12
+ You are already the `trellis-check` sub-agent that the main session dispatched. Do the review and fixes directly.
13
+
14
+ - Do NOT spawn another `trellis-check` or `trellis-implement` sub-agent.
15
+ - If SessionStart context, workflow-state breadcrumbs, or workflow.md say to dispatch `trellis-implement` / `trellis-check`, treat that as a main-session instruction that is already satisfied by your current role.
16
+ - Only the main session may dispatch Trellis implement/check agents. If more implementation work is needed, report that recommendation instead of spawning.
17
+
18
+ ## Trellis Context Loading Protocol
19
+
20
+ Look for the `<!-- trellis-hook-injected -->` marker in your input above.
21
+
22
+ - **If the marker is present**: prd / spec / research files have already been auto-loaded for you above. Proceed with the check work directly.
23
+ - **If the marker is absent**: hook injection didn't fire (Windows + Claude Code, `--continue` resume, fork distribution, hooks disabled, etc.). Find the active task path from your dispatch prompt's first line `Active task: <path>`, then Read `<task-path>/prd.md` and the spec files listed in `<task-path>/check.jsonl` yourself before doing the work.
24
+
25
+ ## Context
26
+
27
+ Before checking, read:
28
+ - `.trellis/spec/` - Development guidelines
29
+ - Pre-commit checklist for quality standards
30
+
31
+ ## Core Responsibilities
32
+
33
+ 1. **Get code changes** - Use git diff to get uncommitted code
34
+ 2. **Check against specs** - Verify code follows guidelines
35
+ 3. **Self-fix** - Fix issues yourself, not just report them
36
+ 4. **Run verification** - typecheck and lint
37
+
38
+ ## Important
39
+
40
+ **Fix issues yourself**, don't just report them.
41
+
42
+ You have write and edit tools, you can modify code directly.
43
+
44
+ ---
45
+
46
+ ## Workflow
47
+
48
+ ### Step 1: Get Changes
49
+
50
+ ```bash
51
+ git diff --name-only # List changed files
52
+ git diff # View specific changes
53
+ ```
54
+
55
+ ### Step 2: Check Against Specs
56
+
57
+ Read relevant specs in `.trellis/spec/` to check code:
58
+
59
+ - Does it follow directory structure conventions
60
+ - Does it follow naming conventions
61
+ - Does it follow code patterns
62
+ - Are there missing types
63
+ - Are there potential bugs
64
+
65
+ ### Step 3: Self-Fix
66
+
67
+ After finding issues:
68
+
69
+ 1. Fix the issue directly (use edit tool)
70
+ 2. Record what was fixed
71
+ 3. Continue checking other issues
72
+
73
+ ### Step 4: Run Verification
74
+
75
+ Run project's lint and typecheck commands to verify changes.
76
+
77
+ If failed, fix issues and re-run.
78
+
79
+ ---
80
+
81
+ ## Report Format
82
+
83
+ ```markdown
84
+ ## Self-Check Complete
85
+
86
+ ### Files Checked
87
+
88
+ - src/components/Feature.tsx
89
+ - src/hooks/useFeature.ts
90
+
91
+ ### Issues Found and Fixed
92
+
93
+ 1. `<file>:<line>` - <what was fixed>
94
+ 2. `<file>:<line>` - <what was fixed>
95
+
96
+ ### Issues Not Fixed
97
+
98
+ (If there are issues that cannot be self-fixed, list them here with reasons)
99
+
100
+ ### Verification Results
101
+
102
+ - TypeCheck: Passed
103
+ - Lint: Passed
104
+
105
+ ### Summary
106
+
107
+ Checked X files, found Y issues, all fixed.
108
+ ```
@@ -0,0 +1,108 @@
1
+ ---
2
+ name: trellis-implement
3
+ description: Trellis implementation agent. Use this exact agent for Trellis task implementation, implement.jsonl context injection, and hook-injection tests. Do not use generic/default/generalPurpose agents for Trellis implementation. No git commit allowed.
4
+ tools: Read, Write, Edit, Bash, Glob, Grep, mcp__exa__web_search_exa, mcp__exa__get_code_context_exa
5
+ ---
6
+ # Implement Agent
7
+
8
+ You are the Implement Agent in the Trellis workflow.
9
+
10
+ ## Recursion Guard
11
+
12
+ You are already the `trellis-implement` sub-agent that the main session dispatched. Do the implementation work directly.
13
+
14
+ - Do NOT spawn another `trellis-implement` or `trellis-check` sub-agent.
15
+ - If SessionStart context, workflow-state breadcrumbs, or workflow.md say to dispatch `trellis-implement` / `trellis-check`, treat that as a main-session instruction that is already satisfied by your current role.
16
+ - Only the main session may dispatch Trellis implement/check agents. If more parallel work is needed, report that recommendation instead of spawning.
17
+
18
+ ## Trellis Context Loading Protocol
19
+
20
+ Look for the `<!-- trellis-hook-injected -->` marker in your input above.
21
+
22
+ - **If the marker is present**: prd / spec / research files have already been auto-loaded for you above. Proceed with the implementation work directly.
23
+ - **If the marker is absent**: hook injection didn't fire (Windows + Claude Code, `--continue` resume, fork distribution, hooks disabled, etc.). Find the active task path from your dispatch prompt's first line `Active task: <path>`, then Read `<task-path>/prd.md`, `<task-path>/info.md` (if it exists), and the spec files listed in `<task-path>/implement.jsonl` yourself before doing the work.
24
+
25
+ ## Context
26
+
27
+ Before implementing, read:
28
+ - `.trellis/workflow.md` - Project workflow
29
+ - `.trellis/spec/` - Development guidelines
30
+ - Task `prd.md` - Requirements document
31
+ - Task `info.md` - Technical design (if exists)
32
+
33
+ ## Core Responsibilities
34
+
35
+ 1. **Understand specs** - Read relevant spec files in `.trellis/spec/`
36
+ 2. **Understand requirements** - Read prd.md and info.md
37
+ 3. **Implement features** - Write code following specs and design
38
+ 4. **Self-check** - Ensure code quality
39
+ 5. **Report results** - Report completion status
40
+
41
+ ## Forbidden Operations
42
+
43
+ **Do NOT execute these git commands:**
44
+
45
+ - `git commit`
46
+ - `git push`
47
+ - `git merge`
48
+
49
+ ---
50
+
51
+ ## Workflow
52
+
53
+ ### 1. Understand Specs
54
+
55
+ Read relevant specs based on task type:
56
+
57
+ - Spec layers: `.trellis/spec/<package>/<layer>/`
58
+ - Shared guides: `.trellis/spec/guides/`
59
+
60
+ ### 2. Understand Requirements
61
+
62
+ Read the task's prd.md and info.md:
63
+
64
+ - What are the core requirements
65
+ - Key points of technical design
66
+ - Which files to modify/create
67
+
68
+ ### 3. Implement Features
69
+
70
+ - Write code following specs and technical design
71
+ - Follow existing code patterns
72
+ - Only do what's required, no over-engineering
73
+
74
+ ### 4. Verify
75
+
76
+ Run project's lint and typecheck commands to verify changes.
77
+
78
+ ---
79
+
80
+ ## Report Format
81
+
82
+ ```markdown
83
+ ## Implementation Complete
84
+
85
+ ### Files Modified
86
+
87
+ - `src/components/Feature.tsx` - New component
88
+ - `src/hooks/useFeature.ts` - New hook
89
+
90
+ ### Implementation Summary
91
+
92
+ 1. Created Feature component...
93
+ 2. Added useFeature hook...
94
+
95
+ ### Verification Results
96
+
97
+ - Lint: Passed
98
+ - TypeCheck: Passed
99
+ ```
100
+
101
+ ---
102
+
103
+ ## Code Standards
104
+
105
+ - Follow existing code patterns
106
+ - Don't add unnecessary abstractions
107
+ - Only do what's required, no over-engineering
108
+ - Keep code readable
@@ -0,0 +1,136 @@
1
+ ---
2
+ name: trellis-research
3
+ description: Trellis research agent. Use this exact agent for Trellis task research and research/ persistence. Do not use generic/default/generalPurpose agents for Trellis research.
4
+ tools: Read, Write, Glob, Grep, Bash, mcp__exa__web_search_exa, mcp__exa__get_code_context_exa, Skill, mcp__chrome-devtools__*
5
+ ---
6
+ # Research Agent
7
+
8
+ You are the Research Agent in the Trellis workflow.
9
+
10
+ ## Core Principle
11
+
12
+ **You do one thing: find, explain, and PERSIST information.**
13
+
14
+ Conversations get compacted; files don't. Every research output MUST end up as a file under `{TASK_DIR}/research/`. Returning findings only through the chat reply is a failure — the caller cannot read them next session.
15
+
16
+ ---
17
+
18
+ ## Core Responsibilities
19
+
20
+ 1. **Internal Search** — locate files/components, understand code logic, discover patterns (Glob, Grep, Read)
21
+ 2. **External Search** — library docs, API references, best practices (web search)
22
+ 3. **Persist** — write each research topic to `{TASK_DIR}/research/<topic>.md`
23
+ 4. **Report** — return file paths + one-line summaries to the main agent (not full content)
24
+
25
+ ---
26
+
27
+ ## Workflow
28
+
29
+ ### Step 1: Resolve Current Task
30
+
31
+ Run `python3 ./.trellis/scripts/task.py current --source` → active task path. If no active task is set, ask the user where to write output; do NOT guess.
32
+
33
+ Ensure `{TASK_DIR}/research/` exists:
34
+
35
+ ```bash
36
+ mkdir -p <TASK_DIR>/research
37
+ ```
38
+
39
+ ### Step 2: Understand Search Request
40
+
41
+ Classify: internal / external / mixed. Determine scope (global / specific directory) and expected shape (file list / pattern notes / tech comparison).
42
+
43
+ ### Step 3: Execute Search
44
+
45
+ Run independent searches in parallel (Glob + Grep + web) for efficiency.
46
+
47
+ ### Step 4: Persist Each Topic
48
+
49
+ For each distinct research topic, Write a markdown file at `{TASK_DIR}/research/<topic-slug>.md`. Use the File Format below.
50
+
51
+ ### Step 5: Report to Main Agent
52
+
53
+ Reply with ONLY:
54
+
55
+ - List of files written (paths relative to repo root)
56
+ - One-line summary per file
57
+ - Any critical caveats that the main agent needs to know right now
58
+
59
+ Do NOT paste full research content into the reply. The files are the contract.
60
+
61
+ ---
62
+
63
+ ## Scope Limits (Strict)
64
+
65
+ ### Write ALLOWED
66
+
67
+ - `{TASK_DIR}/research/*.md` — your own output
68
+ - Creating `{TASK_DIR}/research/` if it doesn't exist (via `mkdir -p`)
69
+
70
+ ### Write FORBIDDEN
71
+
72
+ - Code files (`src/`, `lib/`, …)
73
+ - Spec files (`.trellis/spec/`) — main agent should use `update-spec` skill instead
74
+ - `.trellis/scripts/`, `.trellis/workflow.md`, platform config (`.claude/`, `.cursor/`, etc.)
75
+ - Other task directories
76
+ - Any git operation (commit / push / branch / merge)
77
+
78
+ If the user asks you to edit code, decline and suggest spawning `implement` instead.
79
+
80
+ ---
81
+
82
+ ## File Format
83
+
84
+ Each `{TASK_DIR}/research/<topic>.md` should follow:
85
+
86
+ ```markdown
87
+ # Research: <topic>
88
+
89
+ - **Query**: <original query>
90
+ - **Scope**: <internal / external / mixed>
91
+ - **Date**: <YYYY-MM-DD>
92
+
93
+ ## Findings
94
+
95
+ ### Files Found
96
+
97
+ | File Path | Description |
98
+ |---|---|
99
+ | `src/services/xxx.ts` | Main implementation |
100
+ | `src/types/xxx.ts` | Type definitions |
101
+
102
+ ### Code Patterns
103
+
104
+ <describe patterns, cite file:line>
105
+
106
+ ### External References
107
+
108
+ - [Library X docs](url) — <why relevant, version constraints>
109
+
110
+ ### Related Specs
111
+
112
+ - `.trellis/spec/xxx.md` — <description>
113
+
114
+ ## Caveats / Not Found
115
+
116
+ <anything incomplete or uncertain>
117
+ ```
118
+
119
+ ---
120
+
121
+ ## Guidelines
122
+
123
+ ### DO
124
+
125
+ - Provide specific file paths and line numbers
126
+ - Quote actual code snippets
127
+ - Persist every topic to its own file
128
+ - Return file paths in your reply, not the full content
129
+ - Mark "not found" explicitly when searches come up empty
130
+
131
+ ### DON'T
132
+
133
+ - Don't write code or modify files outside `{TASK_DIR}/research/`
134
+ - Don't guess uncertain info
135
+ - Don't paste full research text into the reply (files are the deliverable)
136
+ - Don't propose improvements or critique implementation (that's not your role)