driftdetect-core 0.4.6 → 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 (644) hide show
  1. package/dist/boundaries/types.d.ts +1 -1
  2. package/dist/boundaries/types.d.ts.map +1 -1
  3. package/dist/call-graph/analysis/graph-builder.d.ts.map +1 -1
  4. package/dist/call-graph/analysis/graph-builder.js +1 -0
  5. package/dist/call-graph/analysis/graph-builder.js.map +1 -1
  6. package/dist/call-graph/extractors/csharp-data-access-extractor.d.ts +8 -0
  7. package/dist/call-graph/extractors/csharp-data-access-extractor.d.ts.map +1 -1
  8. package/dist/call-graph/extractors/csharp-data-access-extractor.js +8 -0
  9. package/dist/call-graph/extractors/csharp-data-access-extractor.js.map +1 -1
  10. package/dist/call-graph/extractors/csharp-extractor.d.ts +35 -0
  11. package/dist/call-graph/extractors/csharp-extractor.d.ts.map +1 -1
  12. package/dist/call-graph/extractors/csharp-extractor.js +362 -4
  13. package/dist/call-graph/extractors/csharp-extractor.js.map +1 -1
  14. package/dist/call-graph/extractors/csharp-hybrid-extractor.d.ts +37 -0
  15. package/dist/call-graph/extractors/csharp-hybrid-extractor.d.ts.map +1 -0
  16. package/dist/call-graph/extractors/csharp-hybrid-extractor.js +408 -0
  17. package/dist/call-graph/extractors/csharp-hybrid-extractor.js.map +1 -0
  18. package/dist/call-graph/extractors/go-data-access-extractor.d.ts +80 -0
  19. package/dist/call-graph/extractors/go-data-access-extractor.d.ts.map +1 -0
  20. package/dist/call-graph/extractors/go-data-access-extractor.js +457 -0
  21. package/dist/call-graph/extractors/go-data-access-extractor.js.map +1 -0
  22. package/dist/call-graph/extractors/go-extractor.d.ts +103 -0
  23. package/dist/call-graph/extractors/go-extractor.d.ts.map +1 -0
  24. package/dist/call-graph/extractors/go-extractor.js +509 -0
  25. package/dist/call-graph/extractors/go-extractor.js.map +1 -0
  26. package/dist/call-graph/extractors/go-hybrid-extractor.d.ts +97 -0
  27. package/dist/call-graph/extractors/go-hybrid-extractor.d.ts.map +1 -0
  28. package/dist/call-graph/extractors/go-hybrid-extractor.js +496 -0
  29. package/dist/call-graph/extractors/go-hybrid-extractor.js.map +1 -0
  30. package/dist/call-graph/extractors/hybrid-extractor-base.d.ts +102 -0
  31. package/dist/call-graph/extractors/hybrid-extractor-base.d.ts.map +1 -0
  32. package/dist/call-graph/extractors/hybrid-extractor-base.js +289 -0
  33. package/dist/call-graph/extractors/hybrid-extractor-base.js.map +1 -0
  34. package/dist/call-graph/extractors/index.d.ts +17 -13
  35. package/dist/call-graph/extractors/index.d.ts.map +1 -1
  36. package/dist/call-graph/extractors/index.js +24 -23
  37. package/dist/call-graph/extractors/index.js.map +1 -1
  38. package/dist/call-graph/extractors/java-data-access-extractor.d.ts +8 -0
  39. package/dist/call-graph/extractors/java-data-access-extractor.d.ts.map +1 -1
  40. package/dist/call-graph/extractors/java-data-access-extractor.js +8 -0
  41. package/dist/call-graph/extractors/java-data-access-extractor.js.map +1 -1
  42. package/dist/call-graph/extractors/java-extractor.d.ts +15 -0
  43. package/dist/call-graph/extractors/java-extractor.d.ts.map +1 -1
  44. package/dist/call-graph/extractors/java-extractor.js +120 -4
  45. package/dist/call-graph/extractors/java-extractor.js.map +1 -1
  46. package/dist/call-graph/extractors/java-hybrid-extractor.d.ts +36 -0
  47. package/dist/call-graph/extractors/java-hybrid-extractor.d.ts.map +1 -0
  48. package/dist/call-graph/extractors/java-hybrid-extractor.js +426 -0
  49. package/dist/call-graph/extractors/java-hybrid-extractor.js.map +1 -0
  50. package/dist/call-graph/extractors/php-data-access-extractor.d.ts +8 -0
  51. package/dist/call-graph/extractors/php-data-access-extractor.d.ts.map +1 -1
  52. package/dist/call-graph/extractors/php-data-access-extractor.js +8 -0
  53. package/dist/call-graph/extractors/php-data-access-extractor.js.map +1 -1
  54. package/dist/call-graph/extractors/php-extractor.d.ts +48 -1
  55. package/dist/call-graph/extractors/php-extractor.d.ts.map +1 -1
  56. package/dist/call-graph/extractors/php-extractor.js +460 -6
  57. package/dist/call-graph/extractors/php-extractor.js.map +1 -1
  58. package/dist/call-graph/extractors/php-hybrid-extractor.d.ts +35 -0
  59. package/dist/call-graph/extractors/php-hybrid-extractor.d.ts.map +1 -0
  60. package/dist/call-graph/extractors/php-hybrid-extractor.js +393 -0
  61. package/dist/call-graph/extractors/php-hybrid-extractor.js.map +1 -0
  62. package/dist/call-graph/extractors/python-data-access-extractor.d.ts +8 -0
  63. package/dist/call-graph/extractors/python-data-access-extractor.d.ts.map +1 -1
  64. package/dist/call-graph/extractors/python-data-access-extractor.js +8 -0
  65. package/dist/call-graph/extractors/python-data-access-extractor.js.map +1 -1
  66. package/dist/call-graph/extractors/python-hybrid-extractor.d.ts +85 -0
  67. package/dist/call-graph/extractors/python-hybrid-extractor.d.ts.map +1 -0
  68. package/dist/call-graph/extractors/python-hybrid-extractor.js +462 -0
  69. package/dist/call-graph/extractors/python-hybrid-extractor.js.map +1 -0
  70. package/dist/call-graph/extractors/regex/base-regex-extractor.d.ts +154 -0
  71. package/dist/call-graph/extractors/regex/base-regex-extractor.d.ts.map +1 -0
  72. package/dist/call-graph/extractors/regex/base-regex-extractor.js +346 -0
  73. package/dist/call-graph/extractors/regex/base-regex-extractor.js.map +1 -0
  74. package/dist/call-graph/extractors/regex/csharp-regex.d.ts +34 -0
  75. package/dist/call-graph/extractors/regex/csharp-regex.d.ts.map +1 -0
  76. package/dist/call-graph/extractors/regex/csharp-regex.js +393 -0
  77. package/dist/call-graph/extractors/regex/csharp-regex.js.map +1 -0
  78. package/dist/call-graph/extractors/regex/go-regex.d.ts +51 -0
  79. package/dist/call-graph/extractors/regex/go-regex.d.ts.map +1 -0
  80. package/dist/call-graph/extractors/regex/go-regex.js +435 -0
  81. package/dist/call-graph/extractors/regex/go-regex.js.map +1 -0
  82. package/dist/call-graph/extractors/regex/index.d.ts +26 -0
  83. package/dist/call-graph/extractors/regex/index.d.ts.map +1 -0
  84. package/dist/call-graph/extractors/regex/index.js +74 -0
  85. package/dist/call-graph/extractors/regex/index.js.map +1 -0
  86. package/dist/call-graph/extractors/regex/java-regex.d.ts +34 -0
  87. package/dist/call-graph/extractors/regex/java-regex.d.ts.map +1 -0
  88. package/dist/call-graph/extractors/regex/java-regex.js +327 -0
  89. package/dist/call-graph/extractors/regex/java-regex.js.map +1 -0
  90. package/dist/call-graph/extractors/regex/php-regex.d.ts +30 -0
  91. package/dist/call-graph/extractors/regex/php-regex.d.ts.map +1 -0
  92. package/dist/call-graph/extractors/regex/php-regex.js +333 -0
  93. package/dist/call-graph/extractors/regex/php-regex.js.map +1 -0
  94. package/dist/call-graph/extractors/regex/python-regex.d.ts +46 -0
  95. package/dist/call-graph/extractors/regex/python-regex.d.ts.map +1 -0
  96. package/dist/call-graph/extractors/regex/python-regex.js +380 -0
  97. package/dist/call-graph/extractors/regex/python-regex.js.map +1 -0
  98. package/dist/call-graph/extractors/regex/typescript-regex.d.ts +27 -0
  99. package/dist/call-graph/extractors/regex/typescript-regex.d.ts.map +1 -0
  100. package/dist/call-graph/extractors/regex/typescript-regex.js +349 -0
  101. package/dist/call-graph/extractors/regex/typescript-regex.js.map +1 -0
  102. package/dist/call-graph/extractors/semantic-data-access-scanner.d.ts +7 -0
  103. package/dist/call-graph/extractors/semantic-data-access-scanner.d.ts.map +1 -1
  104. package/dist/call-graph/extractors/semantic-data-access-scanner.js +7 -0
  105. package/dist/call-graph/extractors/semantic-data-access-scanner.js.map +1 -1
  106. package/dist/call-graph/extractors/types.d.ts +111 -0
  107. package/dist/call-graph/extractors/types.d.ts.map +1 -0
  108. package/dist/call-graph/extractors/types.js +68 -0
  109. package/dist/call-graph/extractors/types.js.map +1 -0
  110. package/dist/call-graph/extractors/typescript-data-access-extractor.d.ts +8 -0
  111. package/dist/call-graph/extractors/typescript-data-access-extractor.d.ts.map +1 -1
  112. package/dist/call-graph/extractors/typescript-data-access-extractor.js +8 -0
  113. package/dist/call-graph/extractors/typescript-data-access-extractor.js.map +1 -1
  114. package/dist/call-graph/extractors/typescript-hybrid-extractor.d.ts +116 -0
  115. package/dist/call-graph/extractors/typescript-hybrid-extractor.d.ts.map +1 -0
  116. package/dist/call-graph/extractors/typescript-hybrid-extractor.js +635 -0
  117. package/dist/call-graph/extractors/typescript-hybrid-extractor.js.map +1 -0
  118. package/dist/call-graph/index.d.ts +3 -0
  119. package/dist/call-graph/index.d.ts.map +1 -1
  120. package/dist/call-graph/index.js +5 -0
  121. package/dist/call-graph/index.js.map +1 -1
  122. package/dist/call-graph/types.d.ts +1 -1
  123. package/dist/call-graph/types.d.ts.map +1 -1
  124. package/dist/constraints/extraction/constraint-synthesizer.d.ts +72 -0
  125. package/dist/constraints/extraction/constraint-synthesizer.d.ts.map +1 -0
  126. package/dist/constraints/extraction/constraint-synthesizer.js +336 -0
  127. package/dist/constraints/extraction/constraint-synthesizer.js.map +1 -0
  128. package/dist/constraints/extraction/index.d.ts +10 -0
  129. package/dist/constraints/extraction/index.d.ts.map +1 -0
  130. package/dist/constraints/extraction/index.js +10 -0
  131. package/dist/constraints/extraction/index.js.map +1 -0
  132. package/dist/constraints/extraction/invariant-detector.d.ts +109 -0
  133. package/dist/constraints/extraction/invariant-detector.d.ts.map +1 -0
  134. package/dist/constraints/extraction/invariant-detector.js +979 -0
  135. package/dist/constraints/extraction/invariant-detector.js.map +1 -0
  136. package/dist/constraints/index.d.ts +15 -0
  137. package/dist/constraints/index.d.ts.map +1 -0
  138. package/dist/constraints/index.js +16 -0
  139. package/dist/constraints/index.js.map +1 -0
  140. package/dist/constraints/store/constraint-store.d.ts +110 -0
  141. package/dist/constraints/store/constraint-store.d.ts.map +1 -0
  142. package/dist/constraints/store/constraint-store.js +584 -0
  143. package/dist/constraints/store/constraint-store.js.map +1 -0
  144. package/dist/constraints/types.d.ts +605 -0
  145. package/dist/constraints/types.d.ts.map +1 -0
  146. package/dist/constraints/types.js +57 -0
  147. package/dist/constraints/types.js.map +1 -0
  148. package/dist/constraints/verification/constraint-verifier.d.ts +100 -0
  149. package/dist/constraints/verification/constraint-verifier.d.ts.map +1 -0
  150. package/dist/constraints/verification/constraint-verifier.js +638 -0
  151. package/dist/constraints/verification/constraint-verifier.js.map +1 -0
  152. package/dist/constraints/verification/index.d.ts +8 -0
  153. package/dist/constraints/verification/index.d.ts.map +1 -0
  154. package/dist/constraints/verification/index.js +8 -0
  155. package/dist/constraints/verification/index.js.map +1 -0
  156. package/dist/decisions/analyzer/decision-mining-analyzer.d.ts +121 -0
  157. package/dist/decisions/analyzer/decision-mining-analyzer.d.ts.map +1 -0
  158. package/dist/decisions/analyzer/decision-mining-analyzer.js +904 -0
  159. package/dist/decisions/analyzer/decision-mining-analyzer.js.map +1 -0
  160. package/dist/decisions/analyzer/index.d.ts +5 -0
  161. package/dist/decisions/analyzer/index.d.ts.map +1 -0
  162. package/dist/decisions/analyzer/index.js +5 -0
  163. package/dist/decisions/analyzer/index.js.map +1 -0
  164. package/dist/decisions/extractors/base-commit-extractor.d.ts +104 -0
  165. package/dist/decisions/extractors/base-commit-extractor.d.ts.map +1 -0
  166. package/dist/decisions/extractors/base-commit-extractor.js +305 -0
  167. package/dist/decisions/extractors/base-commit-extractor.js.map +1 -0
  168. package/dist/decisions/extractors/csharp-commit-extractor.d.ts +18 -0
  169. package/dist/decisions/extractors/csharp-commit-extractor.d.ts.map +1 -0
  170. package/dist/decisions/extractors/csharp-commit-extractor.js +281 -0
  171. package/dist/decisions/extractors/csharp-commit-extractor.js.map +1 -0
  172. package/dist/decisions/extractors/index.d.ts +31 -0
  173. package/dist/decisions/extractors/index.d.ts.map +1 -0
  174. package/dist/decisions/extractors/index.js +63 -0
  175. package/dist/decisions/extractors/index.js.map +1 -0
  176. package/dist/decisions/extractors/java-commit-extractor.d.ts +18 -0
  177. package/dist/decisions/extractors/java-commit-extractor.d.ts.map +1 -0
  178. package/dist/decisions/extractors/java-commit-extractor.js +248 -0
  179. package/dist/decisions/extractors/java-commit-extractor.js.map +1 -0
  180. package/dist/decisions/extractors/php-commit-extractor.d.ts +18 -0
  181. package/dist/decisions/extractors/php-commit-extractor.d.ts.map +1 -0
  182. package/dist/decisions/extractors/php-commit-extractor.js +280 -0
  183. package/dist/decisions/extractors/php-commit-extractor.js.map +1 -0
  184. package/dist/decisions/extractors/python-commit-extractor.d.ts +18 -0
  185. package/dist/decisions/extractors/python-commit-extractor.d.ts.map +1 -0
  186. package/dist/decisions/extractors/python-commit-extractor.js +248 -0
  187. package/dist/decisions/extractors/python-commit-extractor.js.map +1 -0
  188. package/dist/decisions/extractors/typescript-commit-extractor.d.ts +37 -0
  189. package/dist/decisions/extractors/typescript-commit-extractor.d.ts.map +1 -0
  190. package/dist/decisions/extractors/typescript-commit-extractor.js +229 -0
  191. package/dist/decisions/extractors/typescript-commit-extractor.js.map +1 -0
  192. package/dist/decisions/git/commit-parser.d.ts +58 -0
  193. package/dist/decisions/git/commit-parser.d.ts.map +1 -0
  194. package/dist/decisions/git/commit-parser.js +344 -0
  195. package/dist/decisions/git/commit-parser.js.map +1 -0
  196. package/dist/decisions/git/diff-analyzer.d.ts +30 -0
  197. package/dist/decisions/git/diff-analyzer.d.ts.map +1 -0
  198. package/dist/decisions/git/diff-analyzer.js +492 -0
  199. package/dist/decisions/git/diff-analyzer.js.map +1 -0
  200. package/dist/decisions/git/git-walker.d.ts +64 -0
  201. package/dist/decisions/git/git-walker.d.ts.map +1 -0
  202. package/dist/decisions/git/git-walker.js +441 -0
  203. package/dist/decisions/git/git-walker.js.map +1 -0
  204. package/dist/decisions/git/index.d.ts +11 -0
  205. package/dist/decisions/git/index.d.ts.map +1 -0
  206. package/dist/decisions/git/index.js +13 -0
  207. package/dist/decisions/git/index.js.map +1 -0
  208. package/dist/decisions/git/types.d.ts +223 -0
  209. package/dist/decisions/git/types.d.ts.map +1 -0
  210. package/dist/decisions/git/types.js +7 -0
  211. package/dist/decisions/git/types.js.map +1 -0
  212. package/dist/decisions/index.d.ts +27 -0
  213. package/dist/decisions/index.d.ts.map +1 -0
  214. package/dist/decisions/index.js +45 -0
  215. package/dist/decisions/index.js.map +1 -0
  216. package/dist/decisions/types.d.ts +530 -0
  217. package/dist/decisions/types.d.ts.map +1 -0
  218. package/dist/decisions/types.js +8 -0
  219. package/dist/decisions/types.js.map +1 -0
  220. package/dist/error-handling/error-handling-analyzer.d.ts +73 -0
  221. package/dist/error-handling/error-handling-analyzer.d.ts.map +1 -0
  222. package/dist/error-handling/error-handling-analyzer.js +706 -0
  223. package/dist/error-handling/error-handling-analyzer.js.map +1 -0
  224. package/dist/error-handling/index.d.ts +8 -0
  225. package/dist/error-handling/index.d.ts.map +1 -0
  226. package/dist/error-handling/index.js +8 -0
  227. package/dist/error-handling/index.js.map +1 -0
  228. package/dist/error-handling/types.d.ts +307 -0
  229. package/dist/error-handling/types.d.ts.map +1 -0
  230. package/dist/error-handling/types.js +7 -0
  231. package/dist/error-handling/types.js.map +1 -0
  232. package/dist/go/go-analyzer.d.ts +203 -0
  233. package/dist/go/go-analyzer.d.ts.map +1 -0
  234. package/dist/go/go-analyzer.js +509 -0
  235. package/dist/go/go-analyzer.js.map +1 -0
  236. package/dist/go/index.d.ts +7 -0
  237. package/dist/go/index.d.ts.map +1 -0
  238. package/dist/go/index.js +8 -0
  239. package/dist/go/index.js.map +1 -0
  240. package/dist/index.d.ts +25 -0
  241. package/dist/index.d.ts.map +1 -1
  242. package/dist/index.js +85 -0
  243. package/dist/index.js.map +1 -1
  244. package/dist/lake/pattern-shard-store.d.ts +6 -0
  245. package/dist/lake/pattern-shard-store.d.ts.map +1 -1
  246. package/dist/lake/pattern-shard-store.js +6 -0
  247. package/dist/lake/pattern-shard-store.js.map +1 -1
  248. package/dist/module-coupling/coupling-analyzer.d.ts +73 -0
  249. package/dist/module-coupling/coupling-analyzer.d.ts.map +1 -0
  250. package/dist/module-coupling/coupling-analyzer.js +668 -0
  251. package/dist/module-coupling/coupling-analyzer.js.map +1 -0
  252. package/dist/module-coupling/index.d.ts +9 -0
  253. package/dist/module-coupling/index.d.ts.map +1 -0
  254. package/dist/module-coupling/index.js +9 -0
  255. package/dist/module-coupling/index.js.map +1 -0
  256. package/dist/module-coupling/types.d.ts +273 -0
  257. package/dist/module-coupling/types.d.ts.map +1 -0
  258. package/dist/module-coupling/types.js +8 -0
  259. package/dist/module-coupling/types.js.map +1 -0
  260. package/dist/parsers/tree-sitter/go-loader.d.ts +50 -0
  261. package/dist/parsers/tree-sitter/go-loader.d.ts.map +1 -0
  262. package/dist/parsers/tree-sitter/go-loader.js +161 -0
  263. package/dist/parsers/tree-sitter/go-loader.js.map +1 -0
  264. package/dist/parsers/tree-sitter/tree-sitter-go-parser.d.ts +250 -0
  265. package/dist/parsers/tree-sitter/tree-sitter-go-parser.d.ts.map +1 -0
  266. package/dist/parsers/tree-sitter/tree-sitter-go-parser.js +707 -0
  267. package/dist/parsers/tree-sitter/tree-sitter-go-parser.js.map +1 -0
  268. package/dist/parsers/types.d.ts +1 -1
  269. package/dist/parsers/types.d.ts.map +1 -1
  270. package/dist/patterns/adapters/index.d.ts +11 -0
  271. package/dist/patterns/adapters/index.d.ts.map +1 -0
  272. package/dist/patterns/adapters/index.js +11 -0
  273. package/dist/patterns/adapters/index.js.map +1 -0
  274. package/dist/patterns/adapters/pattern-store-adapter.d.ts +59 -0
  275. package/dist/patterns/adapters/pattern-store-adapter.d.ts.map +1 -0
  276. package/dist/patterns/adapters/pattern-store-adapter.js +468 -0
  277. package/dist/patterns/adapters/pattern-store-adapter.js.map +1 -0
  278. package/dist/patterns/adapters/service-factory.d.ts +40 -0
  279. package/dist/patterns/adapters/service-factory.d.ts.map +1 -0
  280. package/dist/patterns/adapters/service-factory.js +144 -0
  281. package/dist/patterns/adapters/service-factory.js.map +1 -0
  282. package/dist/patterns/errors.d.ts +32 -0
  283. package/dist/patterns/errors.d.ts.map +1 -0
  284. package/dist/patterns/errors.js +45 -0
  285. package/dist/patterns/errors.js.map +1 -0
  286. package/dist/patterns/impl/cached-repository.d.ts +79 -0
  287. package/dist/patterns/impl/cached-repository.d.ts.map +1 -0
  288. package/dist/patterns/impl/cached-repository.js +296 -0
  289. package/dist/patterns/impl/cached-repository.js.map +1 -0
  290. package/dist/patterns/impl/file-repository.d.ts +75 -0
  291. package/dist/patterns/impl/file-repository.d.ts.map +1 -0
  292. package/dist/patterns/impl/file-repository.js +507 -0
  293. package/dist/patterns/impl/file-repository.js.map +1 -0
  294. package/dist/patterns/impl/index.d.ts +16 -0
  295. package/dist/patterns/impl/index.d.ts.map +1 -0
  296. package/dist/patterns/impl/index.js +21 -0
  297. package/dist/patterns/impl/index.js.map +1 -0
  298. package/dist/patterns/impl/memory-repository.d.ts +56 -0
  299. package/dist/patterns/impl/memory-repository.d.ts.map +1 -0
  300. package/dist/patterns/impl/memory-repository.js +323 -0
  301. package/dist/patterns/impl/memory-repository.js.map +1 -0
  302. package/dist/patterns/impl/pattern-service.d.ts +52 -0
  303. package/dist/patterns/impl/pattern-service.d.ts.map +1 -0
  304. package/dist/patterns/impl/pattern-service.js +382 -0
  305. package/dist/patterns/impl/pattern-service.js.map +1 -0
  306. package/dist/patterns/impl/repository-factory.d.ts +44 -0
  307. package/dist/patterns/impl/repository-factory.d.ts.map +1 -0
  308. package/dist/patterns/impl/repository-factory.js +140 -0
  309. package/dist/patterns/impl/repository-factory.js.map +1 -0
  310. package/dist/patterns/impl/unified-file-repository.d.ts +111 -0
  311. package/dist/patterns/impl/unified-file-repository.d.ts.map +1 -0
  312. package/dist/patterns/impl/unified-file-repository.js +677 -0
  313. package/dist/patterns/impl/unified-file-repository.js.map +1 -0
  314. package/dist/patterns/index.d.ts +23 -0
  315. package/dist/patterns/index.d.ts.map +1 -0
  316. package/dist/patterns/index.js +41 -0
  317. package/dist/patterns/index.js.map +1 -0
  318. package/dist/patterns/repository.d.ts +241 -0
  319. package/dist/patterns/repository.d.ts.map +1 -0
  320. package/dist/patterns/repository.js +23 -0
  321. package/dist/patterns/repository.js.map +1 -0
  322. package/dist/patterns/service.d.ts +245 -0
  323. package/dist/patterns/service.d.ts.map +1 -0
  324. package/dist/patterns/service.js +25 -0
  325. package/dist/patterns/service.js.map +1 -0
  326. package/dist/patterns/types.d.ts +227 -0
  327. package/dist/patterns/types.d.ts.map +1 -0
  328. package/dist/patterns/types.js +117 -0
  329. package/dist/patterns/types.js.map +1 -0
  330. package/dist/simulation/approach-generator.d.ts +73 -0
  331. package/dist/simulation/approach-generator.d.ts.map +1 -0
  332. package/dist/simulation/approach-generator.js +371 -0
  333. package/dist/simulation/approach-generator.js.map +1 -0
  334. package/dist/simulation/index.d.ts +14 -0
  335. package/dist/simulation/index.d.ts.map +1 -0
  336. package/dist/simulation/index.js +19 -0
  337. package/dist/simulation/index.js.map +1 -0
  338. package/dist/simulation/language-strategies/csharp-strategies.d.ts +17 -0
  339. package/dist/simulation/language-strategies/csharp-strategies.d.ts.map +1 -0
  340. package/dist/simulation/language-strategies/csharp-strategies.js +118 -0
  341. package/dist/simulation/language-strategies/csharp-strategies.js.map +1 -0
  342. package/dist/simulation/language-strategies/index.d.ts +41 -0
  343. package/dist/simulation/language-strategies/index.d.ts.map +1 -0
  344. package/dist/simulation/language-strategies/index.js +92 -0
  345. package/dist/simulation/language-strategies/index.js.map +1 -0
  346. package/dist/simulation/language-strategies/java-strategies.d.ts +17 -0
  347. package/dist/simulation/language-strategies/java-strategies.d.ts.map +1 -0
  348. package/dist/simulation/language-strategies/java-strategies.js +119 -0
  349. package/dist/simulation/language-strategies/java-strategies.js.map +1 -0
  350. package/dist/simulation/language-strategies/php-strategies.d.ts +17 -0
  351. package/dist/simulation/language-strategies/php-strategies.d.ts.map +1 -0
  352. package/dist/simulation/language-strategies/php-strategies.js +129 -0
  353. package/dist/simulation/language-strategies/php-strategies.js.map +1 -0
  354. package/dist/simulation/language-strategies/python-strategies.d.ts +17 -0
  355. package/dist/simulation/language-strategies/python-strategies.d.ts.map +1 -0
  356. package/dist/simulation/language-strategies/python-strategies.js +208 -0
  357. package/dist/simulation/language-strategies/python-strategies.js.map +1 -0
  358. package/dist/simulation/language-strategies/types.d.ts +67 -0
  359. package/dist/simulation/language-strategies/types.d.ts.map +1 -0
  360. package/dist/simulation/language-strategies/types.js +23 -0
  361. package/dist/simulation/language-strategies/types.js.map +1 -0
  362. package/dist/simulation/language-strategies/typescript-strategies.d.ts +17 -0
  363. package/dist/simulation/language-strategies/typescript-strategies.d.ts.map +1 -0
  364. package/dist/simulation/language-strategies/typescript-strategies.js +251 -0
  365. package/dist/simulation/language-strategies/typescript-strategies.js.map +1 -0
  366. package/dist/simulation/scorers/friction-scorer.d.ts +45 -0
  367. package/dist/simulation/scorers/friction-scorer.d.ts.map +1 -0
  368. package/dist/simulation/scorers/friction-scorer.js +336 -0
  369. package/dist/simulation/scorers/friction-scorer.js.map +1 -0
  370. package/dist/simulation/scorers/impact-scorer.d.ts +56 -0
  371. package/dist/simulation/scorers/impact-scorer.d.ts.map +1 -0
  372. package/dist/simulation/scorers/impact-scorer.js +273 -0
  373. package/dist/simulation/scorers/impact-scorer.js.map +1 -0
  374. package/dist/simulation/scorers/index.d.ts +12 -0
  375. package/dist/simulation/scorers/index.d.ts.map +1 -0
  376. package/dist/simulation/scorers/index.js +12 -0
  377. package/dist/simulation/scorers/index.js.map +1 -0
  378. package/dist/simulation/scorers/pattern-alignment-scorer.d.ts +83 -0
  379. package/dist/simulation/scorers/pattern-alignment-scorer.d.ts.map +1 -0
  380. package/dist/simulation/scorers/pattern-alignment-scorer.js +367 -0
  381. package/dist/simulation/scorers/pattern-alignment-scorer.js.map +1 -0
  382. package/dist/simulation/scorers/security-scorer.d.ts +63 -0
  383. package/dist/simulation/scorers/security-scorer.d.ts.map +1 -0
  384. package/dist/simulation/scorers/security-scorer.js +346 -0
  385. package/dist/simulation/scorers/security-scorer.js.map +1 -0
  386. package/dist/simulation/simulation-engine.d.ts +89 -0
  387. package/dist/simulation/simulation-engine.d.ts.map +1 -0
  388. package/dist/simulation/simulation-engine.js +480 -0
  389. package/dist/simulation/simulation-engine.js.map +1 -0
  390. package/dist/simulation/types.d.ts +200 -0
  391. package/dist/simulation/types.d.ts.map +1 -0
  392. package/dist/simulation/types.js +23 -0
  393. package/dist/simulation/types.js.map +1 -0
  394. package/dist/speculative/approach-generator.d.ts +2 -0
  395. package/dist/speculative/approach-generator.d.ts.map +1 -0
  396. package/dist/speculative/approach-generator.js +2 -0
  397. package/dist/speculative/approach-generator.js.map +1 -0
  398. package/dist/speculative/templates/types.d.ts +133 -0
  399. package/dist/speculative/templates/types.d.ts.map +1 -0
  400. package/dist/speculative/templates/types.js +208 -0
  401. package/dist/speculative/templates/types.js.map +1 -0
  402. package/dist/speculative/types.d.ts +523 -0
  403. package/dist/speculative/types.d.ts.map +1 -0
  404. package/dist/speculative/types.js +71 -0
  405. package/dist/speculative/types.js.map +1 -0
  406. package/dist/store/pattern-store.d.ts +6 -0
  407. package/dist/store/pattern-store.d.ts.map +1 -1
  408. package/dist/store/pattern-store.js +6 -0
  409. package/dist/store/pattern-store.js.map +1 -1
  410. package/dist/test-topology/extractors/base-test-extractor.d.ts +89 -0
  411. package/dist/test-topology/extractors/base-test-extractor.d.ts.map +1 -0
  412. package/dist/test-topology/extractors/base-test-extractor.js +187 -0
  413. package/dist/test-topology/extractors/base-test-extractor.js.map +1 -0
  414. package/dist/test-topology/extractors/csharp-test-extractor.d.ts +23 -0
  415. package/dist/test-topology/extractors/csharp-test-extractor.d.ts.map +1 -0
  416. package/dist/test-topology/extractors/csharp-test-extractor.js +367 -0
  417. package/dist/test-topology/extractors/csharp-test-extractor.js.map +1 -0
  418. package/dist/test-topology/extractors/go-test-extractor.d.ts +33 -0
  419. package/dist/test-topology/extractors/go-test-extractor.d.ts.map +1 -0
  420. package/dist/test-topology/extractors/go-test-extractor.js +436 -0
  421. package/dist/test-topology/extractors/go-test-extractor.js.map +1 -0
  422. package/dist/test-topology/extractors/index.d.ts +13 -0
  423. package/dist/test-topology/extractors/index.d.ts.map +1 -0
  424. package/dist/test-topology/extractors/index.js +13 -0
  425. package/dist/test-topology/extractors/index.js.map +1 -0
  426. package/dist/test-topology/extractors/java-test-extractor.d.ts +20 -0
  427. package/dist/test-topology/extractors/java-test-extractor.d.ts.map +1 -0
  428. package/dist/test-topology/extractors/java-test-extractor.js +275 -0
  429. package/dist/test-topology/extractors/java-test-extractor.js.map +1 -0
  430. package/dist/test-topology/extractors/php-test-extractor.d.ts +24 -0
  431. package/dist/test-topology/extractors/php-test-extractor.d.ts.map +1 -0
  432. package/dist/test-topology/extractors/php-test-extractor.js +409 -0
  433. package/dist/test-topology/extractors/php-test-extractor.js.map +1 -0
  434. package/dist/test-topology/extractors/python-test-extractor.d.ts +23 -0
  435. package/dist/test-topology/extractors/python-test-extractor.d.ts.map +1 -0
  436. package/dist/test-topology/extractors/python-test-extractor.js +342 -0
  437. package/dist/test-topology/extractors/python-test-extractor.js.map +1 -0
  438. package/dist/test-topology/extractors/regex/csharp-test-regex.d.ts +51 -0
  439. package/dist/test-topology/extractors/regex/csharp-test-regex.d.ts.map +1 -0
  440. package/dist/test-topology/extractors/regex/csharp-test-regex.js +383 -0
  441. package/dist/test-topology/extractors/regex/csharp-test-regex.js.map +1 -0
  442. package/dist/test-topology/extractors/regex/go-test-regex.d.ts +62 -0
  443. package/dist/test-topology/extractors/regex/go-test-regex.d.ts.map +1 -0
  444. package/dist/test-topology/extractors/regex/go-test-regex.js +528 -0
  445. package/dist/test-topology/extractors/regex/go-test-regex.js.map +1 -0
  446. package/dist/test-topology/extractors/regex/index.d.ts +19 -0
  447. package/dist/test-topology/extractors/regex/index.d.ts.map +1 -0
  448. package/dist/test-topology/extractors/regex/index.js +47 -0
  449. package/dist/test-topology/extractors/regex/index.js.map +1 -0
  450. package/dist/test-topology/extractors/regex/java-test-regex.d.ts +50 -0
  451. package/dist/test-topology/extractors/regex/java-test-regex.d.ts.map +1 -0
  452. package/dist/test-topology/extractors/regex/java-test-regex.js +370 -0
  453. package/dist/test-topology/extractors/regex/java-test-regex.js.map +1 -0
  454. package/dist/test-topology/extractors/regex/php-test-regex.d.ts +56 -0
  455. package/dist/test-topology/extractors/regex/php-test-regex.d.ts.map +1 -0
  456. package/dist/test-topology/extractors/regex/php-test-regex.js +503 -0
  457. package/dist/test-topology/extractors/regex/php-test-regex.js.map +1 -0
  458. package/dist/test-topology/extractors/regex/python-test-regex.d.ts +57 -0
  459. package/dist/test-topology/extractors/regex/python-test-regex.d.ts.map +1 -0
  460. package/dist/test-topology/extractors/regex/python-test-regex.js +381 -0
  461. package/dist/test-topology/extractors/regex/python-test-regex.js.map +1 -0
  462. package/dist/test-topology/extractors/regex/typescript-test-regex.d.ts +60 -0
  463. package/dist/test-topology/extractors/regex/typescript-test-regex.d.ts.map +1 -0
  464. package/dist/test-topology/extractors/regex/typescript-test-regex.js +368 -0
  465. package/dist/test-topology/extractors/regex/typescript-test-regex.js.map +1 -0
  466. package/dist/test-topology/extractors/typescript-test-extractor.d.ts +24 -0
  467. package/dist/test-topology/extractors/typescript-test-extractor.d.ts.map +1 -0
  468. package/dist/test-topology/extractors/typescript-test-extractor.js +266 -0
  469. package/dist/test-topology/extractors/typescript-test-extractor.js.map +1 -0
  470. package/dist/test-topology/hybrid-test-topology-analyzer.d.ts +98 -0
  471. package/dist/test-topology/hybrid-test-topology-analyzer.d.ts.map +1 -0
  472. package/dist/test-topology/hybrid-test-topology-analyzer.js +556 -0
  473. package/dist/test-topology/hybrid-test-topology-analyzer.js.map +1 -0
  474. package/dist/test-topology/index.d.ts +16 -0
  475. package/dist/test-topology/index.d.ts.map +1 -0
  476. package/dist/test-topology/index.js +19 -0
  477. package/dist/test-topology/index.js.map +1 -0
  478. package/dist/test-topology/test-topology-analyzer.d.ts +85 -0
  479. package/dist/test-topology/test-topology-analyzer.d.ts.map +1 -0
  480. package/dist/test-topology/test-topology-analyzer.js +539 -0
  481. package/dist/test-topology/test-topology-analyzer.js.map +1 -0
  482. package/dist/test-topology/types.d.ts +300 -0
  483. package/dist/test-topology/types.d.ts.map +1 -0
  484. package/dist/test-topology/types.js +7 -0
  485. package/dist/test-topology/types.js.map +1 -0
  486. package/dist/unified-provider/matching/database-sql-matcher.d.ts +42 -0
  487. package/dist/unified-provider/matching/database-sql-matcher.d.ts.map +1 -0
  488. package/dist/unified-provider/matching/database-sql-matcher.js +282 -0
  489. package/dist/unified-provider/matching/database-sql-matcher.js.map +1 -0
  490. package/dist/unified-provider/matching/gorm-matcher.d.ts +41 -0
  491. package/dist/unified-provider/matching/gorm-matcher.d.ts.map +1 -0
  492. package/dist/unified-provider/matching/gorm-matcher.js +222 -0
  493. package/dist/unified-provider/matching/gorm-matcher.js.map +1 -0
  494. package/dist/unified-provider/matching/index.d.ts +3 -0
  495. package/dist/unified-provider/matching/index.d.ts.map +1 -1
  496. package/dist/unified-provider/matching/index.js +4 -0
  497. package/dist/unified-provider/matching/index.js.map +1 -1
  498. package/dist/unified-provider/matching/matcher-registry.d.ts.map +1 -1
  499. package/dist/unified-provider/matching/matcher-registry.js +7 -0
  500. package/dist/unified-provider/matching/matcher-registry.js.map +1 -1
  501. package/dist/unified-provider/matching/sqlx-matcher.d.ts +40 -0
  502. package/dist/unified-provider/matching/sqlx-matcher.d.ts.map +1 -0
  503. package/dist/unified-provider/matching/sqlx-matcher.js +214 -0
  504. package/dist/unified-provider/matching/sqlx-matcher.js.map +1 -0
  505. package/dist/unified-provider/normalization/go-normalizer.d.ts +62 -0
  506. package/dist/unified-provider/normalization/go-normalizer.d.ts.map +1 -0
  507. package/dist/unified-provider/normalization/go-normalizer.js +608 -0
  508. package/dist/unified-provider/normalization/go-normalizer.js.map +1 -0
  509. package/dist/unified-provider/normalization/index.d.ts +1 -0
  510. package/dist/unified-provider/normalization/index.d.ts.map +1 -1
  511. package/dist/unified-provider/normalization/index.js +6 -1
  512. package/dist/unified-provider/normalization/index.js.map +1 -1
  513. package/dist/unified-provider/types.d.ts +1 -1
  514. package/dist/unified-provider/types.d.ts.map +1 -1
  515. package/dist/wpf/extractors/binding-error-detector.d.ts +75 -0
  516. package/dist/wpf/extractors/binding-error-detector.d.ts.map +1 -0
  517. package/dist/wpf/extractors/binding-error-detector.js +290 -0
  518. package/dist/wpf/extractors/binding-error-detector.js.map +1 -0
  519. package/dist/wpf/extractors/code-behind-linker.d.ts +70 -0
  520. package/dist/wpf/extractors/code-behind-linker.d.ts.map +1 -0
  521. package/dist/wpf/extractors/code-behind-linker.js +172 -0
  522. package/dist/wpf/extractors/code-behind-linker.js.map +1 -0
  523. package/dist/wpf/extractors/dependency-property-extractor.d.ts +61 -0
  524. package/dist/wpf/extractors/dependency-property-extractor.d.ts.map +1 -0
  525. package/dist/wpf/extractors/dependency-property-extractor.js +201 -0
  526. package/dist/wpf/extractors/dependency-property-extractor.js.map +1 -0
  527. package/dist/wpf/extractors/regex/viewmodel-regex.d.ts +82 -0
  528. package/dist/wpf/extractors/regex/viewmodel-regex.d.ts.map +1 -0
  529. package/dist/wpf/extractors/regex/viewmodel-regex.js +412 -0
  530. package/dist/wpf/extractors/regex/viewmodel-regex.js.map +1 -0
  531. package/dist/wpf/extractors/regex/xaml-regex.d.ts +77 -0
  532. package/dist/wpf/extractors/regex/xaml-regex.d.ts.map +1 -0
  533. package/dist/wpf/extractors/regex/xaml-regex.js +353 -0
  534. package/dist/wpf/extractors/regex/xaml-regex.js.map +1 -0
  535. package/dist/wpf/extractors/resource-dictionary-parser.d.ts +103 -0
  536. package/dist/wpf/extractors/resource-dictionary-parser.d.ts.map +1 -0
  537. package/dist/wpf/extractors/resource-dictionary-parser.js +296 -0
  538. package/dist/wpf/extractors/resource-dictionary-parser.js.map +1 -0
  539. package/dist/wpf/extractors/value-converter-extractor.d.ts +128 -0
  540. package/dist/wpf/extractors/value-converter-extractor.d.ts.map +1 -0
  541. package/dist/wpf/extractors/value-converter-extractor.js +312 -0
  542. package/dist/wpf/extractors/value-converter-extractor.js.map +1 -0
  543. package/dist/wpf/extractors/viewmodel-hybrid-extractor.d.ts +104 -0
  544. package/dist/wpf/extractors/viewmodel-hybrid-extractor.d.ts.map +1 -0
  545. package/dist/wpf/extractors/viewmodel-hybrid-extractor.js +513 -0
  546. package/dist/wpf/extractors/viewmodel-hybrid-extractor.js.map +1 -0
  547. package/dist/wpf/extractors/xaml-hybrid-extractor.d.ts +98 -0
  548. package/dist/wpf/extractors/xaml-hybrid-extractor.d.ts.map +1 -0
  549. package/dist/wpf/extractors/xaml-hybrid-extractor.js +444 -0
  550. package/dist/wpf/extractors/xaml-hybrid-extractor.js.map +1 -0
  551. package/dist/wpf/index.d.ts +25 -0
  552. package/dist/wpf/index.d.ts.map +1 -0
  553. package/dist/wpf/index.js +31 -0
  554. package/dist/wpf/index.js.map +1 -0
  555. package/dist/wpf/integration/wpf-callgraph-adapter.d.ts +82 -0
  556. package/dist/wpf/integration/wpf-callgraph-adapter.d.ts.map +1 -0
  557. package/dist/wpf/integration/wpf-callgraph-adapter.js +311 -0
  558. package/dist/wpf/integration/wpf-callgraph-adapter.js.map +1 -0
  559. package/dist/wpf/integration/wpf-data-flow-tracer.d.ts +129 -0
  560. package/dist/wpf/integration/wpf-data-flow-tracer.d.ts.map +1 -0
  561. package/dist/wpf/integration/wpf-data-flow-tracer.js +367 -0
  562. package/dist/wpf/integration/wpf-data-flow-tracer.js.map +1 -0
  563. package/dist/wpf/linkers/datacontext-resolver.d.ts +66 -0
  564. package/dist/wpf/linkers/datacontext-resolver.d.ts.map +1 -0
  565. package/dist/wpf/linkers/datacontext-resolver.js +240 -0
  566. package/dist/wpf/linkers/datacontext-resolver.js.map +1 -0
  567. package/dist/wpf/linkers/viewmodel-linker.d.ts +71 -0
  568. package/dist/wpf/linkers/viewmodel-linker.d.ts.map +1 -0
  569. package/dist/wpf/linkers/viewmodel-linker.js +268 -0
  570. package/dist/wpf/linkers/viewmodel-linker.js.map +1 -0
  571. package/dist/wpf/types.d.ts +451 -0
  572. package/dist/wpf/types.d.ts.map +1 -0
  573. package/dist/wpf/types.js +8 -0
  574. package/dist/wpf/types.js.map +1 -0
  575. package/dist/wpf/wpf-analyzer.d.ts +114 -0
  576. package/dist/wpf/wpf-analyzer.d.ts.map +1 -0
  577. package/dist/wpf/wpf-analyzer.js +332 -0
  578. package/dist/wpf/wpf-analyzer.js.map +1 -0
  579. package/dist/wrappers/clustering/clusterer.d.ts +43 -0
  580. package/dist/wrappers/clustering/clusterer.d.ts.map +1 -0
  581. package/dist/wrappers/clustering/clusterer.js +374 -0
  582. package/dist/wrappers/clustering/clusterer.js.map +1 -0
  583. package/dist/wrappers/clustering/exclusions.d.ts +47 -0
  584. package/dist/wrappers/clustering/exclusions.d.ts.map +1 -0
  585. package/dist/wrappers/clustering/exclusions.js +318 -0
  586. package/dist/wrappers/clustering/exclusions.js.map +1 -0
  587. package/dist/wrappers/clustering/index.d.ts +6 -0
  588. package/dist/wrappers/clustering/index.d.ts.map +1 -0
  589. package/dist/wrappers/clustering/index.js +6 -0
  590. package/dist/wrappers/clustering/index.js.map +1 -0
  591. package/dist/wrappers/detection/detector.d.ts +69 -0
  592. package/dist/wrappers/detection/detector.d.ts.map +1 -0
  593. package/dist/wrappers/detection/detector.js +279 -0
  594. package/dist/wrappers/detection/detector.js.map +1 -0
  595. package/dist/wrappers/detection/index.d.ts +5 -0
  596. package/dist/wrappers/detection/index.d.ts.map +1 -0
  597. package/dist/wrappers/detection/index.js +5 -0
  598. package/dist/wrappers/detection/index.js.map +1 -0
  599. package/dist/wrappers/export/index.d.ts +5 -0
  600. package/dist/wrappers/export/index.d.ts.map +1 -0
  601. package/dist/wrappers/export/index.js +5 -0
  602. package/dist/wrappers/export/index.js.map +1 -0
  603. package/dist/wrappers/export/json.d.ts +127 -0
  604. package/dist/wrappers/export/json.d.ts.map +1 -0
  605. package/dist/wrappers/export/json.js +160 -0
  606. package/dist/wrappers/export/json.js.map +1 -0
  607. package/dist/wrappers/index.d.ts +56 -0
  608. package/dist/wrappers/index.d.ts.map +1 -0
  609. package/dist/wrappers/index.js +159 -0
  610. package/dist/wrappers/index.js.map +1 -0
  611. package/dist/wrappers/integration/adapter.d.ts +52 -0
  612. package/dist/wrappers/integration/adapter.d.ts.map +1 -0
  613. package/dist/wrappers/integration/adapter.js +210 -0
  614. package/dist/wrappers/integration/adapter.js.map +1 -0
  615. package/dist/wrappers/integration/index.d.ts +9 -0
  616. package/dist/wrappers/integration/index.d.ts.map +1 -0
  617. package/dist/wrappers/integration/index.js +12 -0
  618. package/dist/wrappers/integration/index.js.map +1 -0
  619. package/dist/wrappers/integration/pattern-adapter.d.ts +52 -0
  620. package/dist/wrappers/integration/pattern-adapter.d.ts.map +1 -0
  621. package/dist/wrappers/integration/pattern-adapter.js +192 -0
  622. package/dist/wrappers/integration/pattern-adapter.js.map +1 -0
  623. package/dist/wrappers/integration/scanner.d.ts +85 -0
  624. package/dist/wrappers/integration/scanner.d.ts.map +1 -0
  625. package/dist/wrappers/integration/scanner.js +367 -0
  626. package/dist/wrappers/integration/scanner.js.map +1 -0
  627. package/dist/wrappers/primitives/discovery.d.ts +57 -0
  628. package/dist/wrappers/primitives/discovery.d.ts.map +1 -0
  629. package/dist/wrappers/primitives/discovery.js +389 -0
  630. package/dist/wrappers/primitives/discovery.js.map +1 -0
  631. package/dist/wrappers/primitives/index.d.ts +6 -0
  632. package/dist/wrappers/primitives/index.d.ts.map +1 -0
  633. package/dist/wrappers/primitives/index.js +6 -0
  634. package/dist/wrappers/primitives/index.js.map +1 -0
  635. package/dist/wrappers/primitives/registry.d.ts +63 -0
  636. package/dist/wrappers/primitives/registry.d.ts.map +1 -0
  637. package/dist/wrappers/primitives/registry.js +447 -0
  638. package/dist/wrappers/primitives/registry.js.map +1 -0
  639. package/dist/wrappers/types.d.ts +137 -0
  640. package/dist/wrappers/types.d.ts.map +1 -0
  641. package/dist/wrappers/types.js +7 -0
  642. package/dist/wrappers/types.js.map +1 -0
  643. package/package.json +33 -18
  644. package/LICENSE +0 -21
