sdl-mcp 0.6.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 (496) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +132 -0
  3. package/config/benchmark.ci.config.json +86 -0
  4. package/config/benchmark.ci.windows.config.json +86 -0
  5. package/config/benchmark.config.example.json +86 -0
  6. package/config/benchmark.config.json +86 -0
  7. package/config/sdlmcp.config.example.json +139 -0
  8. package/config/sdlmcp.config.json +48 -0
  9. package/config/sdlmcp.config.schema.json +381 -0
  10. package/dist/agent/evidence.d.ts +18 -0
  11. package/dist/agent/evidence.d.ts.map +1 -0
  12. package/dist/agent/evidence.js +107 -0
  13. package/dist/agent/evidence.js.map +1 -0
  14. package/dist/agent/executor.d.ts +28 -0
  15. package/dist/agent/executor.d.ts.map +1 -0
  16. package/dist/agent/executor.js +261 -0
  17. package/dist/agent/executor.js.map +1 -0
  18. package/dist/agent/index.d.ts +6 -0
  19. package/dist/agent/index.d.ts.map +1 -0
  20. package/dist/agent/index.js +6 -0
  21. package/dist/agent/index.js.map +1 -0
  22. package/dist/agent/orchestrator.d.ts +14 -0
  23. package/dist/agent/orchestrator.d.ts.map +1 -0
  24. package/dist/agent/orchestrator.js +108 -0
  25. package/dist/agent/orchestrator.js.map +1 -0
  26. package/dist/agent/planner.d.ts +21 -0
  27. package/dist/agent/planner.d.ts.map +1 -0
  28. package/dist/agent/planner.js +153 -0
  29. package/dist/agent/planner.js.map +1 -0
  30. package/dist/agent/types.d.ts +86 -0
  31. package/dist/agent/types.d.ts.map +1 -0
  32. package/dist/agent/types.js +2 -0
  33. package/dist/agent/types.js.map +1 -0
  34. package/dist/benchmark/index.d.ts +4 -0
  35. package/dist/benchmark/index.d.ts.map +1 -0
  36. package/dist/benchmark/index.js +4 -0
  37. package/dist/benchmark/index.js.map +1 -0
  38. package/dist/benchmark/regression.d.ts +40 -0
  39. package/dist/benchmark/regression.d.ts.map +1 -0
  40. package/dist/benchmark/regression.js +199 -0
  41. package/dist/benchmark/regression.js.map +1 -0
  42. package/dist/benchmark/smoothing.d.ts +40 -0
  43. package/dist/benchmark/smoothing.d.ts.map +1 -0
  44. package/dist/benchmark/smoothing.js +121 -0
  45. package/dist/benchmark/smoothing.js.map +1 -0
  46. package/dist/benchmark/threshold.d.ts +64 -0
  47. package/dist/benchmark/threshold.d.ts.map +1 -0
  48. package/dist/benchmark/threshold.js +173 -0
  49. package/dist/benchmark/threshold.js.map +1 -0
  50. package/dist/cli/argParsing.d.ts +34 -0
  51. package/dist/cli/argParsing.d.ts.map +1 -0
  52. package/dist/cli/argParsing.js +329 -0
  53. package/dist/cli/argParsing.js.map +1 -0
  54. package/dist/cli/commands/benchmark.d.ts +16 -0
  55. package/dist/cli/commands/benchmark.d.ts.map +1 -0
  56. package/dist/cli/commands/benchmark.js +412 -0
  57. package/dist/cli/commands/benchmark.js.map +1 -0
  58. package/dist/cli/commands/doctor.d.ts +3 -0
  59. package/dist/cli/commands/doctor.d.ts.map +1 -0
  60. package/dist/cli/commands/doctor.js +218 -0
  61. package/dist/cli/commands/doctor.js.map +1 -0
  62. package/dist/cli/commands/export.d.ts +12 -0
  63. package/dist/cli/commands/export.d.ts.map +1 -0
  64. package/dist/cli/commands/export.js +70 -0
  65. package/dist/cli/commands/export.js.map +1 -0
  66. package/dist/cli/commands/import.d.ts +10 -0
  67. package/dist/cli/commands/import.d.ts.map +1 -0
  68. package/dist/cli/commands/import.js +40 -0
  69. package/dist/cli/commands/import.js.map +1 -0
  70. package/dist/cli/commands/index.d.ts +3 -0
  71. package/dist/cli/commands/index.d.ts.map +1 -0
  72. package/dist/cli/commands/index.js +89 -0
  73. package/dist/cli/commands/index.js.map +1 -0
  74. package/dist/cli/commands/init.d.ts +3 -0
  75. package/dist/cli/commands/init.d.ts.map +1 -0
  76. package/dist/cli/commands/init.js +221 -0
  77. package/dist/cli/commands/init.js.map +1 -0
  78. package/dist/cli/commands/pull.d.ts +11 -0
  79. package/dist/cli/commands/pull.d.ts.map +1 -0
  80. package/dist/cli/commands/pull.js +47 -0
  81. package/dist/cli/commands/pull.js.map +1 -0
  82. package/dist/cli/commands/serve.d.ts +3 -0
  83. package/dist/cli/commands/serve.d.ts.map +1 -0
  84. package/dist/cli/commands/serve.js +72 -0
  85. package/dist/cli/commands/serve.js.map +1 -0
  86. package/dist/cli/commands/version.d.ts +3 -0
  87. package/dist/cli/commands/version.d.ts.map +1 -0
  88. package/dist/cli/commands/version.js +24 -0
  89. package/dist/cli/commands/version.js.map +1 -0
  90. package/dist/cli/index.d.ts +3 -0
  91. package/dist/cli/index.d.ts.map +1 -0
  92. package/dist/cli/index.js +213 -0
  93. package/dist/cli/index.js.map +1 -0
  94. package/dist/cli/logging.d.ts +10 -0
  95. package/dist/cli/logging.d.ts.map +1 -0
  96. package/dist/cli/logging.js +48 -0
  97. package/dist/cli/logging.js.map +1 -0
  98. package/dist/cli/transport/http.d.ts +3 -0
  99. package/dist/cli/transport/http.d.ts.map +1 -0
  100. package/dist/cli/transport/http.js +106 -0
  101. package/dist/cli/transport/http.js.map +1 -0
  102. package/dist/cli/transport/stdio.d.ts +3 -0
  103. package/dist/cli/transport/stdio.d.ts.map +1 -0
  104. package/dist/cli/transport/stdio.js +6 -0
  105. package/dist/cli/transport/stdio.js.map +1 -0
  106. package/dist/cli/types.d.ts +41 -0
  107. package/dist/cli/types.d.ts.map +1 -0
  108. package/dist/cli/types.js +2 -0
  109. package/dist/cli/types.js.map +1 -0
  110. package/dist/code/gate.d.ts +11 -0
  111. package/dist/code/gate.d.ts.map +1 -0
  112. package/dist/code/gate.js +134 -0
  113. package/dist/code/gate.js.map +1 -0
  114. package/dist/code/hotpath.d.ts +17 -0
  115. package/dist/code/hotpath.d.ts.map +1 -0
  116. package/dist/code/hotpath.js +200 -0
  117. package/dist/code/hotpath.js.map +1 -0
  118. package/dist/code/redact.d.ts +19 -0
  119. package/dist/code/redact.d.ts.map +1 -0
  120. package/dist/code/redact.js +92 -0
  121. package/dist/code/redact.js.map +1 -0
  122. package/dist/code/skeleton.d.ts +32 -0
  123. package/dist/code/skeleton.d.ts.map +1 -0
  124. package/dist/code/skeleton.js +610 -0
  125. package/dist/code/skeleton.js.map +1 -0
  126. package/dist/code/windows.d.ts +18 -0
  127. package/dist/code/windows.d.ts.map +1 -0
  128. package/dist/code/windows.js +236 -0
  129. package/dist/code/windows.js.map +1 -0
  130. package/dist/config/constants.d.ts +340 -0
  131. package/dist/config/constants.d.ts.map +1 -0
  132. package/dist/config/constants.js +379 -0
  133. package/dist/config/constants.js.map +1 -0
  134. package/dist/config/loadConfig.d.ts +3 -0
  135. package/dist/config/loadConfig.d.ts.map +1 -0
  136. package/dist/config/loadConfig.js +71 -0
  137. package/dist/config/loadConfig.js.map +1 -0
  138. package/dist/config/types.d.ts +509 -0
  139. package/dist/config/types.d.ts.map +1 -0
  140. package/dist/config/types.js +139 -0
  141. package/dist/config/types.js.map +1 -0
  142. package/dist/db/db.d.ts +4 -0
  143. package/dist/db/db.d.ts.map +1 -0
  144. package/dist/db/db.js +47 -0
  145. package/dist/db/db.js.map +1 -0
  146. package/dist/db/migrations.d.ts +15 -0
  147. package/dist/db/migrations.d.ts.map +1 -0
  148. package/dist/db/migrations.js +81 -0
  149. package/dist/db/migrations.js.map +1 -0
  150. package/dist/db/queries.d.ts +440 -0
  151. package/dist/db/queries.d.ts.map +1 -0
  152. package/dist/db/queries.js +1054 -0
  153. package/dist/db/queries.js.map +1 -0
  154. package/dist/db/schema.d.ts +132 -0
  155. package/dist/db/schema.d.ts.map +1 -0
  156. package/dist/db/schema.js +2 -0
  157. package/dist/db/schema.js.map +1 -0
  158. package/dist/delta/blastRadius.d.ts +24 -0
  159. package/dist/delta/blastRadius.d.ts.map +1 -0
  160. package/dist/delta/blastRadius.js +239 -0
  161. package/dist/delta/blastRadius.js.map +1 -0
  162. package/dist/delta/diff.d.ts +16 -0
  163. package/dist/delta/diff.d.ts.map +1 -0
  164. package/dist/delta/diff.js +236 -0
  165. package/dist/delta/diff.js.map +1 -0
  166. package/dist/delta/versioning.d.ts +11 -0
  167. package/dist/delta/versioning.d.ts.map +1 -0
  168. package/dist/delta/versioning.js +68 -0
  169. package/dist/delta/versioning.js.map +1 -0
  170. package/dist/graph/buildGraph.d.ts +12 -0
  171. package/dist/graph/buildGraph.d.ts.map +1 -0
  172. package/dist/graph/buildGraph.js +81 -0
  173. package/dist/graph/buildGraph.js.map +1 -0
  174. package/dist/graph/cache.d.ts +111 -0
  175. package/dist/graph/cache.d.ts.map +1 -0
  176. package/dist/graph/cache.js +237 -0
  177. package/dist/graph/cache.js.map +1 -0
  178. package/dist/graph/metrics.d.ts +12 -0
  179. package/dist/graph/metrics.d.ts.map +1 -0
  180. package/dist/graph/metrics.js +253 -0
  181. package/dist/graph/metrics.js.map +1 -0
  182. package/dist/graph/minHeap.d.ts +91 -0
  183. package/dist/graph/minHeap.d.ts.map +1 -0
  184. package/dist/graph/minHeap.js +159 -0
  185. package/dist/graph/minHeap.js.map +1 -0
  186. package/dist/graph/overview.d.ts +22 -0
  187. package/dist/graph/overview.d.ts.map +1 -0
  188. package/dist/graph/overview.js +379 -0
  189. package/dist/graph/overview.js.map +1 -0
  190. package/dist/graph/score.d.ts +27 -0
  191. package/dist/graph/score.d.ts.map +1 -0
  192. package/dist/graph/score.js +214 -0
  193. package/dist/graph/score.js.map +1 -0
  194. package/dist/graph/slice.d.ts +51 -0
  195. package/dist/graph/slice.d.ts.map +1 -0
  196. package/dist/graph/slice.js +1047 -0
  197. package/dist/graph/slice.js.map +1 -0
  198. package/dist/graph/sliceCache.d.ts +33 -0
  199. package/dist/graph/sliceCache.d.ts.map +1 -0
  200. package/dist/graph/sliceCache.js +140 -0
  201. package/dist/graph/sliceCache.js.map +1 -0
  202. package/dist/indexer/adapter/BaseAdapter.d.ts +29 -0
  203. package/dist/indexer/adapter/BaseAdapter.d.ts.map +1 -0
  204. package/dist/indexer/adapter/BaseAdapter.js +97 -0
  205. package/dist/indexer/adapter/BaseAdapter.js.map +1 -0
  206. package/dist/indexer/adapter/LanguageAdapter.d.ts +20 -0
  207. package/dist/indexer/adapter/LanguageAdapter.d.ts.map +1 -0
  208. package/dist/indexer/adapter/LanguageAdapter.js +2 -0
  209. package/dist/indexer/adapter/LanguageAdapter.js.map +1 -0
  210. package/dist/indexer/adapter/adapters.d.ts +57 -0
  211. package/dist/indexer/adapter/adapters.d.ts.map +1 -0
  212. package/dist/indexer/adapter/adapters.js +129 -0
  213. package/dist/indexer/adapter/adapters.js.map +1 -0
  214. package/dist/indexer/adapter/c.d.ts +18 -0
  215. package/dist/indexer/adapter/c.d.ts.map +1 -0
  216. package/dist/indexer/adapter/c.js +443 -0
  217. package/dist/indexer/adapter/c.js.map +1 -0
  218. package/dist/indexer/adapter/cpp.d.ts +18 -0
  219. package/dist/indexer/adapter/cpp.d.ts.map +1 -0
  220. package/dist/indexer/adapter/cpp.js +493 -0
  221. package/dist/indexer/adapter/cpp.js.map +1 -0
  222. package/dist/indexer/adapter/csharp.d.ts +48 -0
  223. package/dist/indexer/adapter/csharp.d.ts.map +1 -0
  224. package/dist/indexer/adapter/csharp.js +638 -0
  225. package/dist/indexer/adapter/csharp.js.map +1 -0
  226. package/dist/indexer/adapter/go.d.ts +14 -0
  227. package/dist/indexer/adapter/go.d.ts.map +1 -0
  228. package/dist/indexer/adapter/go.js +400 -0
  229. package/dist/indexer/adapter/go.js.map +1 -0
  230. package/dist/indexer/adapter/index.d.ts +14 -0
  231. package/dist/indexer/adapter/index.d.ts.map +1 -0
  232. package/dist/indexer/adapter/index.js +13 -0
  233. package/dist/indexer/adapter/index.js.map +1 -0
  234. package/dist/indexer/adapter/java.d.ts +14 -0
  235. package/dist/indexer/adapter/java.d.ts.map +1 -0
  236. package/dist/indexer/adapter/java.js +391 -0
  237. package/dist/indexer/adapter/java.js.map +1 -0
  238. package/dist/indexer/adapter/kotlin.d.ts +18 -0
  239. package/dist/indexer/adapter/kotlin.d.ts.map +1 -0
  240. package/dist/indexer/adapter/kotlin.js +599 -0
  241. package/dist/indexer/adapter/kotlin.js.map +1 -0
  242. package/dist/indexer/adapter/php.d.ts +18 -0
  243. package/dist/indexer/adapter/php.d.ts.map +1 -0
  244. package/dist/indexer/adapter/php.js +574 -0
  245. package/dist/indexer/adapter/php.js.map +1 -0
  246. package/dist/indexer/adapter/plugin/index.d.ts +3 -0
  247. package/dist/indexer/adapter/plugin/index.d.ts.map +1 -0
  248. package/dist/indexer/adapter/plugin/index.js +3 -0
  249. package/dist/indexer/adapter/plugin/index.js.map +1 -0
  250. package/dist/indexer/adapter/plugin/loader.d.ts +13 -0
  251. package/dist/indexer/adapter/plugin/loader.d.ts.map +1 -0
  252. package/dist/indexer/adapter/plugin/loader.js +154 -0
  253. package/dist/indexer/adapter/plugin/loader.js.map +1 -0
  254. package/dist/indexer/adapter/plugin/types.d.ts +76 -0
  255. package/dist/indexer/adapter/plugin/types.d.ts.map +1 -0
  256. package/dist/indexer/adapter/plugin/types.js +47 -0
  257. package/dist/indexer/adapter/plugin/types.js.map +1 -0
  258. package/dist/indexer/adapter/python.d.ts +14 -0
  259. package/dist/indexer/adapter/python.d.ts.map +1 -0
  260. package/dist/indexer/adapter/python.js +511 -0
  261. package/dist/indexer/adapter/python.js.map +1 -0
  262. package/dist/indexer/adapter/registry.d.ts +17 -0
  263. package/dist/indexer/adapter/registry.d.ts.map +1 -0
  264. package/dist/indexer/adapter/registry.js +134 -0
  265. package/dist/indexer/adapter/registry.js.map +1 -0
  266. package/dist/indexer/adapter/rust.d.ts +18 -0
  267. package/dist/indexer/adapter/rust.d.ts.map +1 -0
  268. package/dist/indexer/adapter/rust.js +709 -0
  269. package/dist/indexer/adapter/rust.js.map +1 -0
  270. package/dist/indexer/adapter/shell.d.ts +18 -0
  271. package/dist/indexer/adapter/shell.d.ts.map +1 -0
  272. package/dist/indexer/adapter/shell.js +345 -0
  273. package/dist/indexer/adapter/shell.js.map +1 -0
  274. package/dist/indexer/adapter/typescript.d.ts +14 -0
  275. package/dist/indexer/adapter/typescript.d.ts.map +1 -0
  276. package/dist/indexer/adapter/typescript.js +31 -0
  277. package/dist/indexer/adapter/typescript.js.map +1 -0
  278. package/dist/indexer/configEdges.d.ts +30 -0
  279. package/dist/indexer/configEdges.d.ts.map +1 -0
  280. package/dist/indexer/configEdges.js +260 -0
  281. package/dist/indexer/configEdges.js.map +1 -0
  282. package/dist/indexer/fileScanner.d.ts +16 -0
  283. package/dist/indexer/fileScanner.d.ts.map +1 -0
  284. package/dist/indexer/fileScanner.js +90 -0
  285. package/dist/indexer/fileScanner.js.map +1 -0
  286. package/dist/indexer/fingerprints.d.ts +23 -0
  287. package/dist/indexer/fingerprints.d.ts.map +1 -0
  288. package/dist/indexer/fingerprints.js +97 -0
  289. package/dist/indexer/fingerprints.js.map +1 -0
  290. package/dist/indexer/indexer.d.ts +58 -0
  291. package/dist/indexer/indexer.d.ts.map +1 -0
  292. package/dist/indexer/indexer.js +1229 -0
  293. package/dist/indexer/indexer.js.map +1 -0
  294. package/dist/indexer/summaries.d.ts +5 -0
  295. package/dist/indexer/summaries.d.ts.map +1 -0
  296. package/dist/indexer/summaries.js +331 -0
  297. package/dist/indexer/summaries.js.map +1 -0
  298. package/dist/indexer/treesitter/extractCalls.d.ts +40 -0
  299. package/dist/indexer/treesitter/extractCalls.d.ts.map +1 -0
  300. package/dist/indexer/treesitter/extractCalls.js +561 -0
  301. package/dist/indexer/treesitter/extractCalls.js.map +1 -0
  302. package/dist/indexer/treesitter/extractImports.d.ts +12 -0
  303. package/dist/indexer/treesitter/extractImports.d.ts.map +1 -0
  304. package/dist/indexer/treesitter/extractImports.js +184 -0
  305. package/dist/indexer/treesitter/extractImports.js.map +1 -0
  306. package/dist/indexer/treesitter/extractSymbols.d.ts +24 -0
  307. package/dist/indexer/treesitter/extractSymbols.d.ts.map +1 -0
  308. package/dist/indexer/treesitter/extractSymbols.js +389 -0
  309. package/dist/indexer/treesitter/extractSymbols.js.map +1 -0
  310. package/dist/indexer/treesitter/grammarLoader.d.ts +6 -0
  311. package/dist/indexer/treesitter/grammarLoader.d.ts.map +1 -0
  312. package/dist/indexer/treesitter/grammarLoader.js +125 -0
  313. package/dist/indexer/treesitter/grammarLoader.js.map +1 -0
  314. package/dist/indexer/treesitter/symbolUtils.d.ts +4 -0
  315. package/dist/indexer/treesitter/symbolUtils.d.ts.map +1 -0
  316. package/dist/indexer/treesitter/symbolUtils.js +26 -0
  317. package/dist/indexer/treesitter/symbolUtils.js.map +1 -0
  318. package/dist/indexer/treesitter/tsTreesitter.d.ts +9 -0
  319. package/dist/indexer/treesitter/tsTreesitter.d.ts.map +1 -0
  320. package/dist/indexer/treesitter/tsTreesitter.js +54 -0
  321. package/dist/indexer/treesitter/tsTreesitter.js.map +1 -0
  322. package/dist/indexer/treesitter/types.d.ts +19 -0
  323. package/dist/indexer/treesitter/types.d.ts.map +1 -0
  324. package/dist/indexer/treesitter/types.js +7 -0
  325. package/dist/indexer/treesitter/types.js.map +1 -0
  326. package/dist/indexer/ts/tsParser.d.ts +20 -0
  327. package/dist/indexer/ts/tsParser.d.ts.map +1 -0
  328. package/dist/indexer/ts/tsParser.js +114 -0
  329. package/dist/indexer/ts/tsParser.js.map +1 -0
  330. package/dist/indexer/worker.d.ts +2 -0
  331. package/dist/indexer/worker.d.ts.map +1 -0
  332. package/dist/indexer/worker.js +59 -0
  333. package/dist/indexer/worker.js.map +1 -0
  334. package/dist/indexer/workerPool.d.ts +20 -0
  335. package/dist/indexer/workerPool.d.ts.map +1 -0
  336. package/dist/indexer/workerPool.js +93 -0
  337. package/dist/indexer/workerPool.js.map +1 -0
  338. package/dist/main.d.ts +2 -0
  339. package/dist/main.d.ts.map +1 -0
  340. package/dist/main.js +111 -0
  341. package/dist/main.js.map +1 -0
  342. package/dist/mcp/errors.d.ts +40 -0
  343. package/dist/mcp/errors.d.ts.map +1 -0
  344. package/dist/mcp/errors.js +66 -0
  345. package/dist/mcp/errors.js.map +1 -0
  346. package/dist/mcp/resources.d.ts +24 -0
  347. package/dist/mcp/resources.d.ts.map +1 -0
  348. package/dist/mcp/resources.js +140 -0
  349. package/dist/mcp/resources.js.map +1 -0
  350. package/dist/mcp/telemetry.d.ts +67 -0
  351. package/dist/mcp/telemetry.d.ts.map +1 -0
  352. package/dist/mcp/telemetry.js +128 -0
  353. package/dist/mcp/telemetry.js.map +1 -0
  354. package/dist/mcp/tools/agent.d.ts +241 -0
  355. package/dist/mcp/tools/agent.d.ts.map +1 -0
  356. package/dist/mcp/tools/agent.js +113 -0
  357. package/dist/mcp/tools/agent.js.map +1 -0
  358. package/dist/mcp/tools/code.d.ts +32 -0
  359. package/dist/mcp/tools/code.d.ts.map +1 -0
  360. package/dist/mcp/tools/code.js +388 -0
  361. package/dist/mcp/tools/code.js.map +1 -0
  362. package/dist/mcp/tools/delta.d.ts +12 -0
  363. package/dist/mcp/tools/delta.d.ts.map +1 -0
  364. package/dist/mcp/tools/delta.js +82 -0
  365. package/dist/mcp/tools/delta.js.map +1 -0
  366. package/dist/mcp/tools/index.d.ts +3 -0
  367. package/dist/mcp/tools/index.d.ts.map +1 -0
  368. package/dist/mcp/tools/index.js +35 -0
  369. package/dist/mcp/tools/index.js.map +1 -0
  370. package/dist/mcp/tools/policy.d.ts +20 -0
  371. package/dist/mcp/tools/policy.d.ts.map +1 -0
  372. package/dist/mcp/tools/policy.js +67 -0
  373. package/dist/mcp/tools/policy.js.map +1 -0
  374. package/dist/mcp/tools/prRisk.d.ts +34 -0
  375. package/dist/mcp/tools/prRisk.d.ts.map +1 -0
  376. package/dist/mcp/tools/prRisk.js +304 -0
  377. package/dist/mcp/tools/prRisk.js.map +1 -0
  378. package/dist/mcp/tools/repo.d.ts +46 -0
  379. package/dist/mcp/tools/repo.d.ts.map +1 -0
  380. package/dist/mcp/tools/repo.js +224 -0
  381. package/dist/mcp/tools/repo.js.map +1 -0
  382. package/dist/mcp/tools/slice.d.ts +44 -0
  383. package/dist/mcp/tools/slice.d.ts.map +1 -0
  384. package/dist/mcp/tools/slice.js +688 -0
  385. package/dist/mcp/tools/slice.js.map +1 -0
  386. package/dist/mcp/tools/symbol.d.ts +21 -0
  387. package/dist/mcp/tools/symbol.d.ts.map +1 -0
  388. package/dist/mcp/tools/symbol.js +416 -0
  389. package/dist/mcp/tools/symbol.js.map +1 -0
  390. package/dist/mcp/tools.d.ts +6003 -0
  391. package/dist/mcp/tools.d.ts.map +1 -0
  392. package/dist/mcp/tools.js +932 -0
  393. package/dist/mcp/tools.js.map +1 -0
  394. package/dist/mcp/types.d.ts +500 -0
  395. package/dist/mcp/types.d.ts.map +1 -0
  396. package/dist/mcp/types.js +2 -0
  397. package/dist/mcp/types.js.map +1 -0
  398. package/dist/policy/engine.d.ts +21 -0
  399. package/dist/policy/engine.d.ts.map +1 -0
  400. package/dist/policy/engine.js +477 -0
  401. package/dist/policy/engine.js.map +1 -0
  402. package/dist/policy/types.d.ts +73 -0
  403. package/dist/policy/types.d.ts.map +1 -0
  404. package/dist/policy/types.js +12 -0
  405. package/dist/policy/types.js.map +1 -0
  406. package/dist/server.d.ts +17 -0
  407. package/dist/server.d.ts.map +1 -0
  408. package/dist/server.js +136 -0
  409. package/dist/server.js.map +1 -0
  410. package/dist/sync/pull.d.ts +4 -0
  411. package/dist/sync/pull.d.ts.map +1 -0
  412. package/dist/sync/pull.js +113 -0
  413. package/dist/sync/pull.js.map +1 -0
  414. package/dist/sync/sync.d.ts +6 -0
  415. package/dist/sync/sync.d.ts.map +1 -0
  416. package/dist/sync/sync.js +244 -0
  417. package/dist/sync/sync.js.map +1 -0
  418. package/dist/sync/types.d.ts +136 -0
  419. package/dist/sync/types.d.ts.map +1 -0
  420. package/dist/sync/types.js +2 -0
  421. package/dist/sync/types.js.map +1 -0
  422. package/dist/ts/diagnostics.d.ts +61 -0
  423. package/dist/ts/diagnostics.d.ts.map +1 -0
  424. package/dist/ts/diagnostics.js +259 -0
  425. package/dist/ts/diagnostics.js.map +1 -0
  426. package/dist/ts/mapping.d.ts +27 -0
  427. package/dist/ts/mapping.d.ts.map +1 -0
  428. package/dist/ts/mapping.js +68 -0
  429. package/dist/ts/mapping.js.map +1 -0
  430. package/dist/util/asyncFs.d.ts +103 -0
  431. package/dist/util/asyncFs.d.ts.map +1 -0
  432. package/dist/util/asyncFs.js +133 -0
  433. package/dist/util/asyncFs.js.map +1 -0
  434. package/dist/util/concurrency.d.ts +77 -0
  435. package/dist/util/concurrency.d.ts.map +1 -0
  436. package/dist/util/concurrency.js +146 -0
  437. package/dist/util/concurrency.js.map +1 -0
  438. package/dist/util/depLabels.d.ts +3 -0
  439. package/dist/util/depLabels.d.ts.map +1 -0
  440. package/dist/util/depLabels.js +19 -0
  441. package/dist/util/depLabels.js.map +1 -0
  442. package/dist/util/findPackageRoot.d.ts +7 -0
  443. package/dist/util/findPackageRoot.d.ts.map +1 -0
  444. package/dist/util/findPackageRoot.js +21 -0
  445. package/dist/util/findPackageRoot.js.map +1 -0
  446. package/dist/util/hashing.d.ts +9 -0
  447. package/dist/util/hashing.d.ts.map +1 -0
  448. package/dist/util/hashing.js +37 -0
  449. package/dist/util/hashing.js.map +1 -0
  450. package/dist/util/logger.d.ts +14 -0
  451. package/dist/util/logger.d.ts.map +1 -0
  452. package/dist/util/logger.js +51 -0
  453. package/dist/util/logger.js.map +1 -0
  454. package/dist/util/paths.d.ts +6 -0
  455. package/dist/util/paths.d.ts.map +1 -0
  456. package/dist/util/paths.js +79 -0
  457. package/dist/util/paths.js.map +1 -0
  458. package/dist/util/time.d.ts +4 -0
  459. package/dist/util/time.d.ts.map +1 -0
  460. package/dist/util/time.js +20 -0
  461. package/dist/util/time.js.map +1 -0
  462. package/dist/util/tokenize.d.ts +5 -0
  463. package/dist/util/tokenize.d.ts.map +1 -0
  464. package/dist/util/tokenize.js +30 -0
  465. package/dist/util/tokenize.js.map +1 -0
  466. package/dist/util/truncation.d.ts +38 -0
  467. package/dist/util/truncation.d.ts.map +1 -0
  468. package/dist/util/truncation.js +259 -0
  469. package/dist/util/truncation.js.map +1 -0
  470. package/migrations/.gitkeep +1 -0
  471. package/migrations/0001_init.sql +61 -0
  472. package/migrations/0002_edges_indexes.sql +2 -0
  473. package/migrations/0003_versions.sql +22 -0
  474. package/migrations/0004_metrics_audit.sql +23 -0
  475. package/migrations/0005_slice_handles.sql +15 -0
  476. package/migrations/0006_content_addressed.sql +29 -0
  477. package/migrations/0007_add_language_to_symbols.sql +28 -0
  478. package/migrations/0008_performance_indexes.sql +21 -0
  479. package/migrations/0009_fix_edge_fks.sql +37 -0
  480. package/migrations/0010_standardize_fks.sql +35 -0
  481. package/migrations/0011_add_directory_column.sql +20 -0
  482. package/migrations/0012_symbol_references.sql +16 -0
  483. package/migrations/0013_sync_artifacts.sql +17 -0
  484. package/package.json +107 -0
  485. package/templates/CLAUDE.md.template +179 -0
  486. package/templates/README.md +228 -0
  487. package/templates/claude-code.json +54 -0
  488. package/templates/codex.json +55 -0
  489. package/templates/gemini.json +66 -0
  490. package/templates/opencode.json +90 -0
  491. package/templates/plugin-template/LICENSE +21 -0
  492. package/templates/plugin-template/README.md +309 -0
  493. package/templates/plugin-template/index.ts +160 -0
  494. package/templates/plugin-template/package.json +31 -0
  495. package/templates/plugin-template/test/plugin.test.ts +186 -0
  496. package/templates/plugin-template/tsconfig.json +21 -0
