agent-ide 0.1.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 (436) hide show
  1. package/README.md +678 -0
  2. package/bin/agent-ide.js +19 -0
  3. package/bin/mcp-server.js +20 -0
  4. package/dist/application/events/event-bus.d.ts +107 -0
  5. package/dist/application/events/event-bus.d.ts.map +1 -0
  6. package/dist/application/events/event-bus.js +364 -0
  7. package/dist/application/events/event-bus.js.map +1 -0
  8. package/dist/application/events/event-types.d.ts +195 -0
  9. package/dist/application/events/event-types.d.ts.map +1 -0
  10. package/dist/application/events/event-types.js +36 -0
  11. package/dist/application/events/event-types.js.map +1 -0
  12. package/dist/application/events/index.d.ts +6 -0
  13. package/dist/application/events/index.d.ts.map +1 -0
  14. package/dist/application/events/index.js +6 -0
  15. package/dist/application/events/index.js.map +1 -0
  16. package/dist/application/index.d.ts +85 -0
  17. package/dist/application/index.d.ts.map +1 -0
  18. package/dist/application/index.js +138 -0
  19. package/dist/application/index.js.map +1 -0
  20. package/dist/application/services/cache-coordinator.service.d.ts +69 -0
  21. package/dist/application/services/cache-coordinator.service.d.ts.map +1 -0
  22. package/dist/application/services/cache-coordinator.service.js +251 -0
  23. package/dist/application/services/cache-coordinator.service.js.map +1 -0
  24. package/dist/application/services/error-handler.service.d.ts +56 -0
  25. package/dist/application/services/error-handler.service.d.ts.map +1 -0
  26. package/dist/application/services/error-handler.service.js +273 -0
  27. package/dist/application/services/error-handler.service.js.map +1 -0
  28. package/dist/application/services/index.d.ts +8 -0
  29. package/dist/application/services/index.d.ts.map +1 -0
  30. package/dist/application/services/index.js +8 -0
  31. package/dist/application/services/index.js.map +1 -0
  32. package/dist/application/services/module-coordinator.service.d.ts +70 -0
  33. package/dist/application/services/module-coordinator.service.d.ts.map +1 -0
  34. package/dist/application/services/module-coordinator.service.js +418 -0
  35. package/dist/application/services/module-coordinator.service.js.map +1 -0
  36. package/dist/application/services/session-manager.service.d.ts +86 -0
  37. package/dist/application/services/session-manager.service.d.ts.map +1 -0
  38. package/dist/application/services/session-manager.service.js +318 -0
  39. package/dist/application/services/session-manager.service.js.map +1 -0
  40. package/dist/application/services/workflow-engine.service.d.ts +76 -0
  41. package/dist/application/services/workflow-engine.service.d.ts.map +1 -0
  42. package/dist/application/services/workflow-engine.service.js +405 -0
  43. package/dist/application/services/workflow-engine.service.js.map +1 -0
  44. package/dist/application/state/application-state.d.ts +164 -0
  45. package/dist/application/state/application-state.d.ts.map +1 -0
  46. package/dist/application/state/application-state.js +290 -0
  47. package/dist/application/state/application-state.js.map +1 -0
  48. package/dist/application/state/index.d.ts +15 -0
  49. package/dist/application/state/index.d.ts.map +1 -0
  50. package/dist/application/state/index.js +15 -0
  51. package/dist/application/state/index.js.map +1 -0
  52. package/dist/application/state/session-state.d.ts +114 -0
  53. package/dist/application/state/session-state.d.ts.map +1 -0
  54. package/dist/application/state/session-state.js +188 -0
  55. package/dist/application/state/session-state.js.map +1 -0
  56. package/dist/application/state/state-manager.d.ts +122 -0
  57. package/dist/application/state/state-manager.d.ts.map +1 -0
  58. package/dist/application/state/state-manager.js +234 -0
  59. package/dist/application/state/state-manager.js.map +1 -0
  60. package/dist/application/types.d.ts +280 -0
  61. package/dist/application/types.d.ts.map +1 -0
  62. package/dist/application/types.js +13 -0
  63. package/dist/application/types.js.map +1 -0
  64. package/dist/application/workflows/analysis-workflow.d.ts +239 -0
  65. package/dist/application/workflows/analysis-workflow.d.ts.map +1 -0
  66. package/dist/application/workflows/analysis-workflow.js +395 -0
  67. package/dist/application/workflows/analysis-workflow.js.map +1 -0
  68. package/dist/application/workflows/base-workflow.d.ts +108 -0
  69. package/dist/application/workflows/base-workflow.d.ts.map +1 -0
  70. package/dist/application/workflows/base-workflow.js +236 -0
  71. package/dist/application/workflows/base-workflow.js.map +1 -0
  72. package/dist/application/workflows/index.d.ts +115 -0
  73. package/dist/application/workflows/index.d.ts.map +1 -0
  74. package/dist/application/workflows/index.js +218 -0
  75. package/dist/application/workflows/index.js.map +1 -0
  76. package/dist/application/workflows/refactor-workflow.d.ts +107 -0
  77. package/dist/application/workflows/refactor-workflow.d.ts.map +1 -0
  78. package/dist/application/workflows/refactor-workflow.js +310 -0
  79. package/dist/application/workflows/refactor-workflow.js.map +1 -0
  80. package/dist/core/analysis/complexity-analyzer.d.ts +81 -0
  81. package/dist/core/analysis/complexity-analyzer.d.ts.map +1 -0
  82. package/dist/core/analysis/complexity-analyzer.js +254 -0
  83. package/dist/core/analysis/complexity-analyzer.js.map +1 -0
  84. package/dist/core/analysis/dead-code-detector.d.ts +123 -0
  85. package/dist/core/analysis/dead-code-detector.d.ts.map +1 -0
  86. package/dist/core/analysis/dead-code-detector.js +275 -0
  87. package/dist/core/analysis/dead-code-detector.js.map +1 -0
  88. package/dist/core/analysis/duplication-detector.d.ts +150 -0
  89. package/dist/core/analysis/duplication-detector.d.ts.map +1 -0
  90. package/dist/core/analysis/duplication-detector.js +433 -0
  91. package/dist/core/analysis/duplication-detector.js.map +1 -0
  92. package/dist/core/analysis/index.d.ts +9 -0
  93. package/dist/core/analysis/index.d.ts.map +1 -0
  94. package/dist/core/analysis/index.js +13 -0
  95. package/dist/core/analysis/index.js.map +1 -0
  96. package/dist/core/analysis/quality-metrics.d.ts +158 -0
  97. package/dist/core/analysis/quality-metrics.d.ts.map +1 -0
  98. package/dist/core/analysis/quality-metrics.js +442 -0
  99. package/dist/core/analysis/quality-metrics.js.map +1 -0
  100. package/dist/core/dependency/cycle-detector.d.ts +81 -0
  101. package/dist/core/dependency/cycle-detector.d.ts.map +1 -0
  102. package/dist/core/dependency/cycle-detector.js +300 -0
  103. package/dist/core/dependency/cycle-detector.js.map +1 -0
  104. package/dist/core/dependency/dependency-analyzer.d.ts +152 -0
  105. package/dist/core/dependency/dependency-analyzer.d.ts.map +1 -0
  106. package/dist/core/dependency/dependency-analyzer.js +458 -0
  107. package/dist/core/dependency/dependency-analyzer.js.map +1 -0
  108. package/dist/core/dependency/dependency-graph.d.ts +156 -0
  109. package/dist/core/dependency/dependency-graph.d.ts.map +1 -0
  110. package/dist/core/dependency/dependency-graph.js +371 -0
  111. package/dist/core/dependency/dependency-graph.js.map +1 -0
  112. package/dist/core/dependency/index.d.ts +27 -0
  113. package/dist/core/dependency/index.d.ts.map +1 -0
  114. package/dist/core/dependency/index.js +36 -0
  115. package/dist/core/dependency/index.js.map +1 -0
  116. package/dist/core/dependency/types.d.ts +168 -0
  117. package/dist/core/dependency/types.d.ts.map +1 -0
  118. package/dist/core/dependency/types.js +103 -0
  119. package/dist/core/dependency/types.js.map +1 -0
  120. package/dist/core/indexing/file-index.d.ts +117 -0
  121. package/dist/core/indexing/file-index.d.ts.map +1 -0
  122. package/dist/core/indexing/file-index.js +302 -0
  123. package/dist/core/indexing/file-index.js.map +1 -0
  124. package/dist/core/indexing/file-watcher.d.ts +110 -0
  125. package/dist/core/indexing/file-watcher.d.ts.map +1 -0
  126. package/dist/core/indexing/file-watcher.js +280 -0
  127. package/dist/core/indexing/file-watcher.js.map +1 -0
  128. package/dist/core/indexing/index-engine.d.ts +120 -0
  129. package/dist/core/indexing/index-engine.d.ts.map +1 -0
  130. package/dist/core/indexing/index-engine.js +445 -0
  131. package/dist/core/indexing/index-engine.js.map +1 -0
  132. package/dist/core/indexing/index.d.ts +25 -0
  133. package/dist/core/indexing/index.d.ts.map +1 -0
  134. package/dist/core/indexing/index.js +36 -0
  135. package/dist/core/indexing/index.js.map +1 -0
  136. package/dist/core/indexing/symbol-index.d.ts +107 -0
  137. package/dist/core/indexing/symbol-index.d.ts.map +1 -0
  138. package/dist/core/indexing/symbol-index.js +352 -0
  139. package/dist/core/indexing/symbol-index.js.map +1 -0
  140. package/dist/core/indexing/types.d.ts +222 -0
  141. package/dist/core/indexing/types.d.ts.map +1 -0
  142. package/dist/core/indexing/types.js +143 -0
  143. package/dist/core/indexing/types.js.map +1 -0
  144. package/dist/core/move/import-resolver.d.ts +54 -0
  145. package/dist/core/move/import-resolver.d.ts.map +1 -0
  146. package/dist/core/move/import-resolver.js +268 -0
  147. package/dist/core/move/import-resolver.js.map +1 -0
  148. package/dist/core/move/index.d.ts +10 -0
  149. package/dist/core/move/index.d.ts.map +1 -0
  150. package/dist/core/move/index.js +12 -0
  151. package/dist/core/move/index.js.map +1 -0
  152. package/dist/core/move/move-service.d.ts +67 -0
  153. package/dist/core/move/move-service.d.ts.map +1 -0
  154. package/dist/core/move/move-service.js +400 -0
  155. package/dist/core/move/move-service.js.map +1 -0
  156. package/dist/core/move/types.d.ts +266 -0
  157. package/dist/core/move/types.d.ts.map +1 -0
  158. package/dist/core/move/types.js +101 -0
  159. package/dist/core/move/types.js.map +1 -0
  160. package/dist/core/performance/analyzer.d.ts +62 -0
  161. package/dist/core/performance/analyzer.d.ts.map +1 -0
  162. package/dist/core/performance/analyzer.js +378 -0
  163. package/dist/core/performance/analyzer.js.map +1 -0
  164. package/dist/core/performance/cache-manager.d.ts +161 -0
  165. package/dist/core/performance/cache-manager.d.ts.map +1 -0
  166. package/dist/core/performance/cache-manager.js +375 -0
  167. package/dist/core/performance/cache-manager.js.map +1 -0
  168. package/dist/core/performance/index.d.ts +14 -0
  169. package/dist/core/performance/index.d.ts.map +1 -0
  170. package/dist/core/performance/index.js +17 -0
  171. package/dist/core/performance/index.js.map +1 -0
  172. package/dist/core/performance/interfaces.d.ts +188 -0
  173. package/dist/core/performance/interfaces.d.ts.map +1 -0
  174. package/dist/core/performance/interfaces.js +17 -0
  175. package/dist/core/performance/interfaces.js.map +1 -0
  176. package/dist/core/performance/memory-manager.d.ts +176 -0
  177. package/dist/core/performance/memory-manager.d.ts.map +1 -0
  178. package/dist/core/performance/memory-manager.js +364 -0
  179. package/dist/core/performance/memory-manager.js.map +1 -0
  180. package/dist/core/performance/monitor.d.ts +92 -0
  181. package/dist/core/performance/monitor.d.ts.map +1 -0
  182. package/dist/core/performance/monitor.js +228 -0
  183. package/dist/core/performance/monitor.js.map +1 -0
  184. package/dist/core/refactor/design-patterns.d.ts +178 -0
  185. package/dist/core/refactor/design-patterns.d.ts.map +1 -0
  186. package/dist/core/refactor/design-patterns.js +656 -0
  187. package/dist/core/refactor/design-patterns.js.map +1 -0
  188. package/dist/core/refactor/extract-function.d.ts +175 -0
  189. package/dist/core/refactor/extract-function.d.ts.map +1 -0
  190. package/dist/core/refactor/extract-function.js +478 -0
  191. package/dist/core/refactor/extract-function.js.map +1 -0
  192. package/dist/core/refactor/index.d.ts +8 -0
  193. package/dist/core/refactor/index.d.ts.map +1 -0
  194. package/dist/core/refactor/index.js +11 -0
  195. package/dist/core/refactor/index.js.map +1 -0
  196. package/dist/core/refactor/inline-function.d.ts +175 -0
  197. package/dist/core/refactor/inline-function.d.ts.map +1 -0
  198. package/dist/core/refactor/inline-function.js +425 -0
  199. package/dist/core/refactor/inline-function.js.map +1 -0
  200. package/dist/core/rename/index.d.ts +9 -0
  201. package/dist/core/rename/index.d.ts.map +1 -0
  202. package/dist/core/rename/index.js +13 -0
  203. package/dist/core/rename/index.js.map +1 -0
  204. package/dist/core/rename/reference-updater.d.ts +77 -0
  205. package/dist/core/rename/reference-updater.d.ts.map +1 -0
  206. package/dist/core/rename/reference-updater.js +400 -0
  207. package/dist/core/rename/reference-updater.js.map +1 -0
  208. package/dist/core/rename/rename-engine.d.ts +69 -0
  209. package/dist/core/rename/rename-engine.d.ts.map +1 -0
  210. package/dist/core/rename/rename-engine.js +350 -0
  211. package/dist/core/rename/rename-engine.js.map +1 -0
  212. package/dist/core/rename/scope-analyzer.d.ts +75 -0
  213. package/dist/core/rename/scope-analyzer.d.ts.map +1 -0
  214. package/dist/core/rename/scope-analyzer.js +269 -0
  215. package/dist/core/rename/scope-analyzer.js.map +1 -0
  216. package/dist/core/rename/types.d.ts +163 -0
  217. package/dist/core/rename/types.d.ts.map +1 -0
  218. package/dist/core/rename/types.js +80 -0
  219. package/dist/core/rename/types.js.map +1 -0
  220. package/dist/core/search/engines/text-engine.d.ts +52 -0
  221. package/dist/core/search/engines/text-engine.d.ts.map +1 -0
  222. package/dist/core/search/engines/text-engine.js +376 -0
  223. package/dist/core/search/engines/text-engine.js.map +1 -0
  224. package/dist/core/search/index.d.ts +10 -0
  225. package/dist/core/search/index.d.ts.map +1 -0
  226. package/dist/core/search/index.js +11 -0
  227. package/dist/core/search/index.js.map +1 -0
  228. package/dist/core/search/service.d.ts +105 -0
  229. package/dist/core/search/service.d.ts.map +1 -0
  230. package/dist/core/search/service.js +384 -0
  231. package/dist/core/search/service.js.map +1 -0
  232. package/dist/core/search/types.d.ts +357 -0
  233. package/dist/core/search/types.d.ts.map +1 -0
  234. package/dist/core/search/types.js +47 -0
  235. package/dist/core/search/types.js.map +1 -0
  236. package/dist/infrastructure/cache/cache-manager.d.ts +113 -0
  237. package/dist/infrastructure/cache/cache-manager.d.ts.map +1 -0
  238. package/dist/infrastructure/cache/cache-manager.js +279 -0
  239. package/dist/infrastructure/cache/cache-manager.js.map +1 -0
  240. package/dist/infrastructure/cache/index.d.ts +138 -0
  241. package/dist/infrastructure/cache/index.d.ts.map +1 -0
  242. package/dist/infrastructure/cache/index.js +266 -0
  243. package/dist/infrastructure/cache/index.js.map +1 -0
  244. package/dist/infrastructure/cache/memory-cache.d.ts +94 -0
  245. package/dist/infrastructure/cache/memory-cache.d.ts.map +1 -0
  246. package/dist/infrastructure/cache/memory-cache.js +327 -0
  247. package/dist/infrastructure/cache/memory-cache.js.map +1 -0
  248. package/dist/infrastructure/cache/strategies.d.ts +99 -0
  249. package/dist/infrastructure/cache/strategies.d.ts.map +1 -0
  250. package/dist/infrastructure/cache/strategies.js +230 -0
  251. package/dist/infrastructure/cache/strategies.js.map +1 -0
  252. package/dist/infrastructure/cache/types.d.ts +220 -0
  253. package/dist/infrastructure/cache/types.d.ts.map +1 -0
  254. package/dist/infrastructure/cache/types.js +42 -0
  255. package/dist/infrastructure/cache/types.js.map +1 -0
  256. package/dist/infrastructure/parser/base.d.ts +126 -0
  257. package/dist/infrastructure/parser/base.d.ts.map +1 -0
  258. package/dist/infrastructure/parser/base.js +269 -0
  259. package/dist/infrastructure/parser/base.js.map +1 -0
  260. package/dist/infrastructure/parser/factory.d.ts +141 -0
  261. package/dist/infrastructure/parser/factory.d.ts.map +1 -0
  262. package/dist/infrastructure/parser/factory.js +306 -0
  263. package/dist/infrastructure/parser/factory.js.map +1 -0
  264. package/dist/infrastructure/parser/index.d.ts +12 -0
  265. package/dist/infrastructure/parser/index.d.ts.map +1 -0
  266. package/dist/infrastructure/parser/index.js +12 -0
  267. package/dist/infrastructure/parser/index.js.map +1 -0
  268. package/dist/infrastructure/parser/interface.d.ts +108 -0
  269. package/dist/infrastructure/parser/interface.d.ts.map +1 -0
  270. package/dist/infrastructure/parser/interface.js +72 -0
  271. package/dist/infrastructure/parser/interface.js.map +1 -0
  272. package/dist/infrastructure/parser/registry.d.ts +141 -0
  273. package/dist/infrastructure/parser/registry.d.ts.map +1 -0
  274. package/dist/infrastructure/parser/registry.js +289 -0
  275. package/dist/infrastructure/parser/registry.js.map +1 -0
  276. package/dist/infrastructure/parser/types.d.ts +172 -0
  277. package/dist/infrastructure/parser/types.d.ts.map +1 -0
  278. package/dist/infrastructure/parser/types.js +147 -0
  279. package/dist/infrastructure/parser/types.js.map +1 -0
  280. package/dist/infrastructure/storage/file-system.d.ts +74 -0
  281. package/dist/infrastructure/storage/file-system.d.ts.map +1 -0
  282. package/dist/infrastructure/storage/file-system.js +334 -0
  283. package/dist/infrastructure/storage/file-system.js.map +1 -0
  284. package/dist/infrastructure/storage/file-watcher.d.ts +84 -0
  285. package/dist/infrastructure/storage/file-watcher.d.ts.map +1 -0
  286. package/dist/infrastructure/storage/file-watcher.js +249 -0
  287. package/dist/infrastructure/storage/file-watcher.js.map +1 -0
  288. package/dist/infrastructure/storage/index.d.ts +11 -0
  289. package/dist/infrastructure/storage/index.d.ts.map +1 -0
  290. package/dist/infrastructure/storage/index.js +16 -0
  291. package/dist/infrastructure/storage/index.js.map +1 -0
  292. package/dist/infrastructure/storage/path-utils.d.ts +96 -0
  293. package/dist/infrastructure/storage/path-utils.d.ts.map +1 -0
  294. package/dist/infrastructure/storage/path-utils.js +272 -0
  295. package/dist/infrastructure/storage/path-utils.js.map +1 -0
  296. package/dist/infrastructure/storage/types.d.ts +106 -0
  297. package/dist/infrastructure/storage/types.d.ts.map +1 -0
  298. package/dist/infrastructure/storage/types.js +53 -0
  299. package/dist/infrastructure/storage/types.js.map +1 -0
  300. package/dist/interfaces/cli/cli.d.ts +70 -0
  301. package/dist/interfaces/cli/cli.d.ts.map +1 -0
  302. package/dist/interfaces/cli/cli.js +1054 -0
  303. package/dist/interfaces/cli/cli.js.map +1 -0
  304. package/dist/interfaces/cli/index.d.ts +7 -0
  305. package/dist/interfaces/cli/index.d.ts.map +1 -0
  306. package/dist/interfaces/cli/index.js +22 -0
  307. package/dist/interfaces/cli/index.js.map +1 -0
  308. package/dist/interfaces/mcp/index.d.ts +7 -0
  309. package/dist/interfaces/mcp/index.d.ts.map +1 -0
  310. package/dist/interfaces/mcp/index.js +6 -0
  311. package/dist/interfaces/mcp/index.js.map +1 -0
  312. package/dist/interfaces/mcp/mcp-server.d.ts +34 -0
  313. package/dist/interfaces/mcp/mcp-server.d.ts.map +1 -0
  314. package/dist/interfaces/mcp/mcp-server.js +154 -0
  315. package/dist/interfaces/mcp/mcp-server.js.map +1 -0
  316. package/dist/interfaces/mcp/mcp.d.ts +44 -0
  317. package/dist/interfaces/mcp/mcp.d.ts.map +1 -0
  318. package/dist/interfaces/mcp/mcp.js +559 -0
  319. package/dist/interfaces/mcp/mcp.js.map +1 -0
  320. package/dist/plugins/javascript/index.d.ts +12 -0
  321. package/dist/plugins/javascript/index.d.ts.map +1 -0
  322. package/dist/plugins/javascript/index.js +16 -0
  323. package/dist/plugins/javascript/index.js.map +1 -0
  324. package/dist/plugins/javascript/parser.d.ts +81 -0
  325. package/dist/plugins/javascript/parser.d.ts.map +1 -0
  326. package/dist/plugins/javascript/parser.js +457 -0
  327. package/dist/plugins/javascript/parser.js.map +1 -0
  328. package/dist/plugins/javascript/types.d.ts +131 -0
  329. package/dist/plugins/javascript/types.d.ts.map +1 -0
  330. package/dist/plugins/javascript/types.js +366 -0
  331. package/dist/plugins/javascript/types.js.map +1 -0
  332. package/dist/plugins/swift/index.d.ts +11 -0
  333. package/dist/plugins/swift/index.d.ts.map +1 -0
  334. package/dist/plugins/swift/index.js +15 -0
  335. package/dist/plugins/swift/index.js.map +1 -0
  336. package/dist/plugins/swift/parser.d.ts +98 -0
  337. package/dist/plugins/swift/parser.d.ts.map +1 -0
  338. package/dist/plugins/swift/parser.js +612 -0
  339. package/dist/plugins/swift/parser.js.map +1 -0
  340. package/dist/plugins/swift/types.d.ts +196 -0
  341. package/dist/plugins/swift/types.d.ts.map +1 -0
  342. package/dist/plugins/swift/types.js +268 -0
  343. package/dist/plugins/swift/types.js.map +1 -0
  344. package/dist/plugins/typescript/dependency-analyzer.d.ts +78 -0
  345. package/dist/plugins/typescript/dependency-analyzer.d.ts.map +1 -0
  346. package/dist/plugins/typescript/dependency-analyzer.js +305 -0
  347. package/dist/plugins/typescript/dependency-analyzer.js.map +1 -0
  348. package/dist/plugins/typescript/index.d.ts +9 -0
  349. package/dist/plugins/typescript/index.d.ts.map +1 -0
  350. package/dist/plugins/typescript/index.js +8 -0
  351. package/dist/plugins/typescript/index.js.map +1 -0
  352. package/dist/plugins/typescript/parser.d.ts +117 -0
  353. package/dist/plugins/typescript/parser.d.ts.map +1 -0
  354. package/dist/plugins/typescript/parser.js +888 -0
  355. package/dist/plugins/typescript/parser.js.map +1 -0
  356. package/dist/plugins/typescript/symbol-extractor.d.ts +76 -0
  357. package/dist/plugins/typescript/symbol-extractor.d.ts.map +1 -0
  358. package/dist/plugins/typescript/symbol-extractor.js +339 -0
  359. package/dist/plugins/typescript/symbol-extractor.js.map +1 -0
  360. package/dist/plugins/typescript/types.d.ts +131 -0
  361. package/dist/plugins/typescript/types.d.ts.map +1 -0
  362. package/dist/plugins/typescript/types.js +331 -0
  363. package/dist/plugins/typescript/types.js.map +1 -0
  364. package/dist/shared/errors/base-error.d.ts +27 -0
  365. package/dist/shared/errors/base-error.d.ts.map +1 -0
  366. package/dist/shared/errors/base-error.js +58 -0
  367. package/dist/shared/errors/base-error.js.map +1 -0
  368. package/dist/shared/errors/config-error.d.ts +21 -0
  369. package/dist/shared/errors/config-error.d.ts.map +1 -0
  370. package/dist/shared/errors/config-error.js +34 -0
  371. package/dist/shared/errors/config-error.js.map +1 -0
  372. package/dist/shared/errors/file-error.d.ts +21 -0
  373. package/dist/shared/errors/file-error.d.ts.map +1 -0
  374. package/dist/shared/errors/file-error.js +34 -0
  375. package/dist/shared/errors/file-error.js.map +1 -0
  376. package/dist/shared/errors/index.d.ts +59 -0
  377. package/dist/shared/errors/index.d.ts.map +1 -0
  378. package/dist/shared/errors/index.js +114 -0
  379. package/dist/shared/errors/index.js.map +1 -0
  380. package/dist/shared/errors/parser-error.d.ts +72 -0
  381. package/dist/shared/errors/parser-error.d.ts.map +1 -0
  382. package/dist/shared/errors/parser-error.js +104 -0
  383. package/dist/shared/errors/parser-error.js.map +1 -0
  384. package/dist/shared/errors/validation-error.d.ts +21 -0
  385. package/dist/shared/errors/validation-error.d.ts.map +1 -0
  386. package/dist/shared/errors/validation-error.js +34 -0
  387. package/dist/shared/errors/validation-error.js.map +1 -0
  388. package/dist/shared/index.d.ts +11 -0
  389. package/dist/shared/index.d.ts.map +1 -0
  390. package/dist/shared/index.js +22 -0
  391. package/dist/shared/index.js.map +1 -0
  392. package/dist/shared/types/ast.d.ts +78 -0
  393. package/dist/shared/types/ast.d.ts.map +1 -0
  394. package/dist/shared/types/ast.js +215 -0
  395. package/dist/shared/types/ast.js.map +1 -0
  396. package/dist/shared/types/core.d.ts +65 -0
  397. package/dist/shared/types/core.d.ts.map +1 -0
  398. package/dist/shared/types/core.js +114 -0
  399. package/dist/shared/types/core.js.map +1 -0
  400. package/dist/shared/types/index.d.ts +11 -0
  401. package/dist/shared/types/index.d.ts.map +1 -0
  402. package/dist/shared/types/index.js +12 -0
  403. package/dist/shared/types/index.js.map +1 -0
  404. package/dist/shared/types/symbol.d.ts +119 -0
  405. package/dist/shared/types/symbol.d.ts.map +1 -0
  406. package/dist/shared/types/symbol.js +197 -0
  407. package/dist/shared/types/symbol.js.map +1 -0
  408. package/dist/shared/utils/array.d.ts +68 -0
  409. package/dist/shared/utils/array.d.ts.map +1 -0
  410. package/dist/shared/utils/array.js +165 -0
  411. package/dist/shared/utils/array.js.map +1 -0
  412. package/dist/shared/utils/async.d.ts +87 -0
  413. package/dist/shared/utils/async.d.ts.map +1 -0
  414. package/dist/shared/utils/async.js +185 -0
  415. package/dist/shared/utils/async.js.map +1 -0
  416. package/dist/shared/utils/index.d.ts +32 -0
  417. package/dist/shared/utils/index.d.ts.map +1 -0
  418. package/dist/shared/utils/index.js +37 -0
  419. package/dist/shared/utils/index.js.map +1 -0
  420. package/dist/shared/utils/memory-monitor.d.ts +83 -0
  421. package/dist/shared/utils/memory-monitor.d.ts.map +1 -0
  422. package/dist/shared/utils/memory-monitor.js +168 -0
  423. package/dist/shared/utils/memory-monitor.js.map +1 -0
  424. package/dist/shared/utils/object.d.ts +71 -0
  425. package/dist/shared/utils/object.d.ts.map +1 -0
  426. package/dist/shared/utils/object.js +284 -0
  427. package/dist/shared/utils/object.js.map +1 -0
  428. package/dist/shared/utils/path.d.ts +59 -0
  429. package/dist/shared/utils/path.d.ts.map +1 -0
  430. package/dist/shared/utils/path.js +201 -0
  431. package/dist/shared/utils/path.js.map +1 -0
  432. package/dist/shared/utils/string.d.ts +74 -0
  433. package/dist/shared/utils/string.d.ts.map +1 -0
  434. package/dist/shared/utils/string.js +201 -0
  435. package/dist/shared/utils/string.js.map +1 -0
  436. package/package.json +81 -0