@@ -0,0 +1,706 @@
1
+ /**
2
+ * Error Handling Analyzer
3
+ *
4
+ * Analyzes error handling patterns, boundaries, and propagation chains.
5
+ * Detects gaps in error handling coverage.
6
+ */
7
+ // ============================================================================
8
+ // Analyzer
9
+ // ============================================================================
10
+ export class ErrorHandlingAnalyzer {
11
+ topology = null;
12
+ callGraph = null;
13
+ options;
14
+ constructor(options) {
15
+ this.options = {
16
+ includeAsync: true,
17
+ detectFrameworkBoundaries: true,
18
+ maxPropagationDepth: 20,
19
+ ...options,
20
+ };
21
+ }
22
+ /**
23
+ * Set the call graph for analysis
24
+ */
25
+ setCallGraph(callGraph) {
26
+ this.callGraph = callGraph;
27
+ }
28
+ /**
29
+ * Build the error handling topology
30
+ */
31
+ build() {
32
+ if (!this.callGraph) {
33
+ throw new Error('Call graph required. Call setCallGraph() first.');
34
+ }
35
+ const functions = new Map();
36
+ const boundaries = [];
37
+ const propagationChains = [];
38
+ // Phase 1: Analyze each function's error handling
39
+ for (const [funcId, func] of this.callGraph.functions) {
40
+ const profile = this.analyzeFunction(funcId, func);
41
+ functions.set(funcId, profile);
42
+ // Detect boundaries
43
+ if (profile.hasTryCatch && profile.catchClauses.length > 0) {
44
+ const boundary = this.detectBoundary(funcId, func, profile);
45
+ if (boundary) {
46
+ boundaries.push(boundary);
47
+ }
48
+ }
49
+ }
50
+ // Phase 2: Build propagation chains for throwing functions
51
+ for (const [funcId, profile] of functions) {
52
+ if (profile.canThrow) {
53
+ const chain = this.traceErrorPropagation(funcId, functions);
54
+ if (chain) {
55
+ propagationChains.push(chain);
56
+ }
57
+ }
58
+ }
59
+ // Phase 3: Find unhandled paths
60
+ const unhandledPaths = this.findUnhandledPaths(propagationChains, functions);
61
+ this.topology = {
62
+ functions,
63
+ boundaries,
64
+ unhandledPaths,
65
+ propagationChains,
66
+ generatedAt: new Date().toISOString(),
67
+ projectRoot: this.options.rootDir,
68
+ };
69
+ return this.topology;
70
+ }
71
+ /**
72
+ * Get the built topology
73
+ */
74
+ getTopology() {
75
+ return this.topology;
76
+ }
77
+ /**
78
+ * Get aggregate metrics
79
+ */
80
+ getMetrics() {
81
+ if (!this.topology)
82
+ return null;
83
+ const functions = Array.from(this.topology.functions.values());
84
+ const totalFunctions = functions.length;
85
+ const functionsWithTryCatch = functions.filter(f => f.hasTryCatch).length;
86
+ const functionsThatThrow = functions.filter(f => f.canThrow).length;
87
+ const swallowedErrorCount = functions.filter(f => f.catchClauses.some(c => c.action === 'swallow')).length;
88
+ const unhandledAsyncCount = functions.filter(f => f.asyncHandling?.hasUnhandledPromises).length;
89
+ const avgQualityScore = totalFunctions > 0
90
+ ? Math.round(functions.reduce((sum, f) => sum + f.qualityScore, 0) / totalFunctions)
91
+ : 0;
92
+ const unhandledBySeverity = {
93
+ critical: 0,
94
+ high: 0,
95
+ medium: 0,
96
+ low: 0,
97
+ };
98
+ for (const path of this.topology.unhandledPaths) {
99
+ unhandledBySeverity[path.severity]++;
100
+ }
101
+ const frameworkBoundaries = this.topology.boundaries.filter(b => b.isFrameworkBoundary).length;
102
+ return {
103
+ totalFunctions,
104
+ functionsWithTryCatch,
105
+ functionsThatThrow,
106
+ boundaryCount: this.topology.boundaries.length,
107
+ unhandledCount: this.topology.unhandledPaths.length,
108
+ unhandledBySeverity,
109
+ avgQualityScore,
110
+ swallowedErrorCount,
111
+ unhandledAsyncCount,
112
+ frameworkBoundaries,
113
+ };
114
+ }
115
+ /**
116
+ * Get summary for display
117
+ */
118
+ getSummary() {
119
+ const metrics = this.getMetrics();
120
+ if (!metrics || !this.topology)
121
+ return null;
122
+ const coveragePercent = metrics.totalFunctions > 0
123
+ ? Math.round((metrics.functionsWithTryCatch / metrics.totalFunctions) * 100)
124
+ : 0;
125
+ const qualityDistribution = {
126
+ excellent: 0,
127
+ good: 0,
128
+ fair: 0,
129
+ poor: 0,
130
+ };
131
+ for (const func of this.topology.functions.values()) {
132
+ const quality = this.scoreToQuality(func.qualityScore);
133
+ qualityDistribution[quality]++;
134
+ }
135
+ const topIssues = [];
136
+ if (metrics.swallowedErrorCount > 0) {
137
+ topIssues.push({
138
+ type: 'swallowed',
139
+ count: metrics.swallowedErrorCount,
140
+ severity: 'high',
141
+ });
142
+ }
143
+ if (metrics.unhandledAsyncCount > 0) {
144
+ topIssues.push({
145
+ type: 'unhandled-async',
146
+ count: metrics.unhandledAsyncCount,
147
+ severity: 'high',
148
+ });
149
+ }
150
+ if (metrics.unhandledBySeverity.critical > 0) {
151
+ topIssues.push({
152
+ type: 'no-boundary',
153
+ count: metrics.unhandledBySeverity.critical,
154
+ severity: 'critical',
155
+ });
156
+ }
157
+ // Sort by severity
158
+ const severityOrder = { critical: 0, high: 1, medium: 2, low: 3 };
159
+ topIssues.sort((a, b) => severityOrder[a.severity] - severityOrder[b.severity]);
160
+ return {
161
+ totalFunctions: metrics.totalFunctions,
162
+ coveragePercent,
163
+ unhandledPaths: metrics.unhandledCount,
164
+ criticalUnhandled: metrics.unhandledBySeverity.critical,
165
+ avgQuality: metrics.avgQualityScore,
166
+ qualityDistribution,
167
+ topIssues: topIssues.slice(0, 5),
168
+ };
169
+ }
170
+ /**
171
+ * Analyze a specific function
172
+ */
173
+ analyzeFunction(funcId, func) {
174
+ const funcNode = func ?? this.callGraph?.functions.get(funcId);
175
+ if (!funcNode) {
176
+ throw new Error(`Function not found: ${funcId}`);
177
+ }
178
+ // Detect error handling constructs from function metadata
179
+ const hasTryCatch = this.detectTryCatch(funcNode);
180
+ const canThrow = this.detectThrows(funcNode);
181
+ const throwLocations = this.findThrowLocations(funcNode);
182
+ const catchClauses = this.extractCatchClauses(funcNode);
183
+ const rethrows = catchClauses.some(c => c.action === 'rethrow');
184
+ const isAsync = this.isAsyncFunction(funcNode);
185
+ const asyncHandling = isAsync && this.options.includeAsync
186
+ ? this.analyzeAsyncHandling(funcNode)
187
+ : null;
188
+ const qualityScore = this.calculateQualityScore({
189
+ hasTryCatch,
190
+ canThrow,
191
+ catchClauses,
192
+ rethrows,
193
+ asyncHandling,
194
+ isAsync,
195
+ });
196
+ return {
197
+ functionId: funcId,
198
+ file: funcNode.file,
199
+ name: funcNode.name,
200
+ qualifiedName: funcNode.className
201
+ ? `${funcNode.className}.${funcNode.name}`
202
+ : funcNode.name,
203
+ line: funcNode.startLine,
204
+ hasTryCatch,
205
+ canThrow,
206
+ throwLocations,
207
+ catchClauses,
208
+ rethrows,
209
+ asyncHandling,
210
+ isAsync,
211
+ qualityScore,
212
+ };
213
+ }
214
+ /**
215
+ * Get detailed analysis for a function
216
+ */
217
+ getFunctionAnalysis(funcId) {
218
+ if (!this.topology || !this.callGraph)
219
+ return null;
220
+ const profile = this.topology.functions.get(funcId);
221
+ if (!profile)
222
+ return null;
223
+ const func = this.callGraph.functions.get(funcId);
224
+ if (!func)
225
+ return null;
226
+ // Find incoming errors (from callees)
227
+ const incomingErrors = [];
228
+ for (const call of func.calls) {
229
+ for (const candidate of call.resolvedCandidates) {
230
+ const calleeProfile = this.topology.functions.get(candidate);
231
+ if (calleeProfile?.canThrow) {
232
+ incomingErrors.push({
233
+ from: candidate,
234
+ errorType: 'Error', // Would need AST analysis for specific types
235
+ });
236
+ }
237
+ }
238
+ }
239
+ // Find outgoing errors (to callers)
240
+ const outgoingErrors = [];
241
+ for (const caller of func.calledBy) {
242
+ const callerProfile = this.topology.functions.get(caller.callerId);
243
+ outgoingErrors.push({
244
+ to: caller.callerId,
245
+ caught: callerProfile?.hasTryCatch ?? false,
246
+ });
247
+ }
248
+ // Check if protected by boundary
249
+ const foundBoundary = this.topology.boundaries.find(b => b.catchesFrom.includes(funcId));
250
+ // Find issues
251
+ const issues = [];
252
+ if (profile.canThrow && !profile.hasTryCatch && !foundBoundary) {
253
+ issues.push({
254
+ type: 'unprotected-throw',
255
+ message: 'Function throws but has no error handling',
256
+ severity: 'high',
257
+ });
258
+ }
259
+ if (profile.catchClauses.some(c => c.action === 'swallow')) {
260
+ const swallowLine = profile.catchClauses.find(c => c.action === 'swallow')?.line;
261
+ issues.push({
262
+ type: 'swallowed-error',
263
+ message: 'Error is caught but swallowed (empty catch block)',
264
+ severity: 'medium',
265
+ ...(swallowLine !== undefined && { line: swallowLine }),
266
+ });
267
+ }
268
+ if (profile.asyncHandling?.hasUnhandledPromises) {
269
+ issues.push({
270
+ type: 'unhandled-promise',
271
+ message: 'Async function has unhandled promise rejections',
272
+ severity: 'high',
273
+ });
274
+ }
275
+ if (profile.catchClauses.some(c => c.errorType === 'any')) {
276
+ issues.push({
277
+ type: 'bare-catch',
278
+ message: 'Catch clause catches all errors without type checking',
279
+ severity: 'low',
280
+ });
281
+ }
282
+ // Generate suggestions
283
+ const suggestions = [];
284
+ if (issues.some(i => i.type === 'unprotected-throw')) {
285
+ suggestions.push('Add try/catch block or ensure caller handles errors');
286
+ }
287
+ if (issues.some(i => i.type === 'swallowed-error')) {
288
+ suggestions.push('Log the error or rethrow it instead of swallowing');
289
+ }
290
+ if (issues.some(i => i.type === 'unhandled-promise')) {
291
+ suggestions.push('Add .catch() to promise chains or use try/catch with await');
292
+ }
293
+ const result = {
294
+ profile,
295
+ incomingErrors,
296
+ outgoingErrors,
297
+ isProtected: !!foundBoundary,
298
+ issues,
299
+ suggestions,
300
+ };
301
+ if (foundBoundary) {
302
+ result.protectingBoundary = foundBoundary;
303
+ }
304
+ return result;
305
+ }
306
+ /**
307
+ * Find error handling gaps
308
+ */
309
+ getGaps(options = {}) {
310
+ if (!this.topology)
311
+ return [];
312
+ const { minSeverity = 'low', limit = 20, includeSuggestions = true, files } = options;
313
+ const gaps = [];
314
+ const severityOrder = { critical: 0, high: 1, medium: 2, low: 3 };
315
+ const minOrder = severityOrder[minSeverity];
316
+ for (const [funcId, profile] of this.topology.functions) {
317
+ // Filter by files if specified
318
+ if (files && !files.some(f => profile.file.includes(f)))
319
+ continue;
320
+ // Check for various gaps
321
+ if (profile.canThrow && !profile.hasTryCatch) {
322
+ const severity = this.calculateGapSeverity(profile, 'no-try-catch');
323
+ if (severityOrder[severity] <= minOrder) {
324
+ gaps.push({
325
+ functionId: funcId,
326
+ file: profile.file,
327
+ name: profile.qualifiedName,
328
+ line: profile.line,
329
+ gapType: 'no-try-catch',
330
+ severity,
331
+ description: 'Function can throw but has no error handling',
332
+ suggestion: includeSuggestions
333
+ ? 'Add try/catch block to handle potential errors'
334
+ : '',
335
+ riskScore: this.calculateRiskScore(profile, 'no-try-catch'),
336
+ });
337
+ }
338
+ }
339
+ if (profile.catchClauses.some(c => c.action === 'swallow')) {
340
+ const severity = this.calculateGapSeverity(profile, 'swallowed-error');
341
+ if (severityOrder[severity] <= minOrder) {
342
+ gaps.push({
343
+ functionId: funcId,
344
+ file: profile.file,
345
+ name: profile.qualifiedName,
346
+ line: profile.catchClauses.find(c => c.action === 'swallow')?.line ?? profile.line,
347
+ gapType: 'swallowed-error',
348
+ severity,
349
+ description: 'Error is caught but not handled (empty catch block)',
350
+ suggestion: includeSuggestions
351
+ ? 'Log the error or rethrow it'
352
+ : '',
353
+ riskScore: this.calculateRiskScore(profile, 'swallowed-error'),
354
+ });
355
+ }
356
+ }
357
+ if (profile.asyncHandling?.hasUnhandledPromises) {
358
+ const severity = this.calculateGapSeverity(profile, 'unhandled-async');
359
+ if (severityOrder[severity] <= minOrder) {
360
+ gaps.push({
361
+ functionId: funcId,
362
+ file: profile.file,
363
+ name: profile.qualifiedName,
364
+ line: profile.asyncHandling.unhandledLocations[0]?.line ?? profile.line,
365
+ gapType: 'unhandled-async',
366
+ severity,
367
+ description: 'Async function has unhandled promise rejections',
368
+ suggestion: includeSuggestions
369
+ ? 'Add .catch() or wrap await in try/catch'
370
+ : '',
371
+ riskScore: this.calculateRiskScore(profile, 'unhandled-async'),
372
+ });
373
+ }
374
+ }
375
+ if (profile.catchClauses.some(c => c.errorType === 'any' && c.action !== 'rethrow')) {
376
+ const severity = 'low';
377
+ if (severityOrder[severity] <= minOrder) {
378
+ gaps.push({
379
+ functionId: funcId,
380
+ file: profile.file,
381
+ name: profile.qualifiedName,
382
+ line: profile.catchClauses.find(c => c.errorType === 'any')?.line ?? profile.line,
383
+ gapType: 'bare-catch',
384
+ severity,
385
+ description: 'Catch clause catches all errors without type checking',
386
+ suggestion: includeSuggestions
387
+ ? 'Consider catching specific error types'
388
+ : '',
389
+ riskScore: this.calculateRiskScore(profile, 'bare-catch'),
390
+ });
391
+ }
392
+ }
393
+ }
394
+ // Sort by risk score descending
395
+ gaps.sort((a, b) => b.riskScore - a.riskScore);
396
+ return gaps.slice(0, limit);
397
+ }
398
+ /**
399
+ * Get error boundaries
400
+ */
401
+ getBoundaries(options = {}) {
402
+ if (!this.topology)
403
+ return [];
404
+ let boundaries = this.topology.boundaries;
405
+ if (!options.includeFramework) {
406
+ boundaries = boundaries.filter(b => !b.isFrameworkBoundary);
407
+ }
408
+ if (options.minCoverage !== undefined) {
409
+ boundaries = boundaries.filter(b => b.coverage >= options.minCoverage);
410
+ }
411
+ return boundaries.sort((a, b) => b.coverage - a.coverage);
412
+ }
413
+ /**
414
+ * Get unhandled error paths
415
+ */
416
+ getUnhandledPaths(minSeverity = 'low') {
417
+ if (!this.topology)
418
+ return [];
419
+ const severityOrder = { critical: 0, high: 1, medium: 2, low: 3 };
420
+ const minOrder = severityOrder[minSeverity];
421
+ return this.topology.unhandledPaths
422
+ .filter(p => severityOrder[p.severity] <= minOrder)
423
+ .sort((a, b) => severityOrder[a.severity] - severityOrder[b.severity]);
424
+ }
425
+ // ============================================================================
426
+ // Private Helpers
427
+ // ============================================================================
428
+ detectTryCatch(func) {
429
+ // Heuristic: check if function body contains try/catch patterns
430
+ // In a full implementation, this would use AST analysis
431
+ // For now, we use metadata from the call graph if available
432
+ return func.hasTryCatch ?? false;
433
+ }
434
+ detectThrows(func) {
435
+ // Heuristic: check if function can throw
436
+ // Functions that call other throwing functions can also throw
437
+ return func.canThrow ??
438
+ func.calls.length > 0; // Conservative: assume any function with calls can throw
439
+ }
440
+ findThrowLocations(func) {
441
+ // Would need AST analysis for precise locations
442
+ return func.throwLocations ?? [];
443
+ }
444
+ extractCatchClauses(func) {
445
+ // Would need AST analysis for precise extraction
446
+ // Return empty for now - real implementation would parse AST
447
+ return func.catchClauses ?? [];
448
+ }
449
+ isAsyncFunction(func) {
450
+ if (func.isAsync)
451
+ return true;
452
+ if (func.name.includes('async'))
453
+ return true;
454
+ return func.returnType?.includes('Promise') ?? false;
455
+ }
456
+ analyzeAsyncHandling(_func) {
457
+ // Would need AST analysis for precise detection
458
+ return {
459
+ hasCatch: false,
460
+ hasAsyncTryCatch: false,
461
+ hasUnhandledPromises: false,
462
+ unhandledLocations: [],
463
+ };
464
+ }
465
+ calculateQualityScore(profile) {
466
+ let score = 50; // Base score
467
+ // Positive factors
468
+ if (profile.hasTryCatch)
469
+ score += 20;
470
+ if (profile.catchClauses?.some(c => c.action === 'recover'))
471
+ score += 15;
472
+ if (profile.catchClauses?.some(c => c.action === 'transform'))
473
+ score += 10;
474
+ if (profile.catchClauses?.some(c => c.preservesError))
475
+ score += 5;
476
+ if (profile.asyncHandling?.hasAsyncTryCatch)
477
+ score += 10;
478
+ if (profile.asyncHandling?.hasCatch)
479
+ score += 5;
480
+ // Negative factors
481
+ if (profile.canThrow && !profile.hasTryCatch)
482
+ score -= 20;
483
+ if (profile.catchClauses?.some(c => c.action === 'swallow'))
484
+ score -= 25;
485
+ if (profile.catchClauses?.some(c => c.errorType === 'any'))
486
+ score -= 5;
487
+ if (profile.asyncHandling?.hasUnhandledPromises)
488
+ score -= 20;
489
+ return Math.max(0, Math.min(100, score));
490
+ }
491
+ scoreToQuality(score) {
492
+ if (score >= 80)
493
+ return 'excellent';
494
+ if (score >= 60)
495
+ return 'good';
496
+ if (score >= 40)
497
+ return 'fair';
498
+ return 'poor';
499
+ }
500
+ detectBoundary(funcId, func, profile) {
501
+ if (!this.callGraph)
502
+ return null;
503
+ // Find what this function catches from
504
+ const catchesFrom = [];
505
+ for (const call of func.calls) {
506
+ for (const candidate of call.resolvedCandidates) {
507
+ const calleeProfile = this.topology?.functions.get(candidate);
508
+ if (calleeProfile?.canThrow) {
509
+ catchesFrom.push(candidate);
510
+ }
511
+ }
512
+ }
513
+ if (catchesFrom.length === 0)
514
+ return null;
515
+ // Detect framework boundaries
516
+ const isFrameworkBoundary = this.isFrameworkBoundary(func);
517
+ const frameworkType = this.detectFrameworkType(func);
518
+ // Calculate coverage
519
+ const totalCallees = func.calls.reduce((sum, c) => sum + c.resolvedCandidates.length, 0);
520
+ const coverage = totalCallees > 0 ? (catchesFrom.length / totalCallees) * 100 : 0;
521
+ const boundary = {
522
+ functionId: funcId,
523
+ file: func.file,
524
+ name: profile.qualifiedName,
525
+ catchesFrom,
526
+ handledTypes: profile.catchClauses.map(c => c.errorType),
527
+ isFrameworkBoundary,
528
+ coverage: Math.round(coverage),
529
+ line: profile.catchClauses[0]?.line ?? func.startLine,
530
+ };
531
+ if (frameworkType) {
532
+ boundary.frameworkType = frameworkType;
533
+ }
534
+ return boundary;
535
+ }
536
+ isFrameworkBoundary(func) {
537
+ const name = func.name.toLowerCase();
538
+ const className = func.className?.toLowerCase() ?? '';
539
+ // React error boundaries
540
+ if (name === 'componentdidcatch' || className.includes('errorboundary'))
541
+ return true;
542
+ // Express/Koa middleware
543
+ if (func.parameters?.length === 4)
544
+ return true; // (err, req, res, next)
545
+ // NestJS exception filters
546
+ if (className.includes('filter') && name === 'catch')
547
+ return true;
548
+ // Spring exception handlers
549
+ if (func.annotations?.some((a) => a.includes('ExceptionHandler') || a.includes('ControllerAdvice')))
550
+ return true;
551
+ return false;
552
+ }
553
+ detectFrameworkType(func) {
554
+ const name = func.name.toLowerCase();
555
+ const className = func.className?.toLowerCase() ?? '';
556
+ if (name === 'componentdidcatch' || className.includes('errorboundary')) {
557
+ return 'react-error-boundary';
558
+ }
559
+ if (func.parameters?.length === 4) {
560
+ return 'express-middleware';
561
+ }
562
+ if (className.includes('filter') && name === 'catch') {
563
+ return 'nestjs-filter';
564
+ }
565
+ return undefined;
566
+ }
567
+ traceErrorPropagation(throwerId, functions) {
568
+ if (!this.callGraph)
569
+ return null;
570
+ const path = [throwerId];
571
+ let current = throwerId;
572
+ let depth = 0;
573
+ const maxDepth = this.options.maxPropagationDepth ?? 20;
574
+ while (depth < maxDepth) {
575
+ const func = this.callGraph.functions.get(current);
576
+ if (!func || func.calledBy.length === 0) {
577
+ // No more callers - error escapes
578
+ return {
579
+ source: { functionId: throwerId, throwLine: functions.get(throwerId)?.line ?? 0 },
580
+ sink: null,
581
+ propagationPath: path,
582
+ transformations: [],
583
+ depth,
584
+ };
585
+ }
586
+ // Check if any caller catches
587
+ for (const caller of func.calledBy) {
588
+ const callerProfile = functions.get(caller.callerId);
589
+ if (callerProfile?.hasTryCatch) {
590
+ // Found a boundary
591
+ return {
592
+ source: { functionId: throwerId, throwLine: functions.get(throwerId)?.line ?? 0 },
593
+ sink: {
594
+ functionId: caller.callerId,
595
+ catchLine: callerProfile.catchClauses[0]?.line ?? callerProfile.line
596
+ },
597
+ propagationPath: path,
598
+ transformations: [],
599
+ depth,
600
+ };
601
+ }
602
+ }
603
+ // Move to first caller (simplified - real impl would explore all paths)
604
+ const nextCaller = func.calledBy[0]?.callerId;
605
+ if (!nextCaller || path.includes(nextCaller))
606
+ break; // Avoid cycles
607
+ path.push(nextCaller);
608
+ current = nextCaller;
609
+ depth++;
610
+ }
611
+ return null;
612
+ }
613
+ findUnhandledPaths(chains, functions) {
614
+ const unhandled = [];
615
+ for (const chain of chains) {
616
+ if (chain.sink === null) {
617
+ // This error escapes without being caught
618
+ const sourceProfile = functions.get(chain.source.functionId);
619
+ const entryPoint = chain.propagationPath[chain.propagationPath.length - 1] ?? chain.source.functionId;
620
+ const entryProfile = functions.get(entryPoint);
621
+ const severity = this.calculatePathSeverity(entryProfile);
622
+ unhandled.push({
623
+ entryPoint,
624
+ path: chain.propagationPath,
625
+ errorType: 'Error', // Would need AST for specific type
626
+ severity,
627
+ suggestedBoundary: this.suggestBoundaryLocation(chain, functions),
628
+ reason: `Error from ${sourceProfile?.qualifiedName ?? chain.source.functionId} escapes to ${entryProfile?.qualifiedName ?? entryPoint}`,
629
+ });
630
+ }
631
+ }
632
+ return unhandled;
633
+ }
634
+ calculatePathSeverity(entryProfile) {
635
+ if (!entryProfile)
636
+ return 'medium';
637
+ // Entry points and exported functions are more critical
638
+ const func = this.callGraph?.functions.get(entryProfile.functionId);
639
+ if (func?.isExported)
640
+ return 'critical';
641
+ // Check if file is an entry point
642
+ if (this.callGraph?.entryPoints.includes(entryProfile.file))
643
+ return 'critical';
644
+ return 'medium';
645
+ }
646
+ suggestBoundaryLocation(chain, _functions) {
647
+ // Suggest adding error handling at the middle of the chain
648
+ const midIndex = Math.floor(chain.propagationPath.length / 2);
649
+ return chain.propagationPath[midIndex] ?? chain.source.functionId;
650
+ }
651
+ calculateGapSeverity(profile, gapType) {
652
+ const func = this.callGraph?.functions.get(profile.functionId);
653
+ // Entry points and exported functions are more critical
654
+ const isEntryPointFile = this.callGraph?.entryPoints.includes(profile.file) ?? false;
655
+ if (func?.isExported || isEntryPointFile) {
656
+ return gapType === 'swallowed-error' ? 'high' : 'critical';
657
+ }
658
+ switch (gapType) {
659
+ case 'no-try-catch':
660
+ return profile.canThrow ? 'high' : 'medium';
661
+ case 'swallowed-error':
662
+ return 'high';
663
+ case 'unhandled-async':
664
+ return 'high';
665
+ case 'bare-catch':
666
+ return 'low';
667
+ default:
668
+ return 'medium';
669
+ }
670
+ }
671
+ calculateRiskScore(profile, gapType) {
672
+ let score = 50;
673
+ // Gap type weights
674
+ switch (gapType) {
675
+ case 'no-try-catch':
676
+ score += 20;
677
+ break;
678
+ case 'swallowed-error':
679
+ score += 30;
680
+ break;
681
+ case 'unhandled-async':
682
+ score += 25;
683
+ break;
684
+ case 'bare-catch':
685
+ score += 5;
686
+ break;
687
+ }
688
+ // Function importance
689
+ const func = this.callGraph?.functions.get(profile.functionId);
690
+ const isEntryPointFile = this.callGraph?.entryPoints.includes(profile.file) ?? false;
691
+ if (func?.isExported)
692
+ score += 15;
693
+ if (isEntryPointFile)
694
+ score += 20;
695
+ if ((func?.calledBy.length ?? 0) > 5)
696
+ score += 10;
697
+ return Math.min(100, score);
698
+ }
699
+ }
700
+ // ============================================================================
701
+ // Factory
702
+ // ============================================================================
703
+ export function createErrorHandlingAnalyzer(options) {
704
+ return new ErrorHandlingAnalyzer(options);
705
+ }
706
+ //# sourceMappingURL=error-handling-analyzer.js.map