( taskListId: string, taskId: string, updates: Partial<Omit<Task, 'id'>>, )
| 352 | // Internal: no lock. Callers already holding a lock on taskPath must use this |
| 353 | // to avoid deadlock (claimTask, deleteTask cascade, etc.). |
| 354 | async function updateTaskUnsafe( |
| 355 | taskListId: string, |
| 356 | taskId: string, |
| 357 | updates: Partial<Omit<Task, 'id'>>, |
| 358 | ): Promise<Task | null> { |
| 359 | const existing = await getTask(taskListId, taskId) |
| 360 | if (!existing) { |
| 361 | return null |
| 362 | } |
| 363 | const updated: Task = { ...existing, ...updates, id: taskId } |
| 364 | const path = getTaskPath(taskListId, taskId) |
| 365 | await writeFile(path, jsonStringify(updated, null, 2)) |
| 366 | notifyTasksUpdated() |
| 367 | return updated |
| 368 | } |
| 369 | |
| 370 | export async function updateTask( |
| 371 | taskListId: string, |
no test coverage detected