@cleocode/core 2026.4.12 → 2026.4.14

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 (924) hide show
  1. package/dist/index.js +69233 -175
  2. package/dist/index.js.map +7 -1
  3. package/dist/init.d.ts.map +1 -1
  4. package/dist/internal.d.ts +16 -5
  5. package/dist/internal.d.ts.map +1 -1
  6. package/dist/memory/brain-embedding.d.ts +1 -1
  7. package/dist/memory/embedding-local.d.ts +8 -3
  8. package/dist/memory/embedding-local.d.ts.map +1 -1
  9. package/dist/memory/embedding-worker.d.ts +1 -1
  10. package/dist/memory/learnings.d.ts +2 -2
  11. package/dist/memory/patterns.d.ts +6 -6
  12. package/dist/store/agent-registry-accessor.d.ts +54 -1
  13. package/dist/store/agent-registry-accessor.d.ts.map +1 -1
  14. package/dist/store/backup-crypto.d.ts +89 -0
  15. package/dist/store/backup-crypto.d.ts.map +1 -0
  16. package/dist/store/backup-pack.d.ts +91 -0
  17. package/dist/store/backup-pack.d.ts.map +1 -0
  18. package/dist/store/backup-unpack.d.ts +140 -0
  19. package/dist/store/backup-unpack.d.ts.map +1 -0
  20. package/dist/store/migrate-signaldock-to-conduit.d.ts.map +1 -1
  21. package/dist/store/regenerators.d.ts +126 -0
  22. package/dist/store/regenerators.d.ts.map +1 -0
  23. package/dist/store/restore-conflict-report.d.ts +118 -0
  24. package/dist/store/restore-conflict-report.d.ts.map +1 -0
  25. package/dist/store/restore-json-merge.d.ts +187 -0
  26. package/dist/store/restore-json-merge.d.ts.map +1 -0
  27. package/dist/store/sqlite-backup.d.ts +60 -5
  28. package/dist/store/sqlite-backup.d.ts.map +1 -1
  29. package/dist/store/t310-readiness.d.ts +83 -0
  30. package/dist/store/t310-readiness.d.ts.map +1 -0
  31. package/package.json +11 -9
  32. package/src/__tests__/cli-parity.test.ts +19 -14
  33. package/src/__tests__/human-output.test.ts +13 -11
  34. package/src/init.ts +18 -8
  35. package/src/internal.ts +52 -2
  36. package/src/memory/__tests__/brain-automation.test.ts +2 -2
  37. package/src/memory/brain-embedding.ts +1 -1
  38. package/src/memory/embedding-local.ts +10 -5
  39. package/src/memory/embedding-worker.ts +1 -1
  40. package/src/skills/__tests__/discovery.test.ts +22 -7
  41. package/src/store/__tests__/backup-crypto.test.ts +101 -0
  42. package/src/store/__tests__/backup-pack.test.ts +491 -0
  43. package/src/store/__tests__/backup-unpack.test.ts +298 -0
  44. package/src/store/__tests__/performance-safety.test.ts +11 -5
  45. package/src/store/__tests__/regenerators.test.ts +234 -0
  46. package/src/store/__tests__/restore-conflict-report.test.ts +274 -0
  47. package/src/store/__tests__/restore-json-merge.test.ts +521 -0
  48. package/src/store/__tests__/t310-readiness.test.ts +111 -0
  49. package/src/store/__tests__/t311-integration.test.ts +661 -0
  50. package/src/store/backup-crypto.ts +209 -0
  51. package/src/store/backup-pack.ts +739 -0
  52. package/src/store/backup-unpack.ts +583 -0
  53. package/src/store/migrate-signaldock-to-conduit.ts +14 -7
  54. package/src/store/regenerators.ts +243 -0
  55. package/src/store/restore-conflict-report.ts +317 -0
  56. package/src/store/restore-json-merge.ts +653 -0
  57. package/src/store/t310-readiness.ts +119 -0
  58. package/src/validation/protocols/_shared.ts +1 -1
  59. package/dist/adapters/adapter-registry.js +0 -64
  60. package/dist/adapters/adapter-registry.js.map +0 -1
  61. package/dist/adapters/discovery.js +0 -83
  62. package/dist/adapters/discovery.js.map +0 -1
  63. package/dist/adapters/index.js +0 -9
  64. package/dist/adapters/index.js.map +0 -1
  65. package/dist/adapters/manager.js +0 -260
  66. package/dist/adapters/manager.js.map +0 -1
  67. package/dist/admin/export-tasks.js +0 -171
  68. package/dist/admin/export-tasks.js.map +0 -1
  69. package/dist/admin/export.js +0 -103
  70. package/dist/admin/export.js.map +0 -1
  71. package/dist/admin/help.js +0 -106
  72. package/dist/admin/help.js.map +0 -1
  73. package/dist/admin/import-tasks.js +0 -182
  74. package/dist/admin/import-tasks.js.map +0 -1
  75. package/dist/admin/import.js +0 -129
  76. package/dist/admin/import.js.map +0 -1
  77. package/dist/admin/index.js +0 -13
  78. package/dist/admin/index.js.map +0 -1
  79. package/dist/adrs/find.js +0 -134
  80. package/dist/adrs/find.js.map +0 -1
  81. package/dist/adrs/index.js +0 -15
  82. package/dist/adrs/index.js.map +0 -1
  83. package/dist/adrs/link-pipeline.js +0 -160
  84. package/dist/adrs/link-pipeline.js.map +0 -1
  85. package/dist/adrs/list.js +0 -43
  86. package/dist/adrs/list.js.map +0 -1
  87. package/dist/adrs/parse.js +0 -51
  88. package/dist/adrs/parse.js.map +0 -1
  89. package/dist/adrs/show.js +0 -22
  90. package/dist/adrs/show.js.map +0 -1
  91. package/dist/adrs/sync.js +0 -188
  92. package/dist/adrs/sync.js.map +0 -1
  93. package/dist/adrs/types.js +0 -9
  94. package/dist/adrs/types.js.map +0 -1
  95. package/dist/adrs/validate.js +0 -57
  96. package/dist/adrs/validate.js.map +0 -1
  97. package/dist/agents/agent-registry.js +0 -288
  98. package/dist/agents/agent-registry.js.map +0 -1
  99. package/dist/agents/agent-schema.js +0 -82
  100. package/dist/agents/agent-schema.js.map +0 -1
  101. package/dist/agents/capacity.js +0 -116
  102. package/dist/agents/capacity.js.map +0 -1
  103. package/dist/agents/execution-learning.js +0 -474
  104. package/dist/agents/execution-learning.js.map +0 -1
  105. package/dist/agents/health-monitor.js +0 -217
  106. package/dist/agents/health-monitor.js.map +0 -1
  107. package/dist/agents/index.js +0 -29
  108. package/dist/agents/index.js.map +0 -1
  109. package/dist/agents/registry.js +0 -314
  110. package/dist/agents/registry.js.map +0 -1
  111. package/dist/agents/retry.js +0 -215
  112. package/dist/agents/retry.js.map +0 -1
  113. package/dist/audit-prune.js +0 -94
  114. package/dist/audit-prune.js.map +0 -1
  115. package/dist/audit.js +0 -68
  116. package/dist/audit.js.map +0 -1
  117. package/dist/backfill/index.js +0 -229
  118. package/dist/backfill/index.js.map +0 -1
  119. package/dist/bootstrap.js +0 -344
  120. package/dist/bootstrap.js.map +0 -1
  121. package/dist/caamp/adapter.js +0 -259
  122. package/dist/caamp/adapter.js.map +0 -1
  123. package/dist/caamp/capability-check.js +0 -38
  124. package/dist/caamp/capability-check.js.map +0 -1
  125. package/dist/caamp/index.js +0 -21
  126. package/dist/caamp/index.js.map +0 -1
  127. package/dist/caamp-init.js +0 -16
  128. package/dist/caamp-init.js.map +0 -1
  129. package/dist/cleo.js +0 -322
  130. package/dist/cleo.js.map +0 -1
  131. package/dist/code/index.js +0 -10
  132. package/dist/code/index.js.map +0 -1
  133. package/dist/code/outline.js +0 -165
  134. package/dist/code/outline.js.map +0 -1
  135. package/dist/code/parser.js +0 -295
  136. package/dist/code/parser.js.map +0 -1
  137. package/dist/code/search.js +0 -135
  138. package/dist/code/search.js.map +0 -1
  139. package/dist/code/unfold.js +0 -155
  140. package/dist/code/unfold.js.map +0 -1
  141. package/dist/codebase-map/analyzers/architecture.js +0 -129
  142. package/dist/codebase-map/analyzers/architecture.js.map +0 -1
  143. package/dist/codebase-map/analyzers/concerns.js +0 -122
  144. package/dist/codebase-map/analyzers/concerns.js.map +0 -1
  145. package/dist/codebase-map/analyzers/conventions.js +0 -149
  146. package/dist/codebase-map/analyzers/conventions.js.map +0 -1
  147. package/dist/codebase-map/analyzers/integrations.js +0 -108
  148. package/dist/codebase-map/analyzers/integrations.js.map +0 -1
  149. package/dist/codebase-map/analyzers/stack.js +0 -117
  150. package/dist/codebase-map/analyzers/stack.js.map +0 -1
  151. package/dist/codebase-map/analyzers/structure.js +0 -137
  152. package/dist/codebase-map/analyzers/structure.js.map +0 -1
  153. package/dist/codebase-map/analyzers/testing.js +0 -118
  154. package/dist/codebase-map/analyzers/testing.js.map +0 -1
  155. package/dist/codebase-map/index.js +0 -57
  156. package/dist/codebase-map/index.js.map +0 -1
  157. package/dist/codebase-map/store.js +0 -122
  158. package/dist/codebase-map/store.js.map +0 -1
  159. package/dist/codebase-map/summary.js +0 -152
  160. package/dist/codebase-map/summary.js.map +0 -1
  161. package/dist/compliance/index.js +0 -288
  162. package/dist/compliance/index.js.map +0 -1
  163. package/dist/compliance/protocol-enforcement.js +0 -332
  164. package/dist/compliance/protocol-enforcement.js.map +0 -1
  165. package/dist/compliance/protocol-rules.js +0 -786
  166. package/dist/compliance/protocol-rules.js.map +0 -1
  167. package/dist/compliance/protocol-types.js +0 -79
  168. package/dist/compliance/protocol-types.js.map +0 -1
  169. package/dist/compliance/store.js +0 -53
  170. package/dist/compliance/store.js.map +0 -1
  171. package/dist/conduit/conduit-client.js +0 -107
  172. package/dist/conduit/conduit-client.js.map +0 -1
  173. package/dist/conduit/factory.js +0 -52
  174. package/dist/conduit/factory.js.map +0 -1
  175. package/dist/conduit/http-transport.js +0 -155
  176. package/dist/conduit/http-transport.js.map +0 -1
  177. package/dist/conduit/index.js +0 -15
  178. package/dist/conduit/index.js.map +0 -1
  179. package/dist/conduit/local-transport.js +0 -255
  180. package/dist/conduit/local-transport.js.map +0 -1
  181. package/dist/conduit/sse-transport.js +0 -299
  182. package/dist/conduit/sse-transport.js.map +0 -1
  183. package/dist/config/build-config.js +0 -29
  184. package/dist/config/build-config.js.map +0 -1
  185. package/dist/config.js +0 -400
  186. package/dist/config.js.map +0 -1
  187. package/dist/constants.js +0 -18
  188. package/dist/constants.js.map +0 -1
  189. package/dist/context/index.js +0 -137
  190. package/dist/context/index.js.map +0 -1
  191. package/dist/crypto/credentials.js +0 -191
  192. package/dist/crypto/credentials.js.map +0 -1
  193. package/dist/discovery.js +0 -182
  194. package/dist/discovery.js.map +0 -1
  195. package/dist/engine-result.js +0 -12
  196. package/dist/engine-result.js.map +0 -1
  197. package/dist/error-catalog.js +0 -404
  198. package/dist/error-catalog.js.map +0 -1
  199. package/dist/error-registry.js +0 -393
  200. package/dist/error-registry.js.map +0 -1
  201. package/dist/errors.js +0 -173
  202. package/dist/errors.js.map +0 -1
  203. package/dist/hooks/handlers/agent-hooks.js +0 -106
  204. package/dist/hooks/handlers/agent-hooks.js.map +0 -1
  205. package/dist/hooks/handlers/context-hooks.js +0 -111
  206. package/dist/hooks/handlers/context-hooks.js.map +0 -1
  207. package/dist/hooks/handlers/error-hooks.js +0 -52
  208. package/dist/hooks/handlers/error-hooks.js.map +0 -1
  209. package/dist/hooks/handlers/file-hooks.js +0 -104
  210. package/dist/hooks/handlers/file-hooks.js.map +0 -1
  211. package/dist/hooks/handlers/handler-helpers.js +0 -61
  212. package/dist/hooks/handlers/handler-helpers.js.map +0 -1
  213. package/dist/hooks/handlers/index.js +0 -28
  214. package/dist/hooks/handlers/index.js.map +0 -1
  215. package/dist/hooks/handlers/memory-bridge-refresh.js +0 -42
  216. package/dist/hooks/handlers/memory-bridge-refresh.js.map +0 -1
  217. package/dist/hooks/handlers/notification-hooks.js +0 -62
  218. package/dist/hooks/handlers/notification-hooks.js.map +0 -1
  219. package/dist/hooks/handlers/session-hooks.js +0 -142
  220. package/dist/hooks/handlers/session-hooks.js.map +0 -1
  221. package/dist/hooks/handlers/task-hooks.js +0 -65
  222. package/dist/hooks/handlers/task-hooks.js.map +0 -1
  223. package/dist/hooks/handlers/work-capture-hooks.js +0 -165
  224. package/dist/hooks/handlers/work-capture-hooks.js.map +0 -1
  225. package/dist/hooks/index.js +0 -13
  226. package/dist/hooks/index.js.map +0 -1
  227. package/dist/hooks/payload-schemas.js +0 -220
  228. package/dist/hooks/payload-schemas.js.map +0 -1
  229. package/dist/hooks/provider-hooks.js +0 -66
  230. package/dist/hooks/provider-hooks.js.map +0 -1
  231. package/dist/hooks/registry.js +0 -229
  232. package/dist/hooks/registry.js.map +0 -1
  233. package/dist/hooks/types.js +0 -66
  234. package/dist/hooks/types.js.map +0 -1
  235. package/dist/hooks.js +0 -136
  236. package/dist/hooks.js.map +0 -1
  237. package/dist/init.js +0 -851
  238. package/dist/init.js.map +0 -1
  239. package/dist/inject/index.js +0 -82
  240. package/dist/inject/index.js.map +0 -1
  241. package/dist/injection.js +0 -343
  242. package/dist/injection.js.map +0 -1
  243. package/dist/intelligence/adaptive-validation.js +0 -497
  244. package/dist/intelligence/adaptive-validation.js.map +0 -1
  245. package/dist/intelligence/impact.js +0 -675
  246. package/dist/intelligence/impact.js.map +0 -1
  247. package/dist/intelligence/index.js +0 -22
  248. package/dist/intelligence/index.js.map +0 -1
  249. package/dist/intelligence/patterns.js +0 -492
  250. package/dist/intelligence/patterns.js.map +0 -1
  251. package/dist/intelligence/prediction.js +0 -499
  252. package/dist/intelligence/prediction.js.map +0 -1
  253. package/dist/intelligence/types.js +0 -13
  254. package/dist/intelligence/types.js.map +0 -1
  255. package/dist/internal.js +0 -306
  256. package/dist/internal.js.map +0 -1
  257. package/dist/issue/create.js +0 -121
  258. package/dist/issue/create.js.map +0 -1
  259. package/dist/issue/diagnostics.js +0 -59
  260. package/dist/issue/diagnostics.js.map +0 -1
  261. package/dist/issue/index.js +0 -10
  262. package/dist/issue/index.js.map +0 -1
  263. package/dist/issue/template-parser.js +0 -267
  264. package/dist/issue/template-parser.js.map +0 -1
  265. package/dist/json-schema-validator.js +0 -76
  266. package/dist/json-schema-validator.js.map +0 -1
  267. package/dist/lib/index.js +0 -11
  268. package/dist/lib/index.js.map +0 -1
  269. package/dist/lib/retry.js +0 -152
  270. package/dist/lib/retry.js.map +0 -1
  271. package/dist/lib/tree-sitter-languages.js +0 -71
  272. package/dist/lib/tree-sitter-languages.js.map +0 -1
  273. package/dist/lifecycle/chain-composition.js +0 -152
  274. package/dist/lifecycle/chain-composition.js.map +0 -1
  275. package/dist/lifecycle/chain-store.js +0 -246
  276. package/dist/lifecycle/chain-store.js.map +0 -1
  277. package/dist/lifecycle/consolidate-rcasd.js +0 -352
  278. package/dist/lifecycle/consolidate-rcasd.js.map +0 -1
  279. package/dist/lifecycle/default-chain.js +0 -176
  280. package/dist/lifecycle/default-chain.js.map +0 -1
  281. package/dist/lifecycle/evidence.js +0 -180
  282. package/dist/lifecycle/evidence.js.map +0 -1
  283. package/dist/lifecycle/frontmatter.js +0 -363
  284. package/dist/lifecycle/frontmatter.js.map +0 -1
  285. package/dist/lifecycle/index.js +0 -756
  286. package/dist/lifecycle/index.js.map +0 -1
  287. package/dist/lifecycle/pipeline.js +0 -656
  288. package/dist/lifecycle/pipeline.js.map +0 -1
  289. package/dist/lifecycle/rcasd-index.js +0 -326
  290. package/dist/lifecycle/rcasd-index.js.map +0 -1
  291. package/dist/lifecycle/rcasd-paths.js +0 -220
  292. package/dist/lifecycle/rcasd-paths.js.map +0 -1
  293. package/dist/lifecycle/resume.js +0 -864
  294. package/dist/lifecycle/resume.js.map +0 -1
  295. package/dist/lifecycle/stage-artifacts.js +0 -94
  296. package/dist/lifecycle/stage-artifacts.js.map +0 -1
  297. package/dist/lifecycle/stage-guidance.js +0 -234
  298. package/dist/lifecycle/stage-guidance.js.map +0 -1
  299. package/dist/lifecycle/stages.js +0 -534
  300. package/dist/lifecycle/stages.js.map +0 -1
  301. package/dist/lifecycle/state-machine.js +0 -516
  302. package/dist/lifecycle/state-machine.js.map +0 -1
  303. package/dist/lifecycle/tessera-engine.js +0 -249
  304. package/dist/lifecycle/tessera-engine.js.map +0 -1
  305. package/dist/logger.js +0 -140
  306. package/dist/logger.js.map +0 -1
  307. package/dist/memory/auto-extract.js +0 -177
  308. package/dist/memory/auto-extract.js.map +0 -1
  309. package/dist/memory/brain-embedding.js +0 -66
  310. package/dist/memory/brain-embedding.js.map +0 -1
  311. package/dist/memory/brain-lifecycle.js +0 -298
  312. package/dist/memory/brain-lifecycle.js.map +0 -1
  313. package/dist/memory/brain-links.js +0 -161
  314. package/dist/memory/brain-links.js.map +0 -1
  315. package/dist/memory/brain-maintenance.js +0 -114
  316. package/dist/memory/brain-maintenance.js.map +0 -1
  317. package/dist/memory/brain-migration.js +0 -149
  318. package/dist/memory/brain-migration.js.map +0 -1
  319. package/dist/memory/brain-reasoning.js +0 -215
  320. package/dist/memory/brain-reasoning.js.map +0 -1
  321. package/dist/memory/brain-retrieval.js +0 -542
  322. package/dist/memory/brain-retrieval.js.map +0 -1
  323. package/dist/memory/brain-row-types.js +0 -10
  324. package/dist/memory/brain-row-types.js.map +0 -1
  325. package/dist/memory/brain-search.js +0 -519
  326. package/dist/memory/brain-search.js.map +0 -1
  327. package/dist/memory/brain-similarity.js +0 -145
  328. package/dist/memory/brain-similarity.js.map +0 -1
  329. package/dist/memory/claude-mem-migration.js +0 -277
  330. package/dist/memory/claude-mem-migration.js.map +0 -1
  331. package/dist/memory/decisions.js +0 -162
  332. package/dist/memory/decisions.js.map +0 -1
  333. package/dist/memory/embedding-local.js +0 -97
  334. package/dist/memory/embedding-local.js.map +0 -1
  335. package/dist/memory/embedding-queue.js +0 -271
  336. package/dist/memory/embedding-queue.js.map +0 -1
  337. package/dist/memory/embedding-worker.js +0 -58
  338. package/dist/memory/embedding-worker.js.map +0 -1
  339. package/dist/memory/engine-compat.js +0 -1397
  340. package/dist/memory/engine-compat.js.map +0 -1
  341. package/dist/memory/index.js +0 -1140
  342. package/dist/memory/index.js.map +0 -1
  343. package/dist/memory/learnings.js +0 -121
  344. package/dist/memory/learnings.js.map +0 -1
  345. package/dist/memory/memory-bridge.js +0 -370
  346. package/dist/memory/memory-bridge.js.map +0 -1
  347. package/dist/memory/patterns.js +0 -122
  348. package/dist/memory/patterns.js.map +0 -1
  349. package/dist/memory/pipeline-manifest-sqlite.js +0 -975
  350. package/dist/memory/pipeline-manifest-sqlite.js.map +0 -1
  351. package/dist/memory/session-memory.js +0 -331
  352. package/dist/memory/session-memory.js.map +0 -1
  353. package/dist/metrics/ab-test.js +0 -260
  354. package/dist/metrics/ab-test.js.map +0 -1
  355. package/dist/metrics/aggregation.js +0 -363
  356. package/dist/metrics/aggregation.js.map +0 -1
  357. package/dist/metrics/common.js +0 -64
  358. package/dist/metrics/common.js.map +0 -1
  359. package/dist/metrics/enums.js +0 -78
  360. package/dist/metrics/enums.js.map +0 -1
  361. package/dist/metrics/index.js +0 -19
  362. package/dist/metrics/index.js.map +0 -1
  363. package/dist/metrics/model-provider-registry.js +0 -88
  364. package/dist/metrics/model-provider-registry.js.map +0 -1
  365. package/dist/metrics/otel-integration.js +0 -263
  366. package/dist/metrics/otel-integration.js.map +0 -1
  367. package/dist/metrics/provider-detection.js +0 -103
  368. package/dist/metrics/provider-detection.js.map +0 -1
  369. package/dist/metrics/token-estimation.js +0 -253
  370. package/dist/metrics/token-estimation.js.map +0 -1
  371. package/dist/metrics/token-service.js +0 -450
  372. package/dist/metrics/token-service.js.map +0 -1
  373. package/dist/migration/agent-outputs.js +0 -316
  374. package/dist/migration/agent-outputs.js.map +0 -1
  375. package/dist/migration/checksum.js +0 -92
  376. package/dist/migration/checksum.js.map +0 -1
  377. package/dist/migration/index.js +0 -282
  378. package/dist/migration/index.js.map +0 -1
  379. package/dist/migration/logger.js +0 -360
  380. package/dist/migration/logger.js.map +0 -1
  381. package/dist/migration/preflight.js +0 -9
  382. package/dist/migration/preflight.js.map +0 -1
  383. package/dist/migration/state.js +0 -421
  384. package/dist/migration/state.js.map +0 -1
  385. package/dist/migration/validate.js +0 -241
  386. package/dist/migration/validate.js.map +0 -1
  387. package/dist/mvi-helpers.js +0 -74
  388. package/dist/mvi-helpers.js.map +0 -1
  389. package/dist/nexus/deps.js +0 -375
  390. package/dist/nexus/deps.js.map +0 -1
  391. package/dist/nexus/discover.js +0 -288
  392. package/dist/nexus/discover.js.map +0 -1
  393. package/dist/nexus/hash.js +0 -10
  394. package/dist/nexus/hash.js.map +0 -1
  395. package/dist/nexus/index.js +0 -40
  396. package/dist/nexus/index.js.map +0 -1
  397. package/dist/nexus/migrate-json-to-sqlite.js +0 -115
  398. package/dist/nexus/migrate-json-to-sqlite.js.map +0 -1
  399. package/dist/nexus/permissions.js +0 -105
  400. package/dist/nexus/permissions.js.map +0 -1
  401. package/dist/nexus/query.js +0 -175
  402. package/dist/nexus/query.js.map +0 -1
  403. package/dist/nexus/registry.js +0 -584
  404. package/dist/nexus/registry.js.map +0 -1
  405. package/dist/nexus/sharing/index.js +0 -288
  406. package/dist/nexus/sharing/index.js.map +0 -1
  407. package/dist/nexus/transfer-types.js +0 -8
  408. package/dist/nexus/transfer-types.js.map +0 -1
  409. package/dist/nexus/transfer.js +0 -263
  410. package/dist/nexus/transfer.js.map +0 -1
  411. package/dist/nexus/workspace.js +0 -355
  412. package/dist/nexus/workspace.js.map +0 -1
  413. package/dist/observability/index.js +0 -103
  414. package/dist/observability/index.js.map +0 -1
  415. package/dist/observability/log-filter.js +0 -63
  416. package/dist/observability/log-filter.js.map +0 -1
  417. package/dist/observability/log-parser.js +0 -99
  418. package/dist/observability/log-parser.js.map +0 -1
  419. package/dist/observability/log-reader.js +0 -139
  420. package/dist/observability/log-reader.js.map +0 -1
  421. package/dist/observability/types.js +0 -19
  422. package/dist/observability/types.js.map +0 -1
  423. package/dist/orchestration/analyze.js +0 -107
  424. package/dist/orchestration/analyze.js.map +0 -1
  425. package/dist/orchestration/bootstrap.js +0 -132
  426. package/dist/orchestration/bootstrap.js.map +0 -1
  427. package/dist/orchestration/context.js +0 -56
  428. package/dist/orchestration/context.js.map +0 -1
  429. package/dist/orchestration/critical-path.js +0 -100
  430. package/dist/orchestration/critical-path.js.map +0 -1
  431. package/dist/orchestration/hierarchy.js +0 -183
  432. package/dist/orchestration/hierarchy.js.map +0 -1
  433. package/dist/orchestration/index.js +0 -287
  434. package/dist/orchestration/index.js.map +0 -1
  435. package/dist/orchestration/parallel.js +0 -89
  436. package/dist/orchestration/parallel.js.map +0 -1
  437. package/dist/orchestration/protocol-validators.js +0 -815
  438. package/dist/orchestration/protocol-validators.js.map +0 -1
  439. package/dist/orchestration/skill-ops.js +0 -98
  440. package/dist/orchestration/skill-ops.js.map +0 -1
  441. package/dist/orchestration/status.js +0 -107
  442. package/dist/orchestration/status.js.map +0 -1
  443. package/dist/orchestration/unblock.js +0 -103
  444. package/dist/orchestration/unblock.js.map +0 -1
  445. package/dist/orchestration/validate-spawn.js +0 -67
  446. package/dist/orchestration/validate-spawn.js.map +0 -1
  447. package/dist/orchestration/waves.js +0 -86
  448. package/dist/orchestration/waves.js.map +0 -1
  449. package/dist/otel/index.js +0 -163
  450. package/dist/otel/index.js.map +0 -1
  451. package/dist/output.js +0 -164
  452. package/dist/output.js.map +0 -1
  453. package/dist/pagination.js +0 -64
  454. package/dist/pagination.js.map +0 -1
  455. package/dist/paths.js +0 -842
  456. package/dist/paths.js.map +0 -1
  457. package/dist/phases/deps.js +0 -372
  458. package/dist/phases/deps.js.map +0 -1
  459. package/dist/phases/index.js +0 -349
  460. package/dist/phases/index.js.map +0 -1
  461. package/dist/pipeline/index.js +0 -10
  462. package/dist/pipeline/index.js.map +0 -1
  463. package/dist/pipeline/phase.js +0 -45
  464. package/dist/pipeline/phase.js.map +0 -1
  465. package/dist/platform.js +0 -211
  466. package/dist/platform.js.map +0 -1
  467. package/dist/project-info.js +0 -84
  468. package/dist/project-info.js.map +0 -1
  469. package/dist/reconciliation/index.js +0 -10
  470. package/dist/reconciliation/index.js.map +0 -1
  471. package/dist/reconciliation/link-store.js +0 -129
  472. package/dist/reconciliation/link-store.js.map +0 -1
  473. package/dist/reconciliation/reconciliation-engine.js +0 -298
  474. package/dist/reconciliation/reconciliation-engine.js.map +0 -1
  475. package/dist/release/artifacts.js +0 -427
  476. package/dist/release/artifacts.js.map +0 -1
  477. package/dist/release/changelog-writer.js +0 -151
  478. package/dist/release/changelog-writer.js.map +0 -1
  479. package/dist/release/channel.js +0 -144
  480. package/dist/release/channel.js.map +0 -1
  481. package/dist/release/ci.js +0 -166
  482. package/dist/release/ci.js.map +0 -1
  483. package/dist/release/github-pr.js +0 -225
  484. package/dist/release/github-pr.js.map +0 -1
  485. package/dist/release/guards.js +0 -116
  486. package/dist/release/guards.js.map +0 -1
  487. package/dist/release/index.js +0 -22
  488. package/dist/release/index.js.map +0 -1
  489. package/dist/release/release-config.js +0 -158
  490. package/dist/release/release-config.js.map +0 -1
  491. package/dist/release/release-manifest.js +0 -1019
  492. package/dist/release/release-manifest.js.map +0 -1
  493. package/dist/release/version-bump.js +0 -255
  494. package/dist/release/version-bump.js.map +0 -1
  495. package/dist/remote/index.js +0 -257
  496. package/dist/remote/index.js.map +0 -1
  497. package/dist/repair.js +0 -130
  498. package/dist/repair.js.map +0 -1
  499. package/dist/research/index.js +0 -2
  500. package/dist/research/index.js.map +0 -1
  501. package/dist/roadmap/index.js +0 -59
  502. package/dist/roadmap/index.js.map +0 -1
  503. package/dist/routing/capability-matrix.js +0 -1556
  504. package/dist/routing/capability-matrix.js.map +0 -1
  505. package/dist/routing/index.js +0 -9
  506. package/dist/routing/index.js.map +0 -1
  507. package/dist/scaffold.js +0 -1759
  508. package/dist/scaffold.js.map +0 -1
  509. package/dist/schema-management.js +0 -295
  510. package/dist/schema-management.js.map +0 -1
  511. package/dist/security/index.js +0 -9
  512. package/dist/security/index.js.map +0 -1
  513. package/dist/security/input-sanitization.js +0 -321
  514. package/dist/security/input-sanitization.js.map +0 -1
  515. package/dist/sequence/index.js +0 -295
  516. package/dist/sequence/index.js.map +0 -1
  517. package/dist/sessions/assumptions.js +0 -54
  518. package/dist/sessions/assumptions.js.map +0 -1
  519. package/dist/sessions/briefing.js +0 -377
  520. package/dist/sessions/briefing.js.map +0 -1
  521. package/dist/sessions/context-alert.js +0 -222
  522. package/dist/sessions/context-alert.js.map +0 -1
  523. package/dist/sessions/context-inject.js +0 -61
  524. package/dist/sessions/context-inject.js.map +0 -1
  525. package/dist/sessions/context-monitor.js +0 -98
  526. package/dist/sessions/context-monitor.js.map +0 -1
  527. package/dist/sessions/decisions.js +0 -65
  528. package/dist/sessions/decisions.js.map +0 -1
  529. package/dist/sessions/find.js +0 -65
  530. package/dist/sessions/find.js.map +0 -1
  531. package/dist/sessions/handoff.js +0 -328
  532. package/dist/sessions/handoff.js.map +0 -1
  533. package/dist/sessions/hitl-warnings.js +0 -254
  534. package/dist/sessions/hitl-warnings.js.map +0 -1
  535. package/dist/sessions/index.js +0 -327
  536. package/dist/sessions/index.js.map +0 -1
  537. package/dist/sessions/session-archive.js +0 -40
  538. package/dist/sessions/session-archive.js.map +0 -1
  539. package/dist/sessions/session-cleanup.js +0 -59
  540. package/dist/sessions/session-cleanup.js.map +0 -1
  541. package/dist/sessions/session-drift.js +0 -134
  542. package/dist/sessions/session-drift.js.map +0 -1
  543. package/dist/sessions/session-enforcement.js +0 -144
  544. package/dist/sessions/session-enforcement.js.map +0 -1
  545. package/dist/sessions/session-grade.js +0 -253
  546. package/dist/sessions/session-grade.js.map +0 -1
  547. package/dist/sessions/session-history.js +0 -42
  548. package/dist/sessions/session-history.js.map +0 -1
  549. package/dist/sessions/session-id.js +0 -81
  550. package/dist/sessions/session-id.js.map +0 -1
  551. package/dist/sessions/session-memory-bridge.js +0 -52
  552. package/dist/sessions/session-memory-bridge.js.map +0 -1
  553. package/dist/sessions/session-show.js +0 -24
  554. package/dist/sessions/session-show.js.map +0 -1
  555. package/dist/sessions/session-stats.js +0 -69
  556. package/dist/sessions/session-stats.js.map +0 -1
  557. package/dist/sessions/session-suspend.js +0 -39
  558. package/dist/sessions/session-suspend.js.map +0 -1
  559. package/dist/sessions/session-switch.js +0 -51
  560. package/dist/sessions/session-switch.js.map +0 -1
  561. package/dist/sessions/session-view.js +0 -76
  562. package/dist/sessions/session-view.js.map +0 -1
  563. package/dist/sessions/snapshot.js +0 -213
  564. package/dist/sessions/snapshot.js.map +0 -1
  565. package/dist/sessions/statusline-setup.js +0 -85
  566. package/dist/sessions/statusline-setup.js.map +0 -1
  567. package/dist/sessions/types.js +0 -8
  568. package/dist/sessions/types.js.map +0 -1
  569. package/dist/skills/agents/config.js +0 -94
  570. package/dist/skills/agents/config.js.map +0 -1
  571. package/dist/skills/agents/install.js +0 -116
  572. package/dist/skills/agents/install.js.map +0 -1
  573. package/dist/skills/agents/registry.js +0 -161
  574. package/dist/skills/agents/registry.js.map +0 -1
  575. package/dist/skills/discovery.js +0 -333
  576. package/dist/skills/discovery.js.map +0 -1
  577. package/dist/skills/dispatch.js +0 -347
  578. package/dist/skills/dispatch.js.map +0 -1
  579. package/dist/skills/dynamic-skill-generator.js +0 -87
  580. package/dist/skills/dynamic-skill-generator.js.map +0 -1
  581. package/dist/skills/index.js +0 -44
  582. package/dist/skills/index.js.map +0 -1
  583. package/dist/skills/injection/subagent.js +0 -195
  584. package/dist/skills/injection/subagent.js.map +0 -1
  585. package/dist/skills/injection/token.js +0 -260
  586. package/dist/skills/injection/token.js.map +0 -1
  587. package/dist/skills/install.js +0 -40
  588. package/dist/skills/install.js.map +0 -1
  589. package/dist/skills/manifests/contribution.js +0 -175
  590. package/dist/skills/manifests/contribution.js.map +0 -1
  591. package/dist/skills/manifests/research.js +0 -281
  592. package/dist/skills/manifests/research.js.map +0 -1
  593. package/dist/skills/manifests/resolver.js +0 -146
  594. package/dist/skills/manifests/resolver.js.map +0 -1
  595. package/dist/skills/marketplace.js +0 -90
  596. package/dist/skills/marketplace.js.map +0 -1
  597. package/dist/skills/orchestrator/spawn.js +0 -178
  598. package/dist/skills/orchestrator/spawn.js.map +0 -1
  599. package/dist/skills/orchestrator/startup.js +0 -451
  600. package/dist/skills/orchestrator/startup.js.map +0 -1
  601. package/dist/skills/orchestrator/validator.js +0 -301
  602. package/dist/skills/orchestrator/validator.js.map +0 -1
  603. package/dist/skills/precedence-integration.js +0 -73
  604. package/dist/skills/precedence-integration.js.map +0 -1
  605. package/dist/skills/precedence-types.js +0 -16
  606. package/dist/skills/precedence-types.js.map +0 -1
  607. package/dist/skills/routing-table.js +0 -63
  608. package/dist/skills/routing-table.js.map +0 -1
  609. package/dist/skills/skill-paths.js +0 -217
  610. package/dist/skills/skill-paths.js.map +0 -1
  611. package/dist/skills/test-utility.js +0 -55
  612. package/dist/skills/test-utility.js.map +0 -1
  613. package/dist/skills/types.js +0 -118
  614. package/dist/skills/types.js.map +0 -1
  615. package/dist/skills/validation.js +0 -183
  616. package/dist/skills/validation.js.map +0 -1
  617. package/dist/skills/version.js +0 -57
  618. package/dist/skills/version.js.map +0 -1
  619. package/dist/snapshot/index.js +0 -188
  620. package/dist/snapshot/index.js.map +0 -1
  621. package/dist/spawn/adapter-registry.js +0 -246
  622. package/dist/spawn/adapter-registry.js.map +0 -1
  623. package/dist/spawn/index.js +0 -10
  624. package/dist/spawn/index.js.map +0 -1
  625. package/dist/stats/index.js +0 -343
  626. package/dist/stats/index.js.map +0 -1
  627. package/dist/stats/workflow-telemetry.js +0 -400
  628. package/dist/stats/workflow-telemetry.js.map +0 -1
  629. package/dist/sticky/archive.js +0 -47
  630. package/dist/sticky/archive.js.map +0 -1
  631. package/dist/sticky/convert.js +0 -235
  632. package/dist/sticky/convert.js.map +0 -1
  633. package/dist/sticky/create.js +0 -48
  634. package/dist/sticky/create.js.map +0 -1
  635. package/dist/sticky/id.js +0 -35
  636. package/dist/sticky/id.js.map +0 -1
  637. package/dist/sticky/index.js +0 -16
  638. package/dist/sticky/index.js.map +0 -1
  639. package/dist/sticky/list.js +0 -44
  640. package/dist/sticky/list.js.map +0 -1
  641. package/dist/sticky/purge.js +0 -45
  642. package/dist/sticky/purge.js.map +0 -1
  643. package/dist/sticky/show.js +0 -42
  644. package/dist/sticky/show.js.map +0 -1
  645. package/dist/sticky/types.js +0 -10
  646. package/dist/sticky/types.js.map +0 -1
  647. package/dist/store/agent-registry-accessor.js +0 -783
  648. package/dist/store/agent-registry-accessor.js.map +0 -1
  649. package/dist/store/api-key-kdf.js +0 -84
  650. package/dist/store/api-key-kdf.js.map +0 -1
  651. package/dist/store/atomic.js +0 -167
  652. package/dist/store/atomic.js.map +0 -1
  653. package/dist/store/backup.js +0 -94
  654. package/dist/store/backup.js.map +0 -1
  655. package/dist/store/brain-accessor.js +0 -397
  656. package/dist/store/brain-accessor.js.map +0 -1
  657. package/dist/store/brain-schema.js +0 -215
  658. package/dist/store/brain-schema.js.map +0 -1
  659. package/dist/store/brain-sqlite.js +0 -222
  660. package/dist/store/brain-sqlite.js.map +0 -1
  661. package/dist/store/cache.js +0 -168
  662. package/dist/store/cache.js.map +0 -1
  663. package/dist/store/chain-schema.js +0 -51
  664. package/dist/store/chain-schema.js.map +0 -1
  665. package/dist/store/cleanup-legacy.js +0 -171
  666. package/dist/store/cleanup-legacy.js.map +0 -1
  667. package/dist/store/conduit-sqlite.js +0 -570
  668. package/dist/store/conduit-sqlite.js.map +0 -1
  669. package/dist/store/converters.js +0 -124
  670. package/dist/store/converters.js.map +0 -1
  671. package/dist/store/cross-db-cleanup.js +0 -319
  672. package/dist/store/cross-db-cleanup.js.map +0 -1
  673. package/dist/store/data-accessor.js +0 -26
  674. package/dist/store/data-accessor.js.map +0 -1
  675. package/dist/store/data-safety-central.js +0 -269
  676. package/dist/store/data-safety-central.js.map +0 -1
  677. package/dist/store/data-safety.js +0 -274
  678. package/dist/store/data-safety.js.map +0 -1
  679. package/dist/store/db-helpers.js +0 -224
  680. package/dist/store/db-helpers.js.map +0 -1
  681. package/dist/store/export.js +0 -155
  682. package/dist/store/export.js.map +0 -1
  683. package/dist/store/file-utils.js +0 -270
  684. package/dist/store/file-utils.js.map +0 -1
  685. package/dist/store/git-checkpoint.js +0 -365
  686. package/dist/store/git-checkpoint.js.map +0 -1
  687. package/dist/store/global-salt.js +0 -147
  688. package/dist/store/global-salt.js.map +0 -1
  689. package/dist/store/import-logging.js +0 -139
  690. package/dist/store/import-logging.js.map +0 -1
  691. package/dist/store/import-remap.js +0 -145
  692. package/dist/store/import-remap.js.map +0 -1
  693. package/dist/store/import-sort.js +0 -121
  694. package/dist/store/import-sort.js.map +0 -1
  695. package/dist/store/index.js +0 -29
  696. package/dist/store/index.js.map +0 -1
  697. package/dist/store/json.js +0 -208
  698. package/dist/store/json.js.map +0 -1
  699. package/dist/store/lifecycle-store.js +0 -249
  700. package/dist/store/lifecycle-store.js.map +0 -1
  701. package/dist/store/lock.js +0 -70
  702. package/dist/store/lock.js.map +0 -1
  703. package/dist/store/migrate-signaldock-to-conduit.js +0 -555
  704. package/dist/store/migrate-signaldock-to-conduit.js.map +0 -1
  705. package/dist/store/migration-manager.js +0 -151
  706. package/dist/store/migration-manager.js.map +0 -1
  707. package/dist/store/migration-sqlite.js +0 -676
  708. package/dist/store/migration-sqlite.js.map +0 -1
  709. package/dist/store/nexus-schema.js +0 -62
  710. package/dist/store/nexus-schema.js.map +0 -1
  711. package/dist/store/nexus-sqlite.js +0 -242
  712. package/dist/store/nexus-sqlite.js.map +0 -1
  713. package/dist/store/nexus-validation-schemas.js +0 -40
  714. package/dist/store/nexus-validation-schemas.js.map +0 -1
  715. package/dist/store/parsers.js +0 -37
  716. package/dist/store/parsers.js.map +0 -1
  717. package/dist/store/project-detect.js +0 -457
  718. package/dist/store/project-detect.js.map +0 -1
  719. package/dist/store/provider.js +0 -101
  720. package/dist/store/provider.js.map +0 -1
  721. package/dist/store/safety-data-accessor.js +0 -257
  722. package/dist/store/safety-data-accessor.js.map +0 -1
  723. package/dist/store/schema.js +0 -7
  724. package/dist/store/schema.js.map +0 -1
  725. package/dist/store/session-store.js +0 -219
  726. package/dist/store/session-store.js.map +0 -1
  727. package/dist/store/signaldock-sqlite.js +0 -550
  728. package/dist/store/signaldock-sqlite.js.map +0 -1
  729. package/dist/store/sqlite-backup.js +0 -359
  730. package/dist/store/sqlite-backup.js.map +0 -1
  731. package/dist/store/sqlite-data-accessor.js +0 -787
  732. package/dist/store/sqlite-data-accessor.js.map +0 -1
  733. package/dist/store/sqlite.js +0 -481
  734. package/dist/store/sqlite.js.map +0 -1
  735. package/dist/store/status-registry.js +0 -8
  736. package/dist/store/status-registry.js.map +0 -1
  737. package/dist/store/task-store.js +0 -358
  738. package/dist/store/task-store.js.map +0 -1
  739. package/dist/store/tasks-schema.js +0 -610
  740. package/dist/store/tasks-schema.js.map +0 -1
  741. package/dist/store/typed-query.js +0 -15
  742. package/dist/store/typed-query.js.map +0 -1
  743. package/dist/store/validation-schemas.js +0 -278
  744. package/dist/store/validation-schemas.js.map +0 -1
  745. package/dist/system/archive-analytics.js +0 -277
  746. package/dist/system/archive-analytics.js.map +0 -1
  747. package/dist/system/archive-stats.js +0 -64
  748. package/dist/system/archive-stats.js.map +0 -1
  749. package/dist/system/audit.js +0 -145
  750. package/dist/system/audit.js.map +0 -1
  751. package/dist/system/backup.js +0 -280
  752. package/dist/system/backup.js.map +0 -1
  753. package/dist/system/cleanup.js +0 -134
  754. package/dist/system/cleanup.js.map +0 -1
  755. package/dist/system/health.js +0 -1100
  756. package/dist/system/health.js.map +0 -1
  757. package/dist/system/index.js +0 -18
  758. package/dist/system/index.js.map +0 -1
  759. package/dist/system/inject-generate.js +0 -122
  760. package/dist/system/inject-generate.js.map +0 -1
  761. package/dist/system/labels.js +0 -38
  762. package/dist/system/labels.js.map +0 -1
  763. package/dist/system/metrics.js +0 -61
  764. package/dist/system/metrics.js.map +0 -1
  765. package/dist/system/migrate.js +0 -43
  766. package/dist/system/migrate.js.map +0 -1
  767. package/dist/system/platform-paths.js +0 -80
  768. package/dist/system/platform-paths.js.map +0 -1
  769. package/dist/system/runtime.js +0 -161
  770. package/dist/system/runtime.js.map +0 -1
  771. package/dist/system/safestop.js +0 -99
  772. package/dist/system/safestop.js.map +0 -1
  773. package/dist/system/storage-preflight.js +0 -123
  774. package/dist/system/storage-preflight.js.map +0 -1
  775. package/dist/task-work/index.js +0 -159
  776. package/dist/task-work/index.js.map +0 -1
  777. package/dist/tasks/add.js +0 -736
  778. package/dist/tasks/add.js.map +0 -1
  779. package/dist/tasks/analyze.js +0 -85
  780. package/dist/tasks/analyze.js.map +0 -1
  781. package/dist/tasks/archive.js +0 -90
  782. package/dist/tasks/archive.js.map +0 -1
  783. package/dist/tasks/atomicity.js +0 -83
  784. package/dist/tasks/atomicity.js.map +0 -1
  785. package/dist/tasks/cancel-ops.js +0 -83
  786. package/dist/tasks/cancel-ops.js.map +0 -1
  787. package/dist/tasks/complete.js +0 -214
  788. package/dist/tasks/complete.js.map +0 -1
  789. package/dist/tasks/crossref-extract.js +0 -73
  790. package/dist/tasks/crossref-extract.js.map +0 -1
  791. package/dist/tasks/delete-preview.js +0 -192
  792. package/dist/tasks/delete-preview.js.map +0 -1
  793. package/dist/tasks/delete.js +0 -120
  794. package/dist/tasks/delete.js.map +0 -1
  795. package/dist/tasks/deletion-strategy.js +0 -200
  796. package/dist/tasks/deletion-strategy.js.map +0 -1
  797. package/dist/tasks/dependency-check.js +0 -278
  798. package/dist/tasks/dependency-check.js.map +0 -1
  799. package/dist/tasks/deps-ready.js +0 -32
  800. package/dist/tasks/deps-ready.js.map +0 -1
  801. package/dist/tasks/enforcement.js +0 -86
  802. package/dist/tasks/enforcement.js.map +0 -1
  803. package/dist/tasks/epic-enforcement.js +0 -294
  804. package/dist/tasks/epic-enforcement.js.map +0 -1
  805. package/dist/tasks/find.js +0 -157
  806. package/dist/tasks/find.js.map +0 -1
  807. package/dist/tasks/graph-cache.js +0 -127
  808. package/dist/tasks/graph-cache.js.map +0 -1
  809. package/dist/tasks/graph-ops.js +0 -171
  810. package/dist/tasks/graph-ops.js.map +0 -1
  811. package/dist/tasks/graph-rag.js +0 -328
  812. package/dist/tasks/graph-rag.js.map +0 -1
  813. package/dist/tasks/hierarchy-policy.js +0 -149
  814. package/dist/tasks/hierarchy-policy.js.map +0 -1
  815. package/dist/tasks/hierarchy.js +0 -185
  816. package/dist/tasks/hierarchy.js.map +0 -1
  817. package/dist/tasks/id-generator.js +0 -65
  818. package/dist/tasks/id-generator.js.map +0 -1
  819. package/dist/tasks/index.js +0 -14
  820. package/dist/tasks/index.js.map +0 -1
  821. package/dist/tasks/labels.js +0 -55
  822. package/dist/tasks/labels.js.map +0 -1
  823. package/dist/tasks/list.js +0 -75
  824. package/dist/tasks/list.js.map +0 -1
  825. package/dist/tasks/phase-tracking.js +0 -133
  826. package/dist/tasks/phase-tracking.js.map +0 -1
  827. package/dist/tasks/pipeline-stage.js +0 -248
  828. package/dist/tasks/pipeline-stage.js.map +0 -1
  829. package/dist/tasks/plan.js +0 -268
  830. package/dist/tasks/plan.js.map +0 -1
  831. package/dist/tasks/relates.js +0 -101
  832. package/dist/tasks/relates.js.map +0 -1
  833. package/dist/tasks/show.js +0 -83
  834. package/dist/tasks/show.js.map +0 -1
  835. package/dist/tasks/size-weighting.js +0 -86
  836. package/dist/tasks/size-weighting.js.map +0 -1
  837. package/dist/tasks/staleness.js +0 -86
  838. package/dist/tasks/staleness.js.map +0 -1
  839. package/dist/tasks/task-ops.js +0 -1741
  840. package/dist/tasks/task-ops.js.map +0 -1
  841. package/dist/tasks/update.js +0 -303
  842. package/dist/tasks/update.js.map +0 -1
  843. package/dist/templates/index.js +0 -10
  844. package/dist/templates/index.js.map +0 -1
  845. package/dist/templates/parser.js +0 -254
  846. package/dist/templates/parser.js.map +0 -1
  847. package/dist/ui/aliases.js +0 -153
  848. package/dist/ui/aliases.js.map +0 -1
  849. package/dist/ui/changelog.js +0 -184
  850. package/dist/ui/changelog.js.map +0 -1
  851. package/dist/ui/command-registry.js +0 -168
  852. package/dist/ui/command-registry.js.map +0 -1
  853. package/dist/ui/flags.js +0 -94
  854. package/dist/ui/flags.js.map +0 -1
  855. package/dist/ui/index.js +0 -24
  856. package/dist/ui/index.js.map +0 -1
  857. package/dist/upgrade.js +0 -1148
  858. package/dist/upgrade.js.map +0 -1
  859. package/dist/validation/chain-validation.js +0 -146
  860. package/dist/validation/chain-validation.js.map +0 -1
  861. package/dist/validation/compliance.js +0 -155
  862. package/dist/validation/compliance.js.map +0 -1
  863. package/dist/validation/docs-sync.js +0 -212
  864. package/dist/validation/docs-sync.js.map +0 -1
  865. package/dist/validation/doctor/checks.js +0 -1069
  866. package/dist/validation/doctor/checks.js.map +0 -1
  867. package/dist/validation/doctor/index.js +0 -9
  868. package/dist/validation/doctor/index.js.map +0 -1
  869. package/dist/validation/doctor/project-cache.js +0 -160
  870. package/dist/validation/doctor/project-cache.js.map +0 -1
  871. package/dist/validation/doctor/utils.js +0 -155
  872. package/dist/validation/doctor/utils.js.map +0 -1
  873. package/dist/validation/engine.js +0 -914
  874. package/dist/validation/engine.js.map +0 -1
  875. package/dist/validation/gap-check.js +0 -175
  876. package/dist/validation/gap-check.js.map +0 -1
  877. package/dist/validation/index.js +0 -40
  878. package/dist/validation/index.js.map +0 -1
  879. package/dist/validation/manifest.js +0 -237
  880. package/dist/validation/manifest.js.map +0 -1
  881. package/dist/validation/operation-gate-validators.js +0 -724
  882. package/dist/validation/operation-gate-validators.js.map +0 -1
  883. package/dist/validation/operation-verification-gates.js +0 -532
  884. package/dist/validation/operation-verification-gates.js.map +0 -1
  885. package/dist/validation/param-utils.js +0 -141
  886. package/dist/validation/param-utils.js.map +0 -1
  887. package/dist/validation/protocol-common.js +0 -300
  888. package/dist/validation/protocol-common.js.map +0 -1
  889. package/dist/validation/protocols/_shared.js +0 -82
  890. package/dist/validation/protocols/_shared.js.map +0 -1
  891. package/dist/validation/protocols/architecture-decision.js +0 -31
  892. package/dist/validation/protocols/architecture-decision.js.map +0 -1
  893. package/dist/validation/protocols/artifact-publish.js +0 -28
  894. package/dist/validation/protocols/artifact-publish.js.map +0 -1
  895. package/dist/validation/protocols/consensus.js +0 -41
  896. package/dist/validation/protocols/consensus.js.map +0 -1
  897. package/dist/validation/protocols/contribution.js +0 -27
  898. package/dist/validation/protocols/contribution.js.map +0 -1
  899. package/dist/validation/protocols/decomposition.js +0 -28
  900. package/dist/validation/protocols/decomposition.js.map +0 -1
  901. package/dist/validation/protocols/implementation.js +0 -24
  902. package/dist/validation/protocols/implementation.js.map +0 -1
  903. package/dist/validation/protocols/provenance.js +0 -29
  904. package/dist/validation/protocols/provenance.js.map +0 -1
  905. package/dist/validation/protocols/release.js +0 -29
  906. package/dist/validation/protocols/release.js.map +0 -1
  907. package/dist/validation/protocols/research.js +0 -24
  908. package/dist/validation/protocols/research.js.map +0 -1
  909. package/dist/validation/protocols/specification.js +0 -27
  910. package/dist/validation/protocols/specification.js.map +0 -1
  911. package/dist/validation/protocols/testing.js +0 -30
  912. package/dist/validation/protocols/testing.js.map +0 -1
  913. package/dist/validation/protocols/validation.js +0 -30
  914. package/dist/validation/protocols/validation.js.map +0 -1
  915. package/dist/validation/schema-integrity.js +0 -170
  916. package/dist/validation/schema-integrity.js.map +0 -1
  917. package/dist/validation/schema-validator.js +0 -176
  918. package/dist/validation/schema-validator.js.map +0 -1
  919. package/dist/validation/validate-ops.js +0 -937
  920. package/dist/validation/validate-ops.js.map +0 -1
  921. package/dist/validation/validation-rules.js +0 -226
  922. package/dist/validation/validation-rules.js.map +0 -1
  923. package/dist/validation/verification.js +0 -321
  924. package/dist/validation/verification.js.map +0 -1
