@roackb2/heddle 0.0.7 → 0.0.9

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 (248) hide show
  1. package/README.md +207 -3
  2. package/dist/examples/cyberloop-observer.d.ts +3 -0
  3. package/dist/examples/cyberloop-observer.d.ts.map +1 -0
  4. package/dist/examples/cyberloop-observer.js +79 -0
  5. package/dist/examples/cyberloop-observer.js.map +1 -0
  6. package/dist/examples/heartbeat.d.ts +2 -0
  7. package/dist/examples/heartbeat.d.ts.map +1 -0
  8. package/dist/examples/heartbeat.js +61 -0
  9. package/dist/examples/heartbeat.js.map +1 -0
  10. package/dist/examples/host-events.d.ts +15 -0
  11. package/dist/examples/host-events.d.ts.map +1 -0
  12. package/dist/examples/host-events.js +233 -0
  13. package/dist/examples/host-events.js.map +1 -0
  14. package/dist/examples/programmatic-loop.d.ts +2 -0
  15. package/dist/examples/programmatic-loop.d.ts.map +1 -0
  16. package/dist/examples/programmatic-loop.js +128 -0
  17. package/dist/examples/programmatic-loop.js.map +1 -0
  18. package/dist/src/cli/ask.d.ts.map +1 -1
  19. package/dist/src/cli/ask.js +10 -41
  20. package/dist/src/cli/ask.js.map +1 -1
  21. package/dist/src/cli/chat/App.d.ts.map +1 -1
  22. package/dist/src/cli/chat/App.js +48 -0
  23. package/dist/src/cli/chat/App.js.map +1 -1
  24. package/dist/src/cli/chat/hooks/useAgentRun.d.ts +9 -0
  25. package/dist/src/cli/chat/hooks/useAgentRun.d.ts.map +1 -1
  26. package/dist/src/cli/chat/hooks/useAgentRun.js +47 -26
  27. package/dist/src/cli/chat/hooks/useAgentRun.js.map +1 -1
  28. package/dist/src/cli/chat/state/local-commands.d.ts +3 -0
  29. package/dist/src/cli/chat/state/local-commands.d.ts.map +1 -1
  30. package/dist/src/cli/chat/state/local-commands.js +21 -0
  31. package/dist/src/cli/chat/state/local-commands.js.map +1 -1
  32. package/dist/src/cli/chat/state/storage.d.ts.map +1 -1
  33. package/dist/src/cli/chat/state/storage.js +2 -0
  34. package/dist/src/cli/chat/state/storage.js.map +1 -1
  35. package/dist/src/cli/chat/state/types.d.ts +1 -0
  36. package/dist/src/cli/chat/state/types.d.ts.map +1 -1
  37. package/dist/src/cli/chat/submit.d.ts +3 -0
  38. package/dist/src/cli/chat/submit.d.ts.map +1 -1
  39. package/dist/src/cli/chat/submit.js +3 -0
  40. package/dist/src/cli/chat/submit.js.map +1 -1
  41. package/dist/src/cli/chat/utils/format.d.ts.map +1 -1
  42. package/dist/src/cli/chat/utils/format.js +6 -0
  43. package/dist/src/cli/chat/utils/format.js.map +1 -1
  44. package/dist/src/cli/chat/utils/runtime.d.ts.map +1 -1
  45. package/dist/src/cli/chat/utils/runtime.js +3 -19
  46. package/dist/src/cli/chat/utils/runtime.js.map +1 -1
  47. package/dist/src/cli/main.js +0 -0
  48. package/dist/src/index.d.ts +16 -0
  49. package/dist/src/index.d.ts.map +1 -1
  50. package/dist/src/index.js +9 -0
  51. package/dist/src/index.js.map +1 -1
  52. package/dist/src/integrations/cyberloop-kinematics.d.ts +16 -0
  53. package/dist/src/integrations/cyberloop-kinematics.d.ts.map +1 -0
  54. package/dist/src/integrations/cyberloop-kinematics.js +77 -0
  55. package/dist/src/integrations/cyberloop-kinematics.js.map +1 -0
  56. package/dist/src/integrations/cyberloop.d.ts +88 -0
  57. package/dist/src/integrations/cyberloop.d.ts.map +1 -0
  58. package/dist/src/integrations/cyberloop.js +244 -0
  59. package/dist/src/integrations/cyberloop.js.map +1 -0
  60. package/dist/src/llm/factory.d.ts +1 -1
  61. package/dist/src/llm/factory.d.ts.map +1 -1
  62. package/dist/src/llm/factory.js +2 -19
  63. package/dist/src/llm/factory.js.map +1 -1
  64. package/dist/src/llm/providers.d.ts +3 -0
  65. package/dist/src/llm/providers.d.ts.map +1 -0
  66. package/dist/src/llm/providers.js +21 -0
  67. package/dist/src/llm/providers.js.map +1 -0
  68. package/dist/src/run-agent.d.ts +3 -1
  69. package/dist/src/run-agent.d.ts.map +1 -1
  70. package/dist/src/run-agent.js +10 -0
  71. package/dist/src/run-agent.js.map +1 -1
  72. package/dist/src/runtime/agent-loop.d.ts +42 -0
  73. package/dist/src/runtime/agent-loop.d.ts.map +1 -0
  74. package/dist/src/runtime/agent-loop.js +173 -0
  75. package/dist/src/runtime/agent-loop.js.map +1 -0
  76. package/dist/src/runtime/api-keys.d.ts +8 -0
  77. package/dist/src/runtime/api-keys.d.ts.map +1 -0
  78. package/dist/src/runtime/api-keys.js +25 -0
  79. package/dist/src/runtime/api-keys.js.map +1 -0
  80. package/dist/src/runtime/default-tools.d.ts +12 -0
  81. package/dist/src/runtime/default-tools.d.ts.map +1 -0
  82. package/dist/src/runtime/default-tools.js +40 -0
  83. package/dist/src/runtime/default-tools.js.map +1 -0
  84. package/dist/src/runtime/events.d.ts +128 -0
  85. package/dist/src/runtime/events.d.ts.map +1 -0
  86. package/dist/src/runtime/events.js +41 -0
  87. package/dist/src/runtime/events.js.map +1 -0
  88. package/dist/src/runtime/heartbeat-store.d.ts +20 -0
  89. package/dist/src/runtime/heartbeat-store.d.ts.map +1 -0
  90. package/dist/src/runtime/heartbeat-store.js +42 -0
  91. package/dist/src/runtime/heartbeat-store.js.map +1 -0
  92. package/dist/src/runtime/heartbeat.d.ts +39 -0
  93. package/dist/src/runtime/heartbeat.d.ts.map +1 -0
  94. package/dist/src/runtime/heartbeat.js +117 -0
  95. package/dist/src/runtime/heartbeat.js.map +1 -0
  96. package/dist/src/trace/format.d.ts.map +1 -1
  97. package/dist/src/trace/format.js +8 -0
  98. package/dist/src/trace/format.js.map +1 -1
  99. package/dist/src/types.d.ts +8 -0
  100. package/dist/src/types.d.ts.map +1 -1
  101. package/dist/src/utils/logger.d.ts.map +1 -1
  102. package/dist/src/utils/logger.js +2 -2
  103. package/dist/src/utils/logger.js.map +1 -1
  104. package/package.json +31 -2
  105. package/dist/src/__tests__/chat-activity-format.test.d.ts +0 -2
  106. package/dist/src/__tests__/chat-activity-format.test.d.ts.map +0 -1
  107. package/dist/src/__tests__/chat-activity-format.test.js +0 -41
  108. package/dist/src/__tests__/chat-activity-format.test.js.map +0 -1
  109. package/dist/src/__tests__/chat-compaction.test.d.ts +0 -2
  110. package/dist/src/__tests__/chat-compaction.test.d.ts.map +0 -1
  111. package/dist/src/__tests__/chat-compaction.test.js +0 -63
  112. package/dist/src/__tests__/chat-compaction.test.js.map +0 -1
  113. package/dist/src/__tests__/chat-format.test.d.ts +0 -2
  114. package/dist/src/__tests__/chat-format.test.d.ts.map +0 -1
  115. package/dist/src/__tests__/chat-format.test.js +0 -137
  116. package/dist/src/__tests__/chat-format.test.js.map +0 -1
  117. package/dist/src/__tests__/chat-runtime.test.d.ts +0 -2
  118. package/dist/src/__tests__/chat-runtime.test.d.ts.map +0 -1
  119. package/dist/src/__tests__/chat-runtime.test.js +0 -39
  120. package/dist/src/__tests__/chat-runtime.test.js.map +0 -1
  121. package/dist/src/__tests__/core-utils.test.d.ts +0 -2
  122. package/dist/src/__tests__/core-utils.test.d.ts.map +0 -1
  123. package/dist/src/__tests__/core-utils.test.js +0 -87
  124. package/dist/src/__tests__/core-utils.test.js.map +0 -1
  125. package/dist/src/__tests__/file-mentions.test.d.ts +0 -2
  126. package/dist/src/__tests__/file-mentions.test.d.ts.map +0 -1
  127. package/dist/src/__tests__/file-mentions.test.js +0 -29
  128. package/dist/src/__tests__/file-mentions.test.js.map +0 -1
  129. package/dist/src/__tests__/llm-factory.test.d.ts +0 -2
  130. package/dist/src/__tests__/llm-factory.test.d.ts.map +0 -1
  131. package/dist/src/__tests__/llm-factory.test.js +0 -45
  132. package/dist/src/__tests__/llm-factory.test.js.map +0 -1
  133. package/dist/src/__tests__/local-commands.test.d.ts +0 -2
  134. package/dist/src/__tests__/local-commands.test.d.ts.map +0 -1
  135. package/dist/src/__tests__/local-commands.test.js +0 -153
  136. package/dist/src/__tests__/local-commands.test.js.map +0 -1
  137. package/dist/src/__tests__/project-approval-rules.test.d.ts +0 -2
  138. package/dist/src/__tests__/project-approval-rules.test.d.ts.map +0 -1
  139. package/dist/src/__tests__/project-approval-rules.test.js +0 -135
  140. package/dist/src/__tests__/project-approval-rules.test.js.map +0 -1
  141. package/dist/src/__tests__/prompt-input.test.d.ts +0 -2
  142. package/dist/src/__tests__/prompt-input.test.d.ts.map +0 -1
  143. package/dist/src/__tests__/prompt-input.test.js +0 -57
  144. package/dist/src/__tests__/prompt-input.test.js.map +0 -1
  145. package/dist/src/__tests__/prompts.test.d.ts +0 -2
  146. package/dist/src/__tests__/prompts.test.d.ts.map +0 -1
  147. package/dist/src/__tests__/prompts.test.js +0 -46
  148. package/dist/src/__tests__/prompts.test.js.map +0 -1
  149. package/dist/src/__tests__/run-agent.test.d.ts +0 -2
  150. package/dist/src/__tests__/run-agent.test.d.ts.map +0 -1
  151. package/dist/src/__tests__/run-agent.test.js +0 -1276
  152. package/dist/src/__tests__/run-agent.test.js.map +0 -1
  153. package/dist/src/__tests__/run-shell.command.test.d.ts +0 -2
  154. package/dist/src/__tests__/run-shell.command.test.d.ts.map +0 -1
  155. package/dist/src/__tests__/run-shell.command.test.js +0 -188
  156. package/dist/src/__tests__/run-shell.command.test.js.map +0 -1
  157. package/dist/src/__tests__/smoke.test.d.ts +0 -2
  158. package/dist/src/__tests__/smoke.test.d.ts.map +0 -1
  159. package/dist/src/__tests__/smoke.test.js +0 -314
  160. package/dist/src/__tests__/smoke.test.js.map +0 -1
  161. package/dist/src/__tests__/tools.test.d.ts +0 -2
  162. package/dist/src/__tests__/tools.test.d.ts.map +0 -1
  163. package/dist/src/__tests__/tools.test.js +0 -698
  164. package/dist/src/__tests__/tools.test.js.map +0 -1
  165. package/dist/src/__tests__/trace-format.test.d.ts +0 -2
  166. package/dist/src/__tests__/trace-format.test.d.ts.map +0 -1
  167. package/dist/src/__tests__/trace-format.test.js +0 -148
  168. package/dist/src/__tests__/trace-format.test.js.map +0 -1
  169. package/dist/src/cli/chat/actions.d.ts +0 -47
  170. package/dist/src/cli/chat/actions.d.ts.map +0 -1
  171. package/dist/src/cli/chat/actions.js +0 -215
  172. package/dist/src/cli/chat/actions.js.map +0 -1
  173. package/dist/src/cli/chat/format.d.ts +0 -23
  174. package/dist/src/cli/chat/format.d.ts.map +0 -1
  175. package/dist/src/cli/chat/format.js +0 -243
  176. package/dist/src/cli/chat/format.js.map +0 -1
  177. package/dist/src/cli/chat/local-commands.d.ts +0 -17
  178. package/dist/src/cli/chat/local-commands.d.ts.map +0 -1
  179. package/dist/src/cli/chat/local-commands.js +0 -180
  180. package/dist/src/cli/chat/local-commands.js.map +0 -1
  181. package/dist/src/cli/chat/panels.d.ts +0 -37
  182. package/dist/src/cli/chat/panels.d.ts.map +0 -1
  183. package/dist/src/cli/chat/panels.js +0 -142
  184. package/dist/src/cli/chat/panels.js.map +0 -1
  185. package/dist/src/cli/chat/runtime.d.ts +0 -26
  186. package/dist/src/cli/chat/runtime.d.ts.map +0 -1
  187. package/dist/src/cli/chat/runtime.js +0 -28
  188. package/dist/src/cli/chat/runtime.js.map +0 -1
  189. package/dist/src/cli/chat/storage.d.ts +0 -13
  190. package/dist/src/cli/chat/storage.d.ts.map +0 -1
  191. package/dist/src/cli/chat/storage.js +0 -126
  192. package/dist/src/cli/chat/storage.js.map +0 -1
  193. package/dist/src/cli/chat/types.d.ts +0 -51
  194. package/dist/src/cli/chat/types.d.ts.map +0 -1
  195. package/dist/src/cli/chat/types.js +0 -2
  196. package/dist/src/cli/chat/types.js.map +0 -1
  197. package/dist/src/cli/chat/use-run-state.d.ts +0 -23
  198. package/dist/src/cli/chat/use-run-state.d.ts.map +0 -1
  199. package/dist/src/cli/chat/use-run-state.js +0 -118
  200. package/dist/src/cli/chat/use-run-state.js.map +0 -1
  201. package/dist/src/cli/chat/use-sessions.d.ts +0 -21
  202. package/dist/src/cli/chat/use-sessions.d.ts.map +0 -1
  203. package/dist/src/cli/chat/use-sessions.js +0 -111
  204. package/dist/src/cli/chat/use-sessions.js.map +0 -1
  205. package/dist/src/cli/chat-actions.d.ts +0 -47
  206. package/dist/src/cli/chat-actions.d.ts.map +0 -1
  207. package/dist/src/cli/chat-actions.js +0 -215
  208. package/dist/src/cli/chat-actions.js.map +0 -1
  209. package/dist/src/cli/chat-format.d.ts +0 -23
  210. package/dist/src/cli/chat-format.d.ts.map +0 -1
  211. package/dist/src/cli/chat-format.js +0 -243
  212. package/dist/src/cli/chat-format.js.map +0 -1
  213. package/dist/src/cli/chat-local-commands.d.ts +0 -17
  214. package/dist/src/cli/chat-local-commands.d.ts.map +0 -1
  215. package/dist/src/cli/chat-local-commands.js +0 -180
  216. package/dist/src/cli/chat-local-commands.js.map +0 -1
  217. package/dist/src/cli/chat-panels.d.ts +0 -37
  218. package/dist/src/cli/chat-panels.d.ts.map +0 -1
  219. package/dist/src/cli/chat-panels.js +0 -142
  220. package/dist/src/cli/chat-panels.js.map +0 -1
  221. package/dist/src/cli/chat-runtime.d.ts +0 -26
  222. package/dist/src/cli/chat-runtime.d.ts.map +0 -1
  223. package/dist/src/cli/chat-runtime.js +0 -28
  224. package/dist/src/cli/chat-runtime.js.map +0 -1
  225. package/dist/src/cli/chat-storage.d.ts +0 -13
  226. package/dist/src/cli/chat-storage.d.ts.map +0 -1
  227. package/dist/src/cli/chat-storage.js +0 -126
  228. package/dist/src/cli/chat-storage.js.map +0 -1
  229. package/dist/src/cli/chat-submit.d.ts +0 -28
  230. package/dist/src/cli/chat-submit.d.ts.map +0 -1
  231. package/dist/src/cli/chat-submit.js +0 -90
  232. package/dist/src/cli/chat-submit.js.map +0 -1
  233. package/dist/src/cli/chat-types.d.ts +0 -51
  234. package/dist/src/cli/chat-types.d.ts.map +0 -1
  235. package/dist/src/cli/chat-types.js +0 -2
  236. package/dist/src/cli/chat-types.js.map +0 -1
  237. package/dist/src/cli/chat.d.ts +0 -4
  238. package/dist/src/cli/chat.d.ts.map +0 -1
  239. package/dist/src/cli/chat.js +0 -153
  240. package/dist/src/cli/chat.js.map +0 -1
  241. package/dist/src/cli/useChatRunState.d.ts +0 -23
  242. package/dist/src/cli/useChatRunState.d.ts.map +0 -1
  243. package/dist/src/cli/useChatRunState.js +0 -118
  244. package/dist/src/cli/useChatRunState.js.map +0 -1
  245. package/dist/src/cli/useChatSessions.d.ts +0 -21
  246. package/dist/src/cli/useChatSessions.d.ts.map +0 -1
  247. package/dist/src/cli/useChatSessions.js +0 -111
  248. package/dist/src/cli/useChatSessions.js.map +0 -1
