trellis-herbivore 0.1.0
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.
- package/bin/trellis.js +3 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +174 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/commands/channel/adapters/claude.d.ts +38 -0
- package/dist/commands/channel/adapters/claude.d.ts.map +1 -0
- package/dist/commands/channel/adapters/claude.js +209 -0
- package/dist/commands/channel/adapters/claude.js.map +1 -0
- package/dist/commands/channel/adapters/codex.d.ts +77 -0
- package/dist/commands/channel/adapters/codex.d.ts.map +1 -0
- package/dist/commands/channel/adapters/codex.js +495 -0
- package/dist/commands/channel/adapters/codex.js.map +1 -0
- package/dist/commands/channel/adapters/index.d.ts +79 -0
- package/dist/commands/channel/adapters/index.d.ts.map +1 -0
- package/dist/commands/channel/adapters/index.js +109 -0
- package/dist/commands/channel/adapters/index.js.map +1 -0
- package/dist/commands/channel/adapters/types.d.ts +33 -0
- package/dist/commands/channel/adapters/types.d.ts.map +1 -0
- package/dist/commands/channel/adapters/types.js +2 -0
- package/dist/commands/channel/adapters/types.js.map +1 -0
- package/dist/commands/channel/agent-loader.d.ts +32 -0
- package/dist/commands/channel/agent-loader.d.ts.map +1 -0
- package/dist/commands/channel/agent-loader.js +154 -0
- package/dist/commands/channel/agent-loader.js.map +1 -0
- package/dist/commands/channel/context-loader.d.ts +26 -0
- package/dist/commands/channel/context-loader.d.ts.map +1 -0
- package/dist/commands/channel/context-loader.js +290 -0
- package/dist/commands/channel/context-loader.js.map +1 -0
- package/dist/commands/channel/context.d.ts +16 -0
- package/dist/commands/channel/context.d.ts.map +1 -0
- package/dist/commands/channel/context.js +83 -0
- package/dist/commands/channel/context.js.map +1 -0
- package/dist/commands/channel/create.d.ts +27 -0
- package/dist/commands/channel/create.d.ts.map +1 -0
- package/dist/commands/channel/create.js +39 -0
- package/dist/commands/channel/create.js.map +1 -0
- package/dist/commands/channel/dev-parse-trace.d.ts +14 -0
- package/dist/commands/channel/dev-parse-trace.d.ts.map +1 -0
- package/dist/commands/channel/dev-parse-trace.js +70 -0
- package/dist/commands/channel/dev-parse-trace.js.map +1 -0
- package/dist/commands/channel/index.d.ts +3 -0
- package/dist/commands/channel/index.d.ts.map +1 -0
- package/dist/commands/channel/index.js +496 -0
- package/dist/commands/channel/index.js.map +1 -0
- package/dist/commands/channel/kill.d.ts +7 -0
- package/dist/commands/channel/kill.d.ts.map +1 -0
- package/dist/commands/channel/kill.js +121 -0
- package/dist/commands/channel/kill.js.map +1 -0
- package/dist/commands/channel/list.d.ts +17 -0
- package/dist/commands/channel/list.d.ts.map +1 -0
- package/dist/commands/channel/list.js +233 -0
- package/dist/commands/channel/list.js.map +1 -0
- package/dist/commands/channel/messages.d.ts +16 -0
- package/dist/commands/channel/messages.d.ts.map +1 -0
- package/dist/commands/channel/messages.js +237 -0
- package/dist/commands/channel/messages.js.map +1 -0
- package/dist/commands/channel/rm.d.ts +27 -0
- package/dist/commands/channel/rm.d.ts.map +1 -0
- package/dist/commands/channel/rm.js +216 -0
- package/dist/commands/channel/rm.js.map +1 -0
- package/dist/commands/channel/run.d.ts +31 -0
- package/dist/commands/channel/run.d.ts.map +1 -0
- package/dist/commands/channel/run.js +137 -0
- package/dist/commands/channel/run.js.map +1 -0
- package/dist/commands/channel/send.d.ts +12 -0
- package/dist/commands/channel/send.d.ts.map +1 -0
- package/dist/commands/channel/send.js +24 -0
- package/dist/commands/channel/send.js.map +1 -0
- package/dist/commands/channel/spawn.d.ts +25 -0
- package/dist/commands/channel/spawn.d.ts.map +1 -0
- package/dist/commands/channel/spawn.js +192 -0
- package/dist/commands/channel/spawn.js.map +1 -0
- package/dist/commands/channel/store/events.d.ts +39 -0
- package/dist/commands/channel/store/events.d.ts.map +1 -0
- package/dist/commands/channel/store/events.js +87 -0
- package/dist/commands/channel/store/events.js.map +1 -0
- package/dist/commands/channel/store/filter.d.ts +3 -0
- package/dist/commands/channel/store/filter.d.ts.map +1 -0
- package/dist/commands/channel/store/filter.js +2 -0
- package/dist/commands/channel/store/filter.js.map +1 -0
- package/dist/commands/channel/store/lock.d.ts +23 -0
- package/dist/commands/channel/store/lock.d.ts.map +1 -0
- package/dist/commands/channel/store/lock.js +99 -0
- package/dist/commands/channel/store/lock.js.map +1 -0
- package/dist/commands/channel/store/paths.d.ts +63 -0
- package/dist/commands/channel/store/paths.d.ts.map +1 -0
- package/dist/commands/channel/store/paths.js +246 -0
- package/dist/commands/channel/store/paths.js.map +1 -0
- package/dist/commands/channel/store/schema.d.ts +27 -0
- package/dist/commands/channel/store/schema.d.ts.map +1 -0
- package/dist/commands/channel/store/schema.js +34 -0
- package/dist/commands/channel/store/schema.js.map +1 -0
- package/dist/commands/channel/store/thread-state.d.ts +5 -0
- package/dist/commands/channel/store/thread-state.d.ts.map +1 -0
- package/dist/commands/channel/store/thread-state.js +16 -0
- package/dist/commands/channel/store/thread-state.js.map +1 -0
- package/dist/commands/channel/store/watch.d.ts +19 -0
- package/dist/commands/channel/store/watch.d.ts.map +1 -0
- package/dist/commands/channel/store/watch.js +130 -0
- package/dist/commands/channel/store/watch.js.map +1 -0
- package/dist/commands/channel/supervisor/inbox.d.ts +25 -0
- package/dist/commands/channel/supervisor/inbox.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/inbox.js +99 -0
- package/dist/commands/channel/supervisor/inbox.js.map +1 -0
- package/dist/commands/channel/supervisor/shutdown.d.ts +66 -0
- package/dist/commands/channel/supervisor/shutdown.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/shutdown.js +143 -0
- package/dist/commands/channel/supervisor/shutdown.js.map +1 -0
- package/dist/commands/channel/supervisor/stdout.d.ts +49 -0
- package/dist/commands/channel/supervisor/stdout.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/stdout.js +107 -0
- package/dist/commands/channel/supervisor/stdout.js.map +1 -0
- package/dist/commands/channel/supervisor.d.ts +47 -0
- package/dist/commands/channel/supervisor.d.ts.map +1 -0
- package/dist/commands/channel/supervisor.js +283 -0
- package/dist/commands/channel/supervisor.js.map +1 -0
- package/dist/commands/channel/text-body.d.ts +13 -0
- package/dist/commands/channel/text-body.d.ts.map +1 -0
- package/dist/commands/channel/text-body.js +47 -0
- package/dist/commands/channel/text-body.js.map +1 -0
- package/dist/commands/channel/threads.d.ts +39 -0
- package/dist/commands/channel/threads.d.ts.map +1 -0
- package/dist/commands/channel/threads.js +106 -0
- package/dist/commands/channel/threads.js.map +1 -0
- package/dist/commands/channel/title.d.ts +12 -0
- package/dist/commands/channel/title.d.ts.map +1 -0
- package/dist/commands/channel/title.js +24 -0
- package/dist/commands/channel/title.js.map +1 -0
- package/dist/commands/channel/wait.d.ts +18 -0
- package/dist/commands/channel/wait.d.ts.map +1 -0
- package/dist/commands/channel/wait.js +76 -0
- package/dist/commands/channel/wait.js.map +1 -0
- package/dist/commands/init.d.ts +57 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +1466 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/mem.d.ts +234 -0
- package/dist/commands/mem.d.ts.map +1 -0
- package/dist/commands/mem.js +1869 -0
- package/dist/commands/mem.js.map +1 -0
- package/dist/commands/uninstall.d.ts +27 -0
- package/dist/commands/uninstall.d.ts.map +1 -0
- package/dist/commands/uninstall.js +339 -0
- package/dist/commands/uninstall.js.map +1 -0
- package/dist/commands/update.d.ts +72 -0
- package/dist/commands/update.d.ts.map +1 -0
- package/dist/commands/update.js +1926 -0
- package/dist/commands/update.js.map +1 -0
- package/dist/commands/upgrade.d.ts +28 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +84 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/configurators/antigravity.d.ts +7 -0
- package/dist/configurators/antigravity.d.ts.map +1 -0
- package/dist/configurators/antigravity.js +19 -0
- package/dist/configurators/antigravity.js.map +1 -0
- package/dist/configurators/claude.d.ts +9 -0
- package/dist/configurators/claude.d.ts.map +1 -0
- package/dist/configurators/claude.js +72 -0
- package/dist/configurators/claude.js.map +1 -0
- package/dist/configurators/codebuddy.d.ts +10 -0
- package/dist/configurators/codebuddy.d.ts.map +1 -0
- package/dist/configurators/codebuddy.js +30 -0
- package/dist/configurators/codebuddy.js.map +1 -0
- package/dist/configurators/codex.d.ts +8 -0
- package/dist/configurators/codex.d.ts.map +1 -0
- package/dist/configurators/codex.js +87 -0
- package/dist/configurators/codex.js.map +1 -0
- package/dist/configurators/copilot.d.ts +10 -0
- package/dist/configurators/copilot.d.ts.map +1 -0
- package/dist/configurators/copilot.js +51 -0
- package/dist/configurators/copilot.js.map +1 -0
- package/dist/configurators/cursor.d.ts +10 -0
- package/dist/configurators/cursor.d.ts.map +1 -0
- package/dist/configurators/cursor.js +29 -0
- package/dist/configurators/cursor.js.map +1 -0
- package/dist/configurators/droid.d.ts +10 -0
- package/dist/configurators/droid.d.ts.map +1 -0
- package/dist/configurators/droid.js +30 -0
- package/dist/configurators/droid.js.map +1 -0
- package/dist/configurators/gemini.d.ts +16 -0
- package/dist/configurators/gemini.d.ts.map +1 -0
- package/dist/configurators/gemini.js +38 -0
- package/dist/configurators/gemini.js.map +1 -0
- package/dist/configurators/index.d.ts +65 -0
- package/dist/configurators/index.d.ts.map +1 -0
- package/dist/configurators/index.js +367 -0
- package/dist/configurators/index.js.map +1 -0
- package/dist/configurators/kilo.d.ts +7 -0
- package/dist/configurators/kilo.d.ts.map +1 -0
- package/dist/configurators/kilo.js +19 -0
- package/dist/configurators/kilo.js.map +1 -0
- package/dist/configurators/kiro.d.ts +8 -0
- package/dist/configurators/kiro.d.ts.map +1 -0
- package/dist/configurators/kiro.js +24 -0
- package/dist/configurators/kiro.js.map +1 -0
- package/dist/configurators/opencode.d.ts +14 -0
- package/dist/configurators/opencode.d.ts.map +1 -0
- package/dist/configurators/opencode.js +96 -0
- package/dist/configurators/opencode.js.map +1 -0
- package/dist/configurators/pi.d.ts +3 -0
- package/dist/configurators/pi.d.ts.map +1 -0
- package/dist/configurators/pi.js +45 -0
- package/dist/configurators/pi.js.map +1 -0
- package/dist/configurators/qoder.d.ts +11 -0
- package/dist/configurators/qoder.d.ts.map +1 -0
- package/dist/configurators/qoder.js +31 -0
- package/dist/configurators/qoder.js.map +1 -0
- package/dist/configurators/shared.d.ts +178 -0
- package/dist/configurators/shared.d.ts.map +1 -0
- package/dist/configurators/shared.js +538 -0
- package/dist/configurators/shared.js.map +1 -0
- package/dist/configurators/windsurf.d.ts +7 -0
- package/dist/configurators/windsurf.d.ts.map +1 -0
- package/dist/configurators/windsurf.js +19 -0
- package/dist/configurators/windsurf.js.map +1 -0
- package/dist/configurators/workflow.d.ts +29 -0
- package/dist/configurators/workflow.d.ts.map +1 -0
- package/dist/configurators/workflow.js +163 -0
- package/dist/configurators/workflow.js.map +1 -0
- package/dist/constants/paths.d.ts +70 -0
- package/dist/constants/paths.d.ts.map +1 -0
- package/dist/constants/paths.js +79 -0
- package/dist/constants/paths.js.map +1 -0
- package/dist/constants/version.d.ts +9 -0
- package/dist/constants/version.d.ts.map +1 -0
- package/dist/constants/version.js +15 -0
- package/dist/constants/version.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/migrations/index.d.ts +62 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +187 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/migrations/manifests/0.1.9.json +30 -0
- package/dist/migrations/manifests/0.2.0.json +49 -0
- package/dist/migrations/manifests/0.2.12.json +9 -0
- package/dist/migrations/manifests/0.2.13.json +9 -0
- package/dist/migrations/manifests/0.2.14.json +175 -0
- package/dist/migrations/manifests/0.2.15.json +33 -0
- package/dist/migrations/manifests/0.3.0-beta.0.json +297 -0
- package/dist/migrations/manifests/0.3.0-beta.1.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.10.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.11.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.12.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.13.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.14.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.15.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.16.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.2.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.3.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.4.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.5.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.6.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.7.json +11 -0
- package/dist/migrations/manifests/0.3.0-beta.8.json +9 -0
- package/dist/migrations/manifests/0.3.0-beta.9.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.0.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.1.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.2.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.3.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.4.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.5.json +9 -0
- package/dist/migrations/manifests/0.3.0-rc.6.json +9 -0
- package/dist/migrations/manifests/0.3.0.json +11 -0
- package/dist/migrations/manifests/0.3.1.json +9 -0
- package/dist/migrations/manifests/0.3.10.json +9 -0
- package/dist/migrations/manifests/0.3.2.json +9 -0
- package/dist/migrations/manifests/0.3.3.json +9 -0
- package/dist/migrations/manifests/0.3.4.json +21 -0
- package/dist/migrations/manifests/0.3.5.json +9 -0
- package/dist/migrations/manifests/0.3.6.json +9 -0
- package/dist/migrations/manifests/0.3.7.json +9 -0
- package/dist/migrations/manifests/0.3.8.json +9 -0
- package/dist/migrations/manifests/0.3.9.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.1.json +228 -0
- package/dist/migrations/manifests/0.4.0-beta.10.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.2.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.3.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.4.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.5.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.6.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.7.json +9 -0
- package/dist/migrations/manifests/0.4.0-beta.8.json +34 -0
- package/dist/migrations/manifests/0.4.0-beta.9.json +9 -0
- package/dist/migrations/manifests/0.4.0-rc.0.json +9 -0
- package/dist/migrations/manifests/0.4.0-rc.1.json +9 -0
- package/dist/migrations/manifests/0.4.0.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.0.json +1646 -0
- package/dist/migrations/manifests/0.5.0-beta.1.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.10.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.11.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.12.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.13.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.14.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.15.json +116 -0
- package/dist/migrations/manifests/0.5.0-beta.16.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.17.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.18.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.19.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.2.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.3.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.4.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.5.json +222 -0
- package/dist/migrations/manifests/0.5.0-beta.6.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.7.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.8.json +9 -0
- package/dist/migrations/manifests/0.5.0-beta.9.json +48 -0
- package/dist/migrations/manifests/0.5.0-rc.0.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.1.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.2.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.3.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.4.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.5.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.6.json +9 -0
- package/dist/migrations/manifests/0.5.0-rc.7.json +9 -0
- package/dist/migrations/manifests/0.5.0.json +9 -0
- package/dist/migrations/manifests/0.5.1.json +9 -0
- package/dist/migrations/manifests/0.5.10.json +9 -0
- package/dist/migrations/manifests/0.5.11.json +16 -0
- package/dist/migrations/manifests/0.5.12.json +9 -0
- package/dist/migrations/manifests/0.5.13.json +9 -0
- package/dist/migrations/manifests/0.5.14.json +9 -0
- package/dist/migrations/manifests/0.5.15.json +9 -0
- package/dist/migrations/manifests/0.5.2.json +9 -0
- package/dist/migrations/manifests/0.5.3.json +9 -0
- package/dist/migrations/manifests/0.5.4.json +9 -0
- package/dist/migrations/manifests/0.5.5.json +9 -0
- package/dist/migrations/manifests/0.5.6.json +9 -0
- package/dist/migrations/manifests/0.5.7.json +16 -0
- package/dist/migrations/manifests/0.5.8.json +9 -0
- package/dist/migrations/manifests/0.5.9.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.0.json +16 -0
- package/dist/migrations/manifests/0.6.0-beta.1.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.10.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.11.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.12.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.13.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.14.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.2.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.3.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.4.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.5.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.6.json +16 -0
- package/dist/migrations/manifests/0.6.0-beta.7.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.8.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.9.json +9 -0
- package/dist/templates/claude/agents/trellis-check.md +114 -0
- package/dist/templates/claude/agents/trellis-implement.md +113 -0
- package/dist/templates/claude/agents/trellis-research.md +137 -0
- package/dist/templates/claude/index.d.ts +22 -0
- package/dist/templates/claude/index.d.ts.map +1 -0
- package/dist/templates/claude/index.js +46 -0
- package/dist/templates/claude/index.js.map +1 -0
- package/dist/templates/claude/settings.json +73 -0
- package/dist/templates/codebuddy/agents/trellis-check.md +109 -0
- package/dist/templates/codebuddy/agents/trellis-implement.md +110 -0
- package/dist/templates/codebuddy/agents/trellis-research.md +137 -0
- package/dist/templates/codebuddy/index.d.ts +15 -0
- package/dist/templates/codebuddy/index.d.ts.map +1 -0
- package/dist/templates/codebuddy/index.js +15 -0
- package/dist/templates/codebuddy/index.js.map +1 -0
- package/dist/templates/codebuddy/settings.json +59 -0
- package/dist/templates/codex/agents/trellis-check.toml +84 -0
- package/dist/templates/codex/agents/trellis-implement.toml +65 -0
- package/dist/templates/codex/agents/trellis-research.toml +73 -0
- package/dist/templates/codex/config.toml +35 -0
- package/dist/templates/codex/hooks/session-start.py +545 -0
- package/dist/templates/codex/hooks.json +15 -0
- package/dist/templates/codex/index.d.ts +39 -0
- package/dist/templates/codex/index.d.ts.map +1 -0
- package/dist/templates/codex/index.js +85 -0
- package/dist/templates/codex/index.js.map +1 -0
- package/dist/templates/codex/skills/before-dev/SKILL.md +40 -0
- package/dist/templates/codex/skills/brainstorm/SKILL.md +112 -0
- package/dist/templates/codex/skills/break-loop/SKILL.md +130 -0
- package/dist/templates/codex/skills/check/SKILL.md +98 -0
- package/dist/templates/codex/skills/check-cross-layer/SKILL.md +158 -0
- package/dist/templates/codex/skills/create-command/SKILL.md +101 -0
- package/dist/templates/codex/skills/finish-work/SKILL.md +90 -0
- package/dist/templates/codex/skills/improve-ut/SKILL.md +69 -0
- package/dist/templates/codex/skills/integrate-skill/SKILL.md +221 -0
- package/dist/templates/codex/skills/onboard/SKILL.md +363 -0
- package/dist/templates/codex/skills/record-session/SKILL.md +67 -0
- package/dist/templates/codex/skills/start/SKILL.md +64 -0
- package/dist/templates/codex/skills/update-spec/SKILL.md +335 -0
- package/dist/templates/common/bundled-skills/trellis-meta/SKILL.md +73 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/add-project-local-conventions.md +83 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-agents.md +54 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-context-loading.md +84 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-hooks.md +57 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-skills-or-commands.md +78 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-spec-structure.md +83 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-task-lifecycle.md +90 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/change-workflow.md +65 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/customize-local/overview.md +55 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/context-injection.md +68 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/generated-files.md +80 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/overview.md +51 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/spec-system.md +102 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/task-system.md +103 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/workflow.md +75 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/local-architecture/workspace-memory.md +71 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/agents.md +80 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/hooks-and-settings.md +69 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/overview.md +59 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/platform-map.md +74 -0
- package/dist/templates/common/bundled-skills/trellis-meta/references/platform-files/skills-and-commands.md +83 -0
- package/dist/templates/common/commands/continue.md +56 -0
- package/dist/templates/common/commands/finish-work.md +66 -0
- package/dist/templates/common/commands/start.md +59 -0
- package/dist/templates/common/index.d.ts +48 -0
- package/dist/templates/common/index.d.ts.map +1 -0
- package/dist/templates/common/index.js +104 -0
- package/dist/templates/common/index.js.map +1 -0
- package/dist/templates/common/skills/before-dev.md +35 -0
- package/dist/templates/common/skills/brainstorm.md +112 -0
- package/dist/templates/common/skills/break-loop.md +125 -0
- package/dist/templates/common/skills/check.md +93 -0
- package/dist/templates/common/skills/update-spec.md +351 -0
- package/dist/templates/copilot/hooks/session-start.py +547 -0
- package/dist/templates/copilot/hooks.json +19 -0
- package/dist/templates/copilot/index.d.ts +23 -0
- package/dist/templates/copilot/index.d.ts.map +1 -0
- package/dist/templates/copilot/index.js +54 -0
- package/dist/templates/copilot/index.js.map +1 -0
- package/dist/templates/copilot/prompts/before-dev.prompt.md +39 -0
- package/dist/templates/copilot/prompts/brainstorm.prompt.md +111 -0
- package/dist/templates/copilot/prompts/break-loop.prompt.md +129 -0
- package/dist/templates/copilot/prompts/check-cross-layer.prompt.md +157 -0
- package/dist/templates/copilot/prompts/check.prompt.md +97 -0
- package/dist/templates/copilot/prompts/create-command.prompt.md +116 -0
- package/dist/templates/copilot/prompts/finish-work.prompt.md +99 -0
- package/dist/templates/copilot/prompts/integrate-skill.prompt.md +223 -0
- package/dist/templates/copilot/prompts/onboard.prompt.md +362 -0
- package/dist/templates/copilot/prompts/parallel.prompt.md +204 -0
- package/dist/templates/copilot/prompts/record-session.prompt.md +66 -0
- package/dist/templates/copilot/prompts/start.prompt.md +63 -0
- package/dist/templates/copilot/prompts/update-spec.prompt.md +358 -0
- package/dist/templates/cursor/agents/trellis-check.md +108 -0
- package/dist/templates/cursor/agents/trellis-implement.md +109 -0
- package/dist/templates/cursor/agents/trellis-research.md +136 -0
- package/dist/templates/cursor/hooks.json +30 -0
- package/dist/templates/cursor/index.d.ts +13 -0
- package/dist/templates/cursor/index.d.ts.map +1 -0
- package/dist/templates/cursor/index.js +13 -0
- package/dist/templates/cursor/index.js.map +1 -0
- package/dist/templates/droid/droids/trellis-check.md +101 -0
- package/dist/templates/droid/droids/trellis-implement.md +102 -0
- package/dist/templates/droid/droids/trellis-research.md +137 -0
- package/dist/templates/droid/index.d.ts +15 -0
- package/dist/templates/droid/index.d.ts.map +1 -0
- package/dist/templates/droid/index.js +15 -0
- package/dist/templates/droid/index.js.map +1 -0
- package/dist/templates/droid/settings.json +59 -0
- package/dist/templates/extract.d.ts +40 -0
- package/dist/templates/extract.d.ts.map +1 -0
- package/dist/templates/extract.js +106 -0
- package/dist/templates/extract.js.map +1 -0
- package/dist/templates/gemini/agents/trellis-check.md +101 -0
- package/dist/templates/gemini/agents/trellis-implement.md +102 -0
- package/dist/templates/gemini/agents/trellis-research.md +136 -0
- package/dist/templates/gemini/index.d.ts +13 -0
- package/dist/templates/gemini/index.d.ts.map +1 -0
- package/dist/templates/gemini/index.js +13 -0
- package/dist/templates/gemini/index.js.map +1 -0
- package/dist/templates/gemini/settings.json +28 -0
- package/dist/templates/kiro/agents/trellis-check.json +26 -0
- package/dist/templates/kiro/agents/trellis-implement.json +26 -0
- package/dist/templates/kiro/agents/trellis-research.json +30 -0
- package/dist/templates/kiro/index.d.ts +18 -0
- package/dist/templates/kiro/index.d.ts.map +1 -0
- package/dist/templates/kiro/index.js +18 -0
- package/dist/templates/kiro/index.js.map +1 -0
- package/dist/templates/markdown/agents.md +21 -0
- package/dist/templates/markdown/gitignore.txt +15 -0
- package/dist/templates/markdown/index.d.ts +27 -0
- package/dist/templates/markdown/index.d.ts.map +1 -0
- package/dist/templates/markdown/index.js +52 -0
- package/dist/templates/markdown/index.js.map +1 -0
- package/dist/templates/markdown/spec/backend/database-guidelines.md.txt +51 -0
- package/dist/templates/markdown/spec/backend/directory-structure.md.txt +54 -0
- package/dist/templates/markdown/spec/backend/error-handling.md.txt +51 -0
- package/dist/templates/markdown/spec/backend/index.md.txt +38 -0
- package/dist/templates/markdown/spec/backend/logging-guidelines.md.txt +51 -0
- package/dist/templates/markdown/spec/backend/quality-guidelines.md.txt +51 -0
- package/dist/templates/markdown/spec/frontend/component-guidelines.md.txt +59 -0
- package/dist/templates/markdown/spec/frontend/directory-structure.md.txt +54 -0
- package/dist/templates/markdown/spec/frontend/hook-guidelines.md.txt +51 -0
- package/dist/templates/markdown/spec/frontend/index.md.txt +39 -0
- package/dist/templates/markdown/spec/frontend/quality-guidelines.md.txt +51 -0
- package/dist/templates/markdown/spec/frontend/state-management.md.txt +51 -0
- package/dist/templates/markdown/spec/frontend/type-safety.md.txt +51 -0
- package/dist/templates/markdown/spec/guides/code-reuse-thinking-guide.md.txt +223 -0
- package/dist/templates/markdown/spec/guides/cross-layer-thinking-guide.md.txt +259 -0
- package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md.txt +595 -0
- package/dist/templates/markdown/spec/guides/index.md.txt +97 -0
- package/dist/templates/markdown/workspace-index.md +125 -0
- package/dist/templates/markdown/worktree.yaml.txt +58 -0
- package/dist/templates/opencode/agents/trellis-check.md +116 -0
- package/dist/templates/opencode/agents/trellis-implement.md +118 -0
- package/dist/templates/opencode/agents/trellis-research.md +145 -0
- package/dist/templates/opencode/lib/session-utils.js +521 -0
- package/dist/templates/opencode/lib/trellis-context.js +381 -0
- package/dist/templates/opencode/package.json +5 -0
- package/dist/templates/opencode/plugins/inject-subagent-context.js +513 -0
- package/dist/templates/opencode/plugins/inject-workflow-state.js +159 -0
- package/dist/templates/opencode/plugins/session-start.js +101 -0
- package/dist/templates/pi/agents/trellis-check.md +36 -0
- package/dist/templates/pi/agents/trellis-implement.md +41 -0
- package/dist/templates/pi/agents/trellis-research.md +25 -0
- package/dist/templates/pi/extensions/trellis/index.ts.txt +1174 -0
- package/dist/templates/pi/index.d.ts +5 -0
- package/dist/templates/pi/index.d.ts.map +1 -0
- package/dist/templates/pi/index.js +12 -0
- package/dist/templates/pi/index.js.map +1 -0
- package/dist/templates/pi/settings.json +21 -0
- package/dist/templates/qoder/agents/trellis-check.md +102 -0
- package/dist/templates/qoder/agents/trellis-implement.md +103 -0
- package/dist/templates/qoder/agents/trellis-research.md +137 -0
- package/dist/templates/qoder/index.d.ts +15 -0
- package/dist/templates/qoder/index.d.ts.map +1 -0
- package/dist/templates/qoder/index.js +15 -0
- package/dist/templates/qoder/index.js.map +1 -0
- package/dist/templates/qoder/settings.json +47 -0
- package/dist/templates/shared-hooks/index.d.ts +50 -0
- package/dist/templates/shared-hooks/index.d.ts.map +1 -0
- package/dist/templates/shared-hooks/index.js +89 -0
- package/dist/templates/shared-hooks/index.js.map +1 -0
- package/dist/templates/shared-hooks/inject-shell-session-context.py +183 -0
- package/dist/templates/shared-hooks/inject-subagent-context.py +771 -0
- package/dist/templates/shared-hooks/inject-workflow-state.py +363 -0
- package/dist/templates/shared-hooks/session-start.py +827 -0
- package/dist/templates/template-utils.d.ts +26 -0
- package/dist/templates/template-utils.d.ts.map +1 -0
- package/dist/templates/template-utils.js +60 -0
- package/dist/templates/template-utils.js.map +1 -0
- package/dist/templates/trellis/config.yaml +90 -0
- package/dist/templates/trellis/gitignore.txt +32 -0
- package/dist/templates/trellis/index.d.ts +52 -0
- package/dist/templates/trellis/index.d.ts.map +1 -0
- package/dist/templates/trellis/index.js +97 -0
- package/dist/templates/trellis/index.js.map +1 -0
- package/dist/templates/trellis/scripts/__init__.py +5 -0
- package/dist/templates/trellis/scripts/add_session.py +547 -0
- package/dist/templates/trellis/scripts/common/__init__.py +92 -0
- package/dist/templates/trellis/scripts/common/active_task.py +626 -0
- package/dist/templates/trellis/scripts/common/cli_adapter.py +811 -0
- package/dist/templates/trellis/scripts/common/config.py +445 -0
- package/dist/templates/trellis/scripts/common/developer.py +190 -0
- package/dist/templates/trellis/scripts/common/git.py +31 -0
- package/dist/templates/trellis/scripts/common/git_context.py +106 -0
- package/dist/templates/trellis/scripts/common/io.py +37 -0
- package/dist/templates/trellis/scripts/common/log.py +45 -0
- package/dist/templates/trellis/scripts/common/packages_context.py +238 -0
- package/dist/templates/trellis/scripts/common/paths.py +447 -0
- package/dist/templates/trellis/scripts/common/safe_commit.py +285 -0
- package/dist/templates/trellis/scripts/common/session_context.py +821 -0
- package/dist/templates/trellis/scripts/common/task_context.py +223 -0
- package/dist/templates/trellis/scripts/common/task_queue.py +188 -0
- package/dist/templates/trellis/scripts/common/task_store.py +698 -0
- package/dist/templates/trellis/scripts/common/task_utils.py +274 -0
- package/dist/templates/trellis/scripts/common/tasks.py +112 -0
- package/dist/templates/trellis/scripts/common/trellis_config.py +131 -0
- package/dist/templates/trellis/scripts/common/types.py +110 -0
- package/dist/templates/trellis/scripts/common/workflow_phase.py +212 -0
- package/dist/templates/trellis/scripts/get_context.py +16 -0
- package/dist/templates/trellis/scripts/get_developer.py +26 -0
- package/dist/templates/trellis/scripts/hooks/linear_sync.py +243 -0
- package/dist/templates/trellis/scripts/init_developer.py +51 -0
- package/dist/templates/trellis/scripts/task.py +500 -0
- package/dist/templates/trellis/tasks/.gitkeep +0 -0
- package/dist/templates/trellis/workflow.md +690 -0
- package/dist/types/ai-tools.d.ts +95 -0
- package/dist/types/ai-tools.d.ts.map +1 -0
- package/dist/types/ai-tools.js +280 -0
- package/dist/types/ai-tools.js.map +1 -0
- package/dist/types/migration.d.ts +125 -0
- package/dist/types/migration.d.ts.map +1 -0
- package/dist/types/migration.js +8 -0
- package/dist/types/migration.js.map +1 -0
- package/dist/utils/compare-versions.d.ts +12 -0
- package/dist/utils/compare-versions.d.ts.map +1 -0
- package/dist/utils/compare-versions.js +86 -0
- package/dist/utils/compare-versions.js.map +1 -0
- package/dist/utils/cwd-guard.d.ts +38 -0
- package/dist/utils/cwd-guard.d.ts.map +1 -0
- package/dist/utils/cwd-guard.js +62 -0
- package/dist/utils/cwd-guard.js.map +1 -0
- package/dist/utils/file-writer.d.ts +36 -0
- package/dist/utils/file-writer.d.ts.map +1 -0
- package/dist/utils/file-writer.js +203 -0
- package/dist/utils/file-writer.js.map +1 -0
- package/dist/utils/manifest-prune.d.ts +61 -0
- package/dist/utils/manifest-prune.d.ts.map +1 -0
- package/dist/utils/manifest-prune.js +136 -0
- package/dist/utils/manifest-prune.js.map +1 -0
- package/dist/utils/posix.d.ts +13 -0
- package/dist/utils/posix.d.ts.map +1 -0
- package/dist/utils/posix.js +15 -0
- package/dist/utils/posix.js.map +1 -0
- package/dist/utils/project-detector.d.ts +46 -0
- package/dist/utils/project-detector.d.ts.map +1 -0
- package/dist/utils/project-detector.js +666 -0
- package/dist/utils/project-detector.js.map +1 -0
- package/dist/utils/proxy.d.ts +25 -0
- package/dist/utils/proxy.d.ts.map +1 -0
- package/dist/utils/proxy.js +60 -0
- package/dist/utils/proxy.js.map +1 -0
- package/dist/utils/task-json.d.ts +13 -0
- package/dist/utils/task-json.d.ts.map +1 -0
- package/dist/utils/task-json.js +12 -0
- package/dist/utils/task-json.js.map +1 -0
- package/dist/utils/template-fetcher.d.ts +150 -0
- package/dist/utils/template-fetcher.d.ts.map +1 -0
- package/dist/utils/template-fetcher.js +907 -0
- package/dist/utils/template-fetcher.js.map +1 -0
- package/dist/utils/template-hash.d.ts +123 -0
- package/dist/utils/template-hash.d.ts.map +1 -0
- package/dist/utils/template-hash.js +334 -0
- package/dist/utils/template-hash.js.map +1 -0
- package/dist/utils/uninstall-scrubbers.d.ts +66 -0
- package/dist/utils/uninstall-scrubbers.d.ts.map +1 -0
- package/dist/utils/uninstall-scrubbers.js +342 -0
- package/dist/utils/uninstall-scrubbers.js.map +1 -0
- package/package.json +90 -0
|
@@ -0,0 +1,690 @@
|
|
|
1
|
+
# Development Workflow
|
|
2
|
+
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
## Core Principles
|
|
6
|
+
|
|
7
|
+
1. **Plan before code** — figure out what to do before you start
|
|
8
|
+
2. **Specs injected, not remembered** — guidelines are injected via hook/skill, not recalled from memory
|
|
9
|
+
3. **Persist everything** — research, decisions, and lessons all go to files; conversations get compacted, files don't
|
|
10
|
+
4. **Incremental development** — one task at a time
|
|
11
|
+
5. **Capture learnings** — after each task, review and write new knowledge back to spec
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## Trellis System
|
|
16
|
+
|
|
17
|
+
### Developer Identity
|
|
18
|
+
|
|
19
|
+
On first use, initialize your identity:
|
|
20
|
+
|
|
21
|
+
```bash
|
|
22
|
+
python3 ./.trellis/scripts/init_developer.py <your-name>
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
Creates `.trellis/.developer` (gitignored) + `.trellis/workspace/<your-name>/`.
|
|
26
|
+
|
|
27
|
+
### Spec System
|
|
28
|
+
|
|
29
|
+
`.trellis/spec/` holds coding guidelines organized by package and layer.
|
|
30
|
+
|
|
31
|
+
- `.trellis/spec/<package>/<layer>/index.md` — entry point with **Pre-Development Checklist** + **Quality Check**. Actual guidelines live in the `.md` files it points to.
|
|
32
|
+
- `.trellis/spec/guides/index.md` — cross-package thinking guides.
|
|
33
|
+
|
|
34
|
+
```bash
|
|
35
|
+
python3 ./.trellis/scripts/get_context.py --mode packages # list packages / layers
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
**When to update spec**: new pattern/convention found · bug-fix prevention to codify · new technical decision.
|
|
39
|
+
|
|
40
|
+
### Task System
|
|
41
|
+
|
|
42
|
+
Every task has its own directory under `.trellis/tasks/{MM-DD-name}/` holding `task.json`, `prd.md`, optional `design.md`, optional `implement.md`, optional `research/`, and context manifests (`implement.jsonl`, `check.jsonl`) for sub-agent-capable platforms.
|
|
43
|
+
|
|
44
|
+
```bash
|
|
45
|
+
# Task lifecycle
|
|
46
|
+
python3 ./.trellis/scripts/task.py create "<title>" [--slug <name>] [--parent <dir>]
|
|
47
|
+
python3 ./.trellis/scripts/task.py start <name> # set active task (session-scoped when available)
|
|
48
|
+
python3 ./.trellis/scripts/task.py current --source # show active task and source
|
|
49
|
+
python3 ./.trellis/scripts/task.py finish # clear active task (triggers after_finish hooks)
|
|
50
|
+
python3 ./.trellis/scripts/task.py archive <name> # move to archive/{year-month}/
|
|
51
|
+
python3 ./.trellis/scripts/task.py list [--mine] [--status <s>]
|
|
52
|
+
python3 ./.trellis/scripts/task.py list-archive
|
|
53
|
+
|
|
54
|
+
# Code-spec context (injected into implement/check agents via JSONL).
|
|
55
|
+
# `implement.jsonl` / `check.jsonl` are seeded on `task create` for sub-agent-capable
|
|
56
|
+
# platforms; the AI curates real spec + research entries during planning when needed.
|
|
57
|
+
python3 ./.trellis/scripts/task.py add-context <name> <action> <file> <reason>
|
|
58
|
+
python3 ./.trellis/scripts/task.py list-context <name> [action]
|
|
59
|
+
python3 ./.trellis/scripts/task.py validate <name>
|
|
60
|
+
|
|
61
|
+
# Task metadata
|
|
62
|
+
python3 ./.trellis/scripts/task.py set-branch <name> <branch>
|
|
63
|
+
python3 ./.trellis/scripts/task.py set-base-branch <name> <branch> # PR target
|
|
64
|
+
python3 ./.trellis/scripts/task.py set-scope <name> <scope>
|
|
65
|
+
|
|
66
|
+
# Hierarchy (parent/child)
|
|
67
|
+
python3 ./.trellis/scripts/task.py add-subtask <parent> <child>
|
|
68
|
+
python3 ./.trellis/scripts/task.py remove-subtask <parent> <child>
|
|
69
|
+
|
|
70
|
+
# PR creation
|
|
71
|
+
python3 ./.trellis/scripts/task.py create-pr [name] [--dry-run]
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
> Run `python3 ./.trellis/scripts/task.py --help` to see the authoritative, up-to-date list.
|
|
75
|
+
|
|
76
|
+
**Current-task mechanism**: `task.py create` creates the task directory and (when session identity is available) auto-sets the per-session active-task pointer so the planning breadcrumb fires immediately. `task.py start` writes the same pointer (idempotent if already set) and flips `task.json.status` from `planning` to `in_progress`. State is stored under `.trellis/.runtime/sessions/`. If no context key is available from hook input, `TRELLIS_CONTEXT_ID`, or a platform-native session environment variable, there is no active task and `task.py start` fails with a session identity hint. `task.py finish` deletes the current session file (status unchanged). `task.py archive <task>` writes `status=completed`, moves the directory to `archive/`, and deletes any runtime session files that still point at the archived task.
|
|
77
|
+
|
|
78
|
+
### Workspace System
|
|
79
|
+
|
|
80
|
+
Records every AI session for cross-session tracking under `.trellis/workspace/<developer>/`.
|
|
81
|
+
|
|
82
|
+
- `journal-N.md` — session log. **Max 2000 lines per file**; a new `journal-(N+1).md` is auto-created when exceeded.
|
|
83
|
+
- `index.md` — personal index (total sessions, last active).
|
|
84
|
+
|
|
85
|
+
```bash
|
|
86
|
+
python3 ./.trellis/scripts/add_session.py --title "Title" --commit "hash" --summary "Summary"
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### Context Script
|
|
90
|
+
|
|
91
|
+
```bash
|
|
92
|
+
python3 ./.trellis/scripts/get_context.py # full session runtime
|
|
93
|
+
python3 ./.trellis/scripts/get_context.py --mode packages # available packages + spec layers
|
|
94
|
+
python3 ./.trellis/scripts/get_context.py --mode phase --step <X.Y> # detailed guide for a workflow step
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
---
|
|
98
|
+
|
|
99
|
+
<!--
|
|
100
|
+
WORKFLOW-STATE BREADCRUMB CONTRACT (read this before editing the tag blocks below)
|
|
101
|
+
|
|
102
|
+
The [workflow-state:STATUS] blocks embedded in the ## Phase Index section
|
|
103
|
+
below are the SINGLE source of truth for the per-turn `<workflow-state>`
|
|
104
|
+
breadcrumb that every supported AI platform's UserPromptSubmit hook
|
|
105
|
+
reads. inject-workflow-state.py (Python platforms) and
|
|
106
|
+
inject-workflow-state.js (OpenCode plugin) only parse them — there is no
|
|
107
|
+
fallback dict baked into the scripts after v0.5.0-rc.0.
|
|
108
|
+
|
|
109
|
+
STATUS charset: [A-Za-z0-9_-]+. When the hook can't find a tag, it
|
|
110
|
+
degrades to a generic "Refer to workflow.md for current step." line —
|
|
111
|
+
intentionally visible so users notice and fix a broken workflow.md.
|
|
112
|
+
|
|
113
|
+
INVARIANT (test/regression.test.ts):
|
|
114
|
+
Every workflow-walkthrough step marked `[required · once]` must have a
|
|
115
|
+
matching enforcement line in its phase's [workflow-state:*] block. The
|
|
116
|
+
breadcrumb is the only per-turn channel; if a mandatory step isn't
|
|
117
|
+
mentioned there, the AI silently skips it (Phase 1 planning gate
|
|
118
|
+
skip and Phase 3.4 commit skip both manifested via this gap).
|
|
119
|
+
|
|
120
|
+
TAG ↔ PHASE scoping:
|
|
121
|
+
[workflow-state:no_task] → no active task; before Phase 1
|
|
122
|
+
[workflow-state:planning] → all of Phase 1 (status='planning')
|
|
123
|
+
[workflow-state:planning-inline] → Codex inline variant of Phase 1
|
|
124
|
+
[workflow-state:in_progress] → Phase 2 + Phase 3.1-3.4
|
|
125
|
+
(status stays 'in_progress' from
|
|
126
|
+
task.py start until task.py archive)
|
|
127
|
+
[workflow-state:in_progress-inline] → Codex inline variant of Phase 2/3
|
|
128
|
+
[workflow-state:completed] → currently DEAD: cmd_archive flips
|
|
129
|
+
status and moves the dir in the same
|
|
130
|
+
call, so the resolver loses the
|
|
131
|
+
pointer (block kept for a future
|
|
132
|
+
explicit in_progress→completed
|
|
133
|
+
transition)
|
|
134
|
+
|
|
135
|
+
Editing checklist:
|
|
136
|
+
- When you change a [workflow-state:STATUS] block, also check the
|
|
137
|
+
matching phase's `[required · once]` walkthrough steps for sync
|
|
138
|
+
- Run `trellis update` after editing to push the new bodies to
|
|
139
|
+
downstream user projects (block-level managed replacement)
|
|
140
|
+
- Full runtime contract:
|
|
141
|
+
.trellis/spec/cli/backend/workflow-state-contract.md
|
|
142
|
+
-->
|
|
143
|
+
|
|
144
|
+
## Phase Index
|
|
145
|
+
|
|
146
|
+
```
|
|
147
|
+
Phase 1: Plan → classify, get task-creation consent, then write planning artifacts
|
|
148
|
+
Phase 2: Execute → implement only after task status is in_progress
|
|
149
|
+
Phase 3: Finish → verify, update spec, commit, and wrap up
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
### Request Triage
|
|
153
|
+
|
|
154
|
+
- Simple conversation or small task: ask only whether this turn should create a Trellis task. If the user says no, skip Trellis for this session.
|
|
155
|
+
- Complex task: ask whether you may create a Trellis task and enter planning. If the user says no, do not do broad inline implementation; explain, clarify scope, or suggest a smaller split.
|
|
156
|
+
- User approval to create a task is not approval to start implementation. Planning still happens first.
|
|
157
|
+
|
|
158
|
+
### Planning Artifacts
|
|
159
|
+
|
|
160
|
+
- `prd.md` — requirements, constraints, and acceptance criteria. Do not put technical design or execution checklists here.
|
|
161
|
+
- `design.md` — technical design for complex tasks: boundaries, contracts, data flow, tradeoffs, compatibility, rollout / rollback shape.
|
|
162
|
+
- `implement.md` — execution plan for complex tasks: ordered checklist, validation commands, review gates, and rollback points.
|
|
163
|
+
- `implement.jsonl` / `check.jsonl` — spec and research manifests for sub-agent context. They do not replace `implement.md`.
|
|
164
|
+
- Lightweight tasks may be PRD-only. Complex tasks must have `prd.md`, `design.md`, and `implement.md` before `task.py start`.
|
|
165
|
+
|
|
166
|
+
<!-- Per-turn breadcrumb: shown when there is no active task (before Phase 1) -->
|
|
167
|
+
|
|
168
|
+
[workflow-state:no_task]
|
|
169
|
+
No active task. First classify the current turn and ask for task-creation consent before creating any Trellis task.
|
|
170
|
+
Simple conversation / small task: ask only whether this turn should create a Trellis task. If the user says no, skip Trellis for this session.
|
|
171
|
+
Complex task: ask the user if you can create a Trellis task and enter the planning phase. If the user says no, explain, clarify scope, or suggest a smaller split.
|
|
172
|
+
[/workflow-state:no_task]
|
|
173
|
+
|
|
174
|
+
### Phase 1: Plan
|
|
175
|
+
- 1.0 Create task `[required · once]` (only after task-creation consent)
|
|
176
|
+
- 1.1 Requirement exploration `[required · repeatable]` (`prd.md`; complex tasks also need `design.md` + `implement.md`)
|
|
177
|
+
- 1.2 Research `[optional · repeatable]`
|
|
178
|
+
- 1.3 Configure context `[conditional · once]` — Claude Code, Cursor, OpenCode, Codex, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi
|
|
179
|
+
- 1.4 Activate task `[required · once]` (review gate, then `task.py start`; status → in_progress)
|
|
180
|
+
- 1.5 Completion criteria
|
|
181
|
+
|
|
182
|
+
<!-- Per-turn breadcrumb: shown throughout Phase 1 (status='planning') -->
|
|
183
|
+
|
|
184
|
+
[workflow-state:planning]
|
|
185
|
+
Load `trellis-brainstorm`; stay in planning.
|
|
186
|
+
Lightweight: `prd.md` can be enough. Complex: finish `prd.md`, `design.md`, and `implement.md`; ask for review before `task.py start`.
|
|
187
|
+
Sub-agent mode: curate `implement.jsonl` and `check.jsonl` as spec/research manifests before start.
|
|
188
|
+
[/workflow-state:planning]
|
|
189
|
+
|
|
190
|
+
<!-- Per-turn breadcrumb: shown throughout Phase 1 when codex.dispatch_mode=inline.
|
|
191
|
+
Codex-only opt-in alternate to [workflow-state:planning]. The main agent
|
|
192
|
+
edits code directly in Phase 2, so jsonl curation is skipped —
|
|
193
|
+
the inline workflow loads `trellis-before-dev` instead of injecting JSONL
|
|
194
|
+
into a sub-agent. -->
|
|
195
|
+
|
|
196
|
+
[workflow-state:planning-inline]
|
|
197
|
+
Load `trellis-brainstorm`; stay in planning.
|
|
198
|
+
Lightweight: `prd.md` can be enough. Complex: finish `prd.md`, `design.md`, and `implement.md`; ask for review before `task.py start`.
|
|
199
|
+
Inline mode: skip jsonl curation; Phase 2 reads artifacts/specs via `trellis-before-dev`.
|
|
200
|
+
[/workflow-state:planning-inline]
|
|
201
|
+
|
|
202
|
+
### Phase 2: Execute
|
|
203
|
+
- 2.1 Implement `[required · repeatable]`
|
|
204
|
+
- 2.2 Quality check `[required · repeatable]`
|
|
205
|
+
- 2.3 Rollback `[on demand]`
|
|
206
|
+
|
|
207
|
+
<!-- Per-turn breadcrumb: shown while status='in_progress'.
|
|
208
|
+
Scope: all of Phase 2 + Phase 3.1-3.4 (status stays 'in_progress' from
|
|
209
|
+
task.py start until task.py archive; only archive flips it). The body
|
|
210
|
+
therefore must cover every required step from implementation through
|
|
211
|
+
commit, including Phase 3.3 spec update and Phase 3.4 commit. -->
|
|
212
|
+
|
|
213
|
+
Sub-agent dispatch protocol applies to all platforms and all sub-agents, including class-2 Codex/Copilot/Gemini/Qoder and `trellis-research`: every dispatch prompt starts with `Active task: <task path from task.py current>` before role-specific instructions.
|
|
214
|
+
|
|
215
|
+
[workflow-state:in_progress]
|
|
216
|
+
Flow: `trellis-implement` -> `trellis-check` -> `trellis-update-spec` -> commit (Phase 3.4) -> `/trellis:finish-work`.
|
|
217
|
+
Main-session default: dispatch implement/check sub-agents. Sub-agent self-exemption: if already running as `trellis-implement`, do NOT spawn another `trellis-implement` or `trellis-check`; if already running as `trellis-check`, do NOT spawn another `trellis-check` or `trellis-implement`. Dispatch is main session only.
|
|
218
|
+
Dispatch prompt starts with `Active task: <task path from task.py current>`. Read context: jsonl entries -> `prd.md` -> `design.md if present` -> `implement.md if present`.
|
|
219
|
+
[/workflow-state:in_progress]
|
|
220
|
+
|
|
221
|
+
<!-- Per-turn breadcrumb: shown while status='in_progress' when
|
|
222
|
+
codex.dispatch_mode=inline. Codex-only opt-in alternate to
|
|
223
|
+
[workflow-state:in_progress]. The main session edits code directly
|
|
224
|
+
instead of dispatching sub-agents. -->
|
|
225
|
+
|
|
226
|
+
[workflow-state:in_progress-inline]
|
|
227
|
+
Flow: `trellis-before-dev` -> edit -> `trellis-check` -> validation -> `trellis-update-spec` -> commit (Phase 3.4) -> `/trellis:finish-work`.
|
|
228
|
+
Do not dispatch implement/check sub-agents in inline mode.
|
|
229
|
+
Read context: `prd.md` -> `design.md if present` -> `implement.md if present`, plus relevant spec/research loaded by skills.
|
|
230
|
+
[/workflow-state:in_progress-inline]
|
|
231
|
+
|
|
232
|
+
### Phase 3: Finish
|
|
233
|
+
- 3.1 Quality verification `[required · repeatable]`
|
|
234
|
+
- 3.2 Debug retrospective `[on demand]`
|
|
235
|
+
- 3.3 Spec update `[required · once]`
|
|
236
|
+
- 3.4 Commit changes `[required · once]`
|
|
237
|
+
- 3.5 Wrap-up reminder
|
|
238
|
+
|
|
239
|
+
<!-- Per-turn breadcrumb: shown while status='completed'.
|
|
240
|
+
Currently DEAD in normal flow: cmd_archive writes status='completed' in
|
|
241
|
+
the same call that moves the task dir to archive/, so the active-task
|
|
242
|
+
resolver loses the pointer and the hook never fires on archived tasks.
|
|
243
|
+
Block preserved for a future status-transition redesign (e.g. an
|
|
244
|
+
explicit in_progress→completed command). Edit through the same spec
|
|
245
|
+
channel as the live blocks. -->
|
|
246
|
+
|
|
247
|
+
[workflow-state:completed]
|
|
248
|
+
Code committed. Run `/trellis:finish-work`; if dirty, return to Phase 3.4 first.
|
|
249
|
+
[/workflow-state:completed]
|
|
250
|
+
|
|
251
|
+
### Rules
|
|
252
|
+
|
|
253
|
+
1. Identify which Phase you're in, then continue from the next step there
|
|
254
|
+
2. Run steps in order inside each Phase; `[required]` steps can't be skipped
|
|
255
|
+
3. Phases can roll back (e.g., Execute reveals a prd defect → return to Plan to fix, then re-enter Execute)
|
|
256
|
+
4. Steps tagged `[once]` are skipped if the output already exists; don't re-run
|
|
257
|
+
5. Artifact presence informs the next step; missing `design.md` / `implement.md` is valid for lightweight tasks and incomplete planning for complex tasks.
|
|
258
|
+
6. **语言**:所有任务文档(prd.md, design.md, implement.md, research/*.md)、agent 回复、注释必须使用中文(简体中文)。代码标识符、commit 消息前缀和技术术语可以保留英文。
|
|
259
|
+
|
|
260
|
+
### Active Task Routing
|
|
261
|
+
|
|
262
|
+
When a user request matches one of these intents inside an active task, route first, then load the detailed phase step if needed.
|
|
263
|
+
|
|
264
|
+
[Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
265
|
+
|
|
266
|
+
- Planning or unclear requirements -> `trellis-brainstorm`.
|
|
267
|
+
- `in_progress` implementation/check -> dispatch `trellis-implement` / `trellis-check`.
|
|
268
|
+
- Repeated debugging -> `trellis-break-loop`; spec updates -> `trellis-update-spec`.
|
|
269
|
+
|
|
270
|
+
[/Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
271
|
+
|
|
272
|
+
[codex-inline, Kilo, Antigravity, Windsurf]
|
|
273
|
+
|
|
274
|
+
- Planning or unclear requirements -> `trellis-brainstorm`.
|
|
275
|
+
- Before editing -> `trellis-before-dev`; after editing -> `trellis-check`.
|
|
276
|
+
- Repeated debugging -> `trellis-break-loop`; spec updates -> `trellis-update-spec`.
|
|
277
|
+
|
|
278
|
+
[/codex-inline, Kilo, Antigravity, Windsurf]
|
|
279
|
+
|
|
280
|
+
### Guardrails
|
|
281
|
+
|
|
282
|
+
- Task creation approval is not implementation approval; implementation waits for `task.py start` after artifact review.
|
|
283
|
+
- PRD-only is valid for lightweight tasks; complex tasks need `design.md` + `implement.md`.
|
|
284
|
+
- Planning must be persisted to task artifacts; checks must run before reporting completion.
|
|
285
|
+
|
|
286
|
+
### Loading Step Detail
|
|
287
|
+
|
|
288
|
+
At each step, run this to fetch detailed guidance:
|
|
289
|
+
|
|
290
|
+
```bash
|
|
291
|
+
python3 ./.trellis/scripts/get_context.py --mode phase --step <step>
|
|
292
|
+
# e.g. python3 ./.trellis/scripts/get_context.py --mode phase --step 1.1
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
---
|
|
296
|
+
|
|
297
|
+
## Phase 1: Plan
|
|
298
|
+
|
|
299
|
+
Goal: classify the request, get task-creation consent when a task is needed, and produce the planning artifacts required before implementation.
|
|
300
|
+
|
|
301
|
+
#### 1.0 Create task `[required · once]`
|
|
302
|
+
|
|
303
|
+
Create the task directory only after task-creation consent. The command sets status to `planning`, writes `task.json`, creates a default `prd.md`, and auto-targets the new task when session identity is available:
|
|
304
|
+
|
|
305
|
+
```bash
|
|
306
|
+
python3 ./.trellis/scripts/task.py create "<task title>" --slug <name>
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
`--slug` is the human-readable name only. Do **not** include the `MM-DD-` date prefix; `task.py create` adds that prefix automatically.
|
|
310
|
+
|
|
311
|
+
After this command succeeds, the per-turn breadcrumb auto-switches to `[workflow-state:planning]`, telling the AI to stay in planning.
|
|
312
|
+
|
|
313
|
+
Run only `create` here — do not also run `start`. `start` flips status to `in_progress`, which switches the breadcrumb to the implementation phase before planning artifacts are reviewed. Save `start` for step 1.4.
|
|
314
|
+
|
|
315
|
+
Skip when `python3 ./.trellis/scripts/task.py current --source` already points to a task.
|
|
316
|
+
|
|
317
|
+
#### 1.1 Requirement exploration `[required · repeatable]`
|
|
318
|
+
|
|
319
|
+
Load the `trellis-brainstorm` skill and explore requirements interactively with the user per the skill's guidance.
|
|
320
|
+
|
|
321
|
+
The brainstorm skill will guide you to:
|
|
322
|
+
- Ask one question at a time
|
|
323
|
+
- Prefer researching over asking the user
|
|
324
|
+
- Prefer offering options over open-ended questions
|
|
325
|
+
- Update `prd.md` immediately after each user answer
|
|
326
|
+
- Keep `prd.md` focused on requirements and acceptance criteria
|
|
327
|
+
- For complex tasks, produce `design.md` and `implement.md` before implementation starts
|
|
328
|
+
|
|
329
|
+
Return to this step whenever requirements change and revise the relevant artifact.
|
|
330
|
+
|
|
331
|
+
#### 1.2 Research `[optional · repeatable]`
|
|
332
|
+
|
|
333
|
+
Research can happen at any time during requirement exploration. It isn't limited to local code — you can use any available tool (MCP servers, skills, web search, etc.) to look up external information, including third-party library docs, industry practices, API references, etc.
|
|
334
|
+
|
|
335
|
+
[Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
336
|
+
|
|
337
|
+
Spawn the research sub-agent:
|
|
338
|
+
|
|
339
|
+
- **Agent type**: `trellis-research`
|
|
340
|
+
- **Task description**: Research <specific question>
|
|
341
|
+
- **Key requirement**: Research output MUST be persisted to `{TASK_DIR}/research/`
|
|
342
|
+
|
|
343
|
+
[/Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
344
|
+
|
|
345
|
+
[codex-inline, Kilo, Antigravity, Windsurf]
|
|
346
|
+
|
|
347
|
+
Do the research in the main session directly and write findings into `{TASK_DIR}/research/`. (For `codex-inline` this avoids the `fork_turns="none"` isolation that prevents `trellis-research` sub-agents from resolving the active task path.)
|
|
348
|
+
|
|
349
|
+
[/codex-inline, Kilo, Antigravity, Windsurf]
|
|
350
|
+
|
|
351
|
+
**Research artifact conventions**:
|
|
352
|
+
- One file per research topic (e.g. `research/auth-library-comparison.md`)
|
|
353
|
+
- Record third-party library usage examples, API references, version constraints in files
|
|
354
|
+
- Note relevant spec file paths you discovered for later reference
|
|
355
|
+
|
|
356
|
+
Brainstorm and research can interleave freely — pause to research a technical question, then return to talk with the user.
|
|
357
|
+
|
|
358
|
+
**Key principle**: Research output must be written to files, not left only in the chat. Conversations get compacted; files don't.
|
|
359
|
+
|
|
360
|
+
#### 1.3 Configure context `[required · once]`
|
|
361
|
+
|
|
362
|
+
[Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
363
|
+
|
|
364
|
+
Curate `implement.jsonl` and `check.jsonl` so the Phase 2 sub-agents get the right spec/research context. These files were seeded on `task create` with a single self-describing `_example` line; your job here is to fill in real entries.
|
|
365
|
+
|
|
366
|
+
**Location**: `{TASK_DIR}/implement.jsonl` and `{TASK_DIR}/check.jsonl` (already exist).
|
|
367
|
+
|
|
368
|
+
**Format**: one JSON object per line — `{"file": "<path>", "reason": "<why>"}`. Paths are repo-root relative.
|
|
369
|
+
|
|
370
|
+
**What to put in**:
|
|
371
|
+
- **Spec files** — `.trellis/spec/<package>/<layer>/index.md` and any specific guideline files (`error-handling.md`, `conventions.md`, etc.) relevant to this task
|
|
372
|
+
- **Research files** — `{TASK_DIR}/research/*.md` that the sub-agent will need to consult
|
|
373
|
+
|
|
374
|
+
**What NOT to put in**:
|
|
375
|
+
- Code files (`src/**`, `packages/**/*.ts`, etc.) — those are read by the sub-agent during implementation, not pre-registered here
|
|
376
|
+
- Files you're about to modify — same reason
|
|
377
|
+
|
|
378
|
+
**Split between the two files**:
|
|
379
|
+
- `implement.jsonl` → specs + research the implement sub-agent needs to write code correctly
|
|
380
|
+
- `check.jsonl` → specs for the check sub-agent (quality guidelines, check conventions, same research if needed)
|
|
381
|
+
|
|
382
|
+
These manifests do not replace `implement.md`. `implement.md` is the human-readable execution plan for a complex task; jsonl files only list context files to inject or load.
|
|
383
|
+
|
|
384
|
+
**How to discover relevant specs**:
|
|
385
|
+
|
|
386
|
+
```bash
|
|
387
|
+
python3 ./.trellis/scripts/get_context.py --mode packages
|
|
388
|
+
```
|
|
389
|
+
|
|
390
|
+
Lists every package + its spec layers with paths. Pick the entries that match this task's domain.
|
|
391
|
+
|
|
392
|
+
**How to append entries**:
|
|
393
|
+
|
|
394
|
+
Either edit the jsonl file directly in your editor, or use:
|
|
395
|
+
|
|
396
|
+
```bash
|
|
397
|
+
python3 ./.trellis/scripts/task.py add-context "$TASK_DIR" implement "<path>" "<reason>"
|
|
398
|
+
python3 ./.trellis/scripts/task.py add-context "$TASK_DIR" check "<path>" "<reason>"
|
|
399
|
+
```
|
|
400
|
+
|
|
401
|
+
Delete the seed `_example` line once real entries exist (optional — it's skipped automatically by consumers).
|
|
402
|
+
|
|
403
|
+
Skip when: `implement.jsonl` and `check.jsonl` have agent-curated entries (the seed row alone doesn't count).
|
|
404
|
+
|
|
405
|
+
[/Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
406
|
+
|
|
407
|
+
[codex-inline, Kilo, Antigravity, Windsurf]
|
|
408
|
+
|
|
409
|
+
Skip this step. Context is loaded directly by the `trellis-before-dev` skill in Phase 2.
|
|
410
|
+
|
|
411
|
+
[/codex-inline, Kilo, Antigravity, Windsurf]
|
|
412
|
+
|
|
413
|
+
#### 1.4 Activate task `[required · once]`
|
|
414
|
+
|
|
415
|
+
After artifact review, flip the task status to `in_progress`:
|
|
416
|
+
|
|
417
|
+
```bash
|
|
418
|
+
python3 ./.trellis/scripts/task.py start <task-dir>
|
|
419
|
+
```
|
|
420
|
+
|
|
421
|
+
For lightweight tasks, `prd.md` can be enough. For complex tasks, `prd.md`, `design.md`, and `implement.md` must exist and be reviewed before start. On sub-agent-capable platforms, curate jsonl manifests when extra spec or research context is needed; seed-only manifests are tolerated by consumers.
|
|
422
|
+
|
|
423
|
+
After this command succeeds, the breadcrumb auto-switches to `[workflow-state:in_progress]`, and the rest of Phase 2 / 3 follows.
|
|
424
|
+
|
|
425
|
+
If `task.py start` errors with a session-identity message (no context key from hook input, `TRELLIS_CONTEXT_ID`, or platform-native session env), follow the hint in the error to set up session identity, then retry.
|
|
426
|
+
|
|
427
|
+
#### 1.5 Completion criteria
|
|
428
|
+
|
|
429
|
+
| Condition | Required |
|
|
430
|
+
|------|:---:|
|
|
431
|
+
| `prd.md` exists | ✅ |
|
|
432
|
+
| User confirms task should enter implementation | ✅ |
|
|
433
|
+
| `task.py start` has been run (status = in_progress) | ✅ |
|
|
434
|
+
| `research/` has artifacts (complex tasks) | recommended |
|
|
435
|
+
| `design.md` exists (complex tasks) | ✅ |
|
|
436
|
+
| `implement.md` exists (complex tasks) | ✅ |
|
|
437
|
+
|
|
438
|
+
[Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
439
|
+
|
|
440
|
+
| `implement.jsonl` / `check.jsonl` curated when extra spec or research context is needed | recommended |
|
|
441
|
+
|
|
442
|
+
[/Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
443
|
+
|
|
444
|
+
---
|
|
445
|
+
|
|
446
|
+
## Phase 2: Execute
|
|
447
|
+
|
|
448
|
+
Goal: turn reviewed planning artifacts into code that passes quality checks.
|
|
449
|
+
|
|
450
|
+
#### 2.1 Implement `[required · repeatable]`
|
|
451
|
+
|
|
452
|
+
[Claude Code, Cursor, OpenCode, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
453
|
+
|
|
454
|
+
Spawn the implement sub-agent:
|
|
455
|
+
|
|
456
|
+
- **Agent type**: `trellis-implement`
|
|
457
|
+
- **Task description**: Implement the reviewed task artifacts, consulting materials under `{TASK_DIR}/research/`; finish by running project lint and type-check
|
|
458
|
+
- **Dispatch prompt guard**: Tell the spawned agent it is already the `trellis-implement` sub-agent and must implement directly, not spawn another `trellis-implement` / `trellis-check`.
|
|
459
|
+
|
|
460
|
+
The platform hook/plugin auto-handles:
|
|
461
|
+
- Reads `implement.jsonl` and injects referenced spec/research files into the agent prompt
|
|
462
|
+
- Injects `prd.md`, `design.md` if present, and `implement.md` if present
|
|
463
|
+
|
|
464
|
+
[/Claude Code, Cursor, OpenCode, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
465
|
+
|
|
466
|
+
[codex-sub-agent]
|
|
467
|
+
|
|
468
|
+
Spawn the implement sub-agent:
|
|
469
|
+
|
|
470
|
+
- **Agent type**: `trellis-implement`
|
|
471
|
+
- **Task description**: Implement the reviewed task artifacts, consulting materials under `{TASK_DIR}/research/`; finish by running project lint and type-check
|
|
472
|
+
- **Dispatch prompt guard**: The prompt MUST start with `Active task: <task path>`, then explicitly say the spawned agent is already `trellis-implement` and must implement directly without spawning another `trellis-implement` / `trellis-check`.
|
|
473
|
+
|
|
474
|
+
The Codex sub-agent definition auto-handles the context load requirement:
|
|
475
|
+
- Resolves the active task with `task.py current --source`, then reads `prd.md`, `design.md` if present, and `implement.md` if present
|
|
476
|
+
- Reads `implement.jsonl` and requires the agent to load each referenced spec/research file before coding
|
|
477
|
+
|
|
478
|
+
[/codex-sub-agent]
|
|
479
|
+
|
|
480
|
+
[Kiro]
|
|
481
|
+
|
|
482
|
+
Spawn the implement sub-agent:
|
|
483
|
+
|
|
484
|
+
- **Agent type**: `trellis-implement`
|
|
485
|
+
- **Task description**: Implement the reviewed task artifacts, consulting materials under `{TASK_DIR}/research/`; finish by running project lint and type-check
|
|
486
|
+
- **Dispatch prompt guard**: Tell the spawned agent it is already the `trellis-implement` sub-agent and must implement directly, not spawn another `trellis-implement` / `trellis-check`.
|
|
487
|
+
|
|
488
|
+
The platform prelude auto-handles the context load requirement:
|
|
489
|
+
- Reads `implement.jsonl` and injects referenced spec/research files into the agent prompt
|
|
490
|
+
- Injects `prd.md`, `design.md` if present, and `implement.md` if present
|
|
491
|
+
|
|
492
|
+
[/Kiro]
|
|
493
|
+
|
|
494
|
+
[codex-inline, Kilo, Antigravity, Windsurf]
|
|
495
|
+
|
|
496
|
+
1. Load the `trellis-before-dev` skill to read project guidelines
|
|
497
|
+
2. Read `{TASK_DIR}/prd.md`, then `design.md` if present, then `implement.md` if present
|
|
498
|
+
3. Consult materials under `{TASK_DIR}/research/`
|
|
499
|
+
4. Implement the code per reviewed artifacts
|
|
500
|
+
5. Run project lint and type-check
|
|
501
|
+
|
|
502
|
+
[/codex-inline, Kilo, Antigravity, Windsurf]
|
|
503
|
+
|
|
504
|
+
#### 2.2 Quality check `[required · repeatable]`
|
|
505
|
+
|
|
506
|
+
[Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
507
|
+
|
|
508
|
+
Spawn the check sub-agent:
|
|
509
|
+
|
|
510
|
+
- **Agent type**: `trellis-check`
|
|
511
|
+
- **Task description**: Review all code changes against specs and task artifacts; fix any findings directly; ensure lint and type-check pass
|
|
512
|
+
- **Dispatch prompt guard**: Tell the spawned agent it is already the `trellis-check` sub-agent and must review/fix directly, not spawn another `trellis-check` / `trellis-implement`.
|
|
513
|
+
|
|
514
|
+
The check agent's job:
|
|
515
|
+
- Review code changes against specs
|
|
516
|
+
- Review code changes against `prd.md`, `design.md` if present, and `implement.md` if present
|
|
517
|
+
- Auto-fix issues it finds
|
|
518
|
+
- Run lint and typecheck to verify
|
|
519
|
+
|
|
520
|
+
[/Claude Code, Cursor, OpenCode, codex-sub-agent, Kiro, Gemini, Qoder, CodeBuddy, Copilot, Droid, Pi]
|
|
521
|
+
|
|
522
|
+
[codex-inline, Kilo, Antigravity, Windsurf]
|
|
523
|
+
|
|
524
|
+
Load the `trellis-check` skill and verify the code per its guidance:
|
|
525
|
+
- Spec compliance
|
|
526
|
+
- lint / type-check / tests
|
|
527
|
+
- Cross-layer consistency (when changes span layers)
|
|
528
|
+
|
|
529
|
+
If issues are found → fix → re-check, until green.
|
|
530
|
+
|
|
531
|
+
[/codex-inline, Kilo, Antigravity, Windsurf]
|
|
532
|
+
|
|
533
|
+
#### 2.3 Rollback `[on demand]`
|
|
534
|
+
|
|
535
|
+
- `check` reveals a prd defect → return to Phase 1, fix `prd.md`, then redo 2.1
|
|
536
|
+
- Implementation went wrong → revert code, redo 2.1
|
|
537
|
+
- Need more research → research (same as Phase 1.2), write findings into `research/`
|
|
538
|
+
|
|
539
|
+
---
|
|
540
|
+
|
|
541
|
+
## Phase 3: Finish
|
|
542
|
+
|
|
543
|
+
Goal: ensure code quality, capture lessons, record the work.
|
|
544
|
+
|
|
545
|
+
#### 3.1 Quality verification `[required · repeatable]`
|
|
546
|
+
|
|
547
|
+
Load the `trellis-check` skill and do a final verification:
|
|
548
|
+
- Spec compliance
|
|
549
|
+
- lint / type-check / tests
|
|
550
|
+
- Cross-layer consistency (when changes span layers)
|
|
551
|
+
|
|
552
|
+
If issues are found → fix → re-check, until green.
|
|
553
|
+
|
|
554
|
+
#### 3.2 Debug retrospective `[on demand]`
|
|
555
|
+
|
|
556
|
+
If this task involved repeated debugging (the same issue was fixed multiple times), load the `trellis-break-loop` skill to:
|
|
557
|
+
- Classify the root cause
|
|
558
|
+
- Explain why earlier fixes failed
|
|
559
|
+
- Propose prevention
|
|
560
|
+
|
|
561
|
+
The goal is to capture debugging lessons so the same class of issue doesn't recur.
|
|
562
|
+
|
|
563
|
+
#### 3.3 Spec update `[required · once]`
|
|
564
|
+
|
|
565
|
+
Load the `trellis-update-spec` skill and review whether this task produced new knowledge worth recording:
|
|
566
|
+
- Newly discovered patterns or conventions
|
|
567
|
+
- Pitfalls you hit
|
|
568
|
+
- New technical decisions
|
|
569
|
+
|
|
570
|
+
Update the docs under `.trellis/spec/` accordingly. Even if the conclusion is "nothing to update", walk through the judgment.
|
|
571
|
+
|
|
572
|
+
#### 3.4 Commit changes `[required · once]`
|
|
573
|
+
|
|
574
|
+
The AI drives a batched commit of this task's code changes so `/finish-work` can run cleanly afterwards. Goal: produce work commits FIRST, then bookkeeping (archive + journal) commits land after — never interleaved.
|
|
575
|
+
|
|
576
|
+
**Step-by-step**:
|
|
577
|
+
|
|
578
|
+
1. **Inspect dirty state**:
|
|
579
|
+
```bash
|
|
580
|
+
git status --porcelain
|
|
581
|
+
```
|
|
582
|
+
Snapshot every dirty path. If the working tree is clean, skip to 3.5.
|
|
583
|
+
|
|
584
|
+
2. **Learn commit style** from recent history (so drafted messages blend in):
|
|
585
|
+
```bash
|
|
586
|
+
git log --oneline -5
|
|
587
|
+
```
|
|
588
|
+
Note the prefix convention (`feat:` / `fix:` / `chore:` / `docs:` ...), language (中文/English), and length style.
|
|
589
|
+
|
|
590
|
+
3. **Classify dirty files into two groups**:
|
|
591
|
+
- **AI-edited this session** — files you wrote/edited via Edit/Write/Bash tool calls in this session. You know what changed and why.
|
|
592
|
+
- **Unrecognized** — dirty files you did NOT touch this session (could be the user's manual edits, leftover WIP from a previous session, or unrelated work). Do NOT silently include these.
|
|
593
|
+
|
|
594
|
+
4. **Draft a commit plan**. Group AI-edited files into logical commits (1 commit per coherent change unit, not 1 commit per file). Each entry: `<commit message>` + file list. List unrecognized files separately at the bottom.
|
|
595
|
+
|
|
596
|
+
5. **Present the plan once, ask for one-shot confirmation**. Format:
|
|
597
|
+
```
|
|
598
|
+
Proposed commits (in order):
|
|
599
|
+
1. <message>
|
|
600
|
+
- <file>
|
|
601
|
+
- <file>
|
|
602
|
+
2. <message>
|
|
603
|
+
- <file>
|
|
604
|
+
|
|
605
|
+
Unrecognized dirty files (NOT in any commit — confirm include/exclude):
|
|
606
|
+
- <file>
|
|
607
|
+
- <file>
|
|
608
|
+
|
|
609
|
+
Reply 'ok' / '行' to execute. Reply with edits, or '我自己来' / 'manual' to abort.
|
|
610
|
+
```
|
|
611
|
+
|
|
612
|
+
6. **On confirmation**: run `git add <files>` + `git commit -m "<msg>"` for each batch in order. Do not amend. Do not push.
|
|
613
|
+
|
|
614
|
+
7. **On rejection** (user replies "不行" / "我自己来" / "manual" / any pushback on the plan): stop. Do not attempt a second plan. The user will commit by hand; you skip ahead to 3.5 once they confirm.
|
|
615
|
+
|
|
616
|
+
**Rules**:
|
|
617
|
+
- No `git commit --amend` anywhere — three-stage three-commit flow (work commits → archive commit → journal commit).
|
|
618
|
+
- Never push to remote in this step.
|
|
619
|
+
- If the user wants different message wording but accepts the file grouping, edit the message and re-confirm once — but if they reject the grouping, exit to manual mode.
|
|
620
|
+
- The batched plan is one prompt; do not prompt per commit.
|
|
621
|
+
|
|
622
|
+
#### 3.5 Wrap-up reminder
|
|
623
|
+
|
|
624
|
+
After the above, remind the user they can run `/finish-work` to wrap up (archive the task, record the session).
|
|
625
|
+
|
|
626
|
+
---
|
|
627
|
+
|
|
628
|
+
## Customizing Trellis (for forks)
|
|
629
|
+
|
|
630
|
+
This section is for developers who want to modify the Trellis workflow itself. All customization is done by editing this file; the scripts are parsers only.
|
|
631
|
+
|
|
632
|
+
### Changing what a step means
|
|
633
|
+
|
|
634
|
+
Edit the corresponding step's walkthrough body in the Phase 1 / 2 / 3 sections above. Critical invariants:
|
|
635
|
+
- No active task must triage first and ask for task-creation consent before creating a Trellis task.
|
|
636
|
+
- Planning must distinguish lightweight PRD-only tasks from complex tasks that require `prd.md`, `design.md`, and `implement.md` before start.
|
|
637
|
+
- Every required execution path must keep the Phase 3.4 commit reminder reachable before `/trellis:finish-work`.
|
|
638
|
+
|
|
639
|
+
All tag blocks live in the `## Phase Index` section above, immediately after each phase summary:
|
|
640
|
+
|
|
641
|
+
| Scope | Corresponding tag |
|
|
642
|
+
|---|---|
|
|
643
|
+
| No active task (before Phase 1) | `[workflow-state:no_task]` (after the Phase Index ASCII art) |
|
|
644
|
+
| All of Phase 1 (task created → ready for implementation) | `[workflow-state:planning]` (after Phase 1 summary) |
|
|
645
|
+
| Codex inline Phase 1 | `[workflow-state:planning-inline]` |
|
|
646
|
+
| Phase 2 + Phase 3.1–3.4 (implementation + check + wrap-up) | `[workflow-state:in_progress]` (after Phase 2 summary) |
|
|
647
|
+
| Codex inline Phase 2 + Phase 3.1–3.4 | `[workflow-state:in_progress-inline]` |
|
|
648
|
+
| After Phase 3.5 (archived) | `[workflow-state:completed]` (after Phase 3 summary; **currently DEAD**) |
|
|
649
|
+
|
|
650
|
+
### Changing the per-turn prompt text
|
|
651
|
+
|
|
652
|
+
Directly edit the body of the corresponding `[workflow-state:STATUS]` block. After editing, run `trellis update` (if you're a template maintainer) or restart your AI session (if you're customizing your own project) — no script changes required.
|
|
653
|
+
|
|
654
|
+
### Adding a custom status
|
|
655
|
+
|
|
656
|
+
Add a new block:
|
|
657
|
+
|
|
658
|
+
```
|
|
659
|
+
[workflow-state:my-status]
|
|
660
|
+
your per-turn prompt text
|
|
661
|
+
[/workflow-state:my-status]
|
|
662
|
+
```
|
|
663
|
+
|
|
664
|
+
Constraints:
|
|
665
|
+
- STATUS charset: `[A-Za-z0-9_-]+` (underscores and hyphens allowed, e.g. `in-review`, `blocked-by-team`)
|
|
666
|
+
- A lifecycle hook must write `task.json.status` to your custom value, otherwise the tag is never read
|
|
667
|
+
- Lifecycle hooks live in `task.json.hooks.after_*` and bind to one of `after_create / after_start / after_finish / after_archive`
|
|
668
|
+
|
|
669
|
+
### Adding a lifecycle hook
|
|
670
|
+
|
|
671
|
+
Add a `hooks` field to your `task.json`:
|
|
672
|
+
|
|
673
|
+
```json
|
|
674
|
+
{
|
|
675
|
+
"hooks": {
|
|
676
|
+
"after_finish": [
|
|
677
|
+
"your-script-or-command-here"
|
|
678
|
+
]
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
```
|
|
682
|
+
|
|
683
|
+
Supported events: `after_create / after_start / after_finish / after_archive`. Note that `after_finish` ≠ a status change (it only clears the active-task pointer); use `after_archive` for "task is done" notifications.
|
|
684
|
+
|
|
685
|
+
### Full contract
|
|
686
|
+
|
|
687
|
+
For the workflow state machine's runtime contract, the locations of all status writers, pseudo-statuses (`no_task` / `stale_<source_type>`), the hook reachability matrix, and other deep details, see:
|
|
688
|
+
|
|
689
|
+
- `.trellis/spec/cli/backend/workflow-state-contract.md` — runtime contract + writer table + test invariants
|
|
690
|
+
- `.trellis/scripts/inject-workflow-state.py` — actual parser (reads workflow.md only, no embedded text)
|