groundswell 0.0.3 → 1.0.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 (292) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +26 -9
  3. package/dist/cache/cache-key.d.ts +20 -0
  4. package/dist/cache/cache-key.d.ts.map +1 -1
  5. package/dist/cache/cache-key.js +9 -0
  6. package/dist/cache/cache-key.js.map +1 -1
  7. package/dist/core/agent.d.ts +120 -29
  8. package/dist/core/agent.d.ts.map +1 -1
  9. package/dist/core/agent.js +584 -177
  10. package/dist/core/agent.js.map +1 -1
  11. package/dist/core/mcp-handler.d.ts +63 -5
  12. package/dist/core/mcp-handler.d.ts.map +1 -1
  13. package/dist/core/mcp-handler.js +184 -4
  14. package/dist/core/mcp-handler.js.map +1 -1
  15. package/dist/core/workflow-context.d.ts +6 -2
  16. package/dist/core/workflow-context.d.ts.map +1 -1
  17. package/dist/core/workflow-context.js +99 -4
  18. package/dist/core/workflow-context.js.map +1 -1
  19. package/dist/core/workflow.d.ts +315 -13
  20. package/dist/core/workflow.d.ts.map +1 -1
  21. package/dist/core/workflow.js +552 -30
  22. package/dist/core/workflow.js.map +1 -1
  23. package/dist/debugger/event-replayer.d.ts +422 -0
  24. package/dist/debugger/event-replayer.d.ts.map +1 -0
  25. package/dist/debugger/event-replayer.js +639 -0
  26. package/dist/debugger/event-replayer.js.map +1 -0
  27. package/dist/debugger/tree-debugger.d.ts +170 -1
  28. package/dist/debugger/tree-debugger.d.ts.map +1 -1
  29. package/dist/debugger/tree-debugger.js +423 -1
  30. package/dist/debugger/tree-debugger.js.map +1 -1
  31. package/dist/decorators/step.d.ts.map +1 -1
  32. package/dist/decorators/step.js +129 -47
  33. package/dist/decorators/step.js.map +1 -1
  34. package/dist/harnesses/claude-code-harness.d.ts +391 -0
  35. package/dist/harnesses/claude-code-harness.d.ts.map +1 -0
  36. package/dist/harnesses/claude-code-harness.js +1076 -0
  37. package/dist/harnesses/claude-code-harness.js.map +1 -0
  38. package/dist/harnesses/harness-registry.d.ts +440 -0
  39. package/dist/harnesses/harness-registry.d.ts.map +1 -0
  40. package/dist/harnesses/harness-registry.js +543 -0
  41. package/dist/harnesses/harness-registry.js.map +1 -0
  42. package/dist/harnesses/index.d.ts +12 -0
  43. package/dist/harnesses/index.d.ts.map +1 -0
  44. package/dist/harnesses/index.js +11 -0
  45. package/dist/harnesses/index.js.map +1 -0
  46. package/dist/harnesses/pi-harness.d.ts +219 -0
  47. package/dist/harnesses/pi-harness.d.ts.map +1 -0
  48. package/dist/harnesses/pi-harness.js +676 -0
  49. package/dist/harnesses/pi-harness.js.map +1 -0
  50. package/dist/harnesses/pi-schema-converter.d.ts +24 -0
  51. package/dist/harnesses/pi-schema-converter.d.ts.map +1 -0
  52. package/dist/harnesses/pi-schema-converter.js +81 -0
  53. package/dist/harnesses/pi-schema-converter.js.map +1 -0
  54. package/dist/harnesses/register-defaults.d.ts +24 -0
  55. package/dist/harnesses/register-defaults.d.ts.map +1 -0
  56. package/dist/harnesses/register-defaults.js +40 -0
  57. package/dist/harnesses/register-defaults.js.map +1 -0
  58. package/dist/harnesses/session-store.d.ts +201 -0
  59. package/dist/harnesses/session-store.d.ts.map +1 -0
  60. package/dist/harnesses/session-store.js +254 -0
  61. package/dist/harnesses/session-store.js.map +1 -0
  62. package/dist/index.d.ts +12 -2
  63. package/dist/index.d.ts.map +1 -1
  64. package/dist/index.js +17 -0
  65. package/dist/index.js.map +1 -1
  66. package/dist/reflection/reflection.d.ts.map +1 -1
  67. package/dist/reflection/reflection.js +19 -4
  68. package/dist/reflection/reflection.js.map +1 -1
  69. package/dist/types/agent.d.ts +1253 -2
  70. package/dist/types/agent.d.ts.map +1 -1
  71. package/dist/types/agent.js +418 -1
  72. package/dist/types/agent.js.map +1 -1
  73. package/dist/types/decorators.d.ts +10 -1
  74. package/dist/types/decorators.d.ts.map +1 -1
  75. package/dist/types/events.d.ts +26 -0
  76. package/dist/types/events.d.ts.map +1 -1
  77. package/dist/types/harnesses.d.ts +474 -0
  78. package/dist/types/harnesses.d.ts.map +1 -0
  79. package/dist/types/harnesses.js +2 -0
  80. package/dist/types/harnesses.js.map +1 -0
  81. package/dist/types/index.d.ts +9 -1
  82. package/dist/types/index.d.ts.map +1 -1
  83. package/dist/types/index.js +6 -0
  84. package/dist/types/index.js.map +1 -1
  85. package/dist/types/providers.d.ts +691 -0
  86. package/dist/types/providers.d.ts.map +1 -0
  87. package/dist/types/providers.js +14 -0
  88. package/dist/types/providers.js.map +1 -0
  89. package/dist/types/restart.d.ts +132 -0
  90. package/dist/types/restart.d.ts.map +1 -0
  91. package/dist/types/restart.js +2 -0
  92. package/dist/types/restart.js.map +1 -0
  93. package/dist/types/streaming.d.ts +194 -0
  94. package/dist/types/streaming.d.ts.map +1 -0
  95. package/dist/types/streaming.js +67 -0
  96. package/dist/types/streaming.js.map +1 -0
  97. package/dist/types/workflow-context.d.ts +137 -1
  98. package/dist/types/workflow-context.d.ts.map +1 -1
  99. package/dist/utils/agent-validation.d.ts +88 -0
  100. package/dist/utils/agent-validation.d.ts.map +1 -0
  101. package/dist/utils/agent-validation.js +87 -0
  102. package/dist/utils/agent-validation.js.map +1 -0
  103. package/dist/utils/delay.d.ts +7 -0
  104. package/dist/utils/delay.d.ts.map +1 -0
  105. package/dist/utils/delay.js +9 -0
  106. package/dist/utils/delay.js.map +1 -0
  107. package/dist/utils/harness-config.d.ts +180 -0
  108. package/dist/utils/harness-config.d.ts.map +1 -0
  109. package/dist/utils/harness-config.js +311 -0
  110. package/dist/utils/harness-config.js.map +1 -0
  111. package/dist/utils/index.d.ts +9 -1
  112. package/dist/utils/index.d.ts.map +1 -1
  113. package/dist/utils/index.js +8 -1
  114. package/dist/utils/index.js.map +1 -1
  115. package/dist/utils/model-spec.d.ts +110 -0
  116. package/dist/utils/model-spec.d.ts.map +1 -0
  117. package/dist/utils/model-spec.js +149 -0
  118. package/dist/utils/model-spec.js.map +1 -0
  119. package/dist/utils/provider-config.d.ts +10 -0
  120. package/dist/utils/provider-config.d.ts.map +1 -0
  121. package/dist/utils/provider-config.js +10 -0
  122. package/dist/utils/provider-config.js.map +1 -0
  123. package/dist/utils/restart-analysis.d.ts +202 -0
  124. package/dist/utils/restart-analysis.d.ts.map +1 -0
  125. package/dist/utils/restart-analysis.js +426 -0
  126. package/dist/utils/restart-analysis.js.map +1 -0
  127. package/dist/utils/session-serialization.d.ts +118 -0
  128. package/dist/utils/session-serialization.d.ts.map +1 -0
  129. package/dist/utils/session-serialization.js +217 -0
  130. package/dist/utils/session-serialization.js.map +1 -0
  131. package/package.json +31 -5
  132. package/CHANGELOG.md +0 -188
  133. package/dist/__tests__/adversarial/attachChild-performance.test.d.ts +0 -16
  134. package/dist/__tests__/adversarial/attachChild-performance.test.d.ts.map +0 -1
  135. package/dist/__tests__/adversarial/attachChild-performance.test.js +0 -187
  136. package/dist/__tests__/adversarial/attachChild-performance.test.js.map +0 -1
  137. package/dist/__tests__/adversarial/circular-reference.test.d.ts +0 -13
  138. package/dist/__tests__/adversarial/circular-reference.test.d.ts.map +0 -1
  139. package/dist/__tests__/adversarial/circular-reference.test.js +0 -92
  140. package/dist/__tests__/adversarial/circular-reference.test.js.map +0 -1
  141. package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts +0 -16
  142. package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts.map +0 -1
  143. package/dist/__tests__/adversarial/complex-circular-reference.test.js +0 -127
  144. package/dist/__tests__/adversarial/complex-circular-reference.test.js.map +0 -1
  145. package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts +0 -21
  146. package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts.map +0 -1
  147. package/dist/__tests__/adversarial/concurrent-task-failures.test.js +0 -667
  148. package/dist/__tests__/adversarial/concurrent-task-failures.test.js.map +0 -1
  149. package/dist/__tests__/adversarial/deep-analysis.test.d.ts +0 -6
  150. package/dist/__tests__/adversarial/deep-analysis.test.d.ts.map +0 -1
  151. package/dist/__tests__/adversarial/deep-analysis.test.js +0 -877
  152. package/dist/__tests__/adversarial/deep-analysis.test.js.map +0 -1
  153. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts +0 -13
  154. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts.map +0 -1
  155. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js +0 -186
  156. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js.map +0 -1
  157. package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts +0 -6
  158. package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts.map +0 -1
  159. package/dist/__tests__/adversarial/e2e-prd-validation.test.js +0 -626
  160. package/dist/__tests__/adversarial/e2e-prd-validation.test.js.map +0 -1
  161. package/dist/__tests__/adversarial/edge-case.test.d.ts +0 -6
  162. package/dist/__tests__/adversarial/edge-case.test.d.ts.map +0 -1
  163. package/dist/__tests__/adversarial/edge-case.test.js +0 -857
  164. package/dist/__tests__/adversarial/edge-case.test.js.map +0 -1
  165. package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts +0 -20
  166. package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts.map +0 -1
  167. package/dist/__tests__/adversarial/error-merge-strategy.test.js +0 -907
  168. package/dist/__tests__/adversarial/error-merge-strategy.test.js.map +0 -1
  169. package/dist/__tests__/adversarial/incremental-performance.test.d.ts +0 -2
  170. package/dist/__tests__/adversarial/incremental-performance.test.d.ts.map +0 -1
  171. package/dist/__tests__/adversarial/incremental-performance.test.js +0 -113
  172. package/dist/__tests__/adversarial/incremental-performance.test.js.map +0 -1
  173. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts +0 -22
  174. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts.map +0 -1
  175. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js +0 -383
  176. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js.map +0 -1
  177. package/dist/__tests__/adversarial/observer-propagation.test.d.ts +0 -21
  178. package/dist/__tests__/adversarial/observer-propagation.test.d.ts.map +0 -1
  179. package/dist/__tests__/adversarial/observer-propagation.test.js +0 -404
  180. package/dist/__tests__/adversarial/observer-propagation.test.js.map +0 -1
  181. package/dist/__tests__/adversarial/parent-validation.test.d.ts +0 -13
  182. package/dist/__tests__/adversarial/parent-validation.test.d.ts.map +0 -1
  183. package/dist/__tests__/adversarial/parent-validation.test.js +0 -128
  184. package/dist/__tests__/adversarial/parent-validation.test.js.map +0 -1
  185. package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts +0 -20
  186. package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts.map +0 -1
  187. package/dist/__tests__/adversarial/prd-12-2-compliance.test.js +0 -482
  188. package/dist/__tests__/adversarial/prd-12-2-compliance.test.js.map +0 -1
  189. package/dist/__tests__/adversarial/prd-compliance.test.d.ts +0 -6
  190. package/dist/__tests__/adversarial/prd-compliance.test.d.ts.map +0 -1
  191. package/dist/__tests__/adversarial/prd-compliance.test.js +0 -886
  192. package/dist/__tests__/adversarial/prd-compliance.test.js.map +0 -1
  193. package/dist/__tests__/compatibility/backward-compatibility.test.d.ts +0 -22
  194. package/dist/__tests__/compatibility/backward-compatibility.test.d.ts.map +0 -1
  195. package/dist/__tests__/compatibility/backward-compatibility.test.js +0 -1843
  196. package/dist/__tests__/compatibility/backward-compatibility.test.js.map +0 -1
  197. package/dist/__tests__/helpers/index.d.ts +0 -10
  198. package/dist/__tests__/helpers/index.d.ts.map +0 -1
  199. package/dist/__tests__/helpers/index.js +0 -10
  200. package/dist/__tests__/helpers/index.js.map +0 -1
  201. package/dist/__tests__/helpers/tree-verification.d.ts +0 -90
  202. package/dist/__tests__/helpers/tree-verification.d.ts.map +0 -1
  203. package/dist/__tests__/helpers/tree-verification.js +0 -202
  204. package/dist/__tests__/helpers/tree-verification.js.map +0 -1
  205. package/dist/__tests__/integration/agent-workflow.test.d.ts +0 -2
  206. package/dist/__tests__/integration/agent-workflow.test.d.ts.map +0 -1
  207. package/dist/__tests__/integration/agent-workflow.test.js +0 -256
  208. package/dist/__tests__/integration/agent-workflow.test.js.map +0 -1
  209. package/dist/__tests__/integration/bidirectional-consistency.test.d.ts +0 -14
  210. package/dist/__tests__/integration/bidirectional-consistency.test.d.ts.map +0 -1
  211. package/dist/__tests__/integration/bidirectional-consistency.test.js +0 -668
  212. package/dist/__tests__/integration/bidirectional-consistency.test.js.map +0 -1
  213. package/dist/__tests__/integration/observer-logging.test.d.ts +0 -2
  214. package/dist/__tests__/integration/observer-logging.test.d.ts.map +0 -1
  215. package/dist/__tests__/integration/observer-logging.test.js +0 -517
  216. package/dist/__tests__/integration/observer-logging.test.js.map +0 -1
  217. package/dist/__tests__/integration/tree-mirroring.test.d.ts +0 -2
  218. package/dist/__tests__/integration/tree-mirroring.test.d.ts.map +0 -1
  219. package/dist/__tests__/integration/tree-mirroring.test.js +0 -117
  220. package/dist/__tests__/integration/tree-mirroring.test.js.map +0 -1
  221. package/dist/__tests__/integration/workflow-reparenting.test.d.ts +0 -12
  222. package/dist/__tests__/integration/workflow-reparenting.test.d.ts.map +0 -1
  223. package/dist/__tests__/integration/workflow-reparenting.test.js +0 -239
  224. package/dist/__tests__/integration/workflow-reparenting.test.js.map +0 -1
  225. package/dist/__tests__/unit/agent.test.d.ts +0 -2
  226. package/dist/__tests__/unit/agent.test.d.ts.map +0 -1
  227. package/dist/__tests__/unit/agent.test.js +0 -143
  228. package/dist/__tests__/unit/agent.test.js.map +0 -1
  229. package/dist/__tests__/unit/cache-key.test.d.ts +0 -5
  230. package/dist/__tests__/unit/cache-key.test.d.ts.map +0 -1
  231. package/dist/__tests__/unit/cache-key.test.js +0 -145
  232. package/dist/__tests__/unit/cache-key.test.js.map +0 -1
  233. package/dist/__tests__/unit/cache.test.d.ts +0 -5
  234. package/dist/__tests__/unit/cache.test.d.ts.map +0 -1
  235. package/dist/__tests__/unit/cache.test.js +0 -132
  236. package/dist/__tests__/unit/cache.test.js.map +0 -1
  237. package/dist/__tests__/unit/context.test.d.ts +0 -2
  238. package/dist/__tests__/unit/context.test.d.ts.map +0 -1
  239. package/dist/__tests__/unit/context.test.js +0 -220
  240. package/dist/__tests__/unit/context.test.js.map +0 -1
  241. package/dist/__tests__/unit/decorators.test.d.ts +0 -2
  242. package/dist/__tests__/unit/decorators.test.d.ts.map +0 -1
  243. package/dist/__tests__/unit/decorators.test.js +0 -162
  244. package/dist/__tests__/unit/decorators.test.js.map +0 -1
  245. package/dist/__tests__/unit/introspection-tools.test.d.ts +0 -5
  246. package/dist/__tests__/unit/introspection-tools.test.d.ts.map +0 -1
  247. package/dist/__tests__/unit/introspection-tools.test.js +0 -191
  248. package/dist/__tests__/unit/introspection-tools.test.js.map +0 -1
  249. package/dist/__tests__/unit/logger.test.d.ts +0 -2
  250. package/dist/__tests__/unit/logger.test.d.ts.map +0 -1
  251. package/dist/__tests__/unit/logger.test.js +0 -241
  252. package/dist/__tests__/unit/logger.test.js.map +0 -1
  253. package/dist/__tests__/unit/observable.test.d.ts +0 -2
  254. package/dist/__tests__/unit/observable.test.d.ts.map +0 -1
  255. package/dist/__tests__/unit/observable.test.js +0 -251
  256. package/dist/__tests__/unit/observable.test.js.map +0 -1
  257. package/dist/__tests__/unit/prompt.test.d.ts +0 -2
  258. package/dist/__tests__/unit/prompt.test.d.ts.map +0 -1
  259. package/dist/__tests__/unit/prompt.test.js +0 -113
  260. package/dist/__tests__/unit/prompt.test.js.map +0 -1
  261. package/dist/__tests__/unit/reflection.test.d.ts +0 -5
  262. package/dist/__tests__/unit/reflection.test.d.ts.map +0 -1
  263. package/dist/__tests__/unit/reflection.test.js +0 -160
  264. package/dist/__tests__/unit/reflection.test.js.map +0 -1
  265. package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts +0 -2
  266. package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts.map +0 -1
  267. package/dist/__tests__/unit/tree-debugger-incremental.test.js +0 -136
  268. package/dist/__tests__/unit/tree-debugger-incremental.test.js.map +0 -1
  269. package/dist/__tests__/unit/tree-debugger.test.d.ts +0 -2
  270. package/dist/__tests__/unit/tree-debugger.test.d.ts.map +0 -1
  271. package/dist/__tests__/unit/tree-debugger.test.js +0 -69
  272. package/dist/__tests__/unit/tree-debugger.test.js.map +0 -1
  273. package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts +0 -2
  274. package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts.map +0 -1
  275. package/dist/__tests__/unit/utils/workflow-error-utils.test.js +0 -154
  276. package/dist/__tests__/unit/utils/workflow-error-utils.test.js.map +0 -1
  277. package/dist/__tests__/unit/workflow-detachChild.test.d.ts +0 -2
  278. package/dist/__tests__/unit/workflow-detachChild.test.d.ts.map +0 -1
  279. package/dist/__tests__/unit/workflow-detachChild.test.js +0 -76
  280. package/dist/__tests__/unit/workflow-detachChild.test.js.map +0 -1
  281. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts +0 -2
  282. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts.map +0 -1
  283. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js +0 -122
  284. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js.map +0 -1
  285. package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts +0 -2
  286. package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts.map +0 -1
  287. package/dist/__tests__/unit/workflow-isDescendantOf.test.js +0 -140
  288. package/dist/__tests__/unit/workflow-isDescendantOf.test.js.map +0 -1
  289. package/dist/__tests__/unit/workflow.test.d.ts +0 -2
  290. package/dist/__tests__/unit/workflow.test.d.ts.map +0 -1
  291. package/dist/__tests__/unit/workflow.test.js +0 -330
  292. package/dist/__tests__/unit/workflow.test.js.map +0 -1
