@zhijiewang/openharness 0.9.3 → 0.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (282) hide show
  1. package/README.md +87 -24
  2. package/dist/Tool.d.ts.map +1 -1
  3. package/dist/Tool.js +7 -1
  4. package/dist/Tool.js.map +1 -1
  5. package/dist/Tool.test.js +8 -2
  6. package/dist/Tool.test.js.map +1 -1
  7. package/dist/agents/roles.d.ts +25 -0
  8. package/dist/agents/roles.d.ts.map +1 -0
  9. package/dist/agents/roles.js +116 -0
  10. package/dist/agents/roles.js.map +1 -0
  11. package/dist/agents/roles.test.d.ts +2 -0
  12. package/dist/agents/roles.test.d.ts.map +1 -0
  13. package/dist/agents/roles.test.js +38 -0
  14. package/dist/agents/roles.test.js.map +1 -0
  15. package/dist/commands/commands-new.test.d.ts +5 -0
  16. package/dist/commands/commands-new.test.d.ts.map +1 -0
  17. package/dist/commands/commands-new.test.js +132 -0
  18. package/dist/commands/commands-new.test.js.map +1 -0
  19. package/dist/commands/commands.test.js +31 -0
  20. package/dist/commands/commands.test.js.map +1 -1
  21. package/dist/commands/index.d.ts +2 -0
  22. package/dist/commands/index.d.ts.map +1 -1
  23. package/dist/commands/index.js +199 -6
  24. package/dist/commands/index.js.map +1 -1
  25. package/dist/components/REPL.js +1 -1
  26. package/dist/components/REPL.js.map +1 -1
  27. package/dist/git/git.test.js +33 -1
  28. package/dist/git/git.test.js.map +1 -1
  29. package/dist/git/index.d.ts +12 -0
  30. package/dist/git/index.d.ts.map +1 -1
  31. package/dist/git/index.js +47 -2
  32. package/dist/git/index.js.map +1 -1
  33. package/dist/harness/checkpoints.d.ts +36 -0
  34. package/dist/harness/checkpoints.d.ts.map +1 -0
  35. package/dist/harness/checkpoints.js +156 -0
  36. package/dist/harness/checkpoints.js.map +1 -0
  37. package/dist/harness/config.d.ts +3 -0
  38. package/dist/harness/config.d.ts.map +1 -1
  39. package/dist/harness/config.js +35 -2
  40. package/dist/harness/config.js.map +1 -1
  41. package/dist/harness/config.test.js +21 -1
  42. package/dist/harness/config.test.js.map +1 -1
  43. package/dist/harness/hooks-env.test.d.ts +5 -0
  44. package/dist/harness/hooks-env.test.d.ts.map +1 -0
  45. package/dist/harness/hooks-env.test.js +41 -0
  46. package/dist/harness/hooks-env.test.js.map +1 -0
  47. package/dist/harness/hooks.d.ts +7 -0
  48. package/dist/harness/hooks.d.ts.map +1 -1
  49. package/dist/harness/hooks.js +14 -0
  50. package/dist/harness/hooks.js.map +1 -1
  51. package/dist/harness/keybindings.d.ts.map +1 -1
  52. package/dist/harness/keybindings.js +4 -0
  53. package/dist/harness/keybindings.js.map +1 -1
  54. package/dist/harness/memory.d.ts +19 -0
  55. package/dist/harness/memory.d.ts.map +1 -1
  56. package/dist/harness/memory.js +85 -0
  57. package/dist/harness/memory.js.map +1 -1
  58. package/dist/harness/onboarding.d.ts +1 -1
  59. package/dist/harness/onboarding.d.ts.map +1 -1
  60. package/dist/harness/onboarding.js +59 -4
  61. package/dist/harness/onboarding.js.map +1 -1
  62. package/dist/harness/onboarding.test.d.ts +5 -0
  63. package/dist/harness/onboarding.test.d.ts.map +1 -0
  64. package/dist/harness/onboarding.test.js +93 -0
  65. package/dist/harness/onboarding.test.js.map +1 -0
  66. package/dist/harness/rules.d.ts +6 -1
  67. package/dist/harness/rules.d.ts.map +1 -1
  68. package/dist/harness/rules.js +52 -5
  69. package/dist/harness/rules.js.map +1 -1
  70. package/dist/harness/rules.test.js +30 -1
  71. package/dist/harness/rules.test.js.map +1 -1
  72. package/dist/harness/session.d.ts +8 -1
  73. package/dist/harness/session.d.ts.map +1 -1
  74. package/dist/harness/session.js +13 -5
  75. package/dist/harness/session.js.map +1 -1
  76. package/dist/harness/store.d.ts +46 -0
  77. package/dist/harness/store.d.ts.map +1 -0
  78. package/dist/harness/store.js +56 -0
  79. package/dist/harness/store.js.map +1 -0
  80. package/dist/harness/store.test.d.ts +2 -0
  81. package/dist/harness/store.test.d.ts.map +1 -0
  82. package/dist/harness/store.test.js +71 -0
  83. package/dist/harness/store.test.js.map +1 -0
  84. package/dist/harness/submit-handler.d.ts +2 -0
  85. package/dist/harness/submit-handler.d.ts.map +1 -1
  86. package/dist/harness/submit-handler.js +3 -0
  87. package/dist/harness/submit-handler.js.map +1 -1
  88. package/dist/main.js +153 -26
  89. package/dist/main.js.map +1 -1
  90. package/dist/mcp/client.d.ts +2 -0
  91. package/dist/mcp/client.d.ts.map +1 -1
  92. package/dist/mcp/client.js +10 -2
  93. package/dist/mcp/client.js.map +1 -1
  94. package/dist/mcp/loader.d.ts +2 -0
  95. package/dist/mcp/loader.d.ts.map +1 -1
  96. package/dist/mcp/loader.js +34 -18
  97. package/dist/mcp/loader.js.map +1 -1
  98. package/dist/mcp/loader.test.d.ts +7 -0
  99. package/dist/mcp/loader.test.d.ts.map +1 -0
  100. package/dist/mcp/loader.test.js +25 -0
  101. package/dist/mcp/loader.test.js.map +1 -0
  102. package/dist/providers/anthropic-convert.test.d.ts +5 -0
  103. package/dist/providers/anthropic-convert.test.d.ts.map +1 -0
  104. package/dist/providers/anthropic-convert.test.js +98 -0
  105. package/dist/providers/anthropic-convert.test.js.map +1 -0
  106. package/dist/providers/anthropic.d.ts.map +1 -1
  107. package/dist/providers/anthropic.js +23 -4
  108. package/dist/providers/anthropic.js.map +1 -1
  109. package/dist/providers/stream-parsing.test.d.ts +6 -0
  110. package/dist/providers/stream-parsing.test.d.ts.map +1 -0
  111. package/dist/providers/stream-parsing.test.js +174 -0
  112. package/dist/providers/stream-parsing.test.js.map +1 -0
  113. package/dist/query/compress.d.ts +17 -0
  114. package/dist/query/compress.d.ts.map +1 -0
  115. package/dist/query/compress.js +115 -0
  116. package/dist/query/compress.js.map +1 -0
  117. package/dist/query/errors.d.ts +10 -0
  118. package/dist/query/errors.d.ts.map +1 -0
  119. package/dist/query/errors.js +22 -0
  120. package/dist/query/errors.js.map +1 -0
  121. package/dist/query/index.d.ts +15 -0
  122. package/dist/query/index.d.ts.map +1 -0
  123. package/dist/query/index.js +199 -0
  124. package/dist/query/index.js.map +1 -0
  125. package/dist/query/tools.d.ts +17 -0
  126. package/dist/query/tools.d.ts.map +1 -0
  127. package/dist/query/tools.js +129 -0
  128. package/dist/query/tools.js.map +1 -0
  129. package/dist/query/types.d.ts +31 -0
  130. package/dist/query/types.d.ts.map +1 -0
  131. package/dist/query/types.js +5 -0
  132. package/dist/query/types.js.map +1 -0
  133. package/dist/query.d.ts +8 -38
  134. package/dist/query.d.ts.map +1 -1
  135. package/dist/query.js +7 -444
  136. package/dist/query.js.map +1 -1
  137. package/dist/query.test.js +1 -1
  138. package/dist/query.test.js.map +1 -1
  139. package/dist/renderer/cells.d.ts.map +1 -1
  140. package/dist/renderer/cells.js +15 -2
  141. package/dist/renderer/cells.js.map +1 -1
  142. package/dist/renderer/colors.d.ts +8 -0
  143. package/dist/renderer/colors.d.ts.map +1 -0
  144. package/dist/renderer/colors.js +18 -0
  145. package/dist/renderer/colors.js.map +1 -0
  146. package/dist/renderer/diff.test.d.ts +5 -0
  147. package/dist/renderer/diff.test.d.ts.map +1 -0
  148. package/dist/renderer/diff.test.js +140 -0
  149. package/dist/renderer/diff.test.js.map +1 -0
  150. package/dist/renderer/differ.d.ts +1 -5
  151. package/dist/renderer/differ.d.ts.map +1 -1
  152. package/dist/renderer/differ.js +3 -20
  153. package/dist/renderer/differ.js.map +1 -1
  154. package/dist/renderer/e2e.test.js +136 -53
  155. package/dist/renderer/e2e.test.js.map +1 -1
  156. package/dist/renderer/image.test.d.ts +5 -0
  157. package/dist/renderer/image.test.d.ts.map +1 -0
  158. package/dist/renderer/image.test.js +66 -0
  159. package/dist/renderer/image.test.js.map +1 -0
  160. package/dist/renderer/index.d.ts +28 -16
  161. package/dist/renderer/index.d.ts.map +1 -1
  162. package/dist/renderer/index.js +289 -222
  163. package/dist/renderer/index.js.map +1 -1
  164. package/dist/renderer/layout.d.ts +14 -5
  165. package/dist/renderer/layout.d.ts.map +1 -1
  166. package/dist/renderer/layout.js +522 -388
  167. package/dist/renderer/layout.js.map +1 -1
  168. package/dist/renderer/markdown.d.ts.map +1 -1
  169. package/dist/renderer/markdown.js +42 -36
  170. package/dist/renderer/markdown.js.map +1 -1
  171. package/dist/renderer/perf.test.js +1 -4
  172. package/dist/renderer/perf.test.js.map +1 -1
  173. package/dist/renderer/session-browser.test.d.ts +6 -0
  174. package/dist/renderer/session-browser.test.d.ts.map +1 -0
  175. package/dist/renderer/session-browser.test.js +95 -0
  176. package/dist/renderer/session-browser.test.js.map +1 -0
  177. package/dist/renderer/ui-ux.test.d.ts +15 -0
  178. package/dist/renderer/ui-ux.test.d.ts.map +1 -0
  179. package/dist/renderer/ui-ux.test.js +470 -0
  180. package/dist/renderer/ui-ux.test.js.map +1 -0
  181. package/dist/repl.d.ts.map +1 -1
  182. package/dist/repl.js +192 -67
  183. package/dist/repl.js.map +1 -1
  184. package/dist/services/StreamingToolExecutor.d.ts.map +1 -1
  185. package/dist/services/StreamingToolExecutor.js +4 -2
  186. package/dist/services/StreamingToolExecutor.js.map +1 -1
  187. package/dist/services/agent-messaging.d.ts +68 -0
  188. package/dist/services/agent-messaging.d.ts.map +1 -0
  189. package/dist/services/agent-messaging.js +121 -0
  190. package/dist/services/agent-messaging.js.map +1 -0
  191. package/dist/services/agent-messaging.test.d.ts +2 -0
  192. package/dist/services/agent-messaging.test.d.ts.map +1 -0
  193. package/dist/services/agent-messaging.test.js +88 -0
  194. package/dist/services/agent-messaging.test.js.map +1 -0
  195. package/dist/services/cron.d.ts +40 -0
  196. package/dist/services/cron.d.ts.map +1 -0
  197. package/dist/services/cron.js +90 -0
  198. package/dist/services/cron.js.map +1 -0
  199. package/dist/services/cron.test.d.ts +2 -0
  200. package/dist/services/cron.test.d.ts.map +1 -0
  201. package/dist/services/cron.test.js +49 -0
  202. package/dist/services/cron.test.js.map +1 -0
  203. package/dist/tools/AgentTool/index.d.ts +9 -0
  204. package/dist/tools/AgentTool/index.d.ts.map +1 -1
  205. package/dist/tools/AgentTool/index.js +89 -6
  206. package/dist/tools/AgentTool/index.js.map +1 -1
  207. package/dist/tools/BashTool/index.d.ts +6 -0
  208. package/dist/tools/BashTool/index.d.ts.map +1 -1
  209. package/dist/tools/BashTool/index.js +39 -1
  210. package/dist/tools/BashTool/index.js.map +1 -1
  211. package/dist/tools/FileEditTool/index.js +4 -4
  212. package/dist/tools/FileEditTool/index.js.map +1 -1
  213. package/dist/tools/FileReadTool/index.d.ts +3 -0
  214. package/dist/tools/FileReadTool/index.d.ts.map +1 -1
  215. package/dist/tools/FileReadTool/index.js +102 -4
  216. package/dist/tools/FileReadTool/index.js.map +1 -1
  217. package/dist/tools/FileWriteTool/index.d.ts.map +1 -1
  218. package/dist/tools/FileWriteTool/index.js +20 -5
  219. package/dist/tools/FileWriteTool/index.js.map +1 -1
  220. package/dist/tools/GlobTool/index.d.ts.map +1 -1
  221. package/dist/tools/GlobTool/index.js +4 -61
  222. package/dist/tools/GlobTool/index.js.map +1 -1
  223. package/dist/tools/GrepTool/index.d.ts +30 -0
  224. package/dist/tools/GrepTool/index.d.ts.map +1 -1
  225. package/dist/tools/GrepTool/index.js +153 -72
  226. package/dist/tools/GrepTool/index.js.map +1 -1
  227. package/dist/tools/LSTool/index.d.ts +3 -0
  228. package/dist/tools/LSTool/index.d.ts.map +1 -1
  229. package/dist/tools/LSTool/index.js +44 -29
  230. package/dist/tools/LSTool/index.js.map +1 -1
  231. package/dist/tools/TaskCreateTool/index.d.ts +6 -0
  232. package/dist/tools/TaskCreateTool/index.d.ts.map +1 -1
  233. package/dist/tools/TaskCreateTool/index.js +8 -2
  234. package/dist/tools/TaskCreateTool/index.js.map +1 -1
  235. package/dist/tools/TaskGetTool/index.d.ts +12 -0
  236. package/dist/tools/TaskGetTool/index.d.ts.map +1 -0
  237. package/dist/tools/TaskGetTool/index.js +50 -0
  238. package/dist/tools/TaskGetTool/index.js.map +1 -0
  239. package/dist/tools/TaskOutputTool/index.d.ts +15 -0
  240. package/dist/tools/TaskOutputTool/index.d.ts.map +1 -0
  241. package/dist/tools/TaskOutputTool/index.js +45 -0
  242. package/dist/tools/TaskOutputTool/index.js.map +1 -0
  243. package/dist/tools/TaskStopTool/index.d.ts +15 -0
  244. package/dist/tools/TaskStopTool/index.d.ts.map +1 -0
  245. package/dist/tools/TaskStopTool/index.js +51 -0
  246. package/dist/tools/TaskStopTool/index.js.map +1 -0
  247. package/dist/tools/TaskUpdateTool/index.d.ts +21 -3
  248. package/dist/tools/TaskUpdateTool/index.d.ts.map +1 -1
  249. package/dist/tools/TaskUpdateTool/index.js +48 -3
  250. package/dist/tools/TaskUpdateTool/index.js.map +1 -1
  251. package/dist/tools/tools-basic.test.js +191 -2
  252. package/dist/tools/tools-basic.test.js.map +1 -1
  253. package/dist/tools.d.ts.map +1 -1
  254. package/dist/tools.js +6 -0
  255. package/dist/tools.js.map +1 -1
  256. package/dist/types/permissions.d.ts +2 -2
  257. package/dist/types/permissions.d.ts.map +1 -1
  258. package/dist/types/permissions.js +59 -13
  259. package/dist/types/permissions.js.map +1 -1
  260. package/dist/types/permissions.test.js +57 -0
  261. package/dist/types/permissions.test.js.map +1 -1
  262. package/dist/utils/bash-safety.d.ts +18 -0
  263. package/dist/utils/bash-safety.d.ts.map +1 -0
  264. package/dist/utils/bash-safety.js +227 -0
  265. package/dist/utils/bash-safety.js.map +1 -0
  266. package/dist/utils/bash-safety.test.d.ts +2 -0
  267. package/dist/utils/bash-safety.test.d.ts.map +1 -0
  268. package/dist/utils/bash-safety.test.js +112 -0
  269. package/dist/utils/bash-safety.test.js.map +1 -0
  270. package/dist/utils/fs.d.ts +15 -0
  271. package/dist/utils/fs.d.ts.map +1 -0
  272. package/dist/utils/fs.js +64 -0
  273. package/dist/utils/fs.js.map +1 -0
  274. package/dist/utils/fs.test.d.ts +5 -0
  275. package/dist/utils/fs.test.d.ts.map +1 -0
  276. package/dist/utils/fs.test.js +82 -0
  277. package/dist/utils/fs.test.js.map +1 -0
  278. package/dist/utils/safe-env.d.ts +10 -0
  279. package/dist/utils/safe-env.d.ts.map +1 -0
  280. package/dist/utils/safe-env.js +40 -0
  281. package/dist/utils/safe-env.js.map +1 -0
  282. package/package.json +3 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/query/errors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,eAAO,MAAM,sBAAsB,IAAI,CAAC;AACxC,eAAO,MAAM,sBAAsB,IAAI,CAAC;AAExC,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,KAAK,GAAG,OAAO,CAGpD;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,KAAK,GAAG,OAAO,CAGnD;AAED,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,KAAK,GAAG,OAAO,CAGxD;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,KAAK,GAAG,OAAO,CAGlD"}
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Error classification and recovery helpers for the query loop.
3
+ */
4
+ export const MAX_CONSECUTIVE_ERRORS = 3;
5
+ export const MAX_RATE_LIMIT_RETRIES = 3;
6
+ export function isRateLimitError(err) {
7
+ const msg = err.message.toLowerCase();
8
+ return msg.includes("429") || msg.includes("rate limit") || msg.includes("too many requests");
9
+ }
10
+ export function isOverloadError(err) {
11
+ const msg = err.message.toLowerCase();
12
+ return msg.includes("503") || msg.includes("overloaded") || msg.includes("service unavailable") || msg.includes("529");
13
+ }
14
+ export function isPromptTooLongError(err) {
15
+ const msg = err.message.toLowerCase();
16
+ return msg.includes("prompt") && msg.includes("long");
17
+ }
18
+ export function isNetworkError(err) {
19
+ const msg = err.message.toLowerCase();
20
+ return msg.includes("network") || msg.includes("fetch") || msg.includes("econnrefused");
21
+ }
22
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/query/errors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC;AACxC,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC;AAExC,MAAM,UAAU,gBAAgB,CAAC,GAAU;IACzC,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;IACtC,OAAO,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;AAChG,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,GAAU;IACxC,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;IACtC,OAAO,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,qBAAqB,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AACzH,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,GAAU;IAC7C,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;IACtC,OAAO,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,GAAU;IACvC,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;IACtC,OAAO,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;AAC1F,CAAC"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Agent loop — the core LLM-to-Tool orchestration cycle.
3
+ *
4
+ * This is the coordinator that delegates to sub-modules:
5
+ * - compress.ts — message compression strategies
6
+ * - tools.ts — tool execution, permission checking, batching
7
+ * - errors.ts — error classification and recovery
8
+ * - types.ts — shared types
9
+ */
10
+ import type { StreamEvent } from "../types/events.js";
11
+ import type { QueryConfig } from "./types.js";
12
+ export type { QueryConfig, QueryLoopState } from "./types.js";
13
+ export { compressMessages } from "./compress.js";
14
+ export declare function query(userMessage: string, config: QueryConfig, existingMessages?: import("../types/message.js").Message[]): AsyncGenerator<StreamEvent, void>;
15
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/query/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAOtD,OAAO,KAAK,EAAE,WAAW,EAAkB,MAAM,YAAY,CAAC;AAM9D,YAAY,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAIjD,wBAAuB,KAAK,CAC1B,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,WAAW,EACnB,gBAAgB,GAAE,OAAO,qBAAqB,EAAE,OAAO,EAAO,GAC7D,cAAc,CAAC,WAAW,EAAE,IAAI,CAAC,CAiNnC"}
@@ -0,0 +1,199 @@
1
+ /**
2
+ * Agent loop — the core LLM-to-Tool orchestration cycle.
3
+ *
4
+ * This is the coordinator that delegates to sub-modules:
5
+ * - compress.ts — message compression strategies
6
+ * - tools.ts — tool execution, permission checking, batching
7
+ * - errors.ts — error classification and recovery
8
+ * - types.ts — shared types
9
+ */
10
+ import { toolToAPIFormat } from "../Tool.js";
11
+ import { createAssistantMessage, createUserMessage } from "../types/message.js";
12
+ import { StreamingToolExecutor } from "../services/StreamingToolExecutor.js";
13
+ import { getContextWindow } from "../harness/cost.js";
14
+ import { createToolResultMessage } from "../types/message.js";
15
+ import { makeTokenEstimator, estimateMessagesTokens, compressMessages, summarizeConversation } from "./compress.js";
16
+ import { executeToolCalls } from "./tools.js";
17
+ import { isRateLimitError, isOverloadError, isPromptTooLongError, isNetworkError, MAX_CONSECUTIVE_ERRORS, MAX_RATE_LIMIT_RETRIES } from "./errors.js";
18
+ export { compressMessages } from "./compress.js";
19
+ const DEFAULT_MAX_TURNS = 50;
20
+ export async function* query(userMessage, config, existingMessages = []) {
21
+ const maxTurns = config.maxTurns ?? DEFAULT_MAX_TURNS;
22
+ const toolContext = {
23
+ workingDir: process.cwd(),
24
+ abortSignal: config.abortSignal,
25
+ provider: config.provider,
26
+ model: config.model,
27
+ tools: config.tools,
28
+ systemPrompt: config.systemPrompt,
29
+ permissionMode: config.permissionMode,
30
+ askUserQuestion: config.askUserQuestion,
31
+ };
32
+ const estimateTokens = makeTokenEstimator(config.provider);
33
+ // Check provider capabilities
34
+ const modelInfo = config.provider.getModelInfo?.(config.model ?? '');
35
+ const toolsSupported = !modelInfo || modelInfo.supportsTools;
36
+ const apiTools = toolsSupported ? config.tools.map(toolToAPIFormat) : undefined;
37
+ const toolPrompts = toolsSupported
38
+ ? config.tools.map((t) => t.prompt()).join("\n\n")
39
+ : "";
40
+ const fullSystemPrompt = toolPrompts
41
+ ? config.systemPrompt + "\n\n# Available Tools\n\n" + toolPrompts
42
+ : config.systemPrompt;
43
+ const state = {
44
+ messages: [...existingMessages, createUserMessage(userMessage)],
45
+ turn: 0,
46
+ totalCost: 0,
47
+ totalInputTokens: 0,
48
+ totalOutputTokens: 0,
49
+ consecutiveErrors: 0,
50
+ };
51
+ // ── Main loop ──
52
+ while (state.turn < maxTurns) {
53
+ state.turn++;
54
+ if (config.abortSignal?.aborted) {
55
+ yield { type: "turn_complete", reason: "aborted" };
56
+ return;
57
+ }
58
+ if (config.maxCost && config.maxCost > 0 && state.totalCost >= config.maxCost) {
59
+ yield { type: "error", message: `Budget exceeded: $${state.totalCost.toFixed(4)}` };
60
+ yield { type: "turn_complete", reason: "budget_exceeded" };
61
+ return;
62
+ }
63
+ // Context window management
64
+ const contextWindow = getContextWindow(config.model);
65
+ const estimatedTokens = estimateMessagesTokens(state.messages, estimateTokens);
66
+ if (estimatedTokens > contextWindow * 0.8) {
67
+ state.messages = compressMessages(state.messages, Math.floor(contextWindow * 0.6));
68
+ const afterBasic = estimateMessagesTokens(state.messages, estimateTokens);
69
+ if (afterBasic > contextWindow * 0.7 && state.messages.length > 4) {
70
+ try {
71
+ state.messages = await summarizeConversation(config.provider, state.messages, config.model, Math.floor(contextWindow * 0.5));
72
+ yield { type: "error", message: "Context compressed with LLM summarization." };
73
+ }
74
+ catch { /* continue with basic compression */ }
75
+ }
76
+ }
77
+ // ── LLM call with streaming ──
78
+ let assistantContent = "";
79
+ const toolCalls = [];
80
+ let streamError = null;
81
+ const streamingExecutor = new StreamingToolExecutor(config.tools, toolContext, config.permissionMode, config.askUser, config.abortSignal);
82
+ try {
83
+ for await (const event of config.provider.stream(state.messages, fullSystemPrompt, apiTools, config.model)) {
84
+ if (config.abortSignal?.aborted)
85
+ break;
86
+ switch (event.type) {
87
+ case "text_delta":
88
+ assistantContent += event.content;
89
+ yield event;
90
+ break;
91
+ case "tool_call_start":
92
+ toolCalls.push({ id: event.callId, toolName: event.toolName, arguments: {} });
93
+ yield event;
94
+ break;
95
+ case "tool_call_complete": {
96
+ const tc = toolCalls.find((t) => t.id === event.callId);
97
+ if (tc) {
98
+ const idx = toolCalls.indexOf(tc);
99
+ toolCalls[idx] = { ...tc, arguments: event.arguments };
100
+ }
101
+ if (streamingExecutor) {
102
+ streamingExecutor.addTool({ id: event.callId, toolName: event.toolName, arguments: event.arguments });
103
+ }
104
+ break;
105
+ }
106
+ case "cost_update":
107
+ state.totalCost += event.cost;
108
+ state.totalInputTokens += event.inputTokens;
109
+ state.totalOutputTokens += event.outputTokens;
110
+ yield event;
111
+ break;
112
+ case "error":
113
+ yield event;
114
+ break;
115
+ }
116
+ }
117
+ state.consecutiveErrors = 0;
118
+ }
119
+ catch (err) {
120
+ streamError = err instanceof Error ? err : new Error(String(err));
121
+ state.consecutiveErrors++;
122
+ // Circuit breaker
123
+ if (state.consecutiveErrors >= MAX_CONSECUTIVE_ERRORS) {
124
+ yield { type: "error", message: `Too many consecutive errors (${state.consecutiveErrors}): ${streamError.message}` };
125
+ yield { type: "turn_complete", reason: "error" };
126
+ return;
127
+ }
128
+ // Error recovery cascade
129
+ if (isRateLimitError(streamError) || isOverloadError(streamError)) {
130
+ const attempt = state.consecutiveErrors;
131
+ const isOverload = isOverloadError(streamError);
132
+ if (attempt <= MAX_RATE_LIMIT_RETRIES) {
133
+ const baseRetry = Math.pow(2, attempt) * (isOverload ? 2 : 1);
134
+ const retryIn = baseRetry * (0.5 + Math.random());
135
+ yield { type: "rate_limited", retryIn: Math.round(retryIn), attempt };
136
+ await new Promise((r) => setTimeout(r, retryIn * 1000));
137
+ continue;
138
+ }
139
+ yield { type: "error", message: `${isOverload ? "Server overloaded" : "Rate limit exceeded"} after ${MAX_RATE_LIMIT_RETRIES} retries.` };
140
+ yield { type: "turn_complete", reason: "error" };
141
+ return;
142
+ }
143
+ if (isPromptTooLongError(streamError)) {
144
+ state.promptTooLongRetries = (state.promptTooLongRetries ?? 0) + 1;
145
+ if (state.promptTooLongRetries > 2) {
146
+ yield { type: "error", message: "Context still too long after 2 compression attempts." };
147
+ yield { type: "turn_complete", reason: "error" };
148
+ return;
149
+ }
150
+ state.messages = compressMessages(state.messages, Math.floor(contextWindow * 0.5));
151
+ state.transition = "retry_prompt_too_long";
152
+ yield { type: "error", message: "Context too long, compressing history..." };
153
+ continue;
154
+ }
155
+ if (isNetworkError(streamError)) {
156
+ state.transition = "retry_network";
157
+ const delay = 1000 * Math.pow(2, state.consecutiveErrors - 1);
158
+ yield { type: "error", message: `Network error, retrying in ${delay / 1000}s...` };
159
+ await new Promise((r) => setTimeout(r, delay));
160
+ continue;
161
+ }
162
+ yield { type: "error", message: streamError.message };
163
+ yield { type: "turn_complete", reason: "error" };
164
+ return;
165
+ }
166
+ if (config.abortSignal?.aborted) {
167
+ yield { type: "turn_complete", reason: "aborted" };
168
+ return;
169
+ }
170
+ if (assistantContent === "" && toolCalls.length === 0) {
171
+ yield { type: "error", message: "No response received. Check that your model server is running and the model name is correct." };
172
+ return;
173
+ }
174
+ state.messages.push(createAssistantMessage(assistantContent, toolCalls.length > 0 ? toolCalls : undefined));
175
+ if (toolCalls.length === 0) {
176
+ yield { type: "turn_complete", reason: "completed" };
177
+ return;
178
+ }
179
+ // Collect streaming tool results
180
+ await streamingExecutor.waitForAll();
181
+ const completedResults = [...streamingExecutor.getCompletedResults()];
182
+ const executedIds = new Set(completedResults.map(r => r.toolCall.id));
183
+ for (const { callId, chunk } of streamingExecutor.outputChunks) {
184
+ yield { type: 'tool_output_delta', callId, chunk };
185
+ }
186
+ for (const { toolCall: tc, result } of completedResults) {
187
+ yield { type: "tool_call_end", callId: tc.id, output: result.output, isError: result.isError };
188
+ state.messages.push(createToolResultMessage({ callId: tc.id, output: result.output, isError: result.isError }));
189
+ }
190
+ // Execute remaining tools not started during streaming
191
+ const remaining = toolCalls.filter(tc => !executedIds.has(tc.id));
192
+ if (remaining.length > 0) {
193
+ yield* executeToolCalls(remaining, config.tools, toolContext, config.permissionMode, config.askUser, state);
194
+ }
195
+ state.transition = "next_turn";
196
+ }
197
+ yield { type: "turn_complete", reason: "max_turns" };
198
+ }
199
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/query/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Tool execution — permission checking, batching, output capping.
3
+ */
4
+ import type { ToolContext, ToolResult, Tools } from "../Tool.js";
5
+ import type { StreamEvent } from "../types/events.js";
6
+ import type { ToolCall } from "../types/message.js";
7
+ import type { AskUserFn, PermissionMode } from "../types/permissions.js";
8
+ import type { QueryLoopState } from "./types.js";
9
+ type Batch = {
10
+ concurrent: boolean;
11
+ calls: ToolCall[];
12
+ };
13
+ export declare function partitionToolCalls(toolCalls: ToolCall[], tools: Tools): Batch[];
14
+ export declare function executeSingleTool(toolCall: ToolCall, tools: Tools, context: ToolContext, permissionMode: PermissionMode, askUser?: AskUserFn): Promise<ToolResult>;
15
+ export declare function executeToolCalls(toolCalls: ToolCall[], tools: Tools, context: ToolContext, permissionMode: PermissionMode, askUser?: AskUserFn, state?: QueryLoopState): AsyncGenerator<StreamEvent, void>;
16
+ export {};
17
+ //# sourceMappingURL=tools.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tools.d.ts","sourceRoot":"","sources":["../../src/query/tools.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAQ,WAAW,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEvE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIzE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAKjD,KAAK,KAAK,GAAG;IAAE,UAAU,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,QAAQ,EAAE,CAAA;CAAE,CAAC;AAExD,wBAAgB,kBAAkB,CAAC,SAAS,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,KAAK,GAAG,KAAK,EAAE,CAqB/E;AAED,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,WAAW,EACpB,cAAc,EAAE,cAAc,EAC9B,OAAO,CAAC,EAAE,SAAS,GAClB,OAAO,CAAC,UAAU,CAAC,CAuErB;AAED,wBAAuB,gBAAgB,CACrC,SAAS,EAAE,QAAQ,EAAE,EACrB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,WAAW,EACpB,cAAc,EAAE,cAAc,EAC9B,OAAO,CAAC,EAAE,SAAS,EACnB,KAAK,CAAC,EAAE,cAAc,GACrB,cAAc,CAAC,WAAW,EAAE,IAAI,CAAC,CA4BnC"}
@@ -0,0 +1,129 @@
1
+ /**
2
+ * Tool execution — permission checking, batching, output capping.
3
+ */
4
+ import { findToolByName } from "../Tool.js";
5
+ import { createToolResultMessage } from "../types/message.js";
6
+ import { checkPermission } from "../types/permissions.js";
7
+ import { emitHook } from "../harness/hooks.js";
8
+ import { createCheckpoint, getAffectedFiles } from "../harness/checkpoints.js";
9
+ const MAX_TOOL_RESULT_CHARS = 100_000;
10
+ const TOOL_TIMEOUT_MS = 120_000;
11
+ export function partitionToolCalls(toolCalls, tools) {
12
+ const batches = [];
13
+ let currentConcurrent = [];
14
+ for (const tc of toolCalls) {
15
+ const tool = findToolByName(tools, tc.toolName);
16
+ const isSafe = tool ? tool.isConcurrencySafe(tc.arguments) : false;
17
+ if (isSafe) {
18
+ currentConcurrent.push(tc);
19
+ }
20
+ else {
21
+ if (currentConcurrent.length > 0) {
22
+ batches.push({ concurrent: true, calls: currentConcurrent });
23
+ currentConcurrent = [];
24
+ }
25
+ batches.push({ concurrent: false, calls: [tc] });
26
+ }
27
+ }
28
+ if (currentConcurrent.length > 0) {
29
+ batches.push({ concurrent: true, calls: currentConcurrent });
30
+ }
31
+ return batches;
32
+ }
33
+ export async function executeSingleTool(toolCall, tools, context, permissionMode, askUser) {
34
+ const tool = findToolByName(tools, toolCall.toolName);
35
+ if (!tool) {
36
+ return { output: `Error: Unknown tool '${toolCall.toolName}'`, isError: true };
37
+ }
38
+ const parsed = tool.inputSchema.safeParse(toolCall.arguments);
39
+ if (!parsed.success) {
40
+ return { output: `Validation error: ${parsed.error.message}`, isError: true };
41
+ }
42
+ // Permission check
43
+ const perm = checkPermission(permissionMode, tool.riskLevel, tool.isReadOnly(parsed.data), tool.name, parsed.data);
44
+ if (!perm.allowed) {
45
+ if (perm.reason === "needs-approval" && askUser) {
46
+ const { formatToolArgs } = await import("../utils/tool-summary.js");
47
+ const description = formatToolArgs(tool.name, toolCall.arguments);
48
+ const allowed = await askUser(tool.name, description, tool.riskLevel);
49
+ if (!allowed) {
50
+ return { output: "Permission denied by user.", isError: true };
51
+ }
52
+ }
53
+ else {
54
+ return { output: `Permission denied: ${perm.reason}`, isError: true };
55
+ }
56
+ }
57
+ // Checkpoint: save affected files before modification
58
+ if (!tool.isReadOnly(parsed.data)) {
59
+ const affected = getAffectedFiles(tool.name, parsed.data);
60
+ if (affected.length > 0) {
61
+ createCheckpoint(0, affected, `${tool.name} ${affected[0]}`);
62
+ }
63
+ }
64
+ // Hook: preToolUse
65
+ const hookAllowed = emitHook("preToolUse", {
66
+ toolName: tool.name,
67
+ toolArgs: JSON.stringify(toolCall.arguments).slice(0, 1000),
68
+ });
69
+ if (!hookAllowed) {
70
+ return { output: "Blocked by preToolUse hook.", isError: true };
71
+ }
72
+ // Execute with timeout and result budgeting
73
+ try {
74
+ const toolAbort = AbortSignal.timeout(TOOL_TIMEOUT_MS);
75
+ const contextWithTimeout = { ...context, abortSignal: context.abortSignal ?? toolAbort };
76
+ const result = await Promise.race([
77
+ tool.call(parsed.data, contextWithTimeout),
78
+ new Promise((_, reject) => {
79
+ toolAbort.addEventListener("abort", () => reject(new Error(`Tool '${tool.name}' timed out after ${TOOL_TIMEOUT_MS / 1000}s`)));
80
+ }),
81
+ ]);
82
+ // Hook: postToolUse
83
+ emitHook("postToolUse", {
84
+ toolName: tool.name,
85
+ toolArgs: JSON.stringify(toolCall.arguments).slice(0, 1000),
86
+ toolOutput: result.output.slice(0, 1000),
87
+ });
88
+ // Strip ANSI and cap output
89
+ let output = result.output.replace(/\x1b\[[0-9;]*[a-zA-Z]/g, "");
90
+ if (output.length > MAX_TOOL_RESULT_CHARS) {
91
+ output = output.slice(0, MAX_TOOL_RESULT_CHARS)
92
+ + `\n\n[TRUNCATED: output was ${result.output.length.toLocaleString()} chars, showing first ${MAX_TOOL_RESULT_CHARS.toLocaleString()}]`;
93
+ }
94
+ return { output, isError: result.isError };
95
+ }
96
+ catch (err) {
97
+ return { output: `Tool error: ${err instanceof Error ? err.message : String(err)}`, isError: true };
98
+ }
99
+ }
100
+ export async function* executeToolCalls(toolCalls, tools, context, permissionMode, askUser, state) {
101
+ const batches = partitionToolCalls(toolCalls, tools);
102
+ const outputChunks = [];
103
+ const onOutputChunk = (callId, chunk) => {
104
+ outputChunks.push({ type: 'tool_output_delta', callId, chunk });
105
+ };
106
+ for (const batch of batches) {
107
+ if (batch.concurrent) {
108
+ const results = await Promise.all(batch.calls.map((tc) => executeSingleTool(tc, tools, { ...context, callId: tc.id, onOutputChunk }, permissionMode, askUser)));
109
+ for (const chunk of outputChunks.splice(0))
110
+ yield chunk;
111
+ for (let i = 0; i < batch.calls.length; i++) {
112
+ const tc = batch.calls[i];
113
+ const result = results[i];
114
+ yield { type: "tool_call_end", callId: tc.id, output: result.output, isError: result.isError };
115
+ state?.messages.push(createToolResultMessage({ callId: tc.id, output: result.output, isError: result.isError }));
116
+ }
117
+ }
118
+ else {
119
+ for (const tc of batch.calls) {
120
+ const result = await executeSingleTool(tc, tools, { ...context, callId: tc.id, onOutputChunk }, permissionMode, askUser);
121
+ for (const chunk of outputChunks.splice(0))
122
+ yield chunk;
123
+ yield { type: "tool_call_end", callId: tc.id, output: result.output, isError: result.isError };
124
+ state?.messages.push(createToolResultMessage({ callId: tc.id, output: result.output, isError: result.isError }));
125
+ }
126
+ }
127
+ }
128
+ }
129
+ //# sourceMappingURL=tools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tools.js","sourceRoot":"","sources":["../../src/query/tools.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Shared types for the query loop sub-modules.
3
+ */
4
+ import type { Message } from "../types/message.js";
5
+ import type { Provider } from "../providers/base.js";
6
+ import type { Tools } from "../Tool.js";
7
+ import type { AskUserFn, PermissionMode } from "../types/permissions.js";
8
+ export type QueryConfig = {
9
+ provider: Provider;
10
+ tools: Tools;
11
+ systemPrompt: string;
12
+ permissionMode: PermissionMode;
13
+ askUser?: AskUserFn;
14
+ askUserQuestion?: (question: string, options?: string[]) => Promise<string>;
15
+ maxTurns?: number;
16
+ maxCost?: number;
17
+ model?: string;
18
+ abortSignal?: AbortSignal;
19
+ };
20
+ export type TransitionReason = "next_turn" | "retry_network" | "retry_prompt_too_long" | "retry_max_output_tokens";
21
+ export type QueryLoopState = {
22
+ messages: Message[];
23
+ turn: number;
24
+ totalCost: number;
25
+ totalInputTokens: number;
26
+ totalOutputTokens: number;
27
+ consecutiveErrors: number;
28
+ transition?: TransitionReason;
29
+ promptTooLongRetries?: number;
30
+ };
31
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/query/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzE,MAAM,MAAM,WAAW,GAAG;IACxB,QAAQ,EAAE,QAAQ,CAAC;IACnB,KAAK,EAAE,KAAK,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,cAAc,CAAC;IAC/B,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,eAAe,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IAC5E,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,gBAAgB,GACxB,WAAW,GACX,eAAe,GACf,uBAAuB,GACvB,yBAAyB,CAAC;AAE9B,MAAM,MAAM,cAAc,GAAG;IAC3B,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,oBAAoB,CAAC,EAAE,MAAM,CAAC;CAC/B,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Shared types for the query loop sub-modules.
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/query/types.ts"],"names":[],"mappings":"AAAA;;GAEG"}
package/dist/query.d.ts CHANGED
@@ -1,41 +1,11 @@
1
1
  /**
2
- * Agent loop — the core LLM-to-Tool orchestration cycle.
3
- *
4
- * Core agent loop architecture:
5
- * - while(true) state machine with explicit transitions
6
- * - Error recovery with ordered fallbacks and circuit breaker
7
- * - Context window management with message compression
8
- * - Tool result budgeting (cap large outputs)
9
- * - Permission blocking (awaits user approval before tool execution)
2
+ * Re-export from query/index.ts — the agent loop has been split into sub-modules:
3
+ * - query/index.ts — main orchestration loop
4
+ * - query/compress.ts message compression strategies
5
+ * - query/tools.ts tool execution, permission checking, batching
6
+ * - query/errors.ts error classification and recovery
7
+ * - query/types.ts shared types
10
8
  */
11
- import type { Tools } from "./Tool.js";
12
- import type { StreamEvent } from "./types/events.js";
13
- import type { Message } from "./types/message.js";
14
- import type { AskUserFn, PermissionMode } from "./types/permissions.js";
15
- import type { Provider } from "./providers/base.js";
16
- export type QueryConfig = {
17
- provider: Provider;
18
- tools: Tools;
19
- systemPrompt: string;
20
- permissionMode: PermissionMode;
21
- askUser?: AskUserFn;
22
- askUserQuestion?: (question: string, options?: string[]) => Promise<string>;
23
- maxTurns?: number;
24
- maxCost?: number;
25
- model?: string;
26
- abortSignal?: AbortSignal;
27
- };
28
- type TransitionReason = "next_turn" | "retry_network" | "retry_prompt_too_long" | "retry_max_output_tokens";
29
- type QueryLoopState = {
30
- messages: Message[];
31
- turn: number;
32
- totalCost: number;
33
- totalInputTokens: number;
34
- totalOutputTokens: number;
35
- consecutiveErrors: number;
36
- transition?: TransitionReason;
37
- };
38
- export declare function query(userMessage: string, config: QueryConfig, existingMessages?: Message[]): AsyncGenerator<StreamEvent, void>;
39
- export declare function compressMessages(messages: Message[], targetTokens: number): Message[];
40
- export type { QueryLoopState };
9
+ export { query, compressMessages } from "./query/index.js";
10
+ export type { QueryConfig, QueryLoopState } from "./query/index.js";
41
11
  //# sourceMappingURL=query.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../src/query.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAiC,KAAK,EAAE,MAAM,WAAW,CAAC;AAEtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAE,OAAO,EAAY,MAAM,oBAAoB,CAAC;AAM5D,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAQpD,MAAM,MAAM,WAAW,GAAG;IACxB,QAAQ,EAAE,QAAQ,CAAC;IACnB,KAAK,EAAE,KAAK,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,cAAc,CAAC;IAC/B,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,eAAe,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IAC5E,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC;AAIF,KAAK,gBAAgB,GACjB,WAAW,GACX,eAAe,GACf,uBAAuB,GACvB,yBAAyB,CAAC;AAE9B,KAAK,cAAc,GAAG;IACpB,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,UAAU,CAAC,EAAE,gBAAgB,CAAC;CAC/B,CAAC;AAcF,wBAAuB,KAAK,CAC1B,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,WAAW,EACnB,gBAAgB,GAAE,OAAO,EAAO,GAC/B,cAAc,CAAC,WAAW,EAAE,IAAI,CAAC,CA+OnC;AAkKD,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,EAAE,CAqDrF;AAuDD,YAAY,EAAE,cAAc,EAAE,CAAC"}
1
+ {"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../src/query.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,OAAO,EAAE,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAC3D,YAAY,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC"}