cognitive-core 0.2.1 → 0.2.2

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 (331) hide show
  1. package/dist/atlas.d.ts +10 -0
  2. package/dist/atlas.d.ts.map +1 -1
  3. package/dist/atlas.js +65 -0
  4. package/dist/atlas.js.map +1 -1
  5. package/dist/learning/pipeline.d.ts +4 -31
  6. package/dist/learning/pipeline.d.ts.map +1 -1
  7. package/dist/learning/pipeline.js +12 -64
  8. package/dist/learning/pipeline.js.map +1 -1
  9. package/dist/memory/curated-loader.d.ts +21 -4
  10. package/dist/memory/curated-loader.d.ts.map +1 -1
  11. package/dist/memory/curated-loader.js +53 -16
  12. package/dist/memory/curated-loader.js.map +1 -1
  13. package/dist/memory/index.d.ts +2 -1
  14. package/dist/memory/index.d.ts.map +1 -1
  15. package/dist/memory/index.js +3 -1
  16. package/dist/memory/index.js.map +1 -1
  17. package/dist/memory/playbook.d.ts +6 -0
  18. package/dist/memory/playbook.d.ts.map +1 -1
  19. package/dist/memory/playbook.js +15 -0
  20. package/dist/memory/playbook.js.map +1 -1
  21. package/dist/memory/source-resolver.d.ts +120 -0
  22. package/dist/memory/source-resolver.d.ts.map +1 -0
  23. package/dist/memory/source-resolver.js +300 -0
  24. package/dist/memory/source-resolver.js.map +1 -0
  25. package/dist/types/config.d.ts +141 -0
  26. package/dist/types/config.d.ts.map +1 -1
  27. package/dist/types/config.js +40 -0
  28. package/dist/types/config.js.map +1 -1
  29. package/dist/types/index.d.ts +1 -1
  30. package/dist/types/index.d.ts.map +1 -1
  31. package/dist/types/index.js +1 -1
  32. package/dist/types/index.js.map +1 -1
  33. package/dist/workspace/types.d.ts +12 -54
  34. package/dist/workspace/types.d.ts.map +1 -1
  35. package/dist/workspace/types.js.map +1 -1
  36. package/package.json +2 -2
  37. package/playbooks/compound-engineering/adversarial-review.json +51 -0
  38. package/playbooks/compound-engineering/agent-native-architecture.json +59 -0
  39. package/playbooks/compound-engineering/agent-native-review.json +54 -0
  40. package/playbooks/compound-engineering/api-contract-review.json +52 -0
  41. package/playbooks/compound-engineering/brainstorm-requirements.json +55 -0
  42. package/playbooks/compound-engineering/bug-reproduction.json +62 -0
  43. package/playbooks/compound-engineering/confidence-calibration.json +49 -0
  44. package/playbooks/compound-engineering/correctness-review.json +49 -0
  45. package/playbooks/compound-engineering/data-migration-safety.json +59 -0
  46. package/playbooks/compound-engineering/deployment-verification.json +63 -0
  47. package/playbooks/compound-engineering/error-recovery-patterns.json +53 -0
  48. package/playbooks/compound-engineering/implementation-planning.json +64 -0
  49. package/playbooks/compound-engineering/issue-pattern-analysis.json +53 -0
  50. package/playbooks/compound-engineering/knowledge-compounding.json +63 -0
  51. package/playbooks/compound-engineering/learnings-research.json +54 -0
  52. package/playbooks/compound-engineering/maintainability-review.json +49 -0
  53. package/playbooks/compound-engineering/performance-review.json +54 -0
  54. package/playbooks/compound-engineering/plan-adversarial-review.json +56 -0
  55. package/playbooks/compound-engineering/plan-feasibility-review.json +56 -0
  56. package/playbooks/compound-engineering/project-standards-review.json +52 -0
  57. package/playbooks/compound-engineering/reliability-review.json +53 -0
  58. package/playbooks/compound-engineering/review-orchestration.json +64 -0
  59. package/playbooks/compound-engineering/security-review.json +54 -0
  60. package/playbooks/compound-engineering/systematic-execution.json +64 -0
  61. package/playbooks/compound-engineering/testing-review.json +50 -0
  62. package/src/atlas.ts +96 -0
  63. package/src/memory/curated-loader.ts +69 -16
  64. package/src/memory/index.ts +16 -0
  65. package/src/memory/playbook.ts +19 -0
  66. package/src/memory/source-resolver.ts +422 -0
  67. package/src/types/config.ts +46 -0
  68. package/src/types/index.ts +4 -0
  69. package/src/workspace/types.ts +22 -78
  70. package/tests/integration/curated-sources-e2e.test.ts +502 -0
  71. package/tests/memory/compound-engineering-seed.test.ts +338 -0
  72. package/tests/memory/curated-loader-extended.test.ts +225 -0
  73. package/tests/memory/playbook-quality-validation.test.ts +430 -0
  74. package/tests/memory/source-resolver.test.ts +700 -0
  75. package/.claude/settings.local.json +0 -11
  76. package/dist/learning/llm-extractor.d.ts +0 -88
  77. package/dist/learning/llm-extractor.d.ts.map +0 -1
  78. package/dist/learning/llm-extractor.js +0 -372
  79. package/dist/learning/llm-extractor.js.map +0 -1
  80. package/dist/learning/loop-coordinator.d.ts +0 -61
  81. package/dist/learning/loop-coordinator.d.ts.map +0 -1
  82. package/dist/learning/loop-coordinator.js +0 -96
  83. package/dist/learning/loop-coordinator.js.map +0 -1
  84. package/references/agent-workspace/CLAUDE.md +0 -74
  85. package/references/agent-workspace/README.md +0 -587
  86. package/references/agent-workspace/media/banner.png +0 -0
  87. package/references/agent-workspace/package-lock.json +0 -2061
  88. package/references/agent-workspace/package.json +0 -54
  89. package/references/agent-workspace/src/handle.ts +0 -122
  90. package/references/agent-workspace/src/index.ts +0 -32
  91. package/references/agent-workspace/src/manager.ts +0 -102
  92. package/references/agent-workspace/src/readers/json.ts +0 -71
  93. package/references/agent-workspace/src/readers/markdown.ts +0 -37
  94. package/references/agent-workspace/src/readers/raw.ts +0 -27
  95. package/references/agent-workspace/src/types.ts +0 -68
  96. package/references/agent-workspace/src/validation.ts +0 -93
  97. package/references/agent-workspace/src/writers/json.ts +0 -17
  98. package/references/agent-workspace/src/writers/markdown.ts +0 -27
  99. package/references/agent-workspace/src/writers/raw.ts +0 -22
  100. package/references/agent-workspace/tests/errors.test.ts +0 -652
  101. package/references/agent-workspace/tests/handle.test.ts +0 -144
  102. package/references/agent-workspace/tests/manager.test.ts +0 -124
  103. package/references/agent-workspace/tests/readers.test.ts +0 -205
  104. package/references/agent-workspace/tests/validation.test.ts +0 -196
  105. package/references/agent-workspace/tests/writers.test.ts +0 -108
  106. package/references/agent-workspace/tsconfig.json +0 -20
  107. package/references/agent-workspace/tsup.config.ts +0 -9
  108. package/references/minimem/.claude/settings.json +0 -7
  109. package/references/minimem/.sudocode/issues.jsonl +0 -18
  110. package/references/minimem/.sudocode/specs.jsonl +0 -1
  111. package/references/minimem/CLAUDE.md +0 -310
  112. package/references/minimem/README.md +0 -556
  113. package/references/minimem/claude-plugin/.claude-plugin/plugin.json +0 -10
  114. package/references/minimem/claude-plugin/.mcp.json +0 -7
  115. package/references/minimem/claude-plugin/README.md +0 -158
  116. package/references/minimem/claude-plugin/commands/recall.md +0 -47
  117. package/references/minimem/claude-plugin/commands/remember.md +0 -41
  118. package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +0 -272
  119. package/references/minimem/claude-plugin/hooks/hooks.json +0 -27
  120. package/references/minimem/claude-plugin/hooks/session-end.sh +0 -86
  121. package/references/minimem/claude-plugin/hooks/session-start.sh +0 -85
  122. package/references/minimem/claude-plugin/skills/memory/SKILL.md +0 -108
  123. package/references/minimem/package-lock.json +0 -5373
  124. package/references/minimem/package.json +0 -60
  125. package/references/minimem/scripts/postbuild.js +0 -35
  126. package/references/minimem/src/__tests__/edge-cases.test.ts +0 -371
  127. package/references/minimem/src/__tests__/errors.test.ts +0 -265
  128. package/references/minimem/src/__tests__/helpers.ts +0 -199
  129. package/references/minimem/src/__tests__/internal.test.ts +0 -407
  130. package/references/minimem/src/__tests__/knowledge.test.ts +0 -287
  131. package/references/minimem/src/__tests__/minimem.integration.test.ts +0 -1127
  132. package/references/minimem/src/__tests__/session.test.ts +0 -190
  133. package/references/minimem/src/cli/__tests__/commands.test.ts +0 -759
  134. package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +0 -141
  135. package/references/minimem/src/cli/commands/append.ts +0 -76
  136. package/references/minimem/src/cli/commands/config.ts +0 -262
  137. package/references/minimem/src/cli/commands/conflicts.ts +0 -413
  138. package/references/minimem/src/cli/commands/daemon.ts +0 -169
  139. package/references/minimem/src/cli/commands/index.ts +0 -12
  140. package/references/minimem/src/cli/commands/init.ts +0 -88
  141. package/references/minimem/src/cli/commands/mcp.ts +0 -177
  142. package/references/minimem/src/cli/commands/push-pull.ts +0 -213
  143. package/references/minimem/src/cli/commands/search.ts +0 -158
  144. package/references/minimem/src/cli/commands/status.ts +0 -84
  145. package/references/minimem/src/cli/commands/sync-init.ts +0 -290
  146. package/references/minimem/src/cli/commands/sync.ts +0 -70
  147. package/references/minimem/src/cli/commands/upsert.ts +0 -197
  148. package/references/minimem/src/cli/config.ts +0 -584
  149. package/references/minimem/src/cli/index.ts +0 -264
  150. package/references/minimem/src/cli/shared.ts +0 -161
  151. package/references/minimem/src/cli/sync/__tests__/central.test.ts +0 -152
  152. package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +0 -209
  153. package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +0 -118
  154. package/references/minimem/src/cli/sync/__tests__/detection.test.ts +0 -207
  155. package/references/minimem/src/cli/sync/__tests__/integration.test.ts +0 -476
  156. package/references/minimem/src/cli/sync/__tests__/registry.test.ts +0 -363
  157. package/references/minimem/src/cli/sync/__tests__/state.test.ts +0 -255
  158. package/references/minimem/src/cli/sync/__tests__/validation.test.ts +0 -193
  159. package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +0 -178
  160. package/references/minimem/src/cli/sync/central.ts +0 -292
  161. package/references/minimem/src/cli/sync/conflicts.ts +0 -204
  162. package/references/minimem/src/cli/sync/daemon.ts +0 -407
  163. package/references/minimem/src/cli/sync/detection.ts +0 -138
  164. package/references/minimem/src/cli/sync/index.ts +0 -107
  165. package/references/minimem/src/cli/sync/operations.ts +0 -373
  166. package/references/minimem/src/cli/sync/registry.ts +0 -279
  167. package/references/minimem/src/cli/sync/state.ts +0 -355
  168. package/references/minimem/src/cli/sync/validation.ts +0 -206
  169. package/references/minimem/src/cli/sync/watcher.ts +0 -234
  170. package/references/minimem/src/cli/version.ts +0 -34
  171. package/references/minimem/src/core/index.ts +0 -9
  172. package/references/minimem/src/core/indexer.ts +0 -628
  173. package/references/minimem/src/core/searcher.ts +0 -221
  174. package/references/minimem/src/db/schema.ts +0 -183
  175. package/references/minimem/src/db/sqlite-vec.ts +0 -24
  176. package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +0 -431
  177. package/references/minimem/src/embeddings/batch-gemini.ts +0 -392
  178. package/references/minimem/src/embeddings/batch-openai.ts +0 -409
  179. package/references/minimem/src/embeddings/embeddings.ts +0 -434
  180. package/references/minimem/src/index.ts +0 -109
  181. package/references/minimem/src/internal.ts +0 -299
  182. package/references/minimem/src/minimem.ts +0 -1276
  183. package/references/minimem/src/search/__tests__/hybrid.test.ts +0 -247
  184. package/references/minimem/src/search/graph.ts +0 -234
  185. package/references/minimem/src/search/hybrid.ts +0 -151
  186. package/references/minimem/src/search/search.ts +0 -256
  187. package/references/minimem/src/server/__tests__/mcp.test.ts +0 -341
  188. package/references/minimem/src/server/__tests__/tools.test.ts +0 -364
  189. package/references/minimem/src/server/mcp.ts +0 -326
  190. package/references/minimem/src/server/tools.ts +0 -720
  191. package/references/minimem/src/session.ts +0 -460
  192. package/references/minimem/tsconfig.json +0 -19
  193. package/references/minimem/tsup.config.ts +0 -26
  194. package/references/minimem/vitest.config.ts +0 -24
  195. package/references/sessionlog/.husky/pre-commit +0 -1
  196. package/references/sessionlog/.lintstagedrc.json +0 -4
  197. package/references/sessionlog/.prettierignore +0 -4
  198. package/references/sessionlog/.prettierrc.json +0 -11
  199. package/references/sessionlog/LICENSE +0 -21
  200. package/references/sessionlog/README.md +0 -453
  201. package/references/sessionlog/eslint.config.js +0 -58
  202. package/references/sessionlog/package-lock.json +0 -3672
  203. package/references/sessionlog/package.json +0 -65
  204. package/references/sessionlog/src/__tests__/agent-hooks.test.ts +0 -570
  205. package/references/sessionlog/src/__tests__/agent-registry.test.ts +0 -127
  206. package/references/sessionlog/src/__tests__/claude-code-hooks.test.ts +0 -225
  207. package/references/sessionlog/src/__tests__/claude-generator.test.ts +0 -46
  208. package/references/sessionlog/src/__tests__/commit-msg.test.ts +0 -86
  209. package/references/sessionlog/src/__tests__/cursor-agent.test.ts +0 -224
  210. package/references/sessionlog/src/__tests__/e2e-live.test.ts +0 -890
  211. package/references/sessionlog/src/__tests__/event-log.test.ts +0 -183
  212. package/references/sessionlog/src/__tests__/flush-sentinel.test.ts +0 -105
  213. package/references/sessionlog/src/__tests__/gemini-agent.test.ts +0 -375
  214. package/references/sessionlog/src/__tests__/git-hooks.test.ts +0 -78
  215. package/references/sessionlog/src/__tests__/hook-managers.test.ts +0 -121
  216. package/references/sessionlog/src/__tests__/lifecycle-tasks.test.ts +0 -759
  217. package/references/sessionlog/src/__tests__/opencode-agent.test.ts +0 -338
  218. package/references/sessionlog/src/__tests__/redaction.test.ts +0 -136
  219. package/references/sessionlog/src/__tests__/session-repo.test.ts +0 -353
  220. package/references/sessionlog/src/__tests__/session-store.test.ts +0 -166
  221. package/references/sessionlog/src/__tests__/setup-ccweb.test.ts +0 -466
  222. package/references/sessionlog/src/__tests__/skill-live.test.ts +0 -461
  223. package/references/sessionlog/src/__tests__/summarize.test.ts +0 -348
  224. package/references/sessionlog/src/__tests__/task-plan-e2e.test.ts +0 -610
  225. package/references/sessionlog/src/__tests__/task-plan-live.test.ts +0 -632
  226. package/references/sessionlog/src/__tests__/transcript-timestamp.test.ts +0 -121
  227. package/references/sessionlog/src/__tests__/types.test.ts +0 -166
  228. package/references/sessionlog/src/__tests__/utils.test.ts +0 -333
  229. package/references/sessionlog/src/__tests__/validation.test.ts +0 -103
  230. package/references/sessionlog/src/__tests__/worktree.test.ts +0 -57
  231. package/references/sessionlog/src/agent/agents/claude-code.ts +0 -1089
  232. package/references/sessionlog/src/agent/agents/cursor.ts +0 -361
  233. package/references/sessionlog/src/agent/agents/gemini-cli.ts +0 -632
  234. package/references/sessionlog/src/agent/agents/opencode.ts +0 -540
  235. package/references/sessionlog/src/agent/registry.ts +0 -143
  236. package/references/sessionlog/src/agent/session-types.ts +0 -113
  237. package/references/sessionlog/src/agent/types.ts +0 -220
  238. package/references/sessionlog/src/cli.ts +0 -597
  239. package/references/sessionlog/src/commands/clean.ts +0 -133
  240. package/references/sessionlog/src/commands/disable.ts +0 -84
  241. package/references/sessionlog/src/commands/doctor.ts +0 -145
  242. package/references/sessionlog/src/commands/enable.ts +0 -202
  243. package/references/sessionlog/src/commands/explain.ts +0 -261
  244. package/references/sessionlog/src/commands/reset.ts +0 -105
  245. package/references/sessionlog/src/commands/resume.ts +0 -180
  246. package/references/sessionlog/src/commands/rewind.ts +0 -195
  247. package/references/sessionlog/src/commands/setup-ccweb.ts +0 -275
  248. package/references/sessionlog/src/commands/status.ts +0 -172
  249. package/references/sessionlog/src/config.ts +0 -165
  250. package/references/sessionlog/src/events/event-log.ts +0 -126
  251. package/references/sessionlog/src/git-operations.ts +0 -558
  252. package/references/sessionlog/src/hooks/git-hooks.ts +0 -165
  253. package/references/sessionlog/src/hooks/lifecycle.ts +0 -391
  254. package/references/sessionlog/src/index.ts +0 -650
  255. package/references/sessionlog/src/security/redaction.ts +0 -283
  256. package/references/sessionlog/src/session/state-machine.ts +0 -452
  257. package/references/sessionlog/src/store/checkpoint-store.ts +0 -509
  258. package/references/sessionlog/src/store/native-store.ts +0 -173
  259. package/references/sessionlog/src/store/provider-types.ts +0 -99
  260. package/references/sessionlog/src/store/session-store.ts +0 -266
  261. package/references/sessionlog/src/strategy/attribution.ts +0 -296
  262. package/references/sessionlog/src/strategy/common.ts +0 -207
  263. package/references/sessionlog/src/strategy/content-overlap.ts +0 -228
  264. package/references/sessionlog/src/strategy/manual-commit.ts +0 -988
  265. package/references/sessionlog/src/strategy/types.ts +0 -279
  266. package/references/sessionlog/src/summarize/claude-generator.ts +0 -115
  267. package/references/sessionlog/src/summarize/summarize.ts +0 -432
  268. package/references/sessionlog/src/types.ts +0 -508
  269. package/references/sessionlog/src/utils/chunk-files.ts +0 -49
  270. package/references/sessionlog/src/utils/commit-message.ts +0 -65
  271. package/references/sessionlog/src/utils/detect-agent.ts +0 -36
  272. package/references/sessionlog/src/utils/hook-managers.ts +0 -125
  273. package/references/sessionlog/src/utils/ide-tags.ts +0 -32
  274. package/references/sessionlog/src/utils/paths.ts +0 -79
  275. package/references/sessionlog/src/utils/preview-rewind.ts +0 -80
  276. package/references/sessionlog/src/utils/rewind-conflict.ts +0 -121
  277. package/references/sessionlog/src/utils/shadow-branch.ts +0 -109
  278. package/references/sessionlog/src/utils/string-utils.ts +0 -46
  279. package/references/sessionlog/src/utils/todo-extract.ts +0 -188
  280. package/references/sessionlog/src/utils/trailers.ts +0 -187
  281. package/references/sessionlog/src/utils/transcript-parse.ts +0 -177
  282. package/references/sessionlog/src/utils/transcript-timestamp.ts +0 -59
  283. package/references/sessionlog/src/utils/tree-ops.ts +0 -219
  284. package/references/sessionlog/src/utils/tty.ts +0 -72
  285. package/references/sessionlog/src/utils/validation.ts +0 -65
  286. package/references/sessionlog/src/utils/worktree.ts +0 -58
  287. package/references/sessionlog/src/wire-types.ts +0 -59
  288. package/references/sessionlog/templates/setup-env.sh +0 -153
  289. package/references/sessionlog/tsconfig.json +0 -18
  290. package/references/sessionlog/vitest.config.ts +0 -12
  291. package/references/skill-tree/.claude/settings.json +0 -6
  292. package/references/skill-tree/.sudocode/issues.jsonl +0 -19
  293. package/references/skill-tree/.sudocode/specs.jsonl +0 -3
  294. package/references/skill-tree/CLAUDE.md +0 -126
  295. package/references/skill-tree/README.md +0 -372
  296. package/references/skill-tree/docs/GAPS_v1.md +0 -221
  297. package/references/skill-tree/docs/INTEGRATION_PLAN.md +0 -467
  298. package/references/skill-tree/docs/TODOS.md +0 -91
  299. package/references/skill-tree/docs/anthropic_skill_guide.md +0 -1364
  300. package/references/skill-tree/docs/design/federated-skill-trees.md +0 -524
  301. package/references/skill-tree/docs/design/multi-agent-sync.md +0 -759
  302. package/references/skill-tree/docs/scraper/BRAINSTORM.md +0 -583
  303. package/references/skill-tree/docs/scraper/POC_PLAN.md +0 -420
  304. package/references/skill-tree/docs/scraper/README.md +0 -170
  305. package/references/skill-tree/examples/basic-usage.ts +0 -164
  306. package/references/skill-tree/package-lock.json +0 -1852
  307. package/references/skill-tree/package.json +0 -66
  308. package/references/skill-tree/scraper/README.md +0 -123
  309. package/references/skill-tree/scraper/docs/DESIGN.md +0 -683
  310. package/references/skill-tree/scraper/docs/PLAN.md +0 -336
  311. package/references/skill-tree/scraper/drizzle.config.ts +0 -10
  312. package/references/skill-tree/scraper/package-lock.json +0 -6329
  313. package/references/skill-tree/scraper/package.json +0 -68
  314. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +0 -7
  315. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +0 -7
  316. package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +0 -27
  317. package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +0 -21
  318. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +0 -54
  319. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +0 -24
  320. package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +0 -93
  321. package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +0 -22
  322. package/references/skill-tree/scraper/tsup.config.ts +0 -14
  323. package/references/skill-tree/scraper/vitest.config.ts +0 -17
  324. package/references/skill-tree/scripts/convert-to-vitest.ts +0 -166
  325. package/references/skill-tree/skills/skill-writer/SKILL.md +0 -339
  326. package/references/skill-tree/skills/skill-writer/references/examples.md +0 -326
  327. package/references/skill-tree/skills/skill-writer/references/patterns.md +0 -210
  328. package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +0 -123
  329. package/references/skill-tree/test/run-all.ts +0 -106
  330. package/references/skill-tree/test/utils.ts +0 -128
  331. package/references/skill-tree/vitest.config.ts +0 -16