@@ -0,0 +1,117 @@
1
+ import { runAgentLoop } from './agent-loop.js';
2
+ import { createAgentLoopCheckpoint } from './events.js';
3
+ const DEFAULT_HEARTBEAT_MAX_STEPS = 80;
4
+ export async function runAgentHeartbeat(options) {
5
+ const result = await runAgentLoop({
6
+ goal: buildHeartbeatGoal(options.task),
7
+ model: options.model,
8
+ apiKey: options.apiKey,
9
+ maxSteps: options.maxSteps ?? DEFAULT_HEARTBEAT_MAX_STEPS,
10
+ workspaceRoot: options.workspaceRoot,
11
+ stateDir: options.stateDir,
12
+ memoryDir: options.memoryDir,
13
+ searchIgnoreDirs: options.searchIgnoreDirs,
14
+ systemContext: appendHeartbeatSystemContext(options.systemContext),
15
+ history: options.history,
16
+ resumeFrom: options.checkpoint,
17
+ llm: options.llm,
18
+ tools: options.tools,
19
+ extraTools: options.extraTools,
20
+ includeDefaultTools: options.includeDefaultTools,
21
+ includePlanTool: options.includePlanTool,
22
+ logger: options.logger,
23
+ onEvent: options.onEvent,
24
+ approveToolCall: options.approveToolCall,
25
+ shouldStop: options.shouldStop,
26
+ abortSignal: options.abortSignal,
27
+ });
28
+ const decision = inferHeartbeatDecision(result.summary, result.outcome);
29
+ const runId = result.state.runId;
30
+ const checkpoint = createAgentLoopCheckpoint(result.state);
31
+ const now = () => new Date().toISOString();
32
+ options.onEvent?.({
33
+ type: 'heartbeat.decision',
34
+ runId,
35
+ decision,
36
+ outcome: result.outcome,
37
+ summary: result.summary,
38
+ timestamp: now(),
39
+ });
40
+ if (decision === 'escalate') {
41
+ options.onEvent?.({
42
+ type: 'escalation.required',
43
+ runId,
44
+ task: options.task,
45
+ outcome: result.outcome,
46
+ summary: result.summary,
47
+ step: result.trace.length,
48
+ timestamp: now(),
49
+ });
50
+ }
51
+ options.onEvent?.({
52
+ type: 'checkpoint.saved',
53
+ runId,
54
+ checkpoint,
55
+ step: result.trace.length,
56
+ timestamp: now(),
57
+ });
58
+ return {
59
+ decision,
60
+ summary: result.summary,
61
+ checkpoint,
62
+ state: result.state,
63
+ };
64
+ }
65
+ function buildHeartbeatGoal(task) {
66
+ return [
67
+ 'Heartbeat wake cycle.',
68
+ '',
69
+ 'Durable task:',
70
+ task,
71
+ '',
72
+ 'Work autonomously on the task if there is useful, safe progress to make now.',
73
+ 'Do not wait for a chat message.',
74
+ 'If blocked, risky, or user input is required, escalate clearly instead of guessing.',
75
+ '',
76
+ 'End your response with exactly one decision line:',
77
+ 'HEARTBEAT_DECISION: continue | pause | complete | escalate',
78
+ ].join('\n');
79
+ }
80
+ function appendHeartbeatSystemContext(systemContext) {
81
+ const heartbeatContext = [
82
+ '## Heartbeat Mode',
83
+ '',
84
+ 'This run was started by an autonomous heartbeat, not by a live chat message.',
85
+ 'Operate within the available tools and approval policy.',
86
+ 'Make bounded useful progress, update durable memory when appropriate, and stop cleanly.',
87
+ 'Escalate only when human input, credentials, policy approval, or risky judgment is required.',
88
+ 'The required final decision line is: HEARTBEAT_DECISION: continue | pause | complete | escalate',
89
+ ].join('\n');
90
+ return systemContext ? `${systemContext}\n\n${heartbeatContext}` : heartbeatContext;
91
+ }
92
+ function inferHeartbeatDecision(summary, outcome) {
93
+ const match = summary.match(/HEARTBEAT_DECISION:\s*(continue|pause|complete|escalate)\b/i);
94
+ if (match) {
95
+ return match[1].toLowerCase();
96
+ }
97
+ if (outcome === 'done') {
98
+ return 'pause';
99
+ }
100
+ return 'escalate';
101
+ }
102
+ function inferEscalationReason(summary, outcome) {
103
+ if (outcome === 'max_steps') {
104
+ return 'max_steps_reached';
105
+ }
106
+ if (outcome === 'error') {
107
+ return 'error';
108
+ }
109
+ if (/blocked|risk|unapproved|policy/i.test(summary)) {
110
+ return 'policy_violation';
111
+ }
112
+ if (/input|user|human|question/i.test(summary)) {
113
+ return 'human_input_required';
114
+ }
115
+ return 'risk_detected';
116
+ }
117
+ //# sourceMappingURL=heartbeat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heartbeat.js","sourceRoot":"","sources":["../../../src/runtime/heartbeat.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"format.d.ts","sourceRoot":"","sources":["../../../src/trace/format.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAa9C;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,MAAM,CAqGjE"}
1
+ {"version":3,"file":"format.d.ts","sourceRoot":"","sources":["../../../src/trace/format.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAa9C;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,MAAM,CAmHjE"}
@@ -66,6 +66,14 @@ export function formatTraceForConsole(trace) {
66
66
  lines.push(`${color} ${status} ${event.tool}${COLORS.reset}: ${content}`, '');
67
67
  break;
68
68
  }
69
+ case 'cyberloop.annotation': {
70
+ const color = event.driftLevel === 'high' ? COLORS.red
71
+ : event.driftLevel === 'medium' ? COLORS.yellow
72
+ : event.driftLevel === 'low' ? COLORS.green
73
+ : COLORS.dim;
74
+ lines.push(`${color} [step ${event.step}]${COLORS.reset} ${COLORS.bold}CyberLoop:${COLORS.reset} drift=${event.driftLevel} frame=${event.frameKind}${event.requestedHalt ? ' halt-requested' : ''}`, ` Metadata: ${truncate(JSON.stringify(event.metadata), 500)}`, '');
75
+ break;
76
+ }
69
77
  case 'run.finished': {
70
78
  const outcomeColor = event.outcome === 'done' ? COLORS.green
71
79
  : event.outcome === 'max_steps' ? COLORS.yellow
@@ -1 +1 @@
1
- {"version":3,"file":"format.js","sourceRoot":"","sources":["../../../src/trace/format.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"format.js","sourceRoot":"","sources":["../../../src/trace/format.ts"],"names":[],"mappings":"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"}
@@ -90,6 +90,14 @@ export type TraceEvent = {
90
90
  result: ToolResult;
91
91
  step: number;
92
92
  timestamp: string;
93
+ } | {
94
+ type: 'cyberloop.annotation';
95
+ step: number;
96
+ frameKind: string;
97
+ driftLevel: 'unknown' | 'low' | 'medium' | 'high';
98
+ requestedHalt: boolean;
99
+ metadata: Record<string, unknown>;
100
+ timestamp: string;
93
101
  } | {
94
102
  type: 'run.finished';
95
103
  outcome: StopReason;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/utils/logger.ts"],"names":[],"mappings":"AAMA,OAAO,IAAI,MAAM,MAAM,CAAC;AAGxB,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAEF;;;GAGG;AACH,wBAAgB,YAAY,CAAC,OAAO,GAAE,mBAAwB,GAAG,IAAI,CAAC,MAAM,CAoC3E;AAED;;GAEG;AACH,eAAO,MAAM,MAAM,6BAAiB,CAAC"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/utils/logger.ts"],"names":[],"mappings":"AAMA,OAAO,IAAI,MAAM,MAAM,CAAC;AAGxB,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAEF;;;GAGG;AACH,wBAAgB,YAAY,CAAC,OAAO,GAAE,mBAAwB,GAAG,IAAI,CAAC,MAAM,CAoC3E;AAED;;GAEG;AACH,eAAO,MAAM,MAAM,6BAA4C,CAAC"}
@@ -39,12 +39,12 @@ export function createLogger(options = {}) {
39
39
  });
40
40
  }
41
41
  if (streams.length === 0) {
42
- return pino({ level }, pino.destination('/dev/null'));
42
+ return pino({ level, enabled: false });
43
43
  }
44
44
  return pino({ level }, pino.multistream(streams));
45
45
  }
