@patze/code-cli 0.20.0 → 0.24.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +54 -0
- package/VERSION +1 -1
- package/dist/backend/agent-trace.d.ts +4 -0
- package/dist/backend/agent-trace.d.ts.map +1 -1
- package/dist/backend/agent-trace.js +13 -0
- package/dist/backend/agent-trace.js.map +1 -1
- package/dist/backend/cancel-client.d.ts +19 -0
- package/dist/backend/cancel-client.d.ts.map +1 -0
- package/dist/backend/cancel-client.js +45 -0
- package/dist/backend/cancel-client.js.map +1 -0
- package/dist/backend/execute-client.d.ts +2 -0
- package/dist/backend/execute-client.d.ts.map +1 -1
- package/dist/backend/execute-client.js +2 -0
- package/dist/backend/execute-client.js.map +1 -1
- package/dist/backend/preview-payload.d.ts +6 -0
- package/dist/backend/preview-payload.d.ts.map +1 -1
- package/dist/backend/preview-payload.js +9 -0
- package/dist/backend/preview-payload.js.map +1 -1
- package/dist/backend/run-record.d.ts +2 -0
- package/dist/backend/run-record.d.ts.map +1 -1
- package/dist/backend/run-record.js +3 -1
- package/dist/backend/run-record.js.map +1 -1
- package/dist/cli/commands/exec.d.ts +5 -0
- package/dist/cli/commands/exec.d.ts.map +1 -0
- package/dist/cli/commands/exec.js +80 -0
- package/dist/cli/commands/exec.js.map +1 -0
- package/dist/cli/help.d.ts.map +1 -1
- package/dist/cli/help.js +1 -0
- package/dist/cli/help.js.map +1 -1
- package/dist/cli/interactive/agent-activity.d.ts +11 -0
- package/dist/cli/interactive/agent-activity.d.ts.map +1 -0
- package/dist/cli/interactive/agent-activity.js +41 -0
- package/dist/cli/interactive/agent-activity.js.map +1 -0
- package/dist/cli/interactive/agent-event-feed.d.ts +14 -0
- package/dist/cli/interactive/agent-event-feed.d.ts.map +1 -0
- package/dist/cli/interactive/agent-event-feed.js +151 -0
- package/dist/cli/interactive/agent-event-feed.js.map +1 -0
- package/dist/cli/interactive/agent-events.d.ts +8 -1
- package/dist/cli/interactive/agent-events.d.ts.map +1 -1
- package/dist/cli/interactive/agent-events.js +7 -2
- package/dist/cli/interactive/agent-events.js.map +1 -1
- package/dist/cli/interactive/agent-execute-turn.d.ts +5 -0
- package/dist/cli/interactive/agent-execute-turn.d.ts.map +1 -1
- package/dist/cli/interactive/agent-execute-turn.js +162 -119
- package/dist/cli/interactive/agent-execute-turn.js.map +1 -1
- package/dist/cli/interactive/agent-stream-format.d.ts +1 -1
- package/dist/cli/interactive/agent-stream-format.d.ts.map +1 -1
- package/dist/cli/interactive/agent-stream-format.js +47 -23
- package/dist/cli/interactive/agent-stream-format.js.map +1 -1
- package/dist/cli/interactive/agent-turn.d.ts +4 -0
- package/dist/cli/interactive/agent-turn.d.ts.map +1 -1
- package/dist/cli/interactive/agent-turn.js +9 -0
- package/dist/cli/interactive/agent-turn.js.map +1 -1
- package/dist/cli/interactive/feed-run-stats.d.ts +9 -0
- package/dist/cli/interactive/feed-run-stats.d.ts.map +1 -0
- package/dist/cli/interactive/feed-run-stats.js +51 -0
- package/dist/cli/interactive/feed-run-stats.js.map +1 -0
- package/dist/cli/interactive/header.d.ts +6 -1
- package/dist/cli/interactive/header.d.ts.map +1 -1
- package/dist/cli/interactive/header.js +7 -3
- package/dist/cli/interactive/header.js.map +1 -1
- package/dist/cli/interactive/json-agent-stream.d.ts +8 -0
- package/dist/cli/interactive/json-agent-stream.d.ts.map +1 -0
- package/dist/cli/interactive/json-agent-stream.js +14 -0
- package/dist/cli/interactive/json-agent-stream.js.map +1 -0
- package/dist/cli/interactive/model-command.d.ts.map +1 -1
- package/dist/cli/interactive/model-command.js +37 -3
- package/dist/cli/interactive/model-command.js.map +1 -1
- package/dist/cli/interactive/plain-agent-render.d.ts.map +1 -1
- package/dist/cli/interactive/plain-agent-render.js +2 -0
- package/dist/cli/interactive/plain-agent-render.js.map +1 -1
- package/dist/cli/interactive/session-controller.d.ts +4 -0
- package/dist/cli/interactive/session-controller.d.ts.map +1 -1
- package/dist/cli/interactive/session-controller.js +23 -2
- package/dist/cli/interactive/session-controller.js.map +1 -1
- package/dist/cli/interactive/session-store.d.ts +3 -0
- package/dist/cli/interactive/session-store.d.ts.map +1 -1
- package/dist/cli/interactive/session-store.js +3 -0
- package/dist/cli/interactive/session-store.js.map +1 -1
- package/dist/cli/interactive/session.d.ts +19 -0
- package/dist/cli/interactive/session.d.ts.map +1 -1
- package/dist/cli/interactive/session.js +44 -0
- package/dist/cli/interactive/session.js.map +1 -1
- package/dist/cli/interactive/slash-dispatch.d.ts +3 -0
- package/dist/cli/interactive/slash-dispatch.d.ts.map +1 -1
- package/dist/cli/interactive/slash-dispatch.js +3 -0
- package/dist/cli/interactive/slash-dispatch.js.map +1 -1
- package/dist/cli/interactive/trace-glyphs.d.ts +13 -0
- package/dist/cli/interactive/trace-glyphs.d.ts.map +1 -0
- package/dist/cli/interactive/trace-glyphs.js +175 -0
- package/dist/cli/interactive/trace-glyphs.js.map +1 -0
- package/dist/cli/interactive/transcript-line-parse.js +2 -2
- package/dist/cli/interactive/transcript-line-parse.js.map +1 -1
- package/dist/cli/interactive/transcript-upsert.d.ts.map +1 -1
- package/dist/cli/interactive/transcript-upsert.js +21 -4
- package/dist/cli/interactive/transcript-upsert.js.map +1 -1
- package/dist/cli/main.d.ts.map +1 -1
- package/dist/cli/main.js +5 -0
- package/dist/cli/main.js.map +1 -1
- package/dist/config/model-preferences.d.ts +13 -0
- package/dist/config/model-preferences.d.ts.map +1 -0
- package/dist/config/model-preferences.js +50 -0
- package/dist/config/model-preferences.js.map +1 -0
- package/dist/config/models.d.ts +2 -1
- package/dist/config/models.d.ts.map +1 -1
- package/dist/config/models.js +5 -2
- package/dist/config/models.js.map +1 -1
- package/opentui/src/App.tsx +40 -5
- package/package.json +1 -1
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Event-native agent feed — adapted from Cursor cookbook coding-agent-cli (tui/App.tsx applyAgentEvent).
|
|
3
|
+
* @see https://github.com/cursor/cookbook/tree/main/sdk/coding-agent-cli/src/tui/App.tsx
|
|
4
|
+
*/
|
|
5
|
+
import { compactText, formatDuration, } from "./agent-events.js";
|
|
6
|
+
import { formatToolStatusGlyph, formatToolTraceBody, } from "./trace-glyphs.js";
|
|
7
|
+
const IGNORED_STATUS = new Set(["CREATING", "RUNNING", "FINISHED", "QUEUED", "PENDING"]);
|
|
8
|
+
export function applyAgentEvent(items, event, assistantId) {
|
|
9
|
+
switch (event.type) {
|
|
10
|
+
case "assistant_delta":
|
|
11
|
+
return appendAssistantDelta(items, assistantId, event.text);
|
|
12
|
+
case "thinking": {
|
|
13
|
+
const text = compactText(event.text);
|
|
14
|
+
if (!text) {
|
|
15
|
+
return items;
|
|
16
|
+
}
|
|
17
|
+
const entryId = `thinking-${assistantId}`;
|
|
18
|
+
const existing = items.find((item) => item.id === entryId);
|
|
19
|
+
const merged = existing && !existing.text.includes(text)
|
|
20
|
+
? compactText(`${existing.text} ${text}`)
|
|
21
|
+
: existing?.text && text.length <= existing.text.length
|
|
22
|
+
? existing.text
|
|
23
|
+
: text;
|
|
24
|
+
return upsertFeedEntry(items, entryId, "status", "think", merged);
|
|
25
|
+
}
|
|
26
|
+
case "tool": {
|
|
27
|
+
const entryId = event.callId
|
|
28
|
+
? normalizeToolEntryId(event.callId)
|
|
29
|
+
: `tool-${assistantId}-${event.name}`;
|
|
30
|
+
const traceEvent = agentToolEventToTrace(event);
|
|
31
|
+
const text = `${formatToolStatusGlyph(traceEvent.status)} ${formatToolTraceBody(traceEvent)}`;
|
|
32
|
+
return upsertFeedEntry(items, entryId, "tool", "tool", text);
|
|
33
|
+
}
|
|
34
|
+
case "status":
|
|
35
|
+
if (IGNORED_STATUS.has(event.status.toUpperCase())) {
|
|
36
|
+
return items;
|
|
37
|
+
}
|
|
38
|
+
return upsertFeedEntry(items, `status-${assistantId}`, event.status === "ERROR" ? "error" : "status", "run", `${formatRunStatus(event.status)}${event.message ? ` · ${event.message}` : ""}`);
|
|
39
|
+
case "task": {
|
|
40
|
+
const text = compactText([event.status, event.text].filter(Boolean).join(" "));
|
|
41
|
+
return text ? upsertFeedEntry(items, `task-${assistantId}`, "status", "task", text) : items;
|
|
42
|
+
}
|
|
43
|
+
case "result": {
|
|
44
|
+
const details = [
|
|
45
|
+
event.status !== "finished" && event.status !== "completed"
|
|
46
|
+
? `status=${event.status}`
|
|
47
|
+
: undefined,
|
|
48
|
+
event.durationMs !== undefined ? `duration=${formatDuration(event.durationMs)}` : undefined,
|
|
49
|
+
event.editSummary ? event.editSummary : undefined,
|
|
50
|
+
event.transport ? `transport=${event.transport}` : undefined,
|
|
51
|
+
event.usage?.inputTokens !== undefined ? `input=${event.usage.inputTokens}` : undefined,
|
|
52
|
+
event.usage?.outputTokens !== undefined ? `output=${event.usage.outputTokens}` : undefined,
|
|
53
|
+
event.errorCode ? `error=${event.errorCode}` : undefined,
|
|
54
|
+
].filter(Boolean);
|
|
55
|
+
if (details.length === 0) {
|
|
56
|
+
return items;
|
|
57
|
+
}
|
|
58
|
+
return [...items, makeFeedEntry("meta", "done", details.join(" · "))];
|
|
59
|
+
}
|
|
60
|
+
default:
|
|
61
|
+
return items;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
export function shouldSkipTranscriptLineForEventFeed(kind, label, text = "") {
|
|
65
|
+
const compact = text.trim();
|
|
66
|
+
const role = label.toLowerCase();
|
|
67
|
+
if (kind === "status" || role === "run") {
|
|
68
|
+
if (compact.startsWith("deliverables") ||
|
|
69
|
+
compact.startsWith("review with")) {
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
if (compact.startsWith("✓ completed") || compact.startsWith("✗ cancelled")) {
|
|
73
|
+
return true;
|
|
74
|
+
}
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
if (kind === "tool" || role === "tool") {
|
|
78
|
+
return true;
|
|
79
|
+
}
|
|
80
|
+
if (kind === "assistant" || role === "agent") {
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
if (role === "think") {
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
function appendAssistantDelta(items, assistantId, text) {
|
|
89
|
+
const last = items.at(-1);
|
|
90
|
+
if (last?.kind === "assistant" && last.id.startsWith(`assistant-${assistantId}`)) {
|
|
91
|
+
return items.map((item, index) => index === items.length - 1 ? { ...item, text: item.text + text } : item);
|
|
92
|
+
}
|
|
93
|
+
const segmentCount = items.filter((item) => item.id.startsWith(`assistant-${assistantId}`)).length;
|
|
94
|
+
return [
|
|
95
|
+
...items,
|
|
96
|
+
{
|
|
97
|
+
id: `assistant-${assistantId}-${segmentCount}`,
|
|
98
|
+
kind: "assistant",
|
|
99
|
+
label: "agent",
|
|
100
|
+
text,
|
|
101
|
+
},
|
|
102
|
+
];
|
|
103
|
+
}
|
|
104
|
+
function upsertFeedEntry(items, id, kind, label, text) {
|
|
105
|
+
const existingIndex = items.findIndex((item) => item.id === id);
|
|
106
|
+
if (existingIndex === -1) {
|
|
107
|
+
return [...items, { id, kind, label, text }];
|
|
108
|
+
}
|
|
109
|
+
return items.map((item, index) => index === existingIndex ? { ...item, kind, label, text } : item);
|
|
110
|
+
}
|
|
111
|
+
function makeFeedEntry(kind, label, text) {
|
|
112
|
+
return {
|
|
113
|
+
id: `${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
|
|
114
|
+
kind,
|
|
115
|
+
label,
|
|
116
|
+
text,
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
function normalizeToolEntryId(callId) {
|
|
120
|
+
return callId.startsWith("tool-") ? callId : `tool-${callId}`;
|
|
121
|
+
}
|
|
122
|
+
function agentToolEventToTrace(event) {
|
|
123
|
+
const status = event.status === "running" || event.status === "requested"
|
|
124
|
+
? "running"
|
|
125
|
+
: event.status === "error"
|
|
126
|
+
? "error"
|
|
127
|
+
: "done";
|
|
128
|
+
return {
|
|
129
|
+
id: event.callId ?? event.name,
|
|
130
|
+
kind: "tool",
|
|
131
|
+
title: event.name,
|
|
132
|
+
toolName: event.name,
|
|
133
|
+
detail: event.params,
|
|
134
|
+
status,
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
function formatRunStatus(status) {
|
|
138
|
+
switch (status.toUpperCase()) {
|
|
139
|
+
case "ERROR":
|
|
140
|
+
return "error";
|
|
141
|
+
case "CANCELLED":
|
|
142
|
+
return "cancelled";
|
|
143
|
+
case "BLOCKED":
|
|
144
|
+
return "blocked";
|
|
145
|
+
case "FAILED":
|
|
146
|
+
return "failed";
|
|
147
|
+
default:
|
|
148
|
+
return status.toLowerCase();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=agent-event-feed.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-event-feed.js","sourceRoot":"","sources":["../../../src/cli/interactive/agent-event-feed.ts"],"names":[],"mappings":"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"}
|
|
@@ -29,10 +29,17 @@ export type AgentEvent = {
|
|
|
29
29
|
status: string;
|
|
30
30
|
durationMs?: number;
|
|
31
31
|
errorCode?: string;
|
|
32
|
+
usage?: TokenUsage;
|
|
33
|
+
transport?: string;
|
|
34
|
+
editSummary?: string;
|
|
35
|
+
};
|
|
36
|
+
export type TokenUsage = {
|
|
37
|
+
inputTokens?: number;
|
|
38
|
+
outputTokens?: number;
|
|
32
39
|
};
|
|
33
40
|
export declare function compactText(text: string): string;
|
|
34
41
|
export declare function formatDuration(ms: number): string;
|
|
35
42
|
export declare function traceEventToAgentEvent(event: AgentTraceEvent, params?: string): AgentEvent | null;
|
|
36
43
|
export declare function runPhaseToAgentEvent(phase: string, status?: string): AgentEvent;
|
|
37
|
-
export declare function runRecordToResultEvent(run: PatzeCodeRunRecord): AgentEvent;
|
|
44
|
+
export declare function runRecordToResultEvent(run: PatzeCodeRunRecord, durationMs?: number, editSummary?: string | null): AgentEvent;
|
|
38
45
|
//# sourceMappingURL=agent-events.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-events.d.ts","sourceRoot":"","sources":["../../../src/cli/interactive/agent-events.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAA;AACnE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAErE,MAAM,MAAM,UAAU,GAClB;IAAE,IAAI,EAAE,iBAAiB,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GACzC;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAClC;IACE,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;CACf,GACD;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,GACpD;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,GAChD;
|
|
1
|
+
{"version":3,"file":"agent-events.d.ts","sourceRoot":"","sources":["../../../src/cli/interactive/agent-events.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAA;AACnE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAErE,MAAM,MAAM,UAAU,GAClB;IAAE,IAAI,EAAE,iBAAiB,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GACzC;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAClC;IACE,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;CACf,GACD;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,GACpD;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,GAChD;IACE,IAAI,EAAE,QAAQ,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,KAAK,CAAC,EAAE,UAAU,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB,CAAA;AAEL,MAAM,MAAM,UAAU,GAAG;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAEhD;AAED,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAKjD;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,eAAe,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,CAmCjG;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,UAAU,CAO/E;AAED,wBAAgB,sBAAsB,CACpC,GAAG,EAAE,kBAAkB,EACvB,UAAU,CAAC,EAAE,MAAM,EACnB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,GAC1B,UAAU,CAYZ"}
|
|
@@ -55,11 +55,16 @@ export function runPhaseToAgentEvent(phase, status) {
|
|
|
55
55
|
message: status && status !== label ? status : undefined,
|
|
56
56
|
};
|
|
57
57
|
}
|
|
58
|
-
export function runRecordToResultEvent(run) {
|
|
58
|
+
export function runRecordToResultEvent(run, durationMs, editSummary) {
|
|
59
|
+
const phase = run.phase || run.status || "finished";
|
|
60
|
+
const normalized = phase === "completed" ? "finished" : phase === "cancelled" ? "cancelled" : phase;
|
|
59
61
|
return {
|
|
60
62
|
type: "result",
|
|
61
|
-
status:
|
|
63
|
+
status: normalized,
|
|
64
|
+
durationMs,
|
|
62
65
|
errorCode: run.error_code || undefined,
|
|
66
|
+
transport: run.cursor_transport?.trim() || undefined,
|
|
67
|
+
editSummary: editSummary?.trim() || undefined,
|
|
63
68
|
};
|
|
64
69
|
}
|
|
65
70
|
//# sourceMappingURL=agent-events.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-events.js","sourceRoot":"","sources":["../../../src/cli/interactive/agent-events.ts"],"names":[],"mappings":"AAAA;;;GAGG;
|
|
1
|
+
{"version":3,"file":"agent-events.js","sourceRoot":"","sources":["../../../src/cli/interactive/agent-events.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,6 +8,9 @@ export type ExecuteTurnOptions = {
|
|
|
8
8
|
objective: string;
|
|
9
9
|
previewArtifactDigest: string;
|
|
10
10
|
modelHint?: string | null;
|
|
11
|
+
modelThinking?: boolean | null;
|
|
12
|
+
modelFast?: boolean | null;
|
|
13
|
+
cursorAgentId?: string | null;
|
|
11
14
|
conversationContext?: string | null;
|
|
12
15
|
executionMode?: "local" | "cloud";
|
|
13
16
|
fetchImpl?: FetchLike;
|
|
@@ -15,6 +18,8 @@ export type ExecuteTurnOptions = {
|
|
|
15
18
|
onTranscriptLine?: (line: string) => void;
|
|
16
19
|
onTranscriptPartial?: (chunk: string) => void;
|
|
17
20
|
onAgentEvent?: (event: AgentEvent) => void;
|
|
21
|
+
onActivity?: (label: string | null) => void;
|
|
22
|
+
useActivitySpinner?: boolean;
|
|
18
23
|
};
|
|
19
24
|
export type ExecuteTurnResult = {
|
|
20
25
|
ok: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-execute-turn.d.ts","sourceRoot":"","sources":["../../../src/cli/interactive/agent-execute-turn.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"agent-execute-turn.d.ts","sourceRoot":"","sources":["../../../src/cli/interactive/agent-execute-turn.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAA;AAGhE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAK5D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAEnD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,GAAG,EAAE,MAAM,CAAA;IACX,MAAM,EAAE,cAAc,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,qBAAqB,EAAE,MAAM,CAAA;IAC7B,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,aAAa,CAAC,EAAE,OAAO,GAAG,IAAI,CAAA;IAC9B,SAAS,CAAC,EAAE,OAAO,GAAG,IAAI,CAAA;IAC1B,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,mBAAmB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACnC,aAAa,CAAC,EAAE,OAAO,GAAG,OAAO,CAAA;IACjC,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,MAAM,CAAC,EAAE,WAAW,CAAA;IACpB,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;IACzC,mBAAmB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC7C,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,KAAK,IAAI,CAAA;IAC1C,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;IAC3C,kBAAkB,CAAC,EAAE,OAAO,CAAA;CAC7B,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,EAAE,EAAE,OAAO,CAAA;IACX,QAAQ,EAAE,OAAO,CAAA;IACjB,GAAG,EAAE,kBAAkB,GAAG,IAAI,CAAA;IAC9B,QAAQ,EAAE,MAAM,CAAA;IAChB,KAAK,EAAE,MAAM,EAAE,CAAA;CAChB,CAAA;AAED,wBAAgB,mBAAmB,IAAI,OAAO,CAM7C;AAED,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAElE;AAED,wBAAsB,cAAc,CAAC,OAAO,EAAE,kBAAkB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAiM5F"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { PatzeBackendClient } from "../../backend/client.js";
|
|
2
|
+
import { postRunCancel } from "../../backend/cancel-client.js";
|
|
2
3
|
import { postUserTaskExecute } from "../../backend/execute-client.js";
|
|
3
4
|
import { buildPreviewPayload } from "../../backend/preview-payload.js";
|
|
4
5
|
import { streamPatzeCodeRun } from "../../backend/run-stream-client.js";
|
|
5
6
|
import { AgentStreamTranscript } from "./agent-stream-format.js";
|
|
7
|
+
import { createAgentActivityReporter } from "./agent-activity.js";
|
|
6
8
|
import { formatAgentReply } from "./transcript-format.js";
|
|
7
9
|
import { inputLooksThai } from "./agent-turn-classify.js";
|
|
8
10
|
export function isCliExecuteEnabled() {
|
|
@@ -16,136 +18,177 @@ export function isExecuteAuthReady(config) {
|
|
|
16
18
|
return Boolean(config.api && config.token && config.userId);
|
|
17
19
|
}
|
|
18
20
|
export async function runExecuteTurn(options) {
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
this.lines.push(line);
|
|
24
|
-
options.onTranscriptLine?.(line);
|
|
25
|
-
}
|
|
26
|
-
},
|
|
27
|
-
};
|
|
28
|
-
const client = new PatzeBackendClient(options.config);
|
|
29
|
-
const payload = buildPreviewPayload({
|
|
30
|
-
objective: options.objective,
|
|
31
|
-
cwd: options.cwd,
|
|
32
|
-
config: options.config,
|
|
33
|
-
modelHint: options.modelHint,
|
|
34
|
-
conversationContext: options.conversationContext,
|
|
35
|
-
executionMode: options.executionMode,
|
|
36
|
-
});
|
|
37
|
-
const transcript = new AgentStreamTranscript({
|
|
38
|
-
emit(lines) {
|
|
39
|
-
for (const line of lines) {
|
|
40
|
-
sink.lines.push(line);
|
|
41
|
-
options.onTranscriptLine?.(line);
|
|
42
|
-
}
|
|
43
|
-
},
|
|
44
|
-
emitPartial(chunk) {
|
|
45
|
-
options.onTranscriptPartial?.(chunk);
|
|
46
|
-
},
|
|
47
|
-
}, inputLooksThai(options.objective), options.onAgentEvent);
|
|
48
|
-
transcript.emitRunPhase("queued");
|
|
49
|
-
const execute = await postUserTaskExecute({
|
|
50
|
-
apiBase: client.baseUrl,
|
|
51
|
-
headers: client.buildHeaders(),
|
|
52
|
-
payload,
|
|
53
|
-
previewArtifactDigest: options.previewArtifactDigest,
|
|
54
|
-
fetchImpl: options.fetchImpl,
|
|
21
|
+
const activity = createAgentActivityReporter({
|
|
22
|
+
onActivity: options.onActivity,
|
|
23
|
+
useSpinner: options.useActivitySpinner ??
|
|
24
|
+
Boolean(process.stdout.isTTY && !options.onTranscriptPartial && !process.env.NO_COLOR),
|
|
55
25
|
});
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
outcome_summary: execute.response.outcome_summary ?? "",
|
|
72
|
-
agent_model: execute.response.agent_model ?? "",
|
|
73
|
-
finding_codes: execute.response.finding_codes,
|
|
74
|
-
deliverable_paths: execute.response.deliverable_paths ?? [],
|
|
75
|
-
agent_trace: execute.response.agent_trace ?? [],
|
|
76
|
-
};
|
|
77
|
-
for (const item of run.agent_trace) {
|
|
78
|
-
transcript.emitTraceItem(item);
|
|
79
|
-
}
|
|
80
|
-
transcript.emitFinalRun(run);
|
|
81
|
-
const ok = run.phase === "completed" || run.status === "completed";
|
|
82
|
-
return {
|
|
83
|
-
ok,
|
|
84
|
-
streamed: sink.lines.length > 0,
|
|
85
|
-
run,
|
|
86
|
-
exitCode: ok ? 0 : 1,
|
|
87
|
-
lines: sink.lines,
|
|
88
|
-
};
|
|
89
|
-
}
|
|
90
|
-
const runId = execute.response.run_id;
|
|
91
|
-
transcript.emitRunPhase(execute.response.phase, execute.response.status);
|
|
92
|
-
if (options.signal?.aborted) {
|
|
93
|
-
transcript.emitRunPhase("cancelled");
|
|
94
|
-
return {
|
|
95
|
-
ok: false,
|
|
96
|
-
streamed: sink.lines.length > 0,
|
|
97
|
-
run: null,
|
|
98
|
-
exitCode: 130,
|
|
99
|
-
lines: sink.lines,
|
|
26
|
+
activity.start("Running agent");
|
|
27
|
+
const startedAt = Date.now();
|
|
28
|
+
const notifyOutput = () => {
|
|
29
|
+
activity.clear();
|
|
30
|
+
};
|
|
31
|
+
try {
|
|
32
|
+
const sink = {
|
|
33
|
+
lines: [],
|
|
34
|
+
emit(lines) {
|
|
35
|
+
for (const line of lines) {
|
|
36
|
+
notifyOutput();
|
|
37
|
+
this.lines.push(line);
|
|
38
|
+
options.onTranscriptLine?.(line);
|
|
39
|
+
}
|
|
40
|
+
},
|
|
100
41
|
};
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
42
|
+
const client = new PatzeBackendClient(options.config);
|
|
43
|
+
const payload = buildPreviewPayload({
|
|
44
|
+
objective: options.objective,
|
|
45
|
+
cwd: options.cwd,
|
|
46
|
+
config: options.config,
|
|
47
|
+
modelHint: options.modelHint,
|
|
48
|
+
modelThinking: options.modelThinking,
|
|
49
|
+
modelFast: options.modelFast,
|
|
50
|
+
cursorAgentId: options.cursorAgentId,
|
|
51
|
+
conversationContext: options.conversationContext,
|
|
52
|
+
executionMode: options.executionMode,
|
|
53
|
+
});
|
|
54
|
+
const transcript = new AgentStreamTranscript({
|
|
55
|
+
emit(lines) {
|
|
56
|
+
for (const line of lines) {
|
|
57
|
+
notifyOutput();
|
|
58
|
+
sink.lines.push(line);
|
|
59
|
+
options.onTranscriptLine?.(line);
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
emitPartial(chunk) {
|
|
63
|
+
notifyOutput();
|
|
64
|
+
options.onTranscriptPartial?.(chunk);
|
|
65
|
+
},
|
|
66
|
+
}, inputLooksThai(options.objective), options.onAgentEvent);
|
|
67
|
+
transcript.emitRunPhase("queued");
|
|
68
|
+
const execute = await postUserTaskExecute({
|
|
105
69
|
apiBase: client.baseUrl,
|
|
106
70
|
headers: client.buildHeaders(),
|
|
107
|
-
|
|
71
|
+
payload,
|
|
72
|
+
previewArtifactDigest: options.previewArtifactDigest,
|
|
108
73
|
fetchImpl: options.fetchImpl,
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
74
|
+
});
|
|
75
|
+
if (!execute.ok) {
|
|
76
|
+
const message = execute.kind === "auth"
|
|
77
|
+
? `${execute.message} — ensure user id is set (/login or /status --check).`
|
|
78
|
+
: execute.message;
|
|
79
|
+
sink.emit(formatAgentReply(`Execute failed: ${message}`));
|
|
80
|
+
return { ok: false, streamed: sink.lines.length > 0, run: null, exitCode: 1, lines: sink.lines };
|
|
81
|
+
}
|
|
82
|
+
if (execute.kind === "completed") {
|
|
83
|
+
transcript.emitRunPhase(execute.response.phase ?? execute.response.status);
|
|
84
|
+
const run = {
|
|
85
|
+
run_id: execute.response.run_id,
|
|
86
|
+
status: execute.response.status,
|
|
87
|
+
phase: execute.response.phase ?? execute.response.status,
|
|
88
|
+
error_code: execute.response.error_code,
|
|
89
|
+
agent_output_preview: execute.response.agent_output_preview ?? "",
|
|
90
|
+
outcome_summary: execute.response.outcome_summary ?? "",
|
|
91
|
+
agent_model: execute.response.agent_model ?? "",
|
|
92
|
+
finding_codes: execute.response.finding_codes,
|
|
93
|
+
deliverable_paths: execute.response.deliverable_paths ?? [],
|
|
94
|
+
agent_trace: execute.response.agent_trace ?? [],
|
|
95
|
+
cursor_agent_id: String(execute.response.cursor_agent_id ?? ""),
|
|
96
|
+
cursor_transport: String(execute.response.cursor_transport ?? ""),
|
|
97
|
+
};
|
|
98
|
+
for (const item of run.agent_trace) {
|
|
99
|
+
transcript.emitTraceItem(item);
|
|
100
|
+
}
|
|
101
|
+
transcript.emitFinalRun(run, Date.now() - startedAt);
|
|
102
|
+
const ok = run.phase === "completed" || run.status === "completed";
|
|
103
|
+
return {
|
|
104
|
+
ok,
|
|
105
|
+
streamed: sink.lines.length > 0,
|
|
106
|
+
run,
|
|
107
|
+
exitCode: ok ? 0 : 1,
|
|
108
|
+
lines: sink.lines,
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
const runId = execute.response.run_id;
|
|
112
|
+
transcript.emitRunPhase(execute.response.phase, execute.response.status);
|
|
113
|
+
let cancelPosted = false;
|
|
114
|
+
const requestServerCancel = () => {
|
|
115
|
+
if (cancelPosted || !runId) {
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
cancelPosted = true;
|
|
119
|
+
void postRunCancel({
|
|
120
|
+
apiBase: client.baseUrl,
|
|
121
|
+
headers: client.buildHeaders(),
|
|
122
|
+
runId,
|
|
123
|
+
fetchImpl: options.fetchImpl,
|
|
124
|
+
});
|
|
125
|
+
};
|
|
126
|
+
if (options.signal) {
|
|
127
|
+
if (options.signal.aborted) {
|
|
128
|
+
requestServerCancel();
|
|
129
|
+
transcript.emitRunPhase("cancelled");
|
|
130
|
+
return {
|
|
131
|
+
ok: false,
|
|
132
|
+
streamed: sink.lines.length > 0,
|
|
133
|
+
run: null,
|
|
134
|
+
exitCode: 130,
|
|
135
|
+
lines: sink.lines,
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
options.signal.addEventListener("abort", requestServerCancel, { once: true });
|
|
139
|
+
}
|
|
140
|
+
const holder = { run: null };
|
|
141
|
+
await new Promise((resolvePromise) => {
|
|
142
|
+
void streamPatzeCodeRun({
|
|
143
|
+
apiBase: client.baseUrl,
|
|
144
|
+
headers: client.buildHeaders(),
|
|
145
|
+
runId,
|
|
146
|
+
fetchImpl: options.fetchImpl,
|
|
147
|
+
signal: options.signal,
|
|
148
|
+
handlers: {
|
|
149
|
+
onStatus: (event) => {
|
|
150
|
+
transcript.emitRunPhase(event.phase, event.status);
|
|
151
|
+
},
|
|
152
|
+
onTrace: (event) => {
|
|
153
|
+
transcript.emitTraceItem(event.item);
|
|
154
|
+
},
|
|
155
|
+
onComplete: (run) => {
|
|
156
|
+
holder.run = run;
|
|
157
|
+
transcript.emitFinalRun(run, Date.now() - startedAt);
|
|
158
|
+
resolvePromise();
|
|
159
|
+
},
|
|
160
|
+
onError: (message) => {
|
|
161
|
+
if (message === "cancelled") {
|
|
162
|
+
transcript.emitRunPhase("cancelled");
|
|
163
|
+
}
|
|
164
|
+
resolvePromise();
|
|
165
|
+
},
|
|
127
166
|
},
|
|
128
|
-
}
|
|
167
|
+
});
|
|
129
168
|
});
|
|
130
|
-
|
|
131
|
-
|
|
169
|
+
options.signal?.removeEventListener("abort", requestServerCancel);
|
|
170
|
+
if (options.signal?.aborted) {
|
|
171
|
+
return {
|
|
172
|
+
ok: false,
|
|
173
|
+
streamed: sink.lines.length > 0,
|
|
174
|
+
run: holder.run,
|
|
175
|
+
exitCode: 130,
|
|
176
|
+
lines: sink.lines,
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
const finalRun = holder.run;
|
|
180
|
+
const ok = finalRun !== null &&
|
|
181
|
+
(finalRun.phase === "completed" || finalRun.status === "completed");
|
|
132
182
|
return {
|
|
133
|
-
ok
|
|
183
|
+
ok,
|
|
134
184
|
streamed: sink.lines.length > 0,
|
|
135
|
-
run:
|
|
136
|
-
exitCode:
|
|
185
|
+
run: finalRun,
|
|
186
|
+
exitCode: ok ? 0 : 1,
|
|
137
187
|
lines: sink.lines,
|
|
138
188
|
};
|
|
139
189
|
}
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
return {
|
|
144
|
-
ok,
|
|
145
|
-
streamed: sink.lines.length > 0,
|
|
146
|
-
run: finalRun,
|
|
147
|
-
exitCode: ok ? 0 : 1,
|
|
148
|
-
lines: sink.lines,
|
|
149
|
-
};
|
|
190
|
+
finally {
|
|
191
|
+
activity.clear();
|
|
192
|
+
}
|
|
150
193
|
}
|
|
151
194
|
//# sourceMappingURL=agent-execute-turn.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-execute-turn.js","sourceRoot":"","sources":["../../../src/cli/interactive/agent-execute-turn.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAA;AAErE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAA;AACtE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAA;AAGvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAA;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAA;
|
|
1
|
+
{"version":3,"file":"agent-execute-turn.js","sourceRoot":"","sources":["../../../src/cli/interactive/agent-execute-turn.ts"],"names":[],"mappings":"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"}
|
|
@@ -19,7 +19,7 @@ export declare class AgentStreamTranscript {
|
|
|
19
19
|
flushPartialLine(): void;
|
|
20
20
|
emitRunPhase(phase: string, status?: string): void;
|
|
21
21
|
emitTraceItem(item: unknown): void;
|
|
22
|
-
emitFinalRun(run: PatzeCodeRunRecord | null): void;
|
|
22
|
+
emitFinalRun(run: PatzeCodeRunRecord | null, durationMs?: number): void;
|
|
23
23
|
private emitUpsertTrace;
|
|
24
24
|
private emitStreamingText;
|
|
25
25
|
private emitAgentPartial;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-stream-format.d.ts","sourceRoot":"","sources":["../../../src/cli/interactive/agent-stream-format.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAErE,OAAO,EAIL,KAAK,UAAU,EAChB,MAAM,mBAAmB,CAAA;AAG1B,OAAO,EAAoB,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;
|
|
1
|
+
{"version":3,"file":"agent-stream-format.d.ts","sourceRoot":"","sources":["../../../src/cli/interactive/agent-stream-format.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAErE,OAAO,EAIL,KAAK,UAAU,EAChB,MAAM,mBAAmB,CAAA;AAG1B,OAAO,EAAoB,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAQhF,MAAM,MAAM,oBAAoB,GAAG;IACjC,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAA;IAC/B,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;CACtC,CAAA;AAQD,qBAAa,qBAAqB;IAQ9B,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC;IAThC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAoB;IACjD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAA+B;IAC1D,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,UAAU,CAAK;IACvB,OAAO,CAAC,kBAAkB,CAAQ;gBAGf,IAAI,EAAE,oBAAoB,EAC1B,SAAS,UAAQ,EACjB,YAAY,CAAC,GAAE,CAAC,KAAK,EAAE,UAAU,KAAK,IAAI,aAAA;IAG7D,OAAO,CAAC,SAAS;IAMjB,gBAAgB,IAAI,IAAI;IAQxB,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAalD,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;IAiDlC,YAAY,CAAC,GAAG,EAAE,kBAAkB,GAAG,IAAI,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI;IA2DvE,OAAO,CAAC,eAAe;IAqCvB,OAAO,CAAC,iBAAiB;IAqBzB,OAAO,CAAC,gBAAgB;CAczB;AA6BD,OAAO,EAAE,qBAAqB,EAAE,CAAA"}
|