import { c as _c } from "react/compiler-runtime"; import React from 'react'; import { z } from 'zod/v4'; import { FallbackToolUseErrorMessage } from '../../components/FallbackToolUseErrorMessage.js'; import { FallbackToolUseRejectedMessage } from '../../components/FallbackToolUseRejectedMessage.js'; import { MessageResponse } from '../../components/MessageResponse.js'; import { Box, Text } from '../../ink.js'; import { useShortcutDisplay } from '../../keybindings/useShortcutDisplay.js'; import type { TaskType } from '../../Task.js'; import type { Tool } from '../../Tool.js'; import { buildTool, type ToolDef } from '../../Tool.js'; import type { LocalAgentTaskState } from '../../tasks/LocalAgentTask/LocalAgentTask.js'; import type { LocalShellTaskState } from '../../tasks/LocalShellTask/guards.js'; import type { RemoteAgentTaskState } from '../../tasks/RemoteAgentTask/RemoteAgentTask.js'; import type { TaskState } from '../../tasks/types.js'; import { AbortError } from '../../utils/errors.js'; import { lazySchema } from '../../utils/lazySchema.js'; import { extractTextContent } from '../../utils/messages.js'; import { semanticBoolean } from '../../utils/semanticBoolean.js'; import { sleep } from '../../utils/sleep.js'; import { jsonParse } from '../../utils/slowOperations.js'; import { countCharInString } from '../../utils/stringUtils.js'; import { getTaskOutput } from '../../utils/task/diskOutput.js'; import { updateTaskState } from '../../utils/task/framework.js'; import { formatTaskOutput } from '../../utils/task/outputFormatting.js'; import type { ThemeName } from '../../utils/theme.js'; import { AgentPromptDisplay, AgentResponseDisplay } from '../AgentTool/UI.js'; import BashToolResultMessage from '../BashTool/BashToolResultMessage.js'; import { TASK_OUTPUT_TOOL_NAME } from './constants.js'; const inputSchema = lazySchema(() => z.strictObject({ task_id: z.string().describe('The task ID to get output from'), block: semanticBoolean(z.boolean().default(true)).describe('Whether to wait for completion'), timeout: z.number().min(0).max(600000).default(30000).describe('Max wait time in ms') })); type InputSchema = ReturnType; type TaskOutputToolInput = z.infer; // Unified output type covering all task types type TaskOutput = { task_id: string; task_type: TaskType; status: string; description: string; output: string; exitCode?: number | null; error?: string; // For agents prompt?: string; result?: string; }; type TaskOutputToolOutput = { retrieval_status: 'success' | 'timeout' | 'not_ready'; task: TaskOutput | null; }; // Re-export Progress from centralized types to break import cycles export type { TaskOutputProgress as Progress } from '../../types/tools.js'; // Get output for any task type async function getTaskOutputData(task: TaskState): Promise { let output: string; if (task.type === 'local_bash') { const bashTask = task as LocalShellTaskState; const taskOutputObj = bashTask.shellCommand?.taskOutput; if (taskOutputObj) { const stdout = await taskOutputObj.getStdout(); const stderr = taskOutputObj.getStderr(); output = [stdout, stderr].filter(Boolean).join('\n'); } else { output = await getTaskOutput(task.id); } } else { output = await getTaskOutput(task.id); } const baseOutput: TaskOutput = { task_id: task.id, task_type: task.type, status: task.status, description: task.description, output }; // Add type-specific fields if (task.type === 'local_bash') { const bashTask = task as LocalShellTaskState; return { ...baseOutput, exitCode: bashTask.result?.code ?? null }; } if (task.type === 'local_agent') { const agentTask = task as LocalAgentTaskState; // Prefer the clean final answer from the in-memory result over the raw // JSONL transcript on disk. The disk output is a symlink to the full // session transcript (every message, tool use, etc.), not just the // subagent's answer. The in-memory result contains only the final // assistant text content blocks. const cleanResult = agentTask.result ? extractTextContent(agentTask.result.content, '\n') : undefined; return { ...baseOutput, prompt: agentTask.prompt, result: cleanResult || output, output: cleanResult || output, error: agentTask.error }; } if (task.type === 'remote_agent') { const remoteTask = task as RemoteAgentTaskState; return { ...baseOutput, prompt: remoteTask.command }; } return baseOutput; } // Wait for task to complete async function waitForTaskCompletion(taskId: string, getAppState: () => { tasks?: Record; }, timeoutMs: number, abortController?: AbortController): Promise { const startTime = Date.now(); while (Date.now() - startTime < timeoutMs) { // Check abort signal if (abortController?.signal.aborted) { throw new AbortError(); } const state = getAppState(); const task = state.tasks?.[taskId] as TaskState | undefined; if (!task) { return null; } if (task.status !== 'running' && task.status !== 'pending') { return task; } // Wait before polling again await sleep(100); } // Timeout - return current state const finalState = getAppState(); return finalState.tasks?.[taskId] as TaskState ?? null; } export const TaskOutputTool: Tool = buildTool({ name: TASK_OUTPUT_TOOL_NAME, searchHint: 'read output/logs from a background task', maxResultSizeChars: 100_000, shouldDefer: true, // Backwards-compatible aliases for renamed tools aliases: ['AgentOutputTool', 'BashOutputTool'], userFacingName() { return 'Task Output'; }, get inputSchema(): InputSchema { return inputSchema(); }, async description() { return '[Deprecated] — prefer Read on the task output file path'; }, isConcurrencySafe(_input) { return this.isReadOnly?.(_input) ?? false; }, isEnabled() { return "external" !== 'ant'; }, isReadOnly(_input) { return true; }, toAutoClassifierInput(input) { return input.task_id; }, async prompt() { return `DEPRECATED: Prefer using the Read tool on the task's output file path instead. Background tasks return their output file path in the tool result, and you receive a with the same path when the task completes — Read that file directly. - Retrieves output from a running or completed task (background shell, agent, or remote session) - Takes a task_id parameter identifying the task - Returns the task output along with status information - Use block=true (default) to wait for task completion - Use block=false for non-blocking check of current status - Task IDs can be found using the /tasks command - Works with all task types: background shells, async agents, and remote sessions`; }, async validateInput({ task_id }, { getAppState }) { if (!task_id) { return { result: false, message: 'Task ID is required', errorCode: 1 }; } const appState = getAppState(); const task = appState.tasks?.[task_id] as TaskState | undefined; if (!task) { return { result: false, message: `No task found with ID: ${task_id}`, errorCode: 2 }; } return { result: true }; }, async call(input: TaskOutputToolInput, toolUseContext, _canUseTool, _parentMessage, onProgress) { const { task_id, block, timeout } = input; const appState = toolUseContext.getAppState(); const task = appState.tasks?.[task_id] as TaskState | undefined; if (!task) { throw new Error(`No task found with ID: ${task_id}`); } if (!block) { // Non-blocking: return current state if (task.status !== 'running' && task.status !== 'pending') { // Mark as notified updateTaskState(task_id, toolUseContext.setAppState, t => ({ ...t, notified: true })); return { data: { retrieval_status: 'success' as const, task: await getTaskOutputData(task) } }; } return { data: { retrieval_status: 'not_ready' as const, task: await getTaskOutputData(task) } }; } // Blocking: wait for completion if (onProgress) { onProgress({ toolUseID: `task-output-waiting-${Date.now()}`, data: { type: 'waiting_for_task', taskDescription: task.description, taskType: task.type } }); } const completedTask = await waitForTaskCompletion(task_id, toolUseContext.getAppState, timeout, toolUseContext.abortController); if (!completedTask) { return { data: { retrieval_status: 'timeout' as const, task: null } }; } if (completedTask.status === 'running' || completedTask.status === 'pending') { return { data: { retrieval_status: 'timeout' as const, task: await getTaskOutputData(completedTask) } }; } // Mark as notified updateTaskState(task_id, toolUseContext.setAppState, t => ({ ...t, notified: true })); return { data: { retrieval_status: 'success' as const, task: await getTaskOutputData(completedTask) } }; }, mapToolResultToToolResultBlockParam(data, toolUseID) { const parts: string[] = []; parts.push(`${data.retrieval_status}`); if (data.task) { parts.push(`${data.task.task_id}`); parts.push(`${data.task.task_type}`); parts.push(`${data.task.status}`); if (data.task.exitCode !== undefined && data.task.exitCode !== null) { parts.push(`${data.task.exitCode}`); } if (data.task.output?.trim()) { const { content } = formatTaskOutput(data.task.output, data.task.task_id); parts.push(`\n${content.trimEnd()}\n`); } if (data.task.error) { parts.push(`${data.task.error}`); } } return { tool_use_id: toolUseID, type: 'tool_result' as const, content: parts.join('\n\n') }; }, renderToolUseMessage(input) { const { block = true } = input; if (!block) { return 'non-blocking'; } return ''; }, renderToolUseTag(input) { if (!input.task_id) { return null; } return {input.task_id}; }, renderToolUseProgressMessage(progressMessages) { const lastProgress = progressMessages[progressMessages.length - 1]; const progressData = lastProgress?.data as { taskDescription?: string; taskType?: string; } | undefined; return {progressData?.taskDescription &&   {progressData.taskDescription}}      Waiting for task{' '} (esc to give additional instructions) ; }, renderToolResultMessage(content, _, { verbose, theme }) { return ; }, renderToolUseRejectedMessage() { return ; }, renderToolUseErrorMessage(result, { verbose }) { return ; } } satisfies ToolDef); function TaskOutputResultDisplay(t0) { const $ = _c(54); const { content, verbose: t1, theme } = t0; const verbose = t1 === undefined ? false : t1; const expandShortcut = useShortcutDisplay("app:toggleTranscript", "Global", "ctrl+o"); let t2; if ($[0] !== content) { t2 = typeof content === "string" ? jsonParse(content) : content; $[0] = content; $[1] = t2; } else { t2 = $[1]; } const result = t2; if (!result.task) { let t3; if ($[2] === Symbol.for("react.memo_cache_sentinel")) { t3 = No task output available; $[2] = t3; } else { t3 = $[2]; } return t3; } const { task } = result; if (task.task_type === "local_bash") { let t3; if ($[3] !== task.error || $[4] !== task.output) { t3 = { stdout: task.output, stderr: "", isImage: false, dangerouslyDisableSandbox: true, returnCodeInterpretation: task.error }; $[3] = task.error; $[4] = task.output; $[5] = t3; } else { t3 = $[5]; } const bashOut = t3; let t4; if ($[6] !== bashOut || $[7] !== verbose) { t4 = ; $[6] = bashOut; $[7] = verbose; $[8] = t4; } else { t4 = $[8]; } return t4; } if (task.task_type === "local_agent") { const lineCount = task.result ? countCharInString(task.result, "\n") + 1 : 0; if (result.retrieval_status === "success") { if (verbose) { let t3; if ($[9] !== lineCount || $[10] !== task.description) { t3 = {task.description} ({lineCount} lines); $[9] = lineCount; $[10] = task.description; $[11] = t3; } else { t3 = $[11]; } let t4; if ($[12] !== task.prompt || $[13] !== theme) { t4 = task.prompt && ; $[12] = task.prompt; $[13] = theme; $[14] = t4; } else { t4 = $[14]; } let t5; if ($[15] !== task.result || $[16] !== theme) { t5 = task.result && ; $[15] = task.result; $[16] = theme; $[17] = t5; } else { t5 = $[17]; } let t6; if ($[18] !== task.error) { t6 = task.error && Error:{task.error}; $[18] = task.error; $[19] = t6; } else { t6 = $[19]; } let t7; if ($[20] !== t4 || $[21] !== t5 || $[22] !== t6) { t7 = {t4}{t5}{t6}; $[20] = t4; $[21] = t5; $[22] = t6; $[23] = t7; } else { t7 = $[23]; } let t8; if ($[24] !== t3 || $[25] !== t7) { t8 = {t3}{t7}; $[24] = t3; $[25] = t7; $[26] = t8; } else { t8 = $[26]; } return t8; } let t3; if ($[27] !== expandShortcut) { t3 = Read output ({expandShortcut} to expand); $[27] = expandShortcut; $[28] = t3; } else { t3 = $[28]; } return t3; } if (result.retrieval_status === "timeout" || task.status === "running") { let t3; if ($[29] === Symbol.for("react.memo_cache_sentinel")) { t3 = Task is still running…; $[29] = t3; } else { t3 = $[29]; } return t3; } if (result.retrieval_status === "not_ready") { let t3; if ($[30] === Symbol.for("react.memo_cache_sentinel")) { t3 = Task is still running…; $[30] = t3; } else { t3 = $[30]; } return t3; } let t3; if ($[31] === Symbol.for("react.memo_cache_sentinel")) { t3 = Task not ready; $[31] = t3; } else { t3 = $[31]; } return t3; } if (task.task_type === "remote_agent") { let t3; if ($[32] !== task.description || $[33] !== task.status) { t3 =   {task.description} [{task.status}]; $[32] = task.description; $[33] = task.status; $[34] = t3; } else { t3 = $[34]; } let t4; if ($[35] !== task.output || $[36] !== verbose) { t4 = task.output && verbose && {task.output}; $[35] = task.output; $[36] = verbose; $[37] = t4; } else { t4 = $[37]; } let t5; if ($[38] !== expandShortcut || $[39] !== task.output || $[40] !== verbose) { t5 = !verbose && task.output && {" "}({expandShortcut} to expand); $[38] = expandShortcut; $[39] = task.output; $[40] = verbose; $[41] = t5; } else { t5 = $[41]; } let t6; if ($[42] !== t3 || $[43] !== t4 || $[44] !== t5) { t6 = {t3}{t4}{t5}; $[42] = t3; $[43] = t4; $[44] = t5; $[45] = t6; } else { t6 = $[45]; } return t6; } let t3; if ($[46] !== task.description || $[47] !== task.status) { t3 =   {task.description} [{task.status}]; $[46] = task.description; $[47] = task.status; $[48] = t3; } else { t3 = $[48]; } let t4; if ($[49] !== task.output) { t4 = task.output && {task.output.slice(0, 500)}; $[49] = task.output; $[50] = t4; } else { t4 = $[50]; } let t5; if ($[51] !== t3 || $[52] !== t4) { t5 = {t3}{t4}; $[51] = t3; $[52] = t4; $[53] = t5; } else { t5 = $[53]; } return t5; } export default TaskOutputTool; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","z","FallbackToolUseErrorMessage","FallbackToolUseRejectedMessage","MessageResponse","Box","Text","useShortcutDisplay","TaskType","Tool","buildTool","ToolDef","LocalAgentTaskState","LocalShellTaskState","RemoteAgentTaskState","TaskState","AbortError","lazySchema","extractTextContent","semanticBoolean","sleep","jsonParse","countCharInString","getTaskOutput","updateTaskState","formatTaskOutput","ThemeName","AgentPromptDisplay","AgentResponseDisplay","BashToolResultMessage","TASK_OUTPUT_TOOL_NAME","inputSchema","strictObject","task_id","string","describe","block","boolean","default","timeout","number","min","max","InputSchema","ReturnType","TaskOutputToolInput","infer","TaskOutput","task_type","status","description","output","exitCode","error","prompt","result","TaskOutputToolOutput","retrieval_status","task","TaskOutputProgress","Progress","getTaskOutputData","Promise","type","bashTask","taskOutputObj","shellCommand","taskOutput","stdout","getStdout","stderr","getStderr","filter","Boolean","join","id","baseOutput","code","agentTask","cleanResult","content","undefined","remoteTask","command","waitForTaskCompletion","taskId","getAppState","tasks","Record","timeoutMs","abortController","AbortController","startTime","Date","now","signal","aborted","state","finalState","TaskOutputTool","name","searchHint","maxResultSizeChars","shouldDefer","aliases","userFacingName","isConcurrencySafe","_input","isReadOnly","isEnabled","toAutoClassifierInput","input","validateInput","message","errorCode","appState","call","toolUseContext","_canUseTool","_parentMessage","onProgress","Error","setAppState","t","notified","data","const","toolUseID","taskDescription","taskType","completedTask","mapToolResultToToolResultBlockParam","parts","push","trim","trimEnd","tool_use_id","renderToolUseMessage","renderToolUseTag","renderToolUseProgressMessage","progressMessages","lastProgress","length","progressData","renderToolResultMessage","_","verbose","theme","renderToolUseRejectedMessage","renderToolUseErrorMessage","TaskOutputResultDisplay","t0","$","_c","t1","expandShortcut","t2","t3","Symbol","for","isImage","dangerouslyDisableSandbox","returnCodeInterpretation","bashOut","t4","lineCount","t5","text","t6","t7","t8","slice"],"sources":["TaskOutputTool.tsx"],"sourcesContent":["import React from 'react'\nimport { z } from 'zod/v4'\nimport { FallbackToolUseErrorMessage } from '../../components/FallbackToolUseErrorMessage.js'\nimport { FallbackToolUseRejectedMessage } from '../../components/FallbackToolUseRejectedMessage.js'\nimport { MessageResponse } from '../../components/MessageResponse.js'\nimport { Box, Text } from '../../ink.js'\nimport { useShortcutDisplay } from '../../keybindings/useShortcutDisplay.js'\nimport type { TaskType } from '../../Task.js'\nimport type { Tool } from '../../Tool.js'\nimport { buildTool, type ToolDef } from '../../Tool.js'\nimport type { LocalAgentTaskState } from '../../tasks/LocalAgentTask/LocalAgentTask.js'\nimport type { LocalShellTaskState } from '../../tasks/LocalShellTask/guards.js'\nimport type { RemoteAgentTaskState } from '../../tasks/RemoteAgentTask/RemoteAgentTask.js'\nimport type { TaskState } from '../../tasks/types.js'\nimport { AbortError } from '../../utils/errors.js'\nimport { lazySchema } from '../../utils/lazySchema.js'\nimport { extractTextContent } from '../../utils/messages.js'\nimport { semanticBoolean } from '../../utils/semanticBoolean.js'\nimport { sleep } from '../../utils/sleep.js'\nimport { jsonParse } from '../../utils/slowOperations.js'\nimport { countCharInString } from '../../utils/stringUtils.js'\nimport { getTaskOutput } from '../../utils/task/diskOutput.js'\nimport { updateTaskState } from '../../utils/task/framework.js'\nimport { formatTaskOutput } from '../../utils/task/outputFormatting.js'\nimport type { ThemeName } from '../../utils/theme.js'\nimport { AgentPromptDisplay, AgentResponseDisplay } from '../AgentTool/UI.js'\nimport BashToolResultMessage from '../BashTool/BashToolResultMessage.js'\nimport { TASK_OUTPUT_TOOL_NAME } from './constants.js'\n\nconst inputSchema = lazySchema(() =>\n  z.strictObject({\n    task_id: z.string().describe('The task ID to get output from'),\n    block: semanticBoolean(z.boolean().default(true)).describe(\n      'Whether to wait for completion',\n    ),\n    timeout: z\n      .number()\n      .min(0)\n      .max(600000)\n      .default(30000)\n      .describe('Max wait time in ms'),\n  }),\n)\ntype InputSchema = ReturnType<typeof inputSchema>\n\ntype TaskOutputToolInput = z.infer<InputSchema>\n\n// Unified output type covering all task types\ntype TaskOutput = {\n  task_id: string\n  task_type: TaskType\n  status: string\n  description: string\n  output: string\n  exitCode?: number | null\n  error?: string\n  // For agents\n  prompt?: string\n  result?: string\n}\n\ntype TaskOutputToolOutput = {\n  retrieval_status: 'success' | 'timeout' | 'not_ready'\n  task: TaskOutput | null\n}\n\n// Re-export Progress from centralized types to break import cycles\nexport type { TaskOutputProgress as Progress } from '../../types/tools.js'\n\n// Get output for any task type\nasync function getTaskOutputData(task: TaskState): Promise<TaskOutput> {\n  let output: string\n  if (task.type === 'local_bash') {\n    const bashTask = task as LocalShellTaskState\n    const taskOutputObj = bashTask.shellCommand?.taskOutput\n    if (taskOutputObj) {\n      const stdout = await taskOutputObj.getStdout()\n      const stderr = taskOutputObj.getStderr()\n      output = [stdout, stderr].filter(Boolean).join('\\n')\n    } else {\n      output = await getTaskOutput(task.id)\n    }\n  } else {\n    output = await getTaskOutput(task.id)\n  }\n\n  const baseOutput: TaskOutput = {\n    task_id: task.id,\n    task_type: task.type,\n    status: task.status,\n    description: task.description,\n    output,\n  }\n\n  // Add type-specific fields\n  if (task.type === 'local_bash') {\n    const bashTask = task as LocalShellTaskState\n    return {\n      ...baseOutput,\n      exitCode: bashTask.result?.code ?? null,\n    }\n  }\n\n  if (task.type === 'local_agent') {\n    const agentTask = task as LocalAgentTaskState\n    // Prefer the clean final answer from the in-memory result over the raw\n    // JSONL transcript on disk. The disk output is a symlink to the full\n    // session transcript (every message, tool use, etc.), not just the\n    // subagent's answer. The in-memory result contains only the final\n    // assistant text content blocks.\n    const cleanResult = agentTask.result\n      ? extractTextContent(agentTask.result.content, '\\n')\n      : undefined\n    return {\n      ...baseOutput,\n      prompt: agentTask.prompt,\n      result: cleanResult || output,\n      output: cleanResult || output,\n      error: agentTask.error,\n    }\n  }\n\n  if (task.type === 'remote_agent') {\n    const remoteTask = task as RemoteAgentTaskState\n    return {\n      ...baseOutput,\n      prompt: remoteTask.command,\n    }\n  }\n\n  return baseOutput\n}\n\n// Wait for task to complete\nasync function waitForTaskCompletion(\n  taskId: string,\n  getAppState: () => { tasks?: Record<string, TaskState> },\n  timeoutMs: number,\n  abortController?: AbortController,\n): Promise<TaskState | null> {\n  const startTime = Date.now()\n\n  while (Date.now() - startTime < timeoutMs) {\n    // Check abort signal\n    if (abortController?.signal.aborted) {\n      throw new AbortError()\n    }\n\n    const state = getAppState()\n    const task = state.tasks?.[taskId] as TaskState | undefined\n\n    if (!task) {\n      return null\n    }\n\n    if (task.status !== 'running' && task.status !== 'pending') {\n      return task\n    }\n\n    // Wait before polling again\n    await sleep(100)\n  }\n\n  // Timeout - return current state\n  const finalState = getAppState()\n  return (finalState.tasks?.[taskId] as TaskState) ?? null\n}\n\nexport const TaskOutputTool: Tool<InputSchema, TaskOutputToolOutput> =\n  buildTool({\n    name: TASK_OUTPUT_TOOL_NAME,\n    searchHint: 'read output/logs from a background task',\n    maxResultSizeChars: 100_000,\n    shouldDefer: true,\n    // Backwards-compatible aliases for renamed tools\n    aliases: ['AgentOutputTool', 'BashOutputTool'],\n\n    userFacingName() {\n      return 'Task Output'\n    },\n\n    get inputSchema(): InputSchema {\n      return inputSchema()\n    },\n\n    async description() {\n      return '[Deprecated] — prefer Read on the task output file path'\n    },\n\n    isConcurrencySafe(_input) {\n      return this.isReadOnly?.(_input) ?? false\n    },\n\n    isEnabled() {\n      return \"external\" !== 'ant'\n    },\n\n    isReadOnly(_input) {\n      return true\n    },\n    toAutoClassifierInput(input) {\n      return input.task_id\n    },\n\n    async prompt() {\n      return `DEPRECATED: Prefer using the Read tool on the task's output file path instead. Background tasks return their output file path in the tool result, and you receive a <task-notification> with the same path when the task completes — Read that file directly.\n\n- Retrieves output from a running or completed task (background shell, agent, or remote session)\n- Takes a task_id parameter identifying the task\n- Returns the task output along with status information\n- Use block=true (default) to wait for task completion\n- Use block=false for non-blocking check of current status\n- Task IDs can be found using the /tasks command\n- Works with all task types: background shells, async agents, and remote sessions`\n    },\n\n    async validateInput({ task_id }, { getAppState }) {\n      if (!task_id) {\n        return {\n          result: false,\n          message: 'Task ID is required',\n          errorCode: 1,\n        }\n      }\n\n      const appState = getAppState()\n      const task = appState.tasks?.[task_id] as TaskState | undefined\n\n      if (!task) {\n        return {\n          result: false,\n          message: `No task found with ID: ${task_id}`,\n          errorCode: 2,\n        }\n      }\n\n      return { result: true }\n    },\n\n    async call(\n      input: TaskOutputToolInput,\n      toolUseContext,\n      _canUseTool,\n      _parentMessage,\n      onProgress,\n    ) {\n      const { task_id, block, timeout } = input\n\n      const appState = toolUseContext.getAppState()\n      const task = appState.tasks?.[task_id] as TaskState | undefined\n\n      if (!task) {\n        throw new Error(`No task found with ID: ${task_id}`)\n      }\n\n      if (!block) {\n        // Non-blocking: return current state\n        if (task.status !== 'running' && task.status !== 'pending') {\n          // Mark as notified\n          updateTaskState(task_id, toolUseContext.setAppState, t => ({\n            ...t,\n            notified: true,\n          }))\n          return {\n            data: {\n              retrieval_status: 'success' as const,\n              task: await getTaskOutputData(task),\n            },\n          }\n        }\n        return {\n          data: {\n            retrieval_status: 'not_ready' as const,\n            task: await getTaskOutputData(task),\n          },\n        }\n      }\n\n      // Blocking: wait for completion\n      if (onProgress) {\n        onProgress({\n          toolUseID: `task-output-waiting-${Date.now()}`,\n          data: {\n            type: 'waiting_for_task',\n            taskDescription: task.description,\n            taskType: task.type,\n          },\n        })\n      }\n\n      const completedTask = await waitForTaskCompletion(\n        task_id,\n        toolUseContext.getAppState,\n        timeout,\n        toolUseContext.abortController,\n      )\n\n      if (!completedTask) {\n        return {\n          data: {\n            retrieval_status: 'timeout' as const,\n            task: null,\n          },\n        }\n      }\n\n      if (\n        completedTask.status === 'running' ||\n        completedTask.status === 'pending'\n      ) {\n        return {\n          data: {\n            retrieval_status: 'timeout' as const,\n            task: await getTaskOutputData(completedTask),\n          },\n        }\n      }\n\n      // Mark as notified\n      updateTaskState(task_id, toolUseContext.setAppState, t => ({\n        ...t,\n        notified: true,\n      }))\n\n      return {\n        data: {\n          retrieval_status: 'success' as const,\n          task: await getTaskOutputData(completedTask),\n        },\n      }\n    },\n\n    mapToolResultToToolResultBlockParam(data, toolUseID) {\n      const parts: string[] = []\n\n      parts.push(\n        `<retrieval_status>${data.retrieval_status}</retrieval_status>`,\n      )\n\n      if (data.task) {\n        parts.push(`<task_id>${data.task.task_id}</task_id>`)\n        parts.push(`<task_type>${data.task.task_type}</task_type>`)\n        parts.push(`<status>${data.task.status}</status>`)\n\n        if (data.task.exitCode !== undefined && data.task.exitCode !== null) {\n          parts.push(`<exit_code>${data.task.exitCode}</exit_code>`)\n        }\n\n        if (data.task.output?.trim()) {\n          const { content } = formatTaskOutput(\n            data.task.output,\n            data.task.task_id,\n          )\n          parts.push(`<output>\\n${content.trimEnd()}\\n</output>`)\n        }\n\n        if (data.task.error) {\n          parts.push(`<error>${data.task.error}</error>`)\n        }\n      }\n\n      return {\n        tool_use_id: toolUseID,\n        type: 'tool_result' as const,\n        content: parts.join('\\n\\n'),\n      }\n    },\n\n    renderToolUseMessage(input) {\n      const { block = true } = input\n      if (!block) {\n        return 'non-blocking'\n      }\n      return ''\n    },\n\n    renderToolUseTag(input) {\n      if (!input.task_id) {\n        return null\n      }\n      return <Text dimColor> {input.task_id}</Text>\n    },\n\n    renderToolUseProgressMessage(progressMessages) {\n      const lastProgress = progressMessages[progressMessages.length - 1]\n      const progressData = lastProgress?.data as\n        | { taskDescription?: string; taskType?: string }\n        | undefined\n\n      return (\n        <Box flexDirection=\"column\">\n          {progressData?.taskDescription && (\n            <Text>&nbsp;&nbsp;{progressData.taskDescription}</Text>\n          )}\n          <Text>\n            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Waiting for task{' '}\n            <Text dimColor>(esc to give additional instructions)</Text>\n          </Text>\n        </Box>\n      )\n    },\n\n    renderToolResultMessage(content, _, { verbose, theme }) {\n      return (\n        <TaskOutputResultDisplay\n          content={content}\n          verbose={verbose}\n          theme={theme}\n        />\n      )\n    },\n\n    renderToolUseRejectedMessage() {\n      return <FallbackToolUseRejectedMessage />\n    },\n\n    renderToolUseErrorMessage(result, { verbose }) {\n      return <FallbackToolUseErrorMessage result={result} verbose={verbose} />\n    },\n  } satisfies ToolDef<InputSchema, TaskOutputToolOutput>)\n\nfunction TaskOutputResultDisplay({\n  content,\n  verbose = false,\n  theme,\n}: {\n  content: string | TaskOutputToolOutput\n  verbose?: boolean\n  theme: ThemeName\n}): React.ReactNode {\n  const expandShortcut = useShortcutDisplay(\n    'app:toggleTranscript',\n    'Global',\n    'ctrl+o',\n  )\n  const result: TaskOutputToolOutput =\n    typeof content === 'string' ? jsonParse(content) : content\n\n  if (!result.task) {\n    return (\n      <MessageResponse>\n        <Text dimColor>No task output available</Text>\n      </MessageResponse>\n    )\n  }\n\n  const { task } = result\n\n  // For shell tasks, render like BashToolResultMessage\n  if (task.task_type === 'local_bash') {\n    const bashOut = {\n      stdout: task.output,\n      stderr: '',\n      isImage: false,\n      dangerouslyDisableSandbox: true,\n      returnCodeInterpretation: task.error,\n    }\n    return <BashToolResultMessage content={bashOut} verbose={verbose} />\n  }\n\n  // For agent tasks, render with prompt/response display\n  if (task.task_type === 'local_agent') {\n    const lineCount = task.result ? countCharInString(task.result, '\\n') + 1 : 0\n\n    if (result.retrieval_status === 'success') {\n      if (verbose) {\n        return (\n          <Box flexDirection=\"column\">\n            <Text>\n              {task.description} ({lineCount} lines)\n            </Text>\n            <Box flexDirection=\"column\" paddingLeft={2} marginTop={1}>\n              {task.prompt && (\n                <AgentPromptDisplay prompt={task.prompt} theme={theme} dim />\n              )}\n              {task.result && (\n                <Box marginTop={1}>\n                  <AgentResponseDisplay\n                    content={[{ type: 'text', text: task.result }]}\n                    theme={theme}\n                  />\n                </Box>\n              )}\n              {task.error && (\n                <Box flexDirection=\"column\" marginTop={1}>\n                  <Text color=\"error\" bold>\n                    Error:\n                  </Text>\n                  <Box paddingLeft={2}>\n                    <Text color=\"error\">{task.error}</Text>\n                  </Box>\n                </Box>\n              )}\n            </Box>\n          </Box>\n        )\n      }\n      return (\n        <MessageResponse>\n          <Text dimColor>Read output ({expandShortcut} to expand)</Text>\n        </MessageResponse>\n      )\n    }\n\n    if (result.retrieval_status === 'timeout' || task.status === 'running') {\n      return (\n        <MessageResponse>\n          <Text dimColor>Task is still running…</Text>\n        </MessageResponse>\n      )\n    }\n\n    if (result.retrieval_status === 'not_ready') {\n      return (\n        <MessageResponse>\n          <Text dimColor>Task is still running…</Text>\n        </MessageResponse>\n      )\n    }\n\n    return (\n      <MessageResponse>\n        <Text dimColor>Task not ready</Text>\n      </MessageResponse>\n    )\n  }\n\n  // For remote agent tasks\n  if (task.task_type === 'remote_agent') {\n    return (\n      <Box flexDirection=\"column\">\n        <Text>\n          &nbsp;&nbsp;{task.description} [{task.status}]\n        </Text>\n        {task.output && verbose && (\n          <Box paddingLeft={4} marginTop={1}>\n            <Text>{task.output}</Text>\n          </Box>\n        )}\n        {!verbose && task.output && (\n          <Text dimColor>\n            {'     '}({expandShortcut} to expand)\n          </Text>\n        )}\n      </Box>\n    )\n  }\n\n  // Default rendering\n  return (\n    <Box flexDirection=\"column\">\n      <Text>\n        &nbsp;&nbsp;{task.description} [{task.status}]\n      </Text>\n      {task.output && (\n        <Box paddingLeft={4}>\n          <Text>{task.output.slice(0, 500)}</Text>\n        </Box>\n      )}\n    </Box>\n  )\n}\n\nexport default TaskOutputTool\n"],"mappings":"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","ignoreList":[]}