@co-engram/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (531) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +167 -0
  3. package/dist/config/defaults.d.ts +45 -0
  4. package/dist/config/defaults.d.ts.map +1 -0
  5. package/dist/config/defaults.js +70 -0
  6. package/dist/config/defaults.js.map +1 -0
  7. package/dist/config/index.d.ts +84 -0
  8. package/dist/config/index.d.ts.map +1 -0
  9. package/dist/config/index.js +230 -0
  10. package/dist/config/index.js.map +1 -0
  11. package/dist/config/types.d.ts +145 -0
  12. package/dist/config/types.d.ts.map +1 -0
  13. package/dist/config/types.js +14 -0
  14. package/dist/config/types.js.map +1 -0
  15. package/dist/contradiction/arbiter.d.ts +51 -0
  16. package/dist/contradiction/arbiter.d.ts.map +1 -0
  17. package/dist/contradiction/arbiter.js +112 -0
  18. package/dist/contradiction/arbiter.js.map +1 -0
  19. package/dist/contradiction/auto-degrade.d.ts +53 -0
  20. package/dist/contradiction/auto-degrade.d.ts.map +1 -0
  21. package/dist/contradiction/auto-degrade.js +79 -0
  22. package/dist/contradiction/auto-degrade.js.map +1 -0
  23. package/dist/contradiction/detector.d.ts +33 -0
  24. package/dist/contradiction/detector.d.ts.map +1 -0
  25. package/dist/contradiction/detector.js +76 -0
  26. package/dist/contradiction/detector.js.map +1 -0
  27. package/dist/contradiction/index.d.ts +11 -0
  28. package/dist/contradiction/index.d.ts.map +1 -0
  29. package/dist/contradiction/index.js +11 -0
  30. package/dist/contradiction/index.js.map +1 -0
  31. package/dist/contradiction/resolver.d.ts +45 -0
  32. package/dist/contradiction/resolver.d.ts.map +1 -0
  33. package/dist/contradiction/resolver.js +196 -0
  34. package/dist/contradiction/resolver.js.map +1 -0
  35. package/dist/contradiction/types.d.ts +73 -0
  36. package/dist/contradiction/types.d.ts.map +1 -0
  37. package/dist/contradiction/types.js +7 -0
  38. package/dist/contradiction/types.js.map +1 -0
  39. package/dist/dedup/dedupe.d.ts +49 -0
  40. package/dist/dedup/dedupe.d.ts.map +1 -0
  41. package/dist/dedup/dedupe.js +111 -0
  42. package/dist/dedup/dedupe.js.map +1 -0
  43. package/dist/dedup/hash.d.ts +27 -0
  44. package/dist/dedup/hash.d.ts.map +1 -0
  45. package/dist/dedup/hash.js +43 -0
  46. package/dist/dedup/hash.js.map +1 -0
  47. package/dist/dedup/index.d.ts +12 -0
  48. package/dist/dedup/index.d.ts.map +1 -0
  49. package/dist/dedup/index.js +12 -0
  50. package/dist/dedup/index.js.map +1 -0
  51. package/dist/dedup/llm-triage.d.ts +48 -0
  52. package/dist/dedup/llm-triage.d.ts.map +1 -0
  53. package/dist/dedup/llm-triage.js +100 -0
  54. package/dist/dedup/llm-triage.js.map +1 -0
  55. package/dist/dedup/merge.d.ts +41 -0
  56. package/dist/dedup/merge.d.ts.map +1 -0
  57. package/dist/dedup/merge.js +55 -0
  58. package/dist/dedup/merge.js.map +1 -0
  59. package/dist/dedup/similar.d.ts +45 -0
  60. package/dist/dedup/similar.d.ts.map +1 -0
  61. package/dist/dedup/similar.js +103 -0
  62. package/dist/dedup/similar.js.map +1 -0
  63. package/dist/dedup/types.d.ts +72 -0
  64. package/dist/dedup/types.d.ts.map +1 -0
  65. package/dist/dedup/types.js +18 -0
  66. package/dist/dedup/types.js.map +1 -0
  67. package/dist/disclosure/adaptive.d.ts +86 -0
  68. package/dist/disclosure/adaptive.d.ts.map +1 -0
  69. package/dist/disclosure/adaptive.js +196 -0
  70. package/dist/disclosure/adaptive.js.map +1 -0
  71. package/dist/disclosure/budget.d.ts +51 -0
  72. package/dist/disclosure/budget.d.ts.map +1 -0
  73. package/dist/disclosure/budget.js +91 -0
  74. package/dist/disclosure/budget.js.map +1 -0
  75. package/dist/disclosure/index.d.ts +11 -0
  76. package/dist/disclosure/index.d.ts.map +1 -0
  77. package/dist/disclosure/index.js +11 -0
  78. package/dist/disclosure/index.js.map +1 -0
  79. package/dist/disclosure/tier-loader.d.ts +58 -0
  80. package/dist/disclosure/tier-loader.d.ts.map +1 -0
  81. package/dist/disclosure/tier-loader.js +205 -0
  82. package/dist/disclosure/tier-loader.js.map +1 -0
  83. package/dist/dreaming/decay.d.ts +46 -0
  84. package/dist/dreaming/decay.d.ts.map +1 -0
  85. package/dist/dreaming/decay.js +69 -0
  86. package/dist/dreaming/decay.js.map +1 -0
  87. package/dist/dreaming/deep.d.ts +48 -0
  88. package/dist/dreaming/deep.d.ts.map +1 -0
  89. package/dist/dreaming/deep.js +41 -0
  90. package/dist/dreaming/deep.js.map +1 -0
  91. package/dist/dreaming/index.d.ts +12 -0
  92. package/dist/dreaming/index.d.ts.map +1 -0
  93. package/dist/dreaming/index.js +12 -0
  94. package/dist/dreaming/index.js.map +1 -0
  95. package/dist/dreaming/light.d.ts +54 -0
  96. package/dist/dreaming/light.d.ts.map +1 -0
  97. package/dist/dreaming/light.js +114 -0
  98. package/dist/dreaming/light.js.map +1 -0
  99. package/dist/dreaming/rem.d.ts +128 -0
  100. package/dist/dreaming/rem.d.ts.map +1 -0
  101. package/dist/dreaming/rem.js +228 -0
  102. package/dist/dreaming/rem.js.map +1 -0
  103. package/dist/dreaming/scheduler.d.ts +75 -0
  104. package/dist/dreaming/scheduler.d.ts.map +1 -0
  105. package/dist/dreaming/scheduler.js +138 -0
  106. package/dist/dreaming/scheduler.js.map +1 -0
  107. package/dist/dreaming/trash.d.ts +174 -0
  108. package/dist/dreaming/trash.d.ts.map +1 -0
  109. package/dist/dreaming/trash.js +466 -0
  110. package/dist/dreaming/trash.js.map +1 -0
  111. package/dist/evolution/category.d.ts +127 -0
  112. package/dist/evolution/category.d.ts.map +1 -0
  113. package/dist/evolution/category.js +271 -0
  114. package/dist/evolution/category.js.map +1 -0
  115. package/dist/evolution/index.d.ts +8 -0
  116. package/dist/evolution/index.d.ts.map +1 -0
  117. package/dist/evolution/index.js +8 -0
  118. package/dist/evolution/index.js.map +1 -0
  119. package/dist/evolution/triggered.d.ts +107 -0
  120. package/dist/evolution/triggered.d.ts.map +1 -0
  121. package/dist/evolution/triggered.js +278 -0
  122. package/dist/evolution/triggered.js.map +1 -0
  123. package/dist/generative/cross-pollinate.d.ts +144 -0
  124. package/dist/generative/cross-pollinate.d.ts.map +1 -0
  125. package/dist/generative/cross-pollinate.js +390 -0
  126. package/dist/generative/cross-pollinate.js.map +1 -0
  127. package/dist/generative/gap-detector.d.ts +80 -0
  128. package/dist/generative/gap-detector.d.ts.map +1 -0
  129. package/dist/generative/gap-detector.js +250 -0
  130. package/dist/generative/gap-detector.js.map +1 -0
  131. package/dist/generative/hypothesis.d.ts +161 -0
  132. package/dist/generative/hypothesis.d.ts.map +1 -0
  133. package/dist/generative/hypothesis.js +356 -0
  134. package/dist/generative/hypothesis.js.map +1 -0
  135. package/dist/generative/index.d.ts +9 -0
  136. package/dist/generative/index.d.ts.map +1 -0
  137. package/dist/generative/index.js +9 -0
  138. package/dist/generative/index.js.map +1 -0
  139. package/dist/graph/clustering.d.ts +117 -0
  140. package/dist/graph/clustering.d.ts.map +1 -0
  141. package/dist/graph/clustering.js +196 -0
  142. package/dist/graph/clustering.js.map +1 -0
  143. package/dist/graph/index.d.ts +13 -0
  144. package/dist/graph/index.d.ts.map +1 -0
  145. package/dist/graph/index.js +13 -0
  146. package/dist/graph/index.js.map +1 -0
  147. package/dist/graph/layout.d.ts +46 -0
  148. package/dist/graph/layout.d.ts.map +1 -0
  149. package/dist/graph/layout.js +269 -0
  150. package/dist/graph/layout.js.map +1 -0
  151. package/dist/graph/presets.d.ts +134 -0
  152. package/dist/graph/presets.d.ts.map +1 -0
  153. package/dist/graph/presets.js +190 -0
  154. package/dist/graph/presets.js.map +1 -0
  155. package/dist/graph/registry.d.ts +42 -0
  156. package/dist/graph/registry.d.ts.map +1 -0
  157. package/dist/graph/registry.js +158 -0
  158. package/dist/graph/registry.js.map +1 -0
  159. package/dist/graph/snapshot.d.ts +113 -0
  160. package/dist/graph/snapshot.d.ts.map +1 -0
  161. package/dist/graph/snapshot.js +194 -0
  162. package/dist/graph/snapshot.js.map +1 -0
  163. package/dist/graph/traverse.d.ts +84 -0
  164. package/dist/graph/traverse.d.ts.map +1 -0
  165. package/dist/graph/traverse.js +190 -0
  166. package/dist/graph/traverse.js.map +1 -0
  167. package/dist/graph/view-config.d.ts +99 -0
  168. package/dist/graph/view-config.d.ts.map +1 -0
  169. package/dist/graph/view-config.js +208 -0
  170. package/dist/graph/view-config.js.map +1 -0
  171. package/dist/host/detect-git-author.d.ts +26 -0
  172. package/dist/host/detect-git-author.d.ts.map +1 -0
  173. package/dist/host/detect-git-author.js +53 -0
  174. package/dist/host/detect-git-author.js.map +1 -0
  175. package/dist/host/index.d.ts +7 -0
  176. package/dist/host/index.d.ts.map +1 -0
  177. package/dist/host/index.js +7 -0
  178. package/dist/host/index.js.map +1 -0
  179. package/dist/i18n/en.d.ts +8 -0
  180. package/dist/i18n/en.d.ts.map +1 -0
  181. package/dist/i18n/en.js +211 -0
  182. package/dist/i18n/en.js.map +1 -0
  183. package/dist/i18n/field-names.d.ts +95 -0
  184. package/dist/i18n/field-names.d.ts.map +1 -0
  185. package/dist/i18n/field-names.js +329 -0
  186. package/dist/i18n/field-names.js.map +1 -0
  187. package/dist/i18n/index.d.ts +92 -0
  188. package/dist/i18n/index.d.ts.map +1 -0
  189. package/dist/i18n/index.js +135 -0
  190. package/dist/i18n/index.js.map +1 -0
  191. package/dist/i18n/types.d.ts +92 -0
  192. package/dist/i18n/types.d.ts.map +1 -0
  193. package/dist/i18n/types.js +7 -0
  194. package/dist/i18n/types.js.map +1 -0
  195. package/dist/i18n/zh.d.ts +197 -0
  196. package/dist/i18n/zh.d.ts.map +1 -0
  197. package/dist/i18n/zh.js +216 -0
  198. package/dist/i18n/zh.js.map +1 -0
  199. package/dist/importance/index.d.ts +7 -0
  200. package/dist/importance/index.d.ts.map +1 -0
  201. package/dist/importance/index.js +7 -0
  202. package/dist/importance/index.js.map +1 -0
  203. package/dist/importance/vector.d.ts +113 -0
  204. package/dist/importance/vector.d.ts.map +1 -0
  205. package/dist/importance/vector.js +202 -0
  206. package/dist/importance/vector.js.map +1 -0
  207. package/dist/index/digest-builder.d.ts +59 -0
  208. package/dist/index/digest-builder.d.ts.map +1 -0
  209. package/dist/index/digest-builder.js +195 -0
  210. package/dist/index/digest-builder.js.map +1 -0
  211. package/dist/index/graph-builder.d.ts +32 -0
  212. package/dist/index/graph-builder.d.ts.map +1 -0
  213. package/dist/index/graph-builder.js +104 -0
  214. package/dist/index/graph-builder.js.map +1 -0
  215. package/dist/index/incremental.d.ts +31 -0
  216. package/dist/index/incremental.d.ts.map +1 -0
  217. package/dist/index/incremental.js +47 -0
  218. package/dist/index/incremental.js.map +1 -0
  219. package/dist/index/index.d.ts +11 -0
  220. package/dist/index/index.d.ts.map +1 -0
  221. package/dist/index/index.js +11 -0
  222. package/dist/index/index.js.map +1 -0
  223. package/dist/index/orchestrator.d.ts +60 -0
  224. package/dist/index/orchestrator.d.ts.map +1 -0
  225. package/dist/index/orchestrator.js +99 -0
  226. package/dist/index/orchestrator.js.map +1 -0
  227. package/dist/index/types.d.ts +116 -0
  228. package/dist/index/types.d.ts.map +1 -0
  229. package/dist/index/types.js +10 -0
  230. package/dist/index/types.js.map +1 -0
  231. package/dist/index.d.ts +37 -0
  232. package/dist/index.d.ts.map +1 -0
  233. package/dist/index.js +37 -0
  234. package/dist/index.js.map +1 -0
  235. package/dist/learning/index.d.ts +7 -0
  236. package/dist/learning/index.d.ts.map +1 -0
  237. package/dist/learning/index.js +7 -0
  238. package/dist/learning/index.js.map +1 -0
  239. package/dist/learning/loop.d.ts +79 -0
  240. package/dist/learning/loop.d.ts.map +1 -0
  241. package/dist/learning/loop.js +116 -0
  242. package/dist/learning/loop.js.map +1 -0
  243. package/dist/lifecycle/freshness.d.ts +35 -0
  244. package/dist/lifecycle/freshness.d.ts.map +1 -0
  245. package/dist/lifecycle/freshness.js +60 -0
  246. package/dist/lifecycle/freshness.js.map +1 -0
  247. package/dist/lifecycle/index.d.ts +7 -0
  248. package/dist/lifecycle/index.d.ts.map +1 -0
  249. package/dist/lifecycle/index.js +7 -0
  250. package/dist/lifecycle/index.js.map +1 -0
  251. package/dist/lineage/index.d.ts +10 -0
  252. package/dist/lineage/index.d.ts.map +1 -0
  253. package/dist/lineage/index.js +10 -0
  254. package/dist/lineage/index.js.map +1 -0
  255. package/dist/lineage/trace.d.ts +142 -0
  256. package/dist/lineage/trace.d.ts.map +1 -0
  257. package/dist/lineage/trace.js +316 -0
  258. package/dist/lineage/trace.js.map +1 -0
  259. package/dist/maintenance/engine.d.ts +78 -0
  260. package/dist/maintenance/engine.d.ts.map +1 -0
  261. package/dist/maintenance/engine.js +291 -0
  262. package/dist/maintenance/engine.js.map +1 -0
  263. package/dist/maintenance/index.d.ts +8 -0
  264. package/dist/maintenance/index.d.ts.map +1 -0
  265. package/dist/maintenance/index.js +8 -0
  266. package/dist/maintenance/index.js.map +1 -0
  267. package/dist/maintenance/types.d.ts +111 -0
  268. package/dist/maintenance/types.d.ts.map +1 -0
  269. package/dist/maintenance/types.js +24 -0
  270. package/dist/maintenance/types.js.map +1 -0
  271. package/dist/observability/audit-log.d.ts +77 -0
  272. package/dist/observability/audit-log.d.ts.map +1 -0
  273. package/dist/observability/audit-log.js +101 -0
  274. package/dist/observability/audit-log.js.map +1 -0
  275. package/dist/observability/effectiveness-tracker.d.ts +162 -0
  276. package/dist/observability/effectiveness-tracker.d.ts.map +1 -0
  277. package/dist/observability/effectiveness-tracker.js +251 -0
  278. package/dist/observability/effectiveness-tracker.js.map +1 -0
  279. package/dist/observability/index.d.ts +16 -0
  280. package/dist/observability/index.d.ts.map +1 -0
  281. package/dist/observability/index.js +16 -0
  282. package/dist/observability/index.js.map +1 -0
  283. package/dist/observability/necessity-evaluator.d.ts +116 -0
  284. package/dist/observability/necessity-evaluator.d.ts.map +1 -0
  285. package/dist/observability/necessity-evaluator.js +487 -0
  286. package/dist/observability/necessity-evaluator.js.map +1 -0
  287. package/dist/observability/proposal-engine.d.ts +224 -0
  288. package/dist/observability/proposal-engine.d.ts.map +1 -0
  289. package/dist/observability/proposal-engine.js +651 -0
  290. package/dist/observability/proposal-engine.js.map +1 -0
  291. package/dist/perspectives/index.d.ts +7 -0
  292. package/dist/perspectives/index.d.ts.map +1 -0
  293. package/dist/perspectives/index.js +7 -0
  294. package/dist/perspectives/index.js.map +1 -0
  295. package/dist/perspectives/multi-view.d.ts +81 -0
  296. package/dist/perspectives/multi-view.d.ts.map +1 -0
  297. package/dist/perspectives/multi-view.js +221 -0
  298. package/dist/perspectives/multi-view.js.map +1 -0
  299. package/dist/prompt-builder/builder.d.ts +47 -0
  300. package/dist/prompt-builder/builder.d.ts.map +1 -0
  301. package/dist/prompt-builder/builder.js +136 -0
  302. package/dist/prompt-builder/builder.js.map +1 -0
  303. package/dist/prompt-builder/index.d.ts +8 -0
  304. package/dist/prompt-builder/index.d.ts.map +1 -0
  305. package/dist/prompt-builder/index.js +8 -0
  306. package/dist/prompt-builder/index.js.map +1 -0
  307. package/dist/prompt-builder/types.d.ts +42 -0
  308. package/dist/prompt-builder/types.d.ts.map +1 -0
  309. package/dist/prompt-builder/types.js +10 -0
  310. package/dist/prompt-builder/types.js.map +1 -0
  311. package/dist/prompt-signals/cache.d.ts +36 -0
  312. package/dist/prompt-signals/cache.d.ts.map +1 -0
  313. package/dist/prompt-signals/cache.js +70 -0
  314. package/dist/prompt-signals/cache.js.map +1 -0
  315. package/dist/prompt-signals/index.d.ts +12 -0
  316. package/dist/prompt-signals/index.d.ts.map +1 -0
  317. package/dist/prompt-signals/index.js +11 -0
  318. package/dist/prompt-signals/index.js.map +1 -0
  319. package/dist/prompt-signals/stats.d.ts +45 -0
  320. package/dist/prompt-signals/stats.d.ts.map +1 -0
  321. package/dist/prompt-signals/stats.js +119 -0
  322. package/dist/prompt-signals/stats.js.map +1 -0
  323. package/dist/prompt-signals/types.d.ts +53 -0
  324. package/dist/prompt-signals/types.d.ts.map +1 -0
  325. package/dist/prompt-signals/types.js +34 -0
  326. package/dist/prompt-signals/types.js.map +1 -0
  327. package/dist/provenance/index.d.ts +7 -0
  328. package/dist/provenance/index.d.ts.map +1 -0
  329. package/dist/provenance/index.js +7 -0
  330. package/dist/provenance/index.js.map +1 -0
  331. package/dist/provenance/reliability.d.ts +133 -0
  332. package/dist/provenance/reliability.d.ts.map +1 -0
  333. package/dist/provenance/reliability.js +213 -0
  334. package/dist/provenance/reliability.js.map +1 -0
  335. package/dist/reinforcement/config.d.ts +34 -0
  336. package/dist/reinforcement/config.d.ts.map +1 -0
  337. package/dist/reinforcement/config.js +43 -0
  338. package/dist/reinforcement/config.js.map +1 -0
  339. package/dist/reinforcement/index.d.ts +12 -0
  340. package/dist/reinforcement/index.d.ts.map +1 -0
  341. package/dist/reinforcement/index.js +12 -0
  342. package/dist/reinforcement/index.js.map +1 -0
  343. package/dist/reinforcement/ltd.d.ts +59 -0
  344. package/dist/reinforcement/ltd.d.ts.map +1 -0
  345. package/dist/reinforcement/ltd.js +90 -0
  346. package/dist/reinforcement/ltd.js.map +1 -0
  347. package/dist/reinforcement/ltp.d.ts +63 -0
  348. package/dist/reinforcement/ltp.d.ts.map +1 -0
  349. package/dist/reinforcement/ltp.js +99 -0
  350. package/dist/reinforcement/ltp.js.map +1 -0
  351. package/dist/reinforcement/related.d.ts +39 -0
  352. package/dist/reinforcement/related.d.ts.map +1 -0
  353. package/dist/reinforcement/related.js +92 -0
  354. package/dist/reinforcement/related.js.map +1 -0
  355. package/dist/retrieval/filter.d.ts +18 -0
  356. package/dist/retrieval/filter.d.ts.map +1 -0
  357. package/dist/retrieval/filter.js +68 -0
  358. package/dist/retrieval/filter.js.map +1 -0
  359. package/dist/retrieval/fts.d.ts +44 -0
  360. package/dist/retrieval/fts.d.ts.map +1 -0
  361. package/dist/retrieval/fts.js +120 -0
  362. package/dist/retrieval/fts.js.map +1 -0
  363. package/dist/retrieval/index.d.ts +10 -0
  364. package/dist/retrieval/index.d.ts.map +1 -0
  365. package/dist/retrieval/index.js +10 -0
  366. package/dist/retrieval/index.js.map +1 -0
  367. package/dist/retrieval/orchestrator.d.ts +78 -0
  368. package/dist/retrieval/orchestrator.d.ts.map +1 -0
  369. package/dist/retrieval/orchestrator.js +156 -0
  370. package/dist/retrieval/orchestrator.js.map +1 -0
  371. package/dist/retrieval/scoring.d.ts +105 -0
  372. package/dist/retrieval/scoring.d.ts.map +1 -0
  373. package/dist/retrieval/scoring.js +165 -0
  374. package/dist/retrieval/scoring.js.map +1 -0
  375. package/dist/signals/extract.d.ts +98 -0
  376. package/dist/signals/extract.d.ts.map +1 -0
  377. package/dist/signals/extract.js +388 -0
  378. package/dist/signals/extract.js.map +1 -0
  379. package/dist/signals/file-sink.d.ts +81 -0
  380. package/dist/signals/file-sink.d.ts.map +1 -0
  381. package/dist/signals/file-sink.js +227 -0
  382. package/dist/signals/file-sink.js.map +1 -0
  383. package/dist/signals/index.d.ts +12 -0
  384. package/dist/signals/index.d.ts.map +1 -0
  385. package/dist/signals/index.js +12 -0
  386. package/dist/signals/index.js.map +1 -0
  387. package/dist/signals/rpe.d.ts +60 -0
  388. package/dist/signals/rpe.d.ts.map +1 -0
  389. package/dist/signals/rpe.js +68 -0
  390. package/dist/signals/rpe.js.map +1 -0
  391. package/dist/signals/types.d.ts +80 -0
  392. package/dist/signals/types.d.ts.map +1 -0
  393. package/dist/signals/types.js +14 -0
  394. package/dist/signals/types.js.map +1 -0
  395. package/dist/storage/engram-index.d.ts +73 -0
  396. package/dist/storage/engram-index.d.ts.map +1 -0
  397. package/dist/storage/engram-index.js +215 -0
  398. package/dist/storage/engram-index.js.map +1 -0
  399. package/dist/storage/engram-store.d.ts +147 -0
  400. package/dist/storage/engram-store.d.ts.map +1 -0
  401. package/dist/storage/engram-store.js +221 -0
  402. package/dist/storage/engram-store.js.map +1 -0
  403. package/dist/storage/git-stage.d.ts +56 -0
  404. package/dist/storage/git-stage.d.ts.map +1 -0
  405. package/dist/storage/git-stage.js +147 -0
  406. package/dist/storage/git-stage.js.map +1 -0
  407. package/dist/storage/git.d.ts +57 -0
  408. package/dist/storage/git.d.ts.map +1 -0
  409. package/dist/storage/git.js +156 -0
  410. package/dist/storage/git.js.map +1 -0
  411. package/dist/storage/hash.d.ts +23 -0
  412. package/dist/storage/hash.d.ts.map +1 -0
  413. package/dist/storage/hash.js +31 -0
  414. package/dist/storage/hash.js.map +1 -0
  415. package/dist/storage/index.d.ts +14 -0
  416. package/dist/storage/index.d.ts.map +1 -0
  417. package/dist/storage/index.js +14 -0
  418. package/dist/storage/index.js.map +1 -0
  419. package/dist/storage/path.d.ts +51 -0
  420. package/dist/storage/path.d.ts.map +1 -0
  421. package/dist/storage/path.js +72 -0
  422. package/dist/storage/path.js.map +1 -0
  423. package/dist/storage/repository.d.ts +342 -0
  424. package/dist/storage/repository.d.ts.map +1 -0
  425. package/dist/storage/repository.js +1221 -0
  426. package/dist/storage/repository.js.map +1 -0
  427. package/dist/storage/synapse-store.d.ts +113 -0
  428. package/dist/storage/synapse-store.d.ts.map +1 -0
  429. package/dist/storage/synapse-store.js +279 -0
  430. package/dist/storage/synapse-store.js.map +1 -0
  431. package/dist/tools/doctor-tools.d.ts +53 -0
  432. package/dist/tools/doctor-tools.d.ts.map +1 -0
  433. package/dist/tools/doctor-tools.js +97 -0
  434. package/dist/tools/doctor-tools.js.map +1 -0
  435. package/dist/tools/engram-tools.d.ts +166 -0
  436. package/dist/tools/engram-tools.d.ts.map +1 -0
  437. package/dist/tools/engram-tools.js +834 -0
  438. package/dist/tools/engram-tools.js.map +1 -0
  439. package/dist/tools/index.d.ts +16 -0
  440. package/dist/tools/index.d.ts.map +1 -0
  441. package/dist/tools/index.js +16 -0
  442. package/dist/tools/index.js.map +1 -0
  443. package/dist/tools/llm-descriptions.d.ts +61 -0
  444. package/dist/tools/llm-descriptions.d.ts.map +1 -0
  445. package/dist/tools/llm-descriptions.js +556 -0
  446. package/dist/tools/llm-descriptions.js.map +1 -0
  447. package/dist/tools/proposal-tools.d.ts +40 -0
  448. package/dist/tools/proposal-tools.d.ts.map +1 -0
  449. package/dist/tools/proposal-tools.js +99 -0
  450. package/dist/tools/proposal-tools.js.map +1 -0
  451. package/dist/tools/registry.d.ts +30 -0
  452. package/dist/tools/registry.d.ts.map +1 -0
  453. package/dist/tools/registry.js +43 -0
  454. package/dist/tools/registry.js.map +1 -0
  455. package/dist/tools/schemas.d.ts +715 -0
  456. package/dist/tools/schemas.d.ts.map +1 -0
  457. package/dist/tools/schemas.js +383 -0
  458. package/dist/tools/schemas.js.map +1 -0
  459. package/dist/tools/skill-tools.d.ts +26 -0
  460. package/dist/tools/skill-tools.d.ts.map +1 -0
  461. package/dist/tools/skill-tools.js +84 -0
  462. package/dist/tools/skill-tools.js.map +1 -0
  463. package/dist/tools/synapse-tools.d.ts +28 -0
  464. package/dist/tools/synapse-tools.d.ts.map +1 -0
  465. package/dist/tools/synapse-tools.js +177 -0
  466. package/dist/tools/synapse-tools.js.map +1 -0
  467. package/dist/tools/tool.d.ts +84 -0
  468. package/dist/tools/tool.d.ts.map +1 -0
  469. package/dist/tools/tool.js +22 -0
  470. package/dist/tools/tool.js.map +1 -0
  471. package/dist/tools/wrapped.d.ts +28 -0
  472. package/dist/tools/wrapped.d.ts.map +1 -0
  473. package/dist/tools/wrapped.js +172 -0
  474. package/dist/tools/wrapped.js.map +1 -0
  475. package/dist/types/disclosure.d.ts +70 -0
  476. package/dist/types/disclosure.d.ts.map +1 -0
  477. package/dist/types/disclosure.js +9 -0
  478. package/dist/types/disclosure.js.map +1 -0
  479. package/dist/types/engram.d.ts +203 -0
  480. package/dist/types/engram.d.ts.map +1 -0
  481. package/dist/types/engram.js +7 -0
  482. package/dist/types/engram.js.map +1 -0
  483. package/dist/types/index.d.ts +15 -0
  484. package/dist/types/index.d.ts.map +1 -0
  485. package/dist/types/index.js +15 -0
  486. package/dist/types/index.js.map +1 -0
  487. package/dist/types/intention.d.ts +91 -0
  488. package/dist/types/intention.d.ts.map +1 -0
  489. package/dist/types/intention.js +9 -0
  490. package/dist/types/intention.js.map +1 -0
  491. package/dist/types/repository-types.d.ts +113 -0
  492. package/dist/types/repository-types.d.ts.map +1 -0
  493. package/dist/types/repository-types.js +18 -0
  494. package/dist/types/repository-types.js.map +1 -0
  495. package/dist/types/scene.d.ts +52 -0
  496. package/dist/types/scene.d.ts.map +1 -0
  497. package/dist/types/scene.js +12 -0
  498. package/dist/types/scene.js.map +1 -0
  499. package/dist/types/skill.d.ts +107 -0
  500. package/dist/types/skill.d.ts.map +1 -0
  501. package/dist/types/skill.js +10 -0
  502. package/dist/types/skill.js.map +1 -0
  503. package/dist/types/slugify.d.ts +34 -0
  504. package/dist/types/slugify.d.ts.map +1 -0
  505. package/dist/types/slugify.js +55 -0
  506. package/dist/types/slugify.js.map +1 -0
  507. package/dist/types/synapse-id.d.ts +22 -0
  508. package/dist/types/synapse-id.d.ts.map +1 -0
  509. package/dist/types/synapse-id.js +34 -0
  510. package/dist/types/synapse-id.js.map +1 -0
  511. package/dist/types/synapse.d.ts +99 -0
  512. package/dist/types/synapse.d.ts.map +1 -0
  513. package/dist/types/synapse.js +9 -0
  514. package/dist/types/synapse.js.map +1 -0
  515. package/dist/verification/index.d.ts +11 -0
  516. package/dist/verification/index.d.ts.map +1 -0
  517. package/dist/verification/index.js +11 -0
  518. package/dist/verification/index.js.map +1 -0
  519. package/dist/verification/metacognition.d.ts +102 -0
  520. package/dist/verification/metacognition.d.ts.map +1 -0
  521. package/dist/verification/metacognition.js +284 -0
  522. package/dist/verification/metacognition.js.map +1 -0
  523. package/dist/verification/state-machine.d.ts +77 -0
  524. package/dist/verification/state-machine.d.ts.map +1 -0
  525. package/dist/verification/state-machine.js +126 -0
  526. package/dist/verification/state-machine.js.map +1 -0
  527. package/dist/verification/upgrade.d.ts +133 -0
  528. package/dist/verification/upgrade.d.ts.map +1 -0
  529. package/dist/verification/upgrade.js +364 -0
  530. package/dist/verification/upgrade.js.map +1 -0
  531. package/package.json +70 -0
