@jahanxu/trellis 0.4.1
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 +212 -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 +97 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/commands/init.d.ts +21 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +527 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/update.d.ts +27 -0
- package/dist/commands/update.d.ts.map +1 -0
- package/dist/commands/update.js +1289 -0
- package/dist/commands/update.js.map +1 -0
- package/dist/configurators/antigravity.d.ts +8 -0
- package/dist/configurators/antigravity.d.ts.map +1 -0
- package/dist/configurators/antigravity.js +18 -0
- package/dist/configurators/antigravity.js.map +1 -0
- package/dist/configurators/claude.d.ts +32 -0
- package/dist/configurators/claude.d.ts.map +1 -0
- package/dist/configurators/claude.js +98 -0
- package/dist/configurators/claude.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 +20 -0
- package/dist/configurators/codex.js.map +1 -0
- package/dist/configurators/cursor.d.ts +5 -0
- package/dist/configurators/cursor.d.ts.map +1 -0
- package/dist/configurators/cursor.js +52 -0
- package/dist/configurators/cursor.js.map +1 -0
- package/dist/configurators/gemini.d.ts +8 -0
- package/dist/configurators/gemini.d.ts.map +1 -0
- package/dist/configurators/gemini.js +52 -0
- package/dist/configurators/gemini.js.map +1 -0
- package/dist/configurators/iflow.d.ts +33 -0
- package/dist/configurators/iflow.d.ts.map +1 -0
- package/dist/configurators/iflow.js +99 -0
- package/dist/configurators/iflow.js.map +1 -0
- package/dist/configurators/index.d.ts +55 -0
- package/dist/configurators/index.d.ts.map +1 -0
- package/dist/configurators/index.js +220 -0
- package/dist/configurators/index.js.map +1 -0
- package/dist/configurators/kilo.d.ts +8 -0
- package/dist/configurators/kilo.d.ts.map +1 -0
- package/dist/configurators/kilo.js +51 -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 +20 -0
- package/dist/configurators/kiro.js.map +1 -0
- package/dist/configurators/opencode.d.ts +32 -0
- package/dist/configurators/opencode.d.ts.map +1 -0
- package/dist/configurators/opencode.js +92 -0
- package/dist/configurators/opencode.js.map +1 -0
- package/dist/configurators/shared.d.ts +12 -0
- package/dist/configurators/shared.d.ts.map +1 -0
- package/dist/configurators/shared.js +21 -0
- package/dist/configurators/shared.js.map +1 -0
- package/dist/configurators/workflow.d.ts +28 -0
- package/dist/configurators/workflow.d.ts.map +1 -0
- package/dist/configurators/workflow.js +134 -0
- package/dist/configurators/workflow.js.map +1 -0
- package/dist/constants/paths.d.ts +68 -0
- package/dist/constants/paths.d.ts.map +1 -0
- package/dist/constants/paths.js +77 -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 +54 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +160 -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 +278 -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/templates/antigravity/index.d.ts +12 -0
- package/dist/templates/antigravity/index.d.ts.map +1 -0
- package/dist/templates/antigravity/index.js +29 -0
- package/dist/templates/antigravity/index.js.map +1 -0
- package/dist/templates/claude/agents/check.md +122 -0
- package/dist/templates/claude/agents/debug.md +106 -0
- package/dist/templates/claude/agents/dispatch.md +214 -0
- package/dist/templates/claude/agents/implement.md +96 -0
- package/dist/templates/claude/agents/plan.md +396 -0
- package/dist/templates/claude/agents/research.md +120 -0
- package/dist/templates/claude/commands/trellis/before-backend-dev.md +13 -0
- package/dist/templates/claude/commands/trellis/before-frontend-dev.md +13 -0
- package/dist/templates/claude/commands/trellis/before-role-work.md +364 -0
- package/dist/templates/claude/commands/trellis/brainstorm.md +474 -0
- package/dist/templates/claude/commands/trellis/break-loop.md +125 -0
- package/dist/templates/claude/commands/trellis/check-backend.md +13 -0
- package/dist/templates/claude/commands/trellis/check-cross-layer.md +153 -0
- package/dist/templates/claude/commands/trellis/check-frontend.md +13 -0
- package/dist/templates/claude/commands/trellis/create-command.md +154 -0
- package/dist/templates/claude/commands/trellis/finish-work.md +153 -0
- package/dist/templates/claude/commands/trellis/handoff.md +445 -0
- package/dist/templates/claude/commands/trellis/integrate-skill.md +219 -0
- package/dist/templates/claude/commands/trellis/onboard.md +358 -0
- package/dist/templates/claude/commands/trellis/parallel.md +193 -0
- package/dist/templates/claude/commands/trellis/pick-task.md +515 -0
- package/dist/templates/claude/commands/trellis/record-session.md +62 -0
- package/dist/templates/claude/commands/trellis/start.md +373 -0
- package/dist/templates/claude/commands/trellis/update-spec.md +354 -0
- package/dist/templates/claude/hooks/inject-subagent-context.py +873 -0
- package/dist/templates/claude/hooks/ralph-loop.py +388 -0
- package/dist/templates/claude/hooks/session-start.py +200 -0
- package/dist/templates/claude/index.d.ts +54 -0
- package/dist/templates/claude/index.d.ts.map +1 -0
- package/dist/templates/claude/index.js +85 -0
- package/dist/templates/claude/index.js.map +1 -0
- package/dist/templates/claude/settings.json +41 -0
- package/dist/templates/codex/index.d.ts +18 -0
- package/dist/templates/codex/index.d.ts.map +1 -0
- package/dist/templates/codex/index.js +40 -0
- package/dist/templates/codex/index.js.map +1 -0
- package/dist/templates/codex/skills/before-backend-dev/SKILL.md +18 -0
- package/dist/templates/codex/skills/before-frontend-dev/SKILL.md +18 -0
- package/dist/templates/codex/skills/brainstorm/SKILL.md +479 -0
- package/dist/templates/codex/skills/break-loop/SKILL.md +130 -0
- package/dist/templates/codex/skills/check-backend/SKILL.md +18 -0
- package/dist/templates/codex/skills/check-cross-layer/SKILL.md +158 -0
- package/dist/templates/codex/skills/check-frontend/SKILL.md +18 -0
- package/dist/templates/codex/skills/create-command/SKILL.md +101 -0
- package/dist/templates/codex/skills/finish-work/SKILL.md +148 -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 +330 -0
- package/dist/templates/codex/skills/update-spec/SKILL.md +335 -0
- package/dist/templates/cursor/commands/trellis-before-backend-dev.md +13 -0
- package/dist/templates/cursor/commands/trellis-before-frontend-dev.md +13 -0
- package/dist/templates/cursor/commands/trellis-brainstorm.md +474 -0
- package/dist/templates/cursor/commands/trellis-break-loop.md +107 -0
- package/dist/templates/cursor/commands/trellis-check-backend.md +13 -0
- package/dist/templates/cursor/commands/trellis-check-cross-layer.md +153 -0
- package/dist/templates/cursor/commands/trellis-check-frontend.md +13 -0
- package/dist/templates/cursor/commands/trellis-create-command.md +154 -0
- package/dist/templates/cursor/commands/trellis-finish-work.md +143 -0
- package/dist/templates/cursor/commands/trellis-integrate-skill.md +219 -0
- package/dist/templates/cursor/commands/trellis-onboard.md +358 -0
- package/dist/templates/cursor/commands/trellis-record-session.md +62 -0
- package/dist/templates/cursor/commands/trellis-start.md +366 -0
- package/dist/templates/cursor/commands/trellis-update-spec.md +354 -0
- package/dist/templates/cursor/index.d.ts +24 -0
- package/dist/templates/cursor/index.d.ts.map +1 -0
- package/dist/templates/cursor/index.js +44 -0
- package/dist/templates/cursor/index.js.map +1 -0
- package/dist/templates/extract.d.ts +166 -0
- package/dist/templates/extract.d.ts.map +1 -0
- package/dist/templates/extract.js +296 -0
- package/dist/templates/extract.js.map +1 -0
- package/dist/templates/gemini/commands/trellis/before-backend-dev.toml +17 -0
- package/dist/templates/gemini/commands/trellis/before-frontend-dev.toml +17 -0
- package/dist/templates/gemini/commands/trellis/brainstorm.toml +420 -0
- package/dist/templates/gemini/commands/trellis/break-loop.toml +129 -0
- package/dist/templates/gemini/commands/trellis/check-backend.toml +17 -0
- package/dist/templates/gemini/commands/trellis/check-cross-layer.toml +147 -0
- package/dist/templates/gemini/commands/trellis/check-frontend.toml +17 -0
- package/dist/templates/gemini/commands/trellis/create-command.toml +119 -0
- package/dist/templates/gemini/commands/trellis/finish-work.toml +133 -0
- package/dist/templates/gemini/commands/trellis/integrate-skill.toml +104 -0
- package/dist/templates/gemini/commands/trellis/onboard.toml +111 -0
- package/dist/templates/gemini/commands/trellis/record-session.toml +66 -0
- package/dist/templates/gemini/commands/trellis/start.toml +292 -0
- package/dist/templates/gemini/commands/trellis/update-spec.toml +132 -0
- package/dist/templates/gemini/index.d.ts +21 -0
- package/dist/templates/gemini/index.d.ts.map +1 -0
- package/dist/templates/gemini/index.js +44 -0
- package/dist/templates/gemini/index.js.map +1 -0
- package/dist/templates/iflow/agents/check.md +122 -0
- package/dist/templates/iflow/agents/debug.md +106 -0
- package/dist/templates/iflow/agents/dispatch.md +214 -0
- package/dist/templates/iflow/agents/implement.md +96 -0
- package/dist/templates/iflow/agents/plan.md +396 -0
- package/dist/templates/iflow/agents/research.md +120 -0
- package/dist/templates/iflow/commands/trellis/before-backend-dev.md +13 -0
- package/dist/templates/iflow/commands/trellis/before-frontend-dev.md +13 -0
- package/dist/templates/iflow/commands/trellis/brainstorm.md +474 -0
- package/dist/templates/iflow/commands/trellis/break-loop.md +125 -0
- package/dist/templates/iflow/commands/trellis/check-backend.md +13 -0
- package/dist/templates/iflow/commands/trellis/check-cross-layer.md +153 -0
- package/dist/templates/iflow/commands/trellis/check-frontend.md +13 -0
- package/dist/templates/iflow/commands/trellis/create-command.md +152 -0
- package/dist/templates/iflow/commands/trellis/finish-work.md +153 -0
- package/dist/templates/iflow/commands/trellis/integrate-skill.md +219 -0
- package/dist/templates/iflow/commands/trellis/onboard.md +358 -0
- package/dist/templates/iflow/commands/trellis/parallel.md +193 -0
- package/dist/templates/iflow/commands/trellis/record-session.md +62 -0
- package/dist/templates/iflow/commands/trellis/start.md +373 -0
- package/dist/templates/iflow/commands/trellis/update-spec.md +354 -0
- package/dist/templates/iflow/hooks/inject-subagent-context.py +788 -0
- package/dist/templates/iflow/hooks/ralph-loop.py +388 -0
- package/dist/templates/iflow/hooks/session-start.py +143 -0
- package/dist/templates/iflow/index.d.ts +54 -0
- package/dist/templates/iflow/index.d.ts.map +1 -0
- package/dist/templates/iflow/index.js +85 -0
- package/dist/templates/iflow/index.js.map +1 -0
- package/dist/templates/iflow/settings.json +40 -0
- package/dist/templates/kilo/commands/trellis/before-backend-dev.md +13 -0
- package/dist/templates/kilo/commands/trellis/before-frontend-dev.md +13 -0
- package/dist/templates/kilo/commands/trellis/brainstorm.md +474 -0
- package/dist/templates/kilo/commands/trellis/break-loop.md +125 -0
- package/dist/templates/kilo/commands/trellis/check-backend.md +13 -0
- package/dist/templates/kilo/commands/trellis/check-cross-layer.md +153 -0
- package/dist/templates/kilo/commands/trellis/check-frontend.md +13 -0
- package/dist/templates/kilo/commands/trellis/create-command.md +152 -0
- package/dist/templates/kilo/commands/trellis/finish-work.md +129 -0
- package/dist/templates/kilo/commands/trellis/integrate-skill.md +219 -0
- package/dist/templates/kilo/commands/trellis/onboard.md +358 -0
- package/dist/templates/kilo/commands/trellis/parallel.md +194 -0
- package/dist/templates/kilo/commands/trellis/record-session.md +62 -0
- package/dist/templates/kilo/commands/trellis/start.md +321 -0
- package/dist/templates/kilo/commands/trellis/update-spec.md +285 -0
- package/dist/templates/kilo/index.d.ts +16 -0
- package/dist/templates/kilo/index.d.ts.map +1 -0
- package/dist/templates/kilo/index.js +39 -0
- package/dist/templates/kilo/index.js.map +1 -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 +40 -0
- package/dist/templates/kiro/index.js.map +1 -0
- package/dist/templates/kiro/skills/before-backend-dev/SKILL.md +18 -0
- package/dist/templates/kiro/skills/before-frontend-dev/SKILL.md +18 -0
- package/dist/templates/kiro/skills/brainstorm/SKILL.md +479 -0
- package/dist/templates/kiro/skills/break-loop/SKILL.md +130 -0
- package/dist/templates/kiro/skills/check-backend/SKILL.md +18 -0
- package/dist/templates/kiro/skills/check-cross-layer/SKILL.md +158 -0
- package/dist/templates/kiro/skills/check-frontend/SKILL.md +18 -0
- package/dist/templates/kiro/skills/create-command/SKILL.md +101 -0
- package/dist/templates/kiro/skills/finish-work/SKILL.md +148 -0
- package/dist/templates/kiro/skills/integrate-skill/SKILL.md +221 -0
- package/dist/templates/kiro/skills/onboard/SKILL.md +363 -0
- package/dist/templates/kiro/skills/record-session/SKILL.md +67 -0
- package/dist/templates/kiro/skills/start/SKILL.md +330 -0
- package/dist/templates/kiro/skills/update-spec/SKILL.md +335 -0
- package/dist/templates/markdown/agents.md +18 -0
- package/dist/templates/markdown/gitignore.txt +12 -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 +40 -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/backend/script-conventions.md +467 -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 +118 -0
- package/dist/templates/markdown/spec/guides/code-reuse-thinking-guide.md.txt +92 -0
- package/dist/templates/markdown/spec/guides/cross-layer-thinking-guide.md.txt +94 -0
- package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md +394 -0
- package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md.txt +319 -0
- package/dist/templates/markdown/spec/guides/index.md.txt +79 -0
- package/dist/templates/markdown/workspace-index.md +123 -0
- package/dist/templates/markdown/worktree.yaml.txt +58 -0
- package/dist/templates/opencode/agents/check.md +146 -0
- package/dist/templates/opencode/agents/debug.md +129 -0
- package/dist/templates/opencode/agents/dispatch.md +223 -0
- package/dist/templates/opencode/agents/implement.md +120 -0
- package/dist/templates/opencode/agents/research.md +147 -0
- package/dist/templates/opencode/agents/trellis-plan.md +427 -0
- package/dist/templates/opencode/commands/trellis/before-backend-dev.md +13 -0
- package/dist/templates/opencode/commands/trellis/before-frontend-dev.md +13 -0
- package/dist/templates/opencode/commands/trellis/brainstorm.md +474 -0
- package/dist/templates/opencode/commands/trellis/break-loop.md +125 -0
- package/dist/templates/opencode/commands/trellis/check-backend.md +13 -0
- package/dist/templates/opencode/commands/trellis/check-cross-layer.md +153 -0
- package/dist/templates/opencode/commands/trellis/check-frontend.md +13 -0
- package/dist/templates/opencode/commands/trellis/create-command.md +154 -0
- package/dist/templates/opencode/commands/trellis/finish-work.md +144 -0
- package/dist/templates/opencode/commands/trellis/integrate-skill.md +219 -0
- package/dist/templates/opencode/commands/trellis/migrate-specs.md +0 -0
- package/dist/templates/opencode/commands/trellis/onboard.md +358 -0
- package/dist/templates/opencode/commands/trellis/parallel.md +194 -0
- package/dist/templates/opencode/commands/trellis/record-session.md +62 -0
- package/dist/templates/opencode/commands/trellis/start.md +338 -0
- package/dist/templates/opencode/commands/trellis/update-spec.md +354 -0
- package/dist/templates/opencode/lib/trellis-context.js +436 -0
- package/dist/templates/opencode/package.json +5 -0
- package/dist/templates/opencode/plugin/inject-subagent-context.js +538 -0
- package/dist/templates/opencode/plugin/session-start.js +192 -0
- package/dist/templates/trellis/VERSION +1 -0
- package/dist/templates/trellis/deliverables/README.md +51 -0
- package/dist/templates/trellis/gitignore.txt +29 -0
- package/dist/templates/trellis/index.d.ts +49 -0
- package/dist/templates/trellis/index.d.ts.map +1 -0
- package/dist/templates/trellis/index.js +92 -0
- package/dist/templates/trellis/index.js.map +1 -0
- package/dist/templates/trellis/paths.README.md +277 -0
- package/dist/templates/trellis/paths.yaml +41 -0
- package/dist/templates/trellis/pool/implementations.json +5 -0
- package/dist/templates/trellis/pool/prototypes.json +5 -0
- package/dist/templates/trellis/pool/requirements.json +5 -0
- package/dist/templates/trellis/scripts/__init__.py +5 -0
- package/dist/templates/trellis/scripts/add_session.py +391 -0
- package/dist/templates/trellis/scripts/common/__init__.py +80 -0
- package/dist/templates/trellis/scripts/common/cli_adapter.py +522 -0
- package/dist/templates/trellis/scripts/common/developer.py +189 -0
- package/dist/templates/trellis/scripts/common/git_context.py +383 -0
- package/dist/templates/trellis/scripts/common/paths.py +346 -0
- package/dist/templates/trellis/scripts/common/phase.py +253 -0
- package/dist/templates/trellis/scripts/common/project_paths.py +189 -0
- package/dist/templates/trellis/scripts/common/registry.py +365 -0
- package/dist/templates/trellis/scripts/common/task_queue.py +255 -0
- package/dist/templates/trellis/scripts/common/task_utils.py +177 -0
- package/dist/templates/trellis/scripts/common/worktree.py +218 -0
- package/dist/templates/trellis/scripts/create_bootstrap.py +290 -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/handoff_generator.py +380 -0
- package/dist/templates/trellis/scripts/init_developer.py +51 -0
- package/dist/templates/trellis/scripts/multi_agent/__init__.py +5 -0
- package/dist/templates/trellis/scripts/multi_agent/cleanup.py +403 -0
- package/dist/templates/trellis/scripts/multi_agent/create_pr.py +329 -0
- package/dist/templates/trellis/scripts/multi_agent/plan.py +233 -0
- package/dist/templates/trellis/scripts/multi_agent/start.py +461 -0
- package/dist/templates/trellis/scripts/multi_agent/status.py +817 -0
- package/dist/templates/trellis/scripts/pool.py +373 -0
- package/dist/templates/trellis/scripts/task.py +1162 -0
- package/dist/templates/trellis/scripts-shell-archive/add-session.sh +384 -0
- package/dist/templates/trellis/scripts-shell-archive/common/developer.sh +129 -0
- package/dist/templates/trellis/scripts-shell-archive/common/git-context.sh +263 -0
- package/dist/templates/trellis/scripts-shell-archive/common/paths.sh +208 -0
- package/dist/templates/trellis/scripts-shell-archive/common/phase.sh +150 -0
- package/dist/templates/trellis/scripts-shell-archive/common/registry.sh +247 -0
- package/dist/templates/trellis/scripts-shell-archive/common/task-queue.sh +142 -0
- package/dist/templates/trellis/scripts-shell-archive/common/task-utils.sh +151 -0
- package/dist/templates/trellis/scripts-shell-archive/common/worktree.sh +128 -0
- package/dist/templates/trellis/scripts-shell-archive/create-bootstrap.sh +299 -0
- package/dist/templates/trellis/scripts-shell-archive/get-context.sh +7 -0
- package/dist/templates/trellis/scripts-shell-archive/get-developer.sh +15 -0
- package/dist/templates/trellis/scripts-shell-archive/init-developer.sh +34 -0
- package/dist/templates/trellis/scripts-shell-archive/multi-agent/cleanup.sh +396 -0
- package/dist/templates/trellis/scripts-shell-archive/multi-agent/create-pr.sh +241 -0
- package/dist/templates/trellis/scripts-shell-archive/multi-agent/plan.sh +207 -0
- package/dist/templates/trellis/scripts-shell-archive/multi-agent/start.sh +317 -0
- package/dist/templates/trellis/scripts-shell-archive/multi-agent/status.sh +828 -0
- package/dist/templates/trellis/scripts-shell-archive/task.sh +1204 -0
- package/dist/templates/trellis/spec/roles/designer/index.md +243 -0
- package/dist/templates/trellis/spec/roles/designer/mock-data-standards.md +481 -0
- package/dist/templates/trellis/spec/roles/designer/prototype-guidelines.md +429 -0
- package/dist/templates/trellis/spec/roles/frontend-impl/api-integration.md +565 -0
- package/dist/templates/trellis/spec/roles/frontend-impl/index.md +321 -0
- package/dist/templates/trellis/spec/roles/frontend-impl/state-management.md +599 -0
- package/dist/templates/trellis/spec/roles/pm/index.md +112 -0
- package/dist/templates/trellis/spec/roles/pm/prd-template.md +124 -0
- package/dist/templates/trellis/tasks/.gitkeep +0 -0
- package/dist/templates/trellis/workflow.md +416 -0
- package/dist/templates/trellis/worktree.yaml +47 -0
- package/dist/types/ai-tools.d.ts +56 -0
- package/dist/types/ai-tools.d.ts.map +1 -0
- package/dist/types/ai-tools.js +103 -0
- package/dist/types/ai-tools.js.map +1 -0
- package/dist/types/migration.d.ts +86 -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 +76 -0
- package/dist/utils/compare-versions.js.map +1 -0
- package/dist/utils/file-writer.d.ts +23 -0
- package/dist/utils/file-writer.d.ts.map +1 -0
- package/dist/utils/file-writer.js +140 -0
- package/dist/utils/file-writer.js.map +1 -0
- package/dist/utils/project-detector.d.ts +16 -0
- package/dist/utils/project-detector.d.ts.map +1 -0
- package/dist/utils/project-detector.js +186 -0
- package/dist/utils/project-detector.js.map +1 -0
- package/dist/utils/template-fetcher.d.ts +51 -0
- package/dist/utils/template-fetcher.d.ts.map +1 -0
- package/dist/utils/template-fetcher.js +174 -0
- package/dist/utils/template-fetcher.js.map +1 -0
- package/dist/utils/template-hash.d.ts +78 -0
- package/dist/utils/template-hash.d.ts.map +1 -0
- package/dist/utils/template-hash.js +233 -0
- package/dist/utils/template-hash.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1,338 @@
|
|
|
1
|
+
# Start Session
|
|
2
|
+
|
|
3
|
+
Initialize your AI development session and begin working on tasks.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Operation Types
|
|
8
|
+
|
|
9
|
+
| Marker | Meaning | Executor |
|
|
10
|
+
|--------|---------|----------|
|
|
11
|
+
| `[AI]` | Bash scripts or Task calls executed by AI | You (AI) |
|
|
12
|
+
| `[USER]` | Slash commands executed by user | User |
|
|
13
|
+
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
## Initialization `[AI]`
|
|
17
|
+
|
|
18
|
+
### Step 1: Understand Development Workflow
|
|
19
|
+
|
|
20
|
+
First, read the workflow guide to understand the development process:
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
cat .trellis/workflow.md
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
**Follow the instructions in workflow.md** - it contains:
|
|
27
|
+
- Core principles (Read Before Write, Follow Standards, etc.)
|
|
28
|
+
- File system structure
|
|
29
|
+
- Development process
|
|
30
|
+
- Best practices
|
|
31
|
+
|
|
32
|
+
### Step 2: Get Current Context
|
|
33
|
+
|
|
34
|
+
```bash
|
|
35
|
+
python3 ./.trellis/scripts/get_context.py
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
This shows: developer identity, git status, current task (if any), active tasks.
|
|
39
|
+
|
|
40
|
+
### Step 3: Read Guidelines Index
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
cat .trellis/spec/frontend/index.md # Frontend guidelines
|
|
44
|
+
cat .trellis/spec/backend/index.md # Backend guidelines
|
|
45
|
+
cat .trellis/spec/guides/index.md # Thinking guides
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
### Step 4: Report and Ask
|
|
49
|
+
|
|
50
|
+
Report what you learned and ask: "What would you like to work on?"
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
## Task Classification
|
|
55
|
+
|
|
56
|
+
When user describes a task, classify it:
|
|
57
|
+
|
|
58
|
+
| Type | Criteria | Workflow |
|
|
59
|
+
|------|----------|----------|
|
|
60
|
+
| **Question** | User asks about code, architecture, or how something works | Answer directly |
|
|
61
|
+
| **Trivial Fix** | Typo fix, comment update, single-line change, < 5 minutes | Direct Edit |
|
|
62
|
+
| **Simple Task** | Clear goal, 1-2 files, well-defined scope | Quick confirm → Task Workflow |
|
|
63
|
+
| **Complex Task** | Vague goal, multiple files, architectural decisions | **Brainstorm → Task Workflow** |
|
|
64
|
+
|
|
65
|
+
### Decision Rule
|
|
66
|
+
|
|
67
|
+
> **If in doubt, use Brainstorm + Task Workflow.**
|
|
68
|
+
>
|
|
69
|
+
> Task Workflow ensures code-spec context is injected to agents, resulting in higher quality code.
|
|
70
|
+
> The overhead is minimal, but the benefit is significant.
|
|
71
|
+
|
|
72
|
+
---
|
|
73
|
+
|
|
74
|
+
## Question / Trivial Fix
|
|
75
|
+
|
|
76
|
+
For questions or trivial fixes, work directly:
|
|
77
|
+
|
|
78
|
+
1. Answer question or make the fix
|
|
79
|
+
2. If code was changed, remind user to run `/trellis:finish-work`
|
|
80
|
+
|
|
81
|
+
---
|
|
82
|
+
|
|
83
|
+
## Complex Task - Brainstorm First
|
|
84
|
+
|
|
85
|
+
For complex or vague tasks, use the brainstorm process to clarify requirements.
|
|
86
|
+
|
|
87
|
+
See `/trellis:brainstorm` for the full process. Summary:
|
|
88
|
+
|
|
89
|
+
1. **Acknowledge and classify** - State your understanding
|
|
90
|
+
2. **Create task directory** - Track evolving requirements in `prd.md`
|
|
91
|
+
3. **Ask questions one at a time** - Update PRD after each answer
|
|
92
|
+
4. **Propose approaches** - For architectural decisions
|
|
93
|
+
5. **Confirm final requirements** - Get explicit approval
|
|
94
|
+
6. **Proceed to Task Workflow** - With clear requirements in PRD
|
|
95
|
+
|
|
96
|
+
---
|
|
97
|
+
|
|
98
|
+
## Task Workflow (Development Tasks)
|
|
99
|
+
|
|
100
|
+
**Why this workflow?**
|
|
101
|
+
- Research Agent analyzes what code-spec files are needed
|
|
102
|
+
- Code-spec files are configured in jsonl files
|
|
103
|
+
- Implement Agent receives code-spec context via Hook injection
|
|
104
|
+
- Check Agent verifies against code-spec requirements
|
|
105
|
+
- Result: Code that follows project conventions automatically
|
|
106
|
+
|
|
107
|
+
### Overview: Two Entry Points
|
|
108
|
+
|
|
109
|
+
```
|
|
110
|
+
From Brainstorm (Complex Task):
|
|
111
|
+
PRD confirmed → Research → Configure Context → Activate → Implement → Check → Complete
|
|
112
|
+
|
|
113
|
+
From Simple Task:
|
|
114
|
+
Confirm → Create Task → Write PRD → Research → Configure Context → Activate → Implement → Check → Complete
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
**Key principle: Research happens AFTER requirements are clear (PRD exists).**
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
### Phase 1: Establish Requirements
|
|
122
|
+
|
|
123
|
+
#### Path A: From Brainstorm (skip to Phase 2)
|
|
124
|
+
|
|
125
|
+
PRD and task directory already exist from brainstorm. Skip directly to Phase 2.
|
|
126
|
+
|
|
127
|
+
#### Path B: From Simple Task
|
|
128
|
+
|
|
129
|
+
**Step 1: Confirm Understanding** `[AI]`
|
|
130
|
+
|
|
131
|
+
Quick confirm:
|
|
132
|
+
- What is the goal?
|
|
133
|
+
- What type of development? (frontend / backend / fullstack)
|
|
134
|
+
- Any specific requirements or constraints?
|
|
135
|
+
|
|
136
|
+
**Step 2: Create Task Directory** `[AI]`
|
|
137
|
+
|
|
138
|
+
```bash
|
|
139
|
+
TASK_DIR=$(python3 ./.trellis/scripts/task.py create "<title>" --slug <name>)
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
**Step 3: Write PRD** `[AI]`
|
|
143
|
+
|
|
144
|
+
Create `prd.md` in the task directory with:
|
|
145
|
+
|
|
146
|
+
```markdown
|
|
147
|
+
# <Task Title>
|
|
148
|
+
|
|
149
|
+
## Goal
|
|
150
|
+
<What we're trying to achieve>
|
|
151
|
+
|
|
152
|
+
## Requirements
|
|
153
|
+
- <Requirement 1>
|
|
154
|
+
- <Requirement 2>
|
|
155
|
+
|
|
156
|
+
## Acceptance Criteria
|
|
157
|
+
- [ ] <Criterion 1>
|
|
158
|
+
- [ ] <Criterion 2>
|
|
159
|
+
|
|
160
|
+
## Technical Notes
|
|
161
|
+
<Any technical decisions or constraints>
|
|
162
|
+
```
|
|
163
|
+
|
|
164
|
+
---
|
|
165
|
+
|
|
166
|
+
### Phase 2: Prepare for Implementation (shared)
|
|
167
|
+
|
|
168
|
+
> Both paths converge here. PRD and task directory must exist before proceeding.
|
|
169
|
+
|
|
170
|
+
**Step 4: Code-Spec Depth Check** `[AI]`
|
|
171
|
+
|
|
172
|
+
If the task touches infra or cross-layer contracts, do not start implementation until code-spec depth is defined.
|
|
173
|
+
|
|
174
|
+
Trigger this requirement when the change includes any of:
|
|
175
|
+
- New or changed command/API signatures
|
|
176
|
+
- Database schema or migration changes
|
|
177
|
+
- Infra integrations (storage, queue, cache, secrets, env contracts)
|
|
178
|
+
- Cross-layer payload transformations
|
|
179
|
+
|
|
180
|
+
Must-have before proceeding:
|
|
181
|
+
- [ ] Target code-spec files to update are identified
|
|
182
|
+
- [ ] Concrete contract is defined (signature, fields, env keys)
|
|
183
|
+
- [ ] Validation and error matrix is defined
|
|
184
|
+
- [ ] At least one Good/Base/Bad case is defined
|
|
185
|
+
|
|
186
|
+
**Step 5: Research the Codebase** `[AI]`
|
|
187
|
+
|
|
188
|
+
Based on the confirmed PRD, call Research Agent to find relevant specs and patterns:
|
|
189
|
+
|
|
190
|
+
```
|
|
191
|
+
Task(
|
|
192
|
+
subagent_type: "research",
|
|
193
|
+
prompt: "Analyze the codebase for this task:
|
|
194
|
+
|
|
195
|
+
Task: <goal from PRD>
|
|
196
|
+
Type: <frontend/backend/fullstack>
|
|
197
|
+
|
|
198
|
+
Please find:
|
|
199
|
+
1. Relevant code-spec files in .trellis/spec/
|
|
200
|
+
2. Existing code patterns to follow (find 2-3 examples)
|
|
201
|
+
3. Files that will likely need modification
|
|
202
|
+
|
|
203
|
+
Output:
|
|
204
|
+
## Relevant Code-Specs
|
|
205
|
+
- <path>: <why it's relevant>
|
|
206
|
+
|
|
207
|
+
## Code Patterns Found
|
|
208
|
+
- <pattern>: <example file path>
|
|
209
|
+
|
|
210
|
+
## Files to Modify
|
|
211
|
+
- <path>: <what change>",
|
|
212
|
+
model: "opus"
|
|
213
|
+
)
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
**Step 6: Configure Context** `[AI]`
|
|
217
|
+
|
|
218
|
+
Initialize default context:
|
|
219
|
+
|
|
220
|
+
```bash
|
|
221
|
+
python3 ./.trellis/scripts/task.py init-context "$TASK_DIR" <type>
|
|
222
|
+
# type: backend | frontend | fullstack
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
Add code-spec files found by Research Agent:
|
|
226
|
+
|
|
227
|
+
```bash
|
|
228
|
+
# For each relevant code-spec and code pattern:
|
|
229
|
+
python3 ./.trellis/scripts/task.py add-context "$TASK_DIR" implement "<path>" "<reason>"
|
|
230
|
+
python3 ./.trellis/scripts/task.py add-context "$TASK_DIR" check "<path>" "<reason>"
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
**Step 7: Activate Task** `[AI]`
|
|
234
|
+
|
|
235
|
+
```bash
|
|
236
|
+
python3 ./.trellis/scripts/task.py start "$TASK_DIR"
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
This sets `.current-task` so hooks can inject context.
|
|
240
|
+
|
|
241
|
+
---
|
|
242
|
+
|
|
243
|
+
### Phase 3: Execute (shared)
|
|
244
|
+
|
|
245
|
+
**Step 8: Implement** `[AI]`
|
|
246
|
+
|
|
247
|
+
Call Implement Agent (code-spec context is auto-injected by hook):
|
|
248
|
+
|
|
249
|
+
```
|
|
250
|
+
Task(
|
|
251
|
+
subagent_type: "implement",
|
|
252
|
+
prompt: "Implement the task described in prd.md.
|
|
253
|
+
|
|
254
|
+
Follow all code-spec files that have been injected into your context.
|
|
255
|
+
Run lint and typecheck before finishing.",
|
|
256
|
+
model: "opus"
|
|
257
|
+
)
|
|
258
|
+
```
|
|
259
|
+
|
|
260
|
+
**Step 9: Check Quality** `[AI]`
|
|
261
|
+
|
|
262
|
+
Call Check Agent (code-spec context is auto-injected by hook):
|
|
263
|
+
|
|
264
|
+
```
|
|
265
|
+
Task(
|
|
266
|
+
subagent_type: "check",
|
|
267
|
+
prompt: "Review all code changes against the code-spec requirements.
|
|
268
|
+
|
|
269
|
+
Fix any issues you find directly.
|
|
270
|
+
Ensure lint and typecheck pass.",
|
|
271
|
+
model: "opus"
|
|
272
|
+
)
|
|
273
|
+
```
|
|
274
|
+
|
|
275
|
+
**Step 10: Complete** `[AI]`
|
|
276
|
+
|
|
277
|
+
1. Verify lint and typecheck pass
|
|
278
|
+
2. Report what was implemented
|
|
279
|
+
3. Remind user to:
|
|
280
|
+
- Test the changes
|
|
281
|
+
- Commit when ready
|
|
282
|
+
- Run `/trellis:record-session` to record this session
|
|
283
|
+
|
|
284
|
+
---
|
|
285
|
+
|
|
286
|
+
## Continuing Existing Task
|
|
287
|
+
|
|
288
|
+
If `get_context.py` shows a current task:
|
|
289
|
+
|
|
290
|
+
1. Read the task's `prd.md` to understand the goal
|
|
291
|
+
2. Check `task.json` for current status and phase
|
|
292
|
+
3. Ask user: "Continue working on <task-name>?"
|
|
293
|
+
|
|
294
|
+
If yes, resume from the appropriate step (usually Step 7 or 8).
|
|
295
|
+
|
|
296
|
+
---
|
|
297
|
+
|
|
298
|
+
## Commands Reference
|
|
299
|
+
|
|
300
|
+
### User Commands `[USER]`
|
|
301
|
+
|
|
302
|
+
| Command | When to Use |
|
|
303
|
+
|---------|-------------|
|
|
304
|
+
| `/trellis:start` | Begin a session (this command) |
|
|
305
|
+
| `/trellis:brainstorm` | Clarify vague requirements (called from start) |
|
|
306
|
+
| `/trellis:parallel` | Complex tasks needing isolated worktree |
|
|
307
|
+
| `/trellis:finish-work` | Before committing changes |
|
|
308
|
+
| `/trellis:record-session` | After completing a task |
|
|
309
|
+
|
|
310
|
+
### AI Scripts `[AI]`
|
|
311
|
+
|
|
312
|
+
| Script | Purpose |
|
|
313
|
+
|--------|---------|
|
|
314
|
+
| `python3 ./.trellis/scripts/get_context.py` | Get session context |
|
|
315
|
+
| `python3 ./.trellis/scripts/task.py create` | Create task directory |
|
|
316
|
+
| `python3 ./.trellis/scripts/task.py init-context` | Initialize jsonl files |
|
|
317
|
+
| `python3 ./.trellis/scripts/task.py add-context` | Add code-spec/context file to jsonl |
|
|
318
|
+
| `python3 ./.trellis/scripts/task.py start` | Set current task |
|
|
319
|
+
| `python3 ./.trellis/scripts/task.py finish` | Clear current task |
|
|
320
|
+
| `python3 ./.trellis/scripts/task.py archive` | Archive completed task |
|
|
321
|
+
|
|
322
|
+
### Sub Agents `[AI]`
|
|
323
|
+
|
|
324
|
+
| Agent | Purpose | Hook Injection |
|
|
325
|
+
|-------|---------|----------------|
|
|
326
|
+
| research | Analyze codebase | No (reads directly) |
|
|
327
|
+
| implement | Write code | Yes (implement.jsonl) |
|
|
328
|
+
| check | Review & fix | Yes (check.jsonl) |
|
|
329
|
+
| debug | Fix specific issues | Yes (debug.jsonl) |
|
|
330
|
+
|
|
331
|
+
---
|
|
332
|
+
|
|
333
|
+
## Key Principle
|
|
334
|
+
|
|
335
|
+
> **Code-spec context is injected, not remembered.**
|
|
336
|
+
>
|
|
337
|
+
> The Task Workflow ensures agents receive relevant code-spec context automatically.
|
|
338
|
+
> This is more reliable than hoping the AI "remembers" conventions.
|
|
@@ -0,0 +1,354 @@
|
|
|
1
|
+
# Update Code-Spec - Capture Executable Contracts
|
|
2
|
+
|
|
3
|
+
When you learn something valuable (from debugging, implementing, or discussion), use this command 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 template download with giget | Relevant `backend/` or `frontend/` file |
|
|
44
|
+
| **Made a design decision** | Used type field + mapping table for extensibility | Relevant code-spec + "Design Decisions" section |
|
|
45
|
+
| **Fixed a bug** | Found a subtle issue with error handling | `backend/error-handling.md` |
|
|
46
|
+
| **Discovered a pattern** | Found a better way to structure code | Relevant `backend/` or `frontend/` file |
|
|
47
|
+
| **Hit a gotcha** | Learned that X must be done before Y | Relevant code-spec + "Common Mistakes" section |
|
|
48
|
+
| **Established a convention** | Team agreed on naming pattern | `quality-guidelines.md` |
|
|
49
|
+
| **New thinking trigger** | "Don't forget to check X before doing Y" | `guides/*.md` (as a checklist item, not detailed rules) |
|
|
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
|
+
├── backend/ # Backend coding standards
|
|
60
|
+
│ ├── index.md # Overview and links
|
|
61
|
+
│ └── *.md # Topic-specific guidelines
|
|
62
|
+
├── frontend/ # Frontend coding standards
|
|
63
|
+
│ ├── index.md # Overview and links
|
|
64
|
+
│ └── *.md # Topic-specific guidelines
|
|
65
|
+
└── guides/ # Thinking checklists (NOT coding specs!)
|
|
66
|
+
├── index.md # Guide index
|
|
67
|
+
└── *.md # Topic-specific guides
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### CRITICAL: Code-Spec vs Guide - Know the Difference
|
|
71
|
+
|
|
72
|
+
| Type | Location | Purpose | Content Style |
|
|
73
|
+
|------|----------|---------|---------------|
|
|
74
|
+
| **Code-Spec** | `backend/*.md`, `frontend/*.md` | Tell AI "how to implement safely" | Signatures, contracts, matrices, cases, test points |
|
|
75
|
+
| **Guide** | `guides/*.md` | Help AI "what to think about" | Checklists, questions, pointers to specs |
|
|
76
|
+
|
|
77
|
+
**Decision Rule**: Ask yourself:
|
|
78
|
+
|
|
79
|
+
- "This is **how to write** the code" → Put in `backend/` or `frontend/`
|
|
80
|
+
- "This is **what to consider** before writing" → Put in `guides/`
|
|
81
|
+
|
|
82
|
+
**Example**:
|
|
83
|
+
|
|
84
|
+
| Learning | Wrong Location | Correct Location |
|
|
85
|
+
|----------|----------------|------------------|
|
|
86
|
+
| "Use `reconfigure()` not `TextIOWrapper` for Windows stdout" | ❌ `guides/cross-platform-thinking-guide.md` | ✅ `backend/script-conventions.md` |
|
|
87
|
+
| "Remember to check encoding when writing cross-platform code" | ❌ `backend/script-conventions.md` | ✅ `guides/cross-platform-thinking-guide.md` |
|
|
88
|
+
|
|
89
|
+
**Guides should be short checklists that point to specs**, not duplicate the detailed rules.
|
|
90
|
+
|
|
91
|
+
---
|
|
92
|
+
|
|
93
|
+
## Update Process
|
|
94
|
+
|
|
95
|
+
### Step 1: Identify What You Learned
|
|
96
|
+
|
|
97
|
+
Answer these questions:
|
|
98
|
+
|
|
99
|
+
1. **What did you learn?** (Be specific)
|
|
100
|
+
2. **Why is it important?** (What problem does it prevent?)
|
|
101
|
+
3. **Where does it belong?** (Which spec file?)
|
|
102
|
+
|
|
103
|
+
### Step 2: Classify the Update Type
|
|
104
|
+
|
|
105
|
+
| Type | Description | Action |
|
|
106
|
+
|------|-------------|--------|
|
|
107
|
+
| **Design Decision** | Why we chose approach X over Y | Add to "Design Decisions" section |
|
|
108
|
+
| **Project Convention** | How we do X in this project | Add to relevant section with examples |
|
|
109
|
+
| **New Pattern** | A reusable approach discovered | Add to "Patterns" section |
|
|
110
|
+
| **Forbidden Pattern** | Something that causes problems | Add to "Anti-patterns" or "Don't" section |
|
|
111
|
+
| **Common Mistake** | Easy-to-make error | Add to "Common Mistakes" section |
|
|
112
|
+
| **Convention** | Agreed-upon standard | Add to relevant section |
|
|
113
|
+
| **Gotcha** | Non-obvious behavior | Add warning callout |
|
|
114
|
+
|
|
115
|
+
### Step 3: Read the Target Code-Spec
|
|
116
|
+
|
|
117
|
+
Before editing, read the current code-spec to:
|
|
118
|
+
- Understand existing structure
|
|
119
|
+
- Avoid duplicating content
|
|
120
|
+
- Find the right section for your update
|
|
121
|
+
|
|
122
|
+
```bash
|
|
123
|
+
cat .trellis/spec/<category>/<file>.md
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### Step 4: Make the Update
|
|
127
|
+
|
|
128
|
+
Follow these principles:
|
|
129
|
+
|
|
130
|
+
1. **Be Specific**: Include concrete examples, not just abstract rules
|
|
131
|
+
2. **Explain Why**: State the problem this prevents
|
|
132
|
+
3. **Show Contracts**: Add signatures, payload fields, and error behavior
|
|
133
|
+
4. **Show Code**: Add code snippets for key patterns
|
|
134
|
+
5. **Keep it Short**: One concept per section
|
|
135
|
+
|
|
136
|
+
### Step 5: Update the Index (if needed)
|
|
137
|
+
|
|
138
|
+
If you added a new section or the code-spec status changed, update the category's `index.md`.
|
|
139
|
+
|
|
140
|
+
---
|
|
141
|
+
|
|
142
|
+
## Update Templates
|
|
143
|
+
|
|
144
|
+
### Mandatory Template for Infra/Cross-Layer Work
|
|
145
|
+
|
|
146
|
+
```markdown
|
|
147
|
+
## Scenario: <name>
|
|
148
|
+
|
|
149
|
+
### 1. Scope / Trigger
|
|
150
|
+
- Trigger: <why this requires code-spec depth>
|
|
151
|
+
|
|
152
|
+
### 2. Signatures
|
|
153
|
+
- Backend command/API/DB signature(s)
|
|
154
|
+
|
|
155
|
+
### 3. Contracts
|
|
156
|
+
- Request fields (name, type, constraints)
|
|
157
|
+
- Response fields (name, type, constraints)
|
|
158
|
+
- Environment keys (required/optional)
|
|
159
|
+
|
|
160
|
+
### 4. Validation & Error Matrix
|
|
161
|
+
- <condition> -> <error>
|
|
162
|
+
|
|
163
|
+
### 5. Good/Base/Bad Cases
|
|
164
|
+
- Good: ...
|
|
165
|
+
- Base: ...
|
|
166
|
+
- Bad: ...
|
|
167
|
+
|
|
168
|
+
### 6. Tests Required
|
|
169
|
+
- Unit/Integration/E2E with assertion points
|
|
170
|
+
|
|
171
|
+
### 7. Wrong vs Correct
|
|
172
|
+
#### Wrong
|
|
173
|
+
...
|
|
174
|
+
#### Correct
|
|
175
|
+
...
|
|
176
|
+
```
|
|
177
|
+
|
|
178
|
+
### Adding a Design Decision
|
|
179
|
+
|
|
180
|
+
```markdown
|
|
181
|
+
### Design Decision: [Decision Name]
|
|
182
|
+
|
|
183
|
+
**Context**: What problem were we solving?
|
|
184
|
+
|
|
185
|
+
**Options Considered**:
|
|
186
|
+
1. Option A - brief description
|
|
187
|
+
2. Option B - brief description
|
|
188
|
+
|
|
189
|
+
**Decision**: We chose Option X because...
|
|
190
|
+
|
|
191
|
+
**Example**:
|
|
192
|
+
\`\`\`typescript
|
|
193
|
+
// How it's implemented
|
|
194
|
+
code example
|
|
195
|
+
\`\`\`
|
|
196
|
+
|
|
197
|
+
**Extensibility**: How to extend this in the future...
|
|
198
|
+
```
|
|
199
|
+
|
|
200
|
+
### Adding a Project Convention
|
|
201
|
+
|
|
202
|
+
```markdown
|
|
203
|
+
### Convention: [Convention Name]
|
|
204
|
+
|
|
205
|
+
**What**: Brief description of the convention.
|
|
206
|
+
|
|
207
|
+
**Why**: Why we do it this way in this project.
|
|
208
|
+
|
|
209
|
+
**Example**:
|
|
210
|
+
\`\`\`typescript
|
|
211
|
+
// How to follow this convention
|
|
212
|
+
code example
|
|
213
|
+
\`\`\`
|
|
214
|
+
|
|
215
|
+
**Related**: Links to related conventions or specs.
|
|
216
|
+
```
|
|
217
|
+
|
|
218
|
+
### Adding a New Pattern
|
|
219
|
+
|
|
220
|
+
```markdown
|
|
221
|
+
### Pattern Name
|
|
222
|
+
|
|
223
|
+
**Problem**: What problem does this solve?
|
|
224
|
+
|
|
225
|
+
**Solution**: Brief description of the approach.
|
|
226
|
+
|
|
227
|
+
**Example**:
|
|
228
|
+
\`\`\`
|
|
229
|
+
// Good
|
|
230
|
+
code example
|
|
231
|
+
|
|
232
|
+
// Bad
|
|
233
|
+
code example
|
|
234
|
+
\`\`\`
|
|
235
|
+
|
|
236
|
+
**Why**: Explanation of why this works better.
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
### Adding a Forbidden Pattern
|
|
240
|
+
|
|
241
|
+
```markdown
|
|
242
|
+
### Don't: Pattern Name
|
|
243
|
+
|
|
244
|
+
**Problem**:
|
|
245
|
+
\`\`\`
|
|
246
|
+
// Don't do this
|
|
247
|
+
bad code example
|
|
248
|
+
\`\`\`
|
|
249
|
+
|
|
250
|
+
**Why it's bad**: Explanation of the issue.
|
|
251
|
+
|
|
252
|
+
**Instead**:
|
|
253
|
+
\`\`\`
|
|
254
|
+
// Do this instead
|
|
255
|
+
good code example
|
|
256
|
+
\`\`\`
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
### Adding a Common Mistake
|
|
260
|
+
|
|
261
|
+
```markdown
|
|
262
|
+
### Common Mistake: Description
|
|
263
|
+
|
|
264
|
+
**Symptom**: What goes wrong
|
|
265
|
+
|
|
266
|
+
**Cause**: Why this happens
|
|
267
|
+
|
|
268
|
+
**Fix**: How to correct it
|
|
269
|
+
|
|
270
|
+
**Prevention**: How to avoid it in the future
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
### Adding a Gotcha
|
|
274
|
+
|
|
275
|
+
```markdown
|
|
276
|
+
> **Warning**: Brief description of the non-obvious behavior.
|
|
277
|
+
>
|
|
278
|
+
> Details about when this happens and how to handle it.
|
|
279
|
+
```
|
|
280
|
+
|
|
281
|
+
---
|
|
282
|
+
|
|
283
|
+
## Interactive Mode
|
|
284
|
+
|
|
285
|
+
If you're unsure what to update, answer these prompts:
|
|
286
|
+
|
|
287
|
+
1. **What did you just finish?**
|
|
288
|
+
- [ ] Fixed a bug
|
|
289
|
+
- [ ] Implemented a feature
|
|
290
|
+
- [ ] Refactored code
|
|
291
|
+
- [ ] Had a discussion about approach
|
|
292
|
+
|
|
293
|
+
2. **What did you learn or decide?**
|
|
294
|
+
- Design decision (why X over Y)
|
|
295
|
+
- Project convention (how we do X)
|
|
296
|
+
- Non-obvious behavior (gotcha)
|
|
297
|
+
- Better approach (pattern)
|
|
298
|
+
|
|
299
|
+
3. **Would future AI/developers need to know this?**
|
|
300
|
+
- To understand how the code works → Yes, update spec
|
|
301
|
+
- To maintain or extend the feature → Yes, update spec
|
|
302
|
+
- To avoid repeating mistakes → Yes, update spec
|
|
303
|
+
- Purely one-off implementation detail → Maybe skip
|
|
304
|
+
|
|
305
|
+
4. **Which area does it relate to?**
|
|
306
|
+
- [ ] Backend code
|
|
307
|
+
- [ ] Frontend code
|
|
308
|
+
- [ ] Cross-layer data flow
|
|
309
|
+
- [ ] Code organization/reuse
|
|
310
|
+
- [ ] Quality/testing
|
|
311
|
+
|
|
312
|
+
---
|
|
313
|
+
|
|
314
|
+
## Quality Checklist
|
|
315
|
+
|
|
316
|
+
Before finishing your code-spec update:
|
|
317
|
+
|
|
318
|
+
- [ ] Is the content specific and actionable?
|
|
319
|
+
- [ ] Did you include a code example?
|
|
320
|
+
- [ ] Did you explain WHY, not just WHAT?
|
|
321
|
+
- [ ] Did you include executable signatures/contracts?
|
|
322
|
+
- [ ] Did you include validation and error matrix?
|
|
323
|
+
- [ ] Did you include Good/Base/Bad cases?
|
|
324
|
+
- [ ] Did you include required tests with assertion points?
|
|
325
|
+
- [ ] Is it in the right code-spec file?
|
|
326
|
+
- [ ] Does it duplicate existing content?
|
|
327
|
+
- [ ] Would a new team member understand it?
|
|
328
|
+
|
|
329
|
+
---
|
|
330
|
+
|
|
331
|
+
## Relationship to Other Commands
|
|
332
|
+
|
|
333
|
+
```
|
|
334
|
+
Development Flow:
|
|
335
|
+
Learn something → /trellis:update-spec → Knowledge captured
|
|
336
|
+
↑ ↓
|
|
337
|
+
/trellis:break-loop ←──────────────────── Future sessions benefit
|
|
338
|
+
(deep bug analysis)
|
|
339
|
+
```
|
|
340
|
+
|
|
341
|
+
- `/trellis:break-loop` - Analyzes bugs deeply, often reveals spec updates needed
|
|
342
|
+
- `/trellis:update-spec` - Actually makes the updates (this command)
|
|
343
|
+
- `/trellis:finish-work` - Reminds you to check if specs need updates
|
|
344
|
+
|
|
345
|
+
---
|
|
346
|
+
|
|
347
|
+
## Core Philosophy
|
|
348
|
+
|
|
349
|
+
> **Code-specs are living documents. Every debugging session, every "aha moment" is an opportunity to make the implementation contract clearer.**
|
|
350
|
+
|
|
351
|
+
The goal is **institutional memory**:
|
|
352
|
+
- What one person learns, everyone benefits from
|
|
353
|
+
- What AI learns in one session, persists to future sessions
|
|
354
|
+
- Mistakes become documented guardrails
|