@@ -0,0 +1,474 @@
1
+ import type { Tool, MCPServer, Skill } from './sdk-primitives.js';
2
+ import type { AgentResponse } from './agent.js';
3
+ import type { StreamEvent } from './streaming.js';
4
+ /**
5
+ * Harness identifier (PRD §7.2).
6
+ *
7
+ * The agent runtime/SDK that drives prompting, tool execution, streaming, and
8
+ * sessions. This axis is ORTHOGONAL to the LLM provider/model — the two are
9
+ * chosen independently (PRD §7). The harness NEVER appears in the model string.
10
+ */
11
+ export type HarnessId = 'pi' | 'claude-code';
12
+ /**
13
+ * LLM host / model provider (PRD §7.8).
14
+ *
15
+ * Open set: the well-known providers get IDE autocomplete via the `(string & {})`
16
+ * idiom, but ANY provider string is valid (e.g. a custom provider registered with a
17
+ * harness's model registry). This is the LLM vendor axis — NOT the harness.
18
+ */
19
+ export type ModelProviderId = 'anthropic' | 'openai' | 'google' | 'zai' | (string & {});
20
+ /**
21
+ * Harness capability flags (PRD §7.4). Identical shape to the legacy
22
+ * ProviderCapabilities. Unsupported features are advertised here rather than
23
+ * silently degrading (PRD §7.14).
24
+ */
25
+ export interface HarnessCapabilities {
26
+ /** MCP server connections */
27
+ mcp: boolean;
28
+ /** Skill loading */
29
+ skills: boolean;
30
+ /** Language Server Protocol integration */
31
+ lsp: boolean;
32
+ /** Streaming responses */
33
+ streaming: boolean;
34
+ /** Session-based state */
35
+ sessions: boolean;
36
+ /** Extended thinking/reasoning */
37
+ extendedThinking: boolean;
38
+ }
39
+ /**
40
+ * Harness-level configuration options (PRD §7.5).
41
+ *
42
+ * Intentionally SLIMMED relative to the legacy ProviderOptions: the session-store
43
+ * fields (sessionStore, sessionPersistence, sessionTtl, sessionPath) are adapter
44
+ * internals and live on the concrete harness, not on the shared harness contract
45
+ * (system_context.md §3 / §7 risk note). `apiKey` is forwarded to the LLM provider
46
+ * — it is not owned by the harness.
47
+ *
48
+ * Harness implementations MAY extend this with harness-specific fields (e.g.
49
+ * `skillsDirs?: string[]` on a `pi` adapter) per PRD §7.5.
50
+ *
51
+ * @example
52
+ * ```ts
53
+ * const options: HarnessOptions = {
54
+ * endpoint: 'https://api.anthropic.com',
55
+ * apiKey: process.env.ANTHROPIC_API_KEY,
56
+ * timeout: 60000,
57
+ * };
58
+ * ```
59
+ */
60
+ export interface HarnessOptions {
61
+ /** API endpoint override */
62
+ endpoint?: string;
63
+ /** API key (forwarded to the LLM provider) */
64
+ apiKey?: string;
65
+ /** Session/resume id */
66
+ sessionId?: string;
67
+ /** Timeout in milliseconds */
68
+ timeout?: number;
69
+ /** Custom headers */
70
+ headers?: Record<string, string>;
71
+ }
72
+ /**
73
+ * Hook events adapted from AgentHooks to harness-specific lifecycle (PRD §7.11).
74
+ * Identical to the legacy ProviderHookEvents.
75
+ *
76
+ * @example
77
+ * ```ts
78
+ * const hooks: HarnessHookEvents = {
79
+ * onToolStart: async (tool) => { console.log('Starting:', tool.name); },
80
+ * onToolEnd: async (tool, result, duration) => {
81
+ * console.log(`Finished ${tool.name} in ${duration}ms`);
82
+ * },
83
+ * onStream: (chunk) => process.stdout.write(chunk),
84
+ * };
85
+ * ```
86
+ */
87
+ export interface HarnessHookEvents {
88
+ /** Called before tool execution */
89
+ onToolStart?: (tool: ToolExecutionRequest) => Promise<void> | void;
90
+ /** Called after tool execution */
91
+ onToolEnd?: (tool: ToolExecutionRequest, result: ToolExecutionResult, duration: number) => Promise<void> | void;
92
+ /** Called when provider session starts */
93
+ onSessionStart?: () => Promise<void> | void;
94
+ /** Called when provider session ends */
95
+ onSessionEnd?: (totalDuration: number) => Promise<void> | void;
96
+ /** Called for each streaming chunk */
97
+ onStream?: (chunk: string) => void;
98
+ }
99
+ /**
100
+ * Tool execution request (PRD §7.10). Copied VERBATIM from providers.ts.
101
+ * Tools are executed locally via MCPHandler regardless of harness.
102
+ *
103
+ * @example
104
+ * ```ts
105
+ * const request: ToolExecutionRequest = {
106
+ * name: 'filesystem__read_file',
107
+ * input: { path: '/src/index.ts' },
108
+ * };
109
+ * ```
110
+ */
111
+ export interface ToolExecutionRequest {
112
+ /** Tool name (may be namespaced: "server__tool") */
113
+ name: string;
114
+ /** Tool input parameters */
115
+ input: unknown;
116
+ }
117
+ /**
118
+ * Tool execution result (PRD §7.10). Copied VERBATIM from providers.ts.
119
+ *
120
+ * @example
121
+ * ```ts
122
+ * const result: ToolExecutionResult = {
123
+ * content: 'const x = 1;',
124
+ * isError: false,
125
+ * };
126
+ * ```
127
+ */
128
+ export interface ToolExecutionResult {
129
+ /** Result content */
130
+ content: string | unknown;
131
+ /** Whether the execution resulted in an error */
132
+ isError: boolean;
133
+ }
134
+ /**
135
+ * Execution options carried inside a {@link HarnessRequest} (PRD §7.3 + §7.10).
136
+ * Mirrors the legacy ProviderExecutionOptions; named separately for adapter reuse.
137
+ *
138
+ * @example
139
+ * ```ts
140
+ * const execOptions: HarnessExecutionOptions = {
141
+ * model: 'anthropic/claude-sonnet-4-20250514',
142
+ * systemPrompt: 'You are a helpful assistant.',
143
+ * tools: [myTool],
144
+ * hooks: myHooks,
145
+ * streaming: true,
146
+ * };
147
+ * ```
148
+ */
149
+ export interface HarnessExecutionOptions {
150
+ /** Model identifier ("provider/model" or plain — never harness-qualified; PRD §7.8) */
151
+ model?: string;
152
+ /** System prompt override */
153
+ systemPrompt?: string;
154
+ /** Available tools */
155
+ tools?: Tool[];
156
+ /** Lifecycle hooks */
157
+ hooks?: HarnessHookEvents;
158
+ /** Session identifier for session-based harnesses */
159
+ sessionId?: string;
160
+ /** Enable streaming mode (returns AsyncGenerator instead of a complete response) */
161
+ streaming?: boolean;
162
+ }
163
+ /**
164
+ * Harness execution request (PRD §7.3). Merges the legacy ProviderRequest +
165
+ * ProviderExecutionOptions (system_context.md §3 mapping).
166
+ *
167
+ * @example
168
+ * ```ts
169
+ * const request: HarnessRequest = {
170
+ * prompt: 'Explain TypeScript generics',
171
+ * options: { model: 'claude-sonnet-4', streaming: false },
172
+ * };
173
+ * ```
174
+ */
175
+ export interface HarnessRequest {
176
+ /** The user prompt/message */
177
+ prompt: string;
178
+ /** Execution options */
179
+ options: HarnessExecutionOptions;
180
+ }
181
+ /**
182
+ * Parsed model identifier (PRD §7.8).
183
+ *
184
+ * `provider` is the LLM host (ModelProviderId) — NEVER the harness. Format is
185
+ * `provider/model` (e.g. `anthropic/claude-sonnet-4-20250514`) or a plain model id
186
+ * resolved against the configured `defaultModelProvider`.
187
+ *
188
+ * NOTE: Defined here (in S1) rather than S2 because {@link Harness.normalizeModel}
189
+ * references it and must compile. S2 (P1.M1.T1.S2) adds GlobalHarnessConfig +
190
+ * parseModelSpec/formatModelForProvider FUNCTIONS and must NOT redefine this interface.
191
+ *
192
+ * @example
193
+ * ```ts
194
+ * // Qualified format
195
+ * const spec1: ModelSpec = {
196
+ * provider: 'anthropic',
197
+ * model: 'claude-sonnet-4-20250514',
198
+ * raw: 'anthropic/claude-sonnet-4-20250514',
199
+ * };
200
+ *
201
+ * // Plain format (resolved against default provider)
202
+ * const spec2: ModelSpec = {
203
+ * provider: 'anthropic',
204
+ * model: 'claude-sonnet-4-20250514',
205
+ * raw: 'claude-sonnet-4-20250514',
206
+ * };
207
+ * ```
208
+ */
209
+ export interface ModelSpec {
210
+ /** LLM host — NOT the harness */
211
+ provider: ModelProviderId;
212
+ /** Model name (without provider prefix) */
213
+ model: string;
214
+ /** Original raw model string (preserves user input) */
215
+ raw: string;
216
+ }
217
+ /**
218
+ * The shared harness contract both `PiHarness` and `ClaudeCodeHarness` implement
219
+ * (PRD §7.3). Identical method surface to the legacy Provider interface; the
220
+ * `execute<T>()` return type matches the already-shipped AnthropicProvider.execute
221
+ * (src/harnesses/anthropic-provider.ts lines 338–344).
222
+ *
223
+ * Adapters: PiHarness wraps `createAgentSession()`; ClaudeCodeHarness (rename of
224
+ * AnthropicProvider) wraps the Claude Code SDK. New harnesses implement this and
225
+ * register with HarnessRegistry (§7.6, owned by P1.M2).
226
+ *
227
+ * @example <caption>Basic harness shape</caption>
228
+ * ```ts
229
+ * const harness: Harness = {
230
+ * readonly id: 'pi',
231
+ * readonly capabilities: { mcp: true, skills: true, lsp: true, streaming: true, sessions: true, extendedThinking: false },
232
+ * initialize: async (opts?) => { … },
233
+ * terminate: async () => { … },
234
+ * execute: async <T>(req, toolExec, hooks?) => { … },
235
+ * registerMCPs: async (servers) => [],
236
+ * loadSkills: async (skills) => {},
237
+ * normalizeModel: (model) => ({ provider: 'anthropic', model, raw: model }),
238
+ * supports: (cap) => cap === 'mcp',
239
+ * requiresFeatures: (features) => features.every(f => f === 'mcp'),
240
+ * };
241
+ * ```
242
+ */
243
+ export interface Harness {
244
+ /**
245
+ * Unique harness identifier (one of the supported HarnessId values)
246
+ *
247
+ * @readonly
248
+ *
249
+ * @example
250
+ * ```ts
251
+ * readonly id: HarnessId; // 'pi' | 'claude-code'
252
+ * ```
253
+ */
254
+ readonly id: HarnessId;
255
+ /**
256
+ * Capability flags for feature detection
257
+ *
258
+ * @readonly
259
+ *
260
+ * @example
261
+ * ```ts
262
+ * readonly capabilities: HarnessCapabilities;
263
+ * // { mcp: true, skills: true, lsp: true, streaming: true, sessions: false, extendedThinking: false }
264
+ * ```
265
+ */
266
+ readonly capabilities: HarnessCapabilities;
267
+ /**
268
+ * Initialize the harness with optional configuration (SDK clients, connections).
269
+ *
270
+ * @param options - Optional harness-specific configuration
271
+ *
272
+ * @example
273
+ * ```ts
274
+ * await harness.initialize({ apiKey: 'sk-...', endpoint: 'https://...' });
275
+ * ```
276
+ */
277
+ initialize(options?: HarnessOptions): Promise<void>;
278
+ /**
279
+ * Terminate the harness and release resources.
280
+ *
281
+ * @example
282
+ * ```ts
283
+ * await harness.terminate();
284
+ * ```
285
+ */
286
+ terminate(): Promise<void>;
287
+ /**
288
+ * Execute a prompt request with a type-safe response (PRD §7.3).
289
+ *
290
+ * `toolExecutor` delegates tool calls back to Groundswell's MCPHandler — the harness
291
+ * only reports tool calls back, it never executes them itself (PRD §7.10 / §7.12).
292
+ *
293
+ * @typeParam T - The expected response data type (inferred from schema or explicit)
294
+ * @param request - The prompt request with options
295
+ * @param toolExecutor - Callback for executing tools (delegated to MCPHandler)
296
+ * @param hooks - Optional lifecycle hooks for events
297
+ * @returns `Promise<AgentResponse<T>>` for non-streaming, or an
298
+ * `AsyncGenerator<StreamEvent, AgentResponse<T>, unknown>` when
299
+ * `request.options.streaming === true`.
300
+ *
301
+ * @example <caption>Non-streaming execution</caption>
302
+ * ```ts
303
+ * const response = await harness.execute<{ answer: string }>(
304
+ * { prompt: 'What is 2+2?', options: {} },
305
+ * toolExecutor,
306
+ * hooks,
307
+ * );
308
+ * if (response.status === 'success') {
309
+ * console.log(response.data.answer); // Type-safe access
310
+ * }
311
+ * ```
312
+ *
313
+ * @example <caption>Streaming execution</caption>
314
+ * ```ts
315
+ * const stream = await harness.execute(
316
+ * { prompt: '...', options: { streaming: true } },
317
+ * toolExecutor,
318
+ * );
319
+ * for await (const event of stream) {
320
+ * // Handle StreamEvent items
321
+ * }
322
+ * ```
323
+ */
324
+ execute<T>(request: HarnessRequest, toolExecutor: (req: ToolExecutionRequest) => Promise<ToolExecutionResult>, hooks?: HarnessHookEvents): Promise<AgentResponse<T>> | AsyncGenerator<StreamEvent, AgentResponse<T>, unknown>;
325
+ /**
326
+ * Register MCP servers and return the discovered tools (PRD §7.10 / §7.12).
327
+ *
328
+ * @param servers - Array of MCP server configurations
329
+ * @returns Promise resolving to array of discovered Tool definitions
330
+ *
331
+ * @example
332
+ * ```ts
333
+ * const tools = await harness.registerMCPs([
334
+ * { name: 'filesystem', transport: 'stdio', command: 'python', args: ['mcp_server.py'] },
335
+ * ]);
336
+ * console.log(`Registered ${tools.length} tools`);
337
+ * ```
338
+ */
339
+ registerMCPs(servers: MCPServer[]): Promise<Tool[]>;
340
+ /**
341
+ * Load skills into the harness (PRD §7.12).
342
+ *
343
+ * @param skills - Array of skill definitions to load
344
+ *
345
+ * @example
346
+ * ```ts
347
+ * await harness.loadSkills([
348
+ * { name: 'web-search', path: '/skills/web-search' },
349
+ * ]);
350
+ * ```
351
+ */
352
+ loadSkills(skills: Skill[]): Promise<void>;
353
+ /**
354
+ * Parse a model string into a ModelSpec (PRD §7.8).
355
+ *
356
+ * @param model - Model string to parse
357
+ * @returns ModelSpec with provider, model, and raw string
358
+ *
359
+ * @example
360
+ * ```ts
361
+ * harness.normalizeModel('claude-sonnet-4')
362
+ * // Returns: { provider: 'anthropic', model: 'claude-sonnet-4', raw: 'claude-sonnet-4' }
363
+ *
364
+ * harness.normalizeModel('anthropic/claude-opus-4')
365
+ * // Returns: { provider: 'anthropic', model: 'claude-opus-4', raw: 'anthropic/claude-opus-4' }
366
+ * ```
367
+ */
368
+ normalizeModel(model: string): ModelSpec;
369
+ /**
370
+ * Check if a single capability is supported.
371
+ *
372
+ * @param capability - The capability to check (must be keyof HarnessCapabilities)
373
+ * @returns true if the capability is supported, false otherwise
374
+ *
375
+ * @example
376
+ * ```ts
377
+ * if (harness.supports('mcp')) {
378
+ * await harness.registerMCPs(servers);
379
+ * }
380
+ * ```
381
+ */
382
+ supports(capability: keyof HarnessCapabilities): boolean;
383
+ /**
384
+ * Check if ALL listed capabilities are supported (empty array → true).
385
+ *
386
+ * @param features - Array of capability keys to check
387
+ * @returns true if all features are supported, false if any are unsupported
388
+ *
389
+ * @example
390
+ * ```ts
391
+ * if (harness.requiresFeatures(['mcp', 'streaming'])) {
392
+ * // Enable advanced features requiring both MCP and streaming
393
+ * }
394
+ * ```
395
+ */
396
+ requiresFeatures(features: (keyof HarnessCapabilities)[]): boolean;
397
+ }
398
+ /**
399
+ * Global harness configuration (PRD §7.6).
400
+ *
401
+ * Configures the default harness, optional per-harness options, and the default LLM provider
402
+ * that resolve unqualified model strings (PRD §7.8). Set once at application startup via
403
+ * `configureHarnesses()` (owned by P1.M2.T2.S1) — it cascades to all agents unless explicitly
404
+ * overridden (PRD §7.7).
405
+ *
406
+ * The two default axes are INDEPENDENT:
407
+ * - `defaultHarness` — the agent RUNTIME ('pi' | 'claude-code').
408
+ * - `defaultModelProvider` — the LLM HOST / vendor (open `ModelProviderId` set).
409
+ *
410
+ * This is the v1.2 successor to the legacy `GlobalProviderConfig`: it adds the orthogonal
411
+ * `defaultModelProvider` field and re-keys `harnessDefaults` by `HarnessId` (the legacy
412
+ * `providerDefaults` was keyed by the conflated `ProviderId`).
413
+ *
414
+ * @example
415
+ * ```ts
416
+ * const config: GlobalHarnessConfig = {
417
+ * defaultHarness: 'pi', // vendor-neutral default runtime
418
+ * defaultModelProvider: 'anthropic', // LLM host — independent of harness
419
+ * harnessDefaults: {
420
+ * 'claude-code': { apiKey: process.env.ANTHROPIC_API_KEY },
421
+ * },
422
+ * };
423
+ * ```
424
+ */
425
+ export interface GlobalHarnessConfig {
426
+ /** Default agent runtime used when none is specified (PRD §7.6 / §7.7 cascade root). */
427
+ defaultHarness: HarnessId;
428
+ /** Optional per-harness default options, keyed by HarnessId (runtime axis). */
429
+ harnessDefaults?: Partial<Record<HarnessId, HarnessOptions>>;
430
+ /**
431
+ * Default LLM provider used to resolve unqualified (plain) model strings (PRD §7.8).
432
+ *
433
+ * Open `ModelProviderId` set — independent of `defaultHarness`. When a caller passes a
434
+ * plain model id like `'claude-sonnet-4-20250514'`, `parseModelSpec` resolves its
435
+ * `provider` against this value.
436
+ */
437
+ defaultModelProvider?: ModelProviderId;
438
+ }
439
+ /**
440
+ * Parse a model specification string into a {@link ModelSpec} (PRD §7.8).
441
+ *
442
+ * Accepts two formats:
443
+ * - Qualified: `"anthropic/claude-sonnet-4-20250514"` → `{ provider: 'anthropic', model: 'claude-sonnet-4-20250514', raw: … }`
444
+ * - Plain: `"claude-sonnet-4-20250514"` → resolved against `defaultProvider`.
445
+ *
446
+ * `provider` is the LLM host (`ModelProviderId`, open set) — NEVER the harness
447
+ * (PRD §7.8 critical rule). Harness-qualified strings (`pi/anthropic/...`) are
448
+ * invalid and rejected by the implementation (P1.M1.T2.S1).
449
+ *
450
+ * @param model - Model string (`"provider/model"` or plain model id).
451
+ * @param defaultProvider - Provider used when `model` is unqualified (open set;
452
+ * implementation default is `'anthropic'`).
453
+ * @returns Parsed {@link ModelSpec} (provider, model, raw).
454
+ *
455
+ * @remarks TYPE-ONLY ambient declaration — see file-level block comment.
456
+ * Runtime implementation: `src/utils/model-spec.ts` (P1.M1.T2.S1).
457
+ */
458
+ export declare function parseModelSpec(model: string, defaultProvider?: ModelProviderId): ModelSpec;
459
+ /**
460
+ * Format a {@link ModelSpec} for a specific target provider (PRD §7.8).
461
+ *
462
+ * Pass-through (returns `spec.model`) when `spec.provider === targetProvider`;
463
+ * otherwise the implementation throws a cross-translation error (MVP behavior —
464
+ * same-provider validation / API preparation is the primary use case).
465
+ *
466
+ * @param spec - {@link ModelSpec} from `parseModelSpec()` or `Harness.normalizeModel()`.
467
+ * @param targetProvider - The LLM host to format the model for (open `ModelProviderId` set).
468
+ * @returns Formatted model string (model name only, when providers match).
469
+ *
470
+ * @remarks TYPE-ONLY ambient declaration — see file-level block comment.
471
+ * Runtime implementation: `src/utils/model-spec.ts` (P1.M1.T2.S1).
472
+ */
473
+ export declare function formatModelForProvider(spec: ModelSpec, targetProvider: ModelProviderId): string;
474
+ //# sourceMappingURL=harnesses.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"harnesses.d.ts","sourceRoot":"","sources":["../../src/types/harnesses.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=harnesses.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"harnesses.js","sourceRoot":"","sources":["../../src/types/harnesses.ts"],"names":[],"mappings":""}
@@ -4,12 +4,20 @@ export type { SerializedWorkflowState, StateFieldMetadata } from './snapshot.js'
4
4
  export type { WorkflowError } from './error.js';