@@ -0,0 +1,194 @@
1
+ /**
2
+ * Graph Snapshot 构建(spec §12.2)
3
+ *
4
+ * 从派生索引(digest.jsonl + graph.json)构建 Graph View 用的快照。
5
+ * 零额外存储:完全基于派生缓存,图视图本身不触发对权威源的读取。
6
+ *
7
+ * 过滤器(spec §12.6):
8
+ * - 节点:kind / domainTags / freshness / status / emotionalValence / createdBy / createdAt 范围 / importance 阈值 / orphansOnly
9
+ * - 边:kinds / minWeight / hideContradicts
10
+ * - 预设:orphans / strong / contradictions / lineage
11
+ *
12
+ * @module @co-engram/core/graph
13
+ */
14
+ import { getSynapseKindMeta } from "./registry.js";
15
+ /** Hub 阈值(spec §12.3:incomingSynapseCount ≥ 10) */
16
+ export const HUB_INCOMING_THRESHOLD = 10;
17
+ /**
18
+ * 构建 Graph View 快照
19
+ *
20
+ * 1. 节点过滤:对 digest 应用节点过滤器
21
+ * 2. 边过滤:剔除两端任一节点被过滤掉的边;应用边过滤器
22
+ * 3. 派生:节点 outgoingCount/incomingCount/isHub 基于过滤后的边
23
+ * 4. 统计:orphan / hub / contradiction / byKind / byDomain / byFreshness
24
+ */
25
+ export function buildGraphSnapshot(input) {
26
+ const digestList = Array.isArray(input.digest)
27
+ ? [...input.digest]
28
+ : Array.from(input.digest.values());
29
+ const filter = input.filter ?? {};
30
+ const edgeById = new Map();
31
+ for (const e of input.graph.edges)
32
+ edgeById.set(e.id, e);
33
+ // --- Step 1: 节点过滤 ---
34
+ const nodeSet = new Set();
35
+ const filteredDigests = [];
36
+ for (const line of digestList) {
37
+ if (!matchesNodeFilter(line, filter))
38
+ continue;
39
+ nodeSet.add(line.id);
40
+ filteredDigests.push(line);
41
+ }
42
+ // --- Step 2: 边过滤 ---
43
+ const filteredEdges = [];
44
+ for (const edge of input.graph.edges) {
45
+ // 两端必须都在过滤后的节点集中
46
+ if (!nodeSet.has(edge.from) || !nodeSet.has(edge.to))
47
+ continue;
48
+ if (!matchesEdgeFilter(edge, filter))
49
+ continue;
50
+ filteredEdges.push(toSnapshotEdge(edge));
51
+ }
52
+ // --- 预设:contradictionsOnly ---
53
+ let finalEdges = filteredEdges;
54
+ let finalNodeSet = nodeSet;
55
+ let finalDigests = filteredDigests;
56
+ if (filter.contradictionsOnly) {
57
+ finalEdges = filteredEdges.filter((e) => e.isContradiction);
58
+ const keepIds = new Set();
59
+ for (const e of finalEdges) {
60
+ keepIds.add(e.from);
61
+ keepIds.add(e.to);
62
+ }
63
+ finalDigests = filteredDigests.filter((d) => keepIds.has(d.id));
64
+ finalNodeSet = keepIds;
65
+ }
66
+ // --- Step 3: 派生节点属性 ---
67
+ const outgoingCount = new Map();
68
+ const incomingCount = new Map();
69
+ for (const e of finalEdges) {
70
+ outgoingCount.set(e.from, (outgoingCount.get(e.from) ?? 0) + 1);
71
+ incomingCount.set(e.to, (incomingCount.get(e.to) ?? 0) + 1);
72
+ }
73
+ const nodes = finalDigests.map((line) => {
74
+ const outgoing = outgoingCount.get(line.id) ?? 0;
75
+ const incoming = incomingCount.get(line.id) ?? 0;
76
+ return {
77
+ id: line.id,
78
+ title: line.title,
79
+ kind: line.kind,
80
+ kinds: line.kinds,
81
+ domainTags: line.domainTags,
82
+ importance: line.importance,
83
+ freshness: line.freshness,
84
+ status: line.status,
85
+ emotionalValence: line.emotionalValence,
86
+ createdBy: line.createdBy,
87
+ createdAt: line.createdAt,
88
+ updatedAt: line.updatedAt,
89
+ retrievalCount: line.retrievalCount,
90
+ effectiveRetrievals: line.effectiveRetrievals,
91
+ reinforcementScore: line.reinforcementScore,
92
+ outgoingCount: outgoing,
93
+ incomingCount: incoming,
94
+ isHub: line.incomingSynapseCount >= HUB_INCOMING_THRESHOLD,
95
+ };
96
+ });
97
+ // --- Step 4: 预设 orphansOnly ---
98
+ let finalNodes = nodes;
99
+ if (filter.orphansOnly) {
100
+ finalNodes = nodes.filter((n) => n.outgoingCount === 0 && n.incomingCount === 0);
101
+ const keepIds = new Set(finalNodes.map((n) => n.id));
102
+ finalEdges = finalEdges.filter((e) => keepIds.has(e.from) && keepIds.has(e.to));
103
+ }
104
+ // --- 统计 ---
105
+ const stats = computeStats(finalNodes, finalEdges);
106
+ return { nodes: finalNodes, edges: finalEdges, stats };
107
+ }
108
+ // ============================================================
109
+ // 过滤匹配
110
+ // ============================================================
111
+ function matchesNodeFilter(line, filter) {
112
+ if (filter.kinds && !filter.kinds.includes(line.kind))
113
+ return false;
114
+ if (filter.domainTags &&
115
+ !filter.domainTags.some((d) => line.domainTags.includes(d)))
116
+ return false;
117
+ if (filter.freshness &&
118
+ !filter.freshness.includes(line.freshness))
119
+ return false;
120
+ if (filter.status && !filter.status.includes(line.status))
121
+ return false;
122
+ if (filter.emotionalValence &&
123
+ !filter.emotionalValence.includes(line.emotionalValence))
124
+ return false;
125
+ if (filter.createdBy && !filter.createdBy.includes(line.createdBy))
126
+ return false;
127
+ if (filter.createdAfter && line.createdAt < filter.createdAfter)
128
+ return false;
129
+ if (filter.createdBefore && line.createdAt > filter.createdBefore)
130
+ return false;
131
+ if (filter.minImportance !== undefined &&
132
+ line.importance < filter.minImportance)
133
+ return false;
134
+ if (filter.maxImportance !== undefined &&
135
+ line.importance > filter.maxImportance)
136
+ return false;
137
+ return true;
138
+ }
139
+ function matchesEdgeFilter(edge, filter) {
140
+ if (filter.synapseKinds && !filter.synapseKinds.includes(edge.kind))
141
+ return false;
142
+ if (filter.synapseFamilies) {
143
+ const meta = getSynapseKindMeta(edge.kind);
144
+ if (!filter.synapseFamilies.includes(meta.family))
145
+ return false;
146
+ }
147
+ if (filter.minWeight !== undefined && edge.weight < filter.minWeight)
148
+ return false;
149
+ if (filter.hideContradicts && edge.kind === "contradicts")
150
+ return false;
151
+ return true;
152
+ }
153
+ function toSnapshotEdge(edge) {
154
+ const meta = getSynapseKindMeta(edge.kind);
155
+ return {
156
+ id: edge.id,
157
+ from: edge.from,
158
+ to: edge.to,
159
+ kind: edge.kind,
160
+ family: meta.family,
161
+ weight: edge.weight,
162
+ direction: edge.direction,
163
+ isContradiction: edge.kind === "contradicts",
164
+ };
165
+ }
166
+ function computeStats(nodes, edges) {
167
+ const byKind = {};
168
+ const byDomain = {};
169
+ const byFreshness = {};
170
+ let orphanCount = 0;
171
+ let hubCount = 0;
172
+ for (const n of nodes) {
173
+ byKind[n.kind] = (byKind[n.kind] ?? 0) + 1;
174
+ for (const d of n.domainTags)
175
+ byDomain[d] = (byDomain[d] ?? 0) + 1;
176
+ byFreshness[n.freshness] = (byFreshness[n.freshness] ?? 0) + 1;
177
+ if (n.outgoingCount === 0 && n.incomingCount === 0)
178
+ orphanCount += 1;
179
+ if (n.isHub)
180
+ hubCount += 1;
181
+ }
182
+ const contradictionCount = edges.filter((e) => e.isContradiction).length;
183
+ return {
184
+ totalNodes: nodes.length,
185
+ totalEdges: edges.length,
186
+ orphanCount,
187
+ hubCount,
188
+ contradictionCount,
189
+ byKind,
190
+ byDomain,
191
+ byFreshness,
192
+ };
193
+ }
194
+ //# sourceMappingURL=snapshot.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snapshot.js","sourceRoot":"","sources":["../../src/graph/snapshot.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,84 @@
1
+ /**
2
+ * 图遍历操作
3
+ *
4
+ * 基于 graph.json 索引(来自派生缓存)做 BFS / DFS / 邻居查询
5
+ *
6
+ * @module @co-engram/core/graph
7
+ */
8
+ import type { EngramId } from "../types/engram.js";
9
+ import type { SynapseKind } from "../types/synapse.js";
10
+ import type { GraphEdge, GraphIndex } from "../index/types.js";
11
+ /** 邻居查询选项 */
12
+ export interface GetNeighborsOptions {
13
+ /** 最大深度(默认 1) */
14
+ readonly depth?: number;
15
+ /** 限制方向:outgoing(出边) / incoming(入边) / both */
16
+ readonly direction?: "outgoing" | "incoming" | "both";
17
+ /** 过滤 Synapse kind */
18
+ readonly kinds?: readonly SynapseKind[];
19
+ /** 最小 weight */
20
+ readonly minWeight?: number;
21
+ /** 最大结果数 */
22
+ readonly limit?: number;
23
+ }
24
+ /** 邻居节点 */
25
+ export interface NeighborNode {
26
+ readonly id: EngramId;
27
+ readonly depth: number;
28
+ readonly viaEdge: GraphEdge;
29
+ }
30
+ /**
31
+ * 从 graph.json 索引构建遍历器
32
+ */
33
+ export declare class GraphTraverser {
34
+ private readonly index;
35
+ constructor(index: GraphIndex);
36
+ /**
37
+ * 获取一阶或多阶邻居
38
+ */
39
+ getNeighbors(startId: EngramId, options?: GetNeighborsOptions): NeighborNode[];
40
+ /**
41
+ * 收集节点的所有相关边
42
+ */
43
+ private collectEdges;
44
+ /**
45
+ * 查找两个节点之间的路径(BFS 最短路径)
46
+ */
47
+ findPaths(fromId: EngramId, toId: EngramId, maxDepth?: number): EngramId[][];
48
+ /**
49
+ * 遍历整个图(BFS)
50
+ */
51
+ traverse(startId: EngramId, maxDepth?: number): NeighborNode[];
52
+ /**
53
+ * 检查节点是否孤立(无连接)
54
+ */
55
+ isIsolated(id: EngramId): boolean;
56
+ /**
57
+ * 获取入度 + 出度
58
+ */
59
+ getDegree(id: EngramId): {
60
+ outgoing: number;
61
+ incoming: number;
62
+ total: number;
63
+ };
64
+ /**
65
+ * 查找 Hub 节点(入度 ≥ threshold)
66
+ */
67
+ findHubs(threshold?: number): Array<{
68
+ id: EngramId;
69
+ incoming: number;
70
+ }>;
71
+ /**
72
+ * 列出所有 contradicts 边
73
+ */
74
+ findContradictions(): GraphEdge[];
75
+ /**
76
+ * 查找所有孤立节点
77
+ */
78
+ findOrphans(): EngramId[];
79
+ /**
80
+ * 沿特定 kind 链追溯(如 derives_from / consolidates / supersedes)
81
+ */
82
+ traceLineage(startId: EngramId, kind: SynapseKind, maxDepth?: number): EngramId[];
83
+ }
84
+ //# sourceMappingURL=traverse.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traverse.d.ts","sourceRoot":"","sources":["../../src/graph/traverse.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/D,aAAa;AACb,MAAM,WAAW,mBAAmB;IAClC,iBAAiB;IACjB,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB,8CAA8C;IAC9C,QAAQ,CAAC,SAAS,CAAC,EAAE,UAAU,GAAG,UAAU,GAAG,MAAM,CAAC;IACtD,sBAAsB;IACtB,QAAQ,CAAC,KAAK,CAAC,EAAE,SAAS,WAAW,EAAE,CAAC;IACxC,gBAAgB;IAChB,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY;IACZ,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,WAAW;AACX,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,EAAE,EAAE,QAAQ,CAAC;IACtB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,OAAO,EAAE,SAAS,CAAC;CAC7B;AAED;;GAEG;AACH,qBAAa,cAAc;IACb,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,UAAU;IAE9C;;OAEG;IACH,YAAY,CACV,OAAO,EAAE,QAAQ,EACjB,OAAO,GAAE,mBAAwB,GAChC,YAAY,EAAE;IAwCjB;;OAEG;IACH,OAAO,CAAC,YAAY;IA6BpB;;OAEG;IACH,SAAS,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,SAAI,GAAG,QAAQ,EAAE,EAAE;IAuCvE;;OAEG;IACH,QAAQ,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,SAAI,GAAG,YAAY,EAAE;IAQzD;;OAEG;IACH,UAAU,CAAC,EAAE,EAAE,QAAQ,GAAG,OAAO;IAMjC;;OAEG;IACH,SAAS,CAAC,EAAE,EAAE,QAAQ,GAAG;QACvB,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;KACf;IAMD;;OAEG;IACH,QAAQ,CAAC,SAAS,SAAI,GAAG,KAAK,CAAC;QAAE,EAAE,EAAE,QAAQ,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;IAOlE;;OAEG;IACH,kBAAkB,IAAI,SAAS,EAAE;IAIjC;;OAEG;IACH,WAAW,IAAI,QAAQ,EAAE;IAMzB;;OAEG;IACH,YAAY,CACV,OAAO,EAAE,QAAQ,EACjB,IAAI,EAAE,WAAW,EACjB,QAAQ,SAAK,GACZ,QAAQ,EAAE;CA4Bd"}
@@ -0,0 +1,190 @@
1
+ /**
2
+ * 图遍历操作
3
+ *
4
+ * 基于 graph.json 索引(来自派生缓存)做 BFS / DFS / 邻居查询
5
+ *
6
+ * @module @co-engram/core/graph
7
+ */
8
+ /**
9
+ * 从 graph.json 索引构建遍历器
10
+ */
11
+ export class GraphTraverser {
12
+ index;
13
+ constructor(index) {
14
+ this.index = index;
15
+ }
16
+ /**
17
+ * 获取一阶或多阶邻居
18
+ */
19
+ getNeighbors(startId, options = {}) {
20
+ const { depth = 1, direction = "both", kinds, minWeight = 0, limit = 100, } = options;
21
+ const result = [];
22
+ const visited = new Set([startId]);
23
+ const queue = [
24
+ { id: startId, depth: 0 },
25
+ ];
26
+ while (queue.length > 0 && result.length < limit) {
27
+ const { id, depth: currentDepth } = queue.shift();
28
+ if (currentDepth >= depth) {
29
+ continue;
30
+ }
31
+ const nextEdges = this.collectEdges(id, direction);
32
+ for (const edge of nextEdges) {
33
+ if (result.length >= limit)
34
+ break;
35
+ if (kinds && !kinds.includes(edge.kind))
36
+ continue;
37
+ if (edge.weight < minWeight)
38
+ continue;
39
+ const nextId = edge.from === id ? edge.to : edge.from;
40
+ if (visited.has(nextId)) {
41
+ continue;
42
+ }
43
+ visited.add(nextId);
44
+ result.push({ id: nextId, depth: currentDepth + 1, viaEdge: edge });
45
+ queue.push({ id: nextId, depth: currentDepth + 1 });
46
+ }
47
+ }
48
+ return result;
49
+ }
50
+ /**
51
+ * 收集节点的所有相关边
52
+ */
53
+ collectEdges(id, direction) {
54
+ const result = [];
55
+ const edgeMap = new Map();
56
+ for (const edge of this.index.edges) {
57
+ edgeMap.set(edge.id, edge);
58
+ }
59
+ if (direction === "outgoing" || direction === "both") {
60
+ const edgeIds = this.index.outgoingAdjacency[id] ?? [];
61
+ for (const eid of edgeIds) {
62
+ const e = edgeMap.get(eid);
63
+ if (e)
64
+ result.push(e);
65
+ }
66
+ }
67
+ if (direction === "incoming" || direction === "both") {
68
+ const edgeIds = this.index.incomingAdjacency[id] ?? [];
69
+ for (const eid of edgeIds) {
70
+ const e = edgeMap.get(eid);
71
+ if (e)
72
+ result.push(e);
73
+ }
74
+ }
75
+ return result;
76
+ }
77
+ /**
78
+ * 查找两个节点之间的路径(BFS 最短路径)
79
+ */
80
+ findPaths(fromId, toId, maxDepth = 5) {
81
+ if (fromId === toId) {
82
+ return [[fromId]];
83
+ }
84
+ const paths = [];
85
+ const queue = [
86
+ { id: fromId, path: [fromId] },
87
+ ];
88
+ const visited = new Set([fromId]);
89
+ while (queue.length > 0) {
90
+ const { id, path } = queue.shift();
91
+ if (path.length > maxDepth) {
92
+ continue;
93
+ }
94
+ const nextEdges = this.collectEdges(id, "both");
95
+ for (const edge of nextEdges) {
96
+ const nextId = edge.from === id ? edge.to : edge.from;
97
+ if (visited.has(nextId)) {
98
+ continue;
99
+ }
100
+ const newPath = [...path, nextId];
101
+ if (nextId === toId) {
102
+ paths.push(newPath);
103
+ if (paths.length >= 10) {
104
+ return paths;
105
+ }
106
+ continue;
107
+ }
108
+ visited.add(nextId);
109
+ queue.push({ id: nextId, path: newPath });
110
+ }
111
+ }
112
+ return paths;
113
+ }
114
+ /**
115
+ * 遍历整个图(BFS)
116
+ */
117
+ traverse(startId, maxDepth = 3) {
118
+ return this.getNeighbors(startId, {
119
+ depth: maxDepth,
120
+ direction: "both",
121
+ limit: 1000,
122
+ });
123
+ }
124
+ /**
125
+ * 检查节点是否孤立(无连接)
126
+ */
127
+ isIsolated(id) {
128
+ const outgoing = this.index.outgoingAdjacency[id]?.length ?? 0;
129
+ const incoming = this.index.incomingAdjacency[id]?.length ?? 0;
130
+ return outgoing === 0 && incoming === 0;
131
+ }
132
+ /**
133
+ * 获取入度 + 出度
134
+ */
135
+ getDegree(id) {
136
+ const outgoing = this.index.outgoingAdjacency[id]?.length ?? 0;
137
+ const incoming = this.index.incomingAdjacency[id]?.length ?? 0;
138
+ return { outgoing, incoming, total: outgoing + incoming };
139
+ }
140
+ /**
141
+ * 查找 Hub 节点(入度 ≥ threshold)
142
+ */
143
+ findHubs(threshold = 5) {
144
+ return this.index.nodes
145
+ .filter((n) => n.incomingCount >= threshold)
146
+ .map((n) => ({ id: n.id, incoming: n.incomingCount }))
147
+ .sort((a, b) => b.incoming - a.incoming);
148
+ }
149
+ /**
150
+ * 列出所有 contradicts 边
151
+ */
152
+ findContradictions() {
153
+ return this.index.edges.filter((e) => e.kind === "contradicts");
154
+ }
155
+ /**
156
+ * 查找所有孤立节点
157
+ */
158
+ findOrphans() {
159
+ return this.index.nodes
160
+ .filter((n) => n.outgoingCount === 0 && n.incomingCount === 0)
161
+ .map((n) => n.id);
162
+ }
163
+ /**
164
+ * 沿特定 kind 链追溯(如 derives_from / consolidates / supersedes)
165
+ */
166
+ traceLineage(startId, kind, maxDepth = 10) {
167
+ const chain = [startId];
168
+ const visited = new Set([startId]);
169
+ let current = startId;
170
+ for (let i = 0; i < maxDepth && current; i++) {
171
+ const currentId = current;
172
+ const outgoing = (this.index.outgoingAdjacency[currentId] ?? [])
173
+ .map((eid) => this.index.edges.find((e) => e.id === eid))
174
+ .filter((e) => e !== undefined)
175
+ .filter((e) => e.kind === kind);
176
+ if (outgoing.length === 0) {
177
+ break;
178
+ }
179
+ const next = outgoing[0].to;
180
+ if (visited.has(next)) {
181
+ break;
182
+ }
183
+ visited.add(next);
184
+ chain.push(next);
185
+ current = next;
186
+ }
187
+ return chain;
188
+ }
189
+ }
190
+ //# sourceMappingURL=traverse.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traverse.js","sourceRoot":"","sources":["../../src/graph/traverse.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Graph View 视图配置(spec §12.9,P3 4.7.4)
3
+ *
4
+ * 把"当前 filter + 布局 + 缩放"序列化为可保存/分享的配置。
5
+ *
6
+ * 用途:
7
+ * - 保存视图:保存到 `config/graph-views/<name>.yaml`(Git 友好)
8
+ * - 分享视图:URL 编码所有 filter state,团队成员可复现
9
+ * - 截图导出:附带视图配置作为 metadata
10
+ *
11
+ * @module @co-engram/core/graph
12
+ */
13
+ import type { GraphFilter } from "./snapshot.js";
14
+ import type { LayoutAlgorithm } from "./layout.js";
15
+ import type { ScenePresetId } from "./presets.js";
16
+ /** 完整的视图配置(可序列化) */
17
+ export interface GraphViewConfig {
18
+ /** 配置 schema 版本 */
19
+ readonly schemaVersion: 1;
20
+ /** 视图名称(用作文件名) */
21
+ readonly name: string;
22
+ /** 视图描述 */
23
+ readonly description?: string;
24
+ /** 创建者 */
25
+ readonly createdBy?: string;
26
+ /** 创建时间 ISO */
27
+ readonly createdAt?: string;
28
+ /** 更新时间 ISO */
29
+ readonly updatedAt?: string;
30
+ /** 关联的场景预设(可选) */
31
+ readonly scenePreset?: ScenePresetId;
32
+ /** 过滤器 */
33
+ readonly filter: GraphFilter;
34
+ /** 布局算法 */
35
+ readonly layout: LayoutAlgorithm;
36
+ /** 视口状态(UI 层使用) */
37
+ readonly viewport?: GraphViewport;
38
+ /** 显示选项(UI 层使用) */
39
+ readonly display?: GraphDisplayOptions;
40
+ }
41
+ /** 视口(缩放/平移) */
42
+ export interface GraphViewport {
43
+ readonly zoom: number;
44
+ readonly centerX: number;
45
+ readonly centerY: number;
46
+ }
47
+ /** 显示选项 */
48
+ export interface GraphDisplayOptions {
49
+ /** 是否显示边标签 */
50
+ readonly showEdgeLabels?: boolean;
51
+ /** 是否显示节点 importance */
52
+ readonly showImportance?: boolean;
53
+ /** 节点大小映射字段 */
54
+ readonly nodeSizeBy?: "fixed" | "importance" | "retrievalCount" | "incomingCount";
55
+ /** 节点颜色映射字段 */
56
+ readonly nodeColorBy?: "kind" | "domain" | "createdBy" | "freshness";
57
+ /** 边粗细映射字段 */
58
+ readonly edgeWidthBy?: "fixed" | "weight" | "kind";
59
+ }
60
+ /** 序列化选项 */
61
+ export interface SerializeOptions {
62
+ /** 缩进(默认 2) */
63
+ readonly indent?: number;
64
+ }
65
+ /**
66
+ * 序列化 GraphViewConfig 为 YAML 字符串
67
+ *
68
+ * 用于保存到 `config/graph-views/<name>.yaml`(Git 友好的纯文本)。
69
+ */
70
+ export declare function serializeViewConfig(config: GraphViewConfig, options?: SerializeOptions): string;
71
+ /**
72
+ * 反序列化 YAML 字符串为 GraphViewConfig
73
+ *
74
+ * 简易 YAML 解析(不支持完整 YAML spec,只支持本模块生成的格式)。
75
+ * 生产环境建议用 `js-yaml` 或类似库。
76
+ */
77
+ export declare function parseViewConfig(raw: string): GraphViewConfig;
78
+ /**
79
+ * 把 GraphViewConfig 编码为 URL 参数
80
+ *
81
+ * 用于分享视图:URL 编码所有 filter state(spec §12.9)
82
+ */
83
+ export declare function encodeViewConfigToUrl(config: GraphViewConfig): string;
84
+ /**
85
+ * 从 URL 参数解码 GraphViewConfig
86
+ */
87
+ export declare function decodeViewConfigFromUrl(urlParam: string): GraphViewConfig;
88
+ export interface DefaultViewConfigOptions {
89
+ readonly name: string;
90
+ readonly description?: string;
91
+ readonly createdBy?: string;
92
+ readonly filter?: GraphFilter;
93
+ readonly layout?: LayoutAlgorithm;
94
+ }
95
+ /**
96
+ * 创建默认视图配置
97
+ */
98
+ export declare function createDefaultViewConfig(options: DefaultViewConfigOptions): GraphViewConfig;
99
+ //# sourceMappingURL=view-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"view-config.d.ts","sourceRoot":"","sources":["../../src/graph/view-config.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAElD,oBAAoB;AACpB,MAAM,WAAW,eAAe;IAC9B,mBAAmB;IACnB,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAC;IAC1B,kBAAkB;IAClB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,WAAW;IACX,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;IAC9B,UAAU;IACV,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,eAAe;IACf,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,eAAe;IACf,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAE5B,kBAAkB;IAClB,QAAQ,CAAC,WAAW,CAAC,EAAE,aAAa,CAAC;IAErC,UAAU;IACV,QAAQ,CAAC,MAAM,EAAE,WAAW,CAAC;IAE7B,WAAW;IACX,QAAQ,CAAC,MAAM,EAAE,eAAe,CAAC;IAEjC,mBAAmB;IACnB,QAAQ,CAAC,QAAQ,CAAC,EAAE,aAAa,CAAC;IAElC,mBAAmB;IACnB,QAAQ,CAAC,OAAO,CAAC,EAAE,mBAAmB,CAAC;CACxC;AAED,gBAAgB;AAChB,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;CAC1B;AAED,WAAW;AACX,MAAM,WAAW,mBAAmB;IAClC,cAAc;IACd,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IAClC,wBAAwB;IACxB,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IAClC,eAAe;IACf,QAAQ,CAAC,UAAU,CAAC,EAChB,OAAO,GACP,YAAY,GACZ,gBAAgB,GAChB,eAAe,CAAC;IACpB,eAAe;IACf,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,WAAW,GAAG,WAAW,CAAC;IACrE,cAAc;IACd,QAAQ,CAAC,WAAW,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,MAAM,CAAC;CACpD;AAED,YAAY;AACZ,MAAM,WAAW,gBAAgB;IAC/B,eAAe;IACf,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,eAAe,EACvB,OAAO,GAAE,gBAAqB,GAC7B,MAAM,CAGR;AAED;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,CAG5D;AAED;;;;GAIG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,eAAe,GAAG,MAAM,CAKrE;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,QAAQ,EAAE,MAAM,GAAG,eAAe,CAKzE;AAMD,MAAM,WAAW,wBAAwB;IACvC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC;IAC9B,QAAQ,CAAC,MAAM,CAAC,EAAE,eAAe,CAAC;CACnC;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CACrC,OAAO,EAAE,wBAAwB,GAChC,eAAe,CAYjB"}