update shell output at an interval to reduce flicker (#614)

This commit is contained in:
Olcan
2025-05-30 00:02:30 -07:00
committed by GitHub
parent 2582c20e2a
commit b0aeeb53b1
4 changed files with 35 additions and 22 deletions

View File

@@ -288,11 +288,9 @@ export function useToolScheduler(
const callId = t.request.callId;
setToolCalls(setStatus(t.request.callId, 'executing'));
let accumulatedOutput = '';
const onOutputChunk =
const updateOutput =
t.tool.name === 'execute_bash_command'
? (chunk: string) => {
accumulatedOutput += chunk;
? (output: string) => {
setPendingHistoryItem(
(prevItem: HistoryItemWithoutId | null) => {
if (prevItem?.type === 'tool_group') {
@@ -304,7 +302,7 @@ export function useToolScheduler(
toolDisplay.status === ToolCallStatus.Executing
? {
...toolDisplay,
resultDisplay: accumulatedOutput,
resultDisplay: output,
}
: toolDisplay,
),
@@ -319,7 +317,7 @@ export function useToolScheduler(
setToolCalls((prevToolCalls) =>
prevToolCalls.map((tc) =>
tc.request.callId === callId && tc.status === 'executing'
? { ...tc, liveOutput: accumulatedOutput }
? { ...tc, liveOutput: output }
: tc,
),
);
@@ -327,7 +325,7 @@ export function useToolScheduler(
: undefined;
t.tool
.execute(t.request.args, signal, onOutputChunk)
.execute(t.request.args, signal, updateOutput)
.then((result: ToolResult) => {
if (signal.aborted) {
// TODO(jacobr): avoid stringifying the LLM content.