mdcontext 0.0.1 → 0.2.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 (337) hide show
  1. package/.changeset/README.md +28 -0
  2. package/.changeset/config.json +11 -0
  3. package/.claude/settings.local.json +25 -0
  4. package/.github/workflows/ci.yml +83 -0
  5. package/.github/workflows/claude-code-review.yml +44 -0
  6. package/.github/workflows/claude.yml +85 -0
  7. package/.github/workflows/release.yml +113 -0
  8. package/.tldrignore +112 -0
  9. package/BACKLOG.md +338 -0
  10. package/CONTRIBUTING.md +186 -0
  11. package/NOTES/NOTES +44 -0
  12. package/README.md +434 -11
  13. package/biome.json +36 -0
  14. package/cspell.config.yaml +14 -0
  15. package/dist/chunk-23UPXDNL.js +3044 -0
  16. package/dist/chunk-2W7MO2DL.js +1366 -0
  17. package/dist/chunk-3NUAZGMA.js +1689 -0
  18. package/dist/chunk-7TOWB2XB.js +366 -0
  19. package/dist/chunk-7XOTOADQ.js +3065 -0
  20. package/dist/chunk-AH2PDM2K.js +3042 -0
  21. package/dist/chunk-BNXWSZ63.js +3742 -0
  22. package/dist/chunk-BTL5DJVU.js +3222 -0
  23. package/dist/chunk-HDHYG7E4.js +104 -0
  24. package/dist/chunk-HLR4KZBP.js +3234 -0
  25. package/dist/chunk-IP3FRFEB.js +1045 -0
  26. package/dist/chunk-KHU56VDO.js +3042 -0
  27. package/dist/chunk-KRYIFLQR.js +88 -0
  28. package/dist/chunk-LBSDNLEM.js +287 -0
  29. package/dist/chunk-MNTQ7HCP.js +2643 -0
  30. package/dist/chunk-MUJELQQ6.js +1387 -0
  31. package/dist/chunk-MXJGMSLV.js +2199 -0
  32. package/dist/chunk-N6QJGC3Z.js +2636 -0
  33. package/dist/chunk-OBELGBPM.js +1713 -0
  34. package/dist/chunk-OT7R5XTA.js +3192 -0
  35. package/dist/chunk-P7X4RA2T.js +106 -0
  36. package/dist/chunk-PIDUQNC2.js +3185 -0
  37. package/dist/chunk-POGCDIH4.js +3187 -0
  38. package/dist/chunk-PSIEOQGZ.js +3043 -0
  39. package/dist/chunk-PVRT3IHA.js +3238 -0
  40. package/dist/chunk-QNN4TT23.js +1430 -0
  41. package/dist/chunk-RE3R45RJ.js +3042 -0
  42. package/dist/chunk-S7E6TFX6.js +803 -0
  43. package/dist/chunk-SG6GLU4U.js +1378 -0
  44. package/dist/chunk-SJCDV2ST.js +274 -0
  45. package/dist/chunk-SYE5XLF3.js +104 -0
  46. package/dist/chunk-T5VLYBZD.js +103 -0
  47. package/dist/chunk-TOQB7VWU.js +3238 -0
  48. package/dist/chunk-VFNMZ4ZQ.js +3228 -0
  49. package/dist/chunk-VVTGZNBT.js +1629 -0
  50. package/dist/chunk-W7Q4RFEV.js +104 -0
  51. package/dist/chunk-XTYYVRLO.js +3190 -0
  52. package/dist/chunk-Y6MDYVJD.js +3063 -0
  53. package/dist/cli/main.d.ts +1 -0
  54. package/dist/cli/main.js +5458 -0
  55. package/dist/index.d.ts +653 -0
  56. package/dist/index.js +79 -0
  57. package/dist/mcp/server.d.ts +1 -0
  58. package/dist/mcp/server.js +472 -0
  59. package/dist/schema-BAWSG7KY.js +22 -0
  60. package/dist/schema-E3QUPL26.js +20 -0
  61. package/dist/schema-EHL7WUT6.js +20 -0
  62. package/docs/019-USAGE.md +625 -0
  63. package/docs/020-current-implementation.md +364 -0
  64. package/docs/021-DOGFOODING-FINDINGS.md +175 -0
  65. package/docs/BACKLOG.md +80 -0
  66. package/docs/CONFIG.md +1123 -0
  67. package/docs/DESIGN.md +439 -0
  68. package/docs/ERRORS.md +383 -0
  69. package/docs/PROJECT.md +88 -0
  70. package/docs/ROADMAP.md +407 -0
  71. package/docs/summarization.md +320 -0
  72. package/docs/test-links.md +9 -0
  73. package/justfile +40 -0
  74. package/package.json +74 -9
  75. package/pnpm-workspace.yaml +5 -0
  76. package/research/INDEX.md +315 -0
  77. package/research/code-review/README.md +90 -0
  78. package/research/code-review/cli-error-handling-review.md +979 -0
  79. package/research/code-review/code-review-validation-report.md +464 -0
  80. package/research/code-review/main-ts-review.md +1128 -0
  81. package/research/config-analysis/01-current-implementation.md +470 -0
  82. package/research/config-analysis/02-strategy-recommendation.md +428 -0
  83. package/research/config-analysis/03-task-candidates.md +715 -0
  84. package/research/config-analysis/033-research-configuration-management.md +828 -0
  85. package/research/config-analysis/034-research-effect-cli-config.md +1504 -0
  86. package/research/config-analysis/04-consolidated-task-candidates.md +277 -0
  87. package/research/config-docs/SUMMARY.md +357 -0
  88. package/research/config-docs/TEST-RESULTS.md +776 -0
  89. package/research/config-docs/TODO.md +542 -0
  90. package/research/config-docs/analysis.md +744 -0
  91. package/research/config-docs/fix-validation.md +502 -0
  92. package/research/config-docs/help-audit.md +264 -0
  93. package/research/config-docs/help-system-analysis.md +890 -0
  94. package/research/dogfood/consolidated-tool-evaluation.md +373 -0
  95. package/research/dogfood/strategy-a/a-synthesis.md +184 -0
  96. package/research/dogfood/strategy-a/a1-docs.md +226 -0
  97. package/research/dogfood/strategy-a/a2-amorphic.md +156 -0
  98. package/research/dogfood/strategy-a/a3-llm.md +164 -0
  99. package/research/dogfood/strategy-b/b-synthesis.md +228 -0
  100. package/research/dogfood/strategy-b/b1-architecture.md +207 -0
  101. package/research/dogfood/strategy-b/b2-gaps.md +258 -0
  102. package/research/dogfood/strategy-b/b3-workflows.md +250 -0
  103. package/research/dogfood/strategy-c/c-synthesis.md +451 -0
  104. package/research/dogfood/strategy-c/c1-explorer.md +192 -0
  105. package/research/dogfood/strategy-c/c2-diver-memory.md +145 -0
  106. package/research/dogfood/strategy-c/c3-diver-control.md +148 -0
  107. package/research/dogfood/strategy-c/c4-diver-failure.md +151 -0
  108. package/research/dogfood/strategy-c/c5-diver-execution.md +221 -0
  109. package/research/dogfood/strategy-c/c6-diver-org.md +221 -0
  110. package/research/effect-cli-error-handling.md +845 -0
  111. package/research/effect-errors-as-values.md +943 -0
  112. package/research/errors-task-analysis/00-consolidated-tasks.md +207 -0
  113. package/research/errors-task-analysis/cli-commands-analysis.md +909 -0
  114. package/research/errors-task-analysis/embeddings-analysis.md +709 -0
  115. package/research/errors-task-analysis/index-search-analysis.md +812 -0
  116. package/research/frontmatter/COMMENTS-ARE-SKIPPED.md +149 -0
  117. package/research/frontmatter/LLM-CODE-NAVIGATION.md +276 -0
  118. package/research/issue-review.md +603 -0
  119. package/research/llm-summarization/agent-cli-tools-2026.md +1082 -0
  120. package/research/llm-summarization/alternative-providers-2026.md +1428 -0
  121. package/research/llm-summarization/anthropic-2026.md +367 -0
  122. package/research/llm-summarization/claude-cli-integration.md +1706 -0
  123. package/research/llm-summarization/cli-integration-patterns.md +3155 -0
  124. package/research/llm-summarization/openai-2026.md +473 -0
  125. package/research/llm-summarization/openai-compatible-providers-2026.md +1022 -0
  126. package/research/llm-summarization/opencode-cli-integration.md +1552 -0
  127. package/research/llm-summarization/prompt-engineering-2026.md +1426 -0
  128. package/research/llm-summarization/prototype-results.md +56 -0
  129. package/research/llm-summarization/provider-switching-patterns-2026.md +2153 -0
  130. package/research/llm-summarization/typescript-llm-libraries-2026.md +2436 -0
  131. package/research/mdcontext-error-analysis.md +521 -0
  132. package/research/mdcontext-pudding/00-EXECUTIVE-SUMMARY.md +282 -0
  133. package/research/mdcontext-pudding/01-index-embed.md +956 -0
  134. package/research/mdcontext-pudding/02-search-COMMANDS.md +142 -0
  135. package/research/mdcontext-pudding/02-search-SUMMARY.md +146 -0
  136. package/research/mdcontext-pudding/02-search.md +970 -0
  137. package/research/mdcontext-pudding/03-context.md +779 -0
  138. package/research/mdcontext-pudding/04-navigation-and-analytics.md +803 -0
  139. package/research/mdcontext-pudding/04-tree.md +704 -0
  140. package/research/mdcontext-pudding/05-config.md +1038 -0
  141. package/research/mdcontext-pudding/06-links-summary.txt +87 -0
  142. package/research/mdcontext-pudding/06-links.md +679 -0
  143. package/research/mdcontext-pudding/07-stats.md +693 -0
  144. package/research/mdcontext-pudding/BUG-FIX-PLAN.md +388 -0
  145. package/research/mdcontext-pudding/P0-BUG-VALIDATION.md +167 -0
  146. package/research/mdcontext-pudding/README.md +168 -0
  147. package/research/mdcontext-pudding/TESTING-SUMMARY.md +128 -0
  148. package/research/npm_publish/011-npm-workflow-research-agent2.md +792 -0
  149. package/research/npm_publish/012-npm-workflow-research-agent1.md +530 -0
  150. package/research/npm_publish/013-npm-workflow-research-agent3.md +722 -0
  151. package/research/npm_publish/014-npm-workflow-synthesis.md +556 -0
  152. package/research/npm_publish/031-npm-workflow-task-analysis.md +134 -0
  153. package/research/research-quality-review.md +834 -0
  154. package/research/semantic-search/002-research-embedding-models.md +490 -0
  155. package/research/semantic-search/003-research-rag-alternatives.md +523 -0
  156. package/research/semantic-search/004-research-vector-search.md +841 -0
  157. package/research/semantic-search/032-research-semantic-search.md +427 -0
  158. package/research/semantic-search/embedding-text-analysis.md +156 -0
  159. package/research/semantic-search/multi-word-failure-reproduction.md +171 -0
  160. package/research/semantic-search/query-processing-analysis.md +207 -0
  161. package/research/semantic-search/root-cause-and-solution.md +114 -0
  162. package/research/semantic-search/threshold-validation-report.md +69 -0
  163. package/research/semantic-search/vector-search-analysis.md +63 -0
  164. package/research/task-management-2026/00-synthesis-recommendations.md +295 -0
  165. package/research/task-management-2026/01-ai-workflow-tools.md +416 -0
  166. package/research/task-management-2026/02-agent-framework-patterns.md +476 -0
  167. package/research/task-management-2026/03-lightweight-file-based.md +567 -0
  168. package/research/task-management-2026/04-established-tools-ai-features.md +541 -0
  169. package/research/task-management-2026/linear/01-core-features-workflow.md +771 -0
  170. package/research/task-management-2026/linear/02-api-integrations.md +930 -0
  171. package/research/task-management-2026/linear/03-ai-features.md +368 -0
  172. package/research/task-management-2026/linear/04-pricing-setup.md +205 -0
  173. package/research/task-management-2026/linear/05-usage-patterns-best-practices.md +605 -0
  174. package/research/test-path-issues.md +276 -0
  175. package/review/ALP-76/1-error-type-design.md +962 -0
  176. package/review/ALP-76/2-error-handling-patterns.md +906 -0
  177. package/review/ALP-76/3-error-presentation.md +624 -0
  178. package/review/ALP-76/4-test-coverage.md +625 -0
  179. package/review/ALP-76/5-migration-completeness.md +440 -0
  180. package/review/ALP-76/6-effect-best-practices.md +755 -0
  181. package/scripts/apply-branch-protection.sh +47 -0
  182. package/scripts/branch-protection-templates.json +79 -0
  183. package/scripts/prototype-summarization.ts +346 -0
  184. package/scripts/rebuild-hnswlib.js +58 -0
  185. package/scripts/setup-branch-protection.sh +64 -0
  186. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/active-provider.json +7 -0
  187. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/bm25.json +541 -0
  188. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/bm25.meta.json +5 -0
  189. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/config.json +8 -0
  190. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/embeddings/openai_text-embedding-3-small_512/vectors.bin +0 -0
  191. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/embeddings/openai_text-embedding-3-small_512/vectors.meta.bin +0 -0
  192. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/indexes/documents.json +60 -0
  193. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/indexes/links.json +13 -0
  194. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/.mdcontext/indexes/sections.json +1197 -0
  195. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/configuration-management.md +99 -0
  196. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/distributed-systems.md +92 -0
  197. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/error-handling.md +78 -0
  198. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/failure-automation.md +55 -0
  199. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/job-context.md +69 -0
  200. package/src/__tests__/fixtures/semantic-search/multi-word-corpus/process-orchestration.md +99 -0
  201. package/src/cli/argv-preprocessor.test.ts +210 -0
  202. package/src/cli/argv-preprocessor.ts +202 -0
  203. package/src/cli/cli.test.ts +627 -0
  204. package/src/cli/commands/backlinks.ts +54 -0
  205. package/src/cli/commands/config-cmd.ts +642 -0
  206. package/src/cli/commands/context.ts +285 -0
  207. package/src/cli/commands/duplicates.ts +122 -0
  208. package/src/cli/commands/embeddings.ts +529 -0
  209. package/src/cli/commands/index-cmd.ts +480 -0
  210. package/src/cli/commands/index.ts +16 -0
  211. package/src/cli/commands/links.ts +52 -0
  212. package/src/cli/commands/search.ts +1281 -0
  213. package/src/cli/commands/stats.ts +149 -0
  214. package/src/cli/commands/tree.ts +128 -0
  215. package/src/cli/config-layer.ts +176 -0
  216. package/src/cli/error-handler.test.ts +235 -0
  217. package/src/cli/error-handler.ts +655 -0
  218. package/src/cli/flag-schemas.ts +341 -0
  219. package/src/cli/help.ts +588 -0
  220. package/src/cli/index.ts +9 -0
  221. package/src/cli/main.ts +435 -0
  222. package/src/cli/options.ts +41 -0
  223. package/src/cli/shared-error-handling.ts +199 -0
  224. package/src/cli/typo-suggester.test.ts +105 -0
  225. package/src/cli/typo-suggester.ts +130 -0
  226. package/src/cli/utils.ts +259 -0
  227. package/src/config/file-provider.test.ts +320 -0
  228. package/src/config/file-provider.ts +273 -0
  229. package/src/config/index.ts +72 -0
  230. package/src/config/integration.test.ts +667 -0
  231. package/src/config/precedence.test.ts +277 -0
  232. package/src/config/precedence.ts +451 -0
  233. package/src/config/schema.test.ts +414 -0
  234. package/src/config/schema.ts +603 -0
  235. package/src/config/service.test.ts +320 -0
  236. package/src/config/service.ts +243 -0
  237. package/src/config/testing.test.ts +264 -0
  238. package/src/config/testing.ts +110 -0
  239. package/src/core/index.ts +1 -0
  240. package/src/core/types.ts +113 -0
  241. package/src/duplicates/detector.test.ts +183 -0
  242. package/src/duplicates/detector.ts +414 -0
  243. package/src/duplicates/index.ts +18 -0
  244. package/src/embeddings/embedding-namespace.test.ts +300 -0
  245. package/src/embeddings/embedding-namespace.ts +947 -0
  246. package/src/embeddings/heading-boost.test.ts +222 -0
  247. package/src/embeddings/hnsw-build-options.test.ts +198 -0
  248. package/src/embeddings/hyde.test.ts +272 -0
  249. package/src/embeddings/hyde.ts +264 -0
  250. package/src/embeddings/index.ts +10 -0
  251. package/src/embeddings/openai-provider.ts +414 -0
  252. package/src/embeddings/pricing.json +22 -0
  253. package/src/embeddings/provider-constants.ts +204 -0
  254. package/src/embeddings/provider-errors.test.ts +967 -0
  255. package/src/embeddings/provider-errors.ts +565 -0
  256. package/src/embeddings/provider-factory.test.ts +240 -0
  257. package/src/embeddings/provider-factory.ts +225 -0
  258. package/src/embeddings/provider-integration.test.ts +788 -0
  259. package/src/embeddings/query-preprocessing.test.ts +187 -0
  260. package/src/embeddings/semantic-search-threshold.test.ts +508 -0
  261. package/src/embeddings/semantic-search.ts +1270 -0
  262. package/src/embeddings/types.ts +359 -0
  263. package/src/embeddings/vector-store.ts +708 -0
  264. package/src/embeddings/voyage-provider.ts +313 -0
  265. package/src/errors/errors.test.ts +845 -0
  266. package/src/errors/index.ts +533 -0
  267. package/src/index/ignore-patterns.test.ts +354 -0
  268. package/src/index/ignore-patterns.ts +305 -0
  269. package/src/index/index.ts +4 -0
  270. package/src/index/indexer.ts +684 -0
  271. package/src/index/storage.ts +260 -0
  272. package/src/index/types.ts +147 -0
  273. package/src/index/watcher.ts +189 -0
  274. package/src/index.ts +30 -0
  275. package/src/integration/search-keyword.test.ts +678 -0
  276. package/src/mcp/server.ts +612 -0
  277. package/src/parser/index.ts +1 -0
  278. package/src/parser/parser.test.ts +291 -0
  279. package/src/parser/parser.ts +394 -0
  280. package/src/parser/section-filter.test.ts +277 -0
  281. package/src/parser/section-filter.ts +392 -0
  282. package/src/search/__tests__/hybrid-search.test.ts +650 -0
  283. package/src/search/bm25-store.ts +366 -0
  284. package/src/search/cross-encoder.test.ts +253 -0
  285. package/src/search/cross-encoder.ts +406 -0
  286. package/src/search/fuzzy-search.test.ts +419 -0
  287. package/src/search/fuzzy-search.ts +273 -0
  288. package/src/search/hybrid-search.ts +448 -0
  289. package/src/search/path-matcher.test.ts +276 -0
  290. package/src/search/path-matcher.ts +33 -0
  291. package/src/search/query-parser.test.ts +260 -0
  292. package/src/search/query-parser.ts +319 -0
  293. package/src/search/searcher.test.ts +280 -0
  294. package/src/search/searcher.ts +724 -0
  295. package/src/search/wink-bm25.d.ts +30 -0
  296. package/src/summarization/cli-providers/claude.ts +202 -0
  297. package/src/summarization/cli-providers/detection.test.ts +273 -0
  298. package/src/summarization/cli-providers/detection.ts +118 -0
  299. package/src/summarization/cli-providers/index.ts +8 -0
  300. package/src/summarization/cost.test.ts +139 -0
  301. package/src/summarization/cost.ts +102 -0
  302. package/src/summarization/error-handler.test.ts +127 -0
  303. package/src/summarization/error-handler.ts +111 -0
  304. package/src/summarization/index.ts +102 -0
  305. package/src/summarization/pipeline.test.ts +498 -0
  306. package/src/summarization/pipeline.ts +231 -0
  307. package/src/summarization/prompts.test.ts +269 -0
  308. package/src/summarization/prompts.ts +133 -0
  309. package/src/summarization/provider-factory.test.ts +396 -0
  310. package/src/summarization/provider-factory.ts +178 -0
  311. package/src/summarization/types.ts +184 -0
  312. package/src/summarize/budget-bugs.test.ts +620 -0
  313. package/src/summarize/formatters.ts +419 -0
  314. package/src/summarize/index.ts +20 -0
  315. package/src/summarize/summarizer.test.ts +275 -0
  316. package/src/summarize/summarizer.ts +597 -0
  317. package/src/summarize/verify-bugs.test.ts +238 -0
  318. package/src/types/huggingface-transformers.d.ts +66 -0
  319. package/src/utils/index.ts +1 -0
  320. package/src/utils/tokens.test.ts +142 -0
  321. package/src/utils/tokens.ts +186 -0
  322. package/tests/fixtures/cli/.mdcontext/active-provider.json +7 -0
  323. package/tests/fixtures/cli/.mdcontext/config.json +8 -0
  324. package/tests/fixtures/cli/.mdcontext/embeddings/openai_text-embedding-3-small_512/vectors.bin +0 -0
  325. package/tests/fixtures/cli/.mdcontext/embeddings/openai_text-embedding-3-small_512/vectors.meta.bin +0 -0
  326. package/tests/fixtures/cli/.mdcontext/indexes/documents.json +33 -0
  327. package/tests/fixtures/cli/.mdcontext/indexes/links.json +12 -0
  328. package/tests/fixtures/cli/.mdcontext/indexes/sections.json +247 -0
  329. package/tests/fixtures/cli/README.md +9 -0
  330. package/tests/fixtures/cli/api-reference.md +11 -0
  331. package/tests/fixtures/cli/getting-started.md +11 -0
  332. package/tests/integration/embed-index.test.ts +712 -0
  333. package/tests/integration/search-context.test.ts +469 -0
  334. package/tests/integration/search-semantic.test.ts +522 -0
  335. package/tsconfig.json +26 -0
  336. package/vitest.config.ts +16 -0
  337. package/vitest.setup.ts +12 -0
