@bolloon/bolloon-agent 0.1.0 → 0.1.1

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 (431) hide show
  1. package/package.json +1 -1
  2. package/dist/constraint-runtime/tests/agent.test.js +0 -16
  3. package/dist/constraint-runtime/tests/constraint.test.js +0 -41
  4. package/dist/constraint-runtime/tests/skill.test.js +0 -19
  5. package/dist/constraint-runtime/tests/thinking.test.js +0 -22
  6. package/dist/electron-preload.js +0 -15
  7. package/dist/electron-preload.js.map +0 -1
  8. package/dist/electron.js +0 -206
  9. package/dist/electron.js.map +0 -1
  10. package/dist/test/constraint-layer.test.js +0 -164
  11. package/dist/test/global-shared-context.test.js +0 -315
  12. package/dist/test/pi-sdk.test.js +0 -47
  13. package/dist/test/set-persona.test.js +0 -38
  14. package/dist/test/subagent-manager.test.js +0 -276
  15. package/dist/test/workflow-engine.test.js +0 -87
  16. package/dist/workflows/collaboration.js +0 -374
  17. package/dist/workflows/index.js +0 -54
  18. package/docs/agent-communication.md +0 -333
  19. package/docs/plans/2026-05-15-document-agent-design.md +0 -479
  20. package/docs/plans/2026-05-15-document-agent-implementation-plan.md +0 -792
  21. package/docs/plans/2026-05-16-chat-ui-design.md +0 -86
  22. package/docs/plans/2026-05-16-constraint-runtime-design.md +0 -106
  23. package/docs/plans/2026-05-16-constraint-runtime-implementation.md +0 -441
  24. package/docs//346/225/260/345/255/246/350/276/205/345/212/251/346/231/272/350/203/275/344/275/223-/346/240/270/345/277/203/346/225/210/346/236/234/345/256/232/344/271/211.md +0 -287
  25. package/src/bollharness/.boll/CLAUDE.md.template +0 -34
  26. package/src/bollharness/.boll/MANIFEST.yaml +0 -213
  27. package/src/bollharness/.boll/active-review-agents/.gitkeep +0 -0
  28. package/src/bollharness/.boll/agents/review-base.yaml +0 -108
  29. package/src/bollharness/.boll/deploy-allowlist.yaml +0 -38
  30. package/src/bollharness/.boll/inbox/schema/message-v1.json +0 -99
  31. package/src/bollharness/.boll/install-staging/.gitkeep +0 -0
  32. package/src/bollharness/.boll/issue-adapter.yaml +0 -31
  33. package/src/bollharness/.boll/plugins/boll-mode-toolkit/contracts/mode-contract.md +0 -85
  34. package/src/bollharness/.boll/plugins/boll-review-toolkit/contracts/evidence-packet-schema.json +0 -102
  35. package/src/bollharness/.boll/plugins/boll-review-toolkit/contracts/review-contract.yaml +0 -247
  36. package/src/bollharness/.boll/rules/backend-routes.md +0 -31
  37. package/src/bollharness/.boll/rules/closure-semantics.md +0 -30
  38. package/src/bollharness/.boll/rules/env-vars.md +0 -32
  39. package/src/bollharness/.boll/rules/hanis-protocol.md +0 -145
  40. package/src/bollharness/.boll/rules/repo-structure.md +0 -42
  41. package/src/bollharness/.boll/rules/review-agent-isolation.md +0 -73
  42. package/src/bollharness/.boll/rules/source-of-truth.md +0 -33
  43. package/src/bollharness/.boll/settings.json +0 -180
  44. package/src/bollharness/.boll/settings.json.template +0 -31
  45. package/src/bollharness/.boll/skills/arch/SKILL.md +0 -372
  46. package/src/bollharness/.boll/skills/bug-pipeline/SKILL.md +0 -168
  47. package/src/bollharness/.boll/skills/bug-triage/SKILL.md +0 -161
  48. package/src/bollharness/.boll/skills/context-chains/SKILL.md +0 -250
  49. package/src/bollharness/.boll/skills/context-chains/context-chain-index.md +0 -48
  50. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/code_change_extractor.ts +0 -142
  51. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/debugging_extractor.ts +0 -126
  52. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/design_extractor.ts +0 -148
  53. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/planning_extractor.ts +0 -162
  54. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/question_extractor.ts +0 -116
  55. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/review_extractor.ts +0 -136
  56. package/src/bollharness/.boll/skills/crystal-learn/SKILL.md +0 -93
  57. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-0.md +0 -34
  58. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-1.md +0 -34
  59. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-2.md +0 -35
  60. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-3.md +0 -34
  61. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-4.md +0 -43
  62. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-5.md +0 -34
  63. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-6.md +0 -37
  64. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-7.md +0 -46
  65. package/src/bollharness/.boll/skills/guardian-fixer/PROMPT.md +0 -415
  66. package/src/bollharness/.boll/skills/guardian-fixer/SKILL.md +0 -320
  67. package/src/bollharness/.boll/skills/harness-dev/SKILL.md +0 -93
  68. package/src/bollharness/.boll/skills/harness-dev/examples/README.md +0 -227
  69. package/src/bollharness/.boll/skills/harness-dev-handoff/SKILL.md +0 -165
  70. package/src/bollharness/.boll/skills/harness-eng/SKILL.md +0 -110
  71. package/src/bollharness/.boll/skills/harness-eng-test/SKILL.md +0 -79
  72. package/src/bollharness/.boll/skills/harness-lab/SKILL.md +0 -170
  73. package/src/bollharness/.boll/skills/harness-ops/SKILL.md +0 -57
  74. package/src/bollharness/.boll/skills/harness-voice/SKILL.md +0 -183
  75. package/src/bollharness/.boll/skills/judgment/SKILL.md +0 -115
  76. package/src/bollharness/.boll/skills/lead/SKILL.md +0 -245
  77. package/src/bollharness/.boll/skills/lead/install-wow-harness.md +0 -77
  78. package/src/bollharness/.boll/skills/lead/ref-review-sop.md +0 -91
  79. package/src/bollharness/.boll/skills/lead/ref-stages.md +0 -129
  80. package/src/bollharness/.boll/skills/skill-discovery/SKILL.md +0 -169
  81. package/src/bollharness/.boll/skills/task-arch/SKILL.md +0 -106
  82. package/src/bollharness/.boll/skills/toolkit/SKILL.md +0 -57
  83. package/src/bollharness/.boll/tasks/.gitkeep +0 -0
  84. package/src/bollharness/.boll/toolkit-index.yaml +0 -112
  85. package/src/bollharness/.claude/agents/review-base.yaml +0 -108
  86. package/src/bollharness/.claude/plugins/boll-mode-toolkit/.claude-plugin/plugin.json +0 -44
  87. package/src/bollharness/.claude/plugins/boll-review-toolkit/.claude-plugin/plugin.json +0 -24
  88. package/src/bollharness/.claude/plugins/boll-review-toolkit/contracts/evidence-packet-schema.json +0 -102
  89. package/src/bollharness/.claude/plugins/boll-review-toolkit/contracts/review-contract.yaml +0 -247
  90. package/src/bollharness/.claude/settings.json +0 -157
  91. package/src/bollharness/.claude/skills/arch/SKILL.md +0 -64
  92. package/src/bollharness/.claude/skills/crystal-learn/SKILL.md +0 -93
  93. package/src/bollharness/.claude/skills/guardian-fixer/PROMPT.md +0 -44
  94. package/src/bollharness/.claude/skills/guardian-fixer/SKILL.md +0 -324
  95. package/src/bollharness/.claude/skills/harness-dev/SKILL.md +0 -93
  96. package/src/bollharness/.claude/skills/harness-dev/examples/README.md +0 -17
  97. package/src/bollharness/.claude/skills/harness-dev-handoff/SKILL.md +0 -165
  98. package/src/bollharness/.claude/skills/harness-eng/SKILL.md +0 -183
  99. package/src/bollharness/.claude/skills/harness-eng-test/SKILL.md +0 -57
  100. package/src/bollharness/.claude/skills/harness-ops/SKILL.md +0 -57
  101. package/src/bollharness/.claude/skills/harness-voice/SKILL.md +0 -84
  102. package/src/bollharness/.claude/skills/lead/INDEX.md +0 -28
  103. package/src/bollharness/.claude/skills/lead/SKILL.md +0 -24
  104. package/src/bollharness/.claude/skills/lead/install-wow-harness.md +0 -77
  105. package/src/bollharness/.claude/skills/lead/ref-review-sop.md +0 -48
  106. package/src/bollharness/.claude/skills/lead/ref-stages.md +0 -58
  107. package/src/bollharness/.claude/skills/plan-lock/SKILL.md +0 -74
  108. package/src/bollharness/.claude/skills/skill-discovery/SKILL.md +0 -120
  109. package/src/bollharness/.claude/skills/task-arch/SKILL.md +0 -106
  110. package/src/bollharness/.claude/skills/toolkit/SKILL.md +0 -57
  111. package/src/bollharness/.claude/skills/toolkit/list.sh +0 -92
  112. package/src/bollharness/.githooks/pre-commit +0 -21
  113. package/src/bollharness/.github/workflows/ci.yml +0 -88
  114. package/src/bollharness/CLAUDE.md +0 -73
  115. package/src/bollharness/README.md +0 -143
  116. package/src/bollharness/README.zh-CN.md +0 -131
  117. package/src/bollharness/docs/decisions/ADR-030-guard-signal-protocol-and-governance-reload.md +0 -1076
  118. package/src/bollharness/docs/decisions/ADR-038-harness-optimization-strategy.md +0 -2039
  119. package/src/bollharness/docs/decisions/ADR-041-codex-claude-code-division-of-labor.md +0 -128
  120. package/src/bollharness/docs/decisions/ADR-H1-crystal-learn-revival.md +0 -188
  121. package/src/bollharness/docs/decisions/ADR-H2-identity-isolation.md +0 -183
  122. package/src/bollharness/docs/decisions/ADR-H3-memory-scope.md +0 -133
  123. package/src/bollharness/docs/decisions/ADR-H4-prompt-governance.md +0 -146
  124. package/src/bollharness/docs/decisions/ADR-H5-gate-quantization.md +0 -212
  125. package/src/bollharness/docs/decisions/ADR-H6-state-file-health.md +0 -211
  126. package/src/bollharness/docs/decisions/ADR-H8-issue-and-doc-compliance.md +0 -202
  127. package/src/bollharness/docs/decisions/ADR-H9-mailbox.md +0 -231
  128. package/src/bollharness/docs/decisions/PLAN-H1-crystal-learn-revival.md +0 -270
  129. package/src/bollharness/docs/decisions/PLAN-H2-identity-isolation.md +0 -291
  130. package/src/bollharness/docs/decisions/PLAN-H3-memory-scope.md +0 -228
  131. package/src/bollharness/docs/decisions/PLAN-H4-prompt-governance.md +0 -227
  132. package/src/bollharness/docs/decisions/PLAN-H5-gate-quantization.md +0 -239
  133. package/src/bollharness/docs/decisions/PLAN-H6-state-file-health.md +0 -325
  134. package/src/bollharness/docs/decisions/PLAN-H8-issue-and-doc-compliance.md +0 -242
  135. package/src/bollharness/docs/decisions/PLAN-H9-mailbox.md +0 -378
  136. package/src/bollharness/docs/launch-article-en.md +0 -276
  137. package/src/bollharness/docs/launch-article-zh.md +0 -305
  138. package/src/bollharness/docs/practice.html +0 -356
  139. package/src/bollharness/docs/practice.md +0 -82
  140. package/src/bollharness/docs/research/round-1/README.md +0 -11
  141. package/src/bollharness/docs/research/round-2/README.md +0 -11
  142. package/src/bollharness/docs/research/round-3/README.md +0 -11
  143. package/src/bollharness/docs/research/round-4/README.md +0 -11
  144. package/src/bollharness/docs/research/round-5/README.md +0 -11
  145. package/src/bollharness/docs/research/round-6/README.md +0 -11
  146. package/src/bollharness/package-lock.json +0 -48
  147. package/src/bollharness/reference/boll-reference/.claude/rules/backend-routes.md +0 -268
  148. package/src/bollharness/reference/boll-reference/.claude/rules/bridge.md +0 -20
  149. package/src/bollharness/reference/boll-reference/.claude/rules/closure-semantics.md +0 -30
  150. package/src/bollharness/reference/boll-reference/.claude/rules/coaching.md +0 -13
  151. package/src/bollharness/reference/boll-reference/.claude/rules/env-vars.md +0 -50
  152. package/src/bollharness/reference/boll-reference/.claude/rules/hackathon.md +0 -12
  153. package/src/bollharness/reference/boll-reference/.claude/rules/repo-structure.md +0 -184
  154. package/src/bollharness/reference/boll-reference/.claude/rules/review-agent-isolation.md +0 -112
  155. package/src/bollharness/reference/boll-reference/.claude/rules/scenes.md +0 -12
  156. package/src/bollharness/reference/boll-reference/.claude/skills/arch/SKILL.md +0 -551
  157. package/src/bollharness/reference/boll-reference/.claude/skills/boll-animation/SKILL.md +0 -26
  158. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/SKILL.md +0 -227
  159. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/agents/openai.yaml +0 -4
  160. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/references/bridge-failure-taxonomy.md +0 -142
  161. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/references/bridge-validation-ladder.md +0 -107
  162. package/src/bollharness/reference/boll-reference/.claude/skills/boll-crystal/SKILL.md +0 -893
  163. package/src/bollharness/reference/boll-reference/.claude/skills/boll-crystal-learn/SKILL.md +0 -89
  164. package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev/SKILL.md +0 -93
  165. package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev/examples/README.md +0 -209
  166. package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev-handoff/SKILL.md +0 -165
  167. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng/SKILL.md +0 -110
  168. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-frontend/SKILL.md +0 -203
  169. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-hdc/SKILL.md +0 -27
  170. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-orchestrator/SKILL.md +0 -28
  171. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-prompt/SKILL.md +0 -27
  172. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-test/SKILL.md +0 -79
  173. package/src/bollharness/reference/boll-reference/.claude/skills/boll-lab/SKILL.md +0 -372
  174. package/src/bollharness/reference/boll-reference/.claude/skills/boll-run/SKILL.md +0 -437
  175. package/src/bollharness/reference/boll-reference/.claude/skills/boll-ux-appstore/SKILL.md +0 -27
  176. package/src/bollharness/reference/boll-reference/.claude/skills/boll-voice/SKILL.md +0 -442
  177. package/src/bollharness/reference/boll-reference/.claude/skills/guardian-fixer/PROMPT.md +0 -421
  178. package/src/bollharness/reference/boll-reference/.claude/skills/guardian-fixer/SKILL.md +0 -326
  179. package/src/bollharness/reference/boll-reference/.claude/skills/lead/SKILL.md +0 -155
  180. package/src/bollharness/reference/boll-reference/.claude/skills/lead/ref-review-sop.md +0 -91
  181. package/src/bollharness/reference/boll-reference/.claude/skills/lead/ref-stages.md +0 -129
  182. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-preview.png +0 -0
  183. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v2.png +0 -0
  184. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v3.png +0 -0
  185. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v4.png +0 -0
  186. package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/SKILL.md +0 -425
  187. package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/ref-three-checks.md +0 -62
  188. package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/ref-wp-templates.md +0 -78
  189. package/src/bollharness/reference/boll-reference/.claude/skills/task-arch/SKILL.md +0 -76
  190. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-graph/SKILL.md +0 -57
  191. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-graph/beads-graph.sh +0 -153
  192. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-init/SKILL.md +0 -52
  193. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-init/beads-auto-link.sh +0 -76
  194. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-sync/SKILL.md +0 -50
  195. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-sync/beads-sync-proj.sh +0 -108
  196. package/src/bollharness/reference/boll-reference/docs/architecture/AGENT-PROFILE.md +0 -151
  197. package/src/bollharness/reference/boll-reference/docs/architecture/COST-STRUCTURE.md +0 -56
  198. package/src/bollharness/reference/boll-reference/docs/architecture/INDEX.md +0 -76
  199. package/src/bollharness/reference/boll-reference/docs/architecture/MODULE1-INTENT-FIELD.md +0 -116
  200. package/src/bollharness/reference/boll-reference/docs/architecture/MODULE2-CRYSTALLIZATION.md +0 -200
  201. package/src/bollharness/reference/boll-reference/docs/architecture/PRINCIPLES.md +0 -84
  202. package/src/bollharness/reference/boll-reference/docs/architecture/PROTOCOL-CORE.md +0 -209
  203. package/src/bollharness/reference/boll-reference/docs/architecture/VISION.md +0 -181
  204. package/src/bollharness/reference/boll-reference/docs/architecture/discussions/D-01-MARKET-SCENE-PROTOCOL.md +0 -754
  205. package/src/bollharness/reference/boll-reference/scripts/hooks/stop-evaluator.md +0 -57
  206. package/src/bollharness/scripts/context-fragments/artifact-linkage.md +0 -14
  207. package/src/bollharness/scripts/context-fragments/auth-consumers.md +0 -17
  208. package/src/bollharness/scripts/context-fragments/bridge-constitution.md +0 -13
  209. package/src/bollharness/scripts/context-fragments/catalyst-distributed.md +0 -18
  210. package/src/bollharness/scripts/context-fragments/closure-checklist.md +0 -13
  211. package/src/bollharness/scripts/context-fragments/contract-consumers.md +0 -15
  212. package/src/bollharness/scripts/context-fragments/db-shared-structures.md +0 -15
  213. package/src/bollharness/scripts/context-fragments/fixed-three-layers.md +0 -19
  214. package/src/bollharness/scripts/context-fragments/general-dev-principles.md +0 -11
  215. package/src/bollharness/scripts/context-fragments/issue-first.md +0 -8
  216. package/src/bollharness/scripts/context-fragments/mcp-parity.md +0 -16
  217. package/src/bollharness/scripts/context-fragments/pi-agent-operations.md +0 -74
  218. package/src/bollharness/scripts/context-fragments/protocol-consumers.md +0 -15
  219. package/src/bollharness/scripts/context-fragments/run-events-consumers.md +0 -15
  220. package/src/bollharness/scripts/context-fragments/scene-fidelity.md +0 -13
  221. package/src/bollharness/scripts/context-fragments/truth-source-hierarchy.md +0 -15
  222. package/src/bollharness/scripts/context-fragments/two-language.md +0 -15
  223. package/src/bollharness/scripts/context-fragments/version-sources.md +0 -14
  224. package/src/bollharness/scripts/hooks/stop-evaluator.md +0 -83
  225. package/src/bollharness/templates/scaffold/.boll/guard/.gitkeep +0 -0
  226. package/src/bollharness/templates/scaffold/.boll/metrics/.gitkeep +0 -0
  227. package/src/bollharness/templates/scaffold/.boll/state/.gitkeep +0 -0
  228. package/src/bollharness/templates/scaffold/CLAUDE.md +0 -89
  229. package/src/bollharness/templates/scaffold/docs/INDEX.md +0 -3
  230. package/src/bollharness/templates/scaffold/docs/decisions/ADR_TEMPLATE.md +0 -38
  231. package/src/bollharness/templates/scaffold/docs/decisions/PLAN_TEMPLATE.md +0 -45
  232. package/src/bollharness/templates/scaffold/docs/decisions/tasks/.gitkeep +0 -2
  233. package/src/bollharness/templates/scaffold/docs/issues/.gitkeep +0 -0
  234. package/src/bollharness/templates/scaffold/docs/issues/GUARD_ISSUE_TEMPLATE.md +0 -35
  235. package/src/bollharness/templates/scaffold/docs/issues/ISSUE_TEMPLATE.md +0 -51
  236. package/src/bollharness/tsconfig.json +0 -26
  237. package/src/constraint-runtime/package-lock.json +0 -48
  238. package/src/constraint-runtime/package.json +0 -34
  239. package/src/constraint-runtime/src/_archive_helper.ts +0 -16
  240. package/src/constraint-runtime/src/agent/coordinator.ts +0 -71
  241. package/src/constraint-runtime/src/agent/index.ts +0 -1
  242. package/src/constraint-runtime/src/assistant/index.ts +0 -15
  243. package/src/constraint-runtime/src/bootstrap/index.ts +0 -15
  244. package/src/constraint-runtime/src/bootstrap_graph.ts +0 -17
  245. package/src/constraint-runtime/src/bridge/index.ts +0 -15
  246. package/src/constraint-runtime/src/buddy/index.ts +0 -15
  247. package/src/constraint-runtime/src/cli/index.ts +0 -15
  248. package/src/constraint-runtime/src/command_graph.ts +0 -20
  249. package/src/constraint-runtime/src/commands.ts +0 -83
  250. package/src/constraint-runtime/src/components/index.ts +0 -15
  251. package/src/constraint-runtime/src/constants/index.ts +0 -15
  252. package/src/constraint-runtime/src/constraint/budget.ts +0 -25
  253. package/src/constraint-runtime/src/constraint/index.ts +0 -3
  254. package/src/constraint-runtime/src/constraint/permission.ts +0 -28
  255. package/src/constraint-runtime/src/context.ts +0 -45
  256. package/src/constraint-runtime/src/coordinator/index.ts +0 -15
  257. package/src/constraint-runtime/src/cost_hook.ts +0 -6
  258. package/src/constraint-runtime/src/cost_tracker.ts +0 -9
  259. package/src/constraint-runtime/src/deferred_init.ts +0 -18
  260. package/src/constraint-runtime/src/direct_modes.ts +0 -13
  261. package/src/constraint-runtime/src/dynamic-tool-loader.ts +0 -115
  262. package/src/constraint-runtime/src/entrypoints/index.ts +0 -15
  263. package/src/constraint-runtime/src/execution_registry.ts +0 -41
  264. package/src/constraint-runtime/src/history.ts +0 -16
  265. package/src/constraint-runtime/src/hooks/index.ts +0 -15
  266. package/src/constraint-runtime/src/index.ts +0 -28
  267. package/src/constraint-runtime/src/ink.ts +0 -4
  268. package/src/constraint-runtime/src/keybindings/index.ts +0 -15
  269. package/src/constraint-runtime/src/memdir/index.ts +0 -15
  270. package/src/constraint-runtime/src/migrations/index.ts +0 -15
  271. package/src/constraint-runtime/src/models.ts +0 -49
  272. package/src/constraint-runtime/src/moreright/index.ts +0 -15
  273. package/src/constraint-runtime/src/native_ts/index.ts +0 -15
  274. package/src/constraint-runtime/src/output_styles/index.ts +0 -15
  275. package/src/constraint-runtime/src/parity_audit.ts +0 -23
  276. package/src/constraint-runtime/src/plugins/index.ts +0 -15
  277. package/src/constraint-runtime/src/port_manifest.ts +0 -20
  278. package/src/constraint-runtime/src/prefetch.ts +0 -17
  279. package/src/constraint-runtime/src/query.ts +0 -7
  280. package/src/constraint-runtime/src/reference_data/archive_surface_snapshot.json +0 -63
  281. package/src/constraint-runtime/src/reference_data/commands_snapshot.json +0 -1037
  282. package/src/constraint-runtime/src/reference_data/subsystems/OpenCLI.json +0 -10
  283. package/src/constraint-runtime/src/reference_data/subsystems/PolymarketSDK.json +0 -12
  284. package/src/constraint-runtime/src/reference_data/subsystems/SafeSDK.json +0 -14
  285. package/src/constraint-runtime/src/reference_data/subsystems/assistant.json +0 -8
  286. package/src/constraint-runtime/src/reference_data/subsystems/bootstrap.json +0 -8
  287. package/src/constraint-runtime/src/reference_data/subsystems/bridge.json +0 -32
  288. package/src/constraint-runtime/src/reference_data/subsystems/buddy.json +0 -13
  289. package/src/constraint-runtime/src/reference_data/subsystems/cli.json +0 -26
  290. package/src/constraint-runtime/src/reference_data/subsystems/components.json +0 -32
  291. package/src/constraint-runtime/src/reference_data/subsystems/constants.json +0 -28
  292. package/src/constraint-runtime/src/reference_data/subsystems/coordinator.json +0 -8
  293. package/src/constraint-runtime/src/reference_data/subsystems/entrypoints.json +0 -15
  294. package/src/constraint-runtime/src/reference_data/subsystems/hooks.json +0 -32
  295. package/src/constraint-runtime/src/reference_data/subsystems/keybindings.json +0 -21
  296. package/src/constraint-runtime/src/reference_data/subsystems/memdir.json +0 -15
  297. package/src/constraint-runtime/src/reference_data/subsystems/migrations.json +0 -18
  298. package/src/constraint-runtime/src/reference_data/subsystems/moreright.json +0 -8
  299. package/src/constraint-runtime/src/reference_data/subsystems/native_ts.json +0 -11
  300. package/src/constraint-runtime/src/reference_data/subsystems/outputStyles.json +0 -8
  301. package/src/constraint-runtime/src/reference_data/subsystems/plugins.json +0 -9
  302. package/src/constraint-runtime/src/reference_data/subsystems/remote.json +0 -11
  303. package/src/constraint-runtime/src/reference_data/subsystems/schemas.json +0 -8
  304. package/src/constraint-runtime/src/reference_data/subsystems/screens.json +0 -10
  305. package/src/constraint-runtime/src/reference_data/subsystems/server.json +0 -10
  306. package/src/constraint-runtime/src/reference_data/subsystems/services.json +0 -32
  307. package/src/constraint-runtime/src/reference_data/subsystems/skills.json +0 -27
  308. package/src/constraint-runtime/src/reference_data/subsystems/state.json +0 -13
  309. package/src/constraint-runtime/src/reference_data/subsystems/types.json +0 -18
  310. package/src/constraint-runtime/src/reference_data/subsystems/upstreamproxy.json +0 -9
  311. package/src/constraint-runtime/src/reference_data/subsystems/utils.json +0 -32
  312. package/src/constraint-runtime/src/reference_data/subsystems/vim.json +0 -12
  313. package/src/constraint-runtime/src/reference_data/subsystems/voice.json +0 -8
  314. package/src/constraint-runtime/src/reference_data/tools_snapshot.json +0 -1042
  315. package/src/constraint-runtime/src/remote/index.ts +0 -15
  316. package/src/constraint-runtime/src/remote_runtime.ts +0 -17
  317. package/src/constraint-runtime/src/runtime/index.ts +0 -1
  318. package/src/constraint-runtime/src/runtime/session.ts +0 -42
  319. package/src/constraint-runtime/src/schemas/index.ts +0 -15
  320. package/src/constraint-runtime/src/screens/index.ts +0 -15
  321. package/src/constraint-runtime/src/server/index.ts +0 -15
  322. package/src/constraint-runtime/src/services/index.ts +0 -15
  323. package/src/constraint-runtime/src/session_store.ts +0 -32
  324. package/src/constraint-runtime/src/setup.ts +0 -50
  325. package/src/constraint-runtime/src/skills/index.ts +0 -1
  326. package/src/constraint-runtime/src/skills/skill-registry.ts +0 -40
  327. package/src/constraint-runtime/src/state/index.ts +0 -15
  328. package/src/constraint-runtime/src/system_init.ts +0 -21
  329. package/src/constraint-runtime/src/thinking/engine.ts +0 -61
  330. package/src/constraint-runtime/src/thinking/index.ts +0 -1
  331. package/src/constraint-runtime/src/tool_pool.ts +0 -20
  332. package/src/constraint-runtime/src/tools/OpenCLI/execAdapter.ts +0 -12
  333. package/src/constraint-runtime/src/tools/OpenCLI/listAdapters.ts +0 -12
  334. package/src/constraint-runtime/src/tools/OpenCLI/runCommand.ts +0 -13
  335. package/src/constraint-runtime/src/tools/PolymarketSDK/cancelOrder.ts +0 -10
  336. package/src/constraint-runtime/src/tools/PolymarketSDK/createOrder.ts +0 -13
  337. package/src/constraint-runtime/src/tools/PolymarketSDK/getMarket.ts +0 -14
  338. package/src/constraint-runtime/src/tools/PolymarketSDK/getOrders.ts +0 -10
  339. package/src/constraint-runtime/src/tools/PolymarketSDK/listMarkets.ts +0 -24
  340. package/src/constraint-runtime/src/tools/SafeSDK/confirmTransaction.ts +0 -13
  341. package/src/constraint-runtime/src/tools/SafeSDK/createTransaction.ts +0 -23
  342. package/src/constraint-runtime/src/tools/SafeSDK/deploySafe.ts +0 -12
  343. package/src/constraint-runtime/src/tools/SafeSDK/executeTransaction.ts +0 -12
  344. package/src/constraint-runtime/src/tools/SafeSDK/getBalance.ts +0 -10
  345. package/src/constraint-runtime/src/tools/SafeSDK/getPendingTransactions.ts +0 -10
  346. package/src/constraint-runtime/src/tools/SafeSDK/proposeTransaction.ts +0 -14
  347. package/src/constraint-runtime/src/tools/WalletTools/autoPay.ts +0 -58
  348. package/src/constraint-runtime/src/tools/WalletTools/createWallet.ts +0 -19
  349. package/src/constraint-runtime/src/tools/WalletTools/getBalance.ts +0 -28
  350. package/src/constraint-runtime/src/tools/WalletTools/importWallet.ts +0 -34
  351. package/src/constraint-runtime/src/tools/WalletTools/sendTransaction.ts +0 -50
  352. package/src/constraint-runtime/src/tools/WalletTools/signMessage.ts +0 -23
  353. package/src/constraint-runtime/src/tools/WalletTools/transferToken.ts +0 -49
  354. package/src/constraint-runtime/src/tools.ts +0 -100
  355. package/src/constraint-runtime/src/transcript.ts +0 -23
  356. package/src/constraint-runtime/src/types/index.ts +0 -15
  357. package/src/constraint-runtime/src/upstream_proxy/index.ts +0 -15
  358. package/src/constraint-runtime/src/utils/index.ts +0 -15
  359. package/src/constraint-runtime/src/vim/index.ts +0 -15
  360. package/src/constraint-runtime/src/voice/index.ts +0 -15
  361. package/src/constraint-runtime/tests/agent.test.ts +0 -20
  362. package/src/constraint-runtime/tests/constraint.test.ts +0 -47
  363. package/src/constraint-runtime/tests/skill.test.ts +0 -23
  364. package/src/constraint-runtime/tests/thinking.test.ts +0 -28
  365. package/src/constraint-runtime/tsconfig.json +0 -13
  366. package/src/pi-ecosystem/index.ts +0 -453
  367. package/src/pi-ecosystem-colony/index.ts +0 -482
  368. package/src/pi-ecosystem-goals/index.ts +0 -585
  369. package/src/pi-ecosystem-judgment/decision.ts +0 -431
  370. package/src/pi-ecosystem-judgment/distillation.ts +0 -398
  371. package/src/pi-ecosystem-judgment/human-value-store.ts +0 -580
  372. package/src/pi-ecosystem-judgment/index.ts +0 -678
  373. package/src/pi-ecosystem-judgment/value-injection.ts +0 -744
  374. package/src/pi-ecosystem-mcp/index.ts +0 -427
  375. package/src/pi-ecosystem-subagents/index.ts +0 -408
  376. package/src/test/ai-judgment-test.ts +0 -92
  377. package/src/test/bollharness-integration.test.ts +0 -398
  378. package/src/test/channel-agent-multi-dialogue.ts +0 -265
  379. package/src/test/channel-heartbeat-agent-test.ts +0 -244
  380. package/src/test/constraint-layer.test.ts +0 -191
  381. package/src/test/diap-identity-test.ts +0 -222
  382. package/src/test/diap-quick-test.ts +0 -73
  383. package/src/test/global-shared-context.test.ts +0 -393
  384. package/src/test/harness-judgment-injection.test.ts +0 -353
  385. package/src/test/harness-workflow-integrator-test.ts +0 -285
  386. package/src/test/human-value-store.test.ts +0 -316
  387. package/src/test/hybrid-integration-test.ts +0 -126
  388. package/src/test/hybrid-messenger-verify.ts +0 -68
  389. package/src/test/iroh-bistream-debug.ts +0 -50
  390. package/src/test/iroh-communication.test.ts +0 -81
  391. package/src/test/iroh-debug-test.ts +0 -69
  392. package/src/test/iroh-diap-test.ts +0 -90
  393. package/src/test/iroh-direct-connect.ts +0 -65
  394. package/src/test/iroh-e2e-fixed.ts +0 -106
  395. package/src/test/iroh-e2e-same-process.ts +0 -83
  396. package/src/test/iroh-e2e.ts +0 -83
  397. package/src/test/iroh-final-e2e.ts +0 -84
  398. package/src/test/iroh-relay-test.ts +0 -46
  399. package/src/test/iroh-simple-test.ts +0 -49
  400. package/src/test/iroh-transport-verify.ts +0 -60
  401. package/src/test/iroh-transport.test.ts +0 -47
  402. package/src/test/iroh-two-nodes.ts +0 -87
  403. package/src/test/iroh-verify.ts +0 -55
  404. package/src/test/judgment-decision.test.ts +0 -373
  405. package/src/test/llm-judgment-integration.test.ts +0 -257
  406. package/src/test/p2p-agent-complex-dialogue.ts +0 -490
  407. package/src/test/p2p-agent-dialogue.ts +0 -423
  408. package/src/test/p2p-agent-full-bidirectional.ts +0 -686
  409. package/src/test/p2p-agent-harness-flow.ts +0 -562
  410. package/src/test/p2p-agent-harness-single.ts +0 -175
  411. package/src/test/p2p-ai-dialogue-test.ts +0 -374
  412. package/src/test/p2p-cid-connect-test.ts +0 -245
  413. package/src/test/p2p-connect-receiver.ts +0 -85
  414. package/src/test/p2p-iroh-test.ts +0 -214
  415. package/src/test/p2p-minimal-test.ts +0 -264
  416. package/src/test/p2p-node-1.ts +0 -172
  417. package/src/test/p2p-node-2.ts +0 -172
  418. package/src/test/p2p-server.ts +0 -335
  419. package/src/test/p2p-two-nodes-test.ts +0 -542
  420. package/src/test/pi-sdk.test.ts +0 -47
  421. package/src/test/set-persona.ts +0 -56
  422. package/src/test/simple.test.ts +0 -11
  423. package/src/test/storage-integration.test.ts +0 -191
  424. package/src/test/subagent-manager.test.ts +0 -392
  425. package/src/test/test-gate-flow.test.ts +0 -92
  426. package/src/test/workflow-engine.test.ts +0 -101
  427. package/src/web/design.md +0 -99
  428. package/src/workflows/collaboration.ts +0 -455
  429. package/src/workflows/index.ts +0 -64
  430. package/vitest.config.ts +0 -12
  431. package//346/203/263/346/263/225.md +0 -79
