Orchestrating
Claude Code Swarm Orchestration
Section titled “Claude Code Swarm Orchestration”Master multi-agent orchestration using Claude Code’s agent teams and task system.
Experimental: Agent teams are disabled by default. Enable with
CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMSin your settings.json or environment.
Primitives
Section titled “Primitives”| Primitive | What It Is | File Location |
|---|---|---|
| Agent | A Claude instance that can use tools. You are an agent. Subagents are agents you spawn. | N/A (process) |
| Team | A named group of agents working together. One leader, multiple teammates. | ~/.claude/teams/{name}/config.json |
| Teammate | An agent that joined a team. Has a name, color, inbox. Spawned via Task with team_name + name. | Listed in team config |
| Leader | The agent that created the team. Receives teammate messages, approves plans/shutdowns. | First member in config |
| Task | A work item with subject, description, status, owner, and dependencies. | ~/.claude/tasks/{team}/N.json |
| Inbox | JSON file where an agent receives messages from teammates. | ~/.claude/teams/{name}/inboxes/{agent}.json |
| Message | A JSON object sent between agents. Can be text or structured (shutdown_request, idle_notification, etc). | Stored in inbox files |
| Backend | How teammates run. Auto-detected: in-process (same Node.js, invisible), tmux (separate panes, visible), iterm2 (split panes in iTerm2). See Spawn Backends. | Auto-detected based on environment |
How They Connect
Section titled “How They Connect”flowchart TB
subgraph TEAM[TEAM]
Leader[Leader - you]
T1[Teammate 1]
T2[Teammate 2]
Leader <-->|messages via inbox| T1
Leader <-->|messages via inbox| T2
T1 <-.->|can message| T2
end
subgraph TASKS[TASK LIST]
Task1["#1 completed: Research<br/>owner: teammate1"]
Task2["#2 in_progress: Implement<br/>owner: teammate2"]
Task3["#3 pending: Test<br/>blocked by #2"]
end
T1 --> Task1
T2 --> Task2
Task2 -.->|unblocks| Task3
Lifecycle
Section titled “Lifecycle”flowchart LR
A[1. Create Team] --> B[2. Create Tasks]
B --> C[3. Spawn Teammates]
C --> D[4. Work]
D --> E[5. Coordinate]
E --> F[6. Shutdown]
F --> G[7. Cleanup]
Message Flow
Section titled “Message Flow”sequenceDiagram
participant L as Leader
participant T1 as Teammate 1
participant T2 as Teammate 2
participant Tasks as Task List
L->>Tasks: TaskCreate (3 tasks)
L->>T1: spawn with prompt
L->>T2: spawn with prompt
T1->>Tasks: claim task #1
T2->>Tasks: claim task #2
T1->>Tasks: complete #1
T1->>L: SendMessage (findings)
Note over Tasks: #3 auto-unblocks
T2->>Tasks: complete #2
T2->>L: SendMessage (findings)
L->>T1: SendMessage (shutdown_request)
T1->>L: SendMessage (shutdown_response, approve)
L->>T2: SendMessage (shutdown_request)
T2->>L: SendMessage (shutdown_response, approve)
L->>L: TeamDelete
Sub-Skills Index
Section titled “Sub-Skills Index”| Skill | What It Covers |
|---|---|
| Team Management | Create teams, spawn teammates, delegate mode, permissions, shutdown, cleanup |
| Task System | TaskCreate, TaskList, TaskGet, TaskUpdate, dependencies, file locking |
| Agent Types | Built-in agents (Bash, Explore, Plan, general-purpose), plugin agents, selection guide |
| Messaging | SendMessage (all types), message formats, automatic delivery, direct interaction |
| Orchestration Patterns | 7 patterns (parallel, pipeline, swarm, research, plan approval, refactoring, RLM) |
| RLM Pattern | Content-aware chunked analysis of large files and directories using RLM pattern |
| Spawn Backends | in-process, tmux, iTerm2, teammateMode setting, auto-detection |
| Error Handling | Common errors, hooks (TeammateIdle, TaskCompleted), limitations, debugging |
Quick Reference
Section titled “Quick Reference”Create Team and Spawn Teammate
Section titled “Create Team and Spawn Teammate”TeamCreate({ team_name: "my-team", description: "Working on feature X" })Task({ team_name: "my-team", name: "worker", subagent_type: "general-purpose", prompt: "...", run_in_background: true })Spawn Subagent (No Team)
Section titled “Spawn Subagent (No Team)”Task({ subagent_type: "Explore", description: "Find files", prompt: "..." })Message Teammate
Section titled “Message Teammate”SendMessage({ type: "message", recipient: "worker-1", content: "...", summary: "Brief update" })Create Task Pipeline
Section titled “Create Task Pipeline”TaskCreate({ subject: "Step 1", description: "...", activeForm: "Working on step 1..." })TaskCreate({ subject: "Step 2", description: "...", activeForm: "Working on step 2..." })TaskUpdate({ taskId: "2", addBlockedBy: ["1"] })Shutdown Team
Section titled “Shutdown Team”SendMessage({ type: "shutdown_request", recipient: "worker-1", content: "All done" })// Wait for approval...TeamDelete()Based on Claude Code agent teams documentation - Updated 2026-02-07