trellis-hgl 0.6.0-beta.18
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/LICENSE +235 -0
- package/README.md +149 -0
- 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 +207 -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 +81 -0
- package/dist/commands/channel/adapters/codex.d.ts.map +1 -0
- package/dist/commands/channel/adapters/codex.js +512 -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 +503 -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 +249 -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 +13 -0
- package/dist/commands/channel/send.d.ts.map +1 -0
- package/dist/commands/channel/send.js +26 -0
- package/dist/commands/channel/send.js.map +1 -0
- package/dist/commands/channel/spawn.d.ts +30 -0
- package/dist/commands/channel/spawn.d.ts.map +1 -0
- package/dist/commands/channel/spawn.js +194 -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 +146 -0
- package/dist/commands/channel/store/watch.js.map +1 -0
- package/dist/commands/channel/supervisor/inbox.d.ts +30 -0
- package/dist/commands/channel/supervisor/inbox.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/inbox.js +160 -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 +51 -0
- package/dist/commands/channel/supervisor/stdout.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/stdout.js +121 -0
- package/dist/commands/channel/supervisor/stdout.js.map +1 -0
- package/dist/commands/channel/supervisor/turns.d.ts +20 -0
- package/dist/commands/channel/supervisor/turns.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/turns.js +28 -0
- package/dist/commands/channel/supervisor/turns.js.map +1 -0
- package/dist/commands/channel/supervisor/warning.d.ts +48 -0
- package/dist/commands/channel/supervisor/warning.d.ts.map +1 -0
- package/dist/commands/channel/supervisor/warning.js +77 -0
- package/dist/commands/channel/supervisor/warning.js.map +1 -0
- package/dist/commands/channel/supervisor.d.ts +53 -0
- package/dist/commands/channel/supervisor.d.ts.map +1 -0
- package/dist/commands/channel/supervisor.js +304 -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 +59 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +1459 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/mem.d.ts +30 -0
- package/dist/commands/mem.d.ts.map +1 -0
- package/dist/commands/mem.js +424 -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/commands/workflow.d.ts +35 -0
- package/dist/commands/workflow.d.ts.map +1 -0
- package/dist/commands/workflow.js +219 -0
- package/dist/commands/workflow.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 +541 -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 +37 -0
- package/dist/configurators/workflow.d.ts.map +1 -0
- package/dist/configurators/workflow.js +164 -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.15.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.16.json +9 -0
- package/dist/migrations/manifests/0.6.0-beta.17.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 +123 -0
- package/dist/templates/claude/agents/trellis-code-architecture-review.md +71 -0
- package/dist/templates/claude/agents/trellis-code-review.md +71 -0
- package/dist/templates/claude/agents/trellis-implement.md +118 -0
- package/dist/templates/claude/agents/trellis-merge-review.md +72 -0
- package/dist/templates/claude/agents/trellis-research.md +137 -0
- package/dist/templates/claude/agents/trellis-spec-review.md +71 -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 +115 -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 +130 -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 +41 -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/grill-me.md +49 -0
- package/dist/templates/common/skills/improve-codebase-architecture.md +38 -0
- package/dist/templates/common/skills/tdd.md +34 -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 +114 -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 +24 -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 +107 -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 +107 -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 +122 -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 +37 -0
- package/dist/templates/pi/agents/trellis-implement.md +42 -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 +108 -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 +88 -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 +832 -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 +750 -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/dist/utils/workflow-resolver.d.ts +86 -0
- package/dist/utils/workflow-resolver.d.ts.map +1 -0
- package/dist/utils/workflow-resolver.js +265 -0
- package/dist/utils/workflow-resolver.js.map +1 -0
- package/package.json +90 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
# Break the Loop - Deep Bug Analysis
|
|
2
|
+
|
|
3
|
+
When debug is complete, use this for deep analysis to break the "fix bug -> forget -> repeat" cycle.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Analysis Framework
|
|
8
|
+
|
|
9
|
+
Analyze the bug you just fixed from these 5 dimensions:
|
|
10
|
+
|
|
11
|
+
### 1. Root Cause Category
|
|
12
|
+
|
|
13
|
+
Which category does this bug belong to?
|
|
14
|
+
|
|
15
|
+
| Category | Characteristics | Example |
|
|
16
|
+
|----------|-----------------|---------|
|
|
17
|
+
| **A. Missing Spec** | No documentation on how to do it | New feature without checklist |
|
|
18
|
+
| **B. Cross-Layer Contract** | Interface between layers unclear | API returns different format than expected |
|
|
19
|
+
| **C. Change Propagation Failure** | Changed one place, missed others | Changed function signature, missed call sites |
|
|
20
|
+
| **D. Test Coverage Gap** | Unit test passes, integration fails | Works alone, breaks when combined |
|
|
21
|
+
| **E. Implicit Assumption** | Code relies on undocumented assumption | Timestamp seconds vs milliseconds |
|
|
22
|
+
|
|
23
|
+
### 2. Why Fixes Failed (if applicable)
|
|
24
|
+
|
|
25
|
+
If you tried multiple fixes before succeeding, analyze each failure:
|
|
26
|
+
|
|
27
|
+
- **Surface Fix**: Fixed symptom, not root cause
|
|
28
|
+
- **Incomplete Scope**: Found root cause, didn't cover all cases
|
|
29
|
+
- **Tool Limitation**: grep missed it, type check wasn't strict
|
|
30
|
+
- **Mental Model**: Kept looking in same layer, didn't think cross-layer
|
|
31
|
+
|
|
32
|
+
### 3. Prevention Mechanisms
|
|
33
|
+
|
|
34
|
+
What mechanisms would prevent this from happening again?
|
|
35
|
+
|
|
36
|
+
| Type | Description | Example |
|
|
37
|
+
|------|-------------|---------|
|
|
38
|
+
| **Documentation** | Write it down so people know | Update thinking guide |
|
|
39
|
+
| **Architecture** | Make the error impossible structurally | Type-safe wrappers |
|
|
40
|
+
| **Compile-time** | Strict type checking, no escape hatches | Signature change causes compile error |
|
|
41
|
+
| **Runtime** | Monitoring, alerts, scans | Detect orphan entities |
|
|
42
|
+
| **Test Coverage** | E2E tests, integration tests | Verify full flow |
|
|
43
|
+
| **Code Review** | Checklist, PR template | "Did you check X?" |
|
|
44
|
+
|
|
45
|
+
### 4. Systematic Expansion
|
|
46
|
+
|
|
47
|
+
What broader problems does this bug reveal?
|
|
48
|
+
|
|
49
|
+
- **Similar Issues**: Where else might this problem exist?
|
|
50
|
+
- **Design Flaw**: Is there a fundamental architecture issue?
|
|
51
|
+
- **Process Flaw**: Is there a development process improvement?
|
|
52
|
+
- **Knowledge Gap**: Is the team missing some understanding?
|
|
53
|
+
|
|
54
|
+
### 5. Knowledge Capture
|
|
55
|
+
|
|
56
|
+
Solidify insights into the system:
|
|
57
|
+
|
|
58
|
+
- [ ] Update `.trellis/spec/guides/` thinking guides
|
|
59
|
+
- [ ] Update relevant `.trellis/spec/` docs
|
|
60
|
+
- [ ] Create issue record (if applicable)
|
|
61
|
+
- [ ] Create feature ticket for root fix
|
|
62
|
+
- [ ] Update check guidelines if needed
|
|
63
|
+
|
|
64
|
+
---
|
|
65
|
+
|
|
66
|
+
## Output Format
|
|
67
|
+
|
|
68
|
+
Please output analysis in this format:
|
|
69
|
+
|
|
70
|
+
```markdown
|
|
71
|
+
## Bug Analysis: [Short Description]
|
|
72
|
+
|
|
73
|
+
### 1. Root Cause Category
|
|
74
|
+
- **Category**: [A/B/C/D/E] - [Category Name]
|
|
75
|
+
- **Specific Cause**: [Detailed description]
|
|
76
|
+
|
|
77
|
+
### 2. Why Fixes Failed (if applicable)
|
|
78
|
+
1. [First attempt]: [Why it failed]
|
|
79
|
+
2. [Second attempt]: [Why it failed]
|
|
80
|
+
...
|
|
81
|
+
|
|
82
|
+
### 3. Prevention Mechanisms
|
|
83
|
+
| Priority | Mechanism | Specific Action | Status |
|
|
84
|
+
|----------|-----------|-----------------|--------|
|
|
85
|
+
| P0 | ... | ... | TODO/DONE |
|
|
86
|
+
|
|
87
|
+
### 4. Systematic Expansion
|
|
88
|
+
- **Similar Issues**: [List places with similar problems]
|
|
89
|
+
- **Design Improvement**: [Architecture-level suggestions]
|
|
90
|
+
- **Process Improvement**: [Development process suggestions]
|
|
91
|
+
|
|
92
|
+
### 5. Knowledge Capture
|
|
93
|
+
- [ ] [Documents to update / tickets to create]
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
---
|
|
97
|
+
|
|
98
|
+
## Core Philosophy
|
|
99
|
+
|
|
100
|
+
> **The value of debugging is not in fixing the bug, but in making this class of bugs never happen again.**
|
|
101
|
+
|
|
102
|
+
Three levels of insight:
|
|
103
|
+
1. **Tactical**: How to fix THIS bug
|
|
104
|
+
2. **Strategic**: How to prevent THIS CLASS of bugs
|
|
105
|
+
3. **Philosophical**: How to expand thinking patterns
|
|
106
|
+
|
|
107
|
+
30 minutes of analysis saves 30 hours of future debugging.
|
|
108
|
+
|
|
109
|
+
---
|
|
110
|
+
|
|
111
|
+
## After Analysis: Immediate Actions
|
|
112
|
+
|
|
113
|
+
**IMPORTANT**: After completing the analysis above, you MUST immediately:
|
|
114
|
+
|
|
115
|
+
1. **Update spec/guides** - Don't just list TODOs, actually update the relevant files:
|
|
116
|
+
- If it's a cross-platform issue → update `cross-platform-thinking-guide.md`
|
|
117
|
+
- If it's a cross-layer issue → update `cross-layer-thinking-guide.md`
|
|
118
|
+
- If it's a code reuse issue → update `code-reuse-thinking-guide.md`
|
|
119
|
+
- If it's domain-specific → update `backend/*.md` or `frontend/*.md`
|
|
120
|
+
|
|
121
|
+
2. **Sync templates** - After updating `.trellis/spec/`, sync to `src/templates/markdown/spec/`
|
|
122
|
+
|
|
123
|
+
3. **Commit the spec updates** - This is the primary output, not just the analysis text
|
|
124
|
+
|
|
125
|
+
> **The analysis is worthless if it stays in chat. The value is in the updated specs.**
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
# Code Quality Check
|
|
2
|
+
|
|
3
|
+
Comprehensive quality verification for recently written code. Combines spec compliance, cross-layer safety, and pre-commit checks.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Step 1: Identify What Changed
|
|
8
|
+
|
|
9
|
+
```bash
|
|
10
|
+
git diff --name-only HEAD
|
|
11
|
+
git status
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
## Step 2: Read Task Artifacts and Applicable Specs
|
|
15
|
+
|
|
16
|
+
Read the current task artifacts in order:
|
|
17
|
+
|
|
18
|
+
- `prd.md`
|
|
19
|
+
- `design.md` if present
|
|
20
|
+
- `implement.md` if present
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
python3 ./.trellis/scripts/get_context.py --mode packages
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
For each changed package/layer, read the spec index and follow its **Quality Check** section:
|
|
27
|
+
|
|
28
|
+
```bash
|
|
29
|
+
cat .trellis/spec/<package>/<layer>/index.md
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
Read the specific guideline files referenced — the index is a pointer, not the goal.
|
|
33
|
+
|
|
34
|
+
## Step 3: Run Project Checks
|
|
35
|
+
|
|
36
|
+
Run the project's lint, type-check, and test commands. Fix any failures before proceeding.
|
|
37
|
+
|
|
38
|
+
## Step 4: Review Against Checklist
|
|
39
|
+
|
|
40
|
+
### Code Quality
|
|
41
|
+
|
|
42
|
+
- [ ] Linter passes?
|
|
43
|
+
- [ ] Type checker passes (if applicable)?
|
|
44
|
+
- [ ] Tests pass?
|
|
45
|
+
- [ ] No debug logging left in?
|
|
46
|
+
- [ ] No suppressed warnings or type-safety bypasses?
|
|
47
|
+
|
|
48
|
+
### Test Coverage
|
|
49
|
+
|
|
50
|
+
- [ ] New function → unit test added?
|
|
51
|
+
- [ ] Bug fix → regression test added?
|
|
52
|
+
- [ ] Changed behavior → existing tests updated?
|
|
53
|
+
|
|
54
|
+
### Spec Sync
|
|
55
|
+
|
|
56
|
+
- [ ] Does `.trellis/spec/` need updates? (new patterns, conventions, lessons learned)
|
|
57
|
+
|
|
58
|
+
> "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.
|
|
59
|
+
|
|
60
|
+
## Step 5: Cross-Layer Dimensions (if applicable)
|
|
61
|
+
|
|
62
|
+
Skip this step if your change is confined to a single layer.
|
|
63
|
+
|
|
64
|
+
### A. Data Flow (changes touch 3+ layers)
|
|
65
|
+
|
|
66
|
+
- [ ] Read flow traces correctly: Storage → Service → API → UI
|
|
67
|
+
- [ ] Write flow traces correctly: UI → API → Service → Storage
|
|
68
|
+
- [ ] Types/schemas correctly passed between layers?
|
|
69
|
+
- [ ] Errors properly propagated to caller?
|
|
70
|
+
|
|
71
|
+
### B. Code Reuse (modifying constants, creating utilities)
|
|
72
|
+
|
|
73
|
+
- [ ] Searched for existing similar code before creating new?
|
|
74
|
+
```bash
|
|
75
|
+
grep -r "pattern" src/
|
|
76
|
+
```
|
|
77
|
+
- [ ] If 2+ places define same value → extracted to shared constant?
|
|
78
|
+
- [ ] After batch modification, all occurrences updated?
|
|
79
|
+
|
|
80
|
+
### C. Import/Dependency (creating new files)
|
|
81
|
+
|
|
82
|
+
- [ ] Correct import paths (relative vs absolute)?
|
|
83
|
+
- [ ] No circular dependencies?
|
|
84
|
+
|
|
85
|
+
### D. Same-Layer Consistency
|
|
86
|
+
|
|
87
|
+
- [ ] Other places using the same concept are consistent?
|
|
88
|
+
|
|
89
|
+
---
|
|
90
|
+
|
|
91
|
+
## Step 6: Report and Fix
|
|
92
|
+
|
|
93
|
+
Report violations found and fix them directly. Re-run project checks after fixes.
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# Trellis Grill Me
|
|
2
|
+
|
|
3
|
+
Use this skill after the initial repository-first clarification pass, when the task still has requirement gaps that only the user can answer.
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
Drive a strict follow-up interview to tighten `prd.md` before implementation starts.
|
|
8
|
+
|
|
9
|
+
This is the Trellis-built-in replacement for external `grill-me` dependency patterns. Do not rely on any local third-party skill path.
|
|
10
|
+
|
|
11
|
+
## Entry Conditions
|
|
12
|
+
|
|
13
|
+
Use this skill only when:
|
|
14
|
+
- a Trellis task already exists
|
|
15
|
+
- repository-answerable questions have already been resolved through inspection
|
|
16
|
+
- the remaining uncertainty is about product intent, scope, preferences, trade-offs, or risk tolerance
|
|
17
|
+
|
|
18
|
+
Do **not** use this skill for questions the codebase can answer directly.
|
|
19
|
+
|
|
20
|
+
## Interview Contract
|
|
21
|
+
|
|
22
|
+
- Ask one question at a time.
|
|
23
|
+
- Each question must include:
|
|
24
|
+
- the exact decision needed
|
|
25
|
+
- why it matters
|
|
26
|
+
- your recommended answer
|
|
27
|
+
- what trade-off the user accepts if they choose differently
|
|
28
|
+
- After each answer, update `prd.md` before asking the next question.
|
|
29
|
+
- Stop once `prd.md` has converged enough to enter development-strategy decisions.
|
|
30
|
+
|
|
31
|
+
## Questioning Style
|
|
32
|
+
|
|
33
|
+
Push for missing details across these dimensions when relevant:
|
|
34
|
+
- user-visible behavior
|
|
35
|
+
- scope boundaries
|
|
36
|
+
- success / failure behavior
|
|
37
|
+
- edge cases
|
|
38
|
+
- sequencing and rollout expectations
|
|
39
|
+
- what is explicitly out of scope
|
|
40
|
+
- what would make the user reject the implementation even if it "works"
|
|
41
|
+
|
|
42
|
+
Prefer concrete trade-offs over generic brainstorming.
|
|
43
|
+
|
|
44
|
+
## Output Standard
|
|
45
|
+
|
|
46
|
+
By the time this skill is done:
|
|
47
|
+
- `prd.md` has testable acceptance criteria
|
|
48
|
+
- unresolved questions are truly strategic, not factual
|
|
49
|
+
- implementation can move on to development mode / worktree / TDD decisions
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
# Trellis Improve Codebase Architecture
|
|
2
|
+
|
|
3
|
+
Use this skill when the user explicitly asks for architecture improvement, when a refactor is structurally risky, or when the workflow identifies a task as architecture-sensitive.
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
Reduce structural drift, prevent AI-generated spaghetti code, and converge on a simpler long-term shape before or during refactoring.
|
|
8
|
+
|
|
9
|
+
## Core Responsibilities
|
|
10
|
+
|
|
11
|
+
1. Identify the architectural problem being solved.
|
|
12
|
+
2. Distinguish real structural issues from cosmetic cleanup.
|
|
13
|
+
3. Reduce unnecessary abstraction, indirection, and speculative flexibility.
|
|
14
|
+
4. Propose the smallest structural change that improves maintainability.
|
|
15
|
+
5. Preserve task alignment — do not widen scope without a concrete reason.
|
|
16
|
+
|
|
17
|
+
## Review Lens
|
|
18
|
+
|
|
19
|
+
Challenge changes that introduce:
|
|
20
|
+
- wrappers with no clear ownership value
|
|
21
|
+
- abstractions created for hypothetical future reuse
|
|
22
|
+
- configuration or strategy layers without current need
|
|
23
|
+
- defensive branching for impossible internal states
|
|
24
|
+
- refactors that move code around without improving boundaries
|
|
25
|
+
|
|
26
|
+
Prefer:
|
|
27
|
+
- direct control flow
|
|
28
|
+
- explicit boundaries
|
|
29
|
+
- behavior-centered module seams
|
|
30
|
+
- changes justified by current requirements or proven maintenance pain
|
|
31
|
+
|
|
32
|
+
## Output Standard
|
|
33
|
+
|
|
34
|
+
When this skill is used, it should produce:
|
|
35
|
+
- the architectural concern in plain language
|
|
36
|
+
- the smallest acceptable direction to fix it
|
|
37
|
+
- what not to add
|
|
38
|
+
- what must stay aligned with current task scope
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
# Trellis TDD
|
|
2
|
+
|
|
3
|
+
Use this skill when the task's chosen development strategy is TDD, or when the user explicitly asks to work test-first.
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
Turn a task into observable behavior slices and drive implementation through failing tests first.
|
|
8
|
+
|
|
9
|
+
This is the Trellis-built-in replacement for external local TDD references. Do not rely on any local third-party skill path.
|
|
10
|
+
|
|
11
|
+
## Core Flow
|
|
12
|
+
|
|
13
|
+
1. Identify the smallest observable behavior slice.
|
|
14
|
+
2. Define the public interface under test.
|
|
15
|
+
3. Decide the mock boundaries before writing tests.
|
|
16
|
+
4. Write the failing test first.
|
|
17
|
+
5. Implement the smallest code change that makes it pass.
|
|
18
|
+
6. Refactor only after the test is green.
|
|
19
|
+
7. Repeat slice by slice.
|
|
20
|
+
|
|
21
|
+
## Rules
|
|
22
|
+
|
|
23
|
+
- Keep slices small and user-observable.
|
|
24
|
+
- Prefer testing public behavior over internal helpers.
|
|
25
|
+
- Do not batch multiple behavior changes into one red-green cycle.
|
|
26
|
+
- If a task artifact already records acceptance criteria, map tests back to them.
|
|
27
|
+
- Keep review gates aligned with the chosen TDD strategy.
|
|
28
|
+
|
|
29
|
+
## Output Standard
|
|
30
|
+
|
|
31
|
+
By the time this skill is done:
|
|
32
|
+
- tests lead the implementation order
|
|
33
|
+
- each behavior slice is backed by an explicit test
|
|
34
|
+
- the task artifacts clearly reflect TDD as the chosen strategy
|
|
@@ -0,0 +1,351 @@
|
|
|
1
|
+
# Update Code-Spec - Capture Executable Contracts
|
|
2
|
+
|
|
3
|
+
When you learn something valuable (from debugging, implementing, or discussion), use this to update the relevant code-spec documents.
|
|
4
|
+
|
|
5
|
+
**Timing**: After completing a task, fixing a bug, or discovering a new pattern
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Code-Spec First Rule (CRITICAL)
|
|
10
|
+
|
|
11
|
+
In this project, "spec" for implementation work means **code-spec**:
|
|
12
|
+
- Executable contracts (not principle-only text)
|
|
13
|
+
- Concrete signatures, payload fields, env keys, and boundary behavior
|
|
14
|
+
- Testable validation/error behavior
|
|
15
|
+
|
|
16
|
+
If the change touches infra or cross-layer contracts, code-spec depth is mandatory.
|
|
17
|
+
|
|
18
|
+
### Mandatory Triggers
|
|
19
|
+
|
|
20
|
+
Apply code-spec depth when the change includes any of:
|
|
21
|
+
- New/changed command or API signature
|
|
22
|
+
- Cross-layer request/response contract change
|
|
23
|
+
- Database schema/migration change
|
|
24
|
+
- Infra integration (storage, queue, cache, secrets, env wiring)
|
|
25
|
+
|
|
26
|
+
### Mandatory Output (7 Sections)
|
|
27
|
+
|
|
28
|
+
For triggered tasks, include all sections below:
|
|
29
|
+
1. Scope / Trigger
|
|
30
|
+
2. Signatures (command/API/DB)
|
|
31
|
+
3. Contracts (request/response/env)
|
|
32
|
+
4. Validation & Error Matrix
|
|
33
|
+
5. Good/Base/Bad Cases
|
|
34
|
+
6. Tests Required (with assertion points)
|
|
35
|
+
7. Wrong vs Correct (at least one pair)
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## When to Update Code-Specs
|
|
40
|
+
|
|
41
|
+
| Trigger | Example | Target Spec |
|
|
42
|
+
|---------|---------|-------------|
|
|
43
|
+
| **Implemented a feature** | Added a new integration or module | Relevant spec file |
|
|
44
|
+
| **Made a design decision** | Chose extensibility pattern over simplicity | Relevant spec + "Design Decisions" section |
|
|
45
|
+
| **Fixed a bug** | Found a subtle issue with error handling | Relevant spec (e.g., error-handling docs) |
|
|
46
|
+
| **Discovered a pattern** | Found a better way to structure code | Relevant spec file |
|
|
47
|
+
| **Hit a gotcha** | Learned that X must be done before Y | Relevant spec + "Common Mistakes" section |
|
|
48
|
+
| **Established a convention** | Team agreed on naming pattern | Quality guidelines |
|
|
49
|
+
| **New thinking trigger** | "Don't forget to check X before doing Y" | `guides/*.md` (as a checklist item) |
|
|
50
|
+
|
|
51
|
+
**Key Insight**: Code-spec updates are NOT just for problems. Every feature implementation contains design decisions and contracts that future AI/developers need to execute safely.
|
|
52
|
+
|
|
53
|
+
---
|
|
54
|
+
|
|
55
|
+
## Spec Structure Overview
|
|
56
|
+
|
|
57
|
+
```
|
|
58
|
+
.trellis/spec/
|
|
59
|
+
├── <layer>/ # Per-layer coding standards (e.g., backend/, frontend/, api/)
|
|
60
|
+
│ ├── index.md # Overview and links
|
|
61
|
+
│ └── *.md # Topic-specific guidelines
|
|
62
|
+
└── guides/ # Thinking checklists (NOT coding specs!)
|
|
63
|
+
├── index.md # Guide index
|
|
64
|
+
└── *.md # Topic-specific guides
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
### CRITICAL: Code-Spec vs Guide - Know the Difference
|
|
68
|
+
|
|
69
|
+
| Type | Location | Purpose | Content Style |
|
|
70
|
+
|------|----------|---------|---------------|
|
|
71
|
+
| **Code-Spec** | `<layer>/*.md` | Tell AI "how to implement safely" | Signatures, contracts, matrices, cases, test points |
|
|
72
|
+
| **Guide** | `guides/*.md` | Help AI "what to think about" | Checklists, questions, pointers to specs |
|
|
73
|
+
|
|
74
|
+
**Decision Rule**: Ask yourself:
|
|
75
|
+
|
|
76
|
+
- "This is **how to write** the code" → Put in a spec layer directory
|
|
77
|
+
- "This is **what to consider** before writing" → Put in `guides/`
|
|
78
|
+
|
|
79
|
+
**Example**:
|
|
80
|
+
|
|
81
|
+
| Learning | Wrong Location | Correct Location |
|
|
82
|
+
|----------|----------------|------------------|
|
|
83
|
+
| "Use API X not API Y for this task" | ❌ `guides/` (too specific for a thinking guide) | ✅ Relevant spec file (concrete convention) |
|
|
84
|
+
| "Remember to check X when doing Y" | ❌ Spec file (too abstract for a spec) | ✅ `guides/` (thinking checklist) |
|
|
85
|
+
|
|
86
|
+
**Guides should be short checklists that point to specs**, not duplicate the detailed rules.
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## Update Process
|
|
91
|
+
|
|
92
|
+
### Step 1: Identify What You Learned
|
|
93
|
+
|
|
94
|
+
Answer these questions:
|
|
95
|
+
|
|
96
|
+
1. **What did you learn?** (Be specific)
|
|
97
|
+
2. **Why is it important?** (What problem does it prevent?)
|
|
98
|
+
3. **Where does it belong?** (Which spec file?)
|
|
99
|
+
|
|
100
|
+
### Step 2: Classify the Update Type
|
|
101
|
+
|
|
102
|
+
| Type | Description | Action |
|
|
103
|
+
|------|-------------|--------|
|
|
104
|
+
| **Design Decision** | Why we chose approach X over Y | Add to "Design Decisions" section |
|
|
105
|
+
| **Project Convention** | How we do X in this project | Add to relevant section with examples |
|
|
106
|
+
| **New Pattern** | A reusable approach discovered | Add to "Patterns" section |
|
|
107
|
+
| **Forbidden Pattern** | Something that causes problems | Add to "Anti-patterns" or "Don't" section |
|
|
108
|
+
| **Common Mistake** | Easy-to-make error | Add to "Common Mistakes" section |
|
|
109
|
+
| **Convention** | Agreed-upon standard | Add to relevant section |
|
|
110
|
+
| **Gotcha** | Non-obvious behavior | Add warning callout |
|
|
111
|
+
|
|
112
|
+
### Step 3: Read the Target Code-Spec
|
|
113
|
+
|
|
114
|
+
Before editing, read the current code-spec to:
|
|
115
|
+
- Understand existing structure
|
|
116
|
+
- Avoid duplicating content
|
|
117
|
+
- Find the right section for your update
|
|
118
|
+
|
|
119
|
+
```bash
|
|
120
|
+
cat .trellis/spec/<category>/<file>.md
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
### Step 4: Make the Update
|
|
124
|
+
|
|
125
|
+
Follow these principles:
|
|
126
|
+
|
|
127
|
+
1. **Be Specific**: Include concrete examples, not just abstract rules
|
|
128
|
+
2. **Explain Why**: State the problem this prevents
|
|
129
|
+
3. **Show Contracts**: Add signatures, payload fields, and error behavior
|
|
130
|
+
4. **Show Code**: Add code snippets for key patterns
|
|
131
|
+
5. **Keep it Short**: One concept per section
|
|
132
|
+
|
|
133
|
+
### Step 5: Update the Index (if needed)
|
|
134
|
+
|
|
135
|
+
If you added a new section or the code-spec status changed, update the category's `index.md`.
|
|
136
|
+
|
|
137
|
+
---
|
|
138
|
+
|
|
139
|
+
## Update Templates
|
|
140
|
+
|
|
141
|
+
### Mandatory Template for Infra/Cross-Layer Work
|
|
142
|
+
|
|
143
|
+
```markdown
|
|
144
|
+
## Scenario: <name>
|
|
145
|
+
|
|
146
|
+
### 1. Scope / Trigger
|
|
147
|
+
- Trigger: <why this requires code-spec depth>
|
|
148
|
+
|
|
149
|
+
### 2. Signatures
|
|
150
|
+
- Backend command/API/DB signature(s)
|
|
151
|
+
|
|
152
|
+
### 3. Contracts
|
|
153
|
+
- Request fields (name, type, constraints)
|
|
154
|
+
- Response fields (name, type, constraints)
|
|
155
|
+
- Environment keys (required/optional)
|
|
156
|
+
|
|
157
|
+
### 4. Validation & Error Matrix
|
|
158
|
+
- <condition> -> <error>
|
|
159
|
+
|
|
160
|
+
### 5. Good/Base/Bad Cases
|
|
161
|
+
- Good: ...
|
|
162
|
+
- Base: ...
|
|
163
|
+
- Bad: ...
|
|
164
|
+
|
|
165
|
+
### 6. Tests Required
|
|
166
|
+
- Unit/Integration/E2E with assertion points
|
|
167
|
+
|
|
168
|
+
### 7. Wrong vs Correct
|
|
169
|
+
#### Wrong
|
|
170
|
+
...
|
|
171
|
+
#### Correct
|
|
172
|
+
...
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
### Adding a Design Decision
|
|
176
|
+
|
|
177
|
+
```markdown
|
|
178
|
+
### Design Decision: [Decision Name]
|
|
179
|
+
|
|
180
|
+
**Context**: What problem were we solving?
|
|
181
|
+
|
|
182
|
+
**Options Considered**:
|
|
183
|
+
1. Option A - brief description
|
|
184
|
+
2. Option B - brief description
|
|
185
|
+
|
|
186
|
+
**Decision**: We chose Option X because...
|
|
187
|
+
|
|
188
|
+
**Example**:
|
|
189
|
+
\`\`\`typescript
|
|
190
|
+
// How it's implemented
|
|
191
|
+
code example
|
|
192
|
+
\`\`\`
|
|
193
|
+
|
|
194
|
+
**Extensibility**: How to extend this in the future...
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
### Adding a Project Convention
|
|
198
|
+
|
|
199
|
+
```markdown
|
|
200
|
+
### Convention: [Convention Name]
|
|
201
|
+
|
|
202
|
+
**What**: Brief description of the convention.
|
|
203
|
+
|
|
204
|
+
**Why**: Why we do it this way in this project.
|
|
205
|
+
|
|
206
|
+
**Example**:
|
|
207
|
+
\`\`\`typescript
|
|
208
|
+
// How to follow this convention
|
|
209
|
+
code example
|
|
210
|
+
\`\`\`
|
|
211
|
+
|
|
212
|
+
**Related**: Links to related conventions or specs.
|
|
213
|
+
```
|
|
214
|
+
|
|
215
|
+
### Adding a New Pattern
|
|
216
|
+
|
|
217
|
+
```markdown
|
|
218
|
+
### Pattern Name
|
|
219
|
+
|
|
220
|
+
**Problem**: What problem does this solve?
|
|
221
|
+
|
|
222
|
+
**Solution**: Brief description of the approach.
|
|
223
|
+
|
|
224
|
+
**Example**:
|
|
225
|
+
\`\`\`
|
|
226
|
+
// Good
|
|
227
|
+
code example
|
|
228
|
+
|
|
229
|
+
// Bad
|
|
230
|
+
code example
|
|
231
|
+
\`\`\`
|
|
232
|
+
|
|
233
|
+
**Why**: Explanation of why this works better.
|
|
234
|
+
```
|
|
235
|
+
|
|
236
|
+
### Adding a Forbidden Pattern
|
|
237
|
+
|
|
238
|
+
```markdown
|
|
239
|
+
### Don't: Pattern Name
|
|
240
|
+
|
|
241
|
+
**Problem**:
|
|
242
|
+
\`\`\`
|
|
243
|
+
// Don't do this
|
|
244
|
+
bad code example
|
|
245
|
+
\`\`\`
|
|
246
|
+
|
|
247
|
+
**Why it's bad**: Explanation of the issue.
|
|
248
|
+
|
|
249
|
+
**Instead**:
|
|
250
|
+
\`\`\`
|
|
251
|
+
// Do this instead
|
|
252
|
+
good code example
|
|
253
|
+
\`\`\`
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
### Adding a Common Mistake
|
|
257
|
+
|
|
258
|
+
```markdown
|
|
259
|
+
### Common Mistake: Description
|
|
260
|
+
|
|
261
|
+
**Symptom**: What goes wrong
|
|
262
|
+
|
|
263
|
+
**Cause**: Why this happens
|
|
264
|
+
|
|
265
|
+
**Fix**: How to correct it
|
|
266
|
+
|
|
267
|
+
**Prevention**: How to avoid it in the future
|
|
268
|
+
```
|
|
269
|
+
|
|
270
|
+
### Adding a Gotcha
|
|
271
|
+
|
|
272
|
+
```markdown
|
|
273
|
+
> **Warning**: Brief description of the non-obvious behavior.
|
|
274
|
+
>
|
|
275
|
+
> Details about when this happens and how to handle it.
|
|
276
|
+
```
|
|
277
|
+
|
|
278
|
+
---
|
|
279
|
+
|
|
280
|
+
## Interactive Mode
|
|
281
|
+
|
|
282
|
+
If you're unsure what to update, answer these prompts:
|
|
283
|
+
|
|
284
|
+
1. **What did you just finish?**
|
|
285
|
+
- [ ] Fixed a bug
|
|
286
|
+
- [ ] Implemented a feature
|
|
287
|
+
- [ ] Refactored code
|
|
288
|
+
- [ ] Had a discussion about approach
|
|
289
|
+
|
|
290
|
+
2. **What did you learn or decide?**
|
|
291
|
+
- Design decision (why X over Y)
|
|
292
|
+
- Project convention (how we do X)
|
|
293
|
+
- Non-obvious behavior (gotcha)
|
|
294
|
+
- Better approach (pattern)
|
|
295
|
+
|
|
296
|
+
3. **Would future AI/developers need to know this?**
|
|
297
|
+
- To understand how the code works → Yes, update spec
|
|
298
|
+
- To maintain or extend the feature → Yes, update spec
|
|
299
|
+
- To avoid repeating mistakes → Yes, update spec
|
|
300
|
+
- Purely one-off implementation detail → Maybe skip
|
|
301
|
+
|
|
302
|
+
4. **Which area does it relate to?**
|
|
303
|
+
- [ ] Backend code
|
|
304
|
+
- [ ] Frontend code
|
|
305
|
+
- [ ] Cross-layer data flow
|
|
306
|
+
- [ ] Code organization/reuse
|
|
307
|
+
- [ ] Quality/testing
|
|
308
|
+
|
|
309
|
+
---
|
|
310
|
+
|
|
311
|
+
## Quality Checklist
|
|
312
|
+
|
|
313
|
+
Before finishing your code-spec update:
|
|
314
|
+
|
|
315
|
+
- [ ] Is the content specific and actionable?
|
|
316
|
+
- [ ] Did you include a code example?
|
|
317
|
+
- [ ] Did you explain WHY, not just WHAT?
|
|
318
|
+
- [ ] Did you include executable signatures/contracts?
|
|
319
|
+
- [ ] Did you include validation and error matrix?
|
|
320
|
+
- [ ] Did you include Good/Base/Bad cases?
|
|
321
|
+
- [ ] Did you include required tests with assertion points?
|
|
322
|
+
- [ ] Is it in the right code-spec file?
|
|
323
|
+
- [ ] Does it duplicate existing content?
|
|
324
|
+
- [ ] Would a new team member understand it?
|
|
325
|
+
|
|
326
|
+
---
|
|
327
|
+
|
|
328
|
+
## Relationship to Other Commands
|
|
329
|
+
|
|
330
|
+
```
|
|
331
|
+
Development Flow:
|
|
332
|
+
Learn something → {{CMD_REF:update-spec}} → Knowledge captured
|
|
333
|
+
↑ ↓
|
|
334
|
+
{{CMD_REF:break-loop}} ←──────────────────── Future sessions benefit
|
|
335
|
+
(deep bug analysis)
|
|
336
|
+
```
|
|
337
|
+
|
|
338
|
+
- `{{CMD_REF:break-loop}}` - Analyzes bugs deeply, often reveals spec updates needed
|
|
339
|
+
- `{{CMD_REF:update-spec}}` - Actually makes the updates
|
|
340
|
+
- `{{CMD_REF:finish-work}}` - Reminds you to check if specs need updates
|
|
341
|
+
|
|
342
|
+
---
|
|
343
|
+
|
|
344
|
+
## Core Philosophy
|
|
345
|
+
|
|
346
|
+
> **Code-specs are living documents. Every debugging session, every "aha moment" is an opportunity to make the implementation contract clearer.**
|
|
347
|
+
|
|
348
|
+
The goal is **institutional memory**:
|
|
349
|
+
- What one person learns, everyone benefits from
|
|
350
|
+
- What AI learns in one session, persists to future sessions
|
|
351
|
+
- Mistakes become documented guardrails
|