@qduc/term2 0.1.4 → 0.1.6

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 (575) hide show
  1. package/dist/agent.d.ts.map +1 -1
  2. package/dist/agent.js +4 -24
  3. package/dist/agent.js.map +1 -1
  4. package/dist/app.d.ts.map +1 -1
  5. package/dist/app.js +12 -33
  6. package/dist/app.js.map +1 -1
  7. package/dist/app.parseInput.test.js +4 -4
  8. package/dist/app.parseInput.test.js.map +1 -1
  9. package/dist/cli.js +44 -29
  10. package/dist/cli.js.map +1 -1
  11. package/dist/components/ApprovalPrompt.d.ts.map +1 -1
  12. package/dist/components/ApprovalPrompt.js +14 -11
  13. package/dist/components/ApprovalPrompt.js.map +1 -1
  14. package/dist/components/Banner.d.ts.map +1 -1
  15. package/dist/components/Banner.js +4 -12
  16. package/dist/components/Banner.js.map +1 -1
  17. package/dist/components/BottomArea.d.ts +2 -0
  18. package/dist/components/BottomArea.d.ts.map +1 -1
  19. package/dist/components/BottomArea.js +6 -9
  20. package/dist/components/BottomArea.js.map +1 -1
  21. package/dist/components/BottomArea.test.js +4 -6
  22. package/dist/components/BottomArea.test.js.map +1 -1
  23. package/dist/components/ChatMessage.d.ts.map +1 -1
  24. package/dist/components/ChatMessage.js.map +1 -1
  25. package/dist/components/CommandMessage.d.ts.map +1 -1
  26. package/dist/components/CommandMessage.js +19 -30
  27. package/dist/components/CommandMessage.js.map +1 -1
  28. package/dist/components/CommandMessage.test.js +2 -2
  29. package/dist/components/CommandMessage.test.js.map +1 -1
  30. package/dist/components/ErrorBoundary.d.ts.map +1 -1
  31. package/dist/components/ErrorBoundary.js +3 -9
  32. package/dist/components/ErrorBoundary.js.map +1 -1
  33. package/dist/components/ErrorBoundary.test.js +2 -2
  34. package/dist/components/ErrorBoundary.test.js.map +1 -1
  35. package/dist/components/Input/PopupManager.d.ts.map +1 -1
  36. package/dist/components/Input/PopupManager.js.map +1 -1
  37. package/dist/components/InputBox.d.ts.map +1 -1
  38. package/dist/components/InputBox.js +15 -33
  39. package/dist/components/InputBox.js.map +1 -1
  40. package/dist/components/InputBox.menu-logic.test.js +6 -7
  41. package/dist/components/InputBox.menu-logic.test.js.map +1 -1
  42. package/dist/components/InputBox.test.js +7 -9
  43. package/dist/components/InputBox.test.js.map +1 -1
  44. package/dist/components/LiveResponse.d.ts.map +1 -1
  45. package/dist/components/LiveResponse.js.map +1 -1
  46. package/dist/components/MarkdownRenderer.d.ts.map +1 -1
  47. package/dist/components/MarkdownRenderer.js +12 -12
  48. package/dist/components/MarkdownRenderer.js.map +1 -1
  49. package/dist/components/MessageList.d.ts.map +1 -1
  50. package/dist/components/MessageList.js.map +1 -1
  51. package/dist/components/MessageList.test.js +1 -1
  52. package/dist/components/MessageList.test.js.map +1 -1
  53. package/dist/components/ModelSelectionMenu.d.ts.map +1 -1
  54. package/dist/components/ModelSelectionMenu.js +35 -31
  55. package/dist/components/ModelSelectionMenu.js.map +1 -1
  56. package/dist/components/ModelSelectionMenu.test.js +9 -9
  57. package/dist/components/ModelSelectionMenu.test.js.map +1 -1
  58. package/dist/components/PathSelectionMenu.d.ts.map +1 -1
  59. package/dist/components/PathSelectionMenu.js +1 -1
  60. package/dist/components/PathSelectionMenu.js.map +1 -1
  61. package/dist/components/SettingsSelectionMenu.d.ts.map +1 -1
  62. package/dist/components/SettingsSelectionMenu.js +1 -1
  63. package/dist/components/SettingsSelectionMenu.js.map +1 -1
  64. package/dist/components/SettingsSelectionMenu.test.js +4 -4
  65. package/dist/components/SettingsSelectionMenu.test.js.map +1 -1
  66. package/dist/components/SettingsValueSelectionMenu.d.ts.map +1 -1
  67. package/dist/components/SettingsValueSelectionMenu.js +5 -6
  68. package/dist/components/SettingsValueSelectionMenu.js.map +1 -1
  69. package/dist/components/SettingsValueSelectionMenu.test.js +5 -5
  70. package/dist/components/SettingsValueSelectionMenu.test.js.map +1 -1
  71. package/dist/components/SlashCommandMenu.d.ts.map +1 -1
  72. package/dist/components/SlashCommandMenu.js +1 -1
  73. package/dist/components/SlashCommandMenu.js.map +1 -1
  74. package/dist/components/StatusBar.d.ts +2 -0
  75. package/dist/components/StatusBar.d.ts.map +1 -1
  76. package/dist/components/StatusBar.js +45 -41
  77. package/dist/components/StatusBar.js.map +1 -1
  78. package/dist/components/StatusBar.test.d.ts +2 -0
  79. package/dist/components/StatusBar.test.d.ts.map +1 -0
  80. package/dist/components/StatusBar.test.js +19 -0
  81. package/dist/components/StatusBar.test.js.map +1 -0
  82. package/dist/context/InputContext.d.ts.map +1 -1
  83. package/dist/context/InputContext.js.map +1 -1
  84. package/dist/context/InputContext.stability.test.js +1 -1
  85. package/dist/context/InputContext.stability.test.js.map +1 -1
  86. package/dist/context/InputContext.test.js +15 -15
  87. package/dist/context/InputContext.test.js.map +1 -1
  88. package/dist/hooks/use-conversation.d.ts +5 -13
  89. package/dist/hooks/use-conversation.d.ts.map +1 -1
  90. package/dist/hooks/use-conversation.js +40 -148
  91. package/dist/hooks/use-conversation.js.map +1 -1
  92. package/dist/hooks/use-input-history.d.ts.map +1 -1
  93. package/dist/hooks/use-input-history.js +1 -3
  94. package/dist/hooks/use-input-history.js.map +1 -1
  95. package/dist/hooks/use-model-selection.d.ts.map +1 -1
  96. package/dist/hooks/use-model-selection.js +9 -35
  97. package/dist/hooks/use-model-selection.js.map +1 -1
  98. package/dist/hooks/use-path-completion.d.ts.map +1 -1
  99. package/dist/hooks/use-path-completion.js +6 -6
  100. package/dist/hooks/use-path-completion.js.map +1 -1
  101. package/dist/hooks/use-setting.d.ts.map +1 -1
  102. package/dist/hooks/use-setting.js +3 -6
  103. package/dist/hooks/use-setting.js.map +1 -1
  104. package/dist/hooks/use-settings-completion.d.ts.map +1 -1
  105. package/dist/hooks/use-settings-completion.js +10 -12
  106. package/dist/hooks/use-settings-completion.js.map +1 -1
  107. package/dist/hooks/use-settings-completion.test.js +46 -46
  108. package/dist/hooks/use-settings-completion.test.js.map +1 -1
  109. package/dist/hooks/use-settings-value-completion.d.ts.map +1 -1
  110. package/dist/hooks/use-settings-value-completion.js +13 -43
  111. package/dist/hooks/use-settings-value-completion.js.map +1 -1
  112. package/dist/hooks/use-settings-value-completion.test.js +12 -18
  113. package/dist/hooks/use-settings-value-completion.test.js.map +1 -1
  114. package/dist/hooks/use-slash-commands.d.ts +1 -1
  115. package/dist/hooks/use-slash-commands.d.ts.map +1 -1
  116. package/dist/hooks/use-slash-commands.js +6 -11
  117. package/dist/hooks/use-slash-commands.js.map +1 -1
  118. package/dist/hooks/use-slash-commands.test.js +24 -24
  119. package/dist/hooks/use-slash-commands.test.js.map +1 -1
  120. package/dist/lib/editor-impl.d.ts.map +1 -1
  121. package/dist/lib/editor-impl.js +6 -16
  122. package/dist/lib/editor-impl.js.map +1 -1
  123. package/dist/lib/editor-impl.test.js.map +1 -1
  124. package/dist/lib/mentor-client.d.ts +41 -0
  125. package/dist/lib/mentor-client.d.ts.map +1 -0
  126. package/dist/lib/mentor-client.js +146 -0
  127. package/dist/lib/mentor-client.js.map +1 -0
  128. package/dist/lib/mentor-client.test.d.ts +2 -0
  129. package/dist/lib/mentor-client.test.d.ts.map +1 -0
  130. package/dist/lib/mentor-client.test.js +440 -0
  131. package/dist/lib/mentor-client.test.js.map +1 -0
  132. package/dist/lib/openai-agent-client.chat.test.js +33 -8
  133. package/dist/lib/openai-agent-client.chat.test.js.map +1 -1
  134. package/dist/lib/openai-agent-client.d.ts.map +1 -1
  135. package/dist/lib/openai-agent-client.flex-tier.test.js +5 -5
  136. package/dist/lib/openai-agent-client.flex-tier.test.js.map +1 -1
  137. package/dist/lib/openai-agent-client.js +99 -88
  138. package/dist/lib/openai-agent-client.js.map +1 -1
  139. package/dist/lib/openai-agent-client.public-methods.test.js +186 -12
  140. package/dist/lib/openai-agent-client.public-methods.test.js.map +1 -1
  141. package/dist/lib/openai-agent-client.test.js +17 -17
  142. package/dist/lib/openai-agent-client.test.js.map +1 -1
  143. package/dist/lib/retry-strategy.d.ts +43 -0
  144. package/dist/lib/retry-strategy.d.ts.map +1 -0
  145. package/dist/lib/retry-strategy.js +93 -0
  146. package/dist/lib/retry-strategy.js.map +1 -0
  147. package/dist/lib/retry-strategy.test.d.ts +2 -0
  148. package/dist/lib/retry-strategy.test.d.ts.map +1 -0
  149. package/dist/lib/retry-strategy.test.js +200 -0
  150. package/dist/lib/retry-strategy.test.js.map +1 -0
  151. package/dist/lib/tool-invoke.d.ts.map +1 -1
  152. package/dist/lib/tool-invoke.js.map +1 -1
  153. package/dist/lib/tool-invoke.test.js.map +1 -1
  154. package/dist/no-singleton-imports.test.js +1 -1
  155. package/dist/no-singleton-imports.test.js.map +1 -1
  156. package/dist/non-interactive.d.ts +20 -0
  157. package/dist/non-interactive.d.ts.map +1 -0
  158. package/dist/non-interactive.js +86 -0
  159. package/dist/non-interactive.js.map +1 -0
  160. package/dist/non-interactive.test.d.ts +2 -0
  161. package/dist/non-interactive.test.d.ts.map +1 -0
  162. package/dist/non-interactive.test.js +213 -0
  163. package/dist/non-interactive.test.js.map +1 -0
  164. package/dist/prompts/anthropic.md +11 -11
  165. package/dist/prompts/codex.md +63 -63
  166. package/dist/prompts/gpt-5.md +95 -95
  167. package/dist/prompts/mentor-addon.md +6 -5
  168. package/dist/prompts/prompt-selector.d.ts +8 -0
  169. package/dist/prompts/prompt-selector.d.ts.map +1 -0
  170. package/dist/prompts/prompt-selector.js +21 -0
  171. package/dist/prompts/prompt-selector.js.map +1 -0
  172. package/dist/prompts/prompt-selector.test.d.ts +2 -0
  173. package/dist/prompts/prompt-selector.test.d.ts.map +1 -0
  174. package/dist/prompts/prompt-selector.test.js +21 -0
  175. package/dist/prompts/prompt-selector.test.js.map +1 -0
  176. package/dist/prompts/prompt-selector.test.ts +32 -0
  177. package/dist/prompts/prompt-selector.ts +30 -0
  178. package/dist/prompts/simple.md +58 -58
  179. package/dist/providers/index.d.ts.map +1 -1
  180. package/dist/providers/index.js.map +1 -1
  181. package/dist/providers/openai-compatible/api.d.ts.map +1 -1
  182. package/dist/providers/openai-compatible/api.js.map +1 -1
  183. package/dist/providers/openai-compatible/model.d.ts.map +1 -1
  184. package/dist/providers/openai-compatible/model.js +19 -53
  185. package/dist/providers/openai-compatible/model.js.map +1 -1
  186. package/dist/providers/openai-compatible/provider.d.ts.map +1 -1
  187. package/dist/providers/openai-compatible/provider.js.map +1 -1
  188. package/dist/providers/openai-compatible/reasoning-content.test.js +2 -2
  189. package/dist/providers/openai-compatible/reasoning-content.test.js.map +1 -1
  190. package/dist/providers/openai-compatible/utils.d.ts.map +1 -1
  191. package/dist/providers/openai-compatible/utils.js.map +1 -1
  192. package/dist/providers/openai-compatible.provider.d.ts.map +1 -1
  193. package/dist/providers/openai-compatible.provider.js +5 -1
  194. package/dist/providers/openai-compatible.provider.js.map +1 -1
  195. package/dist/providers/openai.provider.js +4 -0
  196. package/dist/providers/openai.provider.js.map +1 -1
  197. package/dist/providers/openrouter/api.d.ts.map +1 -1
  198. package/dist/providers/openrouter/api.js +5 -13
  199. package/dist/providers/openrouter/api.js.map +1 -1
  200. package/dist/providers/openrouter/converters.d.ts.map +1 -1
  201. package/dist/providers/openrouter/converters.js +9 -28
  202. package/dist/providers/openrouter/converters.js.map +1 -1
  203. package/dist/providers/openrouter/converters.test.js +7 -11
  204. package/dist/providers/openrouter/converters.test.js.map +1 -1
  205. package/dist/providers/openrouter/index.d.ts.map +1 -1
  206. package/dist/providers/openrouter/index.js.map +1 -1
  207. package/dist/providers/openrouter/model.d.ts.map +1 -1
  208. package/dist/providers/openrouter/model.js +19 -55
  209. package/dist/providers/openrouter/model.js.map +1 -1
  210. package/dist/providers/openrouter/provider.d.ts.map +1 -1
  211. package/dist/providers/openrouter/provider.js.map +1 -1
  212. package/dist/providers/openrouter/reasoning-content.test.js +1 -1
  213. package/dist/providers/openrouter/reasoning-content.test.js.map +1 -1
  214. package/dist/providers/openrouter/utils.d.ts.map +1 -1
  215. package/dist/providers/openrouter/utils.js +2 -3
  216. package/dist/providers/openrouter/utils.js.map +1 -1
  217. package/dist/providers/openrouter.api.retry.test.js.map +1 -1
  218. package/dist/providers/openrouter.provider.createRunner.test.js +1 -1
  219. package/dist/providers/openrouter.provider.createRunner.test.js.map +1 -1
  220. package/dist/providers/openrouter.provider.js +6 -4
  221. package/dist/providers/openrouter.provider.js.map +1 -1
  222. package/dist/providers/openrouter.test.js +13 -17
  223. package/dist/providers/openrouter.test.js.map +1 -1
  224. package/dist/providers/registry.d.ts +5 -0
  225. package/dist/providers/registry.d.ts.map +1 -1
  226. package/dist/providers/registry.js.map +1 -1
  227. package/dist/providers/registry.test.js +11 -11
  228. package/dist/providers/registry.test.js.map +1 -1
  229. package/dist/providers/web-search/index.d.ts +1 -1
  230. package/dist/providers/web-search/index.d.ts.map +1 -1
  231. package/dist/providers/web-search/index.js.map +1 -1
  232. package/dist/providers/web-search/registry.d.ts.map +1 -1
  233. package/dist/providers/web-search/registry.js.map +1 -1
  234. package/dist/providers/web-search/registry.test.js +14 -14
  235. package/dist/providers/web-search/registry.test.js.map +1 -1
  236. package/dist/providers/web-search/tavily.provider.d.ts.map +1 -1
  237. package/dist/providers/web-search/tavily.provider.js +4 -4
  238. package/dist/providers/web-search/tavily.provider.js.map +1 -1
  239. package/dist/providers/web-search/tavily.provider.test.js +7 -7
  240. package/dist/providers/web-search/tavily.provider.test.js.map +1 -1
  241. package/dist/providers/web-search/types.d.ts.map +1 -1
  242. package/dist/scripts/extract-provider-traffic.d.ts +3 -0
  243. package/dist/scripts/extract-provider-traffic.d.ts.map +1 -0
  244. package/dist/scripts/extract-provider-traffic.js +32 -0
  245. package/dist/scripts/extract-provider-traffic.js.map +1 -0
  246. package/dist/services/approval-state.d.ts +24 -0
  247. package/dist/services/approval-state.d.ts.map +1 -0
  248. package/dist/services/approval-state.js +41 -0
  249. package/dist/services/approval-state.js.map +1 -0
  250. package/dist/services/approval-state.test.d.ts +2 -0
  251. package/dist/services/approval-state.test.d.ts.map +1 -0
  252. package/dist/services/approval-state.test.js +59 -0
  253. package/dist/services/approval-state.test.js.map +1 -0
  254. package/dist/services/command-message-streaming.d.ts +12 -0
  255. package/dist/services/command-message-streaming.d.ts.map +1 -0
  256. package/dist/services/command-message-streaming.js +68 -0
  257. package/dist/services/command-message-streaming.js.map +1 -0
  258. package/dist/services/command-message-streaming.test.d.ts +2 -0
  259. package/dist/services/command-message-streaming.test.d.ts.map +1 -0
  260. package/dist/services/command-message-streaming.test.js +78 -0
  261. package/dist/services/command-message-streaming.test.js.map +1 -0
  262. package/dist/services/conversation-events.d.ts +5 -13
  263. package/dist/services/conversation-events.d.ts.map +1 -1
  264. package/dist/services/conversation-integration.test.d.ts +2 -0
  265. package/dist/services/conversation-integration.test.d.ts.map +1 -0
  266. package/dist/services/conversation-integration.test.js +155 -0
  267. package/dist/services/conversation-integration.test.js.map +1 -0
  268. package/dist/services/conversation-result-builder.d.ts +41 -0
  269. package/dist/services/conversation-result-builder.d.ts.map +1 -0
  270. package/dist/services/conversation-result-builder.js +110 -0
  271. package/dist/services/conversation-result-builder.js.map +1 -0
  272. package/dist/services/conversation-result-builder.test.d.ts +2 -0
  273. package/dist/services/conversation-result-builder.test.d.ts.map +1 -0
  274. package/dist/services/conversation-result-builder.test.js +76 -0
  275. package/dist/services/conversation-result-builder.test.js.map +1 -0
  276. package/dist/services/conversation-service.d.ts +1 -1
  277. package/dist/services/conversation-service.d.ts.map +1 -1
  278. package/dist/services/conversation-service.js.map +1 -1
  279. package/dist/services/conversation-session-reasoning.test.js +3 -3
  280. package/dist/services/conversation-session-reasoning.test.js.map +1 -1
  281. package/dist/services/conversation-session.d.ts +7 -17
  282. package/dist/services/conversation-session.d.ts.map +1 -1
  283. package/dist/services/conversation-session.js +290 -278
  284. package/dist/services/conversation-session.js.map +1 -1
  285. package/dist/services/conversation-session.usage.test.d.ts +2 -0
  286. package/dist/services/conversation-session.usage.test.d.ts.map +1 -0
  287. package/dist/services/conversation-session.usage.test.js +59 -0
  288. package/dist/services/conversation-session.usage.test.js.map +1 -0
  289. package/dist/services/conversation-store.d.ts.map +1 -1
  290. package/dist/services/conversation-store.js +3 -9
  291. package/dist/services/conversation-store.js.map +1 -1
  292. package/dist/services/conversation-store.test.js +17 -14
  293. package/dist/services/conversation-store.test.js.map +1 -1
  294. package/dist/services/execution-context.d.ts.map +1 -1
  295. package/dist/services/execution-context.js.map +1 -1
  296. package/dist/services/execution-context.test.js +7 -7
  297. package/dist/services/execution-context.test.js.map +1 -1
  298. package/dist/services/file-service.d.ts.map +1 -1
  299. package/dist/services/file-service.js +5 -9
  300. package/dist/services/file-service.js.map +1 -1
  301. package/dist/services/history-service.d.ts.map +1 -1
  302. package/dist/services/history-service.js +3 -7
  303. package/dist/services/history-service.js.map +1 -1
  304. package/dist/services/logging-contract.d.ts +74 -0
  305. package/dist/services/logging-contract.d.ts.map +1 -0
  306. package/dist/services/logging-contract.js +157 -0
  307. package/dist/services/logging-contract.js.map +1 -0
  308. package/dist/services/logging-contract.test.d.ts +2 -0
  309. package/dist/services/logging-contract.test.d.ts.map +1 -0
  310. package/dist/services/logging-contract.test.js +66 -0
  311. package/dist/services/logging-contract.test.js.map +1 -0
  312. package/dist/services/logging-service.d.ts +5 -0
  313. package/dist/services/logging-service.d.ts.map +1 -1
  314. package/dist/services/logging-service.js +93 -21
  315. package/dist/services/logging-service.js.map +1 -1
  316. package/dist/services/model-service.d.ts.map +1 -1
  317. package/dist/services/model-service.js +2 -2
  318. package/dist/services/model-service.js.map +1 -1
  319. package/dist/services/model-service.test.js +6 -6
  320. package/dist/services/model-service.test.js.map +1 -1
  321. package/dist/services/service-interfaces.d.ts.map +1 -1
  322. package/dist/services/settings-env.d.ts +9 -0
  323. package/dist/services/settings-env.d.ts.map +1 -0
  324. package/dist/services/settings-env.js +75 -0
  325. package/dist/services/settings-env.js.map +1 -0
  326. package/dist/services/settings-env.test.d.ts +2 -0
  327. package/dist/services/settings-env.test.d.ts.map +1 -0
  328. package/dist/services/settings-env.test.js +32 -0
  329. package/dist/services/settings-env.test.js.map +1 -0
  330. package/dist/services/settings-merger.d.ts +26 -0
  331. package/dist/services/settings-merger.d.ts.map +1 -0
  332. package/dist/services/settings-merger.js +122 -0
  333. package/dist/services/settings-merger.js.map +1 -0
  334. package/dist/services/settings-merger.test.d.ts +2 -0
  335. package/dist/services/settings-merger.test.d.ts.map +1 -0
  336. package/dist/services/settings-merger.test.js +26 -0
  337. package/dist/services/settings-merger.test.js.map +1 -0
  338. package/dist/services/settings-persistence.d.ts +32 -0
  339. package/dist/services/settings-persistence.d.ts.map +1 -0
  340. package/dist/services/settings-persistence.js +134 -0
  341. package/dist/services/settings-persistence.js.map +1 -0
  342. package/dist/services/settings-persistence.test.d.ts +2 -0
  343. package/dist/services/settings-persistence.test.d.ts.map +1 -0
  344. package/dist/services/settings-persistence.test.js +51 -0
  345. package/dist/services/settings-persistence.test.js.map +1 -0
  346. package/dist/services/settings-schema.d.ts +320 -0
  347. package/dist/services/settings-schema.d.ts.map +1 -0
  348. package/dist/services/settings-schema.js +272 -0
  349. package/dist/services/settings-schema.js.map +1 -0
  350. package/dist/services/settings-service.d.ts +4 -248
  351. package/dist/services/settings-service.d.ts.map +1 -1
  352. package/dist/services/settings-service.js +45 -641
  353. package/dist/services/settings-service.js.map +1 -1
  354. package/dist/services/settings-service.mock.d.ts.map +1 -1
  355. package/dist/services/settings-service.mock.js.map +1 -1
  356. package/dist/services/singleton-deprecation.test.js +2 -2
  357. package/dist/services/singleton-deprecation.test.js.map +1 -1
  358. package/dist/services/ssh-service.d.ts.map +1 -1
  359. package/dist/services/ssh-service.js +8 -7
  360. package/dist/services/ssh-service.js.map +1 -1
  361. package/dist/services/ssh-service.test.js +15 -13
  362. package/dist/services/ssh-service.test.js.map +1 -1
  363. package/dist/services/stream-event-parsing.d.ts +4 -0
  364. package/dist/services/stream-event-parsing.d.ts.map +1 -0
  365. package/dist/services/stream-event-parsing.js +76 -0
  366. package/dist/services/stream-event-parsing.js.map +1 -0
  367. package/dist/services/stream-event-parsing.test.d.ts +2 -0
  368. package/dist/services/stream-event-parsing.test.d.ts.map +1 -0
  369. package/dist/services/stream-event-parsing.test.js +59 -0
  370. package/dist/services/stream-event-parsing.test.js.map +1 -0
  371. package/dist/services/stream-event-processor.d.ts +32 -0
  372. package/dist/services/stream-event-processor.d.ts.map +1 -0
  373. package/dist/services/stream-event-processor.js +344 -0
  374. package/dist/services/stream-event-processor.js.map +1 -0
  375. package/dist/services/stream-event-processor.test.d.ts +2 -0
  376. package/dist/services/stream-event-processor.test.d.ts.map +1 -0
  377. package/dist/services/stream-event-processor.test.js +117 -0
  378. package/dist/services/stream-event-processor.test.js.map +1 -0
  379. package/dist/tools/apply-patch.d.ts.map +1 -1
  380. package/dist/tools/apply-patch.js +45 -35
  381. package/dist/tools/apply-patch.js.map +1 -1
  382. package/dist/tools/apply-patch.test.js +23 -0
  383. package/dist/tools/apply-patch.test.js.map +1 -1
  384. package/dist/tools/ask-mentor.d.ts.map +1 -1
  385. package/dist/tools/ask-mentor.js +5 -15
  386. package/dist/tools/ask-mentor.js.map +1 -1
  387. package/dist/tools/ask-mentor.test.js +1 -1
  388. package/dist/tools/ask-mentor.test.js.map +1 -1
  389. package/dist/tools/create-file.d.ts.map +1 -1
  390. package/dist/tools/create-file.js +2 -2
  391. package/dist/tools/create-file.js.map +1 -1
  392. package/dist/tools/create-file.test.js.map +1 -1
  393. package/dist/tools/edit-healing.d.ts.map +1 -1
  394. package/dist/tools/edit-healing.js +5 -4
  395. package/dist/tools/edit-healing.js.map +1 -1
  396. package/dist/tools/edit-healing.test.js.map +1 -1
  397. package/dist/tools/find-files.d.ts +1 -0
  398. package/dist/tools/find-files.d.ts.map +1 -1
  399. package/dist/tools/find-files.js +93 -24
  400. package/dist/tools/find-files.js.map +1 -1
  401. package/dist/tools/find-files.test.js +46 -2
  402. package/dist/tools/find-files.test.js.map +1 -1
  403. package/dist/tools/format-helpers.d.ts.map +1 -1
  404. package/dist/tools/format-helpers.js +2 -6
  405. package/dist/tools/format-helpers.js.map +1 -1
  406. package/dist/tools/grep.d.ts +1 -1
  407. package/dist/tools/grep.d.ts.map +1 -1
  408. package/dist/tools/grep.js +6 -21
  409. package/dist/tools/grep.js.map +1 -1
  410. package/dist/tools/read-file.d.ts.map +1 -1
  411. package/dist/tools/read-file.js +3 -7
  412. package/dist/tools/read-file.js.map +1 -1
  413. package/dist/tools/read-file.test.js.map +1 -1
  414. package/dist/tools/search-replace.d.ts.map +1 -1
  415. package/dist/tools/search-replace.js +14 -31
  416. package/dist/tools/search-replace.js.map +1 -1
  417. package/dist/tools/search-replace.test.js.map +1 -1
  418. package/dist/tools/search.d.ts +1 -1
  419. package/dist/tools/search.d.ts.map +1 -1
  420. package/dist/tools/search.js +6 -16
  421. package/dist/tools/search.js.map +1 -1
  422. package/dist/tools/shell.d.ts +1 -1
  423. package/dist/tools/shell.d.ts.map +1 -1
  424. package/dist/tools/shell.js +25 -51
  425. package/dist/tools/shell.js.map +1 -1
  426. package/dist/tools/shell.test.d.ts +2 -0
  427. package/dist/tools/shell.test.d.ts.map +1 -0
  428. package/dist/tools/shell.test.js +70 -0
  429. package/dist/tools/shell.test.js.map +1 -0
  430. package/dist/tools/tool-names.d.ts +3 -0
  431. package/dist/tools/tool-names.d.ts.map +1 -0
  432. package/dist/tools/tool-names.js +3 -0
  433. package/dist/tools/tool-names.js.map +1 -0
  434. package/dist/tools/tool-names.test.d.ts +2 -0
  435. package/dist/tools/tool-names.test.d.ts.map +1 -0
  436. package/dist/tools/tool-names.test.js +7 -0
  437. package/dist/tools/tool-names.test.js.map +1 -0
  438. package/dist/tools/types.d.ts.map +1 -1
  439. package/dist/tools/utils.d.ts.map +1 -1
  440. package/dist/tools/utils.js +3 -8
  441. package/dist/tools/utils.js.map +1 -1
  442. package/dist/tools/web-fetch.d.ts +4 -4
  443. package/dist/tools/web-fetch.d.ts.map +1 -1
  444. package/dist/tools/web-fetch.js +32 -249
  445. package/dist/tools/web-fetch.js.map +1 -1
  446. package/dist/tools/web-fetch.test.js +3 -3
  447. package/dist/tools/web-fetch.test.js.map +1 -1
  448. package/dist/tools/web-search.d.ts.map +1 -1
  449. package/dist/tools/web-search.js +6 -10
  450. package/dist/tools/web-search.js.map +1 -1
  451. package/dist/tools/web-search.test.js +12 -14
  452. package/dist/tools/web-search.test.js.map +1 -1
  453. package/dist/types/messages.d.ts +29 -0
  454. package/dist/types/messages.d.ts.map +1 -0
  455. package/dist/types/messages.js +2 -0
  456. package/dist/types/messages.js.map +1 -0
  457. package/dist/utils/command-logger.d.ts.map +1 -1
  458. package/dist/utils/command-logger.js.map +1 -1
  459. package/dist/utils/command-safety/constants.d.ts.map +1 -1
  460. package/dist/utils/command-safety/constants.js +1 -9
  461. package/dist/utils/command-safety/constants.js.map +1 -1
  462. package/dist/utils/command-safety/find-helpers.d.ts.map +1 -1
  463. package/dist/utils/command-safety/find-helpers.js +4 -9
  464. package/dist/utils/command-safety/find-helpers.js.map +1 -1
  465. package/dist/utils/command-safety/handlers/find-handler.d.ts.map +1 -1
  466. package/dist/utils/command-safety/handlers/find-handler.js +3 -10
  467. package/dist/utils/command-safety/handlers/find-handler.js.map +1 -1
  468. package/dist/utils/command-safety/handlers/git-handler.d.ts.map +1 -1
  469. package/dist/utils/command-safety/handlers/git-handler.js +2 -4
  470. package/dist/utils/command-safety/handlers/git-handler.js.map +1 -1
  471. package/dist/utils/command-safety/handlers/index.d.ts +1 -1
  472. package/dist/utils/command-safety/handlers/index.d.ts.map +1 -1
  473. package/dist/utils/command-safety/handlers/index.js.map +1 -1
  474. package/dist/utils/command-safety/handlers/sed-handler.d.ts.map +1 -1
  475. package/dist/utils/command-safety/handlers/sed-handler.js.map +1 -1
  476. package/dist/utils/command-safety/handlers/types.d.ts.map +1 -1
  477. package/dist/utils/command-safety/index.d.ts.map +1 -1
  478. package/dist/utils/command-safety/index.js +4 -10
  479. package/dist/utils/command-safety/index.js.map +1 -1
  480. package/dist/utils/command-safety/path-analysis.d.ts.map +1 -1
  481. package/dist/utils/command-safety/path-analysis.js +9 -20
  482. package/dist/utils/command-safety/path-analysis.js.map +1 -1
  483. package/dist/utils/command-safety/utils.d.ts.map +1 -1
  484. package/dist/utils/command-safety/utils.js +1 -3
  485. package/dist/utils/command-safety/utils.js.map +1 -1
  486. package/dist/utils/command-safety.find.test.js +44 -87
  487. package/dist/utils/command-safety.find.test.js.map +1 -1
  488. package/dist/utils/command-safety.path.test.js +32 -67
  489. package/dist/utils/command-safety.path.test.js.map +1 -1
  490. package/dist/utils/conversation-event-handler.d.ts +4 -16
  491. package/dist/utils/conversation-event-handler.d.ts.map +1 -1
  492. package/dist/utils/conversation-event-handler.js +4 -8
  493. package/dist/utils/conversation-event-handler.js.map +1 -1
  494. package/dist/utils/conversation-event-handler.test.js +16 -18
  495. package/dist/utils/conversation-event-handler.test.js.map +1 -1
  496. package/dist/utils/conversation-utils.d.ts.map +1 -1
  497. package/dist/utils/conversation-utils.js +5 -8
  498. package/dist/utils/conversation-utils.js.map +1 -1
  499. package/dist/utils/conversation-utils.test.js +45 -44
  500. package/dist/utils/conversation-utils.test.js.map +1 -1
  501. package/dist/utils/diff.d.ts.map +1 -1
  502. package/dist/utils/diff.js +2 -4
  503. package/dist/utils/diff.js.map +1 -1
  504. package/dist/utils/diff.test.js +12 -12
  505. package/dist/utils/diff.test.js.map +1 -1
  506. package/dist/utils/error-helpers.d.ts.map +1 -1
  507. package/dist/utils/error-helpers.js +2 -6
  508. package/dist/utils/error-helpers.js.map +1 -1
  509. package/dist/utils/error-helpers.test.js +32 -32
  510. package/dist/utils/error-helpers.test.js.map +1 -1
  511. package/dist/utils/execute-shell.d.ts.map +1 -1
  512. package/dist/utils/execute-shell.js.map +1 -1
  513. package/dist/utils/execute-shell.test.js.map +1 -1
  514. package/dist/utils/extract-command-messages.d.ts.map +1 -1
  515. package/dist/utils/extract-command-messages.js +16 -21
  516. package/dist/utils/extract-command-messages.js.map +1 -1
  517. package/dist/utils/ink-render-options.d.ts.map +1 -1
  518. package/dist/utils/ink-render-options.js.map +1 -1
  519. package/dist/utils/log-viewer-filters.d.ts +29 -0
  520. package/dist/utils/log-viewer-filters.d.ts.map +1 -0
  521. package/dist/utils/log-viewer-filters.js +49 -0
  522. package/dist/utils/log-viewer-filters.js.map +1 -0
  523. package/dist/utils/log-viewer-filters.test.d.ts +2 -0
  524. package/dist/utils/log-viewer-filters.test.d.ts.map +1 -0
  525. package/dist/utils/log-viewer-filters.test.js +48 -0
  526. package/dist/utils/log-viewer-filters.test.js.map +1 -0
  527. package/dist/utils/message-buffer.d.ts.map +1 -1
  528. package/dist/utils/message-buffer.js.map +1 -1
  529. package/dist/utils/message-buffer.test.js +4 -4
  530. package/dist/utils/message-buffer.test.js.map +1 -1
  531. package/dist/utils/output-trim.d.ts.map +1 -1
  532. package/dist/utils/output-trim.js.map +1 -1
  533. package/dist/utils/provider-credentials.d.ts.map +1 -1
  534. package/dist/utils/provider-credentials.js +1 -1
  535. package/dist/utils/provider-credentials.js.map +1 -1
  536. package/dist/utils/provider-traffic-extractor.d.ts +18 -0
  537. package/dist/utils/provider-traffic-extractor.d.ts.map +1 -0
  538. package/dist/utils/provider-traffic-extractor.js +121 -0
  539. package/dist/utils/provider-traffic-extractor.js.map +1 -0
  540. package/dist/utils/provider-traffic-extractor.test.d.ts +2 -0
  541. package/dist/utils/provider-traffic-extractor.test.d.ts.map +1 -0
  542. package/dist/utils/provider-traffic-extractor.test.js +84 -0
  543. package/dist/utils/provider-traffic-extractor.test.js.map +1 -0
  544. package/dist/utils/settings-command.d.ts.map +1 -1
  545. package/dist/utils/settings-command.js +5 -12
  546. package/dist/utils/settings-command.js.map +1 -1
  547. package/dist/utils/ssh-config-parser.d.ts.map +1 -1
  548. package/dist/utils/ssh-config-parser.js.map +1 -1
  549. package/dist/utils/ssh-config-parser.test.js.map +1 -1
  550. package/dist/utils/streaming-session-factory.d.ts +33 -0
  551. package/dist/utils/streaming-session-factory.d.ts.map +1 -0
  552. package/dist/utils/streaming-session-factory.js +75 -0
  553. package/dist/utils/streaming-session-factory.js.map +1 -0
  554. package/dist/utils/streaming-session-factory.test.d.ts +2 -0
  555. package/dist/utils/streaming-session-factory.test.d.ts.map +1 -0
  556. package/dist/utils/streaming-session-factory.test.js +74 -0
  557. package/dist/utils/streaming-session-factory.test.js.map +1 -0
  558. package/dist/utils/streaming-updater.d.ts.map +1 -1
  559. package/dist/utils/streaming-updater.js.map +1 -1
  560. package/dist/utils/throttle.d.ts.map +1 -1
  561. package/dist/utils/throttle.js.map +1 -1
  562. package/dist/utils/token-usage.d.ts +16 -0
  563. package/dist/utils/token-usage.d.ts.map +1 -0
  564. package/dist/utils/token-usage.js +109 -0
  565. package/dist/utils/token-usage.js.map +1 -0
  566. package/dist/utils/token-usage.test.d.ts +2 -0
  567. package/dist/utils/token-usage.test.d.ts.map +1 -0
  568. package/dist/utils/token-usage.test.js +38 -0
  569. package/dist/utils/token-usage.test.js.map +1 -0
  570. package/dist/utils/trim-tool-output.d.ts +2 -0
  571. package/dist/utils/trim-tool-output.d.ts.map +1 -0
  572. package/dist/utils/trim-tool-output.js +52 -0
  573. package/dist/utils/trim-tool-output.js.map +1 -0
  574. package/package.json +117 -110
  575. package/{README.md → readme.md} +208 -136