package/dist/index.js ADDED
@@ -0,0 +1,79 @@
1
+ import {
2
+ watchDirectory
3
+ } from "./chunk-SYE5XLF3.js";
4
+ import {
5
+ INDEX_DIR,
6
+ INDEX_VERSION,
7
+ buildBM25Index,
8
+ buildIndex,
9
+ computeHash,
10
+ countTokens,
11
+ countTokensApprox,
12
+ countWords,
13
+ createEmptyDocumentIndex,
14
+ createEmptyLinkIndex,
15
+ createEmptySectionIndex,
16
+ createStorage,
17
+ freeEncoder,
18
+ getBrokenLinks,
19
+ getIncomingLinks,
20
+ getIndexPaths,
21
+ getOutgoingLinks,
22
+ indexExists,
23
+ initializeIndex,
24
+ loadConfig,
25
+ loadDocumentIndex,
26
+ loadLinkIndex,
27
+ loadSectionIndex,
28
+ parse,
29
+ parseFile,
30
+ saveConfig,
31
+ saveDocumentIndex,
32
+ saveLinkIndex,
33
+ saveSectionIndex
34
+ } from "./chunk-MUJELQQ6.js";
35
+
36
+ // src/core/types.ts
37
+ var ParseError = (message, line, column) => ({
38
+ _tag: "ParseError",
39
+ message,
40
+ line,
41
+ column
42
+ });
43
+
44
+ // src/index.ts
45
+ var defineConfig = (config) => config;
46
+ export {
47
+ INDEX_DIR,
48
+ INDEX_VERSION,
49
+ ParseError,
50
+ buildBM25Index,
51
+ buildIndex,
52
+ computeHash,
53
+ countTokens,
54
+ countTokensApprox,
55
+ countWords,
56
+ createEmptyDocumentIndex,
57
+ createEmptyLinkIndex,
58
+ createEmptySectionIndex,
59
+ createStorage,
60
+ defineConfig,
61
+ freeEncoder,
62
+ getBrokenLinks,
63
+ getIncomingLinks,
64
+ getIndexPaths,
65
+ getOutgoingLinks,
66
+ indexExists,
67
+ initializeIndex,
68
+ loadConfig,
69
+ loadDocumentIndex,
70
+ loadLinkIndex,
71
+ loadSectionIndex,
72
+ parse,
73
+ parseFile,
74
+ saveConfig,
75
+ saveDocumentIndex,
76
+ saveLinkIndex,
77
+ saveSectionIndex,
78
+ watchDirectory
79
+ };
@@ -0,0 +1 @@
1
+ #!/usr/bin/env node
@@ -0,0 +1,472 @@
1
+ #!/usr/bin/env node
2
+ import {
3
+ formatSummary,
4
+ search,
5
+ semanticSearch,
6
+ summarizeFile
7
+ } from "../chunk-BNXWSZ63.js";
8
+ import {
9
+ buildIndex,
10
+ getIncomingLinks,
11
+ getOutgoingLinks,
12
+ parseFile
13
+ } from "../chunk-MUJELQQ6.js";
14
+ import "../chunk-7TOWB2XB.js";
15
+
16
+ // src/mcp/server.ts
17
+ import { createRequire } from "module";
18
+ import * as path from "path";
19
+ import { Server } from "@modelcontextprotocol/sdk/server/index.js";
20
+ import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
21
+ import {
22
+ CallToolRequestSchema,
23
+ ListToolsRequestSchema
24
+ } from "@modelcontextprotocol/sdk/types.js";
25
+ import { Effect } from "effect";
26
+ var require2 = createRequire(import.meta.url);
27
+ var packageJson = require2("../../package.json");
28
+ var MCP_VERSION = packageJson.version;
29
+ var tools = [
30
+ {
31
+ name: "md_search",
32
+ description: "Search markdown documents by meaning using semantic search. Returns relevant sections based on natural language queries.",
33
+ inputSchema: {
34
+ type: "object",
35
+ properties: {
36
+ query: {
37
+ type: "string",
38
+ description: "Natural language search query"
39
+ },
40
+ limit: {
41
+ type: "number",
42
+ description: "Maximum number of results (default: 5)",
43
+ default: 5
44
+ },
45
+ path_filter: {
46
+ type: "string",
47
+ description: "Glob pattern to filter files (e.g., '*.md', 'docs/**/*.md')"
48
+ },
49
+ threshold: {
50
+ type: "number",
51
+ description: "Minimum similarity threshold 0-1 (default: 0.35)",
52
+ default: 0.35
53
+ }
54
+ },
55
+ required: ["query"]
56
+ }
57
+ },
58
+ {
59
+ name: "md_context",
60
+ description: "Get LLM-ready context from a markdown file. Provides compressed, token-efficient summaries at various detail levels.",
61
+ inputSchema: {
62
+ type: "object",
63
+ properties: {
64
+ path: {
65
+ type: "string",
66
+ description: "Path to the markdown file"
67
+ },
68
+ level: {
69
+ type: "string",
70
+ enum: ["full", "summary", "brief"],
71
+ description: "Compression level (default: summary)",
72
+ default: "summary"
73
+ },
74
+ max_tokens: {
75
+ type: "number",
76
+ description: "Maximum tokens to include in output"
77
+ }
78
+ },
79
+ required: ["path"]
80
+ }
81
+ },
82
+ {
83
+ name: "md_structure",
84
+ description: "Get the structure/outline of a markdown file. Shows heading hierarchy with token counts.",
85
+ inputSchema: {
86
+ type: "object",
87
+ properties: {
88
+ path: {
89
+ type: "string",
90
+ description: "Path to the markdown file"
91
+ }
92
+ },
93
+ required: ["path"]
94
+ }
95
+ },
96
+ {
97
+ name: "md_keyword_search",
98
+ description: "Search markdown documents by keyword search (headings, code blocks, lists, tables).",
99
+ inputSchema: {
100
+ type: "object",
101
+ properties: {
102
+ heading: {
103
+ type: "string",
104
+ description: "Filter by heading pattern (regex)"
105
+ },
106
+ path_filter: {
107
+ type: "string",
108
+ description: "Glob pattern to filter files"
109
+ },
110
+ has_code: {
111
+ type: "boolean",
112
+ description: "Only sections with code blocks"
113
+ },
114
+ has_list: {
115
+ type: "boolean",
116
+ description: "Only sections with lists"
117
+ },
118
+ has_table: {
119
+ type: "boolean",
120
+ description: "Only sections with tables"
121
+ },
122
+ limit: {
123
+ type: "number",
124
+ description: "Maximum results (default: 20)",
125
+ default: 20
126
+ }
127
+ }
128
+ }
129
+ },
130
+ {
131
+ name: "md_index",
132
+ description: "Build or rebuild the index for a directory. Required before using search tools.",
133
+ inputSchema: {
134
+ type: "object",
135
+ properties: {
136
+ path: {
137
+ type: "string",
138
+ description: "Directory to index (default: current directory)",
139
+ default: "."
140
+ },
141
+ force: {
142
+ type: "boolean",
143
+ description: "Force full rebuild (default: false)",
144
+ default: false
145
+ }
146
+ }
147
+ }
148
+ },
149
+ {
150
+ name: "md_links",
151
+ description: "Get outgoing links from a markdown file. Shows what files this document references/links to.",
152
+ inputSchema: {
153
+ type: "object",
154
+ properties: {
155
+ path: {
156
+ type: "string",
157
+ description: "Path to the markdown file"
158
+ }
159
+ },
160
+ required: ["path"]
161
+ }
162
+ },
163
+ {
164
+ name: "md_backlinks",
165
+ description: "Get incoming links to a markdown file. Shows what files reference/link to this document.",
166
+ inputSchema: {
167
+ type: "object",
168
+ properties: {
169
+ path: {
170
+ type: "string",
171
+ description: "Path to the markdown file"
172
+ }
173
+ },
174
+ required: ["path"]
175
+ }
176
+ }
177
+ ];
178
+ var handleMdSearch = async (args, rootPath) => {
179
+ const query = args.query;
180
+ const limit = args.limit ?? 5;
181
+ const pathFilter = args.path_filter;
182
+ const threshold = args.threshold ?? 0.35;
183
+ const result = await Effect.runPromise(
184
+ semanticSearch(rootPath, query, {
185
+ limit,
186
+ threshold,
187
+ pathPattern: pathFilter
188
+ }).pipe(
189
+ Effect.catchAll((e) => Effect.succeed([{ error: e.message }]))
190
+ )
191
+ );
192
+ if (Array.isArray(result) && result.length > 0 && "error" in result[0]) {
193
+ return {
194
+ content: [
195
+ {
196
+ type: "text",
197
+ text: `Error: ${result[0].error}`
198
+ }
199
+ ],
200
+ isError: true
201
+ };
202
+ }
203
+ const formattedResults = result.map((r, i) => {
204
+ const similarity = (r.similarity * 100).toFixed(1);
205
+ return `${i + 1}. **${r.heading}** (${similarity}% match)
206
+ ${r.documentPath}`;
207
+ });
208
+ return {
209
+ content: [
210
+ {
211
+ type: "text",
212
+ text: formattedResults.length > 0 ? `Found ${formattedResults.length} results for "${query}":
213
+
214
+ ${formattedResults.join("\n\n")}` : `No results found for "${query}"`
215
+ }
216
+ ]
217
+ };
218
+ };
219
+ var handleMdContext = async (args, rootPath) => {
220
+ const filePath = args.path;
221
+ const level = args.level ?? "summary";
222
+ const maxTokens = args.max_tokens;
223
+ const resolvedPath = path.isAbsolute(filePath) ? filePath : path.join(rootPath, filePath);
224
+ const result = await Effect.runPromise(
225
+ summarizeFile(resolvedPath, { level, maxTokens }).pipe(
226
+ Effect.catchAll((e) => Effect.succeed({ error: e.message }))
227
+ )
228
+ );
229
+ if ("error" in result) {
230
+ return {
231
+ content: [{ type: "text", text: `Error: ${result.error}` }],
232
+ isError: true
233
+ };
234
+ }
235
+ return {
236
+ content: [{ type: "text", text: formatSummary(result) }]
237
+ };
238
+ };
239
+ var handleMdStructure = async (args, rootPath) => {
240
+ const filePath = args.path;
241
+ const resolvedPath = path.isAbsolute(filePath) ? filePath : path.join(rootPath, filePath);
242
+ const result = await Effect.runPromise(
243
+ parseFile(resolvedPath).pipe(
244
+ Effect.catchAll((e) => Effect.succeed({ error: e.message }))
245
+ )
246
+ );
247
+ if ("error" in result) {
248
+ return {
249
+ content: [{ type: "text", text: `Error: ${result.error}` }],
250
+ isError: true
251
+ };
252
+ }
253
+ const formatSection = (section, depth = 0) => {
254
+ const indent = " ".repeat(depth);
255
+ const marker = "#".repeat(section.level);
256
+ const meta = [];
257
+ if (section.metadata.hasCode) meta.push("code");
258
+ if (section.metadata.hasList) meta.push("list");
259
+ if (section.metadata.hasTable) meta.push("table");
260
+ const metaStr = meta.length > 0 ? ` [${meta.join(", ")}]` : "";
261
+ let output = `${indent}${marker} ${section.heading}${metaStr} (${section.metadata.tokenCount} tokens)
262
+ `;
263
+ for (const child of section.children) {
264
+ output += formatSection(child, depth + 1);
265
+ }
266
+ return output;
267
+ };
268
+ const structure = result.sections.map((s) => formatSection(s)).join("");
269
+ return {
270
+ content: [
271
+ {
272
+ type: "text",
273
+ text: `# ${result.title}
274
+ Path: ${result.path}
275
+ Total tokens: ${result.metadata.tokenCount}
276
+
277
+ ${structure}`
278
+ }
279
+ ]
280
+ };
281
+ };
282
+ var handleMdKeywordSearch = async (args, rootPath) => {
283
+ const heading = args.heading;
284
+ const pathFilter = args.path_filter;
285
+ const hasCode = args.has_code;
286
+ const hasList = args.has_list;
287
+ const hasTable = args.has_table;
288
+ const limit = args.limit ?? 20;
289
+ const result = await Effect.runPromise(
290
+ search(rootPath, {
291
+ heading,
292
+ pathPattern: pathFilter,
293
+ hasCode,
294
+ hasList,
295
+ hasTable,
296
+ limit
297
+ }).pipe(
298
+ Effect.catchAll((e) => Effect.succeed([{ error: e.message }]))
299
+ )
300
+ );
301
+ if (Array.isArray(result) && result.length > 0 && "error" in result[0]) {
302
+ return {
303
+ content: [
304
+ {
305
+ type: "text",
306
+ text: `Error: ${result[0].error}`
307
+ }
308
+ ],
309
+ isError: true
310
+ };
311
+ }
312
+ const formattedResults = result.map((r, i) => {
313
+ const meta = [];
314
+ if (r.section.hasCode) meta.push("code");
315
+ if (r.section.hasList) meta.push("list");
316
+ if (r.section.hasTable) meta.push("table");
317
+ const metaStr = meta.length > 0 ? ` [${meta.join(", ")}]` : "";
318
+ return `${i + 1}. **${r.section.heading}**${metaStr}
319
+ ${r.section.documentPath} (${r.section.tokenCount} tokens)`;
320
+ });
321
+ return {
322
+ content: [
323
+ {
324
+ type: "text",
325
+ text: formattedResults.length > 0 ? `Found ${formattedResults.length} sections:
326
+
327
+ ${formattedResults.join("\n\n")}` : "No sections found matching criteria"
328
+ }
329
+ ]
330
+ };
331
+ };
332
+ var handleMdIndex = async (args, rootPath) => {
333
+ const indexPath = args.path ?? ".";
334
+ const force = args.force ?? false;
335
+ const resolvedPath = path.isAbsolute(indexPath) ? indexPath : path.join(rootPath, indexPath);
336
+ const result = await Effect.runPromise(
337
+ buildIndex(resolvedPath, { force }).pipe(
338
+ Effect.catchAll((e) => Effect.succeed({ error: e.message }))
339
+ )
340
+ );
341
+ if ("error" in result) {
342
+ return {
343
+ content: [{ type: "text", text: `Error: ${result.error}` }],
344
+ isError: true
345
+ };
346
+ }
347
+ return {
348
+ content: [
349
+ {
350
+ type: "text",
351
+ text: `Indexed ${result.documentsIndexed} documents, ${result.sectionsIndexed} sections, ${result.linksIndexed} links in ${result.duration}ms`
352
+ }
353
+ ]
354
+ };
355
+ };
356
+ var handleMdLinks = async (args, rootPath) => {
357
+ const filePath = args.path;
358
+ const resolvedPath = path.isAbsolute(filePath) ? filePath : path.join(rootPath, filePath);
359
+ const result = await Effect.runPromise(
360
+ getOutgoingLinks(rootPath, resolvedPath).pipe(
361
+ Effect.catchAll((e) => Effect.succeed({ error: e.message }))
362
+ )
363
+ );
364
+ if ("error" in result) {
365
+ return {
366
+ content: [{ type: "text", text: `Error: ${result.error}` }],
367
+ isError: true
368
+ };
369
+ }
370
+ const links = result;
371
+ const relativePath = path.relative(rootPath, resolvedPath);
372
+ return {
373
+ content: [
374
+ {
375
+ type: "text",
376
+ text: links.length > 0 ? `Outgoing links from ${relativePath}:
377
+
378
+ ${links.map((l) => ` -> ${l}`).join("\n")}
379
+
380
+ Total: ${links.length} links` : `No outgoing links from ${relativePath}`
381
+ }
382
+ ]
383
+ };
384
+ };
385
+ var handleMdBacklinks = async (args, rootPath) => {
386
+ const filePath = args.path;
387
+ const resolvedPath = path.isAbsolute(filePath) ? filePath : path.join(rootPath, filePath);
388
+ const result = await Effect.runPromise(
389
+ getIncomingLinks(rootPath, resolvedPath).pipe(
390
+ Effect.catchAll((e) => Effect.succeed({ error: e.message }))
391
+ )
392
+ );
393
+ if ("error" in result) {
394
+ return {
395
+ content: [{ type: "text", text: `Error: ${result.error}` }],
396
+ isError: true
397
+ };
398
+ }
399
+ const links = result;
400
+ const relativePath = path.relative(rootPath, resolvedPath);
401
+ return {
402
+ content: [
403
+ {
404
+ type: "text",
405
+ text: links.length > 0 ? `Incoming links to ${relativePath}:
406
+
407
+ ${links.map((l) => ` <- ${l}`).join("\n")}
408
+
409
+ Total: ${links.length} backlinks` : `No incoming links to ${relativePath}`
410
+ }
411
+ ]
412
+ };
413
+ };
414
+ var createServer = (rootPath) => {
415
+ const server = new Server(
416
+ {
417
+ name: "mdcontext-mcp",
418
+ version: MCP_VERSION
419
+ },
420
+ {
421
+ capabilities: {
422
+ tools: {}
423
+ }
424
+ }
425
+ );
426
+ server.setRequestHandler(ListToolsRequestSchema, async () => ({
427
+ tools
428
+ }));
429
+ server.setRequestHandler(CallToolRequestSchema, async (request) => {
430
+ const { name, arguments: args } = request.params;
431
+ switch (name) {
432
+ case "md_search":
433
+ return handleMdSearch(args ?? {}, rootPath);
434
+ case "md_context":
435
+ return handleMdContext(args ?? {}, rootPath);
436
+ case "md_structure":
437
+ return handleMdStructure(args ?? {}, rootPath);
438
+ case "md_keyword_search":
439
+ return handleMdKeywordSearch(args ?? {}, rootPath);
440
+ case "md_index":
441
+ return handleMdIndex(args ?? {}, rootPath);
442
+ case "md_links":
443
+ return handleMdLinks(args ?? {}, rootPath);
444
+ case "md_backlinks":
445
+ return handleMdBacklinks(args ?? {}, rootPath);
446
+ default:
447
+ return {
448
+ content: [{ type: "text", text: `Unknown tool: ${name}` }],
449
+ isError: true
450
+ };
451
+ }
452
+ });
453
+ return server;
454
+ };
455
+ var main = async () => {
456
+ const rootPath = process.cwd();
457
+ const server = createServer(rootPath);
458
+ const transport = new StdioServerTransport();
459
+ await server.connect(transport);
460
+ process.on("SIGINT", async () => {
461
+ await server.close();
462
+ process.exit(0);
463
+ });
464
+ process.on("SIGTERM", async () => {
465
+ await server.close();
466
+ process.exit(0);
467
+ });
468
+ };
469
+ main().catch((error) => {
470
+ console.error("Fatal error:", error);
471
+ process.exit(1);
472
+ });
@@ -0,0 +1,22 @@
1
+ import {
2
+ AISummarizationConfig,
3
+ EmbeddingsConfig,
4
+ IndexConfig,
5
+ MdContextConfig,
6
+ OutputConfig,
7
+ PathsConfig,
8
+ SearchConfig,
9
+ SummarizationConfig,
10
+ defaultConfig
11
+ } from "./chunk-7TOWB2XB.js";
12
+ export {
13
+ AISummarizationConfig,
14
+ EmbeddingsConfig,
15
+ IndexConfig,
16
+ MdContextConfig,
17
+ OutputConfig,
18
+ PathsConfig,
19
+ SearchConfig,
20
+ SummarizationConfig,
21
+ defaultConfig
22
+ };
@@ -0,0 +1,20 @@
1
+ import {
2
+ defaultConfig,
3
+ EmbeddingsConfig,
4
+ IndexConfig,
5
+ MdContextConfig,
6
+ OutputConfig,
7
+ PathsConfig,
8
+ SearchConfig,
9
+ SummarizationConfig,
10
+ } from "./chunk-LBSDNLEM.js";
11
+ export {
12
+ EmbeddingsConfig,
13
+ IndexConfig,
14
+ MdContextConfig,
15
+ OutputConfig,
16
+ PathsConfig,
17
+ SearchConfig,
18
+ SummarizationConfig,
19
+ defaultConfig,
20
+ };
@@ -0,0 +1,20 @@
1
+ import {
2
+ defaultConfig,
3
+ EmbeddingsConfig,
4
+ IndexConfig,
5
+ MdContextConfig,
6
+ OutputConfig,
7
+ PathsConfig,
8
+ SearchConfig,
9
+ SummarizationConfig,
10
+ } from "./chunk-SJCDV2ST.js";
11
+ export {
12
+ EmbeddingsConfig,
13
+ IndexConfig,
14
+ MdContextConfig,
15
+ OutputConfig,
16
+ PathsConfig,
17
+ SearchConfig,
18
+ SummarizationConfig,
19
+ defaultConfig,
20
+ };