@@ -1,1397 +0,0 @@
1
- /**
2
- * Memory Engine Compatibility Layer — Brain.db Cognitive Memory
3
- *
4
- * Async wrappers around brain.db cognitive memory functions that return
5
- * EngineResult<T> format for consumption by the dispatch layer.
6
- *
7
- * After the memory domain cutover (T5241), this file contains ONLY
8
- * brain.db-backed operations. Manifest operations moved to
9
- * pipeline-manifest-compat.ts, and context injection moved to
10
- * sessions/context-inject.ts.
11
- *
12
- * @task T5241
13
- * @epic T5149
14
- */
15
- import { getProjectRoot } from '../paths.js';
16
- // BRAIN accessor for direct table queries (T5241)
17
- import { getBrainAccessor } from '../store/brain-accessor.js';
18
- import { getAccessor } from '../store/data-accessor.js';
19
- import { linkMemoryToTask, unlinkMemoryFromTask } from './brain-links.js';
20
- // BRAIN retrieval imports (T5131-T5135)
21
- import { fetchBrainEntries, observeBrain, searchBrainCompact, timelineBrain, } from './brain-retrieval.js';
22
- import { learningStats, searchLearnings, storeLearning, } from './learnings.js';
23
- // BRAIN memory imports (T4770)
24
- import { patternStats, searchPatterns, storePattern, } from './patterns.js';
25
- // ============================================================================
26
- // Internal helpers
27
- // ============================================================================
28
- function resolveRoot(projectRoot) {
29
- return projectRoot || getProjectRoot();
30
- }
31
- /**
32
- * Parse brain.db entry ID prefix to determine the table type.
33
- *
34
- * Conventions:
35
- * - D... -> decision (D001, D-xxx)
36
- * - P... -> pattern (P001, P-xxx)
37
- * - L... -> learning (L001, L-xxx)
38
- * - O... or CM-... -> observation (O-xxx, CM-xxx)
39
- */
40
- function parseIdPrefix(id) {
41
- if (id.startsWith('D-') || /^D\d/.test(id))
42
- return 'decision';
43
- if (id.startsWith('P-') || /^P\d/.test(id))
44
- return 'pattern';
45
- if (id.startsWith('L-') || /^L\d/.test(id))
46
- return 'learning';
47
- if (id.startsWith('O-') || id.startsWith('O') || id.startsWith('CM-'))
48
- return 'observation';
49
- return null;
50
- }
51
- // ============================================================================
52
- // Brain.db Entry Lookup
53
- // ============================================================================
54
- /**
55
- * Look up a brain.db entry by ID.
56
- *
57
- * @param entryId - Brain entry ID with type prefix (D-, P-, L-, O-, or CM-)
58
- * @param projectRoot - Optional project root path; defaults to resolved root
59
- * @returns EngineResult containing the typed entry data on success
60
- *
61
- * @remarks
62
- * Parses the ID prefix to determine the entry type (decision, pattern, learning,
63
- * or observation) and queries the corresponding brain.db table.
64
- *
65
- * @example
66
- * ```typescript
67
- * const result = await memoryShow('O-abc123', '/project');
68
- * if (result.success) console.log(result.data.type, result.data.entry);
69
- * ```
70
- */
71
- export async function memoryShow(entryId, projectRoot) {
72
- if (!entryId) {
73
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'entryId is required' } };
74
- }
75
- try {
76
- const root = resolveRoot(projectRoot);
77
- const entryType = parseIdPrefix(entryId);
78
- if (!entryType) {
79
- return {
80
- success: false,
81
- error: {
82
- code: 'E_INVALID_INPUT',
83
- message: `Unknown entry ID format: '${entryId}'. Expected prefix D-, P-, L-, or O-`,
84
- },
85
- };
86
- }
87
- const accessor = await getBrainAccessor(root);
88
- switch (entryType) {
89
- case 'decision': {
90
- const row = await accessor.getDecision(entryId);
91
- if (!row) {
92
- return {
93
- success: false,
94
- error: { code: 'E_NOT_FOUND', message: `Decision '${entryId}' not found in brain.db` },
95
- };
96
- }
97
- return { success: true, data: { type: 'decision', entry: row } };
98
- }
99
- case 'pattern': {
100
- const row = await accessor.getPattern(entryId);
101
- if (!row) {
102
- return {
103
- success: false,
104
- error: { code: 'E_NOT_FOUND', message: `Pattern '${entryId}' not found in brain.db` },
105
- };
106
- }
107
- return { success: true, data: { type: 'pattern', entry: row } };
108
- }
109
- case 'learning': {
110
- const row = await accessor.getLearning(entryId);
111
- if (!row) {
112
- return {
113
- success: false,
114
- error: { code: 'E_NOT_FOUND', message: `Learning '${entryId}' not found in brain.db` },
115
- };
116
- }
117
- return { success: true, data: { type: 'learning', entry: row } };
118
- }
119
- case 'observation': {
120
- const row = await accessor.getObservation(entryId);
121
- if (!row) {
122
- return {
123
- success: false,
124
- error: {
125
- code: 'E_NOT_FOUND',
126
- message: `Observation '${entryId}' not found in brain.db`,
127
- },
128
- };
129
- }
130
- return { success: true, data: { type: 'observation', entry: row } };
131
- }
132
- }
133
- }
134
- catch (error) {
135
- return {
136
- success: false,
137
- error: {
138
- code: 'E_BRAIN_SHOW',
139
- message: error instanceof Error ? error.message : String(error),
140
- },
141
- };
142
- }
143
- }
144
- // ============================================================================
145
- // Brain.db Aggregate Stats
146
- // ============================================================================
147
- /**
148
- * Aggregate stats from brain.db across all tables.
149
- *
150
- * @param projectRoot - Optional project root path; defaults to resolved root
151
- * @returns EngineResult with observation, decision, pattern, and learning counts
152
- *
153
- * @remarks
154
- * Queries each brain.db table for row counts and returns a combined statistics object.
155
- * Returns zero counts if brain.db is not initialized.
156
- *
157
- * @example
158
- * ```typescript
159
- * const result = await memoryBrainStats('/project');
160
- * if (result.success) console.log(result.data.observations);
161
- * ```
162
- */
163
- export async function memoryBrainStats(projectRoot) {
164
- try {
165
- const root = resolveRoot(projectRoot);
166
- const { getBrainDb, getBrainNativeDb } = await import('../store/brain-sqlite.js');
167
- await getBrainDb(root);
168
- const nativeDb = getBrainNativeDb();
169
- if (!nativeDb) {
170
- return {
171
- success: true,
172
- data: {
173
- observations: 0,
174
- decisions: 0,
175
- patterns: 0,
176
- learnings: 0,
177
- total: 0,
178
- message: 'brain.db not initialized',
179
- },
180
- };
181
- }
182
- const obsCount = nativeDb.prepare('SELECT COUNT(*) AS cnt FROM brain_observations').get().cnt;
183
- const decCount = nativeDb.prepare('SELECT COUNT(*) AS cnt FROM brain_decisions').get().cnt;
184
- const patCount = nativeDb.prepare('SELECT COUNT(*) AS cnt FROM brain_patterns').get().cnt;
185
- const learnCount = nativeDb.prepare('SELECT COUNT(*) AS cnt FROM brain_learnings').get().cnt;
186
- return {
187
- success: true,
188
- data: {
189
- observations: obsCount,
190
- decisions: decCount,
191
- patterns: patCount,
192
- learnings: learnCount,
193
- total: obsCount + decCount + patCount + learnCount,
194
- },
195
- };
196
- }
197
- catch (error) {
198
- return {
199
- success: false,
200
- error: {
201
- code: 'E_BRAIN_STATS',
202
- message: error instanceof Error ? error.message : String(error),
203
- },
204
- };
205
- }
206
- }
207
- // ============================================================================
208
- // Brain.db Decision Operations
209
- // ============================================================================
210
- /**
211
- * Search decisions in brain.db.
212
- *
213
- * @param params - Search parameters (query, limit, etc.)
214
- * @param projectRoot - Optional project root path; defaults to resolved root
215
- * @returns EngineResult with matching decision entries
216
- *
217
- * @remarks
218
- * Queries the brain.db decisions table with optional text filtering and pagination.
219
- *
220
- * @example
221
- * ```typescript
222
- * const result = await memoryDecisionFind({ query: 'auth' }, '/project');
223
- * ```
224
- */
225
- export async function memoryDecisionFind(params, projectRoot) {
226
- try {
227
- const root = resolveRoot(projectRoot);
228
- const accessor = await getBrainAccessor(root);
229
- if (params.query) {
230
- const { getBrainDb, getBrainNativeDb } = await import('../store/brain-sqlite.js');
231
- await getBrainDb(root);
232
- const nativeDb = getBrainNativeDb();
233
- if (!nativeDb) {
234
- return { success: true, data: { decisions: [], total: 0 } };
235
- }
236
- const likePattern = `%${params.query}%`;
237
- const limit = params.limit ?? 20;
238
- const rows = nativeDb
239
- .prepare(`
240
- SELECT * FROM brain_decisions
241
- WHERE decision LIKE ? OR rationale LIKE ?
242
- ORDER BY created_at DESC
243
- LIMIT ?
244
- `)
245
- .all(likePattern, likePattern, limit);
246
- return { success: true, data: { decisions: rows, total: rows.length } };
247
- }
248
- const decisions = await accessor.findDecisions({
249
- contextTaskId: params.taskId,
250
- limit: params.limit ?? 20,
251
- });
252
- return { success: true, data: { decisions, total: decisions.length } };
253
- }
254
- catch (error) {
255
- return {
256
- success: false,
257
- error: {
258
- code: 'E_DECISION_FIND',
259
- message: error instanceof Error ? error.message : String(error),
260
- },
261
- };
262
- }
263
- }
264
- /**
265
- * Store a decision to brain.db.
266
- *
267
- * @param params - Decision data including title, rationale, and alternatives
268
- * @param projectRoot - Optional project root path; defaults to resolved root
269
- * @returns EngineResult with the stored decision ID
270
- *
271
- * @remarks
272
- * Creates a new decision entry in brain.db with a D-prefixed ID.
273
- * Optionally refreshes the memory bridge after storing.
274
- *
275
- * @example
276
- * ```typescript
277
- * const result = await memoryDecisionStore({ title: 'Use SQLite', rationale: 'Embedded, fast' }, '/project');
278
- * ```
279
- */
280
- export async function memoryDecisionStore(params, projectRoot) {
281
- if (!params.decision) {
282
- return {
283
- success: false,
284
- error: { code: 'E_INVALID_INPUT', message: 'decision text is required' },
285
- };
286
- }
287
- if (!params.rationale) {
288
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'rationale is required' } };
289
- }
290
- try {
291
- const root = resolveRoot(projectRoot);
292
- const accessor = await getBrainAccessor(root);
293
- const now = new Date().toISOString().replace('T', ' ').slice(0, 19);
294
- const id = `D-${Date.now().toString(36)}`;
295
- const row = await accessor.addDecision({
296
- id,
297
- type: 'technical',
298
- decision: params.decision,
299
- rationale: params.rationale,
300
- confidence: 'medium',
301
- outcome: 'pending',
302
- alternativesJson: params.alternatives ? JSON.stringify(params.alternatives) : null,
303
- contextTaskId: params.taskId ?? null,
304
- contextEpicId: null,
305
- contextPhase: null,
306
- createdAt: now,
307
- });
308
- return {
309
- success: true,
310
- data: {
311
- id: row.id,
312
- type: row.type,
313
- decision: row.decision,
314
- createdAt: row.createdAt,
315
- },
316
- };
317
- }
318
- catch (error) {
319
- return {
320
- success: false,
321
- error: {
322
- code: 'E_DECISION_STORE',
323
- message: error instanceof Error ? error.message : String(error),
324
- },
325
- };
326
- }
327
- }
328
- // ============================================================================
329
- // BRAIN Retrieval Operations (T5131-T5135) — Renamed from brain.* to flat ops
330
- // ============================================================================
331
- /**
332
- * Token-efficient brain search returning compact results.
333
- *
334
- * @param params - Search parameters including query string and limit
335
- * @param projectRoot - Optional project root path; defaults to resolved root
336
- * @returns EngineResult with compact search hits (IDs and titles)
337
- *
338
- * @remarks
339
- * Designed for the cheapest-first retrieval pattern. Returns minimal fields
340
- * per hit to conserve tokens. Use memoryFetch for full entry details.
341
- *
342
- * @example
343
- * ```typescript
344
- * const result = await memoryFind({ query: 'authentication', limit: 10 }, '/project');
345
- * ```
346
- */
347
- export async function memoryFind(params, projectRoot) {
348
- try {
349
- const root = resolveRoot(projectRoot);
350
- const result = await searchBrainCompact(root, {
351
- query: params.query,
352
- limit: params.limit,
353
- tables: params.tables,
354
- dateStart: params.dateStart,
355
- dateEnd: params.dateEnd,
356
- });
357
- return { success: true, data: result };
358
- }
359
- catch (error) {
360
- return {
361
- success: false,
362
- error: {
363
- code: 'E_BRAIN_SEARCH',
364
- message: error instanceof Error ? error.message : String(error),
365
- },
366
- };
367
- }
368
- }
369
- /**
370
- * Chronological context around a brain entry anchor.
371
- *
372
- * @param params - Timeline parameters including anchor ID and window size
373
- * @param projectRoot - Optional project root path; defaults to resolved root
374
- * @returns EngineResult with chronologically ordered entries around the anchor
375
- *
376
- * @remarks
377
- * Retrieves entries before and after a given anchor ID for temporal context.
378
- * Useful for understanding the sequence of observations and decisions.
379
- *
380
- * @example
381
- * ```typescript
382
- * const result = await memoryTimeline({ anchorId: 'O-abc123', window: 5 }, '/project');
383
- * ```
384
- */
385
- export async function memoryTimeline(params, projectRoot) {
386
- try {
387
- const root = resolveRoot(projectRoot);
388
- const result = await timelineBrain(root, {
389
- anchor: params.anchor,
390
- depthBefore: params.depthBefore,
391
- depthAfter: params.depthAfter,
392
- });
393
- return { success: true, data: result };
394
- }
395
- catch (error) {
396
- return {
397
- success: false,
398
- error: {
399
- code: 'E_BRAIN_TIMELINE',
400
- message: error instanceof Error ? error.message : String(error),
401
- },
402
- };
403
- }
404
- }
405
- /**
406
- * Batch fetch brain entries by IDs.
407
- *
408
- * @param params - Fetch parameters including an array of entry IDs
409
- * @param projectRoot - Optional project root path; defaults to resolved root
410
- * @returns EngineResult with full entry details for each requested ID
411
- *
412
- * @remarks
413
- * Use after memoryFind to retrieve full details for specific entries.
414
- * Part of the 3-layer retrieval pattern: search -> filter -> fetch.
415
- *
416
- * @example
417
- * ```typescript
418
- * const result = await memoryFetch({ ids: ['O-abc123', 'D-def456'] }, '/project');
419
- * ```
420
- */
421
- export async function memoryFetch(params, projectRoot) {
422
- try {
423
- const root = resolveRoot(projectRoot);
424
- const result = await fetchBrainEntries(root, { ids: params.ids });
425
- return { success: true, data: result };
426
- }
427
- catch (error) {
428
- return {
429
- success: false,
430
- error: {
431
- code: 'E_BRAIN_FETCH',
432
- message: error instanceof Error ? error.message : String(error),
433
- },
434
- };
435
- }
436
- }
437
- /**
438
- * Save an observation to brain.db.
439
- *
440
- * @param params - Observation data including text, title, and optional tags
441
- * @param projectRoot - Optional project root path; defaults to resolved root
442
- * @returns EngineResult with the stored observation ID
443
- *
444
- * @remarks
445
- * Creates a new observation entry in brain.db with an O-prefixed ID.
446
- * Optionally refreshes the memory bridge after storing.
447
- *
448
- * @example
449
- * ```typescript
450
- * const result = await memoryObserve({ text: 'Auth uses JWT', title: 'Auth discovery' }, '/project');
451
- * ```
452
- */
453
- export async function memoryObserve(params, projectRoot) {
454
- try {
455
- const root = resolveRoot(projectRoot);
456
- const result = await observeBrain(root, {
457
- text: params.text,
458
- title: params.title,
459
- type: params.type,
460
- project: params.project,
461
- sourceSessionId: params.sourceSessionId,
462
- sourceType: params.sourceType,
463
- });
464
- return { success: true, data: result };
465
- }
466
- catch (error) {
467
- return {
468
- success: false,
469
- error: {
470
- code: 'E_BRAIN_OBSERVE',
471
- message: error instanceof Error ? error.message : String(error),
472
- },
473
- };
474
- }
475
- }
476
- // ============================================================================
477
- // BRAIN Pattern Operations (T4770)
478
- // ============================================================================
479
- /**
480
- * Store a pattern to BRAIN memory.
481
- *
482
- * @param params - Pattern data including pattern string, type, and confidence
483
- * @param projectRoot - Optional project root path; defaults to resolved root
484
- * @returns EngineResult with the stored pattern ID
485
- *
486
- * @remarks
487
- * Persists a detected pattern (success or failure) to brain.db for future scoring.
488
- *
489
- * @example
490
- * ```typescript
491
- * const result = await memoryPatternStore({ pattern: 'migration', type: 'success' }, '/project');
492
- * ```
493
- */
494
- export async function memoryPatternStore(params, projectRoot) {
495
- try {
496
- const root = resolveRoot(projectRoot);
497
- const result = await storePattern(root, params);
498
- return { success: true, data: result };
499
- }
500
- catch (error) {
501
- return {
502
- success: false,
503
- error: {
504
- code: 'E_PATTERN_STORE',
505
- message: error instanceof Error ? error.message : String(error),
506
- },
507
- };
508
- }
509
- }
510
- /**
511
- * Search patterns in BRAIN memory.
512
- *
513
- * @param params - Search parameters including query and type filter
514
- * @param projectRoot - Optional project root path; defaults to resolved root
515
- * @returns EngineResult with matching pattern entries
516
- *
517
- * @remarks
518
- * Queries the brain.db patterns table with optional type filtering.
519
- *
520
- * @example
521
- * ```typescript
522
- * const result = await memoryPatternFind({ type: 'success', limit: 10 }, '/project');
523
- * ```
524
- */
525
- export async function memoryPatternFind(params, projectRoot) {
526
- try {
527
- const root = resolveRoot(projectRoot);
528
- const results = await searchPatterns(root, params);
529
- return { success: true, data: { patterns: results, total: results.length } };
530
- }
531
- catch (error) {
532
- return {
533
- success: false,
534
- error: {
535
- code: 'E_PATTERN_SEARCH',
536
- message: error instanceof Error ? error.message : String(error),
537
- },
538
- };
539
- }
540
- }
541
- /**
542
- * Get pattern memory statistics.
543
- *
544
- * @param projectRoot - Optional project root path; defaults to resolved root
545
- * @returns EngineResult with pattern counts by type and overall totals
546
- *
547
- * @remarks
548
- * Aggregates pattern data from brain.db to provide type distribution and counts.
549
- *
550
- * @example
551
- * ```typescript
552
- * const result = await memoryPatternStats('/project');
553
- * ```
554
- */
555
- export async function memoryPatternStats(projectRoot) {
556
- try {
557
- const root = resolveRoot(projectRoot);
558
- const stats = await patternStats(root);
559
- return { success: true, data: stats };
560
- }
561
- catch (error) {
562
- return {
563
- success: false,
564
- error: {
565
- code: 'E_PATTERN_STATS',
566
- message: error instanceof Error ? error.message : String(error),
567
- },
568
- };
569
- }
570
- }
571
- // ============================================================================
572
- // BRAIN Learning Operations (T4770)
573
- // ============================================================================
574
- /**
575
- * Store a learning to BRAIN memory.
576
- *
577
- * @param params - Learning data including text and confidence level
578
- * @param projectRoot - Optional project root path; defaults to resolved root
579
- * @returns EngineResult with the stored learning ID
580
- *
581
- * @remarks
582
- * Creates a new learning entry in brain.db with an L-prefixed ID.
583
- *
584
- * @example
585
- * ```typescript
586
- * const result = await memoryLearningStore({ text: 'Drizzle v1 requires beta flag' }, '/project');
587
- * ```
588
- */
589
- export async function memoryLearningStore(params, projectRoot) {
590
- try {
591
- const root = resolveRoot(projectRoot);
592
- const result = await storeLearning(root, params);
593
- return { success: true, data: result };
594
- }
595
- catch (error) {
596
- return {
597
- success: false,
598
- error: {
599
- code: 'E_LEARNING_STORE',
600
- message: error instanceof Error ? error.message : String(error),
601
- },
602
- };
603
- }
604
- }
605
- /**
606
- * Search learnings in BRAIN memory.
607
- *
608
- * @param params - Search parameters including query and limit
609
- * @param projectRoot - Optional project root path; defaults to resolved root
610
- * @returns EngineResult with matching learning entries
611
- *
612
- * @remarks
613
- * Queries the brain.db learnings table with optional text filtering.
614
- *
615
- * @example
616
- * ```typescript
617
- * const result = await memoryLearningFind({ query: 'drizzle' }, '/project');
618
- * ```
619
- */
620
- export async function memoryLearningFind(params, projectRoot) {
621
- try {
622
- const root = resolveRoot(projectRoot);
623
- const results = await searchLearnings(root, params);
624
- return { success: true, data: { learnings: results, total: results.length } };
625
- }
626
- catch (error) {
627
- return {
628
- success: false,
629
- error: {
630
- code: 'E_LEARNING_SEARCH',
631
- message: error instanceof Error ? error.message : String(error),
632
- },
633
- };
634
- }
635
- }
636
- /**
637
- * Get learning memory statistics.
638
- *
639
- * @param projectRoot - Optional project root path; defaults to resolved root
640
- * @returns EngineResult with learning counts and confidence distribution
641
- *
642
- * @remarks
643
- * Aggregates learning data from brain.db to provide totals and breakdowns.
644
- *
645
- * @example
646
- * ```typescript
647
- * const result = await memoryLearningStats('/project');
648
- * ```
649
- */
650
- export async function memoryLearningStats(projectRoot) {
651
- try {
652
- const root = resolveRoot(projectRoot);
653
- const stats = await learningStats(root);
654
- return { success: true, data: stats };
655
- }
656
- catch (error) {
657
- return {
658
- success: false,
659
- error: {
660
- code: 'E_LEARNING_STATS',
661
- message: error instanceof Error ? error.message : String(error),
662
- },
663
- };
664
- }
665
- }
666
- // ============================================================================
667
- // BRAIN Advanced Queries & Links (T5241)
668
- // ============================================================================
669
- /**
670
- * Find contradictory entries in brain.db.
671
- *
672
- * @param projectRoot - Optional project root path; defaults to resolved root
673
- * @returns EngineResult with pairs of contradicting observations
674
- *
675
- * @remarks
676
- * Scans brain.db for observations that contradict each other based on
677
- * semantic similarity and opposing sentiment or content.
678
- *
679
- * @example
680
- * ```typescript
681
- * const result = await memoryContradictions('/project');
682
- * if (result.success) console.log(result.data.contradictions);
683
- * ```
684
- */
685
- export async function memoryContradictions(projectRoot) {
686
- try {
687
- const root = resolveRoot(projectRoot);
688
- const { getBrainDb, getBrainNativeDb } = await import('../store/brain-sqlite.js');
689
- await getBrainDb(root);
690
- const nativeDb = getBrainNativeDb();
691
- if (!nativeDb) {
692
- return { success: true, data: { contradictions: [] } };
693
- }
694
- // Negation patterns for detecting contradictions (adapted from manifest logic)
695
- const negationPairs = [
696
- [/\bdoes NOT\b/i, /\bdoes\b(?!.*\bnot\b)/i],
697
- [/\bcannot\b/i, /\bcan\b(?!.*\bnot\b)/i],
698
- [/\bno\s+\w+\s+required\b/i, /\brequired\b(?!.*\bno\b)/i],
699
- [
700
- /\bnot\s+(?:available|supported|possible|recommended)\b/i,
701
- /\b(?:available|supported|possible|recommended)\b(?!.*\bnot\b)/i,
702
- ],
703
- [/\bwithout\b/i, /\brequires?\b/i],
704
- [/\bavoid\b/i, /\buse\b/i],
705
- [/\bdeprecated\b/i, /\brecommended\b/i],
706
- [/\banti-pattern\b/i, /\bbest practice\b/i],
707
- ];
708
- // Fetch all decisions with context for comparison
709
- const decisions = nativeDb
710
- .prepare(`
711
- SELECT id, type, decision, rationale, context_task_id, created_at
712
- FROM brain_decisions
713
- ORDER BY created_at DESC
714
- `)
715
- .all();
716
- // Fetch all patterns
717
- const patterns = nativeDb
718
- .prepare(`
719
- SELECT id, type, pattern, context, anti_pattern, created_at
720
- FROM brain_patterns
721
- ORDER BY created_at DESC
722
- `)
723
- .all();
724
- // Fetch all learnings
725
- const learnings = nativeDb
726
- .prepare(`
727
- SELECT id, insight, source, created_at
728
- FROM brain_learnings
729
- ORDER BY created_at DESC
730
- `)
731
- .all();
732
- const contradictions = [];
733
- const seenPairs = new Set();
734
- // Helper to create sorted pair key
735
- const pairKey = (idA, idB) => (idA < idB ? `${idA}::${idB}` : `${idB}::${idA}`);
736
- // Check decisions against each other (grouped by task context)
737
- const decisionsByTask = new Map();
738
- for (const d of decisions) {
739
- const key = d.context_task_id;
740
- if (!decisionsByTask.has(key))
741
- decisionsByTask.set(key, []);
742
- decisionsByTask.get(key).push(d);
743
- }
744
- for (const [taskId, taskDecisions] of decisionsByTask) {
745
- if (taskDecisions.length < 2)
746
- continue;
747
- for (let i = 0; i < taskDecisions.length; i++) {
748
- for (let j = i + 1; j < taskDecisions.length; j++) {
749
- const a = taskDecisions[i];
750
- const b = taskDecisions[j];
751
- const key = pairKey(a.id, b.id);
752
- if (seenPairs.has(key))
753
- continue;
754
- const contentA = `${a.decision} ${a.rationale}`;
755
- const contentB = `${b.decision} ${b.rationale}`;
756
- for (const [patternNeg, patternPos] of negationPairs) {
757
- if ((patternNeg.test(contentA) && patternPos.test(contentB)) ||
758
- (patternPos.test(contentA) && patternNeg.test(contentB))) {
759
- seenPairs.add(key);
760
- contradictions.push({
761
- entryA: {
762
- id: a.id,
763
- type: 'decision',
764
- content: a.decision,
765
- createdAt: a.created_at,
766
- },
767
- entryB: {
768
- id: b.id,
769
- type: 'decision',
770
- content: b.decision,
771
- createdAt: b.created_at,
772
- },
773
- context: taskId || undefined,
774
- conflictDetails: `Negation pattern: "${contentA.slice(0, 80)}..." vs "${contentB.slice(0, 80)}..."`,
775
- });
776
- break;
777
- }
778
- }
779
- }
780
- }
781
- }
782
- // Check patterns with anti-patterns
783
- for (const p of patterns) {
784
- if (p.anti_pattern) {
785
- contradictions.push({
786
- entryA: { id: p.id, type: 'pattern', content: p.pattern, createdAt: p.created_at },
787
- entryB: {
788
- id: p.id,
789
- type: 'anti-pattern',
790
- content: p.anti_pattern,
791
- createdAt: p.created_at,
792
- },
793
- conflictDetails: `Pattern defines its own anti-pattern`,
794
- });
795
- }
796
- }
797
- // Check learnings against each other
798
- for (let i = 0; i < learnings.length; i++) {
799
- for (let j = i + 1; j < learnings.length; j++) {
800
- const a = learnings[i];
801
- const b = learnings[j];
802
- const key = pairKey(a.id, b.id);
803
- if (seenPairs.has(key))
804
- continue;
805
- for (const [patternNeg, patternPos] of negationPairs) {
806
- if ((patternNeg.test(a.insight) && patternPos.test(b.insight)) ||
807
- (patternPos.test(a.insight) && patternNeg.test(b.insight))) {
808
- seenPairs.add(key);
809
- contradictions.push({
810
- entryA: { id: a.id, type: 'learning', content: a.insight, createdAt: a.created_at },
811
- entryB: { id: b.id, type: 'learning', content: b.insight, createdAt: b.created_at },
812
- conflictDetails: `Learning contradiction detected`,
813
- });
814
- break;
815
- }
816
- }
817
- }
818
- }
819
- return { success: true, data: { contradictions } };
820
- }
821
- catch (error) {
822
- return {
823
- success: false,
824
- error: {
825
- code: 'E_CONTRADICTIONS',
826
- message: error instanceof Error ? error.message : String(error),
827
- },
828
- };
829
- }
830
- }
831
- /**
832
- * Find superseded entries in brain.db.
833
- *
834
- * Identifies entries that have been superseded by newer entries on the same topic.
835
- *
836
- * @param params - Superseded search parameters
837
- * @param projectRoot - Optional project root path; defaults to resolved root
838
- * @returns EngineResult with superseded entry pairs and their replacements
839
- *
840
- * @remarks
841
- * Scans brain.db for entries where a newer observation or decision covers
842
- * the same topic, rendering the older entry obsolete.
843
- *
844
- * For brain.db, we group by:
845
- * - Decisions: type + contextTaskId/contextEpicId
846
- * - Patterns: type + context (first 100 chars for similarity)
847
- * - Learnings: source + applicableTypes
848
- * - Observations: type + project
849
- *
850
- * @example
851
- * ```typescript
852
- * const result = await memorySuperseded({ type: 'decision' }, '/project');
853
- * ```
854
- */
855
- export async function memorySuperseded(params, projectRoot) {
856
- try {
857
- const root = resolveRoot(projectRoot);
858
- const { getBrainDb, getBrainNativeDb } = await import('../store/brain-sqlite.js');
859
- await getBrainDb(root);
860
- const nativeDb = getBrainNativeDb();
861
- if (!nativeDb) {
862
- return { success: true, data: { superseded: [] } };
863
- }
864
- const superseded = [];
865
- // Helper to normalize and group by key
866
- const addSuperseded = (entries, groupKey) => {
867
- if (entries.length < 2)
868
- return;
869
- // Sort by creation date (oldest first)
870
- const sorted = [...entries].sort((a, b) => a.createdAt.localeCompare(b.createdAt));
871
- // All but the newest are superseded by the newest
872
- const newest = sorted[sorted.length - 1];
873
- for (let i = 0; i < sorted.length - 1; i++) {
874
- superseded.push({
875
- oldEntry: sorted[i],
876
- replacement: newest,
877
- grouping: groupKey,
878
- });
879
- }
880
- };
881
- // === DECISIONS: Group by type + contextTaskId/contextEpicId ===
882
- const decisionGroups = new Map();
883
- const decisionQuery = params?.type
884
- ? `SELECT id, type, decision, context_task_id, context_epic_id, created_at
885
- FROM brain_decisions WHERE type = ? ORDER BY created_at DESC`
886
- : `SELECT id, type, decision, context_task_id, context_epic_id, created_at
887
- FROM brain_decisions ORDER BY created_at DESC`;
888
- const decisionParams = params?.type ? [params.type] : [];
889
- const decisions = nativeDb.prepare(decisionQuery).all(...decisionParams);
890
- for (const d of decisions) {
891
- const contextKey = d.context_task_id || d.context_epic_id || 'general';
892
- const groupKey = `decision:${d.type}:${contextKey}`;
893
- if (!decisionGroups.has(groupKey))
894
- decisionGroups.set(groupKey, []);
895
- decisionGroups.get(groupKey).push({
896
- id: d.id,
897
- type: d.type,
898
- createdAt: d.created_at,
899
- summary: d.decision.slice(0, 100),
900
- });
901
- }
902
- for (const [key, entries] of decisionGroups) {
903
- addSuperseded(entries, key);
904
- }
905
- // === PATTERNS: Group by type + context (first 100 chars for similarity) ===
906
- const patternGroups = new Map();
907
- const patternQuery = params?.type
908
- ? `SELECT id, type, pattern, context, extracted_at
909
- FROM brain_patterns WHERE type = ? ORDER BY extracted_at DESC`
910
- : `SELECT id, type, pattern, context, extracted_at
911
- FROM brain_patterns ORDER BY extracted_at DESC`;
912
- const patternParams = params?.type ? [params.type] : [];
913
- const patterns = nativeDb.prepare(patternQuery).all(...patternParams);
914
- for (const p of patterns) {
915
- // Use first 80 chars of context as grouping key for similarity
916
- const contextKey = p.context?.slice(0, 80) || 'unknown';
917
- const groupKey = `pattern:${p.type}:${contextKey}`;
918
- if (!patternGroups.has(groupKey))
919
- patternGroups.set(groupKey, []);
920
- patternGroups.get(groupKey).push({
921
- id: p.id,
922
- type: p.type,
923
- createdAt: p.extracted_at,
924
- summary: p.pattern.slice(0, 100),
925
- });
926
- }
927
- for (const [key, entries] of patternGroups) {
928
- addSuperseded(entries, key);
929
- }
930
- // === LEARNINGS: Group by source + applicableTypes ===
931
- const learningGroups = new Map();
932
- const learningQuery = `SELECT id, source, insight, applicable_types_json, created_at
933
- FROM brain_learnings ORDER BY created_at DESC`;
934
- const learnings = nativeDb.prepare(learningQuery).all();
935
- for (const l of learnings) {
936
- const applicableTypes = l.applicable_types_json
937
- ? JSON.parse(l.applicable_types_json).slice(0, 2).join(',')
938
- : 'general';
939
- const groupKey = `learning:${l.source}:${applicableTypes}`;
940
- if (!learningGroups.has(groupKey))
941
- learningGroups.set(groupKey, []);
942
- learningGroups.get(groupKey).push({
943
- id: l.id,
944
- type: 'learning',
945
- createdAt: l.created_at,
946
- summary: l.insight.slice(0, 100),
947
- });
948
- }
949
- for (const [key, entries] of learningGroups) {
950
- addSuperseded(entries, key);
951
- }
952
- // === OBSERVATIONS: Group by type + project ===
953
- const observationGroups = new Map();
954
- const observationQuery = params?.type
955
- ? `SELECT id, type, title, project, created_at
956
- FROM brain_observations WHERE type = ? ORDER BY created_at DESC`
957
- : `SELECT id, type, title, project, created_at
958
- FROM brain_observations ORDER BY created_at DESC`;
959
- const observationParams = params?.type ? [params.type] : [];
960
- const observations = nativeDb.prepare(observationQuery).all(...observationParams);
961
- for (const o of observations) {
962
- const projectKey = params?.project ? params.project : o.project || 'general';
963
- const groupKey = `observation:${o.type}:${projectKey}`;
964
- if (!observationGroups.has(groupKey))
965
- observationGroups.set(groupKey, []);
966
- observationGroups.get(groupKey).push({
967
- id: o.id,
968
- type: o.type,
969
- createdAt: o.created_at,
970
- summary: o.title.slice(0, 100),
971
- });
972
- }
973
- for (const [key, entries] of observationGroups) {
974
- addSuperseded(entries, key);
975
- }
976
- return { success: true, data: { superseded, total: superseded.length } };
977
- }
978
- catch (error) {
979
- return {
980
- success: false,
981
- error: {
982
- code: 'E_MEMORY_SUPERSEDED',
983
- message: error instanceof Error ? error.message : String(error),
984
- },
985
- };
986
- }
987
- }
988
- /**
989
- * Link a brain entry to a task.
990
- *
991
- * @param params - Link parameters including entryId and taskId
992
- * @param projectRoot - Optional project root path; defaults to resolved root
993
- * @returns EngineResult confirming the link was created
994
- *
995
- * @remarks
996
- * Creates an association between a brain.db entry and a task in tasks.db.
997
- * Used for traceability between memory entries and the work they relate to.
998
- *
999
- * @example
1000
- * ```typescript
1001
- * const result = await memoryLink({ entryId: 'O-abc123', taskId: 'T042' }, '/project');
1002
- * ```
1003
- */
1004
- export async function memoryLink(params, projectRoot) {
1005
- if (!params.taskId || !params.entryId) {
1006
- return {
1007
- success: false,
1008
- error: { code: 'E_INVALID_INPUT', message: 'taskId and entryId are required' },
1009
- };
1010
- }
1011
- const entryType = parseIdPrefix(params.entryId);
1012
- if (!entryType) {
1013
- return {
1014
- success: false,
1015
- error: { code: 'E_INVALID_INPUT', message: 'Invalid entryId format' },
1016
- };
1017
- }
1018
- try {
1019
- const root = resolveRoot(projectRoot);
1020
- await linkMemoryToTask(root, entryType, params.entryId, params.taskId, 'applies_to');
1021
- return {
1022
- success: true,
1023
- data: { linked: true, taskId: params.taskId, entryId: params.entryId },
1024
- };
1025
- }
1026
- catch (error) {
1027
- return {
1028
- success: false,
1029
- error: {
1030
- code: 'E_MEMORY_LINK',
1031
- message: error instanceof Error ? error.message : String(error),
1032
- },
1033
- };
1034
- }
1035
- }
1036
- /**
1037
- * Remove a link between a brain entry and a task.
1038
- *
1039
- * @param params - Unlink parameters including entryId and taskId
1040
- * @param projectRoot - Optional project root path; defaults to resolved root
1041
- * @returns EngineResult confirming the link was removed
1042
- *
1043
- * @remarks
1044
- * Removes the association created by memoryLink. Idempotent if the link
1045
- * does not exist.
1046
- *
1047
- * @example
1048
- * ```typescript
1049
- * const result = await memoryUnlink({ entryId: 'O-abc123', taskId: 'T042' }, '/project');
1050
- * ```
1051
- */
1052
- export async function memoryUnlink(params, projectRoot) {
1053
- if (!params.taskId || !params.entryId) {
1054
- return {
1055
- success: false,
1056
- error: { code: 'E_INVALID_INPUT', message: 'taskId and entryId are required' },
1057
- };
1058
- }
1059
- const entryType = parseIdPrefix(params.entryId);
1060
- if (!entryType) {
1061
- return {
1062
- success: false,
1063
- error: { code: 'E_INVALID_INPUT', message: 'Invalid entryId format' },
1064
- };
1065
- }
1066
- try {
1067
- const root = resolveRoot(projectRoot);
1068
- await unlinkMemoryFromTask(root, entryType, params.entryId, params.taskId, 'applies_to');
1069
- return {
1070
- success: true,
1071
- data: { unlinked: true, taskId: params.taskId, entryId: params.entryId },
1072
- };
1073
- }
1074
- catch (error) {
1075
- return {
1076
- success: false,
1077
- error: {
1078
- code: 'E_MEMORY_UNLINK',
1079
- message: error instanceof Error ? error.message : String(error),
1080
- },
1081
- };
1082
- }
1083
- }
1084
- // ============================================================================
1085
- // PageIndex Graph Operations (T5385)
1086
- // ============================================================================
1087
- /**
1088
- * Add a node or edge to the PageIndex graph.
1089
- *
1090
- * @param params - Graph add parameters (node data or edge endpoints)
1091
- * @param projectRoot - Optional project root path; defaults to resolved root
1092
- * @returns EngineResult confirming the node or edge was added
1093
- *
1094
- * @remarks
1095
- * Supports adding both nodes (concepts) and edges (relationships) to the
1096
- * brain.db knowledge graph (PageIndex).
1097
- *
1098
- * @example
1099
- * ```typescript
1100
- * const result = await memoryGraphAdd({ type: 'node', label: 'auth', nodeType: 'concept' }, '/project');
1101
- * ```
1102
- */
1103
- export async function memoryGraphAdd(params, projectRoot) {
1104
- try {
1105
- const root = resolveRoot(projectRoot);
1106
- const accessor = await getBrainAccessor(root);
1107
- // Edge mode: fromId + toId + edgeType
1108
- if (params.fromId && params.toId && params.edgeType) {
1109
- const edge = await accessor.addPageEdge({
1110
- fromId: params.fromId,
1111
- toId: params.toId,
1112
- edgeType: params.edgeType,
1113
- weight: params.weight,
1114
- });
1115
- return { success: true, data: { type: 'edge', edge } };
1116
- }
1117
- // Node mode: nodeId + nodeType + label
1118
- if (params.nodeId && params.nodeType && params.label) {
1119
- const node = await accessor.addPageNode({
1120
- id: params.nodeId,
1121
- nodeType: params.nodeType,
1122
- label: params.label,
1123
- metadataJson: params.metadataJson,
1124
- });
1125
- return { success: true, data: { type: 'node', node } };
1126
- }
1127
- return {
1128
- success: false,
1129
- error: {
1130
- code: 'E_INVALID_INPUT',
1131
- message: 'Provide (nodeId + nodeType + label) for a node or (fromId + toId + edgeType) for an edge',
1132
- },
1133
- };
1134
- }
1135
- catch (error) {
1136
- return {
1137
- success: false,
1138
- error: {
1139
- code: 'E_GRAPH_ADD',
1140
- message: error instanceof Error ? error.message : String(error),
1141
- },
1142
- };
1143
- }
1144
- }
1145
- /**
1146
- * Get a node and its edges from the PageIndex graph.
1147
- *
1148
- * @param params - Parameters including the node ID to look up
1149
- * @param projectRoot - Optional project root path; defaults to resolved root
1150
- * @returns EngineResult with the node data and its connected edges
1151
- *
1152
- * @remarks
1153
- * Returns the full node record plus all edges where the node appears as
1154
- * either source or target.
1155
- *
1156
- * @example
1157
- * ```typescript
1158
- * const result = await memoryGraphShow({ nodeId: 'auth' }, '/project');
1159
- * ```
1160
- */
1161
- export async function memoryGraphShow(params, projectRoot) {
1162
- if (!params.nodeId) {
1163
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'nodeId is required' } };
1164
- }
1165
- try {
1166
- const root = resolveRoot(projectRoot);
1167
- const accessor = await getBrainAccessor(root);
1168
- const node = await accessor.getPageNode(params.nodeId);
1169
- if (!node) {
1170
- return {
1171
- success: false,
1172
- error: { code: 'E_NOT_FOUND', message: `Node '${params.nodeId}' not found` },
1173
- };
1174
- }
1175
- const edges = await accessor.getPageEdges(params.nodeId, 'both');
1176
- return { success: true, data: { node, edges } };
1177
- }
1178
- catch (error) {
1179
- return {
1180
- success: false,
1181
- error: {
1182
- code: 'E_GRAPH_SHOW',
1183
- message: error instanceof Error ? error.message : String(error),
1184
- },
1185
- };
1186
- }
1187
- }
1188
- /**
1189
- * Get neighbor nodes from the PageIndex graph.
1190
- *
1191
- * @param params - Parameters including the node ID and optional depth
1192
- * @param projectRoot - Optional project root path; defaults to resolved root
1193
- * @returns EngineResult with neighboring nodes and connecting edges
1194
- *
1195
- * @remarks
1196
- * Traverses the knowledge graph outward from a given node to find related
1197
- * concepts within the specified depth.
1198
- *
1199
- * @example
1200
- * ```typescript
1201
- * const result = await memoryGraphNeighbors({ nodeId: 'auth', depth: 2 }, '/project');
1202
- * ```
1203
- */
1204
- export async function memoryGraphNeighbors(params, projectRoot) {
1205
- if (!params.nodeId) {
1206
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'nodeId is required' } };
1207
- }
1208
- try {
1209
- const root = resolveRoot(projectRoot);
1210
- const accessor = await getBrainAccessor(root);
1211
- const neighbors = await accessor.getNeighbors(params.nodeId, params.edgeType);
1212
- return { success: true, data: { neighbors, total: neighbors.length } };
1213
- }
1214
- catch (error) {
1215
- return {
1216
- success: false,
1217
- error: {
1218
- code: 'E_GRAPH_NEIGHBORS',
1219
- message: error instanceof Error ? error.message : String(error),
1220
- },
1221
- };
1222
- }
1223
- }
1224
- // ============================================================================
1225
- // BRAIN Reasoning & Hybrid Search Operations (T5388-T5393)
1226
- // ============================================================================
1227
- /**
1228
- * Causal trace through task dependency chains.
1229
- *
1230
- * @param params - Parameters including the entry or task ID to trace
1231
- * @param projectRoot - Optional project root path; defaults to resolved root
1232
- * @returns EngineResult with the causal chain explaining why something happened
1233
- *
1234
- * @remarks
1235
- * Traces backward through task dependencies and brain entries to build
1236
- * an explanation chain for a given decision or observation.
1237
- *
1238
- * @example
1239
- * ```typescript
1240
- * const result = await memoryReasonWhy({ id: 'D-abc123' }, '/project');
1241
- * ```
1242
- */
1243
- export async function memoryReasonWhy(params, projectRoot) {
1244
- if (!params.taskId) {
1245
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'taskId is required' } };
1246
- }
1247
- try {
1248
- const root = resolveRoot(projectRoot);
1249
- const taskAccessor = await getAccessor(root);
1250
- const { reasonWhy } = await import('./brain-reasoning.js');
1251
- const result = await reasonWhy(params.taskId, root, taskAccessor);
1252
- return { success: true, data: result };
1253
- }
1254
- catch (error) {
1255
- return {
1256
- success: false,
1257
- error: {
1258
- code: 'E_REASON_WHY',
1259
- message: error instanceof Error ? error.message : String(error),
1260
- },
1261
- };
1262
- }
1263
- }
1264
- /**
1265
- * Find semantically similar entries.
1266
- *
1267
- * @param params - Parameters including the source entry ID or query text
1268
- * @param projectRoot - Optional project root path; defaults to resolved root
1269
- * @returns EngineResult with entries ranked by semantic similarity
1270
- *
1271
- * @remarks
1272
- * Uses embedding vectors or text similarity to find brain entries that are
1273
- * semantically close to the given reference.
1274
- *
1275
- * @example
1276
- * ```typescript
1277
- * const result = await memoryReasonSimilar({ id: 'O-abc123', limit: 5 }, '/project');
1278
- * ```
1279
- */
1280
- export async function memoryReasonSimilar(params, projectRoot) {
1281
- if (!params.entryId) {
1282
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'entryId is required' } };
1283
- }
1284
- try {
1285
- const root = resolveRoot(projectRoot);
1286
- const { reasonSimilar } = await import('./brain-reasoning.js');
1287
- const results = await reasonSimilar(params.entryId, root, params.limit);
1288
- return { success: true, data: { results, total: results.length } };
1289
- }
1290
- catch (error) {
1291
- return {
1292
- success: false,
1293
- error: {
1294
- code: 'E_REASON_SIMILAR',
1295
- message: error instanceof Error ? error.message : String(error),
1296
- },
1297
- };
1298
- }
1299
- }
1300
- /**
1301
- * Hybrid search across FTS5, vector, and graph.
1302
- *
1303
- * @param params - Search parameters including query and optional mode/limit
1304
- * @param projectRoot - Optional project root path; defaults to resolved root
1305
- * @returns EngineResult with merged and ranked results from all search backends
1306
- *
1307
- * @remarks
1308
- * Combines full-text search (FTS5), vector similarity, and graph traversal
1309
- * to produce comprehensive search results with merged relevance scoring.
1310
- *
1311
- * @example
1312
- * ```typescript
1313
- * const result = await memorySearchHybrid({ query: 'authentication flow' }, '/project');
1314
- * ```
1315
- */
1316
- export async function memorySearchHybrid(params, projectRoot) {
1317
- if (!params.query) {
1318
- return { success: false, error: { code: 'E_INVALID_INPUT', message: 'query is required' } };
1319
- }
1320
- try {
1321
- const root = resolveRoot(projectRoot);
1322
- const { hybridSearch } = await import('./brain-search.js');
1323
- const results = await hybridSearch(params.query, root, {
1324
- ftsWeight: params.ftsWeight,
1325
- vecWeight: params.vecWeight,
1326
- graphWeight: params.graphWeight,
1327
- limit: params.limit,
1328
- });
1329
- return { success: true, data: { results, total: results.length } };
1330
- }
1331
- catch (error) {
1332
- return {
1333
- success: false,
1334
- error: {
1335
- code: 'E_HYBRID_SEARCH',
1336
- message: error instanceof Error ? error.message : String(error),
1337
- },
1338
- };
1339
- }
1340
- }
1341
- /**
1342
- * Remove a node or edge from the PageIndex graph.
1343
- *
1344
- * @param params - Parameters specifying the node or edge to remove
1345
- * @param projectRoot - Optional project root path; defaults to resolved root
1346
- * @returns EngineResult confirming the removal
1347
- *
1348
- * @remarks
1349
- * Removes a node (and its connected edges) or a specific edge from the
1350
- * brain.db knowledge graph.
1351
- *
1352
- * @example
1353
- * ```typescript
1354
- * const result = await memoryGraphRemove({ type: 'node', nodeId: 'stale-concept' }, '/project');
1355
- * ```
1356
- */
1357
- export async function memoryGraphRemove(params, projectRoot) {
1358
- try {
1359
- const root = resolveRoot(projectRoot);
1360
- const accessor = await getBrainAccessor(root);
1361
- // Edge removal: fromId + toId + edgeType
1362
- if (params.fromId && params.toId && params.edgeType) {
1363
- await accessor.removePageEdge(params.fromId, params.toId, params.edgeType);
1364
- return {
1365
- success: true,
1366
- data: {
1367
- removed: 'edge',
1368
- fromId: params.fromId,
1369
- toId: params.toId,
1370
- edgeType: params.edgeType,
1371
- },
1372
- };
1373
- }
1374
- // Node removal: nodeId (cascades edges)
1375
- if (params.nodeId) {
1376
- await accessor.removePageNode(params.nodeId);
1377
- return { success: true, data: { removed: 'node', nodeId: params.nodeId } };
1378
- }
1379
- return {
1380
- success: false,
1381
- error: {
1382
- code: 'E_INVALID_INPUT',
1383
- message: 'Provide nodeId to remove a node or (fromId + toId + edgeType) to remove an edge',
1384
- },
1385
- };
1386
- }
1387
- catch (error) {
1388
- return {
1389
- success: false,
1390
- error: {
1391
- code: 'E_GRAPH_REMOVE',
1392
- message: error instanceof Error ? error.message : String(error),
1393
- },
1394
- };
1395
- }
1396
- }
1397
- //# sourceMappingURL=engine-compat.js.map