acpx 0.7.0 → 0.8.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.
Files changed (49) hide show
  1. package/README.md +7 -2
  2. package/dist/{cli-T-Z-9x6a.js → cli-BGYGVo3b.js} +35 -10
  3. package/dist/cli-BGYGVo3b.js.map +1 -0
  4. package/dist/cli.d.ts +1 -1
  5. package/dist/cli.d.ts.map +1 -1
  6. package/dist/cli.js +204 -19
  7. package/dist/cli.js.map +1 -1
  8. package/dist/{client-COPilhO_.d.ts → client-FzXPdgP7.d.ts} +7 -3
  9. package/dist/client-FzXPdgP7.d.ts.map +1 -0
  10. package/dist/{flags-Dj-IXgo9.js → flags-D706STfk.js} +46 -6
  11. package/dist/flags-D706STfk.js.map +1 -0
  12. package/dist/{flows-CF8w1rPI.js → flows-hcjHmU7P.js} +8 -5
  13. package/dist/flows-hcjHmU7P.js.map +1 -0
  14. package/dist/flows.d.ts +3 -2
  15. package/dist/flows.d.ts.map +1 -1
  16. package/dist/flows.js +1 -1
  17. package/dist/{prompt-turn-CVPMWdj1.js → live-checkpoint-B9ctAuqV.js} +1301 -78
  18. package/dist/live-checkpoint-B9ctAuqV.js.map +1 -0
  19. package/dist/output-BL9XRWzS.js +3712 -0
  20. package/dist/output-BL9XRWzS.js.map +1 -0
  21. package/dist/runtime.d.ts +28 -4
  22. package/dist/runtime.d.ts.map +1 -1
  23. package/dist/runtime.js +153 -24
  24. package/dist/runtime.js.map +1 -1
  25. package/dist/{types-CVBeQyi3.d.ts → session-options-BJyG6zEH.d.ts} +56 -3
  26. package/dist/session-options-BJyG6zEH.d.ts.map +1 -0
  27. package/package.json +23 -21
  28. package/skills/acpx/SKILL.md +200 -10
  29. package/dist/cli-T-Z-9x6a.js.map +0 -1
  30. package/dist/client-COPilhO_.d.ts.map +0 -1
  31. package/dist/flags-Dj-IXgo9.js.map +0 -1
  32. package/dist/flows-CF8w1rPI.js.map +0 -1
  33. package/dist/ipc-ABXlXzGP.js +0 -1290
  34. package/dist/ipc-ABXlXzGP.js.map +0 -1
  35. package/dist/jsonrpc-DSxh2w5R.js +0 -68
  36. package/dist/jsonrpc-DSxh2w5R.js.map +0 -1
  37. package/dist/output-DmHvT8vm.js +0 -807
  38. package/dist/output-DmHvT8vm.js.map +0 -1
  39. package/dist/perf-metrics-C2pXfxvR.js +0 -598
  40. package/dist/perf-metrics-C2pXfxvR.js.map +0 -1
  41. package/dist/prompt-turn-CVPMWdj1.js.map +0 -1
  42. package/dist/render-N5YwotCy.js +0 -172
  43. package/dist/render-N5YwotCy.js.map +0 -1
  44. package/dist/rolldown-runtime-CiIaOW0V.js +0 -13
  45. package/dist/session-CDaQe6BH.js +0 -1538
  46. package/dist/session-CDaQe6BH.js.map +0 -1
  47. package/dist/session-options-pCbHn_n7.d.ts +0 -13
  48. package/dist/session-options-pCbHn_n7.d.ts.map +0 -1
  49. package/dist/types-CVBeQyi3.d.ts.map +0 -1