@@ -0,0 +1,442 @@
1
+ /**
2
+ * 程式碼品質評估器
3
+ * 提供可維護性指數計算、程式碼異味檢測等功能
4
+ */
5
+ /**
6
+ * 可維護性指數計算器
7
+ * 基於 Microsoft Visual Studio 公式
8
+ */
9
+ export class MaintainabilityIndex {
10
+ /**
11
+ * 計算可維護性指數
12
+ * @param metrics 程式碼度量
13
+ * @returns 可維護性指數 (0-171)
14
+ */
15
+ calculate(metrics) {
16
+ const { halsteadVolume, cyclomaticComplexity, linesOfCode } = metrics;
17
+ // 防止對數計算錯誤
18
+ const safeLog = (value) => Math.log(Math.max(1, value));
19
+ // Microsoft Visual Studio 公式
20
+ const mi = Math.max(0, 171 -
21
+ 5.2 * safeLog(halsteadVolume) -
22
+ 0.23 * cyclomaticComplexity -
23
+ 16.2 * safeLog(linesOfCode));
24
+ return Math.round(mi * 100) / 100; // 保留兩位小數
25
+ }
26
+ /**
27
+ * 將可維護性指數轉換為等級
28
+ */
29
+ getGrade(maintainabilityIndex) {
30
+ if (maintainabilityIndex >= 85) {
31
+ return 'A';
32
+ }
33
+ if (maintainabilityIndex >= 70) {
34
+ return 'B';
35
+ }
36
+ if (maintainabilityIndex >= 50) {
37
+ return 'C';
38
+ }
39
+ if (maintainabilityIndex >= 25) {
40
+ return 'D';
41
+ }
42
+ return 'F';
43
+ }
44
+ /**
45
+ * 獲取可維護性描述
46
+ */
47
+ getDescription(grade) {
48
+ switch (grade) {
49
+ case 'A': return '優秀 - 易於維護';
50
+ case 'B': return '良好 - 相對易於維護';
51
+ case 'C': return '一般 - 中等維護難度';
52
+ case 'D': return '差 - 維護困難';
53
+ case 'F': return '非常差 - 極難維護';
54
+ default: return '未知等級';
55
+ }
56
+ }
57
+ }
58
+ /**
59
+ * Halstead 複雜度計算器
60
+ */
61
+ export class HalsteadComplexity {
62
+ /**
63
+ * 計算 Halstead 複雜度
64
+ * @param code 程式碼字串
65
+ * @returns Halstead 複雜度指標
66
+ */
67
+ calculate(code) {
68
+ const operators = this.extractOperators(code);
69
+ const operands = this.extractOperands(code);
70
+ const n1 = new Set(operators).size; // 不同運算子數量
71
+ const n2 = new Set(operands).size; // 不同操作數數量
72
+ const N1 = operators.length; // 總運算子數量
73
+ const N2 = operands.length; // 總操作數數量
74
+ const vocabulary = n1 + n2; // 詞彙量
75
+ const length = N1 + N2; // 程式長度
76
+ // Halstead 指標
77
+ const volume = length * Math.log2(Math.max(1, vocabulary));
78
+ const difficulty = (n1 / 2) * (N2 / Math.max(1, n2));
79
+ const effort = difficulty * volume;
80
+ const timeToProgram = effort / 18; // 秒
81
+ const bugsEstimate = volume / 3000;
82
+ return {
83
+ volume: Math.round(volume * 100) / 100,
84
+ difficulty: Math.round(difficulty * 100) / 100,
85
+ effort: Math.round(effort * 100) / 100,
86
+ timeToProgram: Math.round(timeToProgram * 100) / 100,
87
+ bugsEstimate: Math.round(bugsEstimate * 100) / 100
88
+ };
89
+ }
90
+ /**
91
+ * 提取運算子
92
+ */
93
+ extractOperators(code) {
94
+ const operatorPatterns = [
95
+ /\+\+|--|\+=|-=|\*=|\/=|%=|&&|\|\||==|!=|<=|>=|===|!==|<<|>>|>>>/g,
96
+ /[+\-*/%=<>!&|^~?:.,;(){}[\]]/g
97
+ ];
98
+ const operators = [];
99
+ for (const pattern of operatorPatterns) {
100
+ const matches = code.match(pattern);
101
+ if (matches) {
102
+ operators.push(...matches);
103
+ }
104
+ }
105
+ return operators;
106
+ }
107
+ /**
108
+ * 提取操作數
109
+ */
110
+ extractOperands(code) {
111
+ const operands = [];
112
+ // 變數名和函式名
113
+ const identifiers = code.match(/\b[a-zA-Z_$][a-zA-Z0-9_$]*\b/g) || [];
114
+ operands.push(...identifiers);
115
+ // 數字字面值
116
+ const numbers = code.match(/\b\d+(\.\d+)?\b/g) || [];
117
+ operands.push(...numbers);
118
+ // 字串字面值
119
+ const strings = code.match(/(["'`])(?:(?!\1)[^\\]|\\.)*()\1/g) || [];
120
+ operands.push(...strings);
121
+ return operands;
122
+ }
123
+ }
124
+ /**
125
+ * 程式碼異味檢測器
126
+ */
127
+ export class CodeSmellDetector {
128
+ /**
129
+ * 檢測程式碼異味
130
+ * @param code 程式碼字串
131
+ * @param metrics 程式碼度量
132
+ * @returns 程式碼異味列表
133
+ */
134
+ detect(code, metrics) {
135
+ const smells = [];
136
+ // 檢測長方法
137
+ smells.push(...this.detectLongMethod(code, metrics));
138
+ // 檢測大類
139
+ smells.push(...this.detectLargeClass(code, metrics));
140
+ // 檢測長參數列表
141
+ smells.push(...this.detectLongParameterList(code, metrics));
142
+ // 檢測重複程式碼
143
+ smells.push(...this.detectDuplicateCode(code));
144
+ // 檢測複雜條件
145
+ smells.push(...this.detectComplexConditionals(code));
146
+ // 檢測魔術數字
147
+ smells.push(...this.detectMagicNumbers(code));
148
+ return smells;
149
+ }
150
+ /**
151
+ * 檢測長方法
152
+ */
153
+ detectLongMethod(code, metrics) {
154
+ const smells = [];
155
+ const lines = code.split('\n');
156
+ if (metrics.linesOfCode > 50) {
157
+ smells.push({
158
+ type: 'LongMethod',
159
+ location: { line: 1, column: 1 },
160
+ severity: metrics.linesOfCode > 100 ? 'high' : 'medium',
161
+ message: `方法過長:${metrics.linesOfCode} 行`,
162
+ suggestion: '考慮將方法分解為較小的方法'
163
+ });
164
+ }
165
+ return smells;
166
+ }
167
+ /**
168
+ * 檢測大類
169
+ */
170
+ detectLargeClass(code, metrics) {
171
+ const smells = [];
172
+ if (metrics.methodCount > 20 || metrics.fieldCount > 15) {
173
+ smells.push({
174
+ type: 'LargeClass',
175
+ location: { line: 1, column: 1 },
176
+ severity: 'high',
177
+ message: `類別過大:${metrics.methodCount} 個方法,${metrics.fieldCount} 個欄位`,
178
+ suggestion: '考慮將類別分解為多個較小的類別'
179
+ });
180
+ }
181
+ return smells;
182
+ }
183
+ /**
184
+ * 檢測長參數列表
185
+ */
186
+ detectLongParameterList(code, metrics) {
187
+ const smells = [];
188
+ if (metrics.parameterCount > 5) {
189
+ smells.push({
190
+ type: 'LongParameterList',
191
+ location: { line: 1, column: 1 },
192
+ severity: metrics.parameterCount > 8 ? 'high' : 'medium',
193
+ message: `參數列表過長:${metrics.parameterCount} 個參數`,
194
+ suggestion: '考慮使用參數物件或建造者模式'
195
+ });
196
+ }
197
+ return smells;
198
+ }
199
+ /**
200
+ * 檢測重複程式碼
201
+ */
202
+ detectDuplicateCode(code) {
203
+ const smells = [];
204
+ const lines = code.split('\n');
205
+ // 簡化實作:檢測連續重複的行
206
+ for (let i = 0; i < lines.length - 2; i++) {
207
+ const line1 = lines[i].trim();
208
+ const line2 = lines[i + 1].trim();
209
+ const line3 = lines[i + 2].trim();
210
+ if (line1.length > 10 && line1 === line2 && line2 === line3) {
211
+ smells.push({
212
+ type: 'DuplicateCode',
213
+ location: { line: i + 1, column: 1 },
214
+ severity: 'medium',
215
+ message: '檢測到重複程式碼',
216
+ suggestion: '提取重複的程式碼為方法'
217
+ });
218
+ }
219
+ }
220
+ return smells;
221
+ }
222
+ /**
223
+ * 檢測複雜條件
224
+ */
225
+ detectComplexConditionals(code) {
226
+ const smells = [];
227
+ const lines = code.split('\n');
228
+ lines.forEach((line, index) => {
229
+ const logicalOperators = (line.match(/&&|\|\|/g) || []).length;
230
+ if (logicalOperators >= 3) {
231
+ smells.push({
232
+ type: 'ComplexConditional',
233
+ location: { line: index + 1, column: 1 },
234
+ severity: logicalOperators >= 5 ? 'high' : 'medium',
235
+ message: `複雜條件:包含 ${logicalOperators} 個邏輯運算子`,
236
+ suggestion: '考慮將複雜條件提取為方法'
237
+ });
238
+ }
239
+ });
240
+ return smells;
241
+ }
242
+ /**
243
+ * 檢測魔術數字
244
+ */
245
+ detectMagicNumbers(code) {
246
+ const smells = [];
247
+ const lines = code.split('\n');
248
+ lines.forEach((line, index) => {
249
+ // 檢測數字字面值(排除 0, 1, -1)
250
+ const magicNumbers = line.match(/\b(?!0\b|1\b|-1\b)\d{2,}\b/g);
251
+ if (magicNumbers) {
252
+ smells.push({
253
+ type: 'MagicNumber',
254
+ location: { line: index + 1, column: 1 },
255
+ severity: 'low',
256
+ message: `魔術數字:${magicNumbers.join(', ')}`,
257
+ suggestion: '使用命名常數取代魔術數字'
258
+ });
259
+ }
260
+ });
261
+ return smells;
262
+ }
263
+ }
264
+ /**
265
+ * 程式碼品質評估器主類
266
+ */
267
+ export class QualityMetricsAnalyzer {
268
+ maintainabilityIndex = new MaintainabilityIndex();
269
+ halsteadComplexity = new HalsteadComplexity();
270
+ codeSmellDetector = new CodeSmellDetector();
271
+ /**
272
+ * 評估程式碼品質
273
+ * @param code 程式碼字串
274
+ * @returns 品質評估結果
275
+ */
276
+ async assess(code) {
277
+ // 輸入驗證
278
+ if (typeof code !== 'string') {
279
+ throw new Error('程式碼必須是字串類型');
280
+ }
281
+ // 計算程式碼度量
282
+ const metrics = this.calculateMetrics(code);
283
+ // 計算可維護性指數
284
+ const maintainabilityIndex = this.maintainabilityIndex.calculate(metrics);
285
+ const grade = this.maintainabilityIndex.getGrade(maintainabilityIndex);
286
+ // 檢測程式碼異味
287
+ const codeSmells = this.codeSmellDetector.detect(code, metrics);
288
+ // 計算綜合評分
289
+ const overallScore = this.calculateOverallScore(maintainabilityIndex, codeSmells);
290
+ return {
291
+ maintainabilityIndex,
292
+ grade,
293
+ codeSmells,
294
+ metrics,
295
+ overallScore
296
+ };
297
+ }
298
+ /**
299
+ * 計算程式碼度量
300
+ */
301
+ calculateMetrics(code) {
302
+ const lines = code.split('\n');
303
+ const halstead = this.halsteadComplexity.calculate(code);
304
+ // 簡化實作
305
+ const methodCount = (code.match(/function\s+\w+|=>\s*{|\w+\s*\(/g) || []).length;
306
+ const fieldCount = (code.match(/(?:const|let|var)\s+\w+/g) || []).length;
307
+ const parameterCount = this.calculateAverageParameterCount(code);
308
+ return {
309
+ halsteadVolume: halstead.volume,
310
+ cyclomaticComplexity: this.calculateCyclomaticComplexity(code),
311
+ linesOfCode: lines.filter(line => line.trim().length > 0).length,
312
+ methodCount,
313
+ fieldCount,
314
+ parameterCount
315
+ };
316
+ }
317
+ /**
318
+ * 計算循環複雜度
319
+ */
320
+ calculateCyclomaticComplexity(code) {
321
+ const decisionPoints = [
322
+ /\bif\s*\(/g,
323
+ /\belse\s+if\s*\(/g,
324
+ /\bwhile\s*\(/g,
325
+ /\bfor\s*\(/g,
326
+ /\bcase\s+/g,
327
+ /\bcatch\s*\(/g,
328
+ /&&|\|\|/g
329
+ ];
330
+ let complexity = 1; // 基礎路徑
331
+ for (const pattern of decisionPoints) {
332
+ const matches = code.match(pattern);
333
+ if (matches) {
334
+ complexity += matches.length;
335
+ }
336
+ }
337
+ return complexity;
338
+ }
339
+ /**
340
+ * 計算平均參數數量
341
+ */
342
+ calculateAverageParameterCount(code) {
343
+ const functionMatches = code.match(/\([^)]*\)/g);
344
+ if (!functionMatches || functionMatches.length === 0) {
345
+ return 0;
346
+ }
347
+ const totalParams = functionMatches.reduce((sum, match) => {
348
+ const params = match.slice(1, -1).split(',').filter(p => p.trim().length > 0);
349
+ return sum + params.length;
350
+ }, 0);
351
+ return Math.round(totalParams / functionMatches.length);
352
+ }
353
+ /**
354
+ * 計算綜合評分
355
+ */
356
+ calculateOverallScore(maintainabilityIndex, codeSmells) {
357
+ let score = maintainabilityIndex;
358
+ // 根據程式碼異味調整評分
359
+ const smellPenalties = {
360
+ high: 10,
361
+ medium: 5,
362
+ low: 2
363
+ };
364
+ for (const smell of codeSmells) {
365
+ score -= smellPenalties[smell.severity];
366
+ }
367
+ return Math.max(0, Math.round(score * 100) / 100);
368
+ }
369
+ /**
370
+ * 批次評估多個檔案
371
+ */
372
+ async assessFiles(files) {
373
+ if (!Array.isArray(files)) {
374
+ throw new Error('檔案列表必須是陣列');
375
+ }
376
+ const results = await Promise.all(files.map(async (file) => {
377
+ try {
378
+ // 實際實作中應該讀取檔案內容
379
+ const code = ''; // 簡化實作
380
+ const assessment = await this.assess(code);
381
+ return { file, assessment };
382
+ }
383
+ catch (error) {
384
+ return {
385
+ file,
386
+ assessment: {
387
+ maintainabilityIndex: 0,
388
+ grade: 'F',
389
+ codeSmells: [{
390
+ type: 'Error',
391
+ location: { line: 0, column: 0 },
392
+ severity: 'high',
393
+ message: `評估失敗: ${error instanceof Error ? error.message : '未知錯誤'}`,
394
+ suggestion: '請檢查檔案格式和內容'
395
+ }],
396
+ metrics: {
397
+ halsteadVolume: 0,
398
+ cyclomaticComplexity: 0,
399
+ linesOfCode: 0,
400
+ methodCount: 0,
401
+ fieldCount: 0,
402
+ parameterCount: 0
403
+ },
404
+ overallScore: 0
405
+ }
406
+ };
407
+ }
408
+ }));
409
+ return results;
410
+ }
411
+ /**
412
+ * 獲取專案整體品質報告
413
+ */
414
+ async getProjectReport(files) {
415
+ const results = await this.assessFiles(files);
416
+ let totalMaintainability = 0;
417
+ const gradeDistribution = { A: 0, B: 0, C: 0, D: 0, F: 0 };
418
+ const smellsByType = {};
419
+ const allSmells = [];
420
+ for (const result of results) {
421
+ const { assessment } = result;
422
+ totalMaintainability += assessment.maintainabilityIndex;
423
+ gradeDistribution[assessment.grade]++;
424
+ for (const smell of assessment.codeSmells) {
425
+ smellsByType[smell.type] = (smellsByType[smell.type] || 0) + 1;
426
+ allSmells.push(smell);
427
+ }
428
+ }
429
+ // 取得最嚴重的問題
430
+ const topIssues = allSmells
431
+ .filter(smell => smell.severity === 'high')
432
+ .slice(0, 10);
433
+ return {
434
+ averageMaintainabilityIndex: results.length > 0 ? totalMaintainability / results.length : 0,
435
+ gradeDistribution,
436
+ totalCodeSmells: allSmells.length,
437
+ smellsByType,
438
+ topIssues
439
+ };
440
+ }
441
+ }
442
+ //# sourceMappingURL=quality-metrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quality-metrics.js","sourceRoot":"","sources":["../../../src/core/analysis/quality-metrics.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * 循環依賴檢測器
3
+ * 使用 Tarjan 算法檢測強連通分量和循環依賴
4
+ */
5
+ import type { DependencyGraph } from './dependency-graph.js';
6
+ import type { CircularDependency, StronglyConnectedComponent, CycleDetectionOptions } from './types.js';
7
+ /**
8
+ * 循環依賴檢測器類別
9
+ */
10
+ export declare class CycleDetector {
11
+ /**
12
+ * 檢測圖中的所有循環依賴
13
+ * @param graph 依賴圖
14
+ * @param options 檢測選項
15
+ * @returns 循環依賴列表
16
+ */
17
+ detectCycles(graph: DependencyGraph, options?: CycleDetectionOptions): CircularDependency[];
18
+ /**
19
+ * 使用 Tarjan 算法找出強連通分量
20
+ * @param graph 依賴圖
21
+ * @returns 強連通分量列表
22
+ */
23
+ findStronglyConnectedComponents(graph: DependencyGraph): StronglyConnectedComponent[];
24
+ /**
25
+ * 在強連通分量中找出循環路徑
26
+ * @param graph 依賴圖
27
+ * @param sccNodes SCC 中的節點
28
+ * @returns 循環路徑列表
29
+ */
30
+ private findCyclePathsInSCC;
31
+ /**
32
+ * 找出從指定節點開始的最短循環路徑
33
+ * @param graph 依賴圖
34
+ * @param startNode 起始節點
35
+ * @param sccNodes 限制搜尋範圍的節點
36
+ * @returns 循環路徑或 null
37
+ */
38
+ private findShortestCyclePath;
39
+ /**
40
+ * 計算循環的複雜度
41
+ * @param graph 依賴圖
42
+ * @param cycleNodes 循環中的節點
43
+ * @returns 複雜度分數
44
+ */
45
+ private calculateCycleComplexity;
46
+ /**
47
+ * 取得預設檢測選項
48
+ * @param options 使用者提供的選項
49
+ * @returns 合併後的選項
50
+ */
51
+ private getDefaultOptions;
52
+ /**
53
+ * 檢查圖中是否存在循環依賴
54
+ * @param graph 依賴圖
55
+ * @returns 是否存在循環
56
+ */
57
+ hasCycles(graph: DependencyGraph): boolean;
58
+ /**
59
+ * 取得循環依賴的摘要統計
60
+ * @param graph 依賴圖
61
+ * @returns 統計資訊
62
+ */
63
+ getCycleStatistics(graph: DependencyGraph): {
64
+ totalCycles: number;
65
+ averageCycleLength: number;
66
+ maxCycleLength: number;
67
+ cyclesBySeverity: Record<string, number>;
68
+ };
69
+ /**
70
+ * 建議循環依賴的修復策略
71
+ * @param cycles 循環依賴列表
72
+ * @returns 修復建議
73
+ */
74
+ suggestFixStrategies(cycles: CircularDependency[]): Array<{
75
+ cycle: string[];
76
+ strategy: string;
77
+ description: string;
78
+ priority: 'high' | 'medium' | 'low';
79
+ }>;
80
+ }
81
+ //# sourceMappingURL=cycle-detector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cycle-detector.d.ts","sourceRoot":"","sources":["../../../src/core/dependency/cycle-detector.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EACV,kBAAkB,EAClB,0BAA0B,EAC1B,qBAAqB,EACtB,MAAM,YAAY,CAAC;AAYpB;;GAEG;AACH,qBAAa,aAAa;IACxB;;;;;OAKG;IACH,YAAY,CACV,KAAK,EAAE,eAAe,EACtB,OAAO,CAAC,EAAE,qBAAqB,GAC9B,kBAAkB,EAAE;IA+CvB;;;;OAIG;IACH,+BAA+B,CAAC,KAAK,EAAE,eAAe,GAAG,0BAA0B,EAAE;IAoErF;;;;;OAKG;IACH,OAAO,CAAC,mBAAmB;IAqB3B;;;;;;OAMG;IACH,OAAO,CAAC,qBAAqB;IAwC7B;;;;;OAKG;IACH,OAAO,CAAC,wBAAwB;IAyBhC;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;IASzB;;;;OAIG;IACH,SAAS,CAAC,KAAK,EAAE,eAAe,GAAG,OAAO;IAK1C;;;;OAIG;IACH,kBAAkB,CAAC,KAAK,EAAE,eAAe,GAAG;QAC1C,WAAW,EAAE,MAAM,CAAC;QACpB,kBAAkB,EAAE,MAAM,CAAC;QAC3B,cAAc,EAAE,MAAM,CAAC;QACvB,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KAC1C;IAgCD;;;;OAIG;IACH,oBAAoB,CAAC,MAAM,EAAE,kBAAkB,EAAE,GAAG,KAAK,CAAC;QACxD,KAAK,EAAE,MAAM,EAAE,CAAC;QAChB,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,EAAE,MAAM,CAAC;QACpB,QAAQ,EAAE,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;KACrC,CAAC;CAgCH"}