@optave/codegraph 3.4.0 → 3.4.1

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 (410) hide show
  1. package/README.md +7 -7
  2. package/dist/ast-analysis/engine.d.ts.map +1 -1
  3. package/dist/ast-analysis/engine.js +3 -9
  4. package/dist/ast-analysis/engine.js.map +1 -1
  5. package/dist/ast-analysis/shared.d.ts.map +1 -1
  6. package/dist/ast-analysis/shared.js +0 -1
  7. package/dist/ast-analysis/shared.js.map +1 -1
  8. package/dist/ast-analysis/visitors/cfg-conditionals.d.ts +5 -0
  9. package/dist/ast-analysis/visitors/cfg-conditionals.d.ts.map +1 -0
  10. package/dist/ast-analysis/visitors/cfg-conditionals.js +166 -0
  11. package/dist/ast-analysis/visitors/cfg-conditionals.js.map +1 -0
  12. package/dist/ast-analysis/visitors/cfg-loops.d.ts +7 -0
  13. package/dist/ast-analysis/visitors/cfg-loops.d.ts.map +1 -0
  14. package/dist/ast-analysis/visitors/cfg-loops.js +73 -0
  15. package/dist/ast-analysis/visitors/cfg-loops.js.map +1 -0
  16. package/dist/ast-analysis/visitors/cfg-shared.d.ts +56 -0
  17. package/dist/ast-analysis/visitors/cfg-shared.d.ts.map +1 -0
  18. package/dist/ast-analysis/visitors/cfg-shared.js +107 -0
  19. package/dist/ast-analysis/visitors/cfg-shared.js.map +1 -0
  20. package/dist/ast-analysis/visitors/cfg-try-catch.d.ts +4 -0
  21. package/dist/ast-analysis/visitors/cfg-try-catch.d.ts.map +1 -0
  22. package/dist/ast-analysis/visitors/cfg-try-catch.js +100 -0
  23. package/dist/ast-analysis/visitors/cfg-try-catch.js.map +1 -0
  24. package/dist/ast-analysis/visitors/cfg-visitor.d.ts +2 -2
  25. package/dist/ast-analysis/visitors/cfg-visitor.d.ts.map +1 -1
  26. package/dist/ast-analysis/visitors/cfg-visitor.js +11 -445
  27. package/dist/ast-analysis/visitors/cfg-visitor.js.map +1 -1
  28. package/dist/ast-analysis/visitors/complexity-visitor.d.ts.map +1 -1
  29. package/dist/ast-analysis/visitors/complexity-visitor.js.map +1 -1
  30. package/dist/ast-analysis/visitors/dataflow-visitor.d.ts.map +1 -1
  31. package/dist/ast-analysis/visitors/dataflow-visitor.js.map +1 -1
  32. package/dist/cli/commands/batch.d.ts.map +1 -1
  33. package/dist/cli/commands/batch.js +4 -3
  34. package/dist/cli/commands/batch.js.map +1 -1
  35. package/dist/cli/commands/branch-compare.js +1 -1
  36. package/dist/cli/commands/branch-compare.js.map +1 -1
  37. package/dist/cli/commands/build.js +1 -1
  38. package/dist/cli/commands/build.js.map +1 -1
  39. package/dist/cli/commands/info.d.ts.map +1 -1
  40. package/dist/cli/commands/info.js +1 -2
  41. package/dist/cli/commands/info.js.map +1 -1
  42. package/dist/cli/commands/path.d.ts.map +1 -1
  43. package/dist/cli/commands/path.js +7 -2
  44. package/dist/cli/commands/path.js.map +1 -1
  45. package/dist/cli/commands/plot.d.ts.map +1 -1
  46. package/dist/cli/commands/plot.js +2 -2
  47. package/dist/cli/commands/plot.js.map +1 -1
  48. package/dist/cli/commands/watch.js +1 -1
  49. package/dist/cli/commands/watch.js.map +1 -1
  50. package/dist/cli/index.js +2 -2
  51. package/dist/cli/index.js.map +1 -1
  52. package/dist/cli/shared/open-graph.d.ts +2 -2
  53. package/dist/cli/shared/open-graph.d.ts.map +1 -1
  54. package/dist/cli/shared/open-graph.js.map +1 -1
  55. package/dist/cli/types.d.ts +1 -1
  56. package/dist/cli/types.d.ts.map +1 -1
  57. package/dist/cli.js +2 -3
  58. package/dist/cli.js.map +1 -1
  59. package/dist/db/connection.d.ts +17 -0
  60. package/dist/db/connection.d.ts.map +1 -1
  61. package/dist/db/connection.js +91 -2
  62. package/dist/db/connection.js.map +1 -1
  63. package/dist/db/index.d.ts +1 -1
  64. package/dist/db/index.d.ts.map +1 -1
  65. package/dist/db/index.js +1 -1
  66. package/dist/db/index.js.map +1 -1
  67. package/dist/db/migrations.d.ts.map +1 -1
  68. package/dist/db/migrations.js +7 -0
  69. package/dist/db/migrations.js.map +1 -1
  70. package/dist/domain/analysis/brief.d.ts.map +1 -1
  71. package/dist/domain/analysis/brief.js +1 -3
  72. package/dist/domain/analysis/brief.js.map +1 -1
  73. package/dist/domain/analysis/context.d.ts.map +1 -1
  74. package/dist/domain/analysis/context.js +2 -4
  75. package/dist/domain/analysis/context.js.map +1 -1
  76. package/dist/domain/analysis/dependencies.d.ts +49 -0
  77. package/dist/domain/analysis/dependencies.d.ts.map +1 -1
  78. package/dist/domain/analysis/dependencies.js +145 -0
  79. package/dist/domain/analysis/dependencies.js.map +1 -1
  80. package/dist/domain/analysis/diff-impact.d.ts +76 -0
  81. package/dist/domain/analysis/diff-impact.d.ts.map +1 -0
  82. package/dist/domain/analysis/diff-impact.js +282 -0
  83. package/dist/domain/analysis/diff-impact.js.map +1 -0
  84. package/dist/domain/analysis/exports.d.ts.map +1 -1
  85. package/dist/domain/analysis/exports.js +0 -1
  86. package/dist/domain/analysis/exports.js.map +1 -1
  87. package/dist/domain/analysis/fn-impact.d.ts +66 -0
  88. package/dist/domain/analysis/fn-impact.d.ts.map +1 -0
  89. package/dist/domain/analysis/fn-impact.js +189 -0
  90. package/dist/domain/analysis/fn-impact.js.map +1 -0
  91. package/dist/domain/analysis/impact.d.ts +8 -148
  92. package/dist/domain/analysis/impact.d.ts.map +1 -1
  93. package/dist/domain/analysis/impact.js +8 -568
  94. package/dist/domain/analysis/impact.js.map +1 -1
  95. package/dist/domain/analysis/module-map.d.ts.map +1 -1
  96. package/dist/domain/analysis/module-map.js +1 -3
  97. package/dist/domain/analysis/module-map.js.map +1 -1
  98. package/dist/domain/graph/builder/context.d.ts +2 -3
  99. package/dist/domain/graph/builder/context.d.ts.map +1 -1
  100. package/dist/domain/graph/builder/context.js.map +1 -1
  101. package/dist/domain/graph/builder/helpers.d.ts +4 -5
  102. package/dist/domain/graph/builder/helpers.d.ts.map +1 -1
  103. package/dist/domain/graph/builder/helpers.js +1 -2
  104. package/dist/domain/graph/builder/helpers.js.map +1 -1
  105. package/dist/domain/graph/builder/incremental.d.ts +2 -3
  106. package/dist/domain/graph/builder/incremental.d.ts.map +1 -1
  107. package/dist/domain/graph/builder/incremental.js.map +1 -1
  108. package/dist/domain/graph/builder/pipeline.d.ts.map +1 -1
  109. package/dist/domain/graph/builder/pipeline.js +6 -0
  110. package/dist/domain/graph/builder/pipeline.js.map +1 -1
  111. package/dist/domain/graph/builder/stages/build-edges.d.ts.map +1 -1
  112. package/dist/domain/graph/builder/stages/build-edges.js +12 -2
  113. package/dist/domain/graph/builder/stages/build-edges.js.map +1 -1
  114. package/dist/domain/graph/builder/stages/build-structure.d.ts.map +1 -1
  115. package/dist/domain/graph/builder/stages/build-structure.js +155 -59
  116. package/dist/domain/graph/builder/stages/build-structure.js.map +1 -1
  117. package/dist/domain/graph/builder/stages/detect-changes.d.ts.map +1 -1
  118. package/dist/domain/graph/builder/stages/detect-changes.js +6 -6
  119. package/dist/domain/graph/builder/stages/detect-changes.js.map +1 -1
  120. package/dist/domain/graph/builder/stages/finalize.d.ts.map +1 -1
  121. package/dist/domain/graph/builder/stages/finalize.js +85 -61
  122. package/dist/domain/graph/builder/stages/finalize.js.map +1 -1
  123. package/dist/domain/graph/builder/stages/insert-nodes.d.ts.map +1 -1
  124. package/dist/domain/graph/builder/stages/insert-nodes.js.map +1 -1
  125. package/dist/domain/graph/builder/stages/resolve-imports.d.ts.map +1 -1
  126. package/dist/domain/graph/builder/stages/resolve-imports.js +58 -11
  127. package/dist/domain/graph/builder/stages/resolve-imports.js.map +1 -1
  128. package/dist/domain/graph/cycles.js +2 -2
  129. package/dist/domain/graph/cycles.js.map +1 -1
  130. package/dist/domain/graph/resolve.d.ts.map +1 -1
  131. package/dist/domain/graph/resolve.js +10 -8
  132. package/dist/domain/graph/resolve.js.map +1 -1
  133. package/dist/domain/graph/watcher.d.ts.map +1 -1
  134. package/dist/domain/graph/watcher.js +1 -3
  135. package/dist/domain/graph/watcher.js.map +1 -1
  136. package/dist/domain/parser.d.ts.map +1 -1
  137. package/dist/domain/parser.js +11 -12
  138. package/dist/domain/parser.js.map +1 -1
  139. package/dist/domain/queries.d.ts +3 -2
  140. package/dist/domain/queries.d.ts.map +1 -1
  141. package/dist/domain/queries.js +3 -2
  142. package/dist/domain/queries.js.map +1 -1
  143. package/dist/domain/search/generator.d.ts.map +1 -1
  144. package/dist/domain/search/generator.js.map +1 -1
  145. package/dist/extractors/csharp.js +2 -2
  146. package/dist/extractors/csharp.js.map +1 -1
  147. package/dist/extractors/go.js +2 -2
  148. package/dist/extractors/go.js.map +1 -1
  149. package/dist/extractors/helpers.d.ts +5 -0
  150. package/dist/extractors/helpers.d.ts.map +1 -1
  151. package/dist/extractors/helpers.js +5 -0
  152. package/dist/extractors/helpers.js.map +1 -1
  153. package/dist/extractors/javascript.js +58 -60
  154. package/dist/extractors/javascript.js.map +1 -1
  155. package/dist/extractors/php.js +2 -2
  156. package/dist/extractors/php.js.map +1 -1
  157. package/dist/extractors/python.js +2 -2
  158. package/dist/extractors/python.js.map +1 -1
  159. package/dist/extractors/rust.js +2 -2
  160. package/dist/extractors/rust.js.map +1 -1
  161. package/dist/features/audit.d.ts.map +1 -1
  162. package/dist/features/audit.js +1 -2
  163. package/dist/features/audit.js.map +1 -1
  164. package/dist/features/branch-compare.d.ts.map +1 -1
  165. package/dist/features/branch-compare.js +2 -3
  166. package/dist/features/branch-compare.js.map +1 -1
  167. package/dist/features/cfg.d.ts.map +1 -1
  168. package/dist/features/cfg.js +2 -4
  169. package/dist/features/cfg.js.map +1 -1
  170. package/dist/features/cochange.js +4 -4
  171. package/dist/features/cochange.js.map +1 -1
  172. package/dist/features/communities.js +4 -4
  173. package/dist/features/communities.js.map +1 -1
  174. package/dist/features/complexity-query.d.ts +37 -0
  175. package/dist/features/complexity-query.d.ts.map +1 -0
  176. package/dist/features/complexity-query.js +263 -0
  177. package/dist/features/complexity-query.js.map +1 -0
  178. package/dist/features/complexity.d.ts +2 -30
  179. package/dist/features/complexity.d.ts.map +1 -1
  180. package/dist/features/complexity.js +7 -261
  181. package/dist/features/complexity.js.map +1 -1
  182. package/dist/features/dataflow.d.ts.map +1 -1
  183. package/dist/features/dataflow.js +8 -24
  184. package/dist/features/dataflow.js.map +1 -1
  185. package/dist/features/export.d.ts +7 -8
  186. package/dist/features/export.d.ts.map +1 -1
  187. package/dist/features/export.js.map +1 -1
  188. package/dist/features/flow.d.ts.map +1 -1
  189. package/dist/features/flow.js.map +1 -1
  190. package/dist/features/graph-enrichment.d.ts.map +1 -1
  191. package/dist/features/graph-enrichment.js +1 -3
  192. package/dist/features/graph-enrichment.js.map +1 -1
  193. package/dist/features/manifesto.js +8 -8
  194. package/dist/features/manifesto.js.map +1 -1
  195. package/dist/features/snapshot.d.ts.map +1 -1
  196. package/dist/features/snapshot.js +0 -1
  197. package/dist/features/snapshot.js.map +1 -1
  198. package/dist/features/structure-query.d.ts +76 -0
  199. package/dist/features/structure-query.d.ts.map +1 -0
  200. package/dist/features/structure-query.js +245 -0
  201. package/dist/features/structure-query.js.map +1 -0
  202. package/dist/features/structure.d.ts +12 -67
  203. package/dist/features/structure.d.ts.map +1 -1
  204. package/dist/features/structure.js +188 -244
  205. package/dist/features/structure.js.map +1 -1
  206. package/dist/features/triage.js +2 -2
  207. package/dist/features/triage.js.map +1 -1
  208. package/dist/graph/algorithms/leiden/adapter.d.ts.map +1 -1
  209. package/dist/graph/algorithms/leiden/adapter.js +2 -9
  210. package/dist/graph/algorithms/leiden/adapter.js.map +1 -1
  211. package/dist/graph/classifiers/roles.d.ts +5 -1
  212. package/dist/graph/classifiers/roles.d.ts.map +1 -1
  213. package/dist/graph/classifiers/roles.js +20 -12
  214. package/dist/graph/classifiers/roles.js.map +1 -1
  215. package/dist/index.d.ts +1 -0
  216. package/dist/index.d.ts.map +1 -1
  217. package/dist/index.js.map +1 -1
  218. package/dist/infrastructure/config.d.ts.map +1 -1
  219. package/dist/infrastructure/config.js +12 -11
  220. package/dist/infrastructure/config.js.map +1 -1
  221. package/dist/infrastructure/native.d.ts.map +1 -1
  222. package/dist/infrastructure/native.js +7 -3
  223. package/dist/infrastructure/native.js.map +1 -1
  224. package/dist/infrastructure/registry.d.ts.map +1 -1
  225. package/dist/infrastructure/registry.js +1 -1
  226. package/dist/infrastructure/registry.js.map +1 -1
  227. package/dist/infrastructure/update-check.js +3 -3
  228. package/dist/infrastructure/update-check.js.map +1 -1
  229. package/dist/mcp/server.d.ts.map +1 -1
  230. package/dist/mcp/server.js +2 -8
  231. package/dist/mcp/server.js.map +1 -1
  232. package/dist/mcp/tool-registry.d.ts.map +1 -1
  233. package/dist/mcp/tool-registry.js +9 -4
  234. package/dist/mcp/tool-registry.js.map +1 -1
  235. package/dist/mcp/tools/audit.js +1 -1
  236. package/dist/mcp/tools/audit.js.map +1 -1
  237. package/dist/mcp/tools/cfg.js +1 -1
  238. package/dist/mcp/tools/cfg.js.map +1 -1
  239. package/dist/mcp/tools/check.js +2 -2
  240. package/dist/mcp/tools/check.js.map +1 -1
  241. package/dist/mcp/tools/dataflow.js +2 -2
  242. package/dist/mcp/tools/dataflow.js.map +1 -1
  243. package/dist/mcp/tools/export-graph.js +1 -1
  244. package/dist/mcp/tools/export-graph.js.map +1 -1
  245. package/dist/mcp/tools/index.d.ts.map +1 -1
  246. package/dist/mcp/tools/index.js.map +1 -1
  247. package/dist/mcp/tools/path.d.ts +1 -0
  248. package/dist/mcp/tools/path.d.ts.map +1 -1
  249. package/dist/mcp/tools/path.js +9 -0
  250. package/dist/mcp/tools/path.js.map +1 -1
  251. package/dist/mcp/tools/query.js +1 -1
  252. package/dist/mcp/tools/query.js.map +1 -1
  253. package/dist/mcp/tools/semantic-search.js +1 -1
  254. package/dist/mcp/tools/semantic-search.js.map +1 -1
  255. package/dist/mcp/tools/sequence.js +1 -1
  256. package/dist/mcp/tools/sequence.js.map +1 -1
  257. package/dist/mcp/tools/symbol-children.js +1 -1
  258. package/dist/mcp/tools/symbol-children.js.map +1 -1
  259. package/dist/mcp/tools/triage.js +1 -1
  260. package/dist/mcp/tools/triage.js.map +1 -1
  261. package/dist/presentation/audit.d.ts.map +1 -1
  262. package/dist/presentation/audit.js +0 -1
  263. package/dist/presentation/audit.js.map +1 -1
  264. package/dist/presentation/diff-impact-mermaid.d.ts +11 -0
  265. package/dist/presentation/diff-impact-mermaid.d.ts.map +1 -0
  266. package/dist/presentation/diff-impact-mermaid.js +105 -0
  267. package/dist/presentation/diff-impact-mermaid.js.map +1 -0
  268. package/dist/presentation/flow.d.ts.map +1 -1
  269. package/dist/presentation/flow.js +0 -2
  270. package/dist/presentation/flow.js.map +1 -1
  271. package/dist/presentation/manifesto.d.ts.map +1 -1
  272. package/dist/presentation/manifesto.js +0 -1
  273. package/dist/presentation/manifesto.js.map +1 -1
  274. package/dist/presentation/queries-cli/inspect.d.ts.map +1 -1
  275. package/dist/presentation/queries-cli/inspect.js.map +1 -1
  276. package/dist/presentation/queries-cli/path.d.ts.map +1 -1
  277. package/dist/presentation/queries-cli/path.js +45 -1
  278. package/dist/presentation/queries-cli/path.js.map +1 -1
  279. package/dist/presentation/result-formatter.d.ts.map +1 -1
  280. package/dist/presentation/result-formatter.js +1 -3
  281. package/dist/presentation/result-formatter.js.map +1 -1
  282. package/dist/presentation/sequence.d.ts.map +1 -1
  283. package/dist/presentation/sequence.js +0 -1
  284. package/dist/presentation/sequence.js.map +1 -1
  285. package/dist/presentation/structure.d.ts.map +1 -1
  286. package/dist/presentation/structure.js.map +1 -1
  287. package/dist/presentation/triage.d.ts.map +1 -1
  288. package/dist/presentation/triage.js +0 -1
  289. package/dist/presentation/triage.js.map +1 -1
  290. package/dist/shared/constants.d.ts +9 -3
  291. package/dist/shared/constants.d.ts.map +1 -1
  292. package/dist/shared/constants.js +6 -3
  293. package/dist/shared/constants.js.map +1 -1
  294. package/dist/shared/errors.d.ts +2 -0
  295. package/dist/shared/errors.d.ts.map +1 -1
  296. package/dist/shared/errors.js +4 -0
  297. package/dist/shared/errors.js.map +1 -1
  298. package/dist/shared/version.d.ts +2 -0
  299. package/dist/shared/version.d.ts.map +1 -0
  300. package/dist/shared/version.js +5 -0
  301. package/dist/shared/version.js.map +1 -0
  302. package/dist/types.d.ts +2 -2
  303. package/dist/types.d.ts.map +1 -1
  304. package/package.json +8 -7
  305. package/src/ast-analysis/engine.ts +3 -9
  306. package/src/ast-analysis/shared.ts +0 -1
  307. package/src/ast-analysis/visitors/cfg-conditionals.ts +227 -0
  308. package/src/ast-analysis/visitors/cfg-loops.ts +136 -0
  309. package/src/ast-analysis/visitors/cfg-shared.ts +196 -0
  310. package/src/ast-analysis/visitors/cfg-try-catch.ts +142 -0
  311. package/src/ast-analysis/visitors/cfg-visitor.ts +34 -655
  312. package/src/ast-analysis/visitors/complexity-visitor.ts +0 -1
  313. package/src/ast-analysis/visitors/dataflow-visitor.ts +0 -1
  314. package/src/cli/commands/batch.ts +4 -3
  315. package/src/cli/commands/branch-compare.ts +1 -1
  316. package/src/cli/commands/build.ts +1 -1
  317. package/src/cli/commands/info.ts +1 -2
  318. package/src/cli/commands/path.ts +7 -2
  319. package/src/cli/commands/plot.ts +2 -2
  320. package/src/cli/commands/watch.ts +1 -1
  321. package/src/cli/index.ts +2 -2
  322. package/src/cli/shared/open-graph.ts +2 -2
  323. package/src/cli/types.ts +1 -1
  324. package/src/cli.ts +2 -3
  325. package/src/db/connection.ts +97 -13
  326. package/src/db/index.ts +2 -0
  327. package/src/db/migrations.ts +7 -0
  328. package/src/domain/analysis/brief.ts +0 -1
  329. package/src/domain/analysis/context.ts +2 -6
  330. package/src/domain/analysis/dependencies.ts +165 -0
  331. package/src/domain/analysis/diff-impact.ts +354 -0
  332. package/src/domain/analysis/exports.ts +0 -2
  333. package/src/domain/analysis/fn-impact.ts +241 -0
  334. package/src/domain/analysis/impact.ts +8 -718
  335. package/src/domain/analysis/module-map.ts +1 -5
  336. package/src/domain/graph/builder/context.ts +2 -2
  337. package/src/domain/graph/builder/helpers.ts +14 -11
  338. package/src/domain/graph/builder/incremental.ts +33 -28
  339. package/src/domain/graph/builder/pipeline.ts +8 -0
  340. package/src/domain/graph/builder/stages/build-edges.ts +17 -4
  341. package/src/domain/graph/builder/stages/build-structure.ts +205 -76
  342. package/src/domain/graph/builder/stages/detect-changes.ts +11 -12
  343. package/src/domain/graph/builder/stages/finalize.ts +100 -81
  344. package/src/domain/graph/builder/stages/insert-nodes.ts +12 -8
  345. package/src/domain/graph/builder/stages/resolve-imports.ts +75 -10
  346. package/src/domain/graph/cycles.ts +2 -2
  347. package/src/domain/graph/resolve.ts +14 -8
  348. package/src/domain/graph/watcher.ts +2 -4
  349. package/src/domain/parser.ts +11 -13
  350. package/src/domain/queries.ts +2 -2
  351. package/src/domain/search/generator.ts +3 -4
  352. package/src/extractors/csharp.ts +2 -2
  353. package/src/extractors/go.ts +2 -2
  354. package/src/extractors/helpers.ts +6 -0
  355. package/src/extractors/javascript.ts +58 -61
  356. package/src/extractors/php.ts +2 -2
  357. package/src/extractors/python.ts +2 -2
  358. package/src/extractors/rust.ts +2 -2
  359. package/src/features/audit.ts +1 -2
  360. package/src/features/branch-compare.ts +3 -9
  361. package/src/features/cfg.ts +2 -4
  362. package/src/features/cochange.ts +4 -4
  363. package/src/features/communities.ts +4 -4
  364. package/src/features/complexity-query.ts +370 -0
  365. package/src/features/complexity.ts +6 -365
  366. package/src/features/dataflow.ts +48 -70
  367. package/src/features/export.ts +12 -16
  368. package/src/features/flow.ts +0 -1
  369. package/src/features/graph-enrichment.ts +1 -3
  370. package/src/features/manifesto.ts +8 -8
  371. package/src/features/snapshot.ts +1 -2
  372. package/src/features/structure-query.ts +387 -0
  373. package/src/features/structure.ts +231 -376
  374. package/src/features/triage.ts +2 -2
  375. package/src/graph/algorithms/leiden/adapter.ts +2 -9
  376. package/src/graph/classifiers/roles.ts +22 -13
  377. package/src/index.ts +1 -0
  378. package/src/infrastructure/config.ts +12 -13
  379. package/src/infrastructure/native.ts +7 -3
  380. package/src/infrastructure/registry.ts +1 -1
  381. package/src/infrastructure/update-check.ts +3 -3
  382. package/src/mcp/server.ts +2 -10
  383. package/src/mcp/tool-registry.ts +11 -4
  384. package/src/mcp/tools/audit.ts +1 -1
  385. package/src/mcp/tools/cfg.ts +1 -1
  386. package/src/mcp/tools/check.ts +2 -2
  387. package/src/mcp/tools/dataflow.ts +2 -2
  388. package/src/mcp/tools/export-graph.ts +1 -1
  389. package/src/mcp/tools/index.ts +0 -1
  390. package/src/mcp/tools/path.ts +10 -0
  391. package/src/mcp/tools/query.ts +1 -1
  392. package/src/mcp/tools/semantic-search.ts +1 -1
  393. package/src/mcp/tools/sequence.ts +1 -1
  394. package/src/mcp/tools/symbol-children.ts +1 -1
  395. package/src/mcp/tools/triage.ts +1 -1
  396. package/src/presentation/audit.ts +0 -1
  397. package/src/presentation/diff-impact-mermaid.ts +127 -0
  398. package/src/presentation/flow.ts +0 -2
  399. package/src/presentation/manifesto.ts +0 -1
  400. package/src/presentation/queries-cli/inspect.ts +0 -1
  401. package/src/presentation/queries-cli/path.ts +71 -1
  402. package/src/presentation/result-formatter.ts +0 -1
  403. package/src/presentation/sequence.ts +0 -1
  404. package/src/presentation/structure.ts +0 -12
  405. package/src/presentation/triage.ts +0 -1
  406. package/src/shared/constants.ts +33 -19
  407. package/src/shared/errors.ts +5 -0
  408. package/src/shared/version.ts +10 -0
  409. package/src/types.ts +4 -10
  410. package/src/vendor.d.ts +0 -39