5
5
  export type { WorkflowEvent } from './events.js';
6
6
  export type { WorkflowObserver } from './observer.js';
7
+ export type { RestartAnalysis, ErrorCriterion } from './restart.js';
7
8
  export type { StepOptions, TaskOptions } from './decorators.js';
8
9
  export type { ErrorMergeStrategy } from './error-strategy.js';
9
10
  export type { Tool, ToolResult, MCPServer, Skill, HookHandler, PreToolUseContext, PostToolUseContext, SessionStartContext, SessionEndContext, AgentHooks, TokenUsage, } from './sdk-primitives.js';
10
- export type { AgentConfig, PromptOverrides } from './agent.js';
11
+ export type { Provider, ProviderId, ProviderCapabilities, ProviderOptions, ProviderExecutionOptions, ProviderRequest, ProviderHookEvents, ToolExecutionRequest, ToolExecutionResult, ToolExecutor, ProviderResult, ProviderResponseStatus, ProviderErrorDetails, ProviderResponseMetadata, GlobalProviderConfig, SessionState, } from './providers.js';
12
+ export type { Harness, HarnessId, ModelProviderId, HarnessCapabilities, HarnessOptions, HarnessRequest, HarnessHookEvents, GlobalHarnessConfig, ModelSpec, } from './harnesses.js';
13
+ export { ClaudeCodeHarness, AnthropicProvider } from '../harnesses/claude-code-harness.js';
14
+ export type { AgentConfig, PromptOverrides, AgentResponseStatus, AgentResponse, AgentErrorDetails, AgentResponseMetadata, SuccessResponse, ErrorResponse, PartialResponse, } from './agent.js';
15
+ export { AGENT_ERROR_CODES, createSuccessResponse, createErrorResponse, createPartialResponse, isSuccess, isError, isPartial, } from './agent.js';
16
+ export { AgentResponseStatusSchema, AgentErrorDetailsSchema, AgentResponseMetadataSchema, AgentResponseSchema, } from './agent.js';
11
17
  export type { PromptConfig } from './prompt.js';