@@ -1,720 +0,0 @@
1
- /**
2
- * Tool definitions for memory operations
3
- *
4
- * These tools are compatible with:
5
- * - MCP (Model Context Protocol)
6
- * - Anthropic Claude tool use
7
- * - OpenAI function calling
8
- *
9
- * Note: Only memory_search is provided since the memory system is file-based.
10
- * Agents can use filesystem tools directly for read/write operations.
11
- */
12
-
13
- import type { Minimem, MinimemSearchResult } from "../minimem.js";
14
-
15
- /**
16
- * JSON Schema for tool parameters (MCP/OpenAI/Anthropic compatible)
17
- */
18
- export type ToolInputSchema = {
19
- type: "object";
20
- properties: Record<
21
- string,
22
- {
23
- type: string;
24
- description?: string;
25
- enum?: string[];
26
- items?: { type: string };
27
- default?: unknown;
28
- }
29
- >;
30
- required?: string[];
31
- };
32
-
33
- /**
34
- * Tool definition compatible with MCP, Anthropic, and OpenAI
35
- */
36
- export type ToolDefinition = {
37
- name: string;
38
- description: string;
39
- inputSchema: ToolInputSchema;
40
- };
41
-
42
- /**
43
- * Tool execution result
44
- */
45
- export type ToolResult = {
46
- content: Array<{ type: "text"; text: string }>;
47
- isError?: boolean;
48
- };
49
-
50
- /**
51
- * Memory search tool parameters
52
- */
53
- export type MemorySearchParams = {
54
- query: string;
55
- maxResults?: number;
56
- minScore?: number;
57
- directories?: string[];
58
- /** "compact" returns lightweight index; "full" returns complete snippets (default: "compact") */
59
- detail?: "compact" | "full";
60
- /** Filter by observation type (e.g., "decision", "bugfix", "feature", "discovery") */
61
- type?: string;
62
- };
63
-
64
- /**
65
- * Memory get details tool parameters
66
- */
67
- export type MemoryGetDetailsParams = {
68
- results: Array<{ path: string; startLine: number; endLine: number }>;
69
- directories?: string[];
70
- };
71
-
72
- /**
73
- * Knowledge search tool parameters
74
- */
75
- export type KnowledgeSearchParams = {
76
- query: string;
77
- domain?: string[];
78
- entities?: string[];
79
- minConfidence?: number;
80
- knowledgeType?: string;
81
- maxResults?: number;
82
- minScore?: number;
83
- directories?: string[];
84
- };
85
-
86
- /**
87
- * Knowledge graph traversal parameters
88
- */
89
- export type KnowledgeGraphParams = {
90
- nodeId: string;
91
- depth?: number;
92
- relation?: string;
93
- layer?: string;
94
- directories?: string[];
95
- };
96
-
97
- /**
98
- * Knowledge path parameters
99
- */
100
- export type KnowledgePathParams = {
101
- fromId: string;
102
- toId: string;
103
- maxDepth?: number;
104
- directories?: string[];
105
- };
106
-
107
- /**
108
- * Search result with source directory
109
- */
110
- type SearchResultWithSource = MinimemSearchResult & {
111
- memoryDir: string;
112
- };
113
-
114
- export const MEMORY_SEARCH_TOOL: ToolDefinition = {
115
- name: "memory_search",
116
- description:
117
- "Semantically search through memory files (MEMORY.md and memory/*.md). " +
118
- "Use this to recall prior decisions, facts, preferences, people, dates, or context. " +
119
- "Returns ranked snippets with file paths and line numbers. " +
120
- "When multiple memory directories are configured, searches all by default.",
121
- inputSchema: {
122
- type: "object",
123
- properties: {
124
- query: {
125
- type: "string",
126
- description: "Natural language search query",
127
- },
128
- maxResults: {
129
- type: "number",
130
- description: "Maximum number of results to return (default: 10)",
131
- },
132
- minScore: {
133
- type: "number",
134
- description: "Minimum relevance score threshold 0-1 (default: 0.3)",
135
- },
136
- directories: {
137
- type: "array",
138
- items: { type: "string" },
139
- description:
140
- "Optional: filter to specific memory directories by name/path. " +
141
- "If omitted, searches all configured directories.",
142
- },
143
- detail: {
144
- type: "string",
145
- enum: ["compact", "full"],
146
- description:
147
- "Result detail level. 'compact' returns a lightweight index with short previews (~80 chars). " +
148
- "'full' returns complete snippets. Use 'compact' first, then memory_get_details for selected results. " +
149
- "(default: 'compact')",
150
- },
151
- type: {
152
- type: "string",
153
- description:
154
- "Filter by observation type. Matches <!-- type: X --> comments in memory entries. " +
155
- "Common types: decision, bugfix, feature, discovery, context, note.",
156
- },
157
- },
158
- required: ["query"],
159
- },
160
- };
161
-
162
- export const MEMORY_GET_DETAILS_TOOL: ToolDefinition = {
163
- name: "memory_get_details",
164
- description:
165
- "Fetch full text for specific memory chunks identified by path and line range. " +
166
- "Use after memory_search with compact results to get details for selected items only. " +
167
- "This two-step approach significantly reduces token usage.",
168
- inputSchema: {
169
- type: "object",
170
- properties: {
171
- results: {
172
- type: "array",
173
- items: { type: "object" },
174
- description:
175
- "Array of { path, startLine, endLine } objects from compact search results.",
176
- },
177
- directories: {
178
- type: "array",
179
- items: { type: "string" },
180
- description: "Optional: filter to specific memory directories.",
181
- },
182
- },
183
- required: ["results"],
184
- },
185
- };
186
-
187
- export const KNOWLEDGE_SEARCH_TOOL: ToolDefinition = {
188
- name: "knowledge_search",
189
- description:
190
- "Search memory with knowledge metadata filters. " +
191
- "Filter by domain, entities, confidence level, or knowledge type (observation, entity, domain-summary). " +
192
- "Combines semantic search with structured knowledge filtering.",
193
- inputSchema: {
194
- type: "object",
195
- properties: {
196
- query: {
197
- type: "string",
198
- description: "Natural language search query",
199
- },
200
- domain: {
201
- type: "array",
202
- items: { type: "string" },
203
- description: "Filter to entries in these knowledge domains",
204
- },
205
- entities: {
206
- type: "array",
207
- items: { type: "string" },
208
- description: "Filter to entries referencing these entities",
209
- },
210
- minConfidence: {
211
- type: "number",
212
- description: "Minimum confidence threshold (0-1)",
213
- },
214
- knowledgeType: {
215
- type: "string",
216
- description: "Filter by knowledge type: observation, entity, domain-summary",
217
- },
218
- maxResults: {
219
- type: "number",
220
- description: "Maximum number of results (default: 10)",
221
- },
222
- minScore: {
223
- type: "number",
224
- description: "Minimum relevance score 0-1 (default: 0.3)",
225
- },
226
- directories: {
227
- type: "array",
228
- items: { type: "string" },
229
- description: "Optional: filter to specific memory directories",
230
- },
231
- },
232
- required: ["query"],
233
- },
234
- };
235
-
236
- export const KNOWLEDGE_GRAPH_TOOL: ToolDefinition = {
237
- name: "knowledge_graph",
238
- description:
239
- "Traverse knowledge graph links from a note. " +
240
- "Returns neighbor nodes connected by typed relationships (e.g., relates-to, supports, contradicts). " +
241
- "Use depth parameter for multi-hop traversal.",
242
- inputSchema: {
243
- type: "object",
244
- properties: {
245
- nodeId: {
246
- type: "string",
247
- description: "The knowledge node ID to start traversal from",
248
- },
249
- depth: {
250
- type: "number",
251
- description: "Maximum traversal depth (default: 1, max: 3)",
252
- default: 1,
253
- },
254
- relation: {
255
- type: "string",
256
- description: "Optional: filter to specific relation type",
257
- },
258
- layer: {
259
- type: "string",
260
- description: "Optional: filter to specific graph layer",
261
- },
262
- directories: {
263
- type: "array",
264
- items: { type: "string" },
265
- description: "Optional: filter to specific memory directories",
266
- },
267
- },
268
- required: ["nodeId"],
269
- },
270
- };
271
-
272
- export const KNOWLEDGE_PATH_TOOL: ToolDefinition = {
273
- name: "knowledge_path",
274
- description:
275
- "Find the shortest path between two knowledge nodes in the graph. " +
276
- "Uses BFS traversal up to a configurable max depth. " +
277
- "Returns the sequence of links connecting the two nodes.",
278
- inputSchema: {
279
- type: "object",
280
- properties: {
281
- fromId: {
282
- type: "string",
283
- description: "Starting knowledge node ID",
284
- },
285
- toId: {
286
- type: "string",
287
- description: "Target knowledge node ID",
288
- },
289
- maxDepth: {
290
- type: "number",
291
- description: "Maximum path length (default: 3)",
292
- default: 3,
293
- },
294
- directories: {
295
- type: "array",
296
- items: { type: "string" },
297
- description: "Optional: filter to specific memory directories",
298
- },
299
- },
300
- required: ["fromId", "toId"],
301
- },
302
- };
303
-
304
- /**
305
- * All available memory tools
306
- */
307
- export const MEMORY_TOOLS: ToolDefinition[] = [
308
- MEMORY_SEARCH_TOOL,
309
- MEMORY_GET_DETAILS_TOOL,
310
- KNOWLEDGE_SEARCH_TOOL,
311
- KNOWLEDGE_GRAPH_TOOL,
312
- KNOWLEDGE_PATH_TOOL,
313
- ];
314
-
315
- /**
316
- * Get tool definitions for use with LLM APIs
317
- */
318
- export function getToolDefinitions(): ToolDefinition[] {
319
- return MEMORY_TOOLS;
320
- }
321
-
322
- /**
323
- * Memory instance with its directory path
324
- */
325
- export type MemoryInstance = {
326
- minimem: Minimem;
327
- memoryDir: string;
328
- name?: string;
329
- };
330
-
331
- /**
332
- * Tool executor that handles memory search across multiple directories
333
- */
334
- export class MemoryToolExecutor {
335
- private instances: MemoryInstance[];
336
-
337
- constructor(instances: Minimem | MemoryInstance | MemoryInstance[]) {
338
- // Normalize to array of MemoryInstance
339
- if (Array.isArray(instances)) {
340
- this.instances = instances;
341
- } else if ("minimem" in instances) {
342
- this.instances = [instances];
343
- } else {
344
- // Legacy: single Minimem instance without directory info
345
- this.instances = [{ minimem: instances, memoryDir: "default" }];
346
- }
347
- }
348
-
349
- /**
350
- * Get list of configured directory names/paths
351
- */
352
- getDirectories(): string[] {
353
- return this.instances.map((i) => i.name ?? i.memoryDir);
354
- }
355
-
356
- /**
357
- * Execute a tool by name with given parameters
358
- */
359
- async execute(
360
- toolName: string,
361
- params: Record<string, unknown>,
362
- ): Promise<ToolResult> {
363
- try {
364
- switch (toolName) {
365
- case "memory_search":
366
- return await this.memorySearch(params as MemorySearchParams);
367
- case "memory_get_details":
368
- return await this.memoryGetDetails(params as MemoryGetDetailsParams);
369
- case "knowledge_search":
370
- return await this.knowledgeSearch(params as KnowledgeSearchParams);
371
- case "knowledge_graph":
372
- return await this.knowledgeGraph(params as KnowledgeGraphParams);
373
- case "knowledge_path":
374
- return await this.knowledgePath(params as KnowledgePathParams);
375
- default:
376
- return {
377
- content: [{ type: "text", text: `Unknown tool: ${toolName}` }],
378
- isError: true,
379
- };
380
- }
381
- } catch (err) {
382
- const message = err instanceof Error ? err.message : String(err);
383
- return {
384
- content: [{ type: "text", text: `Error: ${message}` }],
385
- isError: true,
386
- };
387
- }
388
- }
389
-
390
- /**
391
- * Filter instances by directory names/paths
392
- */
393
- private filterInstances(directories?: string[]): MemoryInstance[] | null {
394
- if (!directories || directories.length === 0) return this.instances;
395
-
396
- const dirFilter = new Set(directories.map((d) => d.toLowerCase()));
397
- const filtered = this.instances.filter((i) => {
398
- const name = (i.name ?? i.memoryDir).toLowerCase();
399
- const dir = i.memoryDir.toLowerCase();
400
- return (
401
- dirFilter.has(name) ||
402
- dirFilter.has(dir) ||
403
- [...dirFilter].some((f) => dir.includes(f) || name.includes(f))
404
- );
405
- });
406
-
407
- return filtered.length > 0 ? filtered : null;
408
- }
409
-
410
- private async memorySearch(params: MemorySearchParams): Promise<ToolResult> {
411
- const maxResults = params.maxResults ?? 10;
412
- const minScore = params.minScore;
413
- const detail = params.detail ?? "compact";
414
-
415
- const instancesToSearch = this.filterInstances(params.directories);
416
- if (!instancesToSearch) {
417
- const available = this.getDirectories().join(", ");
418
- return {
419
- content: [
420
- {
421
- type: "text",
422
- text: `No matching directories found. Available: ${available}`,
423
- },
424
- ],
425
- isError: true,
426
- };
427
- }
428
-
429
- // Search all matching instances
430
- const allResults: SearchResultWithSource[] = [];
431
-
432
- for (const instance of instancesToSearch) {
433
- const perDirMax = Math.ceil(maxResults * 1.5);
434
- const results = await instance.minimem.search(params.query, {
435
- maxResults: perDirMax,
436
- minScore,
437
- type: params.type,
438
- });
439
-
440
- for (const result of results) {
441
- allResults.push({
442
- ...result,
443
- memoryDir: instance.name ?? instance.memoryDir,
444
- });
445
- }
446
- }
447
-
448
- // Sort by score and limit
449
- allResults.sort((a, b) => b.score - a.score);
450
- const topResults = allResults.slice(0, maxResults);
451
-
452
- if (topResults.length === 0) {
453
- return {
454
- content: [{ type: "text", text: "No results found." }],
455
- };
456
- }
457
-
458
- const showSource = instancesToSearch.length > 1;
459
-
460
- if (detail === "compact") {
461
- return this.formatCompactResults(topResults, showSource, instancesToSearch.length);
462
- }
463
-
464
- return this.formatFullResults(topResults, showSource, instancesToSearch.length);
465
- }
466
-
467
- private formatCompactResults(
468
- results: SearchResultWithSource[],
469
- showSource: boolean,
470
- dirCount: number,
471
- ): ToolResult {
472
- const formatted = results
473
- .map((r, i) => {
474
- const location = `${r.path}:${r.startLine}-${r.endLine}`;
475
- const score = (r.score * 100).toFixed(0);
476
- const source = showSource ? ` [${r.memoryDir}]` : "";
477
- const preview = compactPreview(r.snippet);
478
- return `[${i}] ${location}${source} (${score}%) — ${preview}`;
479
- })
480
- .join("\n");
481
-
482
- const hint = "\n\nUse memory_get_details to fetch full text for selected results.";
483
- const dirSummary = dirCount > 1 ? `\n(Searched ${dirCount} directories)` : "";
484
-
485
- return {
486
- content: [{ type: "text", text: formatted + dirSummary + hint }],
487
- };
488
- }
489
-
490
- private formatFullResults(
491
- results: SearchResultWithSource[],
492
- showSource: boolean,
493
- dirCount: number,
494
- ): ToolResult {
495
- const formatted = results
496
- .map((r, i) => {
497
- const location = `${r.path}:${r.startLine}-${r.endLine}`;
498
- const score = (r.score * 100).toFixed(1);
499
- const source = showSource ? ` [${r.memoryDir}]` : "";
500
- return `[${i + 1}] ${location}${source} (${score}% match)\n${r.snippet}`;
501
- })
502
- .join("\n\n");
503
-
504
- const dirSummary =
505
- dirCount > 1 ? `\n\n(Searched ${dirCount} directories)` : "";
506
-
507
- return {
508
- content: [{ type: "text", text: formatted + dirSummary }],
509
- };
510
- }
511
-
512
- private async memoryGetDetails(params: MemoryGetDetailsParams): Promise<ToolResult> {
513
- if (!params.results || params.results.length === 0) {
514
- return {
515
- content: [{ type: "text", text: "No results specified." }],
516
- isError: true,
517
- };
518
- }
519
-
520
- const instancesToSearch = this.filterInstances(params.directories);
521
- if (!instancesToSearch) {
522
- const available = this.getDirectories().join(", ");
523
- return {
524
- content: [
525
- {
526
- type: "text",
527
- text: `No matching directories found. Available: ${available}`,
528
- },
529
- ],
530
- isError: true,
531
- };
532
- }
533
-
534
- const details: string[] = [];
535
-
536
- for (const ref of params.results) {
537
- let found = false;
538
-
539
- for (const instance of instancesToSearch) {
540
- const lineCount = ref.endLine - ref.startLine + 1;
541
- const result = await instance.minimem.readLines(ref.path, {
542
- from: ref.startLine,
543
- lines: lineCount,
544
- });
545
-
546
- if (result) {
547
- const location = `${ref.path}:${result.startLine}-${result.endLine}`;
548
- details.push(`--- ${location} ---\n${result.content}`);
549
- found = true;
550
- break;
551
- }
552
- }
553
-
554
- if (!found) {
555
- details.push(`--- ${ref.path}:${ref.startLine}-${ref.endLine} ---\n(not found)`);
556
- }
557
- }
558
-
559
- return {
560
- content: [{ type: "text", text: details.join("\n\n") }],
561
- };
562
- }
563
-
564
- private async knowledgeSearch(params: KnowledgeSearchParams): Promise<ToolResult> {
565
- const instancesToSearch = this.filterInstances(params.directories);
566
- if (!instancesToSearch) {
567
- const available = this.getDirectories().join(", ");
568
- return {
569
- content: [{ type: "text", text: `No matching directories found. Available: ${available}` }],
570
- isError: true,
571
- };
572
- }
573
-
574
- const maxResults = params.maxResults ?? 10;
575
- const allResults: SearchResultWithSource[] = [];
576
-
577
- for (const instance of instancesToSearch) {
578
- const results = await instance.minimem.knowledgeSearch(params.query, {
579
- maxResults: Math.ceil(maxResults * 1.5),
580
- minScore: params.minScore,
581
- domain: params.domain,
582
- entities: params.entities,
583
- minConfidence: params.minConfidence,
584
- knowledgeType: params.knowledgeType,
585
- });
586
-
587
- for (const result of results) {
588
- allResults.push({
589
- ...result,
590
- memoryDir: instance.name ?? instance.memoryDir,
591
- });
592
- }
593
- }
594
-
595
- allResults.sort((a, b) => b.score - a.score);
596
- const topResults = allResults.slice(0, maxResults);
597
-
598
- if (topResults.length === 0) {
599
- return { content: [{ type: "text", text: "No knowledge results found." }] };
600
- }
601
-
602
- const formatted = topResults
603
- .map((r, i) => {
604
- const location = `${r.path}:${r.startLine}-${r.endLine}`;
605
- const score = (r.score * 100).toFixed(0);
606
- const preview = compactPreview(r.snippet);
607
- return `[${i}] ${location} (${score}%) — ${preview}`;
608
- })
609
- .join("\n");
610
-
611
- return { content: [{ type: "text", text: formatted }] };
612
- }
613
-
614
- private async knowledgeGraph(params: KnowledgeGraphParams): Promise<ToolResult> {
615
- const instancesToSearch = this.filterInstances(params.directories);
616
- if (!instancesToSearch) {
617
- const available = this.getDirectories().join(", ");
618
- return {
619
- content: [{ type: "text", text: `No matching directories found. Available: ${available}` }],
620
- isError: true,
621
- };
622
- }
623
-
624
- const depth = Math.min(params.depth ?? 1, 3);
625
- const allNeighbors: Array<{ id: string; depth: number; relation: string; layer: string | null; memoryDir: string }> = [];
626
-
627
- for (const instance of instancesToSearch) {
628
- const neighbors = instance.minimem.getGraphNeighbors(params.nodeId, depth, {
629
- relation: params.relation,
630
- layer: params.layer,
631
- });
632
-
633
- for (const n of neighbors) {
634
- allNeighbors.push({
635
- id: n.id,
636
- depth: n.depth,
637
- relation: n.link.relation,
638
- layer: n.link.layer,
639
- memoryDir: instance.name ?? instance.memoryDir,
640
- });
641
- }
642
- }
643
-
644
- if (allNeighbors.length === 0) {
645
- return { content: [{ type: "text", text: `No neighbors found for node "${params.nodeId}".` }] };
646
- }
647
-
648
- const formatted = allNeighbors
649
- .map((n) => ` [depth=${n.depth}] ${n.id} —(${n.relation})${n.layer ? ` [${n.layer}]` : ""}`)
650
- .join("\n");
651
-
652
- return {
653
- content: [{ type: "text", text: `Neighbors of "${params.nodeId}":\n${formatted}` }],
654
- };
655
- }
656
-
657
- private async knowledgePath(params: KnowledgePathParams): Promise<ToolResult> {
658
- const instancesToSearch = this.filterInstances(params.directories);
659
- if (!instancesToSearch) {
660
- const available = this.getDirectories().join(", ");
661
- return {
662
- content: [{ type: "text", text: `No matching directories found. Available: ${available}` }],
663
- isError: true,
664
- };
665
- }
666
-
667
- const maxDepth = Math.min(params.maxDepth ?? 3, 5);
668
-
669
- // Try each instance until a path is found
670
- for (const instance of instancesToSearch) {
671
- const path = instance.minimem.getGraphPath(params.fromId, params.toId, maxDepth);
672
- if (path.length > 0) {
673
- const steps = path
674
- .map((link) => ` ${link.fromId} —(${link.relation})→ ${link.toId}`)
675
- .join("\n");
676
- return {
677
- content: [{
678
- type: "text",
679
- text: `Path from "${params.fromId}" to "${params.toId}" (${path.length} steps):\n${steps}`,
680
- }],
681
- };
682
- }
683
- }
684
-
685
- return {
686
- content: [{
687
- type: "text",
688
- text: `No path found from "${params.fromId}" to "${params.toId}" within depth ${maxDepth}.`,
689
- }],
690
- };
691
- }
692
- }
693
-
694
- /**
695
- * Generate a compact preview from a snippet (~80 chars).
696
- * Prefers the first heading or first non-empty line.
697
- */
698
- function compactPreview(snippet: string): string {
699
- const maxLen = 80;
700
- const lines = snippet.split("\n").filter((l) => l.trim());
701
- if (lines.length === 0) return "(empty)";
702
-
703
- // Prefer a heading line
704
- const heading = lines.find((l) => l.startsWith("#"));
705
- const text = heading ?? lines[0];
706
- // Strip markdown heading markers for cleaner display
707
- const cleaned = text.replace(/^#+\s*/, "").trim();
708
-
709
- if (cleaned.length <= maxLen) return `"${cleaned}"`;
710
- return `"${cleaned.slice(0, maxLen - 3)}..."`;
711
- }
712
-
713
- /**
714
- * Create a tool executor for the given Minimem instance(s)
715
- */
716
- export function createToolExecutor(
717
- instances: Minimem | MemoryInstance | MemoryInstance[],
718
- ): MemoryToolExecutor {
719
- return new MemoryToolExecutor(instances);
720
- }