@@ -0,0 +1,136 @@
1
+ import type { TreeSitterNode } from '../../types.js';
2
+ import type {
3
+ AnyRules,
4
+ CfgBlockInternal,
5
+ FuncState,
6
+ LoopCtx,
7
+ ProcessStatementsFn,
8
+ } from './cfg-shared.js';
9
+ import { getBodyStatements, registerLabelCtx } from './cfg-shared.js';
10
+
11
+ export function processForLoop(
12
+ forStmt: TreeSitterNode,
13
+ currentBlock: CfgBlockInternal,
14
+ S: FuncState,
15
+ cfgRules: AnyRules,
16
+ processStatements: ProcessStatementsFn,
17
+ ): CfgBlockInternal {
18
+ const headerBlock = S.makeBlock(
19
+ 'loop_header',
20
+ forStmt.startPosition.row + 1,
21
+ forStmt.startPosition.row + 1,
22
+ 'for',
23
+ );
24
+ S.addEdge(currentBlock, headerBlock, 'fallthrough');
25
+
26
+ const loopExitBlock = S.makeBlock('body');
27
+ const loopCtx: LoopCtx = { headerBlock, exitBlock: loopExitBlock };
28
+ S.loopStack.push(loopCtx);
29
+ registerLabelCtx(S, headerBlock, loopExitBlock);
30
+
31
+ const body = forStmt.childForFieldName('body');
32
+ const bodyBlock = S.makeBlock('loop_body');
33
+ S.addEdge(headerBlock, bodyBlock, 'branch_true');
34
+
35
+ const bodyStmts = getBodyStatements(body, cfgRules);
36
+ const bodyEnd = processStatements(bodyStmts, bodyBlock, S, cfgRules);
37
+ if (bodyEnd) S.addEdge(bodyEnd, headerBlock, 'loop_back');
38
+
39
+ S.addEdge(headerBlock, loopExitBlock, 'loop_exit');
40
+ S.loopStack.pop();
41
+ return loopExitBlock;
42
+ }
43
+
44
+ export function processWhileLoop(
45
+ whileStmt: TreeSitterNode,
46
+ currentBlock: CfgBlockInternal,
47
+ S: FuncState,
48
+ cfgRules: AnyRules,
49
+ processStatements: ProcessStatementsFn,
50
+ ): CfgBlockInternal {
51
+ const headerBlock = S.makeBlock(
52
+ 'loop_header',
53
+ whileStmt.startPosition.row + 1,
54
+ whileStmt.startPosition.row + 1,
55
+ 'while',
56
+ );
57
+ S.addEdge(currentBlock, headerBlock, 'fallthrough');
58
+
59
+ const loopExitBlock = S.makeBlock('body');
60
+ const loopCtx: LoopCtx = { headerBlock, exitBlock: loopExitBlock };
61
+ S.loopStack.push(loopCtx);
62
+ registerLabelCtx(S, headerBlock, loopExitBlock);
63
+
64
+ const body = whileStmt.childForFieldName('body');
65
+ const bodyBlock = S.makeBlock('loop_body');
66
+ S.addEdge(headerBlock, bodyBlock, 'branch_true');
67
+
68
+ const bodyStmts = getBodyStatements(body, cfgRules);
69
+ const bodyEnd = processStatements(bodyStmts, bodyBlock, S, cfgRules);
70
+ if (bodyEnd) S.addEdge(bodyEnd, headerBlock, 'loop_back');
71
+
72
+ S.addEdge(headerBlock, loopExitBlock, 'loop_exit');
73
+ S.loopStack.pop();
74
+ return loopExitBlock;
75
+ }
76
+
77
+ export function processDoWhileLoop(
78
+ doStmt: TreeSitterNode,
79
+ currentBlock: CfgBlockInternal,
80
+ S: FuncState,
81
+ cfgRules: AnyRules,
82
+ processStatements: ProcessStatementsFn,
83
+ ): CfgBlockInternal {
84
+ const bodyBlock = S.makeBlock('loop_body', doStmt.startPosition.row + 1, null, 'do');
85
+ S.addEdge(currentBlock, bodyBlock, 'fallthrough');
86
+
87
+ const condBlock = S.makeBlock('loop_header', null, null, 'do-while');
88
+ const loopExitBlock = S.makeBlock('body');
89
+
90
+ const loopCtx: LoopCtx = { headerBlock: condBlock, exitBlock: loopExitBlock };
91
+ S.loopStack.push(loopCtx);
92
+ registerLabelCtx(S, condBlock, loopExitBlock);
93
+
94
+ const body = doStmt.childForFieldName('body');
95
+ const bodyStmts = getBodyStatements(body, cfgRules);
96
+ const bodyEnd = processStatements(bodyStmts, bodyBlock, S, cfgRules);
97
+ if (bodyEnd) S.addEdge(bodyEnd, condBlock, 'fallthrough');
98
+
99
+ S.addEdge(condBlock, bodyBlock, 'loop_back');
100
+ S.addEdge(condBlock, loopExitBlock, 'loop_exit');
101
+
102
+ S.loopStack.pop();
103
+ return loopExitBlock;
104
+ }
105
+
106
+ export function processInfiniteLoop(
107
+ loopStmt: TreeSitterNode,
108
+ currentBlock: CfgBlockInternal,
109
+ S: FuncState,
110
+ cfgRules: AnyRules,
111
+ processStatements: ProcessStatementsFn,
112
+ ): CfgBlockInternal {
113
+ const headerBlock = S.makeBlock(
114
+ 'loop_header',
115
+ loopStmt.startPosition.row + 1,
116
+ loopStmt.startPosition.row + 1,
117
+ 'loop',
118
+ );
119
+ S.addEdge(currentBlock, headerBlock, 'fallthrough');
120
+
121
+ const loopExitBlock = S.makeBlock('body');
122
+ const loopCtx: LoopCtx = { headerBlock, exitBlock: loopExitBlock };
123
+ S.loopStack.push(loopCtx);
124
+ registerLabelCtx(S, headerBlock, loopExitBlock);
125
+
126
+ const body = loopStmt.childForFieldName('body');
127
+ const bodyBlock = S.makeBlock('loop_body');
128
+ S.addEdge(headerBlock, bodyBlock, 'branch_true');
129
+
130
+ const bodyStmts = getBodyStatements(body, cfgRules);
131
+ const bodyEnd = processStatements(bodyStmts, bodyBlock, S, cfgRules);
132
+ if (bodyEnd) S.addEdge(bodyEnd, headerBlock, 'loop_back');
133
+
134
+ S.loopStack.pop();
135
+ return loopExitBlock;
136
+ }
@@ -0,0 +1,196 @@
1
+ import type { TreeSitterNode } from '../../types.js';
2
+
3
+ export type AnyRules = any;
4
+
5
+ /** Callback type for the mutual recursion with processStatements in cfg-visitor. */
6
+ export type ProcessStatementsFn = (
7
+ stmts: TreeSitterNode[],
8
+ currentBlock: CfgBlockInternal,
9
+ S: FuncState,
10
+ cfgRules: AnyRules,
11
+ ) => CfgBlockInternal | null;
12
+
13
+ export function nn(node: TreeSitterNode | null, context?: string): TreeSitterNode {
14
+ if (node === null) {
15
+ throw new Error(`Unexpected null tree-sitter node${context ? ` (${context})` : ''}`);
16
+ }
17
+ return node;
18
+ }
19
+
20
+ export interface CfgBlockInternal {
21
+ index: number;
22
+ type: string;
23
+ startLine: number | null;
24
+ endLine: number | null;
25
+ label: string | null;
26
+ }
27
+
28
+ export interface CfgEdgeInternal {
29
+ sourceIndex: number;
30
+ targetIndex: number;
31
+ kind: string;
32
+ }
33
+
34
+ export interface LabelCtx {
35
+ headerBlock: CfgBlockInternal | null;
36
+ exitBlock: CfgBlockInternal | null;
37
+ }
38
+
39
+ export interface LoopCtx {
40
+ headerBlock: CfgBlockInternal;
41
+ exitBlock: CfgBlockInternal;
42
+ }
43
+
44
+ export interface FuncState {
45
+ blocks: CfgBlockInternal[];
46
+ edges: CfgEdgeInternal[];
47
+ makeBlock(
48
+ type: string,
49
+ startLine?: number | null,
50
+ endLine?: number | null,
51
+ label?: string | null,
52
+ ): CfgBlockInternal;
53
+ addEdge(source: CfgBlockInternal, target: CfgBlockInternal, kind: string): void;
54
+ entryBlock: CfgBlockInternal;
55
+ exitBlock: CfgBlockInternal;
56
+ currentBlock: CfgBlockInternal | null;
57
+ loopStack: LoopCtx[];
58
+ labelMap: Map<string, LabelCtx>;
59
+ cfgStack: FuncState[];
60
+ funcNode: TreeSitterNode | null;
61
+ }
62
+
63
+ export interface CFGResultInternal {
64
+ funcNode: TreeSitterNode;
65
+ blocks: CfgBlockInternal[];
66
+ edges: CfgEdgeInternal[];
67
+ cyclomatic: number;
68
+ }
69
+
70
+ export function isIfNode(type: string, cfgRules: AnyRules): boolean {
71
+ return type === cfgRules.ifNode || cfgRules.ifNodes?.has(type);
72
+ }
73
+
74
+ export function isForNode(type: string, cfgRules: AnyRules): boolean {
75
+ return cfgRules.forNodes.has(type);
76
+ }
77
+
78
+ export function isWhileNode(type: string, cfgRules: AnyRules): boolean {
79
+ return type === cfgRules.whileNode || cfgRules.whileNodes?.has(type);
80
+ }
81
+
82
+ export function isSwitchNode(type: string, cfgRules: AnyRules): boolean {
83
+ return type === cfgRules.switchNode || cfgRules.switchNodes?.has(type);
84
+ }
85
+
86
+ export function isCaseNode(type: string, cfgRules: AnyRules): boolean {
87
+ return (
88
+ type === cfgRules.caseNode || type === cfgRules.defaultNode || cfgRules.caseNodes?.has(type)
89
+ );
90
+ }
91
+
92
+ export function isBlockNode(type: string, cfgRules: AnyRules): boolean {
93
+ return type === 'statement_list' || type === cfgRules.blockNode || cfgRules.blockNodes?.has(type);
94
+ }
95
+
96
+ export function isControlFlow(type: string, cfgRules: AnyRules): boolean {
97
+ return (
98
+ isIfNode(type, cfgRules) ||
99
+ (cfgRules.unlessNode && type === cfgRules.unlessNode) ||
100
+ isForNode(type, cfgRules) ||
101
+ isWhileNode(type, cfgRules) ||
102
+ (cfgRules.untilNode && type === cfgRules.untilNode) ||
103
+ (cfgRules.doNode && type === cfgRules.doNode) ||
104
+ (cfgRules.infiniteLoopNode && type === cfgRules.infiniteLoopNode) ||
105
+ isSwitchNode(type, cfgRules) ||
106
+ (cfgRules.tryNode && type === cfgRules.tryNode) ||
107
+ type === cfgRules.returnNode ||
108
+ type === cfgRules.throwNode ||
109
+ type === cfgRules.breakNode ||
110
+ type === cfgRules.continueNode ||
111
+ type === cfgRules.labeledNode
112
+ );
113
+ }
114
+
115
+ export function effectiveNode(node: TreeSitterNode, cfgRules: AnyRules): TreeSitterNode {
116
+ if (node.type === 'expression_statement' && node.namedChildCount === 1) {
117
+ const inner = nn(node.namedChild(0));
118
+ if (isControlFlow(inner.type, cfgRules)) return inner;
119
+ }
120
+ return node;
121
+ }
122
+
123
+ export function registerLabelCtx(
124
+ S: FuncState,
125
+ headerBlock: CfgBlockInternal,
126
+ exitBlock: CfgBlockInternal,
127
+ ): void {
128
+ for (const [, ctx] of Array.from(S.labelMap)) {
129
+ if (!ctx.headerBlock) {
130
+ ctx.headerBlock = headerBlock;
131
+ ctx.exitBlock = exitBlock;
132
+ }
133
+ }
134
+ }
135
+
136
+ export function getBodyStatements(
137
+ bodyNode: TreeSitterNode | null,
138
+ cfgRules: AnyRules,
139
+ ): TreeSitterNode[] {
140
+ if (!bodyNode) return [];
141
+ if (isBlockNode(bodyNode.type, cfgRules)) {
142
+ const stmts: TreeSitterNode[] = [];
143
+ for (let i = 0; i < bodyNode.namedChildCount; i++) {
144
+ const child = nn(bodyNode.namedChild(i));
145
+ if (child.type === 'statement_list') {
146
+ for (let j = 0; j < child.namedChildCount; j++) {
147
+ stmts.push(nn(child.namedChild(j)));
148
+ }
149
+ } else {
150
+ stmts.push(child);
151
+ }
152
+ }
153
+ return stmts;
154
+ }
155
+ return [bodyNode];
156
+ }
157
+
158
+ export function makeFuncState(): FuncState {
159
+ const blocks: CfgBlockInternal[] = [];
160
+ const edges: CfgEdgeInternal[] = [];
161
+ let nextIndex = 0;
162
+
163
+ function makeBlock(
164
+ type: string,
165
+ startLine: number | null = null,
166
+ endLine: number | null = null,
167
+ label: string | null = null,
168
+ ): CfgBlockInternal {
169
+ const block: CfgBlockInternal = { index: nextIndex++, type, startLine, endLine, label };
170
+ blocks.push(block);
171
+ return block;
172
+ }
173
+
174
+ function addEdge(source: CfgBlockInternal, target: CfgBlockInternal, kind: string): void {
175
+ edges.push({ sourceIndex: source.index, targetIndex: target.index, kind });
176
+ }
177
+
178
+ const entry = makeBlock('entry');
179
+ const exit = makeBlock('exit');
180
+ const firstBody = makeBlock('body');
181
+ addEdge(entry, firstBody, 'fallthrough');
182
+
183
+ return {
184
+ blocks,
185
+ edges,
186
+ makeBlock,
187
+ addEdge,
188
+ entryBlock: entry,
189
+ exitBlock: exit,
190
+ currentBlock: firstBody,
191
+ loopStack: [],
192
+ labelMap: new Map(),
193
+ cfgStack: [],
194
+ funcNode: null,
195
+ };
196
+ }
@@ -0,0 +1,142 @@
1
+ import type { TreeSitterNode } from '../../types.js';
2
+ import type { AnyRules, CfgBlockInternal, FuncState, ProcessStatementsFn } from './cfg-shared.js';
3
+ import { getBodyStatements, nn } from './cfg-shared.js';
4
+
5
+ export function processTryCatch(
6
+ tryStmt: TreeSitterNode,
7
+ currentBlock: CfgBlockInternal,
8
+ S: FuncState,
9
+ cfgRules: AnyRules,
10
+ processStatements: ProcessStatementsFn,
11
+ ): CfgBlockInternal {
12
+ currentBlock.endLine = tryStmt.startPosition.row + 1;
13
+
14
+ const joinBlock = S.makeBlock('body');
15
+
16
+ const tryBody = tryStmt.childForFieldName('body');
17
+ let tryBodyStart: number;
18
+ let tryStmts: TreeSitterNode[];
19
+ if (tryBody) {
20
+ tryBodyStart = tryBody.startPosition.row + 1;
21
+ tryStmts = getBodyStatements(tryBody, cfgRules);
22
+ } else {
23
+ tryBodyStart = tryStmt.startPosition.row + 1;
24
+ tryStmts = [];
25
+ for (let i = 0; i < tryStmt.namedChildCount; i++) {
26
+ const child = nn(tryStmt.namedChild(i));
27
+ if (cfgRules.catchNode && child.type === cfgRules.catchNode) continue;
28
+ if (cfgRules.finallyNode && child.type === cfgRules.finallyNode) continue;
29
+ tryStmts.push(child);
30
+ }
31
+ }
32
+
33
+ const tryBlock = S.makeBlock('body', tryBodyStart, null, 'try');
34
+ S.addEdge(currentBlock, tryBlock, 'fallthrough');
35
+ const tryEnd = processStatements(tryStmts, tryBlock, S, cfgRules);
36
+
37
+ const { catchHandler, finallyHandler } = findTryHandlers(tryStmt, cfgRules);
38
+
39
+ if (catchHandler) {
40
+ processCatchHandler(
41
+ catchHandler,
42
+ tryBlock,
43
+ tryEnd,
44
+ finallyHandler,
45
+ joinBlock,
46
+ S,
47
+ cfgRules,
48
+ processStatements,
49
+ );
50
+ } else if (finallyHandler) {
51
+ processFinallyOnly(finallyHandler, tryEnd, joinBlock, S, cfgRules, processStatements);
52
+ } else {
53
+ if (tryEnd) S.addEdge(tryEnd, joinBlock, 'fallthrough');
54
+ }
55
+
56
+ return joinBlock;
57
+ }
58
+
59
+ function findTryHandlers(
60
+ tryStmt: TreeSitterNode,
61
+ cfgRules: AnyRules,
62
+ ): { catchHandler: TreeSitterNode | null; finallyHandler: TreeSitterNode | null } {
63
+ let catchHandler: TreeSitterNode | null = null;
64
+ let finallyHandler: TreeSitterNode | null = null;
65
+ for (let i = 0; i < tryStmt.namedChildCount; i++) {
66
+ const child = nn(tryStmt.namedChild(i));
67
+ if (cfgRules.catchNode && child.type === cfgRules.catchNode) catchHandler = child;
68
+ if (cfgRules.finallyNode && child.type === cfgRules.finallyNode) finallyHandler = child;
69
+ }
70
+ return { catchHandler, finallyHandler };
71
+ }
72
+
73
+ function processCatchHandler(
74
+ catchHandler: TreeSitterNode,
75
+ tryBlock: CfgBlockInternal,
76
+ tryEnd: CfgBlockInternal | null,
77
+ finallyHandler: TreeSitterNode | null,
78
+ joinBlock: CfgBlockInternal,
79
+ S: FuncState,
80
+ cfgRules: AnyRules,
81
+ processStatements: ProcessStatementsFn,
82
+ ): void {
83
+ const catchBlock = S.makeBlock('catch', catchHandler.startPosition.row + 1, null, 'catch');
84
+ S.addEdge(tryBlock, catchBlock, 'exception');
85
+
86
+ const catchBodyNode = catchHandler.childForFieldName('body');
87
+ let catchStmts: TreeSitterNode[];
88
+ if (catchBodyNode) {
89
+ catchStmts = getBodyStatements(catchBodyNode, cfgRules);
90
+ } else {
91
+ catchStmts = [];
92
+ for (let i = 0; i < catchHandler.namedChildCount; i++) {
93
+ catchStmts.push(nn(catchHandler.namedChild(i)));
94
+ }
95
+ }
96
+ const catchEnd = processStatements(catchStmts, catchBlock, S, cfgRules);
97
+
98
+ if (finallyHandler) {
99
+ const finallyBlock = S.makeBlock(
100
+ 'finally',
101
+ finallyHandler.startPosition.row + 1,
102
+ null,
103
+ 'finally',
104
+ );
105
+ if (tryEnd) S.addEdge(tryEnd, finallyBlock, 'fallthrough');
106
+ if (catchEnd) S.addEdge(catchEnd, finallyBlock, 'fallthrough');
107
+
108
+ const finallyBodyNode = finallyHandler.childForFieldName('body');
109
+ const finallyStmts = finallyBodyNode
110
+ ? getBodyStatements(finallyBodyNode, cfgRules)
111
+ : getBodyStatements(finallyHandler, cfgRules);
112
+ const finallyEnd = processStatements(finallyStmts, finallyBlock, S, cfgRules);
113
+ if (finallyEnd) S.addEdge(finallyEnd, joinBlock, 'fallthrough');
114
+ } else {
115
+ if (tryEnd) S.addEdge(tryEnd, joinBlock, 'fallthrough');
116
+ if (catchEnd) S.addEdge(catchEnd, joinBlock, 'fallthrough');
117
+ }
118
+ }
119
+
120
+ function processFinallyOnly(
121
+ finallyHandler: TreeSitterNode,
122
+ tryEnd: CfgBlockInternal | null,
123
+ joinBlock: CfgBlockInternal,
124
+ S: FuncState,
125
+ cfgRules: AnyRules,
126
+ processStatements: ProcessStatementsFn,
127
+ ): void {
128
+ const finallyBlock = S.makeBlock(
129
+ 'finally',
130
+ finallyHandler.startPosition.row + 1,
131
+ null,
132
+ 'finally',
133
+ );
134
+ if (tryEnd) S.addEdge(tryEnd, finallyBlock, 'fallthrough');
135
+
136
+ const finallyBodyNode = finallyHandler.childForFieldName('body');
137
+ const finallyStmts = finallyBodyNode
138
+ ? getBodyStatements(finallyBodyNode, cfgRules)
139
+ : getBodyStatements(finallyHandler, cfgRules);
140
+ const finallyEnd = processStatements(finallyStmts, finallyBlock, S, cfgRules);
141
+ if (finallyEnd) S.addEdge(finallyEnd, joinBlock, 'fallthrough');
142
+ }