@@ -1,172 +0,0 @@
1
- import { t as __exportAll } from "./rolldown-runtime-CiIaOW0V.js";
2
- import { u as normalizeRuntimeSessionId } from "./perf-metrics-C2pXfxvR.js";
3
- import { c as probeQueueOwnerHealth } from "./ipc-ABXlXzGP.js";
4
- import path from "node:path";
5
- //#region src/cli/output/json-output.ts
6
- function emitJsonResult(format, payload) {
7
- if (format !== "json") return false;
8
- process.stdout.write(`${JSON.stringify(payload)}\n`);
9
- return true;
10
- }
11
- //#endregion
12
- //#region src/cli/output/render.ts
13
- var render_exports = /* @__PURE__ */ __exportAll({
14
- agentSessionIdPayload: () => agentSessionIdPayload,
15
- formatPromptSessionBannerLine: () => formatPromptSessionBannerLine,
16
- printClosedSessionByFormat: () => printClosedSessionByFormat,
17
- printCreatedSessionBanner: () => printCreatedSessionBanner,
18
- printEnsuredSessionByFormat: () => printEnsuredSessionByFormat,
19
- printNewSessionByFormat: () => printNewSessionByFormat,
20
- printPromptSessionBanner: () => printPromptSessionBanner,
21
- printPruneResultByFormat: () => printPruneResultByFormat,
22
- printQueuedPromptByFormat: () => printQueuedPromptByFormat,
23
- printSessionsByFormat: () => printSessionsByFormat
24
- });
25
- function formatSessionLabel(record) {
26
- return record.name ?? "cwd";
27
- }
28
- function formatRoutedFrom(sessionCwd, currentCwd) {
29
- const relative = path.relative(sessionCwd, currentCwd);
30
- if (!relative || relative === ".") return;
31
- return relative.startsWith(".") ? relative : `.${path.sep}${relative}`;
32
- }
33
- async function resolveSessionConnectionStatus(record) {
34
- return (await probeQueueOwnerHealth(record.acpxRecordId)).healthy ? "connected" : "needs reconnect";
35
- }
36
- function printSessionsByFormat(sessions, format) {
37
- if (format === "json") {
38
- process.stdout.write(`${JSON.stringify(sessions)}\n`);
39
- return;
40
- }
41
- if (format === "quiet") {
42
- for (const session of sessions) {
43
- const closedMarker = session.closed ? " [closed]" : "";
44
- process.stdout.write(`${session.acpxRecordId}${closedMarker}\n`);
45
- }
46
- return;
47
- }
48
- if (sessions.length === 0) {
49
- process.stdout.write("No sessions\n");
50
- return;
51
- }
52
- for (const session of sessions) {
53
- const closedMarker = session.closed ? " [closed]" : "";
54
- process.stdout.write(`${session.acpxRecordId}${closedMarker}\t${session.name ?? "-"}\t${session.cwd}\t${session.lastUsedAt}\n`);
55
- }
56
- }
57
- function printClosedSessionByFormat(record, format) {
58
- if (emitJsonResult(format, {
59
- action: "session_closed",
60
- acpxRecordId: record.acpxRecordId,
61
- acpxSessionId: record.acpSessionId,
62
- agentSessionId: record.agentSessionId
63
- })) return;
64
- if (format === "quiet") return;
65
- process.stdout.write(`${record.acpxRecordId}\n`);
66
- }
67
- function printNewSessionByFormat(record, replaced, format) {
68
- if (emitJsonResult(format, {
69
- action: "session_ensured",
70
- created: true,
71
- acpxRecordId: record.acpxRecordId,
72
- acpxSessionId: record.acpSessionId,
73
- agentSessionId: record.agentSessionId,
74
- name: record.name,
75
- replacedSessionId: replaced?.acpxRecordId
76
- })) return;
77
- if (format === "quiet") {
78
- process.stdout.write(`${record.acpxRecordId}\n`);
79
- return;
80
- }
81
- if (replaced) {
82
- process.stdout.write(`${record.acpxRecordId}\t(replaced ${replaced.acpxRecordId})\n`);
83
- return;
84
- }
85
- process.stdout.write(`${record.acpxRecordId}\n`);
86
- }
87
- function printEnsuredSessionByFormat(record, created, format) {
88
- if (emitJsonResult(format, {
89
- action: "session_ensured",
90
- created,
91
- acpxRecordId: record.acpxRecordId,
92
- acpxSessionId: record.acpSessionId,
93
- agentSessionId: record.agentSessionId,
94
- name: record.name
95
- })) return;
96
- if (format === "quiet") {
97
- process.stdout.write(`${record.acpxRecordId}\n`);
98
- return;
99
- }
100
- const action = created ? "created" : "existing";
101
- process.stdout.write(`${record.acpxRecordId}\t(${action})\n`);
102
- }
103
- function printQueuedPromptByFormat(result, format) {
104
- if (emitJsonResult(format, {
105
- action: "prompt_queued",
106
- acpxRecordId: result.sessionId,
107
- requestId: result.requestId
108
- })) return;
109
- if (format === "quiet") return;
110
- process.stdout.write(`[queued] ${result.requestId}\n`);
111
- }
112
- function formatPromptSessionBannerLine(record, currentCwd, connectionStatus = "needs reconnect") {
113
- const label = formatSessionLabel(record);
114
- const normalizedSessionCwd = path.resolve(record.cwd);
115
- const normalizedCurrentCwd = path.resolve(currentCwd);
116
- const routedFrom = normalizedSessionCwd === normalizedCurrentCwd ? void 0 : formatRoutedFrom(normalizedSessionCwd, normalizedCurrentCwd);
117
- const status = connectionStatus;
118
- if (routedFrom) return `[acpx] session ${label} (${record.acpxRecordId}) · ${normalizedSessionCwd} (routed from ${routedFrom}) · agent ${status}`;
119
- return `[acpx] session ${label} (${record.acpxRecordId}) · ${normalizedSessionCwd} · agent ${status}`;
120
- }
121
- async function printPromptSessionBanner(record, currentCwd, format, jsonStrict = false) {
122
- if (format === "quiet" || jsonStrict && format === "json") return;
123
- const status = await resolveSessionConnectionStatus(record);
124
- process.stderr.write(`${formatPromptSessionBannerLine(record, currentCwd, status)}\n`);
125
- }
126
- function printCreatedSessionBanner(record, agentName, format, jsonStrict = false) {
127
- if (format === "quiet" || jsonStrict && format === "json") return;
128
- const label = formatSessionLabel(record);
129
- process.stderr.write(`[acpx] created session ${label} (${record.acpxRecordId})\n`);
130
- process.stderr.write(`[acpx] agent: ${agentName}\n`);
131
- process.stderr.write(`[acpx] cwd: ${record.cwd}\n`);
132
- }
133
- function formatBytes(bytes) {
134
- if (bytes >= 1073741824) return `${(bytes / 1073741824).toFixed(1)} GB`;
135
- if (bytes >= 1048576) return `${(bytes / 1048576).toFixed(1)} MB`;
136
- if (bytes >= 1024) return `${(bytes / 1024).toFixed(1)} KB`;
137
- return `${bytes} B`;
138
- }
139
- function printPruneResultByFormat(result, format) {
140
- const count = result.pruned.length;
141
- if (emitJsonResult(format, {
142
- action: result.dryRun ? "sessions_prune_dry_run" : "sessions_pruned",
143
- dryRun: result.dryRun,
144
- count,
145
- bytesFreed: result.bytesFreed,
146
- pruned: result.pruned.map((r) => r.acpxRecordId)
147
- })) return;
148
- if (format === "quiet") {
149
- for (const record of result.pruned) process.stdout.write(`${record.acpxRecordId}\n`);
150
- return;
151
- }
152
- if (count === 0) {
153
- process.stdout.write(result.dryRun ? "[DRY RUN] No sessions to prune\n" : "No sessions pruned\n");
154
- return;
155
- }
156
- const prefix = result.dryRun ? "[DRY RUN] Would prune" : "Pruned";
157
- const bytesSuffix = !result.dryRun && result.bytesFreed > 0 ? `, freed ${formatBytes(result.bytesFreed)}` : "";
158
- process.stdout.write(`${prefix} ${count} session${count === 1 ? "" : "s"}${bytesSuffix}\n`);
159
- for (const record of result.pruned) {
160
- const label = record.name ? ` (${record.name})` : "";
161
- process.stdout.write(` ${record.acpxRecordId}${label}\t${record.closedAt ?? record.lastUsedAt}\n`);
162
- }
163
- }
164
- function agentSessionIdPayload(agentSessionId) {
165
- const normalized = normalizeRuntimeSessionId(agentSessionId);
166
- if (!normalized) return {};
167
- return { agentSessionId: normalized };
168
- }
169
- //#endregion
170
- export { emitJsonResult as i, formatPromptSessionBannerLine as n, render_exports as r, agentSessionIdPayload as t };
171
-
172
- //# sourceMappingURL=render-N5YwotCy.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"render-N5YwotCy.js","names":[],"sources":["../src/cli/output/json-output.ts","../src/cli/output/render.ts"],"sourcesContent":["import type { OutputFormat } from \"../../types.js\";\n\nexport function emitJsonResult(format: OutputFormat, payload: unknown): boolean {\n if (format !== \"json\") {\n return false;\n }\n process.stdout.write(`${JSON.stringify(payload)}\\n`);\n return true;\n}\n","import path from \"node:path\";\nimport { normalizeRuntimeSessionId } from \"../../session/runtime-session-id.js\";\nimport type { OutputFormat, SessionRecord } from \"../../types.js\";\nimport { probeQueueOwnerHealth } from \"../queue/ipc.js\";\nimport { emitJsonResult } from \"./json-output.js\";\n\nfunction formatSessionLabel(record: SessionRecord): string {\n return record.name ?? \"cwd\";\n}\n\nfunction formatRoutedFrom(sessionCwd: string, currentCwd: string): string | undefined {\n const relative = path.relative(sessionCwd, currentCwd);\n if (!relative || relative === \".\") {\n return undefined;\n }\n return relative.startsWith(\".\") ? relative : `.${path.sep}${relative}`;\n}\n\ntype SessionConnectionStatus = \"connected\" | \"needs reconnect\";\n\nasync function resolveSessionConnectionStatus(\n record: SessionRecord,\n): Promise<SessionConnectionStatus> {\n const health = await probeQueueOwnerHealth(record.acpxRecordId);\n return health.healthy ? \"connected\" : \"needs reconnect\";\n}\n\nexport function printSessionsByFormat(sessions: SessionRecord[], format: OutputFormat): void {\n if (format === \"json\") {\n process.stdout.write(`${JSON.stringify(sessions)}\\n`);\n return;\n }\n\n if (format === \"quiet\") {\n for (const session of sessions) {\n const closedMarker = session.closed ? \" [closed]\" : \"\";\n process.stdout.write(`${session.acpxRecordId}${closedMarker}\\n`);\n }\n return;\n }\n\n if (sessions.length === 0) {\n process.stdout.write(\"No sessions\\n\");\n return;\n }\n\n for (const session of sessions) {\n const closedMarker = session.closed ? \" [closed]\" : \"\";\n process.stdout.write(\n `${session.acpxRecordId}${closedMarker}\\t${session.name ?? \"-\"}\\t${session.cwd}\\t${session.lastUsedAt}\\n`,\n );\n }\n}\n\nexport function printClosedSessionByFormat(record: SessionRecord, format: OutputFormat): void {\n if (\n emitJsonResult(format, {\n action: \"session_closed\",\n acpxRecordId: record.acpxRecordId,\n acpxSessionId: record.acpSessionId,\n agentSessionId: record.agentSessionId,\n })\n ) {\n return;\n }\n\n if (format === \"quiet\") {\n return;\n }\n\n process.stdout.write(`${record.acpxRecordId}\\n`);\n}\n\nexport function printNewSessionByFormat(\n record: SessionRecord,\n replaced: SessionRecord | undefined,\n format: OutputFormat,\n): void {\n if (\n emitJsonResult(format, {\n action: \"session_ensured\",\n created: true,\n acpxRecordId: record.acpxRecordId,\n acpxSessionId: record.acpSessionId,\n agentSessionId: record.agentSessionId,\n name: record.name,\n replacedSessionId: replaced?.acpxRecordId,\n })\n ) {\n return;\n }\n\n if (format === \"quiet\") {\n process.stdout.write(`${record.acpxRecordId}\\n`);\n return;\n }\n\n if (replaced) {\n process.stdout.write(`${record.acpxRecordId}\\t(replaced ${replaced.acpxRecordId})\\n`);\n return;\n }\n\n process.stdout.write(`${record.acpxRecordId}\\n`);\n}\n\nexport function printEnsuredSessionByFormat(\n record: SessionRecord,\n created: boolean,\n format: OutputFormat,\n): void {\n if (\n emitJsonResult(format, {\n action: \"session_ensured\",\n created,\n acpxRecordId: record.acpxRecordId,\n acpxSessionId: record.acpSessionId,\n agentSessionId: record.agentSessionId,\n name: record.name,\n })\n ) {\n return;\n }\n\n if (format === \"quiet\") {\n process.stdout.write(`${record.acpxRecordId}\\n`);\n return;\n }\n\n const action = created ? \"created\" : \"existing\";\n process.stdout.write(`${record.acpxRecordId}\\t(${action})\\n`);\n}\n\nexport function printQueuedPromptByFormat(\n result: {\n sessionId: string;\n requestId: string;\n },\n format: OutputFormat,\n): void {\n if (\n emitJsonResult(format, {\n action: \"prompt_queued\",\n acpxRecordId: result.sessionId,\n requestId: result.requestId,\n })\n ) {\n return;\n }\n\n if (format === \"quiet\") {\n return;\n }\n\n process.stdout.write(`[queued] ${result.requestId}\\n`);\n}\n\nexport function formatPromptSessionBannerLine(\n record: SessionRecord,\n currentCwd: string,\n connectionStatus: SessionConnectionStatus = \"needs reconnect\",\n): string {\n const label = formatSessionLabel(record);\n const normalizedSessionCwd = path.resolve(record.cwd);\n const normalizedCurrentCwd = path.resolve(currentCwd);\n const routedFrom =\n normalizedSessionCwd === normalizedCurrentCwd\n ? undefined\n : formatRoutedFrom(normalizedSessionCwd, normalizedCurrentCwd);\n const status = connectionStatus;\n\n if (routedFrom) {\n return `[acpx] session ${label} (${record.acpxRecordId}) · ${normalizedSessionCwd} (routed from ${routedFrom}) · agent ${status}`;\n }\n\n return `[acpx] session ${label} (${record.acpxRecordId}) · ${normalizedSessionCwd} · agent ${status}`;\n}\n\nexport async function printPromptSessionBanner(\n record: SessionRecord,\n currentCwd: string,\n format: OutputFormat,\n jsonStrict = false,\n): Promise<void> {\n if (format === \"quiet\" || (jsonStrict && format === \"json\")) {\n return;\n }\n\n const status = await resolveSessionConnectionStatus(record);\n process.stderr.write(`${formatPromptSessionBannerLine(record, currentCwd, status)}\\n`);\n}\n\nexport function printCreatedSessionBanner(\n record: SessionRecord,\n agentName: string,\n format: OutputFormat,\n jsonStrict = false,\n): void {\n if (format === \"quiet\" || (jsonStrict && format === \"json\")) {\n return;\n }\n\n const label = formatSessionLabel(record);\n process.stderr.write(`[acpx] created session ${label} (${record.acpxRecordId})\\n`);\n process.stderr.write(`[acpx] agent: ${agentName}\\n`);\n process.stderr.write(`[acpx] cwd: ${record.cwd}\\n`);\n}\n\nfunction formatBytes(bytes: number): string {\n if (bytes >= 1_073_741_824) {\n return `${(bytes / 1_073_741_824).toFixed(1)} GB`;\n }\n if (bytes >= 1_048_576) {\n return `${(bytes / 1_048_576).toFixed(1)} MB`;\n }\n if (bytes >= 1024) {\n return `${(bytes / 1024).toFixed(1)} KB`;\n }\n return `${bytes} B`;\n}\n\nexport function printPruneResultByFormat(\n result: { pruned: SessionRecord[]; bytesFreed: number; dryRun: boolean },\n format: OutputFormat,\n): void {\n const count = result.pruned.length;\n\n if (\n emitJsonResult(format, {\n action: result.dryRun ? \"sessions_prune_dry_run\" : \"sessions_pruned\",\n dryRun: result.dryRun,\n count,\n bytesFreed: result.bytesFreed,\n pruned: result.pruned.map((r) => r.acpxRecordId),\n })\n ) {\n return;\n }\n\n if (format === \"quiet\") {\n for (const record of result.pruned) {\n process.stdout.write(`${record.acpxRecordId}\\n`);\n }\n return;\n }\n\n if (count === 0) {\n process.stdout.write(\n result.dryRun ? \"[DRY RUN] No sessions to prune\\n\" : \"No sessions pruned\\n\",\n );\n return;\n }\n\n const prefix = result.dryRun ? \"[DRY RUN] Would prune\" : \"Pruned\";\n const bytesSuffix =\n !result.dryRun && result.bytesFreed > 0 ? `, freed ${formatBytes(result.bytesFreed)}` : \"\";\n process.stdout.write(`${prefix} ${count} session${count === 1 ? \"\" : \"s\"}${bytesSuffix}\\n`);\n\n for (const record of result.pruned) {\n const label = record.name ? ` (${record.name})` : \"\";\n process.stdout.write(\n ` ${record.acpxRecordId}${label}\\t${record.closedAt ?? record.lastUsedAt}\\n`,\n );\n }\n}\n\nexport function agentSessionIdPayload(agentSessionId: string | undefined): {\n agentSessionId?: string;\n} {\n const normalized = normalizeRuntimeSessionId(agentSessionId);\n if (!normalized) {\n return {};\n }\n\n return { agentSessionId: normalized };\n}\n"],"mappings":"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"}
@@ -1,13 +0,0 @@
1
- //#region \0rolldown/runtime.js
2
- var __defProp = Object.defineProperty;
3
- var __exportAll = (all, no_symbols) => {
4
- let target = {};
5
- for (var name in all) __defProp(target, name, {
6
- get: all[name],
7
- enumerable: true
8
- });
9
- if (!no_symbols) __defProp(target, Symbol.toStringTag, { value: "Module" });
10
- return target;
11
- };
12
- //#endregion
13
- export { __exportAll as t };