@@ -0,0 +1,236 @@
1
+ import { getDb } from "../db/db.js";
2
+ import { logger } from "../util/logger.js";
3
+ import { STABILITY_SCORE_INTERFACE, STABILITY_SCORE_BEHAVIOR, STABILITY_SCORE_SIDE_EFFECTS, } from "../config/constants.js";
4
+ function getSymbolVersions(versionId) {
5
+ return getDb()
6
+ .prepare("SELECT * FROM symbol_versions WHERE version_id = ?")
7
+ .all(versionId);
8
+ }
9
+ export function computeDelta(repoId, fromVersion, toVersion) {
10
+ const fromVersions = getSymbolVersions(fromVersion);
11
+ const toVersions = getSymbolVersions(toVersion);
12
+ if (fromVersions.length === 0) {
13
+ throw new Error(`No symbol snapshots found for fromVersion ${fromVersion}. Run indexing to create snapshots.`);
14
+ }
15
+ if (toVersions.length === 0) {
16
+ throw new Error(`No symbol snapshots found for toVersion ${toVersion}. Run indexing to create snapshots.`);
17
+ }
18
+ const fromMap = new Map(fromVersions.map((v) => [v.symbol_id, v]));
19
+ const toMap = new Map(toVersions.map((v) => [v.symbol_id, v]));
20
+ const changedSymbols = [];
21
+ for (const [symbolId, toRow] of toMap) {
22
+ const fromRow = fromMap.get(symbolId);
23
+ if (!fromRow) {
24
+ changedSymbols.push({
25
+ symbolId,
26
+ changeType: "added",
27
+ });
28
+ continue;
29
+ }
30
+ const signatureDiff = diffSignature(fromRow.signature_json, toRow.signature_json);
31
+ const invariantDiff = diffArray(fromRow.invariants_json, toRow.invariants_json);
32
+ const sideEffectDiff = diffArray(fromRow.side_effects_json, toRow.side_effects_json);
33
+ const isModified = fromRow.ast_fingerprint !== toRow.ast_fingerprint ||
34
+ fromRow.summary !== toRow.summary ||
35
+ signatureDiff !== undefined ||
36
+ invariantDiff !== undefined ||
37
+ sideEffectDiff !== undefined;
38
+ if (isModified) {
39
+ changedSymbols.push({
40
+ symbolId,
41
+ changeType: "modified",
42
+ signatureDiff,
43
+ invariantDiff,
44
+ sideEffectDiff,
45
+ });
46
+ }
47
+ }
48
+ for (const [symbolId] of fromMap) {
49
+ if (!toMap.has(symbolId)) {
50
+ changedSymbols.push({
51
+ symbolId,
52
+ changeType: "removed",
53
+ });
54
+ }
55
+ }
56
+ return {
57
+ repoId,
58
+ fromVersion,
59
+ toVersion,
60
+ changedSymbols,
61
+ blastRadius: [],
62
+ };
63
+ }
64
+ export function diffSignature(before, after) {
65
+ if (before === after) {
66
+ return undefined;
67
+ }
68
+ let beforeObj = null;
69
+ if (before !== null) {
70
+ try {
71
+ beforeObj = JSON.parse(before);
72
+ }
73
+ catch (e) {
74
+ logger.warn(`Failed to parse JSON in diffSignature (before): ${e.message}`);
75
+ }
76
+ }
77
+ let afterObj = null;
78
+ if (after !== null) {
79
+ try {
80
+ afterObj = JSON.parse(after);
81
+ }
82
+ catch (e) {
83
+ logger.warn(`Failed to parse JSON in diffSignature (after): ${e.message}`);
84
+ }
85
+ }
86
+ const beforeStr = JSON.stringify(beforeObj);
87
+ const afterStr = JSON.stringify(afterObj);
88
+ if (beforeStr === afterStr) {
89
+ return undefined;
90
+ }
91
+ return {
92
+ before: before ?? undefined,
93
+ after: after ?? undefined,
94
+ };
95
+ }
96
+ export function diffArray(before, after) {
97
+ if (before === after) {
98
+ return undefined;
99
+ }
100
+ let beforeArr = [];
101
+ if (before !== null) {
102
+ try {
103
+ beforeArr = JSON.parse(before);
104
+ }
105
+ catch (e) {
106
+ logger.warn(`Failed to parse JSON in diffArray (before): ${e.message}`);
107
+ beforeArr = [];
108
+ }
109
+ }
110
+ let afterArr = [];
111
+ if (after !== null) {
112
+ try {
113
+ afterArr = JSON.parse(after);
114
+ }
115
+ catch (e) {
116
+ logger.warn(`Failed to parse JSON in diffArray (after): ${e.message}`);
117
+ afterArr = [];
118
+ }
119
+ }
120
+ const beforeSet = new Set(beforeArr);
121
+ const afterSet = new Set(afterArr);
122
+ const added = [];
123
+ const removed = [];
124
+ for (const item of afterSet) {
125
+ if (!beforeSet.has(item)) {
126
+ added.push(item);
127
+ }
128
+ }
129
+ for (const item of beforeSet) {
130
+ if (!afterSet.has(item)) {
131
+ removed.push(item);
132
+ }
133
+ }
134
+ if (added.length === 0 && removed.length === 0) {
135
+ return undefined;
136
+ }
137
+ return { added, removed };
138
+ }
139
+ export function computeStalenessTiers(change, fromRow, toRow) {
140
+ const interfaceStable = change.signatureDiff === undefined;
141
+ const sideEffectsStable = change.sideEffectDiff === undefined;
142
+ let behaviorStable = false;
143
+ if (fromRow && toRow) {
144
+ const astFingerprintUnchanged = fromRow.ast_fingerprint === toRow.ast_fingerprint;
145
+ const summaryUnchanged = fromRow.summary === toRow.summary;
146
+ behaviorStable = astFingerprintUnchanged && summaryUnchanged;
147
+ }
148
+ let stabilityScore = (interfaceStable ? STABILITY_SCORE_INTERFACE : 0) +
149
+ (behaviorStable ? STABILITY_SCORE_BEHAVIOR : 0) +
150
+ (sideEffectsStable ? STABILITY_SCORE_SIDE_EFFECTS : 0);
151
+ if (stabilityScore < 0 || stabilityScore > 100) {
152
+ stabilityScore = Math.max(0, Math.min(100, stabilityScore));
153
+ }
154
+ const riskScore = 100 - stabilityScore;
155
+ return {
156
+ interfaceStable,
157
+ behaviorStable,
158
+ sideEffectsStable,
159
+ riskScore,
160
+ };
161
+ }
162
+ export function computeDeltaWithTiers(repoId, fromVersion, toVersion) {
163
+ const fromVersions = getSymbolVersions(fromVersion);
164
+ const toVersions = getSymbolVersions(toVersion);
165
+ if (fromVersions.length === 0) {
166
+ throw new Error(`No symbol snapshots found for fromVersion ${fromVersion}. Run indexing to create snapshots.`);
167
+ }
168
+ if (toVersions.length === 0) {
169
+ throw new Error(`No symbol snapshots found for toVersion ${toVersion}. Run indexing to create snapshots.`);
170
+ }
171
+ const fromMap = new Map(fromVersions.map((v) => [v.symbol_id, v]));
172
+ const toMap = new Map(toVersions.map((v) => [v.symbol_id, v]));
173
+ const changedSymbols = [];
174
+ for (const [symbolId, toRow] of toMap) {
175
+ const fromRow = fromMap.get(symbolId);
176
+ if (!fromRow) {
177
+ const change = {
178
+ symbolId,
179
+ changeType: "added",
180
+ tiers: {
181
+ interfaceStable: false,
182
+ behaviorStable: false,
183
+ sideEffectsStable: false,
184
+ riskScore: 100,
185
+ },
186
+ };
187
+ changedSymbols.push(change);
188
+ continue;
189
+ }
190
+ const signatureDiff = diffSignature(fromRow.signature_json, toRow.signature_json);
191
+ const invariantDiff = diffArray(fromRow.invariants_json, toRow.invariants_json);
192
+ const sideEffectDiff = diffArray(fromRow.side_effects_json, toRow.side_effects_json);
193
+ const isModified = fromRow.ast_fingerprint !== toRow.ast_fingerprint ||
194
+ fromRow.summary !== toRow.summary ||
195
+ signatureDiff !== undefined ||
196
+ invariantDiff !== undefined ||
197
+ sideEffectDiff !== undefined;
198
+ if (isModified) {
199
+ const baseChange = {
200
+ symbolId,
201
+ changeType: "modified",
202
+ signatureDiff,
203
+ invariantDiff,
204
+ sideEffectDiff,
205
+ };
206
+ const tiers = computeStalenessTiers(baseChange, fromRow, toRow);
207
+ changedSymbols.push({
208
+ ...baseChange,
209
+ tiers,
210
+ });
211
+ }
212
+ }
213
+ for (const [symbolId] of fromMap) {
214
+ if (!toMap.has(symbolId)) {
215
+ const change = {
216
+ symbolId,
217
+ changeType: "removed",
218
+ tiers: {
219
+ interfaceStable: false,
220
+ behaviorStable: false,
221
+ sideEffectsStable: false,
222
+ riskScore: 100,
223
+ },
224
+ };
225
+ changedSymbols.push(change);
226
+ }
227
+ }
228
+ return {
229
+ repoId,
230
+ fromVersion,
231
+ toVersion,
232
+ changedSymbols,
233
+ blastRadius: [],
234
+ };
235
+ }
236
+ //# sourceMappingURL=diff.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diff.js","sourceRoot":"","sources":["../../src/delta/diff.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EACL,yBAAyB,EACzB,wBAAwB,EACxB,4BAA4B,GAC7B,MAAM,wBAAwB,CAAC;AAEhC,SAAS,iBAAiB,CAAC,SAAiB;IAC1C,OAAO,KAAK,EAAE;SACX,OAAO,CAAC,oDAAoD,CAAC;SAC7D,GAAG,CAAC,SAAS,CAAuB,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,YAAY,CAC1B,MAAc,EACd,WAAsB,EACtB,SAAoB;IAEpB,MAAM,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC;IACpD,MAAM,UAAU,GAAG,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAEhD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,KAAK,CACb,6CAA6C,WAAW,qCAAqC,CAC9F,CAAC;IACJ,CAAC;IAED,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,KAAK,CACb,2CAA2C,SAAS,qCAAqC,CAC1F,CAAC;IACJ,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,GAAG,CACrB,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAC1C,CAAC;IACF,MAAM,KAAK,GAAG,IAAI,GAAG,CACnB,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CACxC,CAAC;IAEF,MAAM,cAAc,GAAwB,EAAE,CAAC;IAE/C,KAAK,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,KAAK,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAEtC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,cAAc,CAAC,IAAI,CAAC;gBAClB,QAAQ;gBACR,UAAU,EAAE,OAAO;aACpB,CAAC,CAAC;YACH,SAAS;QACX,CAAC;QAED,MAAM,aAAa,GAAG,aAAa,CACjC,OAAO,CAAC,cAAc,EACtB,KAAK,CAAC,cAAc,CACrB,CAAC;QACF,MAAM,aAAa,GAAG,SAAS,CAC7B,OAAO,CAAC,eAAe,EACvB,KAAK,CAAC,eAAe,CACtB,CAAC;QACF,MAAM,cAAc,GAAG,SAAS,CAC9B,OAAO,CAAC,iBAAiB,EACzB,KAAK,CAAC,iBAAiB,CACxB,CAAC;QAEF,MAAM,UAAU,GACd,OAAO,CAAC,eAAe,KAAK,KAAK,CAAC,eAAe;YACjD,OAAO,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO;YACjC,aAAa,KAAK,SAAS;YAC3B,aAAa,KAAK,SAAS;YAC3B,cAAc,KAAK,SAAS,CAAC;QAE/B,IAAI,UAAU,EAAE,CAAC;YACf,cAAc,CAAC,IAAI,CAAC;gBAClB,QAAQ;gBACR,UAAU,EAAE,UAAU;gBACtB,aAAa;gBACb,aAAa;gBACb,cAAc;aACf,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,KAAK,MAAM,CAAC,QAAQ,CAAC,IAAI,OAAO,EAAE,CAAC;QACjC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzB,cAAc,CAAC,IAAI,CAAC;gBAClB,QAAQ;gBACR,UAAU,EAAE,SAAS;aACtB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO;QACL,MAAM;QACN,WAAW;QACX,SAAS;QACT,cAAc;QACd,WAAW,EAAE,EAAE;KAChB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,MAAqB,EACrB,KAAoB;IAEpB,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;QACrB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,IAAI,SAAS,GAAG,IAAI,CAAC;IACrB,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC;YACH,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACjC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,CAAC,IAAI,CACT,mDAAoD,CAAW,CAAC,OAAO,EAAE,CAC1E,CAAC;QACJ,CAAC;IACH,CAAC;IAED,IAAI,QAAQ,GAAG,IAAI,CAAC;IACpB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC;YACH,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,CAAC,IAAI,CACT,kDAAmD,CAAW,CAAC,OAAO,EAAE,CACzE,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;IAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IAE1C,IAAI,SAAS,KAAK,QAAQ,EAAE,CAAC;QAC3B,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO;QACL,MAAM,EAAE,MAAM,IAAI,SAAS;QAC3B,KAAK,EAAE,KAAK,IAAI,SAAS;KAC1B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,SAAS,CACvB,MAAqB,EACrB,KAAoB;IAEpB,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;QACrB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,IAAI,SAAS,GAAa,EAAE,CAAC;IAC7B,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC;YACH,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAa,CAAC;QAC7C,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,CAAC,IAAI,CACT,+CAAgD,CAAW,CAAC,OAAO,EAAE,CACtE,CAAC;YACF,SAAS,GAAG,EAAE,CAAC;QACjB,CAAC;IACH,CAAC;IAED,IAAI,QAAQ,GAAa,EAAE,CAAC;IAC5B,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC;YACH,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAa,CAAC;QAC3C,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,CAAC,IAAI,CACT,8CAA+C,CAAW,CAAC,OAAO,EAAE,CACrE,CAAC;YACF,QAAQ,GAAG,EAAE,CAAC;QAChB,CAAC;IACH,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC;IACrC,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC;IAEnC,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAED,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE,CAAC;QAC7B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YACxB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IAED,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/C,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,qBAAqB,CACnC,MAAyB,EACzB,OAAgC,EAChC,KAA8B;IAE9B,MAAM,eAAe,GAAG,MAAM,CAAC,aAAa,KAAK,SAAS,CAAC;IAC3D,MAAM,iBAAiB,GAAG,MAAM,CAAC,cAAc,KAAK,SAAS,CAAC;IAE9D,IAAI,cAAc,GAAG,KAAK,CAAC;IAE3B,IAAI,OAAO,IAAI,KAAK,EAAE,CAAC;QACrB,MAAM,uBAAuB,GAC3B,OAAO,CAAC,eAAe,KAAK,KAAK,CAAC,eAAe,CAAC;QACpD,MAAM,gBAAgB,GAAG,OAAO,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO,CAAC;QAE3D,cAAc,GAAG,uBAAuB,IAAI,gBAAgB,CAAC;IAC/D,CAAC;IAED,IAAI,cAAc,GAChB,CAAC,eAAe,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,CAAC;QACjD,CAAC,cAAc,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,CAAC,iBAAiB,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEzD,IAAI,cAAc,GAAG,CAAC,IAAI,cAAc,GAAG,GAAG,EAAE,CAAC;QAC/C,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,SAAS,GAAG,GAAG,GAAG,cAAc,CAAC;IAEvC,OAAO;QACL,eAAe;QACf,cAAc;QACd,iBAAiB;QACjB,SAAS;KACV,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CACnC,MAAc,EACd,WAAsB,EACtB,SAAoB;IAEpB,MAAM,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC;IACpD,MAAM,UAAU,GAAG,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAEhD,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,KAAK,CACb,6CAA6C,WAAW,qCAAqC,CAC9F,CAAC;IACJ,CAAC;IAED,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,KAAK,CACb,2CAA2C,SAAS,qCAAqC,CAC1F,CAAC;IACJ,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,GAAG,CACrB,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAC1C,CAAC;IACF,MAAM,KAAK,GAAG,IAAI,GAAG,CACnB,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CACxC,CAAC;IAEF,MAAM,cAAc,GAAiC,EAAE,CAAC;IAExD,KAAK,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,KAAK,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAEtC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,MAAM,GAA+B;gBACzC,QAAQ;gBACR,UAAU,EAAE,OAAO;gBACnB,KAAK,EAAE;oBACL,eAAe,EAAE,KAAK;oBACtB,cAAc,EAAE,KAAK;oBACrB,iBAAiB,EAAE,KAAK;oBACxB,SAAS,EAAE,GAAG;iBACf;aACF,CAAC;YACF,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5B,SAAS;QACX,CAAC;QAED,MAAM,aAAa,GAAG,aAAa,CACjC,OAAO,CAAC,cAAc,EACtB,KAAK,CAAC,cAAc,CACrB,CAAC;QACF,MAAM,aAAa,GAAG,SAAS,CAC7B,OAAO,CAAC,eAAe,EACvB,KAAK,CAAC,eAAe,CACtB,CAAC;QACF,MAAM,cAAc,GAAG,SAAS,CAC9B,OAAO,CAAC,iBAAiB,EACzB,KAAK,CAAC,iBAAiB,CACxB,CAAC;QAEF,MAAM,UAAU,GACd,OAAO,CAAC,eAAe,KAAK,KAAK,CAAC,eAAe;YACjD,OAAO,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO;YACjC,aAAa,KAAK,SAAS;YAC3B,aAAa,KAAK,SAAS;YAC3B,cAAc,KAAK,SAAS,CAAC;QAE/B,IAAI,UAAU,EAAE,CAAC;YACf,MAAM,UAAU,GAAsB;gBACpC,QAAQ;gBACR,UAAU,EAAE,UAAU;gBACtB,aAAa;gBACb,aAAa;gBACb,cAAc;aACf,CAAC;YAEF,MAAM,KAAK,GAAG,qBAAqB,CAAC,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;YAEhE,cAAc,CAAC,IAAI,CAAC;gBAClB,GAAG,UAAU;gBACb,KAAK;aACN,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,KAAK,MAAM,CAAC,QAAQ,CAAC,IAAI,OAAO,EAAE,CAAC;QACjC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzB,MAAM,MAAM,GAA+B;gBACzC,QAAQ;gBACR,UAAU,EAAE,SAAS;gBACrB,KAAK,EAAE;oBACL,eAAe,EAAE,KAAK;oBACtB,cAAc,EAAE,KAAK;oBACrB,iBAAiB,EAAE,KAAK;oBACxB,SAAS,EAAE,GAAG;iBACf;aACF,CAAC;YACF,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,OAAO;QACL,MAAM;QACN,WAAW;QACX,SAAS;QACT,cAAc;QACd,WAAW,EAAE,EAAE;KAChB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { VersionId, SymbolId } from "../db/schema.js";
2
+ import type { VersionRow } from "../db/schema.js";
3
+ import type { SymbolVersionRow } from "../db/schema.js";
4
+ export declare function createVersion(repoId: string, reason?: string): VersionId;
5
+ export declare function computeVersionHash(prevVersionHash: string | null, symbolVersions: SymbolVersionRow[]): string;
6
+ export declare function finalizeVersionHash(versionId: VersionId, symbolVersions: SymbolVersionRow[]): void;
7
+ export declare function getVersion(versionId: VersionId): VersionRow | null;
8
+ export declare function getLatestVersion(repoId: string): VersionRow | null;
9
+ export declare function listVersions(repoId: string, limit?: number): VersionRow[];
10
+ export declare function snapshotSymbols(versionId: VersionId, symbolIds: SymbolId[]): void;
11
+ //# sourceMappingURL=versioning.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"versioning.d.ts","sourceRoot":"","sources":["../../src/delta/versioning.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAG3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAIxD,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAkBxE;AAED,wBAAgB,kBAAkB,CAChC,eAAe,EAAE,MAAM,GAAG,IAAI,EAC9B,cAAc,EAAE,gBAAgB,EAAE,GACjC,MAAM,CAQR;AAED,wBAAgB,mBAAmB,CACjC,SAAS,EAAE,SAAS,EACpB,cAAc,EAAE,gBAAgB,EAAE,GACjC,IAAI,CAYN;AAED,wBAAgB,UAAU,CAAC,SAAS,EAAE,SAAS,GAAG,UAAU,GAAG,IAAI,CAElE;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,CAElE;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,EAAE,CAEzE;AAED,wBAAgB,eAAe,CAC7B,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,QAAQ,EAAE,GACpB,IAAI,CA2BN"}
@@ -0,0 +1,68 @@
1
+ import * as db from "../db/queries.js";
2
+ import { getCurrentTimestamp } from "../util/time.js";
3
+ import { getDb } from "../db/db.js";
4
+ import { hashContent } from "../util/hashing.js";
5
+ export function createVersion(repoId, reason) {
6
+ const timestamp = Date.now();
7
+ const versionId = `${repoId}-v${timestamp}`;
8
+ const latestVersion = db.getLatestVersion(repoId);
9
+ const prevVersionHash = latestVersion?.version_hash ?? null;
10
+ const version = {
11
+ version_id: versionId,
12
+ repo_id: repoId,
13
+ created_at: getCurrentTimestamp(),
14
+ reason: reason ?? null,
15
+ prev_version_hash: prevVersionHash,
16
+ version_hash: null,
17
+ };
18
+ db.createVersion(version);
19
+ return versionId;
20
+ }
21
+ export function computeVersionHash(prevVersionHash, symbolVersions) {
22
+ const sortedVersions = [...symbolVersions].sort((a, b) => a.symbol_id.localeCompare(b.symbol_id));
23
+ const fingerprints = sortedVersions.map((sv) => sv.ast_fingerprint).join("|");
24
+ const combined = `${prevVersionHash || "none"}:${fingerprints}`;
25
+ return hashContent(combined);
26
+ }
27
+ export function finalizeVersionHash(versionId, symbolVersions) {
28
+ const version = db.getVersion(versionId);
29
+ if (!version) {
30
+ throw new Error(`Version ${versionId} not found`);
31
+ }
32
+ const versionHash = computeVersionHash(version.prev_version_hash, symbolVersions);
33
+ db.updateVersionHashes(versionId, version.prev_version_hash, versionHash);
34
+ }
35
+ export function getVersion(versionId) {
36
+ return db.getVersion(versionId);
37
+ }
38
+ export function getLatestVersion(repoId) {
39
+ return db.getLatestVersion(repoId);
40
+ }
41
+ export function listVersions(repoId, limit) {
42
+ return db.listVersions(repoId, limit ?? 50);
43
+ }
44
+ export function snapshotSymbols(versionId, symbolIds) {
45
+ const dbInstance = getDb();
46
+ const snapshotTx = dbInstance.transaction(() => {
47
+ const snapshots = [];
48
+ for (const symbolId of symbolIds) {
49
+ const symbol = db.getSymbol(symbolId);
50
+ if (!symbol)
51
+ continue;
52
+ const snapshot = {
53
+ version_id: versionId,
54
+ symbol_id: symbolId,
55
+ ast_fingerprint: symbol.ast_fingerprint,
56
+ signature_json: symbol.signature_json,
57
+ summary: symbol.summary,
58
+ invariants_json: symbol.invariants_json,
59
+ side_effects_json: symbol.side_effects_json,
60
+ };
61
+ db.snapshotSymbolVersion(versionId, symbolId, snapshot);
62
+ snapshots.push(snapshot);
63
+ }
64
+ finalizeVersionHash(versionId, snapshots);
65
+ });
66
+ snapshotTx();
67
+ }
68
+ //# sourceMappingURL=versioning.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"versioning.js","sourceRoot":"","sources":["../../src/delta/versioning.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import type { SymbolId, EdgeType, SymbolRow, EdgeRow } from "../db/schema.js";
2
+ export interface Graph {
3
+ repoId: string;
4
+ symbols: Map<SymbolId, SymbolRow>;
5
+ edges: EdgeRow[];
6
+ adjacencyIn: Map<SymbolId, EdgeRow[]>;
7
+ adjacencyOut: Map<SymbolId, EdgeRow[]>;
8
+ }
9
+ export declare function loadGraphForRepo(repoId: string): Graph;
10
+ export declare function getNeighbors(graph: Graph, symbolId: SymbolId, direction: "in" | "out" | "both", edgeType?: EdgeType): SymbolId[];
11
+ export declare function getPath(graph: Graph, fromSymbol: SymbolId, toSymbol: SymbolId): SymbolId[] | null;
12
+ //# sourceMappingURL=buildGraph.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildGraph.d.ts","sourceRoot":"","sources":["../../src/graph/buildGraph.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG9E,MAAM,WAAW,KAAK;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IAClC,KAAK,EAAE,OAAO,EAAE,CAAC;IACjB,WAAW,EAAE,GAAG,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;IACtC,YAAY,EAAE,GAAG,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;CACxC;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,KAAK,CAiCtD;AAED,wBAAgB,YAAY,CAC1B,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,IAAI,GAAG,KAAK,GAAG,MAAM,EAChC,QAAQ,CAAC,EAAE,QAAQ,GAClB,QAAQ,EAAE,CAsBZ;AAED,wBAAgB,OAAO,CACrB,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,QAAQ,EACpB,QAAQ,EAAE,QAAQ,GACjB,QAAQ,EAAE,GAAG,IAAI,CAuCnB"}
@@ -0,0 +1,81 @@
1
+ import * as db from "../db/queries.js";
2
+ export function loadGraphForRepo(repoId) {
3
+ const symbols = db.getSymbolsByRepo(repoId);
4
+ const edges = db.getEdgesByRepo(repoId);
5
+ const symbolMap = new Map();
6
+ const adjacencyIn = new Map();
7
+ const adjacencyOut = new Map();
8
+ for (const symbol of symbols) {
9
+ symbolMap.set(symbol.symbol_id, symbol);
10
+ adjacencyIn.set(symbol.symbol_id, []);
11
+ adjacencyOut.set(symbol.symbol_id, []);
12
+ }
13
+ for (const edge of edges) {
14
+ const outgoing = adjacencyOut.get(edge.from_symbol_id);
15
+ const incoming = adjacencyIn.get(edge.to_symbol_id);
16
+ if (outgoing) {
17
+ outgoing.push(edge);
18
+ }
19
+ if (incoming) {
20
+ incoming.push(edge);
21
+ }
22
+ }
23
+ return {
24
+ repoId,
25
+ symbols: symbolMap,
26
+ edges,
27
+ adjacencyIn,
28
+ adjacencyOut,
29
+ };
30
+ }
31
+ export function getNeighbors(graph, symbolId, direction, edgeType) {
32
+ const neighbors = new Set();
33
+ if (direction === "in" || direction === "both") {
34
+ const incoming = graph.adjacencyIn.get(symbolId) ?? [];
35
+ for (const edge of incoming) {
36
+ if (!edgeType || edge.type === edgeType) {
37
+ neighbors.add(edge.from_symbol_id);
38
+ }
39
+ }
40
+ }
41
+ if (direction === "out" || direction === "both") {
42
+ const outgoing = graph.adjacencyOut.get(symbolId) ?? [];
43
+ for (const edge of outgoing) {
44
+ if (!edgeType || edge.type === edgeType) {
45
+ neighbors.add(edge.to_symbol_id);
46
+ }
47
+ }
48
+ }
49
+ return Array.from(neighbors);
50
+ }
51
+ export function getPath(graph, fromSymbol, toSymbol) {
52
+ if (fromSymbol === toSymbol) {
53
+ return [fromSymbol];
54
+ }
55
+ const visited = new Set();
56
+ const queue = [fromSymbol];
57
+ const parent = new Map();
58
+ visited.add(fromSymbol);
59
+ while (queue.length > 0) {
60
+ const current = queue.shift();
61
+ const neighbors = getNeighbors(graph, current, "out");
62
+ for (const neighbor of neighbors) {
63
+ if (!visited.has(neighbor)) {
64
+ visited.add(neighbor);
65
+ parent.set(neighbor, current);
66
+ if (neighbor === toSymbol) {
67
+ const path = [];
68
+ let node = toSymbol;
69
+ while (node) {
70
+ path.unshift(node);
71
+ node = parent.get(node);
72
+ }
73
+ return path;
74
+ }
75
+ queue.push(neighbor);
76
+ }
77
+ }
78
+ }
79
+ return null;
80
+ }
81
+ //# sourceMappingURL=buildGraph.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildGraph.js","sourceRoot":"","sources":["../../src/graph/buildGraph.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,111 @@
1
+ /**
2
+ * LRU Cache with version-based invalidation for SDL-MCP
3
+ *
4
+ * Provides in-memory caching for SymbolCard and GraphSlice objects with:
5
+ * - LRU (Least Recently Used) eviction policy
6
+ * - Version-based cache key invalidation
7
+ * - Cache statistics tracking (hits, misses, evictions)
8
+ * - Configurable size limits per cache type
9
+ */
10
+ import type { SymbolCard } from "../mcp/types.js";
11
+ import type { VersionId, SymbolId, RepoId } from "../db/schema.js";
12
+ interface CacheEntry<T> {
13
+ value: T;
14
+ versionId: VersionId;
15
+ lastAccessed: number;
16
+ size: number;
17
+ }
18
+ interface CacheStats {
19
+ hits: number;
20
+ misses: number;
21
+ evictions: number;
22
+ currentSize: number;
23
+ entryCount: number;
24
+ }
25
+ interface CacheConfig {
26
+ maxEntries: number;
27
+ maxSizeBytes: number;
28
+ }
29
+ /**
30
+ * LRU Cache implementation with version-based invalidation
31
+ */
32
+ declare class LRUCache<T> {
33
+ private cache;
34
+ private accessOrder;
35
+ private stats;
36
+ private config;
37
+ private lock;
38
+ constructor(config?: Partial<CacheConfig>);
39
+ /**
40
+ * Generates a cache key including version for invalidation
41
+ */
42
+ private makeKey;
43
+ /**
44
+ * Estimates size of a cache entry in bytes
45
+ * Accounts for object overhead and string encoding
46
+ */
47
+ private estimateSize;
48
+ /**
49
+ * Updates access order for LRU tracking
50
+ */
51
+ private updateAccessOrder;
52
+ /**
53
+ * Evicts entries to fit within cache limits
54
+ */
55
+ private evictIfNeeded;
56
+ /**
57
+ * Invalidates all cache entries for a specific version
58
+ */
59
+ invalidateVersion(versionId: VersionId): void;
60
+ /**
61
+ * Clears all cache entries
62
+ */
63
+ clear(): void;
64
+ /**
65
+ * Gets a cached value
66
+ */
67
+ get(repoId: RepoId, id: string, versionId: VersionId): T | undefined;
68
+ /**
69
+ * Sets a cached value
70
+ */
71
+ set(repoId: RepoId, id: string, versionId: VersionId, value: T): Promise<void>;
72
+ /**
73
+ * Checks if a key exists in the cache
74
+ */
75
+ has(repoId: RepoId, id: string, versionId: VersionId): boolean;
76
+ /**
77
+ * Gets cache statistics
78
+ */
79
+ getStats(): CacheStats;
80
+ /**
81
+ * Resets cache statistics
82
+ */
83
+ resetStats(): void;
84
+ }
85
+ /**
86
+ * Global cache instances
87
+ */
88
+ export declare const symbolCardCache: LRUCache<SymbolCard>;
89
+ /**
90
+ * Cache key generators
91
+ */
92
+ export declare function makeSymbolCardCacheKey(repoId: RepoId, symbolId: SymbolId, versionId: VersionId): string;
93
+ /**
94
+ * Cache statistics retrieval
95
+ */
96
+ export declare function getSymbolCardCacheStats(): CacheStats;
97
+ /**
98
+ * Cache invalidation helpers
99
+ */
100
+ export declare function invalidateSymbolCardVersion(versionId: VersionId): void;
101
+ /**
102
+ * Clears all caches
103
+ */
104
+ export declare function clearAllCaches(): void;
105
+ /**
106
+ * Resets all cache statistics
107
+ */
108
+ export declare function resetAllCacheStats(): void;
109
+ export { LRUCache };
110
+ export type { CacheEntry, CacheStats, CacheConfig };
111
+ //# sourceMappingURL=cache.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../src/graph/cache.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEnE,UAAU,UAAU,CAAC,CAAC;IACpB,KAAK,EAAE,CAAC,CAAC;IACT,SAAS,EAAE,SAAS,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,UAAU,UAAU;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,UAAU,WAAW;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;CACtB;AAYD;;GAEG;AACH,cAAM,QAAQ,CAAC,CAAC;IACd,OAAO,CAAC,KAAK,CAAyC;IACtD,OAAO,CAAC,WAAW,CAAgB;IACnC,OAAO,CAAC,KAAK,CAMX;IACF,OAAO,CAAC,MAAM,CAAc;IAC5B,OAAO,CAAC,IAAI,CAAoC;gBAEpC,MAAM,GAAE,OAAO,CAAC,WAAW,CAAM;IAI7C;;OAEG;IACH,OAAO,CAAC,OAAO;IAIf;;;OAGG;IACH,OAAO,CAAC,YAAY;IAWpB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAQzB;;OAEG;IACH,OAAO,CAAC,aAAa;IAmBrB;;OAEG;IACH,iBAAiB,CAAC,SAAS,EAAE,SAAS,GAAG,IAAI;IAqB7C;;OAEG;IACH,KAAK,IAAI,IAAI;IAOb;;OAEG;IACH,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,GAAG,CAAC,GAAG,SAAS;IAepE;;OAEG;IACG,GAAG,CACP,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,MAAM,EACV,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,CAAC,GACP,OAAO,CAAC,IAAI,CAAC;IAqDhB;;OAEG;IACH,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,GAAG,OAAO;IAK9D;;OAEG;IACH,QAAQ,IAAI,UAAU;IAItB;;OAEG;IACH,UAAU,IAAI,IAAI;CAKnB;AAED;;GAEG;AACH,eAAO,MAAM,eAAe,sBAE3B,CAAC;AAEF;;GAEG;AACH,wBAAgB,sBAAsB,CACpC,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,SAAS,GACnB,MAAM,CAER;AAGD;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,UAAU,CAEpD;AAED;;GAEG;AACH,wBAAgB,2BAA2B,CAAC,SAAS,EAAE,SAAS,GAAG,IAAI,CAEtE;AAED;;GAEG;AACH,wBAAgB,cAAc,IAAI,IAAI,CAErC;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,IAAI,CAEzC;AAED,OAAO,EAAE,QAAQ,EAAE,CAAC;AACpB,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC"}