46
46
  /**
47
47
  * Default logger instance.
48
48
  */
49
- export const logger = createLogger();
49
+ export const logger = pino({ level: 'silent', enabled: false });
50
50
  //# sourceMappingURL=logger.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/utils/logger.ts"],"names":[],"mappings":"AAAA,8EAA8E;AAC9E,8DAA8D;AAC9D,8EAA8E;AAE9E,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,UAAU,MAAM,aAAa,CAAC;AASrC;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,UAA+B,EAAE;IAC5D,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,MAAM,CAAC;IACtC,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,CAAC;IAC7E,MAAM,aAAa,GAAG,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC;IAC9C,MAAM,OAAO,GAAuB,EAAE,CAAC;IAEvC,IAAI,aAAa,EAAE,CAAC;QAClB,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,CAAC,IAAI,CAAC;gBACX,MAAM,EAAE,UAAU,CAAC;oBACjB,QAAQ,EAAE,IAAI;oBACd,aAAa,EAAE,YAAY;oBAC3B,MAAM,EAAE,cAAc;iBACvB,CAAC;aACH,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;QACxB,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7D,OAAO,CAAC,IAAI,CAAC;YACX,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC;gBACvB,IAAI,EAAE,OAAO,CAAC,WAAW;gBACzB,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,IAAI;aACZ,CAAC;SACH,CAAC,CAAC;IACL,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,OAAO,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;AACpD,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,YAAY,EAAE,CAAC"}
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/utils/logger.ts"],"names":[],"mappings":"AAAA,8EAA8E;AAC9E,8DAA8D;AAC9D,8EAA8E;AAE9E,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,UAAU,MAAM,aAAa,CAAC;AASrC;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,UAA+B,EAAE;IAC5D,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,MAAM,CAAC;IACtC,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,CAAC;IAC7E,MAAM,aAAa,GAAG,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC;IAC9C,MAAM,OAAO,GAAuB,EAAE,CAAC;IAEvC,IAAI,aAAa,EAAE,CAAC;QAClB,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,CAAC,IAAI,CAAC;gBACX,MAAM,EAAE,UAAU,CAAC;oBACjB,QAAQ,EAAE,IAAI;oBACd,aAAa,EAAE,YAAY;oBAC3B,MAAM,EAAE,cAAc;iBACvB,CAAC;aACH,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;QACxB,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7D,OAAO,CAAC,IAAI,CAAC;YACX,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC;gBACvB,IAAI,EAAE,OAAO,CAAC,WAAW;gBACzB,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,IAAI;aACZ,CAAC;SACH,CAAC,CAAC;IACL,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,OAAO,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;AACpD,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@roackb2/heddle",
3
- "version": "0.0.7",
3
+ "version": "0.0.9",
4
4
  "description": "An open-source terminal coding agent runtime and CLI with OpenAI and Anthropic support",
