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