12
18
  export type { WorkflowContext, WorkflowConfig, WorkflowResult, EventTreeHandle, EventNode, EventMetrics, AgentLike, PromptLike, } from './workflow-context.js';
13
19
  export type { ReflectionAPI, ReflectionConfig, ReflectionContext, ReflectionResult, ReflectionEntry, } from './reflection.js';
14
20
  export { DEFAULT_REFLECTION_CONFIG, createReflectionConfig, } from './reflection.js';
21
+ export type { StreamEvent, AsyncStream, } from './streaming.js';
22
+ export { isTextDeltaEvent, isToolCallEvent, isErrorEvent, } from './streaming.js';
15
23
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AACA,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAClE,YAAY,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACvD,YAAY,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACjF,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAChD,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,YAAY,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAChE,YAAY,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAG9D,YAAY,EACV,IAAI,EACJ,UAAU,EACV,SAAS,EACT,KAAK,EACL,WAAW,EACX,iBAAiB,EACjB,kBAAkB,EAClB,mBAAmB,EACnB,iBAAiB,EACjB,UAAU,EACV,UAAU,GACX,MAAM,qBAAqB,CAAC;AAG7B,YAAY,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAG/D,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGhD,YAAY,EACV,eAAe,EACf,cAAc,EACd,cAAc,EACd,eAAe,EACf,SAAS,EACT,YAAY,EACZ,SAAS,EACT,UAAU,GACX,MAAM,uBAAuB,CAAC;AAG/B,YAAY,EACV,aAAa,EACb,gBAAgB,EAChB,iBAAiB,EACjB,gBAAgB,EAChB,eAAe,GAChB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACL,yBAAyB,EACzB,sBAAsB,GACvB,MAAM,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AACA,YAAY,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAClE,YAAY,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACvD,YAAY,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACjF,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAChD,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,YAAY,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAGtD,YAAY,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAEpE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAChE,YAAY,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAG9D,YAAY,EACV,IAAI,EACJ,UAAU,EACV,SAAS,EACT,KAAK,EACL,WAAW,EACX,iBAAiB,EACjB,kBAAkB,EAClB,mBAAmB,EACnB,iBAAiB,EACjB,UAAU,EACV,UAAU,GACX,MAAM,qBAAqB,CAAC;AAG7B,YAAY,EACV,QAAQ,EACR,UAAU,EACV,oBAAoB,EACpB,eAAe,EACf,wBAAwB,EACxB,eAAe,EACf,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,EACnB,YAAY,EACZ,cAAc,EACd,sBAAsB,EACtB,oBAAoB,EACpB,wBAAwB,EACxB,oBAAoB,EACpB,YAAY,GACb,MAAM,gBAAgB,CAAC;AAGxB,YAAY,EACV,OAAO,EACP,SAAS,EACT,eAAe,EACf,mBAAmB,EACnB,cAAc,EACd,cAAc,EACd,iBAAiB,EACjB,mBAAmB,EACnB,SAAS,GACV,MAAM,gBAAgB,CAAC;AAGxB,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAG3F,YAAY,EACV,WAAW,EACX,eAAe,EACf,mBAAmB,EACnB,aAAa,EACb,iBAAiB,EACjB,qBAAqB,EACrB,eAAe,EACf,aAAa,EACb,eAAe,GAChB,MAAM,YAAY,CAAC;AACpB,OAAO,EACL,iBAAiB,EACjB,qBAAqB,EACrB,mBAAmB,EACnB,qBAAqB,EACrB,SAAS,EACT,OAAO,EACP,SAAS,GACV,MAAM,YAAY,CAAC;AAGpB,OAAO,EACL,yBAAyB,EACzB,uBAAuB,EACvB,2BAA2B,EAC3B,mBAAmB,GACpB,MAAM,YAAY,CAAC;AAGpB,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGhD,YAAY,EACV,eAAe,EACf,cAAc,EACd,cAAc,EACd,eAAe,EACf,SAAS,EACT,YAAY,EACZ,SAAS,EACT,UAAU,GACX,MAAM,uBAAuB,CAAC;AAG/B,YAAY,EACV,aAAa,EACb,gBAAgB,EAChB,iBAAiB,EACjB,gBAAgB,EAChB,eAAe,GAChB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACL,yBAAyB,EACzB,sBAAsB,GACvB,MAAM,iBAAiB,CAAC;AAGzB,YAAY,EACV,WAAW,EACX,WAAW,GACZ,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,YAAY,GACb,MAAM,gBAAgB,CAAC"}
@@ -1,2 +1,8 @@
1
+ // Provider classes
2
+ export { ClaudeCodeHarness, AnthropicProvider } from '../harnesses/claude-code-harness.js';
3
+ export { AGENT_ERROR_CODES, createSuccessResponse, createErrorResponse, createPartialResponse, isSuccess, isError, isPartial, } from './agent.js';
4
+ // Zod schemas for AgentResponse validation
5
+ export { AgentResponseStatusSchema, AgentErrorDetailsSchema, AgentResponseMetadataSchema, AgentResponseSchema, } from './agent.js';
1
6
  export { DEFAULT_REFLECTION_CONFIG, createReflectionConfig, } from './reflection.js';
7
+ export { isTextDeltaEvent, isToolCallEvent, isErrorEvent, } from './streaming.js';
2
8
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAmDA,OAAO,EACL,yBAAyB,EACzB,sBAAsB,GACvB,MAAM,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AA8DA,mBAAmB;AACnB,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAc3F,OAAO,EACL,iBAAiB,EACjB,qBAAqB,EACrB,mBAAmB,EACnB,qBAAqB,EACrB,SAAS,EACT,OAAO,EACP,SAAS,GACV,MAAM,YAAY,CAAC;AAEpB,2CAA2C;AAC3C,OAAO,EACL,yBAAyB,EACzB,uBAAuB,EACvB,2BAA2B,EAC3B,mBAAmB,GACpB,MAAM,YAAY,CAAC;AAyBpB,OAAO,EACL,yBAAyB,EACzB,sBAAsB,GACvB,MAAM,iBAAiB,CAAC;AAOzB,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,YAAY,GACb,MAAM,gBAAgB,CAAC"}