@@ -1,580 +0,0 @@
1
- /**
2
- * Human Value Store - 存储人类判断价值观的机制
3
- *
4
- * 核心概念:
5
- * - 人类判断不是规则,而是价值观表达
6
- * - 价值观通过具体决策体现,而非抽象陈述
7
- * - 存储结构化的人类决策,用于价值注入
8
- *
9
- * 存储格式:
10
- * - decision: 具体决策内容
11
- * - reason: 决策理由(价值观体现)
12
- * - context: 决策场景
13
- * - outcome: 决策结果
14
- * - values: 提取的价值观标签
15
- */
16
-
17
- import * as fs from 'fs/promises';
18
- import * as path from 'path';
19
-
20
- export interface ValueTag {
21
- category: 'quality' | 'efficiency' | 'safety' | 'collaboration' | 'learning' | 'priorities';
22
- value: string;
23
- weight: number; // 0-1, 这个价值观的重要性
24
- }
25
-
26
- export interface HumanJudgment {
27
- id: string;
28
- timestamp: string;
29
-
30
- // 决策内容
31
- decision: string;
32
- decision_type: 'approve' | 'reject' | 'modify' | 'escalate';
33
-
34
- // 决策理由(核心)
35
- reasons: string[];
36
- values_derived: ValueTag[];
37
-
38
- // 上下文
39
- context: {
40
- domain: string; // 代码/架构/安全/测试等
41
- complexity: 'simple' | 'moderate' | 'complex' | 'profound';
42
- stakes: 'low' | 'medium' | 'high' | 'critical';
43
- time_pressure: 'low' | 'medium' | 'high';
44
- };
45
-
46
- // 结果
47
- outcome?: {
48
- approved: boolean;
49
- feedback?: string;
50
- revised?: boolean;
51
- };
52
-
53
- // 元数据
54
- metadata: {
55
- source: 'explicit' | 'implicit' | 'trajectory';
56
- confidence: number;
57
- revisable: boolean;
58
- };
59
- }
60
-
61
- export interface ValueProfile {
62
- agent_id: string;
63
- decision_count: number;
64
-
65
- // 价值观分布
66
- quality_focus: number; // 对质量的重视程度
67
- efficiency_focus: number; // 对效率的重视程度
68
- safety_focus: number; // 对安全的重视程度
69
- collaboration_focus: number; // 对协作的重视程度
70
- learning_focus: number; // 对学习的重视程度
71
-
72
- // 优先级模式
73
- priority_rules: PriorityRule[];
74
-
75
- // 典型决策模式
76
- decision_patterns: DecisionPattern[];
77
-
78
- // 偏好
79
- preferences: ValuePreference[];
80
-
81
- last_updated: string;
82
- }
83
-
84
- export interface PriorityRule {
85
- when: string; // 条件描述
86
- prefer: string; // 偏好选择
87
- reason: string; // 理由
88
- weight: number; // 优先级权重
89
- }
90
-
91
- export interface DecisionPattern {
92
- pattern: string; // 模式描述
93
- description: string;
94
- frequency: number;
95
- success_rate: number;
96
- }
97
-
98
- export interface ValuePreference {
99
- dimension: string;
100
- preference: string;
101
- evidence_count: number;
102
- }
103
-
104
- const VALUE_STORE_DIR = path.join(process.env.HOME || '/tmp', '.bolloon', 'human-values');
105
- const JUDGMENTS_FILE = path.join(VALUE_STORE_DIR, 'judgments.json');
106
-
107
- // In-memory cache
108
- let judgmentCache: HumanJudgment[] = [];
109
- let valueProfileCache: Map<string, ValueProfile> = new Map();
110
- let initialized = false;
111
-
112
- function generateId(): string {
113
- return `hv-${Date.now()}-${Math.random().toString(36).substring(2, 8)}`;
114
- }
115
-
116
- // ============================================================
117
- // 存储操作
118
- // ============================================================
119
-
120
- /**
121
- * 初始化存储(创建目录和空文件)
122
- */
123
- export async function initializeValueStore(): Promise<void> {
124
- if (initialized) return;
125
-
126
- try {
127
- await fs.mkdir(VALUE_STORE_DIR, { recursive: true });
128
-
129
- try {
130
- await fs.access(JUDGMENTS_FILE);
131
- } catch {
132
- await fs.writeFile(JUDGMENTS_FILE, JSON.stringify([], null, 2), 'utf-8');
133
- }
134
-
135
- initialized = true;
136
- console.log('[HumanValueStore] Initialized at', VALUE_STORE_DIR);
137
- } catch (error) {
138
- console.error('[HumanValueStore] Initialization failed:', error);
139
- throw error;
140
- }
141
- }
142
-
143
- /**
144
- * 存储人类判断
145
- */
146
- export async function storeHumanJudgment(judgment: Omit<HumanJudgment, 'id' | 'timestamp'>): Promise<HumanJudgment> {
147
- const fullJudgment: HumanJudgment = {
148
- ...judgment,
149
- id: generateId(),
150
- timestamp: new Date().toISOString()
151
- };
152
-
153
- // 加载现有判断
154
- const judgments = await loadAllJudgments();
155
- judgments.push(fullJudgment);
156
-
157
- // 保存
158
- await saveJudgments(judgments);
159
-
160
- // 更新价值画像
161
- await updateValueProfile(fullJudgment);
162
-
163
- console.log(`[HumanValueStore] Stored judgment ${fullJudgment.id}: ${fullJudgment.decision.substring(0, 50)}...`);
164
- return fullJudgment;
165
- }
166
-
167
- /**
168
- * 从决策结果学习(轨迹学习)
169
- */
170
- export async function learnFromTrajectory(trajectory: {
171
- situation: string;
172
- chosen_action: string;
173
- rejected_alternatives?: string[];
174
- outcome: string;
175
- approved: boolean;
176
- }): Promise<HumanJudgment> {
177
- // 提取价值观
178
- const values = extractValuesFromTrajectory(trajectory);
179
-
180
- return storeHumanJudgment({
181
- decision: trajectory.chosen_action,
182
- decision_type: trajectory.approved ? 'approve' : 'reject',
183
- reasons: [trajectory.outcome],
184
- values_derived: values,
185
- context: inferContext(trajectory.situation),
186
- outcome: {
187
- approved: trajectory.approved,
188
- feedback: trajectory.outcome
189
- },
190
- metadata: {
191
- source: 'trajectory',
192
- confidence: trajectory.approved ? 0.9 : 0.7,
193
- revisable: true
194
- }
195
- });
196
- }
197
-
198
- /**
199
- * 从批准/拒绝学习
200
- */
201
- export async function learnFromFeedback(
202
- action: string,
203
- approved: boolean,
204
- reason?: string
205
- ): Promise<HumanJudgment> {
206
- return storeHumanJudgment({
207
- decision: action,
208
- decision_type: approved ? 'approve' : 'reject',
209
- reasons: reason ? [reason] : [],
210
- values_derived: approved ? inferPositiveValues(action) : inferNegativeValues(action),
211
- context: inferContext(action),
212
- outcome: { approved },
213
- metadata: {
214
- source: 'explicit',
215
- confidence: 0.8,
216
- revisable: true
217
- }
218
- });
219
- }
220
-
221
- /**
222
- * 从建议修正学习
223
- */
224
- export async function learnFromCorrection(
225
- original: string,
226
- corrected: string,
227
- reason: string
228
- ): Promise<HumanJudgment> {
229
- return storeHumanJudgment({
230
- decision: corrected,
231
- decision_type: 'modify',
232
- reasons: [reason],
233
- values_derived: extractValuesFromCorrection(original, corrected),
234
- context: inferContext(original),
235
- outcome: { approved: true, revised: true },
236
- metadata: {
237
- source: 'trajectory',
238
- confidence: 0.85,
239
- revisable: false
240
- }
241
- });
242
- }
243
-
244
- // ============================================================
245
- // 读取操作
246
- // ============================================================
247
-
248
- /**
249
- * 加载所有人类判断
250
- */
251
- export async function loadAllJudgments(): Promise<HumanJudgment[]> {
252
- if (!initialized) {
253
- await initializeValueStore();
254
- }
255
-
256
- if (judgmentCache.length > 0) {
257
- return [...judgmentCache];
258
- }
259
-
260
- try {
261
- const content = await fs.readFile(JUDGMENTS_FILE, 'utf-8');
262
- judgmentCache = JSON.parse(content);
263
- return judgmentCache;
264
- } catch {
265
- judgmentCache = [];
266
- return [];
267
- }
268
- }
269
-
270
- /**
271
- * 获取相关价值观
272
- * 将 context 拆分为关键词,任意一个匹配即可
273
- */
274
- export async function getRelevantValues(context: string, domain?: string): Promise<ValueTag[]> {
275
- const judgments = await loadAllJudgments();
276
-
277
- const keywords = context.split(/[\s,,、]+/).filter(k => k.length >= 2);
278
- const contextLower = context.toLowerCase();
279
-
280
- const relevant = judgments.filter(j => {
281
- if (domain && j.context.domain !== domain) return false;
282
-
283
- if (keywords.length === 0) {
284
- return j.decision.toLowerCase().includes(contextLower) ||
285
- j.reasons.some(r => r.toLowerCase().includes(contextLower));
286
- }
287
-
288
- const decisionLower = j.decision.toLowerCase();
289
- const reasonsLower = j.reasons.map(r => r.toLowerCase());
290
-
291
- return keywords.some(kw => {
292
- const kwLower = kw.toLowerCase();
293
- return decisionLower.includes(kwLower) ||
294
- reasonsLower.some(r => r.includes(kwLower));
295
- });
296
- });
297
-
298
- const valueMap: Map<string, { tag: ValueTag; count: number }> = new Map();
299
-
300
- for (const j of relevant) {
301
- for (const v of j.values_derived) {
302
- const key = `${v.category}:${v.value}`;
303
- const existing = valueMap.get(key);
304
- if (existing) {
305
- existing.count++;
306
- existing.tag.weight = Math.min(1, existing.tag.weight + 0.1);
307
- } else {
308
- valueMap.set(key, { tag: { ...v }, count: 1 });
309
- }
310
- }
311
- }
312
-
313
- return Array.from(valueMap.values())
314
- .map(({ tag, count }) => ({
315
- ...tag,
316
- weight: tag.weight * Math.min(1, count / 3)
317
- }))
318
- .sort((a, b) => b.weight - a.weight)
319
- .slice(0, 10);
320
- }
321
-
322
- /**
323
- * 获取价值画像
324
- */
325
- export async function getValueProfile(agentId: string): Promise<ValueProfile> {
326
- if (valueProfileCache.has(agentId)) {
327
- return valueProfileCache.get(agentId)!;
328
- }
329
-
330
- const judgments = await loadAllJudgments();
331
- const agentJudgments = judgments.filter(j =>
332
- j.metadata.source !== 'trajectory' || j.id.includes(agentId)
333
- );
334
-
335
- const profile = buildValueProfile(agentId, agentJudgments);
336
- valueProfileCache.set(agentId, profile);
337
- return profile;
338
- }
339
-
340
- /**
341
- * 获取优先级规则
342
- */
343
- export async function getPriorityRules(): Promise<PriorityRule[]> {
344
- const judgments = await loadAllJudgments();
345
-
346
- const seen = new Set<string>();
347
- return judgments
348
- .filter(j => {
349
- if (j.metadata.confidence <= 0.7) return false;
350
- const key = `${j.context.domain}:${j.decision}`;
351
- if (seen.has(key)) return false;
352
- seen.add(key);
353
- return true;
354
- })
355
- .map(j => ({
356
- when: j.context.domain,
357
- prefer: j.decision,
358
- reason: j.reasons[0] || 'No reason provided',
359
- weight: j.metadata.confidence
360
- }))
361
- .slice(0, 20);
362
- }
363
-
364
- // ============================================================
365
- // 私有函数
366
- // ============================================================
367
-
368
- async function saveJudgments(judgments: HumanJudgment[]): Promise<void> {
369
- await fs.mkdir(VALUE_STORE_DIR, { recursive: true });
370
- await fs.writeFile(JUDGMENTS_FILE, JSON.stringify(judgments, null, 2), 'utf-8');
371
- }
372
-
373
- function buildValueProfile(agentId: string, judgments: HumanJudgment[]): ValueProfile {
374
- const profile: ValueProfile = {
375
- agent_id: agentId,
376
- decision_count: judgments.length,
377
- quality_focus: 0.5,
378
- efficiency_focus: 0.5,
379
- safety_focus: 0.5,
380
- collaboration_focus: 0.5,
381
- learning_focus: 0.5,
382
- priority_rules: [],
383
- decision_patterns: [],
384
- preferences: [],
385
- last_updated: new Date().toISOString()
386
- };
387
-
388
- // 计算各维度权重
389
- const dimensionCounts: Record<string, number> = {};
390
-
391
- for (const j of judgments) {
392
- for (const v of j.values_derived) {
393
- dimensionCounts[`${v.category}_${v.value}`] =
394
- (dimensionCounts[`${v.category}_${v.value}`] || 0) + v.weight;
395
- }
396
- }
397
-
398
- // 更新各维度分数
399
- for (const [key, weight] of Object.entries(dimensionCounts)) {
400
- const [category] = key.split('_');
401
- const dimensionKey = `${category}_focus` as keyof ValueProfile;
402
- if (dimensionKey in profile) {
403
- (profile as Record<string, unknown>)[dimensionKey] = Math.min(1, weight / judgments.length);
404
- }
405
- }
406
-
407
- // 提取决策模式
408
- const patternMap: Map<string, number> = new Map();
409
- for (const j of judgments) {
410
- const pattern = j.decision_type;
411
- patternMap.set(pattern, (patternMap.get(pattern) || 0) + 1);
412
- }
413
-
414
- for (const [pattern, count] of patternMap) {
415
- profile.decision_patterns.push({
416
- pattern,
417
- description: `Tendency to ${pattern}`,
418
- frequency: count,
419
- success_rate: judgments.filter(j => j.decision_type === pattern && j.outcome?.approved).length / count
420
- });
421
- }
422
-
423
- // 提取优先级规则
424
- profile.priority_rules = judgments
425
- .filter(j => j.metadata.confidence > 0.8)
426
- .map(j => ({
427
- when: j.context.domain,
428
- prefer: j.decision,
429
- reason: j.reasons[0] || '',
430
- weight: j.metadata.confidence
431
- }));
432
-
433
- return profile;
434
- }
435
-
436
- async function updateValueProfile(judgment: HumanJudgment): Promise<void> {
437
- // 简单更新:标记缓存需要刷新
438
- valueProfileCache.clear();
439
- }
440
-
441
- function extractValuesFromTrajectory(trajectory: {
442
- situation: string;
443
- chosen_action: string;
444
- outcome: string;
445
- approved: boolean;
446
- }): ValueTag[] {
447
- const values: ValueTag[] = [];
448
- const action = trajectory.chosen_action.toLowerCase();
449
- const outcome = trajectory.outcome.toLowerCase();
450
-
451
- // 从行动推断价值观
452
- if (action.includes('review') || action.includes('检查') || action.includes('验证')) {
453
- values.push({ category: 'quality', value: 'code-review', weight: 0.8 });
454
- }
455
- if (action.includes('test') || action.includes('测试')) {
456
- values.push({ category: 'quality', value: 'testing', weight: 0.8 });
457
- }
458
- if (action.includes('security') || action.includes('安全')) {
459
- values.push({ category: 'safety', value: 'security-first', weight: 0.9 });
460
- }
461
- if (action.includes('refactor') || action.includes('重构')) {
462
- values.push({ category: 'quality', value: 'maintainability', weight: 0.7 });
463
- }
464
- if (action.includes('simple') || action.includes('简单')) {
465
- values.push({ category: 'efficiency', value: 'simplicity', weight: 0.8 });
466
- }
467
-
468
- // 从结果推断价值观
469
- if (outcome.includes('success') || outcome.includes('成功')) {
470
- values.push({ category: 'learning', value: 'success-validation', weight: 0.6 });
471
- }
472
- if (outcome.includes('fail') || outcome.includes('失败')) {
473
- values.push({ category: 'learning', value: 'failure-learning', weight: 0.7 });
474
- }
475
-
476
- return values.length > 0 ? values : [{ category: 'quality', value: 'general', weight: 0.5 }];
477
- }
478
-
479
- function inferContext(action: string): HumanJudgment['context'] {
480
- const actionLower = action.toLowerCase();
481
-
482
- let domain = 'general';
483
- if (actionLower.includes('code') || actionLower.includes('代码')) domain = 'code';
484
- else if (actionLower.includes('arch') || actionLower.includes('架构')) domain = 'architecture';
485
- else if (actionLower.includes('security') || actionLower.includes('安全')) domain = 'security';
486
- else if (actionLower.includes('test') || actionLower.includes('测试')) domain = 'testing';
487
-
488
- let complexity: HumanJudgment['context']['complexity'] = 'moderate';
489
- if (actionLower.includes('simple') || action.length < 50) complexity = 'simple';
490
- if (actionLower.includes('complex') || action.length > 200) complexity = 'complex';
491
-
492
- return {
493
- domain,
494
- complexity,
495
- stakes: 'medium',
496
- time_pressure: 'low'
497
- };
498
- }
499
-
500
- function inferPositiveValues(action: string): ValueTag[] {
501
- return extractValuesFromTrajectory({
502
- situation: action,
503
- chosen_action: action,
504
- outcome: 'approved',
505
- approved: true
506
- });
507
- }
508
-
509
- function inferNegativeValues(action: string): ValueTag[] {
510
- return extractValuesFromTrajectory({
511
- situation: action,
512
- chosen_action: action,
513
- outcome: 'rejected',
514
- approved: false
515
- }).map(v => ({ ...v, weight: v.weight * 0.5 }));
516
- }
517
-
518
- function extractValuesFromCorrection(original: string, corrected: string): ValueTag[] {
519
- const values: ValueTag[] = [];
520
-
521
- // 检测修正类型
522
- if (corrected.includes('security') || corrected.includes('安全')) {
523
- values.push({ category: 'safety', value: 'security-fix', weight: 0.9 });
524
- }
525
- if (corrected.includes('test') && !original.includes('test')) {
526
- values.push({ category: 'quality', value: 'add-testing', weight: 0.8 });
527
- }
528
- if (corrected.length < original.length) {
529
- values.push({ category: 'efficiency', value: 'simplification', weight: 0.7 });
530
- }
531
-
532
- return values.length > 0 ? values : [{ category: 'quality', value: 'general-fix', weight: 0.6 }];
533
- }
534
-
535
- // ============================================================
536
- // 统计
537
- // ============================================================
538
-
539
- export async function getValueStats(): Promise<{
540
- total_judgments: number;
541
- by_type: Record<string, number>;
542
- by_source: Record<string, number>;
543
- top_values: ValueTag[];
544
- }> {
545
- const judgments = await loadAllJudgments();
546
-
547
- const byType: Record<string, number> = {};
548
- const bySource: Record<string, number> = {};
549
- const valueCounts: Map<string, number> = new Map();
550
-
551
- for (const j of judgments) {
552
- byType[j.decision_type] = (byType[j.decision_type] || 0) + 1;
553
- bySource[j.metadata.source] = (bySource[j.metadata.source] || 0) + 1;
554
-
555
- for (const v of j.values_derived) {
556
- const key = `${v.category}:${v.value}`;
557
- valueCounts.set(key, (valueCounts.get(key) || 0) + 1);
558
- }
559
- }
560
-
561
- const topValues: ValueTag[] = Array.from(valueCounts.entries())
562
- .map(([key, count]) => {
563
- const [category, value] = key.split(':');
564
- return { category: category as ValueTag['category'], value, weight: count };
565
- })
566
- .sort((a, b) => b.weight - a.weight)
567
- .slice(0, 10);
568
-
569
- return {
570
- total_judgments: judgments.length,
571
- by_type: byType,
572
- by_source: bySource,
573
- top_values: topValues
574
- };
575
- }
576
-
577
- export function clearCache(): void {
578
- judgmentCache = [];
579
- valueProfileCache.clear();
580
- }