5
5
  "author": "Jay / Fienna Liang <roackb2@gmail.com>",
6
6
  "license": "MIT",
@@ -26,12 +26,19 @@
26
26
  "types": "dist/src/index.d.ts",
27
27
  "files": [
28
28
  "dist",
29
+ "!dist/src/__tests__",
30
+ "!dist/src/**/*.test.*",
29
31
  "README.md",
30
32
  "LICENSE"
31
33
  ],
32
34
  "scripts": {
33
- "build": "tsc",
35
+ "clean": "node scripts/clean-dist.mjs",
36
+ "build": "yarn clean && tsc -p tsconfig.build.json",
34
37
  "dev": "tsx --no-cache examples/repo-investigator.ts",
38
+ "example:programmatic": "tsx --no-cache examples/programmatic-loop.ts",
39
+ "example:heartbeat": "tsx --no-cache examples/heartbeat.ts",
40
+ "example:host-events": "tsx --no-cache examples/host-events.ts",
41
+ "example:cyberloop-observer": "tsx --no-cache examples/cyberloop-observer.ts",
35
42
  "chat": "tsx --no-cache examples/conversation.tsx",
36
43
  "chat:light": "OPENAI_MODEL=gpt-5.1-codex-mini tsx --no-cache examples/conversation.tsx",
37
44
  "repo-investigator:dev": "OPENAI_API_KEY=\"$PERSONAL_OPENAI_API_KEY\" tsx --no-cache examples/repo-investigator.ts",
@@ -45,9 +52,22 @@
45
52
  "keywords": [
46
53
  "agent",
47
54
  "coding-agent",
55
+ "agentic-coding",
56
+ "agent-runtime",
57
+ "agent-framework",
58
+ "ai-agent",
48
59
  "terminal-agent",
49
60
  "cli-agent",
61
+ "llm-agent",
50
62
  "ai-cli",
63
+ "autonomous-agent",
64
+ "heartbeat",
65
+ "long-running-agent",
66
+ "agent-observability",
67
+ "semantic-drift",
68
+ "persistent-memory",
69
+ "agent-memory",
70
+ "knowledge-persistence",
51
71
  "developer-tools",
52
72
  "workspace-agent",
53
73
  "repository-tools",
@@ -59,6 +79,14 @@
59
79
  "trace",
60
80
  "chat"
61
81
  ],
82
+ "peerDependencies": {
83
+ "cyberloop": "^1.0.0"
84
+ },
85
+ "peerDependenciesMeta": {
86
+ "cyberloop": {
87
+ "optional": true
88
+ }
89
+ },
62
90
  "dependencies": {
63
91
  "@anthropic-ai/sdk": "^0.54.0",
64
92
  "@inkjs/ui": "^2.0.0",
@@ -71,6 +99,7 @@
71
99
  "@types/node": "^22.13.10",
72
100
  "@types/react": "^19.2.14",
73
101
  "@vitest/coverage-v8": "^4.1.2",
102
+ "cyberloop": "^1.0.0",
74
103
  "pino-pretty": "^13.1.3",
75
104
  "tsx": "^4.19.3",
76
105
  "typescript": "^5.8.2",
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=chat-activity-format.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-activity-format.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/chat-activity-format.test.ts"],"names":[],"mappings":""}
@@ -1,41 +0,0 @@
1
- import { describe, expect, it } from 'vitest';
2
- import { summarizeToolCall, toLiveEvent } from '../cli/chat/utils/format.js';
3
- describe('chat activity formatting', () => {
4
- it('includes read_file paths in tool call summaries', () => {
5
- expect(summarizeToolCall('read_file', { path: 'docs/framework-vision.md' })).toBe('read_file (docs/framework-vision.md)');
6
- });
7
- it('includes list_files paths in tool call summaries', () => {
8
- expect(summarizeToolCall('list_files', { path: 'src/cli/chat' })).toBe('list_files (src/cli/chat)');
9
- });
10
- it('includes search_files query and path in tool call summaries', () => {
11
- expect(summarizeToolCall('search_files', { query: 'trace-1775195542429', path: '.heddle/traces' })).toBe('search_files ("trace-1775195542429" in .heddle/traces)');
12
- });
13
- it('includes read paths in live activity events', () => {
14
- const event = {
15
- type: 'tool.call',
16
- call: { id: 'call-1', tool: 'read_file', input: { path: 'README.md' } },
17
- step: 1,
18
- timestamp: '2024-01-01T00:00:00Z',
19
- };
20
- expect(toLiveEvent(event)).toBe('running read_file (README.md)');
21
- });
22
- it('includes list paths in approval activity events', () => {
23
- const event = {
24
- type: 'tool.approval_requested',
25
- call: { id: 'call-2', tool: 'list_files', input: { path: 'src' } },
26
- step: 2,
27
- timestamp: '2024-01-01T00:00:01Z',
28
- };
29
- expect(toLiveEvent(event)).toBe('approval needed for list_files (src)');
30
- });
31
- it('includes search query details in live activity events', () => {
32
- const event = {
33
- type: 'tool.call',
34
- call: { id: 'call-3', tool: 'search_files', input: { query: 'trace', path: '.heddle/traces' } },
35
- step: 3,
36
- timestamp: '2024-01-01T00:00:02Z',
37
- };
38
- expect(toLiveEvent(event)).toBe('running search_files ("trace" in .heddle/traces)');
39
- });
40
- });
41
- //# sourceMappingURL=chat-activity-format.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-activity-format.test.js","sourceRoot":"","sources":["../../../src/__tests__/chat-activity-format.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAG7E,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACxC,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,CAAC,iBAAiB,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,0BAA0B,EAAE,CAAC,CAAC,CAAC,IAAI,CAC/E,sCAAsC,CACvC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,CAAC,iBAAiB,CAAC,YAAY,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC,IAAI,CACpE,2BAA2B,CAC5B,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,MAAM,CAAC,iBAAiB,CAAC,cAAc,EAAE,EAAE,KAAK,EAAE,qBAAqB,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC,IAAI,CACtG,wDAAwD,CACzD,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,KAAK,GAAe;YACxB,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE;YACvE,IAAI,EAAE,CAAC;YACP,SAAS,EAAE,sBAAsB;SAClC,CAAC;QAEF,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,KAAK,GAAe;YACxB,IAAI,EAAE,yBAAyB;YAC/B,IAAI,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE;YAClE,IAAI,EAAE,CAAC;YACP,SAAS,EAAE,sBAAsB;SAClC,CAAC;QAEF,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,KAAK,GAAe;YACxB,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,EAAE;YAC/F,IAAI,EAAE,CAAC;YACP,SAAS,EAAE,sBAAsB;SAClC,CAAC;QAEF,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;IACtF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=chat-compaction.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-compaction.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/chat-compaction.test.ts"],"names":[],"mappings":""}
@@ -1,63 +0,0 @@
1
- import { describe, expect, it } from 'vitest';
2
- import { compactChatHistory, isCompactedHistorySummary } from '../cli/chat/state/compaction.js';
3
- import { buildConversationMessages } from '../cli/chat/utils/format.js';
4
- describe('chat history compaction', () => {
5
- it('compacts older transcript messages into a summary and keeps recent messages', () => {
6
- const history = Array.from({ length: 50 }).flatMap((_, index) => [
7
- { role: 'user', content: `User prompt ${index}: ${'u'.repeat(4000)}` },
8
- { role: 'assistant', content: `Assistant reply ${index}: ${'a'.repeat(4000)}` },
9
- ]);
10
- const compacted = compactChatHistory({
11
- history,
12
- model: 'gpt-4.1',
13
- });
14
- expect(isCompactedHistorySummary(compacted.history[0])).toBe(true);
15
- expect(compacted.history.length).toBeLessThan(history.length);
16
- expect(compacted.history.at(-1)).toEqual(history.at(-1));
17
- expect(compacted.history.at(-2)).toEqual(history.at(-2));
18
- expect(compacted.context.estimatedHistoryTokens).toBeLessThan(80_000);
19
- expect(compacted.context.compactedMessages).toBeGreaterThan(0);
20
- const visibleMessages = buildConversationMessages(compacted.history);
21
- expect(visibleMessages[0]?.text).toContain('Earlier conversation history was compacted');
22
- });
23
- it('can force a single manual compaction pass even before the auto threshold is exceeded', () => {
24
- const history = Array.from({ length: 6 }).flatMap((_, index) => [
25
- { role: 'user', content: `User prompt ${index}: ${'u'.repeat(60)}` },
26
- { role: 'assistant', content: `Assistant reply ${index}: ${'a'.repeat(60)}` },
27
- ]);
28
- const autoCompacted = compactChatHistory({
29
- history,
30
- model: 'gpt-5.1',
31
- });
32
- const manuallyCompacted = compactChatHistory({
33
- history,
34
- model: 'gpt-5.1',
35
- force: true,
36
- });
37
- expect(autoCompacted.history).toEqual(history);
38
- expect(isCompactedHistorySummary(manuallyCompacted.history[0])).toBe(true);
39
- expect(manuallyCompacted.history.length).toBeLessThan(history.length);
40
- expect(manuallyCompacted.context.compactedMessages).toBeGreaterThan(0);
41
- });
42
- it('can re-compact an already compacted short session when forced manually', () => {
43
- const history = [
44
- {
45
- role: 'system',
46
- content: 'Heddle compacted earlier conversation history.\n\nMore recent archived turns:\nAssistant: Earlier summary.',
47
- },
48
- { role: 'system', content: 'Host reminder: use the evidence you already gathered.' },
49
- { role: 'tool', toolCallId: 'tool-1', content: '{"ok":true,"output":"git diff --stat HEAD"}' },
50
- { role: 'user', content: 'can you try again' },
51
- { role: 'user', content: 'try again' },
52
- ];
53
- const compacted = compactChatHistory({
54
- history,
55
- model: 'gpt-5.1',
56
- force: true,
57
- });
58
- expect(compacted.history.length).toBeLessThan(history.length);
59
- expect(isCompactedHistorySummary(compacted.history[0])).toBe(true);
60
- expect(compacted.context.compactedMessages).toBeGreaterThan(0);
61
- });
62
- });
63
- //# sourceMappingURL=chat-compaction.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-compaction.test.js","sourceRoot":"","sources":["../../../src/__tests__/chat-compaction.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=chat-format.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-format.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/chat-format.test.ts"],"names":[],"mappings":""}
@@ -1,137 +0,0 @@
1
- import { describe, expect, it } from 'vitest';
2
- import { buildConversationMessages, formatChatFailureMessage, formatEditPreviewHistoryMessage, formatPlanHistoryMessage, } from '../cli/chat/utils/format.js';
3
- describe('buildConversationMessages', () => {
4
- it('renders successful edit_file tool results into visible conversation history', () => {
5
- const history = [
6
- { role: 'user', content: 'Update the file.' },
7
- {
8
- role: 'assistant',
9
- content: 'I will update the file.',
10
- toolCalls: [{ id: 'call-1', tool: 'edit_file', input: { path: 'src/example.ts', oldText: 'old', newText: 'new' } }],
11
- },
12
- {
13
- role: 'tool',
14
- toolCallId: 'call-1',
15
- content: JSON.stringify({
16
- ok: true,
17
- output: {
18
- path: 'src/example.ts',
19
- action: 'replaced',
20
- matchCount: 1,
21
- bytesWritten: 42,
22
- diff: {
23
- path: 'src/example.ts',
24
- action: 'replaced',
25
- diff: ['--- a/src/example.ts', '+++ b/src/example.ts', '@@ -1 +1 @@', '-const value = "old";', '+const value = "new";'].join('\n'),
26
- truncated: false,
27
- },
28
- },
29
- }),
30
- },
31
- { role: 'assistant', content: 'Done.' },
32
- ];
33
- const messages = buildConversationMessages(history);
34
- expect(messages).toHaveLength(4);
35
- expect(messages[2]).toMatchObject({
36
- role: 'assistant',
37
- text: expect.stringContaining('## Edited `src/example.ts`'),
38
- });
39
- expect(messages[2]?.text).toContain('Action: replaced');
40
- expect(messages[2]?.text).toContain('Matches changed: 1');
41
- expect(messages[2]?.text).toContain('```diff');
42
- expect(messages[2]?.text).toContain('+const value = "new";');
43
- });
44
- it('does not render non-edit tool results into conversation history', () => {
45
- const history = [
46
- { role: 'user', content: 'Inspect the repo.' },
47
- {
48
- role: 'assistant',
49
- content: 'I will inspect.',
50
- toolCalls: [{ id: 'call-1', tool: 'list_files', input: { path: '.' } }],
51
- },
52
- {
53
- role: 'tool',
54
- toolCallId: 'call-1',
55
- content: JSON.stringify({ ok: true, output: 'README.md\nsrc/' }),
56
- },
57
- ];
58
- const messages = buildConversationMessages(history);
59
- expect(messages).toEqual([
60
- { id: 'user-0-Inspect the repo.', role: 'user', text: 'Inspect the repo.' },
61
- { id: 'assistant-1-I will inspect.', role: 'assistant', text: 'I will inspect.' },
62
- ]);
63
- });
64
- it('renders update_plan tool results into visible checklist history', () => {
65
- const history = [
66
- { role: 'user', content: 'Move the project forward.' },
67
- {
68
- role: 'assistant',
69
- content: 'I will plan the work first.',
70
- toolCalls: [{ id: 'call-1', tool: 'update_plan', input: { plan: [{ step: 'Inspect roadmap', status: 'completed' }] } }],
71
- },
72
- {
73
- role: 'tool',
74
- toolCallId: 'call-1',
75
- content: JSON.stringify({
76
- ok: true,
77
- output: {
78
- explanation: 'Tracking the next implementation slice.',
79
- plan: [
80
- { step: 'Inspect roadmap and runtime state', status: 'completed' },
81
- { step: 'Implement the next bounded capability', status: 'in_progress' },
82
- { step: 'Verify with tests and build', status: 'pending' },
83
- ],
84
- },
85
- }),
86
- },
87
- ];
88
- const messages = buildConversationMessages(history);
89
- expect(messages).toHaveLength(3);
90
- expect(messages[2]?.text).toContain('## Plan');
91
- expect(messages[2]?.text).toContain('Tracking the next implementation slice.');
92
- expect(messages[2]?.text).toContain('- [x] Inspect roadmap and runtime state');
93
- expect(messages[2]?.text).toContain('- [-] Implement the next bounded capability');
94
- expect(messages[2]?.text).toContain('- [ ] Verify with tests and build');
95
- });
96
- it('formats a live edit preview into the same visible diff block shape', () => {
97
- const rendered = formatEditPreviewHistoryMessage({
98
- path: 'src/example.ts',
99
- action: 'replaced',
100
- diff: ['--- a/src/example.ts', '+++ b/src/example.ts', '@@ -1 +1 @@', '-old', '+new'].join('\n'),
101
- truncated: false,
102
- });
103
- expect(rendered).toContain('## Edited `src/example.ts`');
104
- expect(rendered).toContain('Action: replaced');
105
- expect(rendered).toContain('```diff');
106
- expect(rendered).toContain('+new');
107
- });
108
- it('formats a live plan update into the same visible checklist block shape', () => {
109
- const rendered = formatPlanHistoryMessage({
110
- explanation: 'Tracking the current implementation slice.',
111
- plan: [
112
- { step: 'Inspect runtime behavior', status: 'completed' },
113
- { step: 'Implement the fix', status: 'in_progress' },
114
- { step: 'Verify with tests', status: 'pending' },
115
- ],
116
- });
117
- expect(rendered).toContain('## Plan');
118
- expect(rendered).toContain('Tracking the current implementation slice.');
119
- expect(rendered).toContain('- [x] Inspect runtime behavior');
120
- expect(rendered).toContain('- [-] Implement the fix');
121
- expect(rendered).toContain('- [ ] Verify with tests');
122
- });
123
- });
124
- describe('formatChatFailureMessage', () => {
125
- it('adds manual compaction guidance for likely input-size TPM failures', () => {
126
- const formatted = formatChatFailureMessage(`429 {"type":"error","error":{"type":"rate_limit_error","message":"This request would exceed your organization's rate limit of 30,000 input tokens per minute. Please reduce the prompt length or the maximum tokens requested."}}`, { model: 'claude-sonnet-4-6', estimatedHistoryTokens: 18234 });
127
- expect(formatted).toContain('input-token-per-minute limit');
128
- expect(formatted).toContain('18,234 tokens');
129
- expect(formatted).toContain('/compact, /clear, or /session new');
130
- });
131
- it('distinguishes OpenAI quota exhaustion from prompt-size issues', () => {
132
- const formatted = formatChatFailureMessage('You exceeded your current quota, please check your plan and billing details.', { model: 'gpt-5.4' });
133
- expect(formatted).toContain('quota or billing limit');
134
- expect(formatted).toContain('not a transient prompt-size issue');
135
- });
136
- });
137
- //# sourceMappingURL=chat-format.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-format.test.js","sourceRoot":"","sources":["../../../src/__tests__/chat-format.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=chat-runtime.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-runtime.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/chat-runtime.test.ts"],"names":[],"mappings":""}