stable-harness 0.0.36 → 0.0.38

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 (233) hide show
  1. package/node_modules/@stable-harness/adapter-deepagents/dist/src/adapter.d.ts +9 -0
  2. package/node_modules/@stable-harness/adapter-deepagents/dist/src/adapter.js +1 -0
  3. package/node_modules/@stable-harness/adapter-deepagents/dist/src/index.d.ts +4 -0
  4. package/node_modules/@stable-harness/adapter-deepagents/dist/src/index.js +1 -0
  5. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/builtin-args.d.ts +5 -0
  6. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/builtin-args.js +1 -0
  7. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/builtin-call-repair.d.ts +9 -0
  8. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/builtin-call-repair.js +1 -0
  9. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/builtin-tool-policy.d.ts +39 -0
  10. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/builtin-tool-policy.js +1 -0
  11. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/gateway/tool-evidence.d.ts +10 -0
  12. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/gateway/tool-evidence.js +1 -0
  13. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/gateway/tool-failure-events.d.ts +2 -0
  14. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/gateway/tool-failure-events.js +1 -0
  15. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/gateway-tools.d.ts +33 -0
  16. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/gateway-tools.js +1 -0
  17. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/messages.d.ts +9 -0
  18. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/messages.js +1 -0
  19. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/raw-tool-call-parser.d.ts +12 -0
  20. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/raw-tool-call-parser.js +1 -0
  21. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/skill-file-policy.d.ts +10 -0
  22. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/skill-file-policy.js +1 -0
  23. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/stream-events.d.ts +2 -0
  24. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/stream-events.js +1 -0
  25. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/tool-repeat-visibility.d.ts +4 -0
  26. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/tool-repeat-visibility.js +1 -0
  27. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/trace-projection.d.ts +16 -0
  28. package/node_modules/@stable-harness/adapter-deepagents/dist/src/internal/trace-projection.js +1 -0
  29. package/node_modules/@stable-harness/adapter-deepagents/dist/src/memory.d.ts +5 -0
  30. package/node_modules/@stable-harness/adapter-deepagents/dist/src/memory.js +1 -0
  31. package/node_modules/@stable-harness/adapter-deepagents/dist/src/model-providers.d.ts +4 -0
  32. package/node_modules/@stable-harness/adapter-deepagents/dist/src/model-providers.js +1 -0
  33. package/node_modules/@stable-harness/adapter-deepagents/dist/src/retry-policy.d.ts +2 -0
  34. package/node_modules/@stable-harness/adapter-deepagents/dist/src/retry-policy.js +1 -0
  35. package/node_modules/@stable-harness/adapter-deepagents/dist/src/types.d.ts +12 -0
  36. package/node_modules/@stable-harness/adapter-deepagents/dist/src/types.js +1 -0
  37. package/node_modules/@stable-harness/adapter-deepagents/package.json +26 -0
  38. package/node_modules/@stable-harness/adapter-langgraph/dist/src/graph.d.ts +3 -0
  39. package/node_modules/@stable-harness/adapter-langgraph/dist/src/graph.js +1 -0
  40. package/node_modules/@stable-harness/adapter-langgraph/dist/src/index.d.ts +8 -0
  41. package/node_modules/@stable-harness/adapter-langgraph/dist/src/index.js +1 -0
  42. package/node_modules/@stable-harness/adapter-langgraph/dist/src/runtime.d.ts +3 -0
  43. package/node_modules/@stable-harness/adapter-langgraph/dist/src/runtime.js +1 -0
  44. package/node_modules/@stable-harness/adapter-langgraph/dist/src/skill-providers.d.ts +29 -0
  45. package/node_modules/@stable-harness/adapter-langgraph/dist/src/skill-providers.js +1 -0
  46. package/node_modules/@stable-harness/adapter-langgraph/dist/src/types.d.ts +60 -0
  47. package/node_modules/@stable-harness/adapter-langgraph/dist/src/types.js +1 -0
  48. package/node_modules/@stable-harness/adapter-langgraph/package.json +16 -0
  49. package/node_modules/@stable-harness/core/dist/boundary-scan.d.ts +38 -0
  50. package/node_modules/@stable-harness/core/dist/boundary-scan.js +1 -0
  51. package/node_modules/@stable-harness/core/dist/evaluations/index.d.ts +18 -0
  52. package/node_modules/@stable-harness/core/dist/evaluations/index.js +1 -0
  53. package/node_modules/@stable-harness/core/dist/execution-contract.d.ts +9 -0
  54. package/node_modules/@stable-harness/core/dist/execution-contract.js +1 -0
  55. package/node_modules/@stable-harness/core/dist/index.d.ts +20 -0
  56. package/node_modules/@stable-harness/core/dist/index.js +1 -0
  57. package/node_modules/@stable-harness/core/dist/memory-plugins/maintenance.d.ts +42 -0
  58. package/node_modules/@stable-harness/core/dist/memory-plugins/maintenance.js +1 -0
  59. package/node_modules/@stable-harness/core/dist/memory-plugins/shared.d.ts +8 -0
  60. package/node_modules/@stable-harness/core/dist/memory-plugins/shared.js +1 -0
  61. package/node_modules/@stable-harness/core/dist/memory-plugins.d.ts +25 -0
  62. package/node_modules/@stable-harness/core/dist/memory-plugins.js +1 -0
  63. package/node_modules/@stable-harness/core/dist/quality/event-evidence.d.ts +11 -0
  64. package/node_modules/@stable-harness/core/dist/quality/event-evidence.js +1 -0
  65. package/node_modules/@stable-harness/core/dist/quality/execution-review.d.ts +2 -0
  66. package/node_modules/@stable-harness/core/dist/quality/execution-review.js +1 -0
  67. package/node_modules/@stable-harness/core/dist/quality/index.d.ts +9 -0
  68. package/node_modules/@stable-harness/core/dist/quality/index.js +1 -0
  69. package/node_modules/@stable-harness/core/dist/quality/llm-review.d.ts +7 -0
  70. package/node_modules/@stable-harness/core/dist/quality/llm-review.js +1 -0
  71. package/node_modules/@stable-harness/core/dist/quality/planning-review.d.ts +2 -0
  72. package/node_modules/@stable-harness/core/dist/quality/planning-review.js +1 -0
  73. package/node_modules/@stable-harness/core/dist/quality/profile.d.ts +3 -0
  74. package/node_modules/@stable-harness/core/dist/quality/profile.js +1 -0
  75. package/node_modules/@stable-harness/core/dist/quality/recovery-policy.d.ts +11 -0
  76. package/node_modules/@stable-harness/core/dist/quality/recovery-policy.js +1 -0
  77. package/node_modules/@stable-harness/core/dist/quality/runtime.d.ts +13 -0
  78. package/node_modules/@stable-harness/core/dist/quality/runtime.js +1 -0
  79. package/node_modules/@stable-harness/core/dist/quality/synthesis/fields.d.ts +19 -0
  80. package/node_modules/@stable-harness/core/dist/quality/synthesis/fields.js +1 -0
  81. package/node_modules/@stable-harness/core/dist/quality/synthesis/language.d.ts +3 -0
  82. package/node_modules/@stable-harness/core/dist/quality/synthesis/language.js +1 -0
  83. package/node_modules/@stable-harness/core/dist/quality/synthesis/observed.d.ts +3 -0
  84. package/node_modules/@stable-harness/core/dist/quality/synthesis/observed.js +1 -0
  85. package/node_modules/@stable-harness/core/dist/quality/synthesis.d.ts +2 -0
  86. package/node_modules/@stable-harness/core/dist/quality/synthesis.js +1 -0
  87. package/node_modules/@stable-harness/core/dist/quality/types.d.ts +52 -0
  88. package/node_modules/@stable-harness/core/dist/quality/types.js +1 -0
  89. package/node_modules/@stable-harness/core/dist/recovery/tool-call.d.ts +28 -0
  90. package/node_modules/@stable-harness/core/dist/recovery/tool-call.js +1 -0
  91. package/node_modules/@stable-harness/core/dist/runtime/capabilities.d.ts +47 -0
  92. package/node_modules/@stable-harness/core/dist/runtime/capabilities.js +1 -0
  93. package/node_modules/@stable-harness/core/dist/runtime/completion.d.ts +18 -0
  94. package/node_modules/@stable-harness/core/dist/runtime/completion.js +1 -0
  95. package/node_modules/@stable-harness/core/dist/runtime/direct-tool-call.d.ts +11 -0
  96. package/node_modules/@stable-harness/core/dist/runtime/direct-tool-call.js +1 -0
  97. package/node_modules/@stable-harness/core/dist/runtime/events.d.ts +295 -0
  98. package/node_modules/@stable-harness/core/dist/runtime/events.js +1 -0
  99. package/node_modules/@stable-harness/core/dist/runtime/governance/approval-gate.d.ts +8 -0
  100. package/node_modules/@stable-harness/core/dist/runtime/governance/approval-gate.js +1 -0
  101. package/node_modules/@stable-harness/core/dist/runtime/governance/sandbox.d.ts +9 -0
  102. package/node_modules/@stable-harness/core/dist/runtime/governance/sandbox.js +1 -0
  103. package/node_modules/@stable-harness/core/dist/runtime/inspection/artifacts.d.ts +15 -0
  104. package/node_modules/@stable-harness/core/dist/runtime/inspection/artifacts.js +1 -0
  105. package/node_modules/@stable-harness/core/dist/runtime/inspection/methods.d.ts +11 -0
  106. package/node_modules/@stable-harness/core/dist/runtime/inspection/methods.js +1 -0
  107. package/node_modules/@stable-harness/core/dist/runtime/inspection/replay.d.ts +6 -0
  108. package/node_modules/@stable-harness/core/dist/runtime/inspection/replay.js +1 -0
  109. package/node_modules/@stable-harness/core/dist/runtime/memory.d.ts +29 -0
  110. package/node_modules/@stable-harness/core/dist/runtime/memory.js +1 -0
  111. package/node_modules/@stable-harness/core/dist/runtime/persistence/artifacts.d.ts +8 -0
  112. package/node_modules/@stable-harness/core/dist/runtime/persistence/artifacts.js +1 -0
  113. package/node_modules/@stable-harness/core/dist/runtime/persistence/inspection.d.ts +4 -0
  114. package/node_modules/@stable-harness/core/dist/runtime/persistence/inspection.js +1 -0
  115. package/node_modules/@stable-harness/core/dist/runtime/persistence/queue.d.ts +2 -0
  116. package/node_modules/@stable-harness/core/dist/runtime/persistence/queue.js +1 -0
  117. package/node_modules/@stable-harness/core/dist/runtime/persistence/stores.d.ts +3 -0
  118. package/node_modules/@stable-harness/core/dist/runtime/persistence/stores.js +1 -0
  119. package/node_modules/@stable-harness/core/dist/runtime/progress-narration.d.ts +38 -0
  120. package/node_modules/@stable-harness/core/dist/runtime/progress-narration.js +1 -0
  121. package/node_modules/@stable-harness/core/dist/runtime/selection-repair.d.ts +24 -0
  122. package/node_modules/@stable-harness/core/dist/runtime/selection-repair.js +1 -0
  123. package/node_modules/@stable-harness/core/dist/runtime/tool-failure.d.ts +41 -0
  124. package/node_modules/@stable-harness/core/dist/runtime/tool-failure.js +1 -0
  125. package/node_modules/@stable-harness/core/dist/runtime/tool-gateway.d.ts +59 -0
  126. package/node_modules/@stable-harness/core/dist/runtime/tool-gateway.js +1 -0
  127. package/node_modules/@stable-harness/core/dist/runtime/types.d.ts +191 -0
  128. package/node_modules/@stable-harness/core/dist/runtime/types.js +1 -0
  129. package/node_modules/@stable-harness/core/dist/runtime.d.ts +21 -0
  130. package/node_modules/@stable-harness/core/dist/runtime.js +1 -0
  131. package/node_modules/@stable-harness/core/dist/spec-driven/config.d.ts +4 -0
  132. package/node_modules/@stable-harness/core/dist/spec-driven/config.js +1 -0
  133. package/node_modules/@stable-harness/core/dist/spec-driven/events.d.ts +11 -0
  134. package/node_modules/@stable-harness/core/dist/spec-driven/events.js +1 -0
  135. package/node_modules/@stable-harness/core/dist/spec-driven/index.d.ts +4 -0
  136. package/node_modules/@stable-harness/core/dist/spec-driven/index.js +1 -0
  137. package/node_modules/@stable-harness/core/dist/spec-driven/lifecycle.d.ts +11 -0
  138. package/node_modules/@stable-harness/core/dist/spec-driven/lifecycle.js +1 -0
  139. package/node_modules/@stable-harness/core/dist/spec-driven/types.d.ts +38 -0
  140. package/node_modules/@stable-harness/core/dist/spec-driven/types.js +1 -0
  141. package/node_modules/@stable-harness/core/dist/trace.d.ts +15 -0
  142. package/node_modules/@stable-harness/core/dist/trace.js +1 -0
  143. package/node_modules/@stable-harness/core/dist/types.d.ts +144 -0
  144. package/node_modules/@stable-harness/core/dist/types.js +1 -0
  145. package/node_modules/@stable-harness/core/dist/workflows/index.d.ts +70 -0
  146. package/node_modules/@stable-harness/core/dist/workflows/index.js +1 -0
  147. package/node_modules/@stable-harness/core/dist/workflows/runtime.d.ts +12 -0
  148. package/node_modules/@stable-harness/core/dist/workflows/runtime.js +1 -0
  149. package/node_modules/@stable-harness/core/dist/workspace/tool-quality.d.ts +22 -0
  150. package/node_modules/@stable-harness/core/dist/workspace/tool-quality.js +1 -0
  151. package/node_modules/@stable-harness/core/dist/workspace/types.d.ts +134 -0
  152. package/node_modules/@stable-harness/core/dist/workspace/types.js +1 -0
  153. package/node_modules/@stable-harness/core/package.json +18 -0
  154. package/node_modules/@stable-harness/governance/dist/src/approval-queue.d.ts +2 -0
  155. package/node_modules/@stable-harness/governance/dist/src/approval-queue.js +1 -0
  156. package/node_modules/@stable-harness/governance/dist/src/index.d.ts +4 -0
  157. package/node_modules/@stable-harness/governance/dist/src/index.js +1 -0
  158. package/node_modules/@stable-harness/governance/dist/src/policy-engine.d.ts +2 -0
  159. package/node_modules/@stable-harness/governance/dist/src/policy-engine.js +1 -0
  160. package/node_modules/@stable-harness/governance/dist/src/skill-candidates.d.ts +2 -0
  161. package/node_modules/@stable-harness/governance/dist/src/skill-candidates.js +1 -0
  162. package/node_modules/@stable-harness/governance/dist/src/types.d.ts +101 -0
  163. package/node_modules/@stable-harness/governance/dist/src/types.js +1 -0
  164. package/node_modules/@stable-harness/governance/package.json +12 -0
  165. package/node_modules/@stable-harness/memory/dist/src/index.d.ts +9 -0
  166. package/node_modules/@stable-harness/memory/dist/src/index.js +1 -0
  167. package/node_modules/@stable-harness/memory/dist/src/langmem-service.d.ts +8 -0
  168. package/node_modules/@stable-harness/memory/dist/src/langmem-service.js +1 -0
  169. package/node_modules/@stable-harness/memory/dist/src/maintenance.d.ts +2 -0
  170. package/node_modules/@stable-harness/memory/dist/src/maintenance.js +1 -0
  171. package/node_modules/@stable-harness/memory/dist/src/persistence.d.ts +4 -0
  172. package/node_modules/@stable-harness/memory/dist/src/persistence.js +1 -0
  173. package/node_modules/@stable-harness/memory/dist/src/policy.d.ts +2 -0
  174. package/node_modules/@stable-harness/memory/dist/src/policy.js +1 -0
  175. package/node_modules/@stable-harness/memory/dist/src/provider.d.ts +50 -0
  176. package/node_modules/@stable-harness/memory/dist/src/provider.js +1 -0
  177. package/node_modules/@stable-harness/memory/dist/src/store.d.ts +5 -0
  178. package/node_modules/@stable-harness/memory/dist/src/store.js +1 -0
  179. package/node_modules/@stable-harness/memory/dist/src/types.d.ts +138 -0
  180. package/node_modules/@stable-harness/memory/dist/src/types.js +1 -0
  181. package/node_modules/@stable-harness/memory/package.json +12 -0
  182. package/node_modules/@stable-harness/protocols/dist/src/http-server.d.ts +3 -0
  183. package/node_modules/@stable-harness/protocols/dist/src/http-server.js +1 -0
  184. package/node_modules/@stable-harness/protocols/dist/src/in-process-client.d.ts +2 -0
  185. package/node_modules/@stable-harness/protocols/dist/src/in-process-client.js +1 -0
  186. package/node_modules/@stable-harness/protocols/dist/src/index.d.ts +4 -0
  187. package/node_modules/@stable-harness/protocols/dist/src/index.js +1 -0
  188. package/node_modules/@stable-harness/protocols/dist/src/openai-compatible.d.ts +9 -0
  189. package/node_modules/@stable-harness/protocols/dist/src/openai-compatible.js +1 -0
  190. package/node_modules/@stable-harness/protocols/dist/src/openai-payload.d.ts +74 -0
  191. package/node_modules/@stable-harness/protocols/dist/src/openai-payload.js +1 -0
  192. package/node_modules/@stable-harness/protocols/dist/src/openai-stream.d.ts +39 -0
  193. package/node_modules/@stable-harness/protocols/dist/src/openai-stream.js +1 -0
  194. package/node_modules/@stable-harness/protocols/package.json +15 -0
  195. package/node_modules/@stable-harness/tool-gateway/dist/src/argument-guard.d.ts +33 -0
  196. package/node_modules/@stable-harness/tool-gateway/dist/src/argument-guard.js +1 -0
  197. package/node_modules/@stable-harness/tool-gateway/dist/src/in-memory.d.ts +4 -0
  198. package/node_modules/@stable-harness/tool-gateway/dist/src/in-memory.js +1 -0
  199. package/node_modules/@stable-harness/tool-gateway/dist/src/index.d.ts +7 -0
  200. package/node_modules/@stable-harness/tool-gateway/dist/src/index.js +1 -0
  201. package/node_modules/@stable-harness/tool-gateway/dist/src/module-loader.d.ts +13 -0
  202. package/node_modules/@stable-harness/tool-gateway/dist/src/module-loader.js +1 -0
  203. package/node_modules/@stable-harness/tool-gateway/dist/src/schema-validation.d.ts +3 -0
  204. package/node_modules/@stable-harness/tool-gateway/dist/src/schema-validation.js +1 -0
  205. package/node_modules/@stable-harness/tool-gateway/dist/src/types.d.ts +79 -0
  206. package/node_modules/@stable-harness/tool-gateway/dist/src/types.js +1 -0
  207. package/node_modules/@stable-harness/tool-gateway/package.json +15 -0
  208. package/node_modules/@stable-harness/workspace-yaml/dist/boundary-scan.d.ts +3 -0
  209. package/node_modules/@stable-harness/workspace-yaml/dist/boundary-scan.js +1 -0
  210. package/node_modules/@stable-harness/workspace-yaml/dist/discovery.d.ts +4 -0
  211. package/node_modules/@stable-harness/workspace-yaml/dist/discovery.js +1 -0
  212. package/node_modules/@stable-harness/workspace-yaml/dist/documents.d.ts +16 -0
  213. package/node_modules/@stable-harness/workspace-yaml/dist/documents.js +1 -0
  214. package/node_modules/@stable-harness/workspace-yaml/dist/evaluations.d.ts +9 -0
  215. package/node_modules/@stable-harness/workspace-yaml/dist/evaluations.js +1 -0
  216. package/node_modules/@stable-harness/workspace-yaml/dist/index.d.ts +1 -0
  217. package/node_modules/@stable-harness/workspace-yaml/dist/index.js +1 -0
  218. package/node_modules/@stable-harness/workspace-yaml/dist/loader.d.ts +2 -0
  219. package/node_modules/@stable-harness/workspace-yaml/dist/loader.js +1 -0
  220. package/node_modules/@stable-harness/workspace-yaml/dist/workflows.d.ts +16 -0
  221. package/node_modules/@stable-harness/workspace-yaml/dist/workflows.js +1 -0
  222. package/node_modules/@stable-harness/workspace-yaml/package.json +16 -0
  223. package/package.json +32 -10
  224. package/packages/adapter-deepagents/package.json +4 -6
  225. package/packages/adapter-langgraph/package.json +1 -1
  226. package/packages/cli/package.json +1 -1
  227. package/packages/core/dist/quality/synthesis/fields.js +1 -1
  228. package/packages/core/dist/quality/synthesis.js +1 -1
  229. package/packages/core/package.json +1 -1
  230. package/packages/evaluation/package.json +1 -1
  231. package/packages/protocols/package.json +1 -1
  232. package/packages/tool-gateway/package.json +1 -1
  233. package/packages/workspace-yaml/package.json +1 -1