@@ -0,0 +1,344 @@
1
+ import { extractCommandMessages } from '../utils/extract-command-messages.js';
2
+ import { extractUsage } from '../utils/token-usage.js';
3
+ export class StreamEventProcessor {
4
+ logger;
5
+ sessionId;
6
+ toolCallArgumentsById = new Map();
7
+ textDeltaCount = 0;
8
+ reasoningDeltaCount = 0;
9
+ lastEventType = null;
10
+ eventTypeCount = 0;
11
+ constructor({ logger, sessionId }) {
12
+ this.logger = logger;
13
+ this.sessionId = sessionId;
14
+ }
15
+ reset() {
16
+ this.toolCallArgumentsById.clear();
17
+ this.textDeltaCount = 0;
18
+ this.reasoningDeltaCount = 0;
19
+ this.lastEventType = null;
20
+ this.eventTypeCount = 0;
21
+ }
22
+ getToolCallArgumentsSnapshot() {
23
+ return new Map(this.toolCallArgumentsById);
24
+ }
25
+ restoreToolCallArguments(snapshot) {
26
+ this.toolCallArgumentsById.clear();
27
+ if (!snapshot?.size) {
28
+ return;
29
+ }
30
+ for (const [key, value] of snapshot.entries()) {
31
+ this.toolCallArgumentsById.set(key, value);
32
+ }
33
+ }
34
+ async *streamEvents(stream, acc, { preserveExistingToolArgs }) {
35
+ const toolCallArgumentsById = this.toolCallArgumentsById;
36
+ if (!preserveExistingToolArgs) {
37
+ toolCallArgumentsById.clear();
38
+ }
39
+ this.textDeltaCount = 0;
40
+ this.reasoningDeltaCount = 0;
41
+ const emitText = (delta) => {
42
+ if (!delta) {
43
+ return null;
44
+ }
45
+ acc.finalOutput += delta;
46
+ this.textDeltaCount++;
47
+ return {
48
+ type: 'text_delta',
49
+ delta,
50
+ fullText: acc.finalOutput,
51
+ };
52
+ };
53
+ const emitReasoning = (delta) => {
54
+ if (!delta || delta.replaceAll('\n', '') === '') {
55
+ return null;
56
+ }
57
+ acc.reasoningOutput += delta;
58
+ this.reasoningDeltaCount++;
59
+ return {
60
+ type: 'reasoning_delta',
61
+ delta,
62
+ fullText: acc.reasoningOutput,
63
+ };
64
+ };
65
+ for await (const event of stream) {
66
+ // Extract usage if present in any of the common locations
67
+ const usage = extractUsage(event);
68
+ if (usage) {
69
+ acc.latestUsage = usage;
70
+ this.logger.debug('Usage extracted from stream event', {
71
+ sessionId: this.sessionId,
72
+ source: 'stream_event',
73
+ eventType: event?.type ?? event?.data?.type ?? 'unknown',
74
+ usage,
75
+ });
76
+ }
77
+ // Log event type with deduplication for ordering understanding
78
+ const delta1 = this.#extractTextDelta(event);
79
+ if (delta1) {
80
+ const e = emitText(delta1);
81
+ if (e)
82
+ yield e;
83
+ }
84
+ if (event?.data) {
85
+ const delta2 = this.#extractTextDelta(event.data);
86
+ if (delta2) {
87
+ const e = emitText(delta2);
88
+ if (e)
89
+ yield e;
90
+ }
91
+ }
92
+ // Handle reasoning items
93
+ const reasoningDelta = (() => {
94
+ // OpenAI style
95
+ const data = event?.data;
96
+ if (data && typeof data === 'object' && data.type === 'model') {
97
+ const eventDetail = data.event;
98
+ if (eventDetail &&
99
+ typeof eventDetail === 'object' &&
100
+ eventDetail.type === 'response.reasoning_summary_text.delta') {
101
+ return eventDetail.delta ?? '';
102
+ }
103
+ }
104
+ // OpenRouter style
105
+ const choices = event?.data?.event?.choices;
106
+ if (!choices)
107
+ return '';
108
+ if (Array.isArray(choices)) {
109
+ return choices[0]?.delta?.reasoning ?? choices[0]?.delta?.reasoning_content ?? '';
110
+ }
111
+ if (typeof choices === 'object') {
112
+ const byZero = choices['0'];
113
+ const first = byZero ?? choices[Object.keys(choices)[0]];
114
+ return first?.delta?.reasoning ?? first?.delta?.reasoning_content ?? '';
115
+ }
116
+ return '';
117
+ })();
118
+ if (reasoningDelta) {
119
+ const e = emitReasoning(reasoningDelta);
120
+ if (e)
121
+ yield e;
122
+ }
123
+ const maybeEmitCommandMessagesFromItems = (items) => {
124
+ this.#attachCachedArguments(items, toolCallArgumentsById);
125
+ const commandMessages = extractCommandMessages(items);
126
+ const out = [];
127
+ for (const cmdMsg of commandMessages) {
128
+ if (acc.emittedCommandIds.has(cmdMsg.id)) {
129
+ continue;
130
+ }
131
+ if (cmdMsg.isApprovalRejection) {
132
+ continue;
133
+ }
134
+ acc.emittedCommandIds.add(cmdMsg.id);
135
+ out.push({ type: 'command_message', message: cmdMsg });
136
+ }
137
+ return out;
138
+ };
139
+ if (event?.type === 'run_item_stream_event') {
140
+ this.#captureToolCallArguments(event.item, toolCallArgumentsById);
141
+ // Emit tool_started event when a function_call is detected
142
+ const rawItem = event.item?.rawItem ?? event.item;
143
+ if (rawItem?.type === 'function_call') {
144
+ const callId = rawItem.callId ?? rawItem.call_id ?? rawItem.tool_call_id ?? rawItem.toolCallId ?? rawItem.id;
145
+ if (callId) {
146
+ const toolName = rawItem.name ?? event.item?.name;
147
+ const args = rawItem.arguments ?? rawItem.args ?? event.item?.arguments ?? event.item?.args;
148
+ // Providers sometimes surface arguments as a JSON string.
149
+ // Normalize here so downstream UI (pending/running display)
150
+ // can reliably render parameters.
151
+ const normalizedArgs = (() => {
152
+ if (typeof args !== 'string') {
153
+ return args;
154
+ }
155
+ const trimmed = args.trim();
156
+ if (!trimmed) {
157
+ return args;
158
+ }
159
+ try {
160
+ return JSON.parse(trimmed);
161
+ }
162
+ catch {
163
+ return args;
164
+ }
165
+ })();
166
+ yield {
167
+ type: 'tool_started',
168
+ toolCallId: callId,
169
+ toolName: toolName ?? 'unknown',
170
+ arguments: normalizedArgs,
171
+ };
172
+ }
173
+ }
174
+ for (const e of maybeEmitCommandMessagesFromItems([event.item])) {
175
+ yield e;
176
+ }
177
+ }
178
+ else if (event?.type === 'tool_call_output_item' || event?.rawItem?.type === 'function_call_output') {
179
+ this.#captureToolCallArguments(event, toolCallArgumentsById);
180
+ for (const e of maybeEmitCommandMessagesFromItems([event])) {
181
+ yield e;
182
+ }
183
+ }
184
+ }
185
+ const completedResult = await stream.completed;
186
+ const rawResponses = Array.isArray(stream?.rawResponses) ? stream.rawResponses : [];
187
+ let usageFromRawResponses;
188
+ for (let i = rawResponses.length - 1; i >= 0; i--) {
189
+ const candidate = extractUsage(rawResponses[i]);
190
+ if (candidate) {
191
+ usageFromRawResponses = candidate;
192
+ break;
193
+ }
194
+ }
195
+ const finalUsage = extractUsage(completedResult) || extractUsage(stream) || usageFromRawResponses;
196
+ if (finalUsage) {
197
+ acc.latestUsage = finalUsage;
198
+ const usageSource = extractUsage(completedResult)
199
+ ? 'completed_result'
200
+ : extractUsage(stream)
201
+ ? 'stream_object'
202
+ : 'stream_raw_responses';
203
+ this.logger.debug('Usage extracted from stream completion', {
204
+ sessionId: this.sessionId,
205
+ source: 'stream_completed',
206
+ usageSource,
207
+ usage: finalUsage,
208
+ });
209
+ }
210
+ else {
211
+ const completedResultRecord = completedResult && typeof completedResult === 'object' && !Array.isArray(completedResult)
212
+ ? completedResult
213
+ : undefined;
214
+ const streamRecord = stream && typeof stream === 'object' && !Array.isArray(stream)
215
+ ? stream
216
+ : undefined;
217
+ this.logger.debug('No usage found in stream completion', {
218
+ sessionId: this.sessionId,
219
+ source: 'stream_completed',
220
+ completedResultType: completedResult === null ? 'null' : Array.isArray(completedResult) ? 'array' : typeof completedResult,
221
+ completedResultKeys: completedResultRecord ? Object.keys(completedResultRecord) : [],
222
+ streamKeys: streamRecord ? Object.keys(streamRecord) : [],
223
+ completedResultHasUsagePath: {
224
+ usage: Boolean(completedResultRecord?.usage),
225
+ usageMetadata: Boolean(completedResultRecord?.usageMetadata),
226
+ usage_metadata: Boolean(completedResultRecord?.usage_metadata),
227
+ responseUsage: Boolean(completedResultRecord?.response?.usage),
228
+ },
229
+ });
230
+ }
231
+ this.flushStreamEventLog();
232
+ }
233
+ flushStreamEventLog() {
234
+ if (this.lastEventType !== null && this.eventTypeCount > 1) {
235
+ this.logger.debug('Stream event summary', {
236
+ eventType: this.lastEventType,
237
+ count: this.eventTypeCount,
238
+ });
239
+ }
240
+ this.lastEventType = null;
241
+ this.eventTypeCount = 0;
242
+ }
243
+ #captureToolCallArguments(item, toolCallArgumentsById) {
244
+ const rawItem = item?.rawItem ?? item;
245
+ if (!rawItem) {
246
+ return;
247
+ }
248
+ if (rawItem?.type !== 'function_call') {
249
+ return;
250
+ }
251
+ const callId = rawItem.callId ?? rawItem.call_id ?? rawItem.tool_call_id ?? rawItem.toolCallId ?? rawItem.id;
252
+ if (!callId) {
253
+ return;
254
+ }
255
+ const args = rawItem.arguments ?? rawItem.args ?? item?.arguments ?? item?.args;
256
+ if (!args) {
257
+ return;
258
+ }
259
+ toolCallArgumentsById.set(callId, args);
260
+ }
261
+ #attachCachedArguments(items = [], toolCallArgumentsById) {
262
+ if (!items?.length) {
263
+ return;
264
+ }
265
+ for (const item of items) {
266
+ if (!item) {
267
+ continue;
268
+ }
269
+ if (item.arguments || item.args || item?.rawItem?.arguments || item?.rawItem?.args) {
270
+ continue;
271
+ }
272
+ const rawItem = item?.rawItem ?? item;
273
+ const callId = rawItem?.callId ??
274
+ rawItem?.call_id ??
275
+ rawItem?.tool_call_id ??
276
+ rawItem?.toolCallId ??
277
+ rawItem?.id ??
278
+ item?.callId ??
279
+ item?.call_id ??
280
+ item?.tool_call_id ??
281
+ item?.toolCallId ??
282
+ item?.id;
283
+ if (!callId) {
284
+ continue;
285
+ }
286
+ const args = toolCallArgumentsById.get(callId);
287
+ if (!args) {
288
+ continue;
289
+ }
290
+ item.arguments = args;
291
+ }
292
+ }
293
+ #extractTextDelta(payload) {
294
+ if (payload === null || payload === undefined) {
295
+ return null;
296
+ }
297
+ if (typeof payload === 'string') {
298
+ return payload || null;
299
+ }
300
+ if (typeof payload !== 'object') {
301
+ return null;
302
+ }
303
+ const type = typeof payload.type === 'string' ? payload.type : '';
304
+ const looksLikeOutput = typeof type === 'string' && type.includes('output_text');
305
+ const hasOutputProperties = Boolean(payload.delta ?? payload.output_text ?? payload.text ?? payload.content);
306
+ if (!looksLikeOutput && !hasOutputProperties) {
307
+ return null;
308
+ }
309
+ const deltaCandidate = payload.delta ?? payload.output_text ?? payload.text ?? payload.content;
310
+ const text = this.#coerceToText(deltaCandidate);
311
+ return text || null;
312
+ }
313
+ #coerceToText(value) {
314
+ if (value === null || value === undefined) {
315
+ return '';
316
+ }
317
+ if (typeof value === 'string') {
318
+ return value;
319
+ }
320
+ if (typeof value === 'number' || typeof value === 'boolean') {
321
+ return String(value);
322
+ }
323
+ if (Array.isArray(value)) {
324
+ return value
325
+ .map((entry) => this.#coerceToText(entry))
326
+ .filter(Boolean)
327
+ .join('');
328
+ }
329
+ if (typeof value === 'object') {
330
+ const record = value;
331
+ const candidates = ['text', 'value', 'content', 'delta'];
332
+ for (const field of candidates) {
333
+ if (field in record) {
334
+ const text = this.#coerceToText(record[field]);
335
+ if (text) {
336
+ return text;
337
+ }
338
+ }
339
+ }
340
+ }
341
+ return '';
342
+ }
343
+ }
344
+ //# sourceMappingURL=stream-event-processor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-event-processor.js","sourceRoot":"","sources":["../../source/services/stream-event-processor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=stream-event-processor.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-event-processor.test.d.ts","sourceRoot":"","sources":["../../source/services/stream-event-processor.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,117 @@
1
+ import test from 'ava';
2
+ import { StreamEventProcessor } from './stream-event-processor.js';
3
+ const mockLogger = {
4
+ info: () => { },
5
+ warn: () => { },
6
+ error: () => { },
7
+ debug: () => { },
8
+ security: () => { },
9
+ setCorrelationId: () => { },
10
+ getCorrelationId: () => undefined,
11
+ clearCorrelationId: () => { },
12
+ };
13
+ class MockStream {
14
+ constructor(events, completed = undefined) {
15
+ this.events = events;
16
+ this.completed = Promise.resolve(completed);
17
+ this.lastResponseId = 'resp_test';
18
+ this.interruptions = [];
19
+ this.state = {};
20
+ this.newItems = [];
21
+ this.history = [];
22
+ this.finalOutput = '';
23
+ }
24
+ events;
25
+ completed;
26
+ lastResponseId;
27
+ interruptions;
28
+ state;
29
+ newItems;
30
+ history;
31
+ finalOutput;
32
+ async *[Symbol.asyncIterator]() {
33
+ for (const event of this.events) {
34
+ yield event;
35
+ }
36
+ }
37
+ }
38
+ test('StreamEventProcessor streams text and reasoning deltas with fullText', async (t) => {
39
+ const stream = new MockStream([
40
+ { type: 'response.output_text.delta', delta: 'Hello' },
41
+ {
42
+ data: {
43
+ type: 'model',
44
+ event: {
45
+ choices: [
46
+ {
47
+ delta: {
48
+ reasoning_content: 'think',
49
+ },
50
+ },
51
+ ],
52
+ },
53
+ },
54
+ },
55
+ ]);
56
+ const processor = new StreamEventProcessor({ logger: mockLogger, sessionId: 's1' });
57
+ const acc = {
58
+ finalOutput: '',
59
+ reasoningOutput: '',
60
+ emittedCommandIds: new Set(),
61
+ latestUsage: undefined,
62
+ };
63
+ const emitted = [];
64
+ for await (const event of processor.streamEvents(stream, acc, { preserveExistingToolArgs: false })) {
65
+ emitted.push(event);
66
+ }
67
+ t.is(emitted[0].type, 'text_delta');
68
+ t.is(emitted[0].delta, 'Hello');
69
+ t.is(emitted[0].fullText, 'Hello');
70
+ t.is(emitted[1].type, 'reasoning_delta');
71
+ t.is(emitted[1].delta, 'think');
72
+ t.is(emitted[1].fullText, 'think');
73
+ });
74
+ test('StreamEventProcessor emits tool_started and command_message with cached args', async (t) => {
75
+ const stream = new MockStream([
76
+ {
77
+ type: 'run_item_stream_event',
78
+ item: {
79
+ rawItem: {
80
+ type: 'function_call',
81
+ callId: 'call-1',
82
+ name: 'shell',
83
+ arguments: JSON.stringify({ command: 'echo hi' }),
84
+ },
85
+ },
86
+ },
87
+ {
88
+ type: 'tool_call_output_item',
89
+ rawItem: {
90
+ type: 'function_call_output',
91
+ callId: 'call-1',
92
+ name: 'shell',
93
+ output: 'exit 0\nhi',
94
+ },
95
+ },
96
+ ]);
97
+ const processor = new StreamEventProcessor({ logger: mockLogger, sessionId: 's1' });
98
+ const acc = {
99
+ finalOutput: '',
100
+ reasoningOutput: '',
101
+ emittedCommandIds: new Set(),
102
+ latestUsage: undefined,
103
+ };
104
+ const emitted = [];
105
+ for await (const event of processor.streamEvents(stream, acc, { preserveExistingToolArgs: false })) {
106
+ emitted.push(event);
107
+ }
108
+ const toolStarted = emitted.find((event) => event.type === 'tool_started');
109
+ const commandMessage = emitted.find((event) => event.type === 'command_message');
110
+ t.truthy(toolStarted);
111
+ t.is(toolStarted.toolCallId, 'call-1');
112
+ t.is(toolStarted.toolName, 'shell');
113
+ t.deepEqual(toolStarted.arguments, { command: 'echo hi' });
114
+ t.truthy(commandMessage);
115
+ t.is(commandMessage.message.command, 'echo hi');
116
+ });
117
+ //# sourceMappingURL=stream-event-processor.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-event-processor.test.js","sourceRoot":"","sources":["../../source/services/stream-event-processor.test.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"apply-patch.d.ts","sourceRoot":"","sources":["../../source/tools/apply-patch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,CAAC,EAAC,MAAM,KAAK,CAAC;AAKtB,OAAO,KAAK,EAAC,cAAc,EAAE,cAAc,EAAC,MAAM,YAAY,CAAC;AAC/D,OAAO,KAAK,EACR,eAAe,EACf,gBAAgB,EACnB,MAAM,mCAAmC,CAAC;AAO3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAEpE;;GAEG;AACH,qBAAa,oBAAqB,SAAQ,KAAK;IACP,QAAQ,EAAE,MAAM;gBAAxC,OAAO,EAAE,MAAM,EAAS,QAAQ,EAAE,MAAM;CAIvD;AAED,QAAA,MAAM,0BAA0B;;;;;;;iBAM9B,CAAC;AAEH,MAAM,MAAM,oBAAoB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,0BAA0B,CAAC,CAAC;AAE9E,eAAO,MAAM,8BAA8B,GACvC,MAAM,GAAG,EACT,OAAO,MAAM,EACb,wBAAwB,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,KAC7C,cAAc,EA8ChB,CAAC;AAEF,wBAAgB,8BAA8B,CAAC,IAAI,EAAE;IACjD,cAAc,EAAE,eAAe,CAAC;IAChC,eAAe,EAAE,gBAAgB,CAAC;IAClC,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACvC,GAAG,cAAc,CAAC,oBAAoB,CAAC,CAyXvC"}
1
+ {"version":3,"file":"apply-patch.d.ts","sourceRoot":"","sources":["../../source/tools/apply-patch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAKxB,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAE3F,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAEpE;;GAEG;AACH,qBAAa,oBAAqB,SAAQ,KAAK;IACT,QAAQ,EAAE,MAAM;gBAAxC,OAAO,EAAE,MAAM,EAAS,QAAQ,EAAE,MAAM;CAIrD;AAED,QAAA,MAAM,0BAA0B;;;;;;;iBAI9B,CAAC;AAEH,MAAM,MAAM,oBAAoB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,0BAA0B,CAAC,CAAC;AAE9E,eAAO,MAAM,8BAA8B,GACzC,MAAM,GAAG,EACT,OAAO,MAAM,EACb,wBAAwB,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,KAC3C,cAAc,EA4ChB,CAAC;AAEF,wBAAgB,8BAA8B,CAAC,IAAI,EAAE;IACnD,cAAc,EAAE,eAAe,CAAC;IAChC,eAAe,EAAE,gBAAgB,CAAC;IAClC,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACrC,GAAG,cAAc,CAAC,oBAAoB,CAAC,CAkXvC"}
@@ -3,7 +3,7 @@ import { readFile, writeFile, mkdir } from 'fs/promises';
3
3
  import path from 'path';
4
4
  import { applyDiff } from '@openai/agents';
5
5
  import { resolveWorkspacePath } from './utils.js';
6
- import { getOutputText, safeJsonParse, normalizeToolArguments, createBaseMessage, } from './format-helpers.js';
6
+ import { getOutputText, safeJsonParse, normalizeToolArguments, createBaseMessage } from './format-helpers.js';
7
7
  /**
8
8
  * Error thrown when patch validation fails (malformed diff)
9
9
  */
@@ -18,9 +18,7 @@ export class PatchValidationError extends Error {
18
18
  const applyPatchParametersSchema = z.object({
19
19
  type: z.enum(['create_file', 'update_file']),
20
20
  path: z.string().min(1, 'File path cannot be empty'),
21
- diff: z
22
- .string()
23
- .describe('Unified diff content for create/update operations'),
21
+ diff: z.string().describe('Unified diff content for create/update operations'),
24
22
  });
25
23
  export const formatApplyPatchCommandMessage = (item, index, _toolCallArgumentsById) => {
26
24
  const parsedOutput = safeJsonParse(getOutputText(item));
@@ -112,6 +110,25 @@ export function createApplyPatchToolDefinition(deps) {
112
110
  try {
113
111
  const editMode = settingsService.get('app.editMode');
114
112
  const { type, path: filePath, diff } = params;
113
+ const workspaceRoot = executionContext?.getCwd() || process.cwd();
114
+ const sshService = executionContext?.getSSHService();
115
+ const isRemote = executionContext?.isRemote() && !!sshService;
116
+ // Resolve and ensure target within workspace before any validation.
117
+ // This prevents validation from running against a mismatched cwd.
118
+ let targetPath;
119
+ try {
120
+ targetPath = resolveWorkspacePath(filePath, workspaceRoot);
121
+ }
122
+ catch (e) {
123
+ // Outside workspace => require approval
124
+ loggingService.security('apply_patch needsApproval: outside workspace', {
125
+ editMode,
126
+ type,
127
+ path: filePath,
128
+ error: e?.message || String(e),
129
+ });
130
+ return true;
131
+ }
115
132
  // Validate diff syntax by attempting a dry-run (before approval)
116
133
  if (type === 'create_file' || type === 'update_file') {
117
134
  try {
@@ -120,9 +137,10 @@ export function createApplyPatchToolDefinition(deps) {
120
137
  applyDiff('', diff);
121
138
  }
122
139
  else {
123
- // Dry-run: read existing file and test diff application
124
- const targetPath = resolveWorkspacePath(filePath);
125
- const original = await readFile(targetPath, 'utf8');
140
+ // Dry-run: read existing file and test diff application.
141
+ // Read failures are environment/file-state issues, not
142
+ // deterministic patch syntax failures.
143
+ const original = isRemote && sshService ? await sshService.readFile(targetPath) : await readFile(targetPath, 'utf8');
126
144
  applyDiff(original, diff);
127
145
  }
128
146
  loggingService.info('apply_patch validation passed', {
@@ -131,8 +149,22 @@ export function createApplyPatchToolDefinition(deps) {
131
149
  });
132
150
  }
133
151
  catch (diffError) {
134
- // Diff validation failed - auto-approve (skip user prompt) and fail in execute
135
- // This prevents breaking the stream while still rejecting the invalid patch
152
+ // Keep fast UX for deterministic patch-format errors, but
153
+ // require approval for environment/file-state failures.
154
+ const fileAccessFailure = typeof diffError?.code === 'string' ||
155
+ ['enoent', 'not found', 'no such file', 'permission denied', 'eacces', 'eperm', 'is a directory'].some((token) => String(diffError?.message || '')
156
+ .toLowerCase()
157
+ .includes(token));
158
+ if (fileAccessFailure) {
159
+ loggingService.warn('apply_patch prevalidation could not confirm patch due to file/context issue', {
160
+ type,
161
+ path: filePath,
162
+ error: diffError?.message || String(diffError),
163
+ });
164
+ return true;
165
+ }
166
+ // Diff-format validation failed - auto-approve and let execute
167
+ // return a structured error without bothering the user.
136
168
  loggingService.error('apply_patch validation failed - will fail in execute', {
137
169
  type,
138
170
  path: filePath,
@@ -151,27 +183,9 @@ export function createApplyPatchToolDefinition(deps) {
151
183
  // });
152
184
  // return true;
153
185
  // }
154
- // Resolve and ensure target within workspace
155
- const workspaceRoot = executionContext?.getCwd() || process.cwd();
156
- let targetPath;
157
- try {
158
- targetPath = resolveWorkspacePath(filePath, workspaceRoot);
159
- }
160
- catch (e) {
161
- // Outside workspace => require approval
162
- loggingService.security('apply_patch needsApproval: outside workspace', {
163
- editMode,
164
- type,
165
- path: filePath,
166
- error: e?.message || String(e),
167
- });
168
- return true;
169
- }
170
186
  const insideCwd = targetPath.startsWith(workspaceRoot + path.sep);
171
187
  // In edit mode, auto-approve create/update within cwd
172
- if (editMode &&
173
- insideCwd &&
174
- (type === 'create_file' || type === 'update_file')) {
188
+ if (editMode && insideCwd && (type === 'create_file' || type === 'update_file')) {
175
189
  loggingService.security('apply_patch needsApproval: auto-approved in edit mode', {
176
190
  editMode,
177
191
  type,
@@ -244,15 +258,13 @@ export function createApplyPatchToolDefinition(deps) {
244
258
  loggingService.error('Patch validation failed in execute', {
245
259
  type,
246
260
  path: filePath,
247
- error: validationError?.message ||
248
- String(validationError),
261
+ error: validationError?.message || String(validationError),
249
262
  });
250
263
  return JSON.stringify({
251
264
  output: [
252
265
  {
253
266
  success: false,
254
- error: `Invalid patch: ${validationError?.message ||
255
- String(validationError)}. Please check the file path and diff format.`,
267
+ error: `Invalid patch: ${validationError?.message || String(validationError)}. Please check the file path and diff format.`,
256
268
  },
257
269
  ],
258
270
  });
@@ -378,9 +390,7 @@ export function createApplyPatchToolDefinition(deps) {
378
390
  loggingService.error('File operation failed', {
379
391
  type: params.type,
380
392
  path: params.path,
381
- error: error instanceof Error
382
- ? error.message
383
- : String(error),
393
+ error: error instanceof Error ? error.message : String(error),
384
394
  });
385
395
  }
386
396
  return JSON.stringify({