- add plan-orchestrate skill from closed PR #1603 - add Longhand MCP config from closed PR #1503 - sync catalog counts to 54 agents, 207 skills, 70 commands
18 KiB
name, description, origin
| name | description | origin |
|---|---|---|
| plan-orchestrate | Read a plan document, decompose it into steps, design a per-step agent chain from the ECC catalogue, and emit ready-to-paste /orchestrate custom prompts. Generative only — never invokes /orchestrate itself. Use when the user has a multi-step plan and wants to drive it through orchestrate without composing chains by hand. | ECC |
Plan Orchestrate
Bridge a plan document to /orchestrate custom by emitting one ready-to-paste invocation per step. The skill is generative only — it never executes /orchestrate. The user pastes each line when ready.
When to Activate
- User has a multi-step plan document (PRD, RFC, implementation plan) and wants to drive it through
/orchestrate. - User says "orchestrate this plan", "give me orchestrate prompts for each step", "compose chains for this plan".
- A step-by-step plan exists but the user does not want to manually pick agents per step.
Skip when:
- The work is one ad-hoc step → call
/orchestrate customdirectly. - The plan is unreadable or empty. Lack of explicit numbering alone is not a skip condition — see the "No clear steps" edge case below.
Inputs
<plan-doc-path> [--lang=python|typescript|go|rust|cpp|java|kotlin|flutter|auto] [--scope=all|step:<n>|range:<a>-<b>] [--dry-run]
<plan-doc-path>— required; relative or absolute path (@docs/...accepted).--lang— reviewer language variant; defaults toauto(detected from project).--scope— limits emitted steps; defaults toall.--dry-run— print decomposition + chain rationale only; do not emit final prompts.
Authoritative /orchestrate shape (do not deviate)
{ORCH_CMD} custom "<agent1>,<agent2>,...,<agentN>" "<task description>"
Where {ORCH_CMD} is determined in Phase 0 (see below). The command string in the emitted output always uses one concrete form — never both, never a placeholder.
customis a sequential chain; each agent's HANDOFF feeds the next.- Comma-separated agent list. No spaces preferred; one space tolerated.
- No
--mode/--gate/--agents=...flags exist — never invent them. - Agent names come from the catalogue in this skill. Embedded double quotes in the task description are escaped as
\".
ECC install form and namespacing
Two install forms determine the prefix on both the slash command and every agent name. The two MUST stay in sync — one form per output, never mixed:
Let <claude-home> denote the Claude Code home directory: ~/.claude on macOS/Linux, %USERPROFILE%\.claude on Windows. Resolve it the way the host platform resolves the user home directory (do not hardcode ~).
| Form | Detection | {ORCH_CMD} |
Agent name format |
|---|---|---|---|
| Plugin install (1.9.0+) | <claude-home>/plugins/marketplaces/everything-claude-code/ exists |
/everything-claude-code:orchestrate |
everything-claude-code:<name> |
| Legacy bare install | Above absent; agent files under <claude-home>/agents/ |
/orchestrate |
<name> |
Why this matters: under the plugin install, agents register as everything-claude-code:tdd-guide. Bare names force fuzzy matching, which fails intermittently under parallel calls. Under legacy, the prefixed forms are not registered and fail outright.
Available agent catalogue (must pick from these)
General:
planner— requirement restatement, risk decomposition, step planningarchitect— architecture, system design, refactor proposalstdd-guide— write tests → implement → 80%+ coveragecode-reviewer— generic code reviewsecurity-reviewer— security audit, OWASP, secret leakagerefactor-cleaner— dead code, duplicates, knip-class cleanupdoc-updater— documentation, codemap, READMEdocs-lookup— third-party library API lookups (Context7)e2e-runner— end-to-end test orchestrationdatabase-reviewer— PostgreSQL schema, migration, performanceharness-optimizer— local agent harness configurationloop-operator— long-running autonomous loopschief-of-staff— multi-channel triage (rarely a fit for plan steps)
Build error resolvers:
build-error-resolver(generic) /cpp-build-resolver/go-build-resolver/java-build-resolver/kotlin-build-resolver/rust-build-resolver/pytorch-build-resolver
Code reviewers:
python-reviewer/typescript-reviewer/go-reviewer/rust-reviewer/cpp-reviewer/java-reviewer/kotlin-reviewer/flutter-reviewer
A misspelled agent name fails /orchestrate. Cross-check against this list before emitting.
How It Works
Phase 0 — Detect ECC mode + language
-
Read
<plan-doc-path>. If missing or empty, report and stop. -
Detect ECC install form once and freeze it into
ECC_MODE. Algorithm (run in order, stop at the first match):- If
<claude-home>/plugins/marketplaces/everything-claude-code/exists →ECC_MODE=plugin. - Else if
<claude-home>/agents/exists and contains at least one ECC agent file (e.g.tdd-guide.md,code-reviewer.md) →ECC_MODE=legacy. - Else → default to
ECC_MODE=legacyand emit a one-line warning at the top of the output:> Warning: could not detect ECC install; defaulting to legacy form. If you use the plugin install, edit the prefixes manually. - If both markers exist (mixed install),
pluginwins — the plugin namespace is the only one that resolves agent names without fuzzy matching.
From this point on, every emitted line uses the matching prefix on both the slash command and every agent name. Never emit both forms in the same output.
- If
-
Resolve
--lang. Whenauto, run a polyglot-aware detection:- Probe markers:
pyproject.toml/uv.lock/requirements.txt→ python;package.json→ typescript;go.mod→ go;Cargo.toml→ rust;CMakeLists.txtor top-level*.cpp→ cpp;pom.xml/build.gradle(Java) → java;build.gradle.ktsor top-level Kotlin → kotlin;pubspec.yaml→ flutter. - Polyglot tie-break: if more than one marker matches, pick the language whose source files outnumber the others (count via
git ls-files, excludingvendor/,node_modules/,dist/,build/,.venv/, generated files, and obvious test fixtures). On a tie or when no language exceeds 60% of source files, setlang=unknown. - No marker matched → set
lang=unknown. lang=unknownis a sentinel — it is not an agent name. Phase 2 rules 4 and 5 turn it intocode-reviewer/build-error-resolverat chain composition time.
- Probe markers:
-
Detect a PyTorch sub-profile: when
lang=pythonand any ofpyproject.toml/requirements.txt/uv.lockdeclares a dependency ontorch, setpytorch=true. This only affectsbuildchain selection (Phase 2 rule below); the reviewer remainspython-reviewer. -
Normalize any agent names declared in the plan: if the plan text references agents by their plugin-prefixed form (e.g.
everything-claude-code:tdd-guide), strip the prefix to get the bare catalogue name before validating or composing chains. Re-prefixing happens only at output time perECC_MODE(Phase 4). Never let a pre-prefixed name flow into chain composition — it would double-prefix in plugin mode.
Phase 1 — Decompose steps
Identify "step units" in priority order:
- Explicit numbering:
## Step N/### Phase N/## N. .../ top-level ordered list. - A "Step" column in a table.
----separated blocks with verb-led headings.- Otherwise treat each H2 as one step.
Per step extract id (1-based), title (≤ 80 chars), intent (1–3 sentences), tags.
Phase 2 — Tag and pick chain
Tag by intent (multi-tag allowed; chain built from primary + stacked secondaries):
Trigger words below are matched case-insensitively. Multilingual plans are supported by matching the word stems in any language as long as the meaning aligns with the listed English trigger words.
| Tag | Trigger words | Default chain |
|---|---|---|
design |
architecture, design, choose, evaluate, RFC | planner,architect |
plan |
plan, breakdown, milestone | planner |
impl |
implement, build, add, create, port | tdd-guide,<lang>-reviewer |
test |
test, coverage, e2e, integration | tdd-guide,e2e-runner |
refactor |
refactor, cleanup, dedupe, split | architect,refactor-cleaner,<lang>-reviewer |
migration |
migrate, upgrade, rewrite, port | architect,tdd-guide,<lang>-reviewer |
db |
schema, migration, index, SQL, Postgres, alembic, sqlmodel | database-reviewer,<lang>-reviewer |
security |
encrypt, auth, secret, OWASP, PII | security-reviewer,<lang>-reviewer |
build |
build, compile, lint failure, CI | <lang>-build-resolver (falls back to build-error-resolver) |
docs |
docs, readme, codemap, changelog | doc-updater |
lookup |
lookup, reference, API usage | docs-lookup |
review |
review, audit, verify | <lang>-reviewer,code-reviewer |
loop |
loop, autonomous, watchdog | loop-operator |
Chain composition rules:
- Primary tag selection: when a step matches multiple tags, the first one in table order (top of the table = highest priority) is the primary; the rest are secondaries. Composition rules 2 and 3 below handle specific multi-tag combinations explicitly; otherwise, append secondary chains in tag table order.
impl+security→tdd-guide,<lang>-reviewer,security-reviewer.impl+db→tdd-guide,database-reviewer,<lang>-reviewer.- Deduplicate the resulting chain (preserve first occurrence). E.g.
review+lang=unknownwould yieldcode-reviewer,code-reviewerafter rule 5; deduplication collapses it tocode-reviewer. <lang>-reviewerresolves tocode-reviewerwhenlang=unknown.<lang>-build-resolverresolves tobuild-error-resolverwhenlang=unknown. Special case: if Phase 0 setpytorch=true, usepytorch-build-resolverforbuildchains regardless of<lang>. There is nopython-build-resolver;--lang=pythonwithoutpytorch=trueresolves tobuild-error-resolver.- Zero-tag steps: if no trigger word matches, set chain to
code-reviewerand writeno tag matched; default review-only chainunder "Chain rationale". - Chain length ≤ 4 after deduplication. If exceeded, drop weakest tag (
lookupanddocsfirst). - Do not pair
plannerandarchitectin animplchain (token waste). Pair them only ondesignsteps. - Steps tagged
impl,refactor, ormigrationend with a reviewer-class agent — any of<lang>-reviewer,code-reviewer,security-reviewer, ordatabase-reviewer. The most domain-specific reviewer wins the tail position (e.g. rule 2'simpl+securityends withsecurity-reviewer; rule 3'simpl+dbends with<lang>-reviewerbecausedatabase-revieweralready gates the migration earlier in the chain).testandbuildsteps are gated by their own validators (e2e-runnerand the build resolver respectively) and do not require an additional reviewer.
Phase 3 — Compress task description
Each emitted <task description> must:
- Be self-contained (the first agent does not need the plan document open).
- Start with
[Plan: <path>#step-<id>]. - Include 1–3 verifiable Acceptance criteria.
- Include a Scope guard (
Out of scope: ...) only if the plan declares one for this step. Inherit verbatim. If the plan has no out-of-scope statement, omit the clause entirely — do not invent one. - Be 200–600 characters; one line; embedded
"escaped as\"; no literal newlines.
Phase 4 — Output
Emit Markdown using the form determined by ECC_MODE. The output uses one form throughout — every {ORCH_CMD} and every agent name is rendered with the matching prefix from Phase 0. Do not emit both forms; do not include "this is plugin form" / "strip the prefix" instructions in the rendered output.
Concrete rendering rules:
{ORCH_CMD}=/everything-claude-code:orchestrateunderplugin,/orchestrateunderlegacy.{AGENT(name)}=everything-claude-code:<name>underplugin,<name>underlegacy.- The overview-table "Chain" column uses the same
{AGENT(name)}rendering. - Per-step bash blocks contain only the runnable command. No
# plugin formor# legacy formcomments — the form is implicit and uniform across the whole output.
Output structure:
# Plan-Orchestrate Result
**Plan**: `<path>`
**Lang**: `<detected-or-given>`
**ECC mode**: `<plugin | legacy>`
**Steps**: <N>
**Scope**: <all | step:n | range:a-b>
## Steps overview
| # | Title | Tags | Chain |
|---|---|---|---|
| 1 | ... | impl, db | `{AGENT(tdd-guide)},{AGENT(database-reviewer)},{AGENT(python-reviewer)}` |
| ... | | | |
---
## Step 1 — <title>
**Intent**: <1–3 sentences>
**Tags**: <a, b>
**Chain rationale**: <why this chain; which agent closes the loop>
```bash
{ORCH_CMD} custom "{AGENT(tdd-guide)},{AGENT(database-reviewer)},{AGENT(python-reviewer)}" "[Plan: docs/foo.md#step-1] <compressed task description>; Acceptance: <1–3 items>; Out of scope: <…>"
```
The
{ORCH_CMD}and{AGENT(...)}notation above describes the substitution this skill performs at runtime. The actual emitted Markdown contains the resolved strings, never the placeholders.
Append a final "Batch execution" block aggregating every step's command in order so the user can paste them all at once. Skip the Batch block in overview-only mode (see "Large plan" edge case): when only the overview table is being emitted, there are no per-step commands to aggregate.
Phase 5 — Self-check (run before emitting)
- Every agent in every chain comes from the catalogue (after stripping any
everything-claude-code:prefix that appeared in the plan; see Phase 0 step 5). - Resolved
{ORCH_CMD}and every resolved{AGENT(...)}use the same form (pluginorlegacy) — never mixed in one output. - No
# plugin form/# legacy formannotations and no "strip the prefix" instructions remain in the rendered output. - No invented
--mode/--gate/--agents=...fields. - Each task description is single-line, double-quoted, with embedded
"escaped. - Each task description begins with
[Plan: <path>#step-<id>]and includes Acceptance (1–3 items). TheOut of scope:clause is present only when inherited from the plan. - No duplicate agent in any chain after Phase 2 dedup.
- Chain length ≤ 4.
- Steps tagged
impl/refactor/migrationend with a reviewer-class agent (<lang>-reviewer,code-reviewer,security-reviewer, ordatabase-reviewer).testandbuildare exempt — see Phase 2 rule 10. - Zero-tag steps emit
code-reviewerwith the rationaleno tag matched; default review-only chain. - Overview table lists every step in the plan, regardless of
--scope. - Per-step detail block count matches the resolved
--scope(full plan when--scope=all; one block forstep:n; range size forrange:a-b). In overview-only mode, no per-step blocks and no Batch block are emitted.
Edge cases
- No clear steps: prefer H2/H3 splitting; if still ambiguous, report "no structured steps detected" with the document outline and ask the user to confirm running by outline.
- Large plan (>1500 lines): enter overview-only mode — emit only the overview table and ask the user to narrow with
--scopebefore re-running for details. In this mode, skip per-step detail blocks and skip the Batch execution block. - Step too broad (e.g. "complete all backend work"): do not force a single chain. Suggest splitting into N.a and N.b and propose a split.
- Plan declares agents (rare): first strip any
everything-claude-code:prefix to get the bare catalogue name (Phase 0 step 5), then validate against the catalogue. Replace invalid agents and explain under "Chain rationale". The bare name is re-prefixed at output time perECC_MODE. - Polyglot project where
--lang=autocannot pick a winner: setlang=unknown; reviewer resolves tocode-reviewerand build resolver tobuild-error-resolver. Mention the fallback under "Chain rationale".
Examples
Example 1 — Plugin mode, Python plan
Input:
plan-orchestrate @docs/plan/example-feature.md --lang=python
Excerpt of expected output:
## Step 2 — Encrypt sensitive UserProfile fields
**Intent**: Introduce an `EncryptedString` SQLAlchemy type and AES-GCM encrypt `birth_datetime` / `location` before persistence; load the key from an environment variable.
**Tags**: impl, security, db
**Chain rationale**: Security-sensitive write path, so `security-reviewer` closes the chain; `database-reviewer` validates the alembic migration; `python-reviewer` covers typing and PEP 8.
```bash
/everything-claude-code:orchestrate custom "everything-claude-code:tdd-guide,everything-claude-code:database-reviewer,everything-claude-code:python-reviewer,everything-claude-code:security-reviewer" "[Plan: docs/plan/example-feature.md#step-2] Implement EncryptedString SQLAlchemy type and migrate UserProfile.birth_datetime/location columns; key from ENV APP_DB_KEY; Acceptance: encrypt/decrypt roundtrip tests pass; alembic upgrade/downgrade clean on empty DB; no plaintext in DB after migrate; Out of scope: cross-tenant profile sharing logic"
```
Example 2 — Legacy mode, same step
If ECC_MODE=legacy were detected, the same step would be emitted as a single uniform command (no plugin-prefixed forms anywhere in the output):
/orchestrate custom "tdd-guide,database-reviewer,python-reviewer,security-reviewer" "[Plan: docs/plan/example-feature.md#step-2] ..."
The two examples above illustrate the two possible outputs for two different environments. A single skill invocation produces only one of them, end to end.
Notes
- Generative only. Never invoke
/orchestratefrom inside this skill. - Match the language of the plan document for task descriptions (agent names always remain English).
- Do not insert "Co-Authored-By" lines or emoji in the output unless the user explicitly asks.