@@ -0,0 +1,9 @@
1
+ import type { WorkspaceAgent, WorkspaceEvaluation, WorkspaceTool, WorkspaceWorkflow } from "@stable-harness/core";
2
+ import type { RawDocument } from "./documents.js";
3
+ export declare function compileEvaluation(document: RawDocument, sourcePath: string): WorkspaceEvaluation;
4
+ export declare function validateEvaluations(input: {
5
+ evaluations: Map<string, WorkspaceEvaluation>;
6
+ agents: Map<string, WorkspaceAgent>;
7
+ tools: Map<string, WorkspaceTool>;
8
+ workflows: Map<string, WorkspaceWorkflow>;
9
+ }): void;
@@ -0,0 +1 @@
1
+ export function compileEvaluation(r,t){const e=assertRecord(r.spec,"Evaluation.spec"),o=function readName(r){const t=r.metadata?.name;if("string"==typeof t&&t.trim())return t.trim();throw new Error("Evaluation document requires metadata.name")}(r);return{id:o,...readDescription(r)?{description:readDescription(r)}:{},sourcePath:t,...readString(e.suite)?{suite:readString(e.suite)}:{},cases:readCases(e.cases,o),..."object"==typeof e.config&&e.config?{config:e.config}:{}}}export function validateEvaluations(r){for(const t of r.evaluations.values())for(const e of t.cases){if(e.agentId&&!r.agents.has(e.agentId))throw new Error(`Evaluation ${t.id} case ${e.id} references unknown agent ${e.agentId}`);if(e.workflowId&&!r.workflows.has(e.workflowId))throw new Error(`Evaluation ${t.id} case ${e.id} references unknown workflow ${e.workflowId}`);for(const o of e.tools??[])if(!r.tools.has(o))throw new Error(`Evaluation ${t.id} case ${e.id} references unknown tool ${o}`)}}function readCases(r,t){if(!Array.isArray(r)||0===r.length)throw new Error(`Evaluation ${t} spec.cases must be a non-empty array`);return r.map(r=>{const e=assertRecord(r,`Evaluation ${t} spec.cases[]`),o=readString(e.id);if(!o)throw new Error(`Evaluation ${t} spec.cases[] requires id`);return{id:o,...readString(e.description)?{description:readString(e.description)}:{},...readString(e.agentId)?{agentId:readString(e.agentId)}:{},...readString(e.workflowId)?{workflowId:readString(e.workflowId)}:{},...void 0!==e.input?{input:e.input}:{},...Array.isArray(e.tools)?{tools:e.tools.filter(r=>"string"==typeof r&&r.trim().length>0)}:{},..."object"==typeof e.assertions&&e.assertions?{assertions:e.assertions}:{},..."object"==typeof e.metadata&&e.metadata?{metadata:e.metadata}:{}}})}function assertRecord(r,t){if("object"!=typeof r||null===r||Array.isArray(r))throw new Error(`${t} must be an object`);return r}function readDescription(r){return readString(r.metadata?.description)}function readString(r){return"string"==typeof r&&r.trim()?r.trim():void 0}
@@ -0,0 +1 @@
1
+ export * from "./loader.js";
@@ -0,0 +1 @@
1
+ export*from"./loader.js";
@@ -0,0 +1,2 @@
1
+ import type { CompiledWorkspace } from "@stable-harness/core";
2
+ export declare function loadWorkspaceFromYaml(workspaceRoot: string): Promise<CompiledWorkspace>;
@@ -0,0 +1 @@
1
+ import{readFile as o}from"node:fs/promises";import e from"node:path";import{parseAllDocuments as s}from"yaml";import{discoverModuleTools as t,discoverSkills as r,listYamlFiles as a}from"./discovery.js";import{compileAgent as n,compileMemory as l,compileModel as i,compileModelSpec as c,compileRuntime as f,compileTool as u}from"./documents.js";import{compileWorkflow as m,validateWorkflows as w}from"./workflows.js";import{compileEvaluation as d,validateEvaluations as p}from"./evaluations.js";import{assertWorkspaceBoundaryDiagnostics as k,scanWorkspaceBoundaries as g}from"./boundary-scan.js";import{assertWorkspaceToolQualityDiagnostics as v,scanWorkspaceToolQuality as y}from"@stable-harness/core";export async function loadWorkspaceFromYaml(n){const l=e.join(n,"config"),i=await a(l),c=[],f=new Map,u=new Map,m=new Map,d=new Map,M=new Map,W=new Map,h=new Map;for(const e of i){const t=await o(e,"utf8"),r=s(t).map(o=>o.toJSON()).filter(o=>null!==o);for(const o of r)collectWorkspaceDocument(o,e,{runtimeDocs:c,agents:f,models:u,tools:m,memories:M,workflows:W,evaluations:h})}for(const o of await t(n))m.has(o.id)||m.set(o.id,o);for(const o of await r(n))d.set(o.id,o);const R=c.at(-1)??{defaultAgentId:"orchestra"};w({workflows:W,agents:f,tools:m,skills:d}),p({evaluations:h,agents:f,tools:m,workflows:W}),function validateAgentRouting(o,e){for(const s of o.routes??[])if(!e.has(s.agentId))throw new Error(`Runtime routing route ${s.id} references unknown agent ${s.agentId}`)}(R,f),function validateWorkflowRouting(o,e){const s=o.workflowRouting;if(s){if(s.defaultWorkflowId&&!e.has(s.defaultWorkflowId))throw new Error(`Runtime workflowRouting.defaultWorkflowId references unknown workflow ${s.defaultWorkflowId}`);for(const o of s.routes??[])if(!e.has(o.workflowId))throw new Error(`Runtime workflowRouting route ${o.id} references unknown workflow ${o.workflowId}`)}}(R,W);const A={root:n,runtime:R,agents:f,models:u,tools:m,skills:d,memories:M,workflows:W,evaluations:h},I=g(A);k(I);const O=y(A,R.workspaceValidation?.toolQuality);return v(O),{...A,...[...I??[],...O].length>0?{diagnostics:[...I,...O]}:{}}}function collectWorkspaceDocument(o,e,s){if("string"==typeof o.kind)switch(o.kind){case"Runtime":return void s.runtimeDocs.push(f(o));case"Agent":return collectOne(s.agents,n(o,e));case"Model":return collectOne(s.models,i(o));case"Models":return function collectModelSpecs(o,e){if(Array.isArray(o.spec))for(const s of o.spec)if("object"==typeof s&&null!==s&&!Array.isArray(s)){const o=c(s);e.set(o.id,o)}}(o,s.models);case"Tool":return collectOne(s.tools,u(o,e));case"Memory":return collectOne(s.memories,l(o));case"Workflow":return collectOne(s.workflows,m(o,e));case"Evaluation":return collectOne(s.evaluations,d(o,e));default:return}}function collectOne(o,e){o.set(e.id,e)}
@@ -0,0 +1,16 @@
1
+ import type { WorkspaceAgent, WorkspaceSkill, WorkspaceTool, WorkspaceWorkflow } from "@stable-harness/core";
2
+ type RawDocument = {
3
+ metadata?: {
4
+ name?: unknown;
5
+ description?: unknown;
6
+ };
7
+ spec?: unknown;
8
+ };
9
+ export declare function compileWorkflow(document: RawDocument, sourcePath: string): WorkspaceWorkflow;
10
+ export declare function validateWorkflows(input: {
11
+ workflows: Map<string, WorkspaceWorkflow>;
12
+ agents: Map<string, WorkspaceAgent>;
13
+ tools: Map<string, WorkspaceTool>;
14
+ skills: Map<string, WorkspaceSkill>;
15
+ }): void;
16
+ export {};
@@ -0,0 +1 @@
1
+ export function compileWorkflow(o,r){const e=assertRecord(o.spec,"Workflow.spec"),t="object"==typeof e.config&&e.config?e.config:{};return{id:readName(o),...readDescription(o)?{description:readDescription(o)}:{},sourcePath:r,...readOptionalString(e.adapter)?{adapter:readOptionalString(e.adapter)}:{},...readOptionalString(e.entry)?{entry:readOptionalString(e.entry)}:{},..."object"==typeof e.state&&e.state?{state:readWorkflowState(e.state)}:{},nodes:readWorkflowNodes(e.nodes),edges:readWorkflowEdges(e.edges),..."object"==typeof e.policies&&e.policies?{policies:e.policies}:{},...Object.keys(t).length>0?{config:t}:{}}}export function validateWorkflows(o){for(const r of o.workflows.values()){const e=new Set(r.nodes.map(o=>o.id));validateWorkflowEntry(r,e),validateWorkflowEdges(r,e);for(const e of r.nodes)validateWorkflowUse(e.use,o)}}function readWorkflowState(o){const r=assertRecord(o,"Workflow.spec.state");return{...readOptionalString(r.schema)?{schema:readOptionalString(r.schema)}:{},..."object"==typeof r.config&&r.config?{config:r.config}:{}}}function readWorkflowNodes(o){if(!Array.isArray(o)||0===o.length)throw new Error("Workflow.spec.nodes must be a non-empty array");return o.map(o=>{const r=assertRecord(o,"Workflow.spec.nodes[]"),e=readOptionalString(r.id),t=readOptionalString(r.use);if(!e||!t)throw new Error("Workflow.spec.nodes[] requires id and use");return{id:e,use:t,...readOptionalString(r.type)?{type:readOptionalString(r.type)}:{},..."object"==typeof r.config&&r.config?{config:r.config}:{}}})}function readWorkflowEdges(o){if(!Array.isArray(o))throw new Error("Workflow.spec.edges must be an array");return o.map(o=>{const r=assertRecord(o,"Workflow.spec.edges[]"),e=readOptionalString(r.from),t=readOptionalString(r.to);if(!e||!t)throw new Error("Workflow.spec.edges[] requires from and to");return{from:e,to:t,...readOptionalString(r.condition)?{condition:readOptionalString(r.condition)}:{}}})}function validateWorkflowEntry(o,r){if(o.entry&&!r.has(o.entry))throw new Error(`Workflow ${o.id} entry references unknown node ${o.entry}`)}function validateWorkflowEdges(o,r){for(const e of o.edges)if(!r.has(e.from)||!r.has(e.to))throw new Error(`Workflow ${o.id} edge references unknown node ${e.from}->${e.to}`)}function validateWorkflowUse(o,r){const e=o.indexOf("."),t=e>0?o.slice(0,e):"",n=e>0?o.slice(e+1):"";if(!t||!n)throw new Error(`Workflow node use must reference inventory as agents.<id>, tools.<id>, skills.<id>, or workflows.<id>: ${o}`);const i="agents"===t?r.agents:"tools"===t?r.tools:"skills"===t?r.skills:"workflows"===t?r.workflows:void 0;if(!i?.has(n))throw new Error(`Workflow node references unknown ${t}.${n}`)}function assertRecord(o,r){if("object"!=typeof o||null===o||Array.isArray(o))throw new Error(`${r} must be an object`);return o}function readName(o){const r=o.metadata?.name;if("string"==typeof r&&r.trim())return r.trim();throw new Error("Workflow document requires metadata.name")}function readDescription(o){const r=o.metadata?.description;return"string"==typeof r&&r.trim()?r.trim():void 0}function readOptionalString(o){return"string"==typeof o&&o.trim()?o.trim():void 0}
@@ -0,0 +1,16 @@
1
+ {
2
+ "name": "@stable-harness/workspace-yaml",
3
+ "version": "0.0.1",
4
+ "type": "module",
5
+ "files": [
6
+ "dist/**/*.js",
7
+ "dist/**/*.d.ts",
8
+ "package.json"
9
+ ],
10
+ "exports": {
11
+ ".": "./dist/index.js"
12
+ },
13
+ "peerDependencies": {
14
+ "@stable-harness/core": "0.0.1"
15
+ }
16
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "stable-harness",
3
- "version": "0.0.36",
3
+ "version": "0.0.38",
4
4
  "type": "module",
5
5
  "description": "Stable application runtime and operator control plane for agent workspaces.",
6
6
  "license": "Apache-2.0",
@@ -84,14 +84,14 @@
84
84
  "@langchain/langgraph-api": "^1.2.1",
85
85
  "@langchain/ollama": "^1.2.7",
86
86
  "@langchain/openai": "^1.4.5",
87
- "@stable-harness/adapter-deepagents": "file:packages/adapter-deepagents",
88
- "@stable-harness/adapter-langgraph": "file:packages/adapter-langgraph",
89
- "@stable-harness/core": "file:packages/core",
90
- "@stable-harness/governance": "file:packages/governance",
91
- "@stable-harness/memory": "file:packages/memory",
92
- "@stable-harness/protocols": "file:packages/protocols",
93
- "@stable-harness/tool-gateway": "file:packages/tool-gateway",
94
- "@stable-harness/workspace-yaml": "file:packages/workspace-yaml",
87
+ "@stable-harness/adapter-deepagents": "0.0.1",
88
+ "@stable-harness/adapter-langgraph": "0.0.1",
89
+ "@stable-harness/core": "0.0.1",
90
+ "@stable-harness/governance": "0.0.1",
91
+ "@stable-harness/memory": "0.0.1",
92
+ "@stable-harness/protocols": "0.0.1",
93
+ "@stable-harness/tool-gateway": "0.0.1",
94
+ "@stable-harness/workspace-yaml": "0.0.1",
95
95
  "deepagents": "^1.9.1",
96
96
  "langchain": "^1.3.1",
97
97
  "yaml": "^2.8.2",
@@ -101,5 +101,27 @@
101
101
  "@types/node": "^25.6.2",
102
102
  "terser": "^5.47.1",
103
103
  "typescript": "^5.9.3"
104
- }
104
+ },
105
+ "main": "index.js",
106
+ "directories": {
107
+ "doc": "docs",
108
+ "example": "examples",
109
+ "test": "test"
110
+ },
111
+ "keywords": [],
112
+ "author": "",
113
+ "bugs": {
114
+ "url": "https://github.com/botbotgo/stable-harness/issues"
115
+ },
116
+ "homepage": "https://github.com/botbotgo/stable-harness#readme",
117
+ "bundleDependencies": [
118
+ "@stable-harness/adapter-deepagents",
119
+ "@stable-harness/adapter-langgraph",
120
+ "@stable-harness/core",
121
+ "@stable-harness/governance",
122
+ "@stable-harness/memory",
123
+ "@stable-harness/protocols",
124
+ "@stable-harness/tool-gateway",
125
+ "@stable-harness/workspace-yaml"
126
+ ]
105
127
  }
@@ -9,16 +9,14 @@
9
9
  ],
10
10
  "main": "dist/src/index.js",
11
11
  "types": "dist/src/index.d.ts",
12
- "dependencies": {
12
+ "peerDependencies": {
13
13
  "@botbotgo/better-call": "^0.1.58",
14
14
  "@langchain/core": "^1.1.43",
15
15
  "@langchain/ollama": "^1.2.7",
16
16
  "@langchain/openai": "^1.4.5",
17
- "langchain": "^1.3.1",
18
- "@stable-harness/core": "0.0.1"
19
- },
20
- "peerDependencies": {
21
- "deepagents": "^1.9.1"
17
+ "@stable-harness/core": "0.0.1",
18
+ "deepagents": "^1.9.1",
19
+ "langchain": "^1.3.1"
22
20
  },
23
21
  "peerDependenciesMeta": {
24
22
  "deepagents": {
@@ -9,7 +9,7 @@
9
9
  ],
10
10
  "main": "dist/src/index.js",
11
11
  "types": "dist/src/index.d.ts",
12
- "dependencies": {
12
+ "peerDependencies": {
13
13
  "@langchain/langgraph": "^1.3.0",
14
14
  "@stable-harness/core": "0.0.1"
15
15
  }
@@ -12,7 +12,7 @@
12
12
  },
13
13
  "main": "dist/src/index.js",
14
14
  "types": "dist/src/index.d.ts",
15
- "dependencies": {
15
+ "peerDependencies": {
16
16
  "@langchain/langgraph-api": "^1.2.1",
17
17
  "@stable-harness/adapter-deepagents": "0.0.1",
18
18
  "@stable-harness/adapter-langgraph": "0.0.1",
@@ -1 +1 @@
1
- export function evidenceFields(e){const t=new Set,l=[];for(const a of e)for(const e of parseEvidenceFields(a)){const a=`${normalizeFieldLabel(e.label)}\0${e.value.toLowerCase()}`;t.has(a)||(t.add(a),l.push(e))}return l}export function selectSectionFields(e,t,l){return function withSourceCoverage(e,t){const l=[...e].sort((e,t)=>scoreField(t)-scoreField(e)),a=new Map;for(const e of[...new Set(l.map(e=>e.source))]){const t=l.find(t=>t.source===e);t&&a.set(fieldKey(t),t)}for(const e of l)if(a.set(fieldKey(e),e),a.size>=t)break;return[...a.values()].slice(0,t)}(e.filter(e=>e.kind===t),l).sort((e,t)=>scoreField(t)-scoreField(e)||e.label.localeCompare(t.label))}export function fieldTableLines(e,t){return 0===e.length?[]:[..."zh"===t?["| 项目 | 数值 | 来源 |","|---|---:|---|"]:["| Field | Value | Source |","|---|---:|---|"],...e.map(e=>`| ${escapeTableCell(e.label)} | ${escapeTableCell(e.value)} | ${escapeTableCell(function humanSourceLabel(e){const t=e.replace(/([a-z])([A-Z])/gu,"$1 $2").split(/[_:.\-\s]+/u).map(e=>e.trim()).filter(Boolean);return 0===t.length?e:t.map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}(e.source))} |`)]}export function hasExtractableFields(e){return extractKeyValueFields(e).some(e=>!isBoilerplateField(e.label)&&e.value.length>0)}export function classifyFact(e){return/(?:gap|blocked|missing|unavailable|unsupported|缺口|阻塞|缺失|不支持|无法|未提供)/iu.test(e)?"limit":/(?:news|headline|recent|latest|filing|event|公告|新闻|近期|最新|披露|\b20\d{2}[-/年])/iu.test(e)?"timeBound":/(?:[$€£¥%]|\b\d[\d,]*(?:\.\d+)?\b)/u.test(e)?"data":/(?:name|company|symbol|resolved|overview|query|名称|公司|代码|概览|识别)/iu.test(e)?"context":"other"}function parseEvidenceFields(e){return extractKeyValueFields(e.text).filter(e=>e.value.length>0&&!isBoilerplateField(e.label)).filter(e=>!function isLowValueField(e,t){return!!/(?:snapshot for|source type|loaded sources)/iu.test(e)||!!/^\d{1,2}\s+(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b/iu.test(e)||scoreField({source:"",label:e,value:t,kind:"other"})<0}(e.label,e.value)).map(t=>{const l=classifyFact(`${t.label}: ${t.value}`);return{source:e.source,label:titleCaseLabel(t.label),value:formatEvidence(t.value),kind:"other"===l?e.kind:l}})}function scoreField(e){const t=normalizeFieldLabel(e.label);let l=e.value.length>0?10:0;return/(?:price|value|amount|total|ratio|rate|range|target|estimate|revenue|income|earnings|margin|volume|date|rating|status|count|metric|价格|收入|利润|目标|评级|数量|日期|范围|比率)/iu.test(t)&&(l+=8),/(?:name|company|symbol|title|headline|summary|名称|公司|代码|标题|摘要)/iu.test(t)&&(l+=6),/(?:unix|epoch|timestamp|raw|html|url|href|source|id|identifier|internal|debug)/iu.test(t)&&(l-=20),(/^https?:\/\//iu.test(e.value)||"/"===e.value)&&(l-=12),e.value.length>240&&(l-=5),l}function extractKeyValueFields(e){const t=[...e.matchAll(/(^|[\s;|])([\p{L}\p{N}][\p{L}\p{N} _./()%&+\-]{0,48})[::](?!\/\/)\s*/gu)].filter(e=>void 0!==e.index).map((e,t,l)=>{l[t-1];const a=function cleanFieldLabel(e){const t=e.replace(/^(?:[-*]\s*)+/u,"").replace(/\s+/gu," ").trim(),l=t.match(/^.+\b(PE Ratio TTM)$/iu);if(l?.[1]&&l[1]!==t&&/(?:beta|\b20\d{2}|\b(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b)/iu.test(t))return l[1];const a=t.split(" ").filter(Boolean);return a.length>1&&/^\d{4}$/u.test(a[0]??"")||a.length>1&&/^\d+(?:\.\d+)?$/u.test(a[0]??"")&&/^(?:\d+|beta|pe|p\/b)$/iu.test(a[1]??"")||a.length>1&&/^[A-Z]$/u.test(a[0]??"")||a.length>1&&/^(?:inc\.?|llc\.?|ltd\.?|corp\.?|corporation|co\.?)$/iu.test(a[0]??"")||a.length>1&&/^(?:usd|eur|gbp|jpy|cny|cad|aud)$/iu.test(a[0]??"")||a.length>1&&/^(?:gmt|utc)$/iu.test(a[0]??"")?a.slice(1).join(" "):function trailingKnownLabel(e){if(/\bPE Ratio TTM$/iu.test(e)&&!/^PE Ratio TTM$/iu.test(e))return"PE Ratio TTM";const t=e.match(/\b(?:Revenue|Net Income|Operating Income|Diluted EPS|EPS|Market Cap|Book Value|Target Estimate|Target Mean Price|Target Median Price|Target High Price|Target Low Price|PE Ratio TTM|P\/B|Beta(?: 5Y Monthly)?|Published|Updated|Date|Time|Summary|Title|Headline)$/iu);return t&&/(?:filed|\b20\d{2}|10-k|10-q|\bfy\b|\b(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b|\s{3,}|[a-z].{8,}\s)/iu.test(e.slice(0,t.index))?t?.[0]??e:e}(t)}(e[2]??""),r=function droppedLabelPrefix(e,t){const l=e.trim();if(l===t)return"";const a=l.toLowerCase().lastIndexOf(t.toLowerCase());return a>0?l.slice(0,a):""}(e[2]??"",a);return{index:(e.index??0)+String(e[1]??"").length+r.length,start:(e.index??0)+e[0].length,label:a,rawLabel:e[2]??""}}).filter(e=>!isBoundaryNoiseLabel(e.label)&&!isBoundaryNoiseLabel(e.rawLabel));return t.map((l,a)=>{const r=t[a+1]?.index??e.length;return{label:l.label,value:cleanFieldValue(e.slice(l.start,r),l.label)}}).filter(e=>e.label.length>0)}function cleanFieldValue(e,t){const l=e.replace(/^[\s,;|.-]+/u,"").replace(/[\s,;|.-]+$/u,"").replace(/\s+/gu," ").trim(),a=normalizeFieldLabel(t);if(/\brange\b/iu.test(a))return l.replace(/\s+Beta\b.*$/iu,"").trim();if(/^(?:ticker|symbol|resolved symbol|resolved ticker|股票 resolved ticker|代码)$/iu.test(a)){const e=l.match(/^([A-Z0-9._-]{1,24})(?:\s+\d+[.)]\s+|$)/u);if(e?.[1])return e[1]}return l}function isBoilerplateField(e){return/^(?:status|control status|evidence tool|tool|source|来源)$/iu.test(e.trim())}function isBoundaryNoiseLabel(e){return/^\d{1,2}\s+(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b/iu.test(e)||/^(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\s+\d{1,4}(?:\s+\d{1,2})?$/iu.test(e)||/^\d{4}\s+\d{1,2}$/u.test(e)}export function normalizeFieldLabel(e){return e.toLowerCase().replace(/[^a-z0-9\p{L}\p{N}]+/giu," ").trim()}function titleCaseLabel(e){if(/\p{Script=Han}/u.test(e))return e;const t=e.split(/[^A-Za-z0-9]+/u).filter(Boolean);return normalizeFieldLabel(e).split(" ").filter(Boolean).map((e,l)=>{const a=t[l]??e;return/^[A-Z0-9]{2,}$/u.test(a)?a:e.charAt(0).toUpperCase()+e.slice(1)}).join(" ")}function formatEvidence(e){const t=e.replace(/\s+/gu," ").trim();return t.length>1200?`${t.slice(0,1197)}...`:t}function escapeTableCell(e){return e.replace(/\|/gu,"\\|").replace(/\r?\n/gu," ")}function fieldKey(e){return`${e.source}\0${normalizeFieldLabel(e.label)}\0${e.value.toLowerCase()}`}
1
+ export function evidenceFields(e){const t=new Set,a=[];for(const l of e)for(const e of parseEvidenceFields(l)){const l=`${normalizeFieldLabel(e.label)}\0${e.value.toLowerCase()}`;t.has(l)||(t.add(l),a.push(e))}return a}export function selectSectionFields(e,t,a){return function withSourceCoverage(e,t){const a=[...e].sort((e,t)=>scoreField(t)-scoreField(e)),l=new Map;for(const e of[...new Set(a.map(e=>e.source))]){const t=a.find(t=>t.source===e);t&&l.set(fieldKey(t),t)}for(const e of a)if(l.set(fieldKey(e),e),l.size>=t)break;return[...l.values()].slice(0,t)}(e.filter(e=>e.kind===t),a).sort((e,t)=>scoreField(t)-scoreField(e)||e.label.localeCompare(t.label))}export function fieldTableLines(e,t){return 0===e.length?[]:[..."zh"===t?["| 项目 | 数值 | 来源 |","|---|---:|---|"]:["| Field | Value | Source |","|---|---:|---|"],...e.map(e=>`| ${escapeTableCell(e.label)} | ${escapeTableCell(e.value)} | ${escapeTableCell(function humanSourceLabel(e){const t=e.replace(/([a-z])([A-Z])/gu,"$1 $2").split(/[_:.\-\s]+/u).map(e=>e.trim()).filter(Boolean);return 0===t.length?e:t.map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}(e.source))} |`)]}export function hasExtractableFields(e){return extractKeyValueFields(e).some(e=>!isBoilerplateField(e.label)&&e.value.length>0)}export function classifyFact(e){return/(?:gap|blocked|missing|unavailable|unsupported|缺口|阻塞|缺失|不支持|无法|未提供)/iu.test(e)?"limit":/(?:news|headline|recent|latest|filing|event|公告|新闻|近期|最新|披露|\b20\d{2}[-/年])/iu.test(e)?"timeBound":/(?:[$€£¥%]|\b\d[\d,]*(?:\.\d+)?\b)/u.test(e)?"data":/(?:name|company|symbol|resolved|overview|query|名称|公司|代码|概览|识别)/iu.test(e)?"context":"other"}function parseEvidenceFields(e){return extractKeyValueFields(e.text).filter(e=>e.value.length>0&&!isBoilerplateField(e.label)).filter(e=>!function isLowValueField(e,t){return!!/(?:snapshot for|source type|loaded sources)/iu.test(e)||!!/^\d{1,2}\s+(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b/iu.test(e)||scoreField({source:"",label:e,value:t,kind:"other"})<0}(e.label,e.value)).map(t=>{const a=classifyFact(`${t.label}: ${t.value}`);return{source:e.source,label:titleCaseLabel(t.label),value:formatEvidence(t.value),kind:"other"===a?e.kind:a}})}function scoreField(e){const t=normalizeFieldLabel(e.label);let a=e.value.length>0?10:0;return/(?:price|value|amount|total|ratio|rate|range|target|estimate|revenue|income|earnings|margin|volume|date|rating|status|count|metric|价格|收入|利润|目标|评级|数量|日期|范围|比率)/iu.test(t)&&(a+=8),/(?:pe ratio|p b|market cap|book value|52 week range|day range|target estimate|revenue|net income|operating income|diluted eps)/iu.test(t)&&(a+=12),/(?:name|company|symbol|title|headline|summary|名称|公司|代码|标题|摘要)/iu.test(t)&&(a+=6),/(?:unix|epoch|timestamp|raw|html|url|href|source|id|identifier|internal|debug)/iu.test(t)&&(a-=20),/^(?:date|time|cik)$/iu.test(t)&&(a-=12),/^(?:open|high|low)$/iu.test(t)&&(a-=4),(/^https?:\/\//iu.test(e.value)||"/"===e.value)&&(a-=12),e.value.length>240&&(a-=5),a}function extractKeyValueFields(e){const t=[...e.matchAll(/(^|[\s;|])([\p{L}\p{N}][\p{L}\p{N} _./()%&+\-]{0,48})[::](?!\/\/)\s*/gu)].filter(e=>void 0!==e.index).map((e,t,a)=>{a[t-1];const l=function cleanFieldLabel(e){const t=e.replace(/^(?:[-*]\s*)+/u,"").replace(/\s+/gu," ").trim(),a=t.match(/^.+\b(PE Ratio TTM)$/iu);if(a?.[1]&&a[1]!==t&&/(?:beta|\b20\d{2}|\b(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b)/iu.test(t))return a[1];const l=t.split(" ").filter(Boolean);return l.length>1&&/^\d{4}$/u.test(l[0]??"")||l.length>1&&/^\d+(?:\.\d+)?$/u.test(l[0]??"")&&/^(?:\d+|beta|pe|p\/b)$/iu.test(l[1]??"")||l.length>1&&/^[A-Z]$/u.test(l[0]??"")||l.length>1&&/^(?:inc\.?|llc\.?|ltd\.?|corp\.?|corporation|co\.?)$/iu.test(l[0]??"")||l.length>1&&/^(?:usd|eur|gbp|jpy|cny|cad|aud)$/iu.test(l[0]??"")||l.length>1&&/^(?:gmt|utc)$/iu.test(l[0]??"")?l.slice(1).join(" "):function trailingKnownLabel(e){if(/\bPE Ratio TTM$/iu.test(e)&&!/^PE Ratio TTM$/iu.test(e))return"PE Ratio TTM";const t=e.match(/\b(?:Revenue|Net Income|Operating Income|Diluted EPS|EPS|Market Cap|Book Value|Target Estimate|Target Mean Price|Target Median Price|Target High Price|Target Low Price|PE Ratio TTM|P\/B|Beta(?: 5Y Monthly)?|Published|Updated|Date|Time|Summary|Title|Headline)$/iu);return t&&/(?:filed|\b20\d{2}|10-k|10-q|\bfy\b|\b(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b|\s{3,}|[a-z].{8,}\s)/iu.test(e.slice(0,t.index))?t?.[0]??e:e}(t)}(e[2]??""),i=function droppedLabelPrefix(e,t){const a=e.trim();if(a===t)return"";const l=a.toLowerCase().lastIndexOf(t.toLowerCase());return l>0?a.slice(0,l):""}(e[2]??"",l);return{index:(e.index??0)+String(e[1]??"").length+i.length,start:(e.index??0)+e[0].length,label:l,rawLabel:e[2]??""}}).filter(e=>!isBoundaryNoiseLabel(e.label)&&!isBoundaryNoiseLabel(e.rawLabel));return t.map((a,l)=>{const i=t[l+1]?.index??e.length;return{label:a.label,value:cleanFieldValue(e.slice(a.start,i),a.label)}}).filter(e=>e.label.length>0)}function cleanFieldValue(e,t){const a=e.replace(/^[\s,;|.-]+/u,"").replace(/[\s,;|.-]+$/u,"").replace(/\s+/gu," ").trim(),l=normalizeFieldLabel(t);if(/\brange\b/iu.test(l))return a.replace(/\s+Beta\b.*$/iu,"").trim();if(/^(?:ticker|symbol|resolved symbol|resolved ticker|股票 resolved ticker|代码)$/iu.test(l)){const e=a.match(/^([A-Z0-9._-]{1,24})(?:\s+\d+[.)]\s+|$)/u);if(e?.[1])return e[1]}return a}function isBoilerplateField(e){return/^(?:status|control status|evidence tool|tool|source|来源)$/iu.test(e.trim())}function isBoundaryNoiseLabel(e){return/^\d{1,2}\s+(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\b/iu.test(e)||/^(?:jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\s+\d{1,4}(?:\s+\d{1,2})?$/iu.test(e)||/^\d{4}\s+\d{1,2}$/u.test(e)}export function normalizeFieldLabel(e){return e.toLowerCase().replace(/[^a-z0-9\p{L}\p{N}]+/giu," ").trim()}function titleCaseLabel(e){if(/\p{Script=Han}/u.test(e))return e;const t=e.split(/[^A-Za-z0-9]+/u).filter(Boolean);return normalizeFieldLabel(e).split(" ").filter(Boolean).map((e,a)=>{const l=t[a]??e;return/^[A-Z0-9]{2,}$/u.test(l)?l:e.charAt(0).toUpperCase()+e.slice(1)}).join(" ")}function formatEvidence(e){const t=e.replace(/\s+/gu," ").trim();return t.length>1200?`${t.slice(0,1197)}...`:t}function escapeTableCell(e){return e.replace(/\|/gu,"\\|").replace(/\r?\n/gu," ")}function fieldKey(e){return`${e.source}\0${normalizeFieldLabel(e.label)}\0${e.value.toLowerCase()}`}
@@ -1 +1 @@
1
- import{controlBlockers as e,controlGaps as t,successfulEvidenceItems as n}from"./event-evidence.js";import{classifyFact as s,evidenceFields as r,fieldTableLines as o,hasExtractableFields as i,selectSectionFields as c}from"./synthesis/fields.js";import{detectSynthesisLanguage as u}from"./synthesis/language.js";import{observedResultLines as a}from"./synthesis/observed.js";export function synthesizeEvidenceOnlyReport(s,r,o){if(!o.enabled||!o.synthesis.enabled||"evidence_only"!==o.synthesis.mode)return;if("pass"===r.verdict||!function hasRecoverableSynthesisIssue(e){return e.issues.some(e=>"control_blocker"!==e.code)}(r))return;const i=n(s.events).slice(-o.synthesis.maxEvidenceItems),c=e(s.events),a=t(s.events);if(0===i.length&&0===c.length&&0===a.length)return;const l=function latestDelegatedReport(e){const t=e.filter(e=>"task"===e.source&&function looksLikeFinalReport(e){const t=e.trim();return!(t.length<80)&&(/^#{1,3}\s+\S/mu.test(t)||/\n#{1,3}\s+\S/mu.test(t)||/\n-{3,}\n/u.test(t))}(e.output)&&!function looksLikeCommentaryInsteadOfEvidence(e){const t=e.trim();return!(t.length>8e3)&&[/(?:这篇文章|this article)[\s\S]{0,1200}(?:我认为|我认同|打动我|值得深入探讨|特别认同|what I find|I think|I agree)/iu,/(?:你还有什么|还想深入探讨|would you like|do you want).{0,120}[??]\s*$/iu].some(e=>e.test(t))}(e.output)).at(-1)?.output.trim();return t||void 0}(i);return l||("zh"===u(s)?function buildChineseReport(e,t,n){const s=evidenceFacts(e);return["# 调查结果","","## 结论",...resultSummaryLines(e,s,t,n,"zh"),"","## 证据摘要",...summaryLines(e,t,n,"zh"),"",...structuredFactSections(s,"zh"),"","## 证据缺口与阻塞",...gapLines(t,n,"zh"),"","## 使用的证据来源",...sourceLines(sourceSummary(e),"zh")].join("\n")}(i,c,a):function buildEnglishReport(e,t,n){const s=evidenceFacts(e);return["# Result","","## Conclusion",...resultSummaryLines(e,s,t,n,"en"),"","## Evidence summary",...summaryLines(e,t,n,"en"),"",...structuredFactSections(s,"en"),"","## Evidence gaps and blockers",...gapLines(t,n,"en"),"","## Sources used",...sourceLines(sourceSummary(e),"en")].join("\n")}(i,c,a))}function resultSummaryLines(e,t,n,s,o){if(0===e.length)return["zh"===o?"- 没有成功证据可用于形成调查结论。":"- No successful evidence was available for a result."];const i=[...new Set(e.map(e=>humanSourceLabel(e.source)))],c=r(t),u=a(c,o),l=0===n.length&&0===s.length?"zh"===o?"未观察到运行时阻塞;未覆盖的业务、估值或风险细节不应视为已确认。":"No runtime blocker was observed; uncovered business, valuation, or risk details should not be treated as confirmed.":"zh"===o?`仍有 ${n.length+s.length} 个证据缺口或阻塞,结论应按部分调查读取。`:`${n.length+s.length} evidence gap(s) or blocker(s) remain, so read this as a partial result.`;return["zh"===o?`- 已基于 ${i.join("、")} 形成可交付结果。`:`- Result formed from ${i.join(", ")}.`,`- ${l}`,...u]}function sourceSummary(e){const t=new Map;for(const n of e){const e=t.get(n.source)??{source:n.source,count:0,facts:[]};e.count+=1,e.facts.push(...factLines(n.output)),t.set(n.source,e)}return[...t.values()].map(t=>({...t,facts:t.facts.length>0?t.facts.slice(0,8):[fallbackEvidenceText(evidenceTextForSource(e,t.source))]}))}function evidenceFacts(e){return e.flatMap(e=>{const t=factLines(e.output);return(t.length>0?t:[fallbackEvidenceText(e.output)]).map(t=>({source:e.source,text:t,kind:s(t)}))}).slice(0,40)}function summaryLines(e,t,n,s){if(0===e.length)return["zh"===s?"- 未观察到成功的工具或委托任务证据。":"- No successful tool or delegated-task evidence was observed."];const r=new Set(e.map(e=>e.source)).size,o=0===t.length&&0===n.length?"zh"===s?"未观察到未解决的运行时证据缺口或阻塞。":"No unresolved runtime evidence gaps or blockers were observed.":"zh"===s?`仍有 ${t.length+n.length} 个运行时证据缺口或阻塞。`:`${t.length+n.length} runtime evidence gaps or blockers remain.`;return["zh"===s?`- 已使用 ${e.length} 条完成证据,来自 ${r} 个来源。`:`- Used ${e.length} completed evidence item(s) from ${r} source(s).`,`- ${o}`]}function structuredFactSections(e,t){if(0===e.length)return["zh"===t?"- 证据缺口:没有可用于生成事实性结论的成功证据。":"- Evidence gap: no successful tool or delegated-task evidence was available."];const n=r(e);return[{kind:"context",title:"zh"===t?"## 已确认背景":"## Confirmed context"},{kind:"data",title:"zh"===t?"## 观察到的数据":"## Observed data points"},{kind:"timeBound",title:"zh"===t?"## 近期或时间相关证据":"## Recent or time-bound evidence"},{kind:"limit",title:"zh"===t?"## 证据限制":"## Evidence limits"},{kind:"other",title:"zh"===t?"## 其他观察":"## Additional observations"}].flatMap(s=>{const r=c(n,s.kind,12),u=e.filter(e=>e.kind===s.kind&&!i(e.text)).slice(0,5);return 0===r.length&&0===u.length?[]:[s.title,...o(r,t),...u.map(e=>function factLine(e,t){const n=humanSourceLabel(e.source);return"zh"===t?`- ${e.text}(来源:${n})`:`- ${e.text} (source: ${n})`}(e,t)),""]}).filter((e,t,n)=>""!==e||t<n.length-1)}function sourceLines(e,t){return 0===e.length?["zh"===t?"- 未使用成功证据来源。":"- No successful evidence source was used."]:e.map(e=>`- ${humanSourceLabel(e.source)}${e.count>1?` (${e.count})`:""}: ${e.source}`)}function gapLines(e,t,n){return 0===e.length&&0===t.length?["zh"===n?"- 未观察到未解决的运行时证据缺口或阻塞。":"- No unresolved runtime evidence gaps or blockers were observed."]:"zh"===n?[...e.map(e=>`- 阻塞:${e}`),...t.map(e=>`- 证据缺口:${e}`)]:[...e.map(e=>`- Blocked: ${e}`),...t.map(e=>`- Evidence gap: ${e}`)]}function formatEvidence(e){const t=e.replace(/\s+/gu," ").trim();return t.length>1200?`${t.slice(0,1197)}...`:t}function factLines(e){const t=function factLinesFromJson(e){try{const t=JSON.parse(e);return function isRecord(e){return"object"==typeof e&&null!==e&&!Array.isArray(e)}(t)?Object.entries(t).filter(([e])=>!/^(?:status|controlStatus)$/iu.test(e)).slice(0,8).map(([e,t])=>`${e}: ${formatEvidence(function stringifyJsonValue(e){return"string"==typeof e?e:JSON.stringify(e)}(t))}`):[]}catch{return[]}}(e);return t.length>0?t:function splitPlainTextFacts(e){const t=function stripControlPreamble(e){return e.replace(/^(?:Status:\s*(?:completed|success|ok|recorded)\b\.?\s*)+/iu,"").replace(/^(?:Evidence tool:\s*[A-Za-z0-9_.-]+\b\.?\s*)+/iu,"").trim()}(e);return t.split(/\r?\n|;\s*/u).map(e=>e.trim()).map(stripControlFragments).filter(e=>e&&!function isControlFact(e){return/^Status:\s*(?:completed|success|ok|recorded)$/iu.test(e)||/^Evidence tool:\s*[A-Za-z0-9_.-]+$/iu.test(e)}(e))}(e).slice(0,8).map(formatEvidence)}function stripControlFragments(e){return e.replace(/\bStatus:\s*(?:completed|success|ok|recorded)\b\.?\s*/giu,"").replace(/\bEvidence tool:\s*[A-Za-z0-9_.-]+\b\.?\s*/giu,"").trim()}function evidenceTextForSource(e,t){return e.find(e=>e.source===t)?.output??""}function fallbackEvidenceText(e){return formatEvidence(e)}function humanSourceLabel(e){const t=e.replace(/([a-z])([A-Z])/gu,"$1 $2").split(/[_:.\-\s]+/u).map(e=>e.trim()).filter(Boolean);return 0===t.length?e:t.map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}
1
+ import{controlBlockers as e,controlGaps as t,successfulEvidenceItems as n}from"./event-evidence.js";import{classifyFact as s,evidenceFields as r,fieldTableLines as o,hasExtractableFields as i,selectSectionFields as c}from"./synthesis/fields.js";import{detectSynthesisLanguage as u}from"./synthesis/language.js";import{observedResultLines as a}from"./synthesis/observed.js";export function synthesizeEvidenceOnlyReport(s,r,o){if(!o.enabled||!o.synthesis.enabled||"evidence_only"!==o.synthesis.mode)return;if("pass"===r.verdict||!function hasRecoverableSynthesisIssue(e){return e.issues.some(e=>"control_blocker"!==e.code)}(r))return;const i=n(s.events).slice(-o.synthesis.maxEvidenceItems),c=e(s.events),a=t(s.events);if(0===i.length&&0===c.length&&0===a.length)return;const l=function latestDelegatedReport(e){const t=e.filter(e=>"task"===e.source&&function looksLikeFinalReport(e){const t=e.trim();return!(t.length<80)&&(/^#{1,3}\s+\S/mu.test(t)||/\n#{1,3}\s+\S/mu.test(t)||/\n-{3,}\n/u.test(t))}(e.output)&&!function looksLikeCommentaryInsteadOfEvidence(e){const t=e.trim();return!(t.length>8e3)&&[/(?:这篇文章|this article)[\s\S]{0,1200}(?:我认为|我认同|打动我|值得深入探讨|特别认同|what I find|I think|I agree)/iu,/(?:你还有什么|还想深入探讨|would you like|do you want).{0,120}[??]\s*$/iu].some(e=>e.test(t))}(e.output)).at(-1)?.output.trim();return t||void 0}(i);return l||("zh"===u(s)?function buildChineseReport(e,t,n){const s=evidenceFacts(e);return["# 调查结果","","## 结论",...resultSummaryLines(e,s,t,n,"zh"),"","## 证据摘要",...summaryLines(e,t,n,"zh"),"",...structuredFactSections(s,"zh"),"","## 证据缺口与阻塞",...gapLines(t,n,"zh"),"","## 使用的证据来源",...sourceLines(sourceSummary(e),"zh")].join("\n")}(i,c,a):function buildEnglishReport(e,t,n){const s=evidenceFacts(e);return["# Result","","## Conclusion",...resultSummaryLines(e,s,t,n,"en"),"","## Evidence summary",...summaryLines(e,t,n,"en"),"",...structuredFactSections(s,"en"),"","## Evidence gaps and blockers",...gapLines(t,n,"en"),"","## Sources used",...sourceLines(sourceSummary(e),"en")].join("\n")}(i,c,a))}function resultSummaryLines(e,t,n,s,o){if(0===e.length)return["zh"===o?"- 没有成功证据可用于形成调查结论。":"- No successful evidence was available for a result."];const i=[...new Set(e.map(e=>humanSourceLabel(e.source)))],c=r(t),u=a(c,o),l=0===n.length&&0===s.length?"zh"===o?"未观察到运行时阻塞;未覆盖的业务、估值或风险细节不应视为已确认。":"No runtime blocker was observed; uncovered business, valuation, or risk details should not be treated as confirmed.":"zh"===o?`仍有 ${n.length+s.length} 个证据缺口或阻塞,结论应按部分调查读取。`:`${n.length+s.length} evidence gap(s) or blocker(s) remain, so read this as a partial result.`;return["zh"===o?`- 已基于 ${i.join("、")} 形成可交付结果。`:`- Result formed from ${i.join(", ")}.`,`- ${l}`,...u]}function sourceSummary(e){const t=new Map;for(const n of e){const e=t.get(n.source)??{source:n.source,count:0,facts:[]};e.count+=1,e.facts.push(...factLines(n.output)),t.set(n.source,e)}return[...t.values()].map(t=>({...t,facts:t.facts.length>0?t.facts.slice(0,8):[fallbackEvidenceText(evidenceTextForSource(e,t.source))]}))}function evidenceFacts(e){return e.flatMap(e=>{const t=factLines(e.output);return(t.length>0?t:[fallbackEvidenceText(e.output)]).map(t=>({source:e.source,text:t,kind:s(t)}))}).slice(0,40)}function summaryLines(e,t,n,s){if(0===e.length)return["zh"===s?"- 未观察到成功的工具或委托任务证据。":"- No successful tool or delegated-task evidence was observed."];const r=new Set(e.map(e=>e.source)).size,o=0===t.length&&0===n.length?"zh"===s?"未观察到未解决的运行时证据缺口或阻塞。":"No unresolved runtime evidence gaps or blockers were observed.":"zh"===s?`仍有 ${t.length+n.length} 个运行时证据缺口或阻塞。`:`${t.length+n.length} runtime evidence gaps or blockers remain.`;return["zh"===s?`- 已使用 ${e.length} 条完成证据,来自 ${r} 个来源。`:`- Used ${e.length} completed evidence item(s) from ${r} source(s).`,`- ${o}`]}function structuredFactSections(e,t){if(0===e.length)return["zh"===t?"- 证据缺口:没有可用于生成事实性结论的成功证据。":"- Evidence gap: no successful tool or delegated-task evidence was available."];const n=r(e);return[{kind:"context",title:"zh"===t?"## 已确认背景":"## Confirmed context"},{kind:"data",title:"zh"===t?"## 观察到的数据":"## Observed data points"},{kind:"timeBound",title:"zh"===t?"## 近期或时间相关证据":"## Recent or time-bound evidence"},{kind:"limit",title:"zh"===t?"## 证据限制":"## Evidence limits"},{kind:"other",title:"zh"===t?"## 其他观察":"## Additional observations"}].flatMap(s=>{const r=c(n,s.kind,12),u=e.filter(e=>e.kind===s.kind&&!i(e.text)).filter(e=>!function isLowValueTextFact(e){const t=e.trim();return/^https?:\/\/\S+$/iu.test(t)||/^source\s*:/iu.test(t)||/^来源\s*[::]/u.test(t)}(e.text)).slice(0,5);return 0===r.length&&0===u.length?[]:[s.title,...o(r,t),...u.map(e=>function factLine(e,t){const n=humanSourceLabel(e.source);return"zh"===t?`- ${e.text}(来源:${n})`:`- ${e.text} (source: ${n})`}(e,t)),""]}).filter((e,t,n)=>""!==e||t<n.length-1)}function sourceLines(e,t){return 0===e.length?["zh"===t?"- 未使用成功证据来源。":"- No successful evidence source was used."]:e.map(e=>`- ${humanSourceLabel(e.source)}${e.count>1?` (${e.count})`:""}: ${e.source}`)}function gapLines(e,t,n){return 0===e.length&&0===t.length?["zh"===n?"- 未观察到未解决的运行时证据缺口或阻塞。":"- No unresolved runtime evidence gaps or blockers were observed."]:"zh"===n?[...e.map(e=>`- 阻塞:${e}`),...t.map(e=>`- 证据缺口:${e}`)]:[...e.map(e=>`- Blocked: ${e}`),...t.map(e=>`- Evidence gap: ${e}`)]}function formatEvidence(e){const t=e.replace(/\s+/gu," ").trim();return t.length>1200?`${t.slice(0,1197)}...`:t}function factLines(e){const t=function factLinesFromJson(e){try{const t=JSON.parse(e);return function isRecord(e){return"object"==typeof e&&null!==e&&!Array.isArray(e)}(t)?Object.entries(t).filter(([e])=>!/^(?:status|controlStatus)$/iu.test(e)).slice(0,8).map(([e,t])=>`${e}: ${formatEvidence(function stringifyJsonValue(e){return"string"==typeof e?e:JSON.stringify(e)}(t))}`):[]}catch{return[]}}(e);return t.length>0?t:function splitPlainTextFacts(e){const t=function stripControlPreamble(e){return e.replace(/^(?:Status:\s*(?:completed|success|ok|recorded)\b\.?\s*)+/iu,"").replace(/^(?:Evidence tool:\s*[A-Za-z0-9_.-]+\b\.?\s*)+/iu,"").trim()}(e);return t.split(/\r?\n|;\s*/u).map(e=>e.trim()).map(stripControlFragments).map(normalizePlainFactLine).filter(e=>e&&!function isControlFact(e){return/^Status:\s*(?:completed|success|ok|recorded)$/iu.test(e)||/^Evidence tool:\s*[A-Za-z0-9_.-]+$/iu.test(e)}(e))}(e).slice(0,8).map(formatEvidence)}function stripControlFragments(e){return e.replace(/\bStatus:\s*(?:completed|success|ok|recorded)\b\.?\s*/giu,"").replace(/\bEvidence tool:\s*[A-Za-z0-9_.-]+\b\.?\s*/giu,"").trim()}function normalizePlainFactLine(e){if(/^https?:\/\//iu.test(e))return"";const t=e.match(/^\d+[.)]\s+(.+)$/u);return t?.[1]?`Headline: ${t[1]}`:e}function evidenceTextForSource(e,t){return e.find(e=>e.source===t)?.output??""}function fallbackEvidenceText(e){return formatEvidence(e)}function humanSourceLabel(e){const t=e.replace(/([a-z])([A-Z])/gu,"$1 $2").split(/[_:.\-\s]+/u).map(e=>e.trim()).filter(Boolean);return 0===t.length?e:t.map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}
@@ -10,7 +10,7 @@
10
10
  "exports": {
11
11
  ".": "./dist/index.js"
12
12
  },
13
- "dependencies": {
13
+ "peerDependencies": {
14
14
  "@botbotgo/better-call": "^0.1.58",
15
15
  "@stable-harness/governance": "0.0.1",
16
16
  "@stable-harness/memory": "0.0.1"
@@ -9,7 +9,7 @@
9
9
  ],
10
10
  "main": "dist/src/index.js",
11
11
  "types": "dist/src/index.d.ts",
12
- "dependencies": {
12
+ "peerDependencies": {
13
13
  "@stable-harness/core": "0.0.1"
14
14
  }
15
15
  }
@@ -9,7 +9,7 @@
9
9
  ],
10
10
  "main": "dist/src/index.js",
11
11
  "types": "dist/src/index.d.ts",
12
- "dependencies": {
12
+ "peerDependencies": {
13
13
  "@stable-harness/core": "0.0.1"
14
14
  }
15
15
  }
@@ -9,7 +9,7 @@
9
9
  ],
10
10
  "main": "dist/src/index.js",
11
11
  "types": "dist/src/index.d.ts",
12
- "dependencies": {
12
+ "peerDependencies": {
13
13
  "@botbotgo/better-call": "^0.1.58"
14
14
  }
15
15
  }
@@ -10,7 +10,7 @@
10
10
  "exports": {
11
11
  ".": "./dist/index.js"
12
12
  },
13
- "dependencies": {
13
+ "peerDependencies": {
14
14
  "@stable-harness/core": "0.0.1"
15
15
  }
16
16
  }