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,40 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: before-dev
|
|
3
|
+
description: "Discovers and injects project-specific coding guidelines from .trellis/spec/ before implementation begins. Reads spec indexes, pre-development checklists, and shared thinking guides for the target package. Use when starting a new coding task, before writing any code, switching to a different package, or needing to refresh project conventions and standards."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Read the relevant development guidelines before starting your task.
|
|
7
|
+
|
|
8
|
+
Execute these steps:
|
|
9
|
+
|
|
10
|
+
1. **Read current task artifacts**:
|
|
11
|
+
- `prd.md` for requirements and acceptance criteria
|
|
12
|
+
- `design.md` if present for technical design
|
|
13
|
+
- `implement.md` if present for execution order and validation plan
|
|
14
|
+
|
|
15
|
+
2. **Discover packages and their spec layers**:
|
|
16
|
+
```bash
|
|
17
|
+
python3 ./.trellis/scripts/get_context.py --mode packages
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
3. **Identify which specs apply** to your task based on:
|
|
21
|
+
- Which package you're modifying (e.g., `cli/`, `docs-site/`)
|
|
22
|
+
- What type of work (backend, frontend, unit-test, docs, etc.)
|
|
23
|
+
- Any spec/research paths referenced by the task artifacts
|
|
24
|
+
|
|
25
|
+
4. **Read the spec index** for each relevant module:
|
|
26
|
+
```bash
|
|
27
|
+
cat .trellis/spec/<package>/<layer>/index.md
|
|
28
|
+
```
|
|
29
|
+
Follow the **"Pre-Development Checklist"** section in the index.
|
|
30
|
+
|
|
31
|
+
5. **Read the specific guideline files** listed in the Pre-Development Checklist that are relevant to your task. The index is NOT the goal — it points you to the actual guideline files (e.g., `error-handling.md`, `conventions.md`, `mock-strategies.md`). Read those files to understand the coding standards and patterns.
|
|
32
|
+
|
|
33
|
+
6. **Always read shared guides**:
|
|
34
|
+
```bash
|
|
35
|
+
cat .trellis/spec/guides/index.md
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
7. Understand the coding standards and patterns you need to follow, then proceed with your development plan.
|
|
39
|
+
|
|
40
|
+
This step is **mandatory** before writing any code.
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: brainstorm
|
|
3
|
+
description: "Guide requirements discovery for a Trellis task after task-creation consent. Use when the user is ready to clarify requirements before implementation."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Trellis Brainstorm
|
|
7
|
+
|
|
8
|
+
## Non-Negotiable Interview Contract
|
|
9
|
+
|
|
10
|
+
Interview me relentlessly about every aspect of this plan until we reach a shared understanding. Walk down each branch of the design tree, resolving dependencies between decisions one-by-one. For each question, provide your recommended answer.
|
|
11
|
+
|
|
12
|
+
Ask the questions one at a time.
|
|
13
|
+
|
|
14
|
+
## Non-Negotiable Evidence Rule
|
|
15
|
+
|
|
16
|
+
If a question can be answered by exploring the codebase, explore the codebase instead.
|
|
17
|
+
|
|
18
|
+
This is mandatory. Before asking the user a question, first check whether the answer is already available in code, tests, configs, docs, existing specs, or task history.
|
|
19
|
+
|
|
20
|
+
Do not ask the user to confirm facts that the repository can answer. Ask only for product intent, preference, scope, risk tolerance, or decisions that remain ambiguous after inspection.
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
Use this skill during Phase 1 planning to turn the user's request into clear requirements and planning artifacts.
|
|
25
|
+
|
|
26
|
+
## Preconditions
|
|
27
|
+
|
|
28
|
+
Use this skill only after task-creation consent has been given and the user is ready to enter Trellis planning.
|
|
29
|
+
|
|
30
|
+
If no task exists yet, create one:
|
|
31
|
+
|
|
32
|
+
```bash
|
|
33
|
+
TASK_DIR=$({{PYTHON_CMD}} ./.trellis/scripts/task.py create "<short task title>" --slug <slug>)
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
Use a concise title from the user's request. Use a slug without a date prefix. `task.py create` adds the `MM-DD-` directory prefix automatically.
|
|
37
|
+
|
|
38
|
+
`task.py create` creates the default `prd.md`. Update that file with the current understanding before asking follow-up questions.
|
|
39
|
+
|
|
40
|
+
## Planning Flow
|
|
41
|
+
|
|
42
|
+
1. Capture the user's request and initial known facts in `prd.md`.
|
|
43
|
+
2. Inspect available evidence before asking questions:
|
|
44
|
+
- code, tests, fixtures, and configs
|
|
45
|
+
- README files, docs, existing specs, and domain notes
|
|
46
|
+
- related Trellis tasks, research files, and session history when present
|
|
47
|
+
3. Separate what you found into:
|
|
48
|
+
- confirmed facts
|
|
49
|
+
- product intent still needed from the user
|
|
50
|
+
- scope or risk decisions still needed from the user
|
|
51
|
+
- likely out-of-scope items
|
|
52
|
+
4. Ask the single highest-value remaining question.
|
|
53
|
+
5. Include your recommended answer with the question.
|
|
54
|
+
6. After each user answer, update `prd.md` before continuing.
|
|
55
|
+
7. For complex tasks, create or update `design.md` and `implement.md` before implementation starts.
|
|
56
|
+
|
|
57
|
+
Do not invent a project-specific product/spec hierarchy. If the repository already has product, domain, or spec docs, use them. If it does not, proceed with the evidence that exists.
|
|
58
|
+
|
|
59
|
+
## Question Rules
|
|
60
|
+
|
|
61
|
+
Ask only one question per message.
|
|
62
|
+
|
|
63
|
+
Each question must include:
|
|
64
|
+
|
|
65
|
+
- the decision needed
|
|
66
|
+
- why the answer matters
|
|
67
|
+
- your recommended answer
|
|
68
|
+
- the trade-off if the user chooses differently
|
|
69
|
+
|
|
70
|
+
Do not ask process questions such as whether to search, inspect files, or continue brainstorming. Do the evidence work directly. Ask the user only when the remaining issue is a product decision, preference, scope boundary, or risk tolerance choice.
|
|
71
|
+
|
|
72
|
+
## Artifact Rules
|
|
73
|
+
|
|
74
|
+
`prd.md` records requirements and acceptance:
|
|
75
|
+
|
|
76
|
+
- goal and user value
|
|
77
|
+
- confirmed facts
|
|
78
|
+
- requirements
|
|
79
|
+
- acceptance criteria
|
|
80
|
+
- out of scope
|
|
81
|
+
- open questions that still block planning
|
|
82
|
+
|
|
83
|
+
`design.md` records technical design for complex tasks:
|
|
84
|
+
|
|
85
|
+
- architecture and boundaries
|
|
86
|
+
- data flow and contracts
|
|
87
|
+
- compatibility and migration notes
|
|
88
|
+
- important trade-offs
|
|
89
|
+
- operational or rollback considerations
|
|
90
|
+
|
|
91
|
+
`implement.md` records execution planning for complex tasks:
|
|
92
|
+
|
|
93
|
+
- ordered implementation checklist
|
|
94
|
+
- validation commands
|
|
95
|
+
- risky files or rollback points
|
|
96
|
+
- follow-up checks before `task.py start`
|
|
97
|
+
|
|
98
|
+
Lightweight tasks may have only `prd.md`. Complex tasks must have `prd.md`, `design.md`, and `implement.md` before `task.py start`.
|
|
99
|
+
|
|
100
|
+
`implement.md` is not a replacement for `implement.jsonl`. Use JSONL files only for manifest-style spec and research references when the task needs them.
|
|
101
|
+
|
|
102
|
+
## Quality Bar
|
|
103
|
+
|
|
104
|
+
Before declaring planning ready:
|
|
105
|
+
|
|
106
|
+
- `prd.md` contains testable acceptance criteria.
|
|
107
|
+
- Repository-answerable questions have already been answered through inspection.
|
|
108
|
+
- Remaining open questions are genuinely about user intent or scope.
|
|
109
|
+
- Complex tasks have `design.md` and `implement.md`.
|
|
110
|
+
- The user has reviewed the final planning artifacts or explicitly approved proceeding.
|
|
111
|
+
|
|
112
|
+
Do not start implementation until the user approves or asks for implementation.
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: break-loop
|
|
3
|
+
description: "Deep post-fix bug analysis across five dimensions: root cause categorization, fix failure analysis, prevention mechanisms, systematic expansion, and knowledge capture. Updates .trellis/spec/ guides with lessons learned to prevent recurring bugs. Use when a debugging session completes, after fixing a tricky bug, when the same class of bug keeps recurring, or when you want to capture debugging insights into project documentation."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Break the Loop - Deep Bug Analysis
|
|
7
|
+
|
|
8
|
+
When debug is complete, use this skill for deep analysis to break the "fix bug -> forget -> repeat" cycle.
|
|
9
|
+
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
## Analysis Framework
|
|
13
|
+
|
|
14
|
+
Analyze the bug you just fixed from these 5 dimensions:
|
|
15
|
+
|
|
16
|
+
### 1. Root Cause Category
|
|
17
|
+
|
|
18
|
+
Which category does this bug belong to?
|
|
19
|
+
|
|
20
|
+
| Category | Characteristics | Example |
|
|
21
|
+
|----------|-----------------|---------|
|
|
22
|
+
| **A. Missing Spec** | No documentation on how to do it | New feature without checklist |
|
|
23
|
+
| **B. Cross-Layer Contract** | Interface between layers unclear | API returns different format than expected |
|
|
24
|
+
| **C. Change Propagation Failure** | Changed one place, missed others | Changed function signature, missed call sites |
|
|
25
|
+
| **D. Test Coverage Gap** | Unit test passes, integration fails | Works alone, breaks when combined |
|
|
26
|
+
| **E. Implicit Assumption** | Code relies on undocumented assumption | Timestamp seconds vs milliseconds |
|
|
27
|
+
|
|
28
|
+
### 2. Why Fixes Failed (if applicable)
|
|
29
|
+
|
|
30
|
+
If you tried multiple fixes before succeeding, analyze each failure:
|
|
31
|
+
|
|
32
|
+
- **Surface Fix**: Fixed symptom, not root cause
|
|
33
|
+
- **Incomplete Scope**: Found root cause, didn't cover all cases
|
|
34
|
+
- **Tool Limitation**: grep missed it, type check wasn't strict
|
|
35
|
+
- **Mental Model**: Kept looking in same layer, didn't think cross-layer
|
|
36
|
+
|
|
37
|
+
### 3. Prevention Mechanisms
|
|
38
|
+
|
|
39
|
+
What mechanisms would prevent this from happening again?
|
|
40
|
+
|
|
41
|
+
| Type | Description | Example |
|
|
42
|
+
|------|-------------|---------|
|
|
43
|
+
| **Documentation** | Write it down so people know | Update thinking guide |
|
|
44
|
+
| **Architecture** | Make the error impossible structurally | Type-safe wrappers |
|
|
45
|
+
| **Compile-time** | TypeScript strict, no any | Signature change causes compile error |
|
|
46
|
+
| **Runtime** | Monitoring, alerts, scans | Detect orphan entities |
|
|
47
|
+
| **Test Coverage** | E2E tests, integration tests | Verify full flow |
|
|
48
|
+
| **Code Review** | Checklist, PR template | "Did you check X?" |
|
|
49
|
+
|
|
50
|
+
### 4. Systematic Expansion
|
|
51
|
+
|
|
52
|
+
What broader problems does this bug reveal?
|
|
53
|
+
|
|
54
|
+
- **Similar Issues**: Where else might this problem exist?
|
|
55
|
+
- **Design Flaw**: Is there a fundamental architecture issue?
|
|
56
|
+
- **Process Flaw**: Is there a development process improvement?
|
|
57
|
+
- **Knowledge Gap**: Is the team missing some understanding?
|
|
58
|
+
|
|
59
|
+
### 5. Knowledge Capture
|
|
60
|
+
|
|
61
|
+
Solidify insights into the system:
|
|
62
|
+
|
|
63
|
+
- [ ] Update `.trellis/spec/guides/` thinking guides
|
|
64
|
+
- [ ] Update `.trellis/spec/backend/` or `frontend/` docs
|
|
65
|
+
- [ ] Create issue record (if applicable)
|
|
66
|
+
- [ ] Create feature ticket for root fix
|
|
67
|
+
- [ ] Update check skills if needed
|
|
68
|
+
|
|
69
|
+
---
|
|
70
|
+
|
|
71
|
+
## Output Format
|
|
72
|
+
|
|
73
|
+
Please output analysis in this format:
|
|
74
|
+
|
|
75
|
+
```markdown
|
|
76
|
+
## Bug Analysis: [Short Description]
|
|
77
|
+
|
|
78
|
+
### 1. Root Cause Category
|
|
79
|
+
- **Category**: [A/B/C/D/E] - [Category Name]
|
|
80
|
+
- **Specific Cause**: [Detailed description]
|
|
81
|
+
|
|
82
|
+
### 2. Why Fixes Failed (if applicable)
|
|
83
|
+
1. [First attempt]: [Why it failed]
|
|
84
|
+
2. [Second attempt]: [Why it failed]
|
|
85
|
+
...
|
|
86
|
+
|
|
87
|
+
### 3. Prevention Mechanisms
|
|
88
|
+
| Priority | Mechanism | Specific Action | Status |
|
|
89
|
+
|----------|-----------|-----------------|--------|
|
|
90
|
+
| P0 | ... | ... | TODO/DONE |
|
|
91
|
+
|
|
92
|
+
### 4. Systematic Expansion
|
|
93
|
+
- **Similar Issues**: [List places with similar problems]
|
|
94
|
+
- **Design Improvement**: [Architecture-level suggestions]
|
|
95
|
+
- **Process Improvement**: [Development process suggestions]
|
|
96
|
+
|
|
97
|
+
### 5. Knowledge Capture
|
|
98
|
+
- [ ] [Documents to update / tickets to create]
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
---
|
|
102
|
+
|
|
103
|
+
## Core Philosophy
|
|
104
|
+
|
|
105
|
+
> **The value of debugging is not in fixing the bug, but in making this class of bugs never happen again.**
|
|
106
|
+
|
|
107
|
+
Three levels of insight:
|
|
108
|
+
1. **Tactical**: How to fix THIS bug
|
|
109
|
+
2. **Strategic**: How to prevent THIS CLASS of bugs
|
|
110
|
+
3. **Philosophical**: How to expand thinking patterns
|
|
111
|
+
|
|
112
|
+
30 minutes of analysis saves 30 hours of future debugging.
|
|
113
|
+
|
|
114
|
+
---
|
|
115
|
+
|
|
116
|
+
## After Analysis: Immediate Actions
|
|
117
|
+
|
|
118
|
+
**IMPORTANT**: After completing the analysis above, you MUST immediately:
|
|
119
|
+
|
|
120
|
+
1. **Update spec/guides** - Don't just list TODOs, actually update the relevant files:
|
|
121
|
+
- If it's a cross-platform issue → update `cross-platform-thinking-guide.md`
|
|
122
|
+
- If it's a cross-layer issue → update `cross-layer-thinking-guide.md`
|
|
123
|
+
- If it's a code reuse issue → update `code-reuse-thinking-guide.md`
|
|
124
|
+
- If it's domain-specific → update `backend/*.md` or `frontend/*.md`
|
|
125
|
+
|
|
126
|
+
2. **Sync templates** - After updating `.trellis/spec/`, sync to `src/templates/markdown/spec/`
|
|
127
|
+
|
|
128
|
+
3. **Commit the spec updates** - This is the primary output, not just the analysis text
|
|
129
|
+
|
|
130
|
+
> **The analysis is worthless if it stays in chat. The value is in the updated specs.**
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: check
|
|
3
|
+
description: "Validates recently written code against project-specific development guidelines from .trellis/spec/. Identifies changed files via git diff, discovers applicable spec modules, runs lint and typecheck, and reports guideline violations. Use when code is written and needs quality verification, to catch context drift during long sessions, or before committing changes."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Code Quality Check
|
|
7
|
+
|
|
8
|
+
Comprehensive quality verification for recently written code. Combines spec compliance, cross-layer safety, and pre-commit checks.
|
|
9
|
+
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
## Step 1: Identify What Changed
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
git diff --name-only HEAD
|
|
16
|
+
git status
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
## Step 2: Read Task Artifacts and Applicable Specs
|
|
20
|
+
|
|
21
|
+
Read the current task artifacts in order:
|
|
22
|
+
|
|
23
|
+
- `prd.md`
|
|
24
|
+
- `design.md` if present
|
|
25
|
+
- `implement.md` if present
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
python3 ./.trellis/scripts/get_context.py --mode packages
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
For each changed package/layer, read the spec index and follow its **Quality Check** section:
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
cat .trellis/spec/<package>/<layer>/index.md
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
Read the specific guideline files referenced — the index is a pointer, not the goal.
|
|
38
|
+
|
|
39
|
+
## Step 3: Run Project Checks
|
|
40
|
+
|
|
41
|
+
Run the project's lint, type-check, and test commands. Fix any failures before proceeding.
|
|
42
|
+
|
|
43
|
+
## Step 4: Review Against Checklist
|
|
44
|
+
|
|
45
|
+
### Code Quality
|
|
46
|
+
|
|
47
|
+
- [ ] Linter passes?
|
|
48
|
+
- [ ] Type checker passes (if applicable)?
|
|
49
|
+
- [ ] Tests pass?
|
|
50
|
+
- [ ] No debug logging left in?
|
|
51
|
+
- [ ] No suppressed warnings or type-safety bypasses?
|
|
52
|
+
|
|
53
|
+
### Test Coverage
|
|
54
|
+
|
|
55
|
+
- [ ] New function → unit test added?
|
|
56
|
+
- [ ] Bug fix → regression test added?
|
|
57
|
+
- [ ] Changed behavior → existing tests updated?
|
|
58
|
+
|
|
59
|
+
### Spec Sync
|
|
60
|
+
|
|
61
|
+
- [ ] Does `.trellis/spec/` need updates? (new patterns, conventions, lessons learned)
|
|
62
|
+
|
|
63
|
+
> "If I fixed a bug or discovered something non-obvious, should I document it so future me won't hit the same issue?" → If YES, update the relevant spec doc.
|
|
64
|
+
|
|
65
|
+
## Step 5: Cross-Layer Dimensions (if applicable)
|
|
66
|
+
|
|
67
|
+
Skip this step if your change is confined to a single layer.
|
|
68
|
+
|
|
69
|
+
### A. Data Flow (changes touch 3+ layers)
|
|
70
|
+
|
|
71
|
+
- [ ] Read flow traces correctly: Storage → Service → API → UI
|
|
72
|
+
- [ ] Write flow traces correctly: UI → API → Service → Storage
|
|
73
|
+
- [ ] Types/schemas correctly passed between layers?
|
|
74
|
+
- [ ] Errors properly propagated to caller?
|
|
75
|
+
|
|
76
|
+
### B. Code Reuse (modifying constants, creating utilities)
|
|
77
|
+
|
|
78
|
+
- [ ] Searched for existing similar code before creating new?
|
|
79
|
+
```bash
|
|
80
|
+
grep -r "pattern" src/
|
|
81
|
+
```
|
|
82
|
+
- [ ] If 2+ places define same value → extracted to shared constant?
|
|
83
|
+
- [ ] After batch modification, all occurrences updated?
|
|
84
|
+
|
|
85
|
+
### C. Import/Dependency (creating new files)
|
|
86
|
+
|
|
87
|
+
- [ ] Correct import paths (relative vs absolute)?
|
|
88
|
+
- [ ] No circular dependencies?
|
|
89
|
+
|
|
90
|
+
### D. Same-Layer Consistency
|
|
91
|
+
|
|
92
|
+
- [ ] Other places using the same concept are consistent?
|
|
93
|
+
|
|
94
|
+
---
|
|
95
|
+
|
|
96
|
+
## Step 6: Report and Fix
|
|
97
|
+
|
|
98
|
+
Report violations found and fix them directly. Re-run project checks after fixes.
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: check-cross-layer
|
|
3
|
+
description: "Post-implementation verification across multiple code dimensions: cross-layer data flow, code reuse analysis, import path validation, and same-layer consistency checks. Identifies missed update sites, type mismatches, and duplicated constants. Use when changes span 3+ architectural layers, after modifying shared constants or configs, after batch file modifications, or when creating new utility functions."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Cross-Layer Check
|
|
7
|
+
|
|
8
|
+
Check if your changes considered all dimensions. Most bugs come from "didn't think of it", not lack of technical skill.
|
|
9
|
+
|
|
10
|
+
> **Note**: This is a **post-implementation** safety net. Ideally, read the [Pre-Implementation Checklist](.trellis/spec/guides/pre-implementation-checklist.md) **before** writing code.
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## Related Documents
|
|
15
|
+
|
|
16
|
+
| Document | Purpose | Timing |
|
|
17
|
+
|----------|---------|--------|
|
|
18
|
+
| [Pre-Implementation Checklist](.trellis/spec/guides/pre-implementation-checklist.md) | Questions before coding | **Before** writing code |
|
|
19
|
+
| [Code Reuse Thinking Guide](.trellis/spec/guides/code-reuse-thinking-guide.md) | Pattern recognition | During implementation |
|
|
20
|
+
| **`$check-cross-layer`** (this skill) | Verification check | **After** implementation |
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## Execution Steps
|
|
25
|
+
|
|
26
|
+
### 1. Identify Change Scope
|
|
27
|
+
|
|
28
|
+
```bash
|
|
29
|
+
git status
|
|
30
|
+
git diff --name-only
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### 2. Select Applicable Check Dimensions
|
|
34
|
+
|
|
35
|
+
Based on your change type, execute relevant checks below:
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## Dimension A: Cross-Layer Data Flow (Required when 3+ layers)
|
|
40
|
+
|
|
41
|
+
**Trigger**: Changes involve 3 or more layers
|
|
42
|
+
|
|
43
|
+
| Layer | Common Locations |
|
|
44
|
+
|-------|------------------|
|
|
45
|
+
| API/Routes | `routes/`, `api/`, `handlers/`, `controllers/` |
|
|
46
|
+
| Service/Business Logic | `services/`, `lib/`, `core/`, `domain/` |
|
|
47
|
+
| Database/Storage | `db/`, `models/`, `repositories/`, `schema/` |
|
|
48
|
+
| UI/Presentation | `components/`, `views/`, `templates/`, `pages/` |
|
|
49
|
+
| Utility | `utils/`, `helpers/`, `common/` |
|
|
50
|
+
|
|
51
|
+
**Checklist**:
|
|
52
|
+
- [ ] Read flow: Database -> Service -> API -> UI
|
|
53
|
+
- [ ] Write flow: UI -> API -> Service -> Database
|
|
54
|
+
- [ ] Types/schemas correctly passed between layers?
|
|
55
|
+
- [ ] Errors properly propagated to caller?
|
|
56
|
+
- [ ] Loading/pending states handled at each layer?
|
|
57
|
+
|
|
58
|
+
**Detailed Guide**: `.trellis/spec/guides/cross-layer-thinking-guide.md`
|
|
59
|
+
|
|
60
|
+
---
|
|
61
|
+
|
|
62
|
+
## Dimension B: Code Reuse (Required when modifying constants/config)
|
|
63
|
+
|
|
64
|
+
**Trigger**:
|
|
65
|
+
- Modifying UI constants (label, icon, color)
|
|
66
|
+
- Modifying any hardcoded value
|
|
67
|
+
- Seeing similar code in multiple places
|
|
68
|
+
- Creating a new utility/helper function
|
|
69
|
+
- Just finished batch modifications across files
|
|
70
|
+
|
|
71
|
+
**Checklist**:
|
|
72
|
+
- [ ] Search first: How many places define this value?
|
|
73
|
+
```bash
|
|
74
|
+
# Search in source files (adjust extensions for your project)
|
|
75
|
+
grep -r "value-to-change" src/
|
|
76
|
+
```
|
|
77
|
+
- [ ] If 2+ places define same value -> Should extract to shared constant
|
|
78
|
+
- [ ] After modification, all usage sites updated?
|
|
79
|
+
- [ ] If creating utility: Does similar utility already exist?
|
|
80
|
+
|
|
81
|
+
**Detailed Guide**: `.trellis/spec/guides/code-reuse-thinking-guide.md`
|
|
82
|
+
|
|
83
|
+
---
|
|
84
|
+
|
|
85
|
+
## Dimension B2: New Utility Functions
|
|
86
|
+
|
|
87
|
+
**Trigger**: About to create a new utility/helper function
|
|
88
|
+
|
|
89
|
+
**Checklist**:
|
|
90
|
+
- [ ] Search for existing similar utilities first
|
|
91
|
+
```bash
|
|
92
|
+
grep -r "functionNamePattern" src/
|
|
93
|
+
```
|
|
94
|
+
- [ ] If similar exists, can you extend it instead?
|
|
95
|
+
- [ ] If creating new, is it in the right location (shared vs domain-specific)?
|
|
96
|
+
|
|
97
|
+
---
|
|
98
|
+
|
|
99
|
+
## Dimension B3: After Batch Modifications
|
|
100
|
+
|
|
101
|
+
**Trigger**: Just modified similar patterns in multiple files
|
|
102
|
+
|
|
103
|
+
**Checklist**:
|
|
104
|
+
- [ ] Did you check ALL files with similar patterns?
|
|
105
|
+
```bash
|
|
106
|
+
grep -r "patternYouChanged" src/
|
|
107
|
+
```
|
|
108
|
+
- [ ] Any files missed that should also be updated?
|
|
109
|
+
- [ ] Should this pattern be abstracted to prevent future duplication?
|
|
110
|
+
|
|
111
|
+
---
|
|
112
|
+
|
|
113
|
+
## Dimension C: Import/Dependency Paths (Required when creating new files)
|
|
114
|
+
|
|
115
|
+
**Trigger**: Creating new source files
|
|
116
|
+
|
|
117
|
+
**Checklist**:
|
|
118
|
+
- [ ] Using correct import paths (relative vs absolute)?
|
|
119
|
+
- [ ] No circular dependencies?
|
|
120
|
+
- [ ] Consistent with project's module organization?
|
|
121
|
+
|
|
122
|
+
---
|
|
123
|
+
|
|
124
|
+
## Dimension D: Same-Layer Consistency
|
|
125
|
+
|
|
126
|
+
**Trigger**:
|
|
127
|
+
- Modifying display logic or formatting
|
|
128
|
+
- Same domain concept used in multiple places
|
|
129
|
+
|
|
130
|
+
**Checklist**:
|
|
131
|
+
- [ ] Search for other places using same concept
|
|
132
|
+
```bash
|
|
133
|
+
grep -r "ConceptName" src/
|
|
134
|
+
```
|
|
135
|
+
- [ ] Are these usages consistent?
|
|
136
|
+
- [ ] Should they share configuration/constants?
|
|
137
|
+
|
|
138
|
+
---
|
|
139
|
+
|
|
140
|
+
## Common Issues Quick Reference
|
|
141
|
+
|
|
142
|
+
| Issue | Root Cause | Prevention |
|
|
143
|
+
|-------|------------|------------|
|
|
144
|
+
| Changed one place, missed others | Didn't search impact scope | `grep` before changing |
|
|
145
|
+
| Data lost at some layer | Didn't check data flow | Trace data source to destination |
|
|
146
|
+
| Type/schema mismatch | Cross-layer types inconsistent | Use shared type definitions |
|
|
147
|
+
| UI/output inconsistent | Same concept in multiple places | Extract shared constants |
|
|
148
|
+
| Similar utility exists | Didn't search first | Search before creating |
|
|
149
|
+
| Batch fix incomplete | Didn't verify all occurrences | grep after fixing |
|
|
150
|
+
|
|
151
|
+
---
|
|
152
|
+
|
|
153
|
+
## Output
|
|
154
|
+
|
|
155
|
+
Report:
|
|
156
|
+
1. Which dimensions your changes involve
|
|
157
|
+
2. Check results for each dimension
|
|
158
|
+
3. Issues found and fix suggestions
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: create-command
|
|
3
|
+
description: "Scaffolds a new skill file with proper naming conventions and structure. Analyzes requirements to determine skill type and generates appropriate content. Use when adding a new developer workflow skill, creating a custom skill, or extending the Trellis skill set."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Create New Skill
|
|
7
|
+
|
|
8
|
+
Create a new Codex skill in `.agents/skills/<skill-name>/SKILL.md` based on user requirements.
|
|
9
|
+
|
|
10
|
+
## Usage
|
|
11
|
+
|
|
12
|
+
```bash
|
|
13
|
+
$create-command <skill-name> <description>
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
**Example**:
|
|
17
|
+
```bash
|
|
18
|
+
$create-command review-pr Check PR code changes against project guidelines
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## Execution Steps
|
|
22
|
+
|
|
23
|
+
### 1. Parse Input
|
|
24
|
+
|
|
25
|
+
Extract from user input:
|
|
26
|
+
- **Skill name**: Use kebab-case (e.g., `review-pr`)
|
|
27
|
+
- **Description**: What the skill should accomplish
|
|
28
|
+
|
|
29
|
+
### 2. Analyze Requirements
|
|
30
|
+
|
|
31
|
+
Determine skill type based on description:
|
|
32
|
+
- **Initialization**: Read docs, establish context
|
|
33
|
+
- **Pre-development**: Read guidelines, check dependencies
|
|
34
|
+
- **Code check**: Validate code quality and guideline compliance
|
|
35
|
+
- **Recording**: Record progress, questions, structure changes
|
|
36
|
+
- **Generation**: Generate docs or code templates
|
|
37
|
+
|
|
38
|
+
### 3. Generate Skill Content
|
|
39
|
+
|
|
40
|
+
Minimum `SKILL.md` structure:
|
|
41
|
+
|
|
42
|
+
```markdown
|
|
43
|
+
---
|
|
44
|
+
name: <skill-name>
|
|
45
|
+
description: "<description>"
|
|
46
|
+
---
|
|
47
|
+
|
|
48
|
+
# <Skill Title>
|
|
49
|
+
|
|
50
|
+
<Instructions for when and how to use this skill>
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
### 4. Create Files
|
|
54
|
+
|
|
55
|
+
Create:
|
|
56
|
+
- `.agents/skills/<skill-name>/SKILL.md`
|
|
57
|
+
|
|
58
|
+
### 5. Confirm Creation
|
|
59
|
+
|
|
60
|
+
Output result:
|
|
61
|
+
|
|
62
|
+
```text
|
|
63
|
+
[OK] Created Skill: <skill-name>
|
|
64
|
+
|
|
65
|
+
File path:
|
|
66
|
+
- .agents/skills/<skill-name>/SKILL.md
|
|
67
|
+
|
|
68
|
+
Usage:
|
|
69
|
+
- Trigger directly with $<skill-name>
|
|
70
|
+
- Or open /skills and select it
|
|
71
|
+
|
|
72
|
+
Description:
|
|
73
|
+
<description>
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
## Skill Content Guidelines
|
|
77
|
+
|
|
78
|
+
### [OK] Good skill content
|
|
79
|
+
|
|
80
|
+
1. **Clear and concise**: Immediately understandable
|
|
81
|
+
2. **Executable**: AI can follow steps directly
|
|
82
|
+
3. **Well-scoped**: Clear boundaries of what to do and not do
|
|
83
|
+
4. **Has output**: Specifies expected output format (if needed)
|
|
84
|
+
|
|
85
|
+
### [X] Avoid
|
|
86
|
+
|
|
87
|
+
1. **Too vague**: e.g., "optimize code"
|
|
88
|
+
2. **Too complex**: Single skill should not exceed 100 lines
|
|
89
|
+
3. **Duplicate functionality**: Check if similar skill exists first
|
|
90
|
+
|
|
91
|
+
## Naming Conventions
|
|
92
|
+
|
|
93
|
+
| Skill Type | Prefix | Example |
|
|
94
|
+
|------------|--------|---------|
|
|
95
|
+
| Session Start | `start` | `start` |
|
|
96
|
+
| Pre-development | `before-` | `before-dev` |
|
|
97
|
+
| Check | `check-` | `check` |
|
|
98
|
+
| Record | `record-` | `record-session` |
|
|
99
|
+
| Generate | `generate-` | `generate-api-doc` |
|
|
100
|
+
| Update | `update-` | `update-changelog` |
|
|
101
|
+
| Other | Verb-first | `review-code`, `sync-data` |
|