8.9 KiB
Documentation Index
Fetch the complete documentation index at: https://vineetagarwal-code-claude-code.mintlify.app/llms.txt Use this file to discover all available pages before exploring further.
Agent & Task Tools
Spawn sub-agents for complex tasks and track work with a structured todo list.
Claude Code has two meta-tools for managing complex, multi-step work: Task (also called the Agent tool) for launching autonomous sub-agents, and TodoWrite for maintaining a structured task list within a session.
Task (Agent tool)
Launches a specialized sub-agent to handle a complex task autonomously. The sub-agent runs independently, uses its own set of tools, and returns a single result message when it finishes.
Parameters
The full task description for the agent. Since sub-agents start with no knowledge of the parent conversation, the prompt must be self-contained — include relevant file paths, line numbers, context, and any constraints. Terse command-style prompts produce shallow results. A short (3–5 word) label describing what the agent will do. Shown in the UI. The type of specialized agent to use (e.g., `"code-reviewer"`, `"test-runner"`). When omitted, the general-purpose agent is used. Available agent types are listed in the system prompt. Optional model override: `"sonnet"`, `"opus"`, or `"haiku"`. Takes precedence over the agent definition's configured model. Omit to inherit from the agent definition or parent. When `true`, the agent runs in the background. Claude is notified when it completes and should not poll or sleep while waiting. Use background mode when you have genuinely independent work to continue in the meantime. Isolation mode for the agent's filesystem context:"worktree"— agent runs in a temporary git worktree (isolated copy of the repo). The worktree is cleaned up automatically if the agent makes no changes; otherwise the path and branch are returned.
How sub-agents work
Each agent invocation starts with zero conversation context. The agent:
- Receives its own system prompt and the
promptyou provide - Has access to a tool set defined by its
subagent_type(or all tools for the general-purpose agent) - Runs autonomously until the task is complete
- Returns a single result message back to the parent
The result is not shown directly to the user — Claude summarizes it in a follow-up message.
Never write "based on your findings, fix the bug" or similar delegation phrases. Prompts that push synthesis back onto the agent produce generic work. Include concrete file paths, line numbers, and specific instructions in the prompt.When to use the Task tool
* Open-ended research that requires multiple rounds of searching and reading * Running a test suite and analyzing failures after code changes * Independent code review by a fresh agent with no prior context bias * Long-running operations that can proceed while Claude handles other requests * Tasks that would generate noisy intermediate output you don't need in the main context * Reading a specific file — use the `Read` tool directly * Searching for a class definition — use `Grep` directly * Searching within 2–3 known files — use `Read` directly * Simple tasks unrelated to the available agent typesParallel agents
When tasks are independent, Claude launches multiple agents in a single message:
Task({ description: "Run tests", prompt: "Run the full test suite..." })
Task({ description: "Check types", prompt: "Run tsc --noEmit and report errors..." })
Both agents run concurrently. When both complete, Claude synthesizes the results.
Resuming agents
To send a follow-up message to a running or completed agent, use SendMessage with the agent's name as the to field. The agent resumes with its full context preserved.
Writing effective prompts
The agent knows nothing about your session. Treat the prompt like a complete briefing for a smart colleague who just arrived:- What you're trying to accomplish and why
- What you've already tried or ruled out
- The specific files, functions, or systems involved
- What form the result should take ("report in under 200 words", "make the fix directly", etc.)
TodoWrite
Maintains a structured task list for the current session. Claude uses this tool proactively to track progress, organize multi-step work, and provide visibility into what it is doing.
Parameters
The complete, updated todo list. Each call **replaces** the entire list — there is no incremental add or remove.TodoItem schema
Each item in the todos array has the following fields:
| Value | Meaning |
|---|---|
pending |
Not yet started |
in_progress |
Currently being worked on |
completed |
Finished successfully |
Exactly one task should be in_progress at any time.
How Claude uses TodoWrite
Claude calls TodoWrite proactively when:
- A task requires 3 or more distinct steps
- Work is non-trivial and benefits from structured tracking
- The user provides a list of multiple things to do
- New sub-tasks are discovered mid-implementation
Claude does not use TodoWrite for:
- Single-step tasks
- Trivial operations (e.g., adding a comment, running one command)
- Purely informational or conversational responses
Task lifecycle
Claude marks a task `in_progress` **before** beginning, not after. This ensures the UI reflects what is actively happening.{ "content": "Add dark mode toggle", "activeForm": "Adding dark mode toggle", "status": "in_progress" }
- Implementation is fully done
- No tests are failing
- No unresolved errors remain
Example list
{
"todos": [
{
"content": "Add dark mode CSS variables",
"activeForm": "Adding dark mode CSS variables",
"status": "completed"
},
{
"content": "Implement theme context provider",
"activeForm": "Implementing theme context provider",
"status": "in_progress"
},
{
"content": "Update existing components to use theme",
"activeForm": "Updating existing components to use theme",
"status": "pending"
},
{
"content": "Run tests and build",
"activeForm": "Running tests and build",
"status": "pending"
}
]
}
Built with Mintlify.