todo_write
Create and manage structured task lists for coding sessions to organize multi-step tasks, track progress, and ensure thoroughness in completing complex projects.
Instructions
Use this tool to create and manage a structured task list for your current coding session. This helps you track progress, organize complex tasks, and demonstrate thoroughness to the user. It also helps the user understand the progress of the task and overall progress of their requests.
When to Use This Tool
Use this tool proactively in these scenarios:
Complex multi-step tasks - When a task requires 3 or more distinct steps or actions
Non-trivial and complex tasks - Tasks that require careful planning or multiple operations
User explicitly requests todo list - When the user directly asks you to use the todo list
User provides multiple tasks - When users provide a list of things to be done (numbered or comma-separated)
After receiving new instructions - Immediately capture user requirements as todos. Feel free to edit the todo list based on new information.
After completing a task - Mark it complete and add any new follow-up tasks
When you start working on a new task, mark the todo as in_progress. Ideally you should only have one todo as in_progress at a time. Complete existing tasks before starting new ones.
When NOT to Use This Tool
Skip using this tool when:
There is only a single, straightforward task
The task is trivial and tracking it provides no organizational benefit
The task can be completed in less than 3 trivial steps
The task is purely conversational or informational
NOTE that you should use should not use this tool if there is only one trivial task to do. In this case you are better off just doing the task directly.
Examples of When to Use the Todo List
Examples of When NOT to Use the Todo List
python print("Hello World")
This will output the text "Hello World" to the console when executed.
Executes: npm install
The command completed successfully. Here's the output: [Output of npm install command]
All dependencies have been installed according to your package.json file.
Task States and Management
Task States: Use these states to track progress:
pending: Task not yet started
in_progress: Currently working on (limit to ONE task at a time)
completed: Task finished successfully
cancelled: Task no longer needed
Task Management:
Update task status in real-time as you work
Mark tasks complete IMMEDIATELY after finishing (don't batch completions)
Only have ONE task in_progress at any time
Complete current tasks before starting new ones
Cancel tasks that become irrelevant
Task Breakdown:
Create specific, actionable items
Break complex tasks into smaller, manageable steps
Use clear, descriptive task names
When in doubt, use this tool. Being proactive with task management demonstrates attentiveness and ensures you complete all requirements successfully.
Input Schema
Name | Required | Description | Default |
---|---|---|---|
session_id | Yes | Unique identifier for the Claude Desktop session (generate using timestamp command) | |
todos | Yes | The complete todo list to store for this session |