subtask
Parallel task orchestration CLI that dispatches work to AI workers (via Claude Code) in isolated git workspaces. Use when the user wants to draft, create, run, or manage tasks, delegate tasks to workers/subagents, or mentions subtask or Subtask.
git clone https://github.com/zippoxer/subtask
T=$(mktemp -d) && git clone --depth=1 https://github.com/zippoxer/subtask "$T" && mkdir -p ~/.claude/skills && cp -r "$T/pkg/install" ~/.claude/skills/zippoxer-subtask-subtask && rm -rf "$T"
pkg/install/SKILL.mdSubtask
Subtask is a CLI for orchestrating parallel AI workers. There are three roles: the user who gives direction, you (the lead) who orchestrates and delegates, and workers who execute tasks.
Each worker runs in an isolated git worktree. They can't conflict with each other.
The user tells you what they need. You clarify requirements, break work into tasks, dispatch to workers, review their output, iterate until it's right, and merge when ready.
Prefer to delegate exploration, research and planning to workers as parts of their tasks. Workers have time & space to dig deep, whereas you should preserve context to lead. Only go into details yourself when user explicitly requested, or the situation calls for it.
Mindset
- Understand before delegating — ask questions, clarify requirements. Don't rush to create tasks until you understand what the user actually wants.
- Own the complexity — stay on top of all tasks. Surface progress and blockers. Don't make the user chase status.
- Work autonomously — review output, request changes, iterate with workers. Only involve the user for decisions they need to make.
- Ask before merging — get user sign-off before merging. Don't merge without user approval.
Commands
| Command | Description |
|---|---|
| Quick question (no task, runs in cwd) |
| Create a task |
| Prompt worker on task (blocks until reply) |
| Advance workflow stage |
| View all tasks |
| View task details |
| Show changes (from merge base) |
| Squash-merge task into base branch |
| Close without merging, free workspace |
| Get workspace path (a git worktree) |
| Gracefully stop a running worker |
| Show task conversation and history |
| Debug what a worker is doing and thinking internally |
Tip: Add
--follow-up <task> on draft to carry forward conversation context from a prior task.
Flow
# 1. Draft (task name is branch name, task description is shared with worker) subtask draft fix/bug --base-branch main --title "Fix worker pool panic" <<'EOF' There's an intermittent panic in the worker pool under high concurrency—likely a race condition in pool.go. Reproduce, find root cause, fix, and add tests. EOF # 2. Start the worker subtask send fix/bug "Go ahead." # 3. When worker finishes, review and iterate subtask stage fix/bug review # Review with `subtask diff --stat fix/bug`, or read the files at `cd $(subtask workspace fix/bug)`. # 4. Request changes if needed subtask send fix/bug <<'EOF' Also handle the edge case when pool is empty. EOF # 5. When ready, merge or close subtask stage fix/bug ready subtask merge fix/bug -m "Fix race condition in worker pool" # Or if not merging: subtask close fix/bug
Critical: Use the Bash tool with
run_in_background: true for subtask send. Tell the user you're waiting and stop. Don't poll or check. You'll be notified when done.
Merging
subtask merge squashes all task commits into a single commit on the base branch.
subtask merge fix/bug -m "Fix race condition"
If conflicts occur, merge will fail with instructions. Follow them.
Stages
All tasks have stages:
doing → review → ready
| Stage | When to advance |
|---|---|
| Worker is working (default) |
| Worker done, you're reviewing code |
| Ready for human to decide (human review, merge, more work, etc.) |
Advance with:
subtask stage <task> <stage>
Planning Workflows
For complex tasks, add a plan stage:
plan → implement → review → ready
You plan (
): You draft PLAN.md in task folder, worker reviews and pokes holes.
They plan (--workflow you-plan
): Worker drafts PLAN.md in task folder, you review and approve or request changes.--workflow they-plan
Notes
- Use
to see what’s in flight.subtask list - Use
to see progress and details.subtask show <task> - Use
to see task conversation and events.subtask log <task> - Use
to debug what a worker is doing and thinking internally.subtask trace <task>