Mulai dari TypeScript Agent SDK 0.3.142 dan Claude Code v2.1.142, sesi menggunakan alat Task terstruktur
TaskCreate, TaskUpdate, TaskGet, dan TaskList sebagai pengganti TodoWrite. Lihat Migrasi ke alat Task untuk cara memantau perubahan kode. Contoh di halaman ini menetapkan CLAUDE_CODE_ENABLE_TASKS=0 untuk terus menampilkan TodoWrite untuk sesi yang belum bermigrasi.Siklus Hidup Todo
Todos mengikuti siklus hidup yang dapat diprediksi:- Dibuat sebagai
pendingketika tugas diidentifikasi - Diaktifkan menjadi
in_progressketika pekerjaan dimulai - Diselesaikan ketika tugas selesai dengan sukses
- Dihapus ketika semua tugas dalam grup selesai
Kapan Todos Digunakan
SDK secara otomatis membuat todos untuk:- Tugas multi-langkah yang kompleks memerlukan 3 atau lebih tindakan yang berbeda
- Daftar tugas yang disediakan pengguna ketika beberapa item disebutkan
- Operasi non-trivial yang mendapat manfaat dari pelacakan kemajuan
- Permintaan eksplisit ketika pengguna meminta organisasi todo
Contoh
Memantau Perubahan Todo
Tampilan Kemajuan Real-time
Migrasi ke alat Task
Alat Task membagi panggilanTodoWrite tunggal menjadi TaskCreate untuk setiap item baru dan TaskUpdate untuk setiap perubahan status, dengan TaskList dan TaskGet tersedia untuk model membaca kembali daftar saat ini. Kode pemantauan Anda masih memeriksa blok tool_use dalam aliran asisten, tetapi mempertahankan peta yang dikunci berdasarkan ID tugas alih-alih mengganti seluruh daftar pada setiap panggilan. Alat Task adalah default mulai dari TypeScript Agent SDK 0.3.142 dan Claude Code v2.1.142, jadi tidak ada perubahan options.env yang diperlukan.
Dengan TodoWrite | Dengan alat Task |
|---|---|
Satu panggilan alat menulis ulang array todos lengkap | TaskCreate menambahkan satu item, TaskUpdate menambal satu item berdasarkan taskId |
Cocokkan block.name === "TodoWrite" | Cocokkan block.name === "TaskCreate" atau "TaskUpdate" |
Bentuk item: { content, status, activeForm } | Input TaskCreate: { subject, description, activeForm?, metadata? }. Input TaskUpdate: { taskId, status?, subject?, description?, activeForm?, addBlocks?, addBlockedBy?, owner?, metadata? }. status adalah "pending", "in_progress", atau "completed"; atur status: "deleted" untuk menghapus |
Render block.input.todos secara langsung | Akumulasi item di seluruh panggilan, atau baca snapshot dari hasil alat TaskList |
TaskCreate. Ini kembali dalam tool_result yang cocok sebagai { task: { id, subject } }, jadi tangkap dari blok hasil untuk mengunci peta Anda. Contoh berikut menunjukkan perubahan minimal ke loop Memantau Perubahan Todo. Untuk merender daftar lengkap, pantau hasil alat TaskList dalam aliran atau akumulasi hasil TaskCreate dan input TaskUpdate ke dalam peta: