@girardelli/architect 6.0.0 → 8.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (992) hide show
  1. package/dist/{adapters → src/adapters}/cli.d.ts +1 -2
  2. package/dist/src/adapters/cli.js +639 -0
  3. package/dist/src/adapters/cli.js.map +1 -0
  4. package/dist/src/adapters/github-action.d.ts +9 -0
  5. package/dist/src/adapters/github-action.js +94 -0
  6. package/dist/src/adapters/github-action.js.map +1 -0
  7. package/dist/{html-reporter → src/adapters/html-reporter}/scripts.d.ts +1 -2
  8. package/dist/{adapters → src/adapters}/html-reporter/scripts.js.map +1 -1
  9. package/dist/src/adapters/html-reporter/sections/agents.d.ts +2 -0
  10. package/dist/{html-reporter → src/adapters/html-reporter}/sections/agents.js +8 -7
  11. package/dist/src/adapters/html-reporter/sections/agents.js.map +1 -0
  12. package/dist/{html-reporter → src/adapters/html-reporter}/sections/anti-patterns.d.ts +1 -2
  13. package/dist/src/adapters/html-reporter/sections/anti-patterns.js.map +1 -0
  14. package/dist/{html-reporter → src/adapters/html-reporter}/sections/header.d.ts +1 -2
  15. package/dist/{adapters → src/adapters}/html-reporter/sections/header.js +1 -1
  16. package/dist/src/adapters/html-reporter/sections/header.js.map +1 -0
  17. package/dist/{html-reporter → src/adapters/html-reporter}/sections/layers.d.ts +1 -2
  18. package/dist/src/adapters/html-reporter/sections/layers.js.map +1 -0
  19. package/dist/src/adapters/html-reporter/sections/overview.d.ts +2 -0
  20. package/dist/src/adapters/html-reporter/sections/overview.js.map +1 -0
  21. package/dist/{html-reporter → src/adapters/html-reporter}/sections/refactoring-plan.d.ts +1 -2
  22. package/dist/src/adapters/html-reporter/sections/refactoring-plan.js.map +1 -0
  23. package/dist/{html-reporter → src/adapters/html-reporter}/sections/score.d.ts +1 -2
  24. package/dist/{adapters → src/adapters}/html-reporter/sections/score.js +1 -0
  25. package/dist/src/adapters/html-reporter/sections/score.js.map +1 -0
  26. package/dist/{adapters → src/adapters}/html-reporter/sections/suggestions.d.ts +0 -1
  27. package/dist/src/adapters/html-reporter/sections/suggestions.js.map +1 -0
  28. package/dist/{adapters → src/adapters}/html-reporter/styles.d.ts +0 -1
  29. package/dist/{adapters → src/adapters}/html-reporter/styles.js.map +1 -1
  30. package/dist/{adapters → src/adapters}/html-reporter/utils_adapters.d.ts +1 -2
  31. package/dist/src/adapters/html-reporter/utils_adapters.js.map +1 -0
  32. package/dist/{adapters → src/adapters}/html-reporter/utils_sections.d.ts +0 -1
  33. package/dist/src/adapters/html-reporter/utils_sections.js.map +1 -0
  34. package/dist/{html-reporter.d.ts → src/adapters/html-reporter.d.ts} +3 -3
  35. package/dist/{html-reporter.js → src/adapters/html-reporter.js} +11 -11
  36. package/dist/src/adapters/html-reporter.js.map +1 -0
  37. package/dist/src/adapters/progress-logger.d.ts +55 -0
  38. package/dist/src/adapters/progress-logger.js +200 -0
  39. package/dist/src/adapters/progress-logger.js.map +1 -0
  40. package/dist/{refactor-reporter.d.ts → src/adapters/refactor-reporter.d.ts} +1 -2
  41. package/dist/{refactor-reporter.js → src/adapters/refactor-reporter.js} +1 -1
  42. package/dist/src/adapters/refactor-reporter.js.map +1 -0
  43. package/dist/{reporter.d.ts → src/adapters/reporter.d.ts} +1 -2
  44. package/dist/src/adapters/reporter.js.map +1 -0
  45. package/dist/src/core/GenesisTerminal.d.ts +9 -0
  46. package/dist/src/core/GenesisTerminal.js +196 -0
  47. package/dist/src/core/GenesisTerminal.js.map +1 -0
  48. package/dist/{core → src/core}/architect.d.ts +3 -2
  49. package/dist/{core → src/core}/architect.js +32 -12
  50. package/dist/src/core/architect.js.map +1 -0
  51. package/dist/src/core/interactive-refactor.d.ts +84 -0
  52. package/dist/src/core/interactive-refactor.js +440 -0
  53. package/dist/src/core/interactive-refactor.js.map +1 -0
  54. package/dist/tests/architect-adapter-enrichment.test.d.ts +1 -0
  55. package/dist/tests/architect-adapter-enrichment.test.js +11 -0
  56. package/dist/tests/architect-adapter-enrichment.test.js.map +1 -0
  57. package/dist/tests/github-action.test.d.ts +1 -0
  58. package/dist/tests/github-action.test.js +92 -0
  59. package/dist/tests/github-action.test.js.map +1 -0
  60. package/dist/tests/interactive-refactor.test.d.ts +7 -0
  61. package/dist/tests/interactive-refactor.test.js +125 -0
  62. package/dist/tests/interactive-refactor.test.js.map +1 -0
  63. package/package.json +15 -65
  64. package/src/adapters/cli.ts +457 -244
  65. package/src/adapters/github-action.ts +109 -0
  66. package/src/adapters/html-reporter/scripts.ts +1 -1
  67. package/src/adapters/html-reporter/sections/agents.ts +12 -11
  68. package/src/adapters/html-reporter/sections/anti-patterns.ts +1 -1
  69. package/src/adapters/html-reporter/sections/header.ts +2 -2
  70. package/src/adapters/html-reporter/sections/layers.ts +4 -4
  71. package/src/adapters/html-reporter/sections/overview.ts +1 -1
  72. package/src/adapters/html-reporter/sections/refactoring-plan.ts +1 -1
  73. package/src/adapters/html-reporter/sections/score.ts +2 -1
  74. package/src/adapters/html-reporter/utils_adapters.ts +4 -4
  75. package/src/adapters/html-reporter.ts +14 -1
  76. package/src/adapters/progress-logger.ts +236 -0
  77. package/src/adapters/refactor-reporter.ts +4 -4
  78. package/src/adapters/reporter.ts +3 -3
  79. package/src/core/GenesisTerminal.ts +221 -0
  80. package/src/core/architect.ts +38 -13
  81. package/src/core/interactive-refactor.ts +552 -0
  82. package/tests/github-action.test.ts +109 -0
  83. package/tests/interactive-refactor.test.ts +141 -0
  84. package/tsconfig.json +12 -19
  85. package/.agent/INDEX.md +0 -197
  86. package/.agent/agents/AGENT-ORCHESTRATOR.md +0 -408
  87. package/.agent/agents/QA-TEST-ENGINEER.md +0 -152
  88. package/.agent/agents/SECURITY-AUDITOR.md +0 -87
  89. package/.agent/agents/TECH-DEBT-CONTROLLER.md +0 -154
  90. package/.agent/agents/TYPESCRIPT-BACKEND-DEVELOPER.md +0 -484
  91. package/.agent/guards/CODE-REVIEW-CHECKLIST.md +0 -94
  92. package/.agent/guards/PREFLIGHT.md +0 -200
  93. package/.agent/guards/QUALITY-GATES.md +0 -212
  94. package/.agent/hooks/post-analysis.sh +0 -64
  95. package/.agent/hooks/pre-commit.sh +0 -68
  96. package/.agent/hooks/pre-push.sh +0 -59
  97. package/.agent/rules/00-general.md +0 -229
  98. package/.agent/rules/01-architecture.md +0 -182
  99. package/.agent/rules/02-security.md +0 -388
  100. package/.agent/skills/ARCHITECT-INTEGRATION.md +0 -103
  101. package/.agent/skills/CI-PIPELINE.md +0 -113
  102. package/.agent/skills/PROJECT-PATTERNS.md +0 -62
  103. package/.agent/templates/ADR.md +0 -95
  104. package/.agent/templates/BDD.md +0 -57
  105. package/.agent/templates/C4.md +0 -67
  106. package/.agent/templates/TDD.md +0 -86
  107. package/.agent/templates/THREAT-MODEL.md +0 -63
  108. package/.agent/workflows/fix-bug.md +0 -228
  109. package/.agent/workflows/new-feature.md +0 -311
  110. package/.agent/workflows/review.md +0 -95
  111. package/.github/workflows/ci.yml +0 -43
  112. package/.github/workflows/publish.yml +0 -40
  113. package/CONTRIBUTING.md +0 -140
  114. package/LICENSE +0 -21
  115. package/PROJECT_STRUCTURE.txt +0 -168
  116. package/README.md +0 -261
  117. package/architect-report--girardelli-architect.json +0 -5332
  118. package/architect-run.sh +0 -427
  119. package/assets/banner-v3.html +0 -561
  120. package/debug.js +0 -6
  121. package/dist/adapters/cli.d.ts.map +0 -1
  122. package/dist/adapters/cli.js +0 -446
  123. package/dist/adapters/cli.js.map +0 -1
  124. package/dist/adapters/html-reporter/scripts.d.ts +0 -6
  125. package/dist/adapters/html-reporter/scripts.d.ts.map +0 -1
  126. package/dist/adapters/html-reporter/sections/agents.d.ts +0 -3
  127. package/dist/adapters/html-reporter/sections/agents.d.ts.map +0 -1
  128. package/dist/adapters/html-reporter/sections/agents.js +0 -259
  129. package/dist/adapters/html-reporter/sections/agents.js.map +0 -1
  130. package/dist/adapters/html-reporter/sections/anti-patterns.d.ts +0 -14
  131. package/dist/adapters/html-reporter/sections/anti-patterns.d.ts.map +0 -1
  132. package/dist/adapters/html-reporter/sections/anti-patterns.js.map +0 -1
  133. package/dist/adapters/html-reporter/sections/header.d.ts +0 -4
  134. package/dist/adapters/html-reporter/sections/header.d.ts.map +0 -1
  135. package/dist/adapters/html-reporter/sections/header.js.map +0 -1
  136. package/dist/adapters/html-reporter/sections/layers.d.ts +0 -10
  137. package/dist/adapters/html-reporter/sections/layers.d.ts.map +0 -1
  138. package/dist/adapters/html-reporter/sections/layers.js.map +0 -1
  139. package/dist/adapters/html-reporter/sections/overview.d.ts +0 -3
  140. package/dist/adapters/html-reporter/sections/overview.d.ts.map +0 -1
  141. package/dist/adapters/html-reporter/sections/overview.js.map +0 -1
  142. package/dist/adapters/html-reporter/sections/refactoring-plan.d.ts +0 -4
  143. package/dist/adapters/html-reporter/sections/refactoring-plan.d.ts.map +0 -1
  144. package/dist/adapters/html-reporter/sections/refactoring-plan.js.map +0 -1
  145. package/dist/adapters/html-reporter/sections/score.d.ts +0 -8
  146. package/dist/adapters/html-reporter/sections/score.d.ts.map +0 -1
  147. package/dist/adapters/html-reporter/sections/score.js.map +0 -1
  148. package/dist/adapters/html-reporter/sections/suggestions.d.ts.map +0 -1
  149. package/dist/adapters/html-reporter/sections/suggestions.js.map +0 -1
  150. package/dist/adapters/html-reporter/styles.d.ts.map +0 -1
  151. package/dist/adapters/html-reporter/utils.d.ts +0 -27
  152. package/dist/adapters/html-reporter/utils.d.ts.map +0 -1
  153. package/dist/adapters/html-reporter/utils.js +0 -82
  154. package/dist/adapters/html-reporter/utils.js.map +0 -1
  155. package/dist/adapters/html-reporter/utils_adapters.d.ts.map +0 -1
  156. package/dist/adapters/html-reporter/utils_adapters.js.map +0 -1
  157. package/dist/adapters/html-reporter/utils_sections.d.ts.map +0 -1
  158. package/dist/adapters/html-reporter/utils_sections.js.map +0 -1
  159. package/dist/adapters/html-reporter.d.ts +0 -9
  160. package/dist/adapters/html-reporter.d.ts.map +0 -1
  161. package/dist/adapters/html-reporter.js +0 -87
  162. package/dist/adapters/html-reporter.js.map +0 -1
  163. package/dist/adapters/html-reporter_deps.d.ts +0 -15
  164. package/dist/adapters/html-reporter_deps.d.ts.map +0 -1
  165. package/dist/adapters/html-reporter_deps.js +0 -12
  166. package/dist/adapters/html-reporter_deps.js.map +0 -1
  167. package/dist/adapters/refactor-reporter.d.ts +0 -20
  168. package/dist/adapters/refactor-reporter.d.ts.map +0 -1
  169. package/dist/adapters/refactor-reporter.js +0 -389
  170. package/dist/adapters/refactor-reporter.js.map +0 -1
  171. package/dist/adapters/reporter.d.ts +0 -13
  172. package/dist/adapters/reporter.d.ts.map +0 -1
  173. package/dist/adapters/reporter.js.map +0 -1
  174. package/dist/agent-generator/context-enricher.d.ts +0 -15
  175. package/dist/agent-generator/context-enricher.d.ts.map +0 -1
  176. package/dist/agent-generator/context-enricher.js +0 -53
  177. package/dist/agent-generator/context-enricher.js.map +0 -1
  178. package/dist/agent-generator/detectors/base-detector.d.ts +0 -9
  179. package/dist/agent-generator/detectors/base-detector.d.ts.map +0 -1
  180. package/dist/agent-generator/detectors/base-detector.js +0 -12
  181. package/dist/agent-generator/detectors/base-detector.js.map +0 -1
  182. package/dist/agent-generator/detectors/dart-detector.d.ts +0 -6
  183. package/dist/agent-generator/detectors/dart-detector.d.ts.map +0 -1
  184. package/dist/agent-generator/detectors/dart-detector.js +0 -15
  185. package/dist/agent-generator/detectors/dart-detector.js.map +0 -1
  186. package/dist/agent-generator/detectors/framework-registry.d.ts +0 -6
  187. package/dist/agent-generator/detectors/framework-registry.d.ts.map +0 -1
  188. package/dist/agent-generator/detectors/framework-registry.js +0 -81
  189. package/dist/agent-generator/detectors/framework-registry.js.map +0 -1
  190. package/dist/agent-generator/detectors/go-detector.d.ts +0 -6
  191. package/dist/agent-generator/detectors/go-detector.d.ts.map +0 -1
  192. package/dist/agent-generator/detectors/go-detector.js +0 -25
  193. package/dist/agent-generator/detectors/go-detector.js.map +0 -1
  194. package/dist/agent-generator/detectors/java-detector.d.ts +0 -6
  195. package/dist/agent-generator/detectors/java-detector.d.ts.map +0 -1
  196. package/dist/agent-generator/detectors/java-detector.js +0 -44
  197. package/dist/agent-generator/detectors/java-detector.js.map +0 -1
  198. package/dist/agent-generator/detectors/node-detector.d.ts +0 -6
  199. package/dist/agent-generator/detectors/node-detector.d.ts.map +0 -1
  200. package/dist/agent-generator/detectors/node-detector.js +0 -28
  201. package/dist/agent-generator/detectors/node-detector.js.map +0 -1
  202. package/dist/agent-generator/detectors/php-detector.d.ts +0 -6
  203. package/dist/agent-generator/detectors/php-detector.d.ts.map +0 -1
  204. package/dist/agent-generator/detectors/php-detector.js +0 -28
  205. package/dist/agent-generator/detectors/php-detector.js.map +0 -1
  206. package/dist/agent-generator/detectors/python-detector.d.ts +0 -8
  207. package/dist/agent-generator/detectors/python-detector.d.ts.map +0 -1
  208. package/dist/agent-generator/detectors/python-detector.js +0 -116
  209. package/dist/agent-generator/detectors/python-detector.js.map +0 -1
  210. package/dist/agent-generator/detectors/ruby-detector.d.ts +0 -6
  211. package/dist/agent-generator/detectors/ruby-detector.d.ts.map +0 -1
  212. package/dist/agent-generator/detectors/ruby-detector.js +0 -22
  213. package/dist/agent-generator/detectors/ruby-detector.js.map +0 -1
  214. package/dist/agent-generator/detectors/rust-detector.d.ts +0 -6
  215. package/dist/agent-generator/detectors/rust-detector.d.ts.map +0 -1
  216. package/dist/agent-generator/detectors/rust-detector.js +0 -18
  217. package/dist/agent-generator/detectors/rust-detector.js.map +0 -1
  218. package/dist/agent-generator/detectors/structure-detector.d.ts +0 -5
  219. package/dist/agent-generator/detectors/structure-detector.d.ts.map +0 -1
  220. package/dist/agent-generator/detectors/structure-detector.js +0 -35
  221. package/dist/agent-generator/detectors/structure-detector.js.map +0 -1
  222. package/dist/agent-generator/detectors/toolchain-detector.d.ts +0 -6
  223. package/dist/agent-generator/detectors/toolchain-detector.d.ts.map +0 -1
  224. package/dist/agent-generator/detectors/toolchain-detector.js +0 -163
  225. package/dist/agent-generator/detectors/toolchain-detector.js.map +0 -1
  226. package/dist/agent-generator/domain-inferrer.d.ts +0 -52
  227. package/dist/agent-generator/domain-inferrer.d.ts.map +0 -1
  228. package/dist/agent-generator/domain-inferrer.js +0 -585
  229. package/dist/agent-generator/domain-inferrer.js.map +0 -1
  230. package/dist/agent-generator/engines/audit-engine.d.ts +0 -7
  231. package/dist/agent-generator/engines/audit-engine.d.ts.map +0 -1
  232. package/dist/agent-generator/engines/audit-engine.js +0 -84
  233. package/dist/agent-generator/engines/audit-engine.js.map +0 -1
  234. package/dist/agent-generator/engines/context-builder.d.ts +0 -11
  235. package/dist/agent-generator/engines/context-builder.d.ts.map +0 -1
  236. package/dist/agent-generator/engines/context-builder.js +0 -86
  237. package/dist/agent-generator/engines/context-builder.js.map +0 -1
  238. package/dist/agent-generator/engines/generation-engine.d.ts +0 -9
  239. package/dist/agent-generator/engines/generation-engine.d.ts.map +0 -1
  240. package/dist/agent-generator/engines/generation-engine.js +0 -177
  241. package/dist/agent-generator/engines/generation-engine.js.map +0 -1
  242. package/dist/agent-generator/engines/suggestion-engine.d.ts +0 -15
  243. package/dist/agent-generator/engines/suggestion-engine.d.ts.map +0 -1
  244. package/dist/agent-generator/engines/suggestion-engine.js +0 -176
  245. package/dist/agent-generator/engines/suggestion-engine.js.map +0 -1
  246. package/dist/agent-generator/enrichers/analysis-helpers.d.ts +0 -9
  247. package/dist/agent-generator/enrichers/analysis-helpers.d.ts.map +0 -1
  248. package/dist/agent-generator/enrichers/analysis-helpers.js +0 -51
  249. package/dist/agent-generator/enrichers/analysis-helpers.js.map +0 -1
  250. package/dist/agent-generator/enrichers/description-generator.d.ts +0 -5
  251. package/dist/agent-generator/enrichers/description-generator.d.ts.map +0 -1
  252. package/dist/agent-generator/enrichers/description-generator.js +0 -81
  253. package/dist/agent-generator/enrichers/description-generator.js.map +0 -1
  254. package/dist/agent-generator/enrichers/endpoint-extractor.d.ts +0 -8
  255. package/dist/agent-generator/enrichers/endpoint-extractor.d.ts.map +0 -1
  256. package/dist/agent-generator/enrichers/endpoint-extractor.js +0 -91
  257. package/dist/agent-generator/enrichers/endpoint-extractor.js.map +0 -1
  258. package/dist/agent-generator/enrichers/layer-classifier.d.ts +0 -13
  259. package/dist/agent-generator/enrichers/layer-classifier.d.ts.map +0 -1
  260. package/dist/agent-generator/enrichers/layer-classifier.js +0 -150
  261. package/dist/agent-generator/enrichers/layer-classifier.js.map +0 -1
  262. package/dist/agent-generator/enrichers/module-extractor.d.ts +0 -11
  263. package/dist/agent-generator/enrichers/module-extractor.d.ts.map +0 -1
  264. package/dist/agent-generator/enrichers/module-extractor.js +0 -174
  265. package/dist/agent-generator/enrichers/module-extractor.js.map +0 -1
  266. package/dist/agent-generator/framework-detector.d.ts +0 -18
  267. package/dist/agent-generator/framework-detector.d.ts.map +0 -1
  268. package/dist/agent-generator/framework-detector.js +0 -58
  269. package/dist/agent-generator/framework-detector.js.map +0 -1
  270. package/dist/agent-generator/index.d.ts +0 -22
  271. package/dist/agent-generator/index.d.ts.map +0 -1
  272. package/dist/agent-generator/index.js +0 -39
  273. package/dist/agent-generator/index.js.map +0 -1
  274. package/dist/agent-generator/stack-detector.d.ts +0 -14
  275. package/dist/agent-generator/stack-detector.d.ts.map +0 -1
  276. package/dist/agent-generator/stack-detector.js +0 -124
  277. package/dist/agent-generator/stack-detector.js.map +0 -1
  278. package/dist/agent-generator/templates/core/agents.d.ts +0 -17
  279. package/dist/agent-generator/templates/core/agents.d.ts.map +0 -1
  280. package/dist/agent-generator/templates/core/agents.js +0 -1256
  281. package/dist/agent-generator/templates/core/agents.js.map +0 -1
  282. package/dist/agent-generator/templates/core/architecture-rules.d.ts +0 -7
  283. package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +0 -1
  284. package/dist/agent-generator/templates/core/architecture-rules.js +0 -274
  285. package/dist/agent-generator/templates/core/architecture-rules.js.map +0 -1
  286. package/dist/agent-generator/templates/core/general-rules.d.ts +0 -8
  287. package/dist/agent-generator/templates/core/general-rules.d.ts.map +0 -1
  288. package/dist/agent-generator/templates/core/general-rules.js +0 -301
  289. package/dist/agent-generator/templates/core/general-rules.js.map +0 -1
  290. package/dist/agent-generator/templates/core/hooks-generator.d.ts +0 -21
  291. package/dist/agent-generator/templates/core/hooks-generator.d.ts.map +0 -1
  292. package/dist/agent-generator/templates/core/hooks-generator.js +0 -233
  293. package/dist/agent-generator/templates/core/hooks-generator.js.map +0 -1
  294. package/dist/agent-generator/templates/core/index-md.d.ts +0 -7
  295. package/dist/agent-generator/templates/core/index-md.d.ts.map +0 -1
  296. package/dist/agent-generator/templates/core/index-md.js +0 -246
  297. package/dist/agent-generator/templates/core/index-md.js.map +0 -1
  298. package/dist/agent-generator/templates/core/orchestrator.d.ts +0 -8
  299. package/dist/agent-generator/templates/core/orchestrator.d.ts.map +0 -1
  300. package/dist/agent-generator/templates/core/orchestrator.js +0 -422
  301. package/dist/agent-generator/templates/core/orchestrator.js.map +0 -1
  302. package/dist/agent-generator/templates/core/preflight.d.ts +0 -8
  303. package/dist/agent-generator/templates/core/preflight.d.ts.map +0 -1
  304. package/dist/agent-generator/templates/core/preflight.js +0 -213
  305. package/dist/agent-generator/templates/core/preflight.js.map +0 -1
  306. package/dist/agent-generator/templates/core/quality-gates.d.ts +0 -11
  307. package/dist/agent-generator/templates/core/quality-gates.d.ts.map +0 -1
  308. package/dist/agent-generator/templates/core/quality-gates.js +0 -254
  309. package/dist/agent-generator/templates/core/quality-gates.js.map +0 -1
  310. package/dist/agent-generator/templates/core/security-rules.d.ts +0 -7
  311. package/dist/agent-generator/templates/core/security-rules.d.ts.map +0 -1
  312. package/dist/agent-generator/templates/core/security-rules.js +0 -528
  313. package/dist/agent-generator/templates/core/security-rules.js.map +0 -1
  314. package/dist/agent-generator/templates/core/skills-generator.d.ts +0 -19
  315. package/dist/agent-generator/templates/core/skills-generator.d.ts.map +0 -1
  316. package/dist/agent-generator/templates/core/skills-generator.js +0 -546
  317. package/dist/agent-generator/templates/core/skills-generator.js.map +0 -1
  318. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +0 -7
  319. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +0 -1
  320. package/dist/agent-generator/templates/core/workflow-fix-bug.js +0 -237
  321. package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +0 -1
  322. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +0 -8
  323. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +0 -1
  324. package/dist/agent-generator/templates/core/workflow-new-feature.js +0 -321
  325. package/dist/agent-generator/templates/core/workflow-new-feature.js.map +0 -1
  326. package/dist/agent-generator/templates/core/workflow-review.d.ts +0 -7
  327. package/dist/agent-generator/templates/core/workflow-review.d.ts.map +0 -1
  328. package/dist/agent-generator/templates/core/workflow-review.js +0 -104
  329. package/dist/agent-generator/templates/core/workflow-review.js.map +0 -1
  330. package/dist/agent-generator/templates/domain/index.d.ts +0 -22
  331. package/dist/agent-generator/templates/domain/index.d.ts.map +0 -1
  332. package/dist/agent-generator/templates/domain/index.js +0 -1176
  333. package/dist/agent-generator/templates/domain/index.js.map +0 -1
  334. package/dist/agent-generator/templates/helpers/base-helpers.d.ts +0 -11
  335. package/dist/agent-generator/templates/helpers/base-helpers.d.ts.map +0 -1
  336. package/dist/agent-generator/templates/helpers/base-helpers.js +0 -20
  337. package/dist/agent-generator/templates/helpers/base-helpers.js.map +0 -1
  338. package/dist/agent-generator/templates/helpers/cross-ref-helpers.d.ts +0 -3
  339. package/dist/agent-generator/templates/helpers/cross-ref-helpers.d.ts.map +0 -1
  340. package/dist/agent-generator/templates/helpers/cross-ref-helpers.js +0 -77
  341. package/dist/agent-generator/templates/helpers/cross-ref-helpers.js.map +0 -1
  342. package/dist/agent-generator/templates/helpers/security-helpers.d.ts +0 -3
  343. package/dist/agent-generator/templates/helpers/security-helpers.d.ts.map +0 -1
  344. package/dist/agent-generator/templates/helpers/security-helpers.js +0 -182
  345. package/dist/agent-generator/templates/helpers/security-helpers.js.map +0 -1
  346. package/dist/agent-generator/templates/helpers/stack-helpers.d.ts +0 -5
  347. package/dist/agent-generator/templates/helpers/stack-helpers.d.ts.map +0 -1
  348. package/dist/agent-generator/templates/helpers/stack-helpers.js +0 -69
  349. package/dist/agent-generator/templates/helpers/stack-helpers.js.map +0 -1
  350. package/dist/agent-generator/templates/helpers/structure-helpers.d.ts +0 -3
  351. package/dist/agent-generator/templates/helpers/structure-helpers.d.ts.map +0 -1
  352. package/dist/agent-generator/templates/helpers/structure-helpers.js +0 -275
  353. package/dist/agent-generator/templates/helpers/structure-helpers.js.map +0 -1
  354. package/dist/agent-generator/templates/helpers/summary-helpers.d.ts +0 -7
  355. package/dist/agent-generator/templates/helpers/summary-helpers.d.ts.map +0 -1
  356. package/dist/agent-generator/templates/helpers/summary-helpers.js +0 -56
  357. package/dist/agent-generator/templates/helpers/summary-helpers.js.map +0 -1
  358. package/dist/agent-generator/templates/stack/index.d.ts +0 -8
  359. package/dist/agent-generator/templates/stack/index.d.ts.map +0 -1
  360. package/dist/agent-generator/templates/stack/index.js +0 -695
  361. package/dist/agent-generator/templates/stack/index.js.map +0 -1
  362. package/dist/agent-generator/templates/template-helpers.d.ts +0 -12
  363. package/dist/agent-generator/templates/template-helpers.d.ts.map +0 -1
  364. package/dist/agent-generator/templates/template-helpers.js +0 -12
  365. package/dist/agent-generator/templates/template-helpers.js.map +0 -1
  366. package/dist/agent-generator/types.d.ts +0 -196
  367. package/dist/agent-generator/types.d.ts.map +0 -1
  368. package/dist/agent-generator/types.js +0 -27
  369. package/dist/agent-generator/types.js.map +0 -1
  370. package/dist/analyzer.d.ts +0 -38
  371. package/dist/analyzer.d.ts.map +0 -1
  372. package/dist/analyzer.js +0 -383
  373. package/dist/analyzer.js.map +0 -1
  374. package/dist/analyzers/forecast.d.ts +0 -85
  375. package/dist/analyzers/forecast.d.ts.map +0 -1
  376. package/dist/analyzers/forecast.js +0 -337
  377. package/dist/analyzers/forecast.js.map +0 -1
  378. package/dist/analyzers/git-cache.d.ts +0 -7
  379. package/dist/analyzers/git-cache.d.ts.map +0 -1
  380. package/dist/analyzers/git-cache.js +0 -41
  381. package/dist/analyzers/git-cache.js.map +0 -1
  382. package/dist/analyzers/git-history.d.ts +0 -113
  383. package/dist/analyzers/git-history.d.ts.map +0 -1
  384. package/dist/analyzers/git-history.js +0 -339
  385. package/dist/analyzers/git-history.js.map +0 -1
  386. package/dist/analyzers/index.d.ts +0 -10
  387. package/dist/analyzers/index.d.ts.map +0 -1
  388. package/dist/analyzers/index.js +0 -7
  389. package/dist/analyzers/index.js.map +0 -1
  390. package/dist/analyzers/temporal-scorer.d.ts +0 -72
  391. package/dist/analyzers/temporal-scorer.d.ts.map +0 -1
  392. package/dist/analyzers/temporal-scorer.js +0 -140
  393. package/dist/analyzers/temporal-scorer.js.map +0 -1
  394. package/dist/anti-patterns.d.ts +0 -24
  395. package/dist/anti-patterns.d.ts.map +0 -1
  396. package/dist/anti-patterns.js +0 -230
  397. package/dist/anti-patterns.js.map +0 -1
  398. package/dist/cli.d.ts +0 -14
  399. package/dist/cli.d.ts.map +0 -1
  400. package/dist/cli.js.map +0 -1
  401. package/dist/config.d.ts +0 -12
  402. package/dist/config.d.ts.map +0 -1
  403. package/dist/config.js +0 -110
  404. package/dist/config.js.map +0 -1
  405. package/dist/core/agent-generator/context-enricher.d.ts +0 -18
  406. package/dist/core/agent-generator/context-enricher.d.ts.map +0 -1
  407. package/dist/core/agent-generator/context-enricher.js +0 -53
  408. package/dist/core/agent-generator/context-enricher.js.map +0 -1
  409. package/dist/core/agent-generator/detectors/base-detector.d.ts +0 -9
  410. package/dist/core/agent-generator/detectors/base-detector.d.ts.map +0 -1
  411. package/dist/core/agent-generator/detectors/base-detector.js +0 -12
  412. package/dist/core/agent-generator/detectors/base-detector.js.map +0 -1
  413. package/dist/core/agent-generator/detectors/dart-detector.d.ts +0 -6
  414. package/dist/core/agent-generator/detectors/dart-detector.d.ts.map +0 -1
  415. package/dist/core/agent-generator/detectors/dart-detector.js +0 -15
  416. package/dist/core/agent-generator/detectors/dart-detector.js.map +0 -1
  417. package/dist/core/agent-generator/detectors/framework-registry.d.ts +0 -6
  418. package/dist/core/agent-generator/detectors/framework-registry.d.ts.map +0 -1
  419. package/dist/core/agent-generator/detectors/framework-registry.js +0 -81
  420. package/dist/core/agent-generator/detectors/framework-registry.js.map +0 -1
  421. package/dist/core/agent-generator/detectors/go-detector.d.ts +0 -6
  422. package/dist/core/agent-generator/detectors/go-detector.d.ts.map +0 -1
  423. package/dist/core/agent-generator/detectors/go-detector.js +0 -25
  424. package/dist/core/agent-generator/detectors/go-detector.js.map +0 -1
  425. package/dist/core/agent-generator/detectors/java-detector.d.ts +0 -6
  426. package/dist/core/agent-generator/detectors/java-detector.d.ts.map +0 -1
  427. package/dist/core/agent-generator/detectors/java-detector.js +0 -44
  428. package/dist/core/agent-generator/detectors/java-detector.js.map +0 -1
  429. package/dist/core/agent-generator/detectors/node-detector.d.ts +0 -6
  430. package/dist/core/agent-generator/detectors/node-detector.d.ts.map +0 -1
  431. package/dist/core/agent-generator/detectors/node-detector.js +0 -28
  432. package/dist/core/agent-generator/detectors/node-detector.js.map +0 -1
  433. package/dist/core/agent-generator/detectors/php-detector.d.ts +0 -6
  434. package/dist/core/agent-generator/detectors/php-detector.d.ts.map +0 -1
  435. package/dist/core/agent-generator/detectors/php-detector.js +0 -28
  436. package/dist/core/agent-generator/detectors/php-detector.js.map +0 -1
  437. package/dist/core/agent-generator/detectors/python-detector.d.ts +0 -8
  438. package/dist/core/agent-generator/detectors/python-detector.d.ts.map +0 -1
  439. package/dist/core/agent-generator/detectors/python-detector.js +0 -116
  440. package/dist/core/agent-generator/detectors/python-detector.js.map +0 -1
  441. package/dist/core/agent-generator/detectors/ruby-detector.d.ts +0 -6
  442. package/dist/core/agent-generator/detectors/ruby-detector.d.ts.map +0 -1
  443. package/dist/core/agent-generator/detectors/ruby-detector.js +0 -22
  444. package/dist/core/agent-generator/detectors/ruby-detector.js.map +0 -1
  445. package/dist/core/agent-generator/detectors/rust-detector.d.ts +0 -6
  446. package/dist/core/agent-generator/detectors/rust-detector.d.ts.map +0 -1
  447. package/dist/core/agent-generator/detectors/rust-detector.js +0 -18
  448. package/dist/core/agent-generator/detectors/rust-detector.js.map +0 -1
  449. package/dist/core/agent-generator/detectors/structure-detector.d.ts +0 -5
  450. package/dist/core/agent-generator/detectors/structure-detector.d.ts.map +0 -1
  451. package/dist/core/agent-generator/detectors/structure-detector.js +0 -35
  452. package/dist/core/agent-generator/detectors/structure-detector.js.map +0 -1
  453. package/dist/core/agent-generator/detectors/toolchain-detector.d.ts +0 -6
  454. package/dist/core/agent-generator/detectors/toolchain-detector.d.ts.map +0 -1
  455. package/dist/core/agent-generator/detectors/toolchain-detector.js +0 -163
  456. package/dist/core/agent-generator/detectors/toolchain-detector.js.map +0 -1
  457. package/dist/core/agent-generator/domain-inferrer.d.ts +0 -52
  458. package/dist/core/agent-generator/domain-inferrer.d.ts.map +0 -1
  459. package/dist/core/agent-generator/domain-inferrer.js +0 -585
  460. package/dist/core/agent-generator/domain-inferrer.js.map +0 -1
  461. package/dist/core/agent-generator/engines/audit-engine.d.ts +0 -9
  462. package/dist/core/agent-generator/engines/audit-engine.d.ts.map +0 -1
  463. package/dist/core/agent-generator/engines/audit-engine.js +0 -84
  464. package/dist/core/agent-generator/engines/audit-engine.js.map +0 -1
  465. package/dist/core/agent-generator/engines/context-builder.d.ts +0 -13
  466. package/dist/core/agent-generator/engines/context-builder.d.ts.map +0 -1
  467. package/dist/core/agent-generator/engines/context-builder.js +0 -86
  468. package/dist/core/agent-generator/engines/context-builder.js.map +0 -1
  469. package/dist/core/agent-generator/engines/generation-engine.d.ts +0 -8
  470. package/dist/core/agent-generator/engines/generation-engine.d.ts.map +0 -1
  471. package/dist/core/agent-generator/engines/generation-engine.js +0 -162
  472. package/dist/core/agent-generator/engines/generation-engine.js.map +0 -1
  473. package/dist/core/agent-generator/engines/generation-engine_deps.d.ts +0 -22
  474. package/dist/core/agent-generator/engines/generation-engine_deps.d.ts.map +0 -1
  475. package/dist/core/agent-generator/engines/generation-engine_deps.js +0 -17
  476. package/dist/core/agent-generator/engines/generation-engine_deps.js.map +0 -1
  477. package/dist/core/agent-generator/engines/suggestion-engine.d.ts +0 -14
  478. package/dist/core/agent-generator/engines/suggestion-engine.d.ts.map +0 -1
  479. package/dist/core/agent-generator/engines/suggestion-engine.js +0 -173
  480. package/dist/core/agent-generator/engines/suggestion-engine.js.map +0 -1
  481. package/dist/core/agent-generator/engines/suggestion-engine_deps.d.ts +0 -9
  482. package/dist/core/agent-generator/engines/suggestion-engine_deps.d.ts.map +0 -1
  483. package/dist/core/agent-generator/engines/suggestion-engine_deps.js +0 -5
  484. package/dist/core/agent-generator/engines/suggestion-engine_deps.js.map +0 -1
  485. package/dist/core/agent-generator/enrichers/analysis-helpers.d.ts +0 -10
  486. package/dist/core/agent-generator/enrichers/analysis-helpers.d.ts.map +0 -1
  487. package/dist/core/agent-generator/enrichers/analysis-helpers.js +0 -51
  488. package/dist/core/agent-generator/enrichers/analysis-helpers.js.map +0 -1
  489. package/dist/core/agent-generator/enrichers/description-generator.d.ts +0 -5
  490. package/dist/core/agent-generator/enrichers/description-generator.d.ts.map +0 -1
  491. package/dist/core/agent-generator/enrichers/description-generator.js +0 -81
  492. package/dist/core/agent-generator/enrichers/description-generator.js.map +0 -1
  493. package/dist/core/agent-generator/enrichers/endpoint-extractor.d.ts +0 -8
  494. package/dist/core/agent-generator/enrichers/endpoint-extractor.d.ts.map +0 -1
  495. package/dist/core/agent-generator/enrichers/endpoint-extractor.js +0 -91
  496. package/dist/core/agent-generator/enrichers/endpoint-extractor.js.map +0 -1
  497. package/dist/core/agent-generator/enrichers/layer-classifier.d.ts +0 -13
  498. package/dist/core/agent-generator/enrichers/layer-classifier.d.ts.map +0 -1
  499. package/dist/core/agent-generator/enrichers/layer-classifier.js +0 -150
  500. package/dist/core/agent-generator/enrichers/layer-classifier.js.map +0 -1
  501. package/dist/core/agent-generator/enrichers/module-extractor.d.ts +0 -11
  502. package/dist/core/agent-generator/enrichers/module-extractor.d.ts.map +0 -1
  503. package/dist/core/agent-generator/enrichers/module-extractor.js +0 -174
  504. package/dist/core/agent-generator/enrichers/module-extractor.js.map +0 -1
  505. package/dist/core/agent-generator/framework-detector.d.ts +0 -18
  506. package/dist/core/agent-generator/framework-detector.d.ts.map +0 -1
  507. package/dist/core/agent-generator/framework-detector.js +0 -58
  508. package/dist/core/agent-generator/framework-detector.js.map +0 -1
  509. package/dist/core/agent-generator/index.d.ts +0 -26
  510. package/dist/core/agent-generator/index.d.ts.map +0 -1
  511. package/dist/core/agent-generator/index.js +0 -39
  512. package/dist/core/agent-generator/index.js.map +0 -1
  513. package/dist/core/agent-generator/stack-detector.d.ts +0 -14
  514. package/dist/core/agent-generator/stack-detector.d.ts.map +0 -1
  515. package/dist/core/agent-generator/stack-detector.js +0 -124
  516. package/dist/core/agent-generator/stack-detector.js.map +0 -1
  517. package/dist/core/agent-generator/templates/core/agents.d.ts +0 -17
  518. package/dist/core/agent-generator/templates/core/agents.d.ts.map +0 -1
  519. package/dist/core/agent-generator/templates/core/agents.js +0 -1256
  520. package/dist/core/agent-generator/templates/core/agents.js.map +0 -1
  521. package/dist/core/agent-generator/templates/core/architecture-rules.d.ts +0 -7
  522. package/dist/core/agent-generator/templates/core/architecture-rules.d.ts.map +0 -1
  523. package/dist/core/agent-generator/templates/core/architecture-rules.js +0 -274
  524. package/dist/core/agent-generator/templates/core/architecture-rules.js.map +0 -1
  525. package/dist/core/agent-generator/templates/core/general-rules.d.ts +0 -8
  526. package/dist/core/agent-generator/templates/core/general-rules.d.ts.map +0 -1
  527. package/dist/core/agent-generator/templates/core/general-rules.js +0 -301
  528. package/dist/core/agent-generator/templates/core/general-rules.js.map +0 -1
  529. package/dist/core/agent-generator/templates/core/hooks-generator.d.ts +0 -21
  530. package/dist/core/agent-generator/templates/core/hooks-generator.d.ts.map +0 -1
  531. package/dist/core/agent-generator/templates/core/hooks-generator.js +0 -233
  532. package/dist/core/agent-generator/templates/core/hooks-generator.js.map +0 -1
  533. package/dist/core/agent-generator/templates/core/index-md.d.ts +0 -7
  534. package/dist/core/agent-generator/templates/core/index-md.d.ts.map +0 -1
  535. package/dist/core/agent-generator/templates/core/index-md.js +0 -246
  536. package/dist/core/agent-generator/templates/core/index-md.js.map +0 -1
  537. package/dist/core/agent-generator/templates/core/orchestrator.d.ts +0 -8
  538. package/dist/core/agent-generator/templates/core/orchestrator.d.ts.map +0 -1
  539. package/dist/core/agent-generator/templates/core/orchestrator.js +0 -422
  540. package/dist/core/agent-generator/templates/core/orchestrator.js.map +0 -1
  541. package/dist/core/agent-generator/templates/core/preflight.d.ts +0 -8
  542. package/dist/core/agent-generator/templates/core/preflight.d.ts.map +0 -1
  543. package/dist/core/agent-generator/templates/core/preflight.js +0 -213
  544. package/dist/core/agent-generator/templates/core/preflight.js.map +0 -1
  545. package/dist/core/agent-generator/templates/core/quality-gates.d.ts +0 -11
  546. package/dist/core/agent-generator/templates/core/quality-gates.d.ts.map +0 -1
  547. package/dist/core/agent-generator/templates/core/quality-gates.js +0 -254
  548. package/dist/core/agent-generator/templates/core/quality-gates.js.map +0 -1
  549. package/dist/core/agent-generator/templates/core/security-rules.d.ts +0 -7
  550. package/dist/core/agent-generator/templates/core/security-rules.d.ts.map +0 -1
  551. package/dist/core/agent-generator/templates/core/security-rules.js +0 -528
  552. package/dist/core/agent-generator/templates/core/security-rules.js.map +0 -1
  553. package/dist/core/agent-generator/templates/core/skills-generator.d.ts +0 -19
  554. package/dist/core/agent-generator/templates/core/skills-generator.d.ts.map +0 -1
  555. package/dist/core/agent-generator/templates/core/skills-generator.js +0 -546
  556. package/dist/core/agent-generator/templates/core/skills-generator.js.map +0 -1
  557. package/dist/core/agent-generator/templates/core/workflow-fix-bug.d.ts +0 -7
  558. package/dist/core/agent-generator/templates/core/workflow-fix-bug.d.ts.map +0 -1
  559. package/dist/core/agent-generator/templates/core/workflow-fix-bug.js +0 -237
  560. package/dist/core/agent-generator/templates/core/workflow-fix-bug.js.map +0 -1
  561. package/dist/core/agent-generator/templates/core/workflow-new-feature.d.ts +0 -8
  562. package/dist/core/agent-generator/templates/core/workflow-new-feature.d.ts.map +0 -1
  563. package/dist/core/agent-generator/templates/core/workflow-new-feature.js +0 -321
  564. package/dist/core/agent-generator/templates/core/workflow-new-feature.js.map +0 -1
  565. package/dist/core/agent-generator/templates/core/workflow-review.d.ts +0 -7
  566. package/dist/core/agent-generator/templates/core/workflow-review.d.ts.map +0 -1
  567. package/dist/core/agent-generator/templates/core/workflow-review.js +0 -104
  568. package/dist/core/agent-generator/templates/core/workflow-review.js.map +0 -1
  569. package/dist/core/agent-generator/templates/domain/index.d.ts +0 -22
  570. package/dist/core/agent-generator/templates/domain/index.d.ts.map +0 -1
  571. package/dist/core/agent-generator/templates/domain/index.js +0 -1176
  572. package/dist/core/agent-generator/templates/domain/index.js.map +0 -1
  573. package/dist/core/agent-generator/templates/helpers/base-helpers.d.ts +0 -11
  574. package/dist/core/agent-generator/templates/helpers/base-helpers.d.ts.map +0 -1
  575. package/dist/core/agent-generator/templates/helpers/base-helpers.js +0 -20
  576. package/dist/core/agent-generator/templates/helpers/base-helpers.js.map +0 -1
  577. package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts +0 -3
  578. package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts.map +0 -1
  579. package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.js +0 -77
  580. package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.js.map +0 -1
  581. package/dist/core/agent-generator/templates/helpers/security-helpers.d.ts +0 -3
  582. package/dist/core/agent-generator/templates/helpers/security-helpers.d.ts.map +0 -1
  583. package/dist/core/agent-generator/templates/helpers/security-helpers.js +0 -182
  584. package/dist/core/agent-generator/templates/helpers/security-helpers.js.map +0 -1
  585. package/dist/core/agent-generator/templates/helpers/stack-helpers.d.ts +0 -5
  586. package/dist/core/agent-generator/templates/helpers/stack-helpers.d.ts.map +0 -1
  587. package/dist/core/agent-generator/templates/helpers/stack-helpers.js +0 -69
  588. package/dist/core/agent-generator/templates/helpers/stack-helpers.js.map +0 -1
  589. package/dist/core/agent-generator/templates/helpers/structure-helpers.d.ts +0 -3
  590. package/dist/core/agent-generator/templates/helpers/structure-helpers.d.ts.map +0 -1
  591. package/dist/core/agent-generator/templates/helpers/structure-helpers.js +0 -275
  592. package/dist/core/agent-generator/templates/helpers/structure-helpers.js.map +0 -1
  593. package/dist/core/agent-generator/templates/helpers/summary-helpers.d.ts +0 -7
  594. package/dist/core/agent-generator/templates/helpers/summary-helpers.d.ts.map +0 -1
  595. package/dist/core/agent-generator/templates/helpers/summary-helpers.js +0 -56
  596. package/dist/core/agent-generator/templates/helpers/summary-helpers.js.map +0 -1
  597. package/dist/core/agent-generator/templates/stack/index.d.ts +0 -8
  598. package/dist/core/agent-generator/templates/stack/index.d.ts.map +0 -1
  599. package/dist/core/agent-generator/templates/stack/index.js +0 -695
  600. package/dist/core/agent-generator/templates/stack/index.js.map +0 -1
  601. package/dist/core/agent-generator/templates/template-helpers.d.ts +0 -12
  602. package/dist/core/agent-generator/templates/template-helpers.d.ts.map +0 -1
  603. package/dist/core/agent-generator/templates/template-helpers.js +0 -12
  604. package/dist/core/agent-generator/templates/template-helpers.js.map +0 -1
  605. package/dist/core/agent-generator/types/agent.d.ts +0 -40
  606. package/dist/core/agent-generator/types/agent.d.ts.map +0 -1
  607. package/dist/core/agent-generator/types/agent.js +0 -27
  608. package/dist/core/agent-generator/types/agent.js.map +0 -1
  609. package/dist/core/agent-generator/types/domain.d.ts +0 -59
  610. package/dist/core/agent-generator/types/domain.d.ts.map +0 -1
  611. package/dist/core/agent-generator/types/domain.js +0 -2
  612. package/dist/core/agent-generator/types/domain.js.map +0 -1
  613. package/dist/core/agent-generator/types/stack.d.ts +0 -37
  614. package/dist/core/agent-generator/types/stack.d.ts.map +0 -1
  615. package/dist/core/agent-generator/types/stack.js +0 -2
  616. package/dist/core/agent-generator/types/stack.js.map +0 -1
  617. package/dist/core/agent-generator/types/template.d.ts +0 -30
  618. package/dist/core/agent-generator/types/template.d.ts.map +0 -1
  619. package/dist/core/agent-generator/types/template.js +0 -2
  620. package/dist/core/agent-generator/types/template.js.map +0 -1
  621. package/dist/core/agent-generator/types.d.ts +0 -197
  622. package/dist/core/agent-generator/types.d.ts.map +0 -1
  623. package/dist/core/agent-generator/types.js +0 -27
  624. package/dist/core/agent-generator/types.js.map +0 -1
  625. package/dist/core/analyzer.d.ts +0 -39
  626. package/dist/core/analyzer.d.ts.map +0 -1
  627. package/dist/core/analyzer.js +0 -383
  628. package/dist/core/analyzer.js.map +0 -1
  629. package/dist/core/analyzers/forecast.d.ts +0 -85
  630. package/dist/core/analyzers/forecast.d.ts.map +0 -1
  631. package/dist/core/analyzers/forecast.js +0 -337
  632. package/dist/core/analyzers/forecast.js.map +0 -1
  633. package/dist/core/analyzers/index.d.ts +0 -10
  634. package/dist/core/analyzers/index.d.ts.map +0 -1
  635. package/dist/core/analyzers/index.js +0 -7
  636. package/dist/core/analyzers/index.js.map +0 -1
  637. package/dist/core/analyzers/temporal-scorer.d.ts +0 -72
  638. package/dist/core/analyzers/temporal-scorer.d.ts.map +0 -1
  639. package/dist/core/analyzers/temporal-scorer.js +0 -140
  640. package/dist/core/analyzers/temporal-scorer.js.map +0 -1
  641. package/dist/core/anti-patterns.d.ts +0 -25
  642. package/dist/core/anti-patterns.d.ts.map +0 -1
  643. package/dist/core/anti-patterns.js +0 -239
  644. package/dist/core/anti-patterns.js.map +0 -1
  645. package/dist/core/architect.d.ts.map +0 -1
  646. package/dist/core/architect.js.map +0 -1
  647. package/dist/core/architect_deps.d.ts +0 -14
  648. package/dist/core/architect_deps.d.ts.map +0 -1
  649. package/dist/core/architect_deps.js +0 -12
  650. package/dist/core/architect_deps.js.map +0 -1
  651. package/dist/core/config.d.ts +0 -12
  652. package/dist/core/config.d.ts.map +0 -1
  653. package/dist/core/config.js +0 -110
  654. package/dist/core/config.js.map +0 -1
  655. package/dist/core/diagram.d.ts +0 -10
  656. package/dist/core/diagram.d.ts.map +0 -1
  657. package/dist/core/diagram.js +0 -101
  658. package/dist/core/diagram.js.map +0 -1
  659. package/dist/core/project-summarizer.d.ts +0 -17
  660. package/dist/core/project-summarizer.d.ts.map +0 -1
  661. package/dist/core/project-summarizer.js +0 -39
  662. package/dist/core/project-summarizer.js.map +0 -1
  663. package/dist/core/refactor-engine.d.ts +0 -19
  664. package/dist/core/refactor-engine.d.ts.map +0 -1
  665. package/dist/core/refactor-engine.js +0 -86
  666. package/dist/core/refactor-engine.js.map +0 -1
  667. package/dist/core/rules/barrel-optimizer.d.ts +0 -14
  668. package/dist/core/rules/barrel-optimizer.d.ts.map +0 -1
  669. package/dist/core/rules/barrel-optimizer.js +0 -78
  670. package/dist/core/rules/barrel-optimizer.js.map +0 -1
  671. package/dist/core/rules/dead-code-detector.d.ts +0 -22
  672. package/dist/core/rules/dead-code-detector.d.ts.map +0 -1
  673. package/dist/core/rules/dead-code-detector.js +0 -118
  674. package/dist/core/rules/dead-code-detector.js.map +0 -1
  675. package/dist/core/rules/hub-splitter.d.ts +0 -14
  676. package/dist/core/rules/hub-splitter.d.ts.map +0 -1
  677. package/dist/core/rules/hub-splitter.js +0 -119
  678. package/dist/core/rules/hub-splitter.js.map +0 -1
  679. package/dist/core/rules/import-organizer.d.ts +0 -14
  680. package/dist/core/rules/import-organizer.d.ts.map +0 -1
  681. package/dist/core/rules/import-organizer.js +0 -86
  682. package/dist/core/rules/import-organizer.js.map +0 -1
  683. package/dist/core/rules/module-grouper.d.ts +0 -14
  684. package/dist/core/rules/module-grouper.d.ts.map +0 -1
  685. package/dist/core/rules/module-grouper.js +0 -118
  686. package/dist/core/rules/module-grouper.js.map +0 -1
  687. package/dist/core/scorer.d.ts +0 -27
  688. package/dist/core/scorer.d.ts.map +0 -1
  689. package/dist/core/scorer.js +0 -229
  690. package/dist/core/scorer.js.map +0 -1
  691. package/dist/core/summarizer/keyword-extractor.d.ts +0 -7
  692. package/dist/core/summarizer/keyword-extractor.d.ts.map +0 -1
  693. package/dist/core/summarizer/keyword-extractor.js +0 -37
  694. package/dist/core/summarizer/keyword-extractor.js.map +0 -1
  695. package/dist/core/summarizer/module-inferrer.d.ts +0 -12
  696. package/dist/core/summarizer/module-inferrer.d.ts.map +0 -1
  697. package/dist/core/summarizer/module-inferrer.js +0 -171
  698. package/dist/core/summarizer/module-inferrer.js.map +0 -1
  699. package/dist/core/summarizer/package-reader.d.ts +0 -4
  700. package/dist/core/summarizer/package-reader.d.ts.map +0 -1
  701. package/dist/core/summarizer/package-reader.js +0 -30
  702. package/dist/core/summarizer/package-reader.js.map +0 -1
  703. package/dist/core/summarizer/purpose-inferrer.d.ts +0 -9
  704. package/dist/core/summarizer/purpose-inferrer.d.ts.map +0 -1
  705. package/dist/core/summarizer/purpose-inferrer.js +0 -178
  706. package/dist/core/summarizer/purpose-inferrer.js.map +0 -1
  707. package/dist/core/summarizer/readme-reader.d.ts +0 -4
  708. package/dist/core/summarizer/readme-reader.d.ts.map +0 -1
  709. package/dist/core/summarizer/readme-reader.js +0 -21
  710. package/dist/core/summarizer/readme-reader.js.map +0 -1
  711. package/dist/core/types/core.d.ts +0 -87
  712. package/dist/core/types/core.d.ts.map +0 -1
  713. package/dist/core/types/core.js +0 -2
  714. package/dist/core/types/core.js.map +0 -1
  715. package/dist/core/types/infrastructure.d.ts +0 -39
  716. package/dist/core/types/infrastructure.d.ts.map +0 -1
  717. package/dist/core/types/infrastructure.js +0 -2
  718. package/dist/core/types/infrastructure.js.map +0 -1
  719. package/dist/core/types/rules.d.ts +0 -54
  720. package/dist/core/types/rules.d.ts.map +0 -1
  721. package/dist/core/types/rules.js +0 -2
  722. package/dist/core/types/rules.js.map +0 -1
  723. package/dist/core/types/summarizer.d.ts +0 -13
  724. package/dist/core/types/summarizer.d.ts.map +0 -1
  725. package/dist/core/types/summarizer.js +0 -2
  726. package/dist/core/types/summarizer.js.map +0 -1
  727. package/dist/core/types.d.ts +0 -187
  728. package/dist/core/types.d.ts.map +0 -1
  729. package/dist/core/types.js +0 -2
  730. package/dist/core/types.js.map +0 -1
  731. package/dist/diagram.d.ts +0 -10
  732. package/dist/diagram.d.ts.map +0 -1
  733. package/dist/diagram.js +0 -101
  734. package/dist/diagram.js.map +0 -1
  735. package/dist/html-reporter/scripts.d.ts.map +0 -1
  736. package/dist/html-reporter/scripts.js +0 -316
  737. package/dist/html-reporter/scripts.js.map +0 -1
  738. package/dist/html-reporter/sections/agents.d.ts +0 -3
  739. package/dist/html-reporter/sections/agents.d.ts.map +0 -1
  740. package/dist/html-reporter/sections/agents.js.map +0 -1
  741. package/dist/html-reporter/sections/anti-patterns.d.ts.map +0 -1
  742. package/dist/html-reporter/sections/anti-patterns.js +0 -64
  743. package/dist/html-reporter/sections/anti-patterns.js.map +0 -1
  744. package/dist/html-reporter/sections/header.d.ts.map +0 -1
  745. package/dist/html-reporter/sections/header.js +0 -30
  746. package/dist/html-reporter/sections/header.js.map +0 -1
  747. package/dist/html-reporter/sections/layers.d.ts.map +0 -1
  748. package/dist/html-reporter/sections/layers.js +0 -143
  749. package/dist/html-reporter/sections/layers.js.map +0 -1
  750. package/dist/html-reporter/sections/overview.d.ts +0 -3
  751. package/dist/html-reporter/sections/overview.d.ts.map +0 -1
  752. package/dist/html-reporter/sections/overview.js +0 -58
  753. package/dist/html-reporter/sections/overview.js.map +0 -1
  754. package/dist/html-reporter/sections/refactoring-plan.d.ts.map +0 -1
  755. package/dist/html-reporter/sections/refactoring-plan.js +0 -120
  756. package/dist/html-reporter/sections/refactoring-plan.js.map +0 -1
  757. package/dist/html-reporter/sections/score.d.ts.map +0 -1
  758. package/dist/html-reporter/sections/score.js +0 -69
  759. package/dist/html-reporter/sections/score.js.map +0 -1
  760. package/dist/html-reporter/sections/suggestions.d.ts +0 -8
  761. package/dist/html-reporter/sections/suggestions.d.ts.map +0 -1
  762. package/dist/html-reporter/sections/suggestions.js +0 -34
  763. package/dist/html-reporter/sections/suggestions.js.map +0 -1
  764. package/dist/html-reporter/styles.d.ts +0 -2
  765. package/dist/html-reporter/styles.d.ts.map +0 -1
  766. package/dist/html-reporter/styles.js +0 -504
  767. package/dist/html-reporter/styles.js.map +0 -1
  768. package/dist/html-reporter/utils.d.ts +0 -27
  769. package/dist/html-reporter/utils.d.ts.map +0 -1
  770. package/dist/html-reporter/utils.js +0 -82
  771. package/dist/html-reporter/utils.js.map +0 -1
  772. package/dist/html-reporter.d.ts.map +0 -1
  773. package/dist/html-reporter.js.map +0 -1
  774. package/dist/index.d.ts +0 -17
  775. package/dist/index.d.ts.map +0 -1
  776. package/dist/index.js +0 -14
  777. package/dist/index.js.map +0 -1
  778. package/dist/infrastructure/git-cache.d.ts +0 -7
  779. package/dist/infrastructure/git-cache.d.ts.map +0 -1
  780. package/dist/infrastructure/git-cache.js +0 -41
  781. package/dist/infrastructure/git-cache.js.map +0 -1
  782. package/dist/infrastructure/git-history.d.ts +0 -113
  783. package/dist/infrastructure/git-history.d.ts.map +0 -1
  784. package/dist/infrastructure/git-history.js +0 -339
  785. package/dist/infrastructure/git-history.js.map +0 -1
  786. package/dist/infrastructure/logger.d.ts +0 -21
  787. package/dist/infrastructure/logger.d.ts.map +0 -1
  788. package/dist/infrastructure/logger.js +0 -59
  789. package/dist/infrastructure/logger.js.map +0 -1
  790. package/dist/infrastructure/scanner.d.ts +0 -32
  791. package/dist/infrastructure/scanner.d.ts.map +0 -1
  792. package/dist/infrastructure/scanner.js +0 -330
  793. package/dist/infrastructure/scanner.js.map +0 -1
  794. package/dist/logger.d.ts +0 -21
  795. package/dist/logger.d.ts.map +0 -1
  796. package/dist/logger.js +0 -59
  797. package/dist/logger.js.map +0 -1
  798. package/dist/project-summarizer.d.ts +0 -16
  799. package/dist/project-summarizer.d.ts.map +0 -1
  800. package/dist/project-summarizer.js +0 -39
  801. package/dist/project-summarizer.js.map +0 -1
  802. package/dist/refactor-engine.d.ts +0 -18
  803. package/dist/refactor-engine.d.ts.map +0 -1
  804. package/dist/refactor-engine.js +0 -86
  805. package/dist/refactor-engine.js.map +0 -1
  806. package/dist/refactor-reporter.d.ts.map +0 -1
  807. package/dist/refactor-reporter.js.map +0 -1
  808. package/dist/reporter.d.ts.map +0 -1
  809. package/dist/reporter.js +0 -135
  810. package/dist/reporter.js.map +0 -1
  811. package/dist/rules/barrel-optimizer.d.ts +0 -13
  812. package/dist/rules/barrel-optimizer.d.ts.map +0 -1
  813. package/dist/rules/barrel-optimizer.js +0 -77
  814. package/dist/rules/barrel-optimizer.js.map +0 -1
  815. package/dist/rules/dead-code-detector.d.ts +0 -21
  816. package/dist/rules/dead-code-detector.d.ts.map +0 -1
  817. package/dist/rules/dead-code-detector.js +0 -117
  818. package/dist/rules/dead-code-detector.js.map +0 -1
  819. package/dist/rules/hub-splitter.d.ts +0 -13
  820. package/dist/rules/hub-splitter.d.ts.map +0 -1
  821. package/dist/rules/hub-splitter.js +0 -110
  822. package/dist/rules/hub-splitter.js.map +0 -1
  823. package/dist/rules/import-organizer.d.ts +0 -13
  824. package/dist/rules/import-organizer.d.ts.map +0 -1
  825. package/dist/rules/import-organizer.js +0 -85
  826. package/dist/rules/import-organizer.js.map +0 -1
  827. package/dist/rules/module-grouper.d.ts +0 -13
  828. package/dist/rules/module-grouper.d.ts.map +0 -1
  829. package/dist/rules/module-grouper.js +0 -110
  830. package/dist/rules/module-grouper.js.map +0 -1
  831. package/dist/scanner.d.ts +0 -31
  832. package/dist/scanner.d.ts.map +0 -1
  833. package/dist/scanner.js +0 -330
  834. package/dist/scanner.js.map +0 -1
  835. package/dist/scorer.d.ts +0 -27
  836. package/dist/scorer.d.ts.map +0 -1
  837. package/dist/scorer.js +0 -229
  838. package/dist/scorer.js.map +0 -1
  839. package/dist/summarizer/keyword-extractor.d.ts +0 -6
  840. package/dist/summarizer/keyword-extractor.d.ts.map +0 -1
  841. package/dist/summarizer/keyword-extractor.js +0 -37
  842. package/dist/summarizer/keyword-extractor.js.map +0 -1
  843. package/dist/summarizer/module-inferrer.d.ts +0 -10
  844. package/dist/summarizer/module-inferrer.d.ts.map +0 -1
  845. package/dist/summarizer/module-inferrer.js +0 -171
  846. package/dist/summarizer/module-inferrer.js.map +0 -1
  847. package/dist/summarizer/package-reader.d.ts +0 -4
  848. package/dist/summarizer/package-reader.d.ts.map +0 -1
  849. package/dist/summarizer/package-reader.js +0 -30
  850. package/dist/summarizer/package-reader.js.map +0 -1
  851. package/dist/summarizer/purpose-inferrer.d.ts +0 -8
  852. package/dist/summarizer/purpose-inferrer.d.ts.map +0 -1
  853. package/dist/summarizer/purpose-inferrer.js +0 -178
  854. package/dist/summarizer/purpose-inferrer.js.map +0 -1
  855. package/dist/summarizer/readme-reader.d.ts +0 -4
  856. package/dist/summarizer/readme-reader.d.ts.map +0 -1
  857. package/dist/summarizer/readme-reader.js +0 -21
  858. package/dist/summarizer/readme-reader.js.map +0 -1
  859. package/dist/types.d.ts +0 -186
  860. package/dist/types.d.ts.map +0 -1
  861. package/dist/types.js +0 -2
  862. package/dist/types.js.map +0 -1
  863. package/examples/sample-report.md +0 -207
  864. package/fix-scorer.js +0 -18
  865. package/fix-tests.js +0 -73
  866. package/jest.config.js +0 -18
  867. package/scripts/decompose-detectors.ts +0 -183
  868. package/scripts/decompose-detectors_deps.ts +0 -16
  869. package/scripts/decompose-enrichers.ts +0 -191
  870. package/scripts/decompose-enrichers_deps.ts +0 -10
  871. package/scripts/decompose-helpers.ts +0 -92
  872. package/scripts/decompose-summarizer.ts +0 -127
  873. package/setup-refactor.sh +0 -21
  874. package/src/adapters/html-reporter_deps.ts +0 -14
  875. package/src/core/agent-generator/context-enricher.ts +0 -67
  876. package/src/core/agent-generator/detectors/base-detector.ts +0 -18
  877. package/src/core/agent-generator/detectors/dart-detector.ts +0 -17
  878. package/src/core/agent-generator/detectors/framework-registry.ts +0 -82
  879. package/src/core/agent-generator/detectors/go-detector.ts +0 -26
  880. package/src/core/agent-generator/detectors/java-detector.ts +0 -46
  881. package/src/core/agent-generator/detectors/node-detector.ts +0 -28
  882. package/src/core/agent-generator/detectors/php-detector.ts +0 -28
  883. package/src/core/agent-generator/detectors/python-detector.ts +0 -125
  884. package/src/core/agent-generator/detectors/ruby-detector.ts +0 -24
  885. package/src/core/agent-generator/detectors/rust-detector.ts +0 -19
  886. package/src/core/agent-generator/detectors/structure-detector.ts +0 -38
  887. package/src/core/agent-generator/detectors/toolchain-detector.ts +0 -180
  888. package/src/core/agent-generator/domain-inferrer.ts +0 -630
  889. package/src/core/agent-generator/engines/audit-engine.ts +0 -98
  890. package/src/core/agent-generator/engines/context-builder.ts +0 -96
  891. package/src/core/agent-generator/engines/generation-engine.ts +0 -184
  892. package/src/core/agent-generator/engines/generation-engine_deps.ts +0 -21
  893. package/src/core/agent-generator/engines/suggestion-engine.ts +0 -202
  894. package/src/core/agent-generator/engines/suggestion-engine_deps.ts +0 -8
  895. package/src/core/agent-generator/enrichers/analysis-helpers.ts +0 -58
  896. package/src/core/agent-generator/enrichers/description-generator.ts +0 -91
  897. package/src/core/agent-generator/enrichers/endpoint-extractor.ts +0 -114
  898. package/src/core/agent-generator/enrichers/layer-classifier.ts +0 -156
  899. package/src/core/agent-generator/enrichers/module-extractor.ts +0 -203
  900. package/src/core/agent-generator/framework-detector.ts +0 -66
  901. package/src/core/agent-generator/index.ts +0 -55
  902. package/src/core/agent-generator/stack-detector.ts +0 -115
  903. package/src/core/agent-generator/templates/core/agents.ts +0 -1296
  904. package/src/core/agent-generator/templates/core/architecture-rules.ts +0 -287
  905. package/src/core/agent-generator/templates/core/general-rules.ts +0 -306
  906. package/src/core/agent-generator/templates/core/hooks-generator.ts +0 -242
  907. package/src/core/agent-generator/templates/core/index-md.ts +0 -260
  908. package/src/core/agent-generator/templates/core/orchestrator.ts +0 -459
  909. package/src/core/agent-generator/templates/core/preflight.ts +0 -215
  910. package/src/core/agent-generator/templates/core/quality-gates.ts +0 -256
  911. package/src/core/agent-generator/templates/core/security-rules.ts +0 -543
  912. package/src/core/agent-generator/templates/core/skills-generator.ts +0 -585
  913. package/src/core/agent-generator/templates/core/workflow-fix-bug.ts +0 -239
  914. package/src/core/agent-generator/templates/core/workflow-new-feature.ts +0 -323
  915. package/src/core/agent-generator/templates/core/workflow-review.ts +0 -106
  916. package/src/core/agent-generator/templates/domain/index.ts +0 -1201
  917. package/src/core/agent-generator/templates/helpers/base-helpers.ts +0 -32
  918. package/src/core/agent-generator/templates/helpers/cross-ref-helpers.ts +0 -79
  919. package/src/core/agent-generator/templates/helpers/security-helpers.ts +0 -196
  920. package/src/core/agent-generator/templates/helpers/stack-helpers.ts +0 -78
  921. package/src/core/agent-generator/templates/helpers/structure-helpers.ts +0 -291
  922. package/src/core/agent-generator/templates/helpers/summary-helpers.ts +0 -65
  923. package/src/core/agent-generator/templates/stack/index.ts +0 -705
  924. package/src/core/agent-generator/templates/template-helpers.ts +0 -12
  925. package/src/core/agent-generator/types/agent.ts +0 -65
  926. package/src/core/agent-generator/types/domain.ts +0 -63
  927. package/src/core/agent-generator/types/stack.ts +0 -38
  928. package/src/core/agent-generator/types/template.ts +0 -31
  929. package/src/core/analyzer.ts +0 -448
  930. package/src/core/analyzers/forecast.ts +0 -496
  931. package/src/core/analyzers/index.ts +0 -33
  932. package/src/core/analyzers/temporal-scorer.ts +0 -227
  933. package/src/core/anti-patterns.ts +0 -297
  934. package/src/core/architect_deps.ts +0 -13
  935. package/src/core/config.ts +0 -123
  936. package/src/core/diagram.ts +0 -129
  937. package/src/core/project-summarizer.ts +0 -42
  938. package/src/core/refactor-engine.ts +0 -112
  939. package/src/core/rules/barrel-optimizer.ts +0 -99
  940. package/src/core/rules/dead-code-detector.ts +0 -134
  941. package/src/core/rules/hub-splitter.ts +0 -135
  942. package/src/core/rules/import-organizer.ts +0 -100
  943. package/src/core/rules/module-grouper.ts +0 -133
  944. package/src/core/scorer.ts +0 -254
  945. package/src/core/summarizer/keyword-extractor.ts +0 -53
  946. package/src/core/summarizer/module-inferrer.ts +0 -194
  947. package/src/core/summarizer/package-reader.ts +0 -34
  948. package/src/core/summarizer/purpose-inferrer.ts +0 -197
  949. package/src/core/summarizer/readme-reader.ts +0 -24
  950. package/src/core/types/core.ts +0 -93
  951. package/src/core/types/infrastructure.ts +0 -41
  952. package/src/core/types/rules.ts +0 -51
  953. package/src/core/types/summarizer.ts +0 -8
  954. package/src/index.ts +0 -27
  955. package/src/infrastructure/git-cache.ts +0 -52
  956. package/src/infrastructure/git-history.ts +0 -497
  957. package/src/infrastructure/logger.ts +0 -68
  958. package/src/infrastructure/scanner.ts +0 -347
  959. package/src/scripts/bundle-deps.js +0 -123
  960. package/src/scripts/fix-imports.mjs +0 -106
  961. package/src/scripts/refactor-imports.js +0 -74
  962. package/src/scripts/refactor-utils.js +0 -23
  963. package/test-shotgun.js +0 -7
  964. package/tests/agent-generator.test.ts +0 -428
  965. package/tests/analyzers-integration.test.ts +0 -174
  966. package/tests/anti-patterns.test.ts +0 -95
  967. package/tests/context-enricher.test.ts +0 -972
  968. package/tests/fixtures/monorepo/package.json +0 -6
  969. package/tests/fixtures/monorepo/packages/app/package.json +0 -12
  970. package/tests/fixtures/monorepo/packages/app/src/index.ts +0 -6
  971. package/tests/fixtures/monorepo/packages/core/package.json +0 -7
  972. package/tests/fixtures/monorepo/packages/core/src/index.ts +0 -7
  973. package/tests/forecast.test.ts +0 -509
  974. package/tests/framework-detector.test.ts +0 -1172
  975. package/tests/git-history.test.ts +0 -254
  976. package/tests/monorepo-scan.test.ts +0 -170
  977. package/tests/scanner.test.ts +0 -54
  978. package/tests/scorer.test.ts +0 -674
  979. package/tests/stack-detector.test.ts +0 -241
  980. package/tests/template-generation.test.ts +0 -707
  981. package/tests/template-helpers.test.ts +0 -1130
  982. package/tests/temporal-scorer.test.ts +0 -307
  983. /package/dist/{adapters → src/adapters}/html-reporter/scripts.js +0 -0
  984. /package/dist/{adapters → src/adapters}/html-reporter/sections/anti-patterns.js +0 -0
  985. /package/dist/{adapters → src/adapters}/html-reporter/sections/layers.js +0 -0
  986. /package/dist/{adapters → src/adapters}/html-reporter/sections/overview.js +0 -0
  987. /package/dist/{adapters → src/adapters}/html-reporter/sections/refactoring-plan.js +0 -0
  988. /package/dist/{adapters → src/adapters}/html-reporter/sections/suggestions.js +0 -0
  989. /package/dist/{adapters → src/adapters}/html-reporter/styles.js +0 -0
  990. /package/dist/{adapters → src/adapters}/html-reporter/utils_adapters.js +0 -0
  991. /package/dist/{adapters → src/adapters}/html-reporter/utils_sections.js +0 -0
  992. /package/dist/{adapters → src/adapters}/reporter.js +0 -0
@@ -1,1172 +0,0 @@
1
- import { FrameworkDetector } from '../src/core/agent-generator/framework-detector.js';
2
- import { AnalysisReport } from '../src/core/types/core.js';
3
- import { existsSync, mkdtempSync, writeFileSync, rmSync } from 'fs';
4
- import { join } from 'path';
5
-
6
- // ── Test Data Factories ──
7
-
8
- /**
9
- * Creates a mock AnalysisReport for testing purposes.
10
- */
11
- function makeReport(overrides: Partial<AnalysisReport> = {}): AnalysisReport {
12
- return {
13
- timestamp: new Date().toISOString(),
14
- projectInfo: {
15
- path: '/test',
16
- name: 'test-project',
17
- frameworks: [],
18
- totalFiles: 50,
19
- totalLines: 5000,
20
- primaryLanguages: ['Unknown'],
21
- },
22
- score: {
23
- overall: 72,
24
- components: [],
25
- breakdown: { modularity: 80, coupling: 65, cohesion: 70, layering: 75 },
26
- },
27
- antiPatterns: [],
28
- layers: [],
29
- dependencyGraph: {
30
- nodes: ['src/index.ts'],
31
- edges: [],
32
- },
33
- suggestions: [],
34
- diagram: { mermaid: '', type: 'layer' },
35
- ...overrides,
36
- };
37
- }
38
-
39
- // ── Test Suite ──
40
-
41
- describe('FrameworkDetector', () => {
42
- const detector = new FrameworkDetector();
43
- let tempDir: string;
44
-
45
- beforeEach(() => {
46
- tempDir = mkdtempSync(join(process.cwd(), '__test_framework__'));
47
- });
48
-
49
- afterEach(() => {
50
- if (existsSync(tempDir)) {
51
- rmSync(tempDir, { recursive: true, force: true });
52
- }
53
- });
54
-
55
- // ═══════════════════════════════════════════════════════════════════════
56
- // PYTHON DETECTION
57
- // ═══════════════════════════════════════════════════════════════════════
58
-
59
- describe('Python detection', () => {
60
- it('should detect FastAPI, Django, Flask from requirements.txt with versions', () => {
61
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] } });
62
- writeFileSync(join(tempDir, 'requirements.txt'), 'fastapi==0.109.0\ndjango>=4.0\nflask~=2.3.0\n');
63
-
64
- const result = detector.detect(tempDir, report);
65
-
66
- expect(result.frameworks.length).toBeGreaterThanOrEqual(3);
67
- expect(result.frameworks.map(f => f.name)).toContain('FastAPI');
68
- expect(result.frameworks.map(f => f.name)).toContain('Django');
69
- expect(result.frameworks.map(f => f.name)).toContain('Flask');
70
- expect(result.primaryFramework).toBeDefined();
71
- expect(result.primaryFramework?.category).toBe('web');
72
- });
73
-
74
- it('should detect dependencies from pyproject.toml PEP 621 format with [project] section', () => {
75
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] } });
76
- writeFileSync(
77
- join(tempDir, 'pyproject.toml'),
78
- `[project]
79
- dependencies = [
80
- "fastapi>=0.109.0",
81
- "sqlalchemy>=2.0.0"
82
- ]
83
- `,
84
- );
85
-
86
- const result = detector.detect(tempDir, report);
87
-
88
- expect(result.frameworks.map(f => f.name)).toContain('FastAPI');
89
- expect(result.frameworks.map(f => f.name)).toContain('SQLAlchemy');
90
- });
91
-
92
- it('should detect dependencies from pyproject.toml with [project.optional-dependencies]', () => {
93
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] } });
94
- writeFileSync(
95
- join(tempDir, 'pyproject.toml'),
96
- `[project]
97
- dependencies = ["fastapi>=0.109.0"]
98
-
99
- [project.optional-dependencies]
100
- dev = ["pytest>=7.0", "ruff>=0.1.0"]
101
- test = ["hypothesis>=6.0"]
102
- `,
103
- );
104
-
105
- const result = detector.detect(tempDir, report);
106
-
107
- expect(result.frameworks.map(f => f.name)).toContain('FastAPI');
108
- expect(result.frameworks.map(f => f.name)).toContain('pytest');
109
- expect(result.frameworks.map(f => f.name)).toContain('Ruff');
110
- expect(result.frameworks.map(f => f.name)).toContain('Hypothesis');
111
- });
112
-
113
- it('should detect dependencies from pyproject.toml with [tool.poetry.dependencies]', () => {
114
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] } });
115
- writeFileSync(
116
- join(tempDir, 'pyproject.toml'),
117
- `[tool.poetry.dependencies]
118
- python = "^3.11"
119
- django = "~4.2.0"
120
- sqlalchemy = "^2.0"
121
- `,
122
- );
123
-
124
- const result = detector.detect(tempDir, report);
125
-
126
- expect(result.frameworks.map(f => f.name)).toContain('Django');
127
- expect(result.frameworks.map(f => f.name)).toContain('SQLAlchemy');
128
- });
129
-
130
- it('should detect setup.py as fallback Python dependencies', () => {
131
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] } });
132
- // parsePythonRequirements parses line-by-line, so setup.py needs one dep per line
133
- writeFileSync(
134
- join(tempDir, 'setup.py'),
135
- `flask>=2.0
136
- sqlalchemy>=2.0
137
- `,
138
- );
139
-
140
- const result = detector.detect(tempDir, report);
141
-
142
- expect(result.frameworks.map(f => f.name)).toContain('Flask');
143
- expect(result.frameworks.map(f => f.name)).toContain('SQLAlchemy');
144
- });
145
-
146
- it('should detect Pipfile as fallback Python dependencies', () => {
147
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] } });
148
- writeFileSync(
149
- join(tempDir, 'Pipfile'),
150
- `[packages]
151
- tornado = "*"
152
- peewee = ">=3.0"
153
-
154
- [dev-packages]
155
- pytest = "*"
156
- `,
157
- );
158
-
159
- const result = detector.detect(tempDir, report);
160
-
161
- expect(result.frameworks.map(f => f.name)).toContain('Tornado');
162
- expect(result.frameworks.map(f => f.name)).toContain('Peewee');
163
- expect(result.frameworks.map(f => f.name)).toContain('pytest');
164
- });
165
- });
166
-
167
- // ═══════════════════════════════════════════════════════════════════════
168
- // NODE.JS DETECTION
169
- // ═══════════════════════════════════════════════════════════════════════
170
-
171
- describe('Node.js detection', () => {
172
- it('should detect Express, NestJS, Jest, ESLint from package.json', () => {
173
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] } });
174
- writeFileSync(
175
- join(tempDir, 'package.json'),
176
- JSON.stringify({
177
- name: 'test-app',
178
- dependencies: {
179
- express: '^4.18.0',
180
- '@nestjs/core': '^10.0.0',
181
- },
182
- devDependencies: {
183
- jest: '^29.0.0',
184
- eslint: '^8.0.0',
185
- },
186
- }),
187
- );
188
-
189
- const result = detector.detect(tempDir, report);
190
-
191
- expect(result.frameworks.map(f => f.name)).toContain('Express');
192
- expect(result.frameworks.map(f => f.name)).toContain('NestJS');
193
- expect(result.frameworks.map(f => f.name)).toContain('Jest');
194
- expect(result.frameworks.map(f => f.name)).toContain('ESLint');
195
- });
196
-
197
- it('should handle invalid JSON gracefully', () => {
198
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] } });
199
- writeFileSync(join(tempDir, 'package.json'), 'invalid json {]');
200
-
201
- const result = detector.detect(tempDir, report);
202
-
203
- expect(result.frameworks.length).toBe(0);
204
- expect(result.primaryFramework).toBeNull();
205
- });
206
- });
207
-
208
- // ═══════════════════════════════════════════════════════════════════════
209
- // JAVA DETECTION
210
- // ═══════════════════════════════════════════════════════════════════════
211
-
212
- describe('Java detection', () => {
213
- it('should detect Spring Boot from pom.xml with spring-boot-starter-web artifactId', () => {
214
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Java'] } });
215
- writeFileSync(
216
- join(tempDir, 'pom.xml'),
217
- `<project>
218
- <dependencies>
219
- <dependency>
220
- <artifactId>spring-boot-starter-web</artifactId>
221
- </dependency>
222
- </dependencies>
223
- </project>`,
224
- );
225
-
226
- const result = detector.detect(tempDir, report);
227
-
228
- expect(result.frameworks.map(f => f.name)).toContain('Spring Boot');
229
- });
230
-
231
- it('should detect Spring Boot, Quarkus, Micronaut, Ktor from build.gradle', () => {
232
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Java'] } });
233
- writeFileSync(
234
- join(tempDir, 'build.gradle'),
235
- `plugins {
236
- id 'java'
237
- }
238
-
239
- dependencies {
240
- implementation 'io.quarkus:quarkus-core'
241
- }`,
242
- );
243
-
244
- const result = detector.detect(tempDir, report);
245
-
246
- expect(result.frameworks.map(f => f.name)).toContain('Quarkus');
247
- });
248
-
249
- it('should detect frameworks from build.gradle.kts', () => {
250
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Kotlin'] } });
251
- writeFileSync(
252
- join(tempDir, 'build.gradle.kts'),
253
- `dependencies {
254
- implementation("io.micronaut:micronaut-core")
255
- implementation("io.ktor:ktor-server-core")
256
- }`,
257
- );
258
-
259
- const result = detector.detect(tempDir, report);
260
-
261
- expect(result.frameworks.map(f => f.name)).toContain('Micronaut');
262
- expect(result.frameworks.map(f => f.name)).toContain('Ktor');
263
- });
264
- });
265
-
266
- // ═══════════════════════════════════════════════════════════════════════
267
- // PHP DETECTION
268
- // ═══════════════════════════════════════════════════════════════════════
269
-
270
- describe('PHP detection', () => {
271
- it('should detect Laravel from composer.json', () => {
272
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['PHP'] } });
273
- writeFileSync(
274
- join(tempDir, 'composer.json'),
275
- JSON.stringify({
276
- name: 'myapp',
277
- require: {
278
- 'laravel/framework': '^10.0',
279
- php: '^8.1',
280
- },
281
- }),
282
- );
283
-
284
- const result = detector.detect(tempDir, report);
285
-
286
- expect(result.frameworks.map(f => f.name)).toContain('Laravel');
287
- });
288
- });
289
-
290
- // ═══════════════════════════════════════════════════════════════════════
291
- // GO DETECTION
292
- // ═══════════════════════════════════════════════════════════════════════
293
-
294
- describe('Go detection', () => {
295
- it('should detect Gin from go.mod', () => {
296
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Go'] } });
297
- writeFileSync(
298
- join(tempDir, 'go.mod'),
299
- `module myapp
300
-
301
- go 1.21
302
-
303
- require (
304
- github.com/gin-gonic/gin v1.9.0
305
- github.com/labstack/echo v3.3.0
306
- )`,
307
- );
308
-
309
- const result = detector.detect(tempDir, report);
310
-
311
- expect(result.frameworks.map(f => f.name)).toContain('Gin');
312
- expect(result.frameworks.map(f => f.name)).toContain('Echo');
313
- });
314
- });
315
-
316
- // ═══════════════════════════════════════════════════════════════════════
317
- // RUBY DETECTION
318
- // ═══════════════════════════════════════════════════════════════════════
319
-
320
- describe('Ruby detection', () => {
321
- it('should detect Rails, Sinatra, RSpec from Gemfile', () => {
322
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Ruby'] } });
323
- writeFileSync(
324
- join(tempDir, 'Gemfile'),
325
- `source "https://rubygems.org"
326
-
327
- gem "rails", "~> 7.0.0"
328
- gem "sinatra"
329
- gem "rspec"`,
330
- );
331
-
332
- const result = detector.detect(tempDir, report);
333
-
334
- expect(result.frameworks.map(f => f.name)).toContain('Ruby on Rails');
335
- expect(result.frameworks.map(f => f.name)).toContain('Sinatra');
336
- expect(result.frameworks.map(f => f.name)).toContain('RSpec');
337
- });
338
- });
339
-
340
- // ═══════════════════════════════════════════════════════════════════════
341
- // DART DETECTION
342
- // ═══════════════════════════════════════════════════════════════════════
343
-
344
- describe('Dart detection', () => {
345
- it('should detect Flutter from pubspec.yaml with flutter: section', () => {
346
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Dart'] } });
347
- writeFileSync(
348
- join(tempDir, 'pubspec.yaml'),
349
- `name: myapp
350
- description: A Flutter app
351
-
352
- flutter:
353
- uses-material-design: true
354
-
355
- dev_dependencies:
356
- flutter_test:
357
- sdk: flutter`,
358
- );
359
-
360
- const result = detector.detect(tempDir, report);
361
-
362
- expect(result.frameworks.map(f => f.name)).toContain('Flutter');
363
- });
364
- });
365
-
366
- // ═══════════════════════════════════════════════════════════════════════
367
- // RUST DETECTION
368
- // ═══════════════════════════════════════════════════════════════════════
369
-
370
- describe('Rust detection', () => {
371
- it('should detect Actix Web and Axum from Cargo.toml', () => {
372
- const report = makeReport({ projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Rust'] } });
373
- writeFileSync(
374
- join(tempDir, 'Cargo.toml'),
375
- `[package]
376
- name = "myapp"
377
- version = "0.1.0"
378
-
379
- [dependencies]
380
- actix-web = "4.4"
381
- axum = "0.7"`,
382
- );
383
-
384
- const result = detector.detect(tempDir, report);
385
-
386
- expect(result.frameworks.map(f => f.name)).toContain('Actix Web');
387
- expect(result.frameworks.map(f => f.name)).toContain('Axum');
388
- });
389
- });
390
-
391
- // ═══════════════════════════════════════════════════════════════════════
392
- // TOOLCHAIN DETECTION
393
- // ═══════════════════════════════════════════════════════════════════════
394
-
395
- describe('Toolchain detection', () => {
396
- it('should detect Python + FastAPI toolchain with uvicorn, pytest, ruff', () => {
397
- const report = makeReport({
398
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] },
399
- dependencyGraph: { nodes: ['src/main.py'], edges: [] },
400
- });
401
- writeFileSync(
402
- join(tempDir, 'pyproject.toml'),
403
- `[project]
404
- dependencies = [
405
- "fastapi>=0.109.0",
406
- "uvicorn[standard]>=0.27.0"
407
- ]
408
-
409
- [project.optional-dependencies]
410
- dev = ["pytest>=7.0", "ruff>=0.1.0"]`,
411
- );
412
-
413
- const result = detector.detect(tempDir, report);
414
-
415
- expect(result.toolchain.runCmd).toContain('uvicorn');
416
- expect(result.toolchain.testCmd).toBe('pytest');
417
- expect(result.toolchain.lintCmd).toContain('ruff');
418
- // depsFile defaults to requirements.txt unless poetry.lock or Pipfile.lock exists
419
- expect(result.toolchain.depsFile).toBe('requirements.txt');
420
- });
421
-
422
- it('should detect Python + Django toolchain with manage.py commands', () => {
423
- const report = makeReport({
424
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] },
425
- dependencyGraph: { nodes: ['manage.py', 'app/models.py'], edges: [] },
426
- });
427
- writeFileSync(
428
- join(tempDir, 'requirements.txt'),
429
- `django>=4.0
430
- pytest>=7.0`,
431
- );
432
- writeFileSync(join(tempDir, 'manage.py'), 'import django\n');
433
-
434
- const result = detector.detect(tempDir, report);
435
-
436
- expect(result.toolchain.runCmd).toBe('python manage.py runserver');
437
- expect(result.toolchain.testCmd).toBe('pytest');
438
- expect(result.toolchain.migrateCmd).toBe('python manage.py migrate');
439
- });
440
-
441
- it('should detect TypeScript with npm by default', () => {
442
- const report = makeReport({
443
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] },
444
- dependencyGraph: { nodes: ['src/index.ts'], edges: [] },
445
- });
446
- writeFileSync(
447
- join(tempDir, 'package.json'),
448
- JSON.stringify({
449
- name: 'test',
450
- dependencies: { express: '^4.18.0' },
451
- devDependencies: { jest: '^29.0.0' },
452
- }),
453
- );
454
-
455
- const result = detector.detect(tempDir, report);
456
-
457
- expect(result.toolchain.buildCmd).toContain('npm');
458
- expect(result.toolchain.testCmd).toContain('npm');
459
- expect(result.toolchain.runCmd).toContain('npm');
460
- });
461
-
462
- it('should detect TypeScript with yarn when yarn.lock exists', () => {
463
- const report = makeReport({
464
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] },
465
- dependencyGraph: { nodes: ['src/index.ts'], edges: [] },
466
- });
467
- writeFileSync(
468
- join(tempDir, 'package.json'),
469
- JSON.stringify({
470
- name: 'test',
471
- dependencies: { express: '^4.18.0' },
472
- }),
473
- );
474
- writeFileSync(join(tempDir, 'yarn.lock'), '# yarn lockfile v1\n');
475
-
476
- const result = detector.detect(tempDir, report);
477
-
478
- expect(result.toolchain.buildCmd).toContain('yarn');
479
- expect(result.toolchain.testCmd).toContain('yarn');
480
- });
481
-
482
- it('should detect TypeScript with pnpm when pnpm-lock.yaml exists', () => {
483
- const report = makeReport({
484
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] },
485
- dependencyGraph: { nodes: ['src/index.ts'], edges: [] },
486
- });
487
- writeFileSync(
488
- join(tempDir, 'package.json'),
489
- JSON.stringify({
490
- name: 'test',
491
- dependencies: { express: '^4.18.0' },
492
- }),
493
- );
494
- writeFileSync(join(tempDir, 'pnpm-lock.yaml'), 'lockfileVersion: 5.4\n');
495
-
496
- const result = detector.detect(tempDir, report);
497
-
498
- expect(result.toolchain.buildCmd).toContain('pnpm');
499
- expect(result.toolchain.testCmd).toContain('pnpm');
500
- });
501
-
502
- it('should detect Java + pom.xml toolchain with mvn commands', () => {
503
- const report = makeReport({
504
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Java'] },
505
- dependencyGraph: { nodes: ['src/main/java/App.java'], edges: [] },
506
- });
507
- writeFileSync(
508
- join(tempDir, 'pom.xml'),
509
- `<project>
510
- <dependencies>
511
- <dependency>
512
- <artifactId>spring-boot-starter-web</artifactId>
513
- </dependency>
514
- </dependencies>
515
- </project>`,
516
- );
517
-
518
- const result = detector.detect(tempDir, report);
519
-
520
- expect(result.toolchain.buildCmd).toBe('mvn clean package');
521
- expect(result.toolchain.testCmd).toBe('mvn test');
522
- expect(result.toolchain.runCmd).toBe('mvn spring-boot:run');
523
- expect(result.toolchain.depsFile).toBe('pom.xml');
524
- });
525
-
526
- it('should detect Java + build.gradle toolchain with gradlew commands', () => {
527
- const report = makeReport({
528
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Java'] },
529
- dependencyGraph: { nodes: ['src/main/java/App.java'], edges: [] },
530
- });
531
- writeFileSync(
532
- join(tempDir, 'build.gradle'),
533
- `plugins { id 'java' }
534
- dependencies { implementation 'org.springframework.boot:spring-boot' }`,
535
- );
536
-
537
- const result = detector.detect(tempDir, report);
538
-
539
- expect(result.toolchain.buildCmd).toBe('./gradlew build');
540
- expect(result.toolchain.testCmd).toBe('./gradlew test');
541
- expect(result.toolchain.runCmd).toBe('./gradlew bootRun');
542
- expect(result.toolchain.depsFile).toBe('build.gradle');
543
- });
544
-
545
- it('should detect PHP + Laravel toolchain with artisan commands', () => {
546
- const report = makeReport({
547
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['PHP'] },
548
- dependencyGraph: { nodes: ['app/Http/Controllers/AppController.php'], edges: [] },
549
- });
550
- writeFileSync(
551
- join(tempDir, 'composer.json'),
552
- JSON.stringify({
553
- require: { 'laravel/framework': '^10.0' },
554
- }),
555
- );
556
-
557
- const result = detector.detect(tempDir, report);
558
-
559
- expect(result.toolchain.runCmd).toBe('php artisan serve');
560
- expect(result.toolchain.testCmd).toBe('php artisan test');
561
- expect(result.toolchain.migrateCmd).toBe('php artisan migrate');
562
- });
563
-
564
- it('should detect Go toolchain with go commands', () => {
565
- const report = makeReport({
566
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Go'] },
567
- dependencyGraph: { nodes: ['main.go'], edges: [] },
568
- });
569
- writeFileSync(
570
- join(tempDir, 'go.mod'),
571
- `module myapp
572
- go 1.21
573
- require github.com/gin-gonic/gin v1.9.0`,
574
- );
575
-
576
- const result = detector.detect(tempDir, report);
577
-
578
- expect(result.toolchain.buildCmd).toBe('go build ./...');
579
- expect(result.toolchain.testCmd).toBe('go test ./...');
580
- expect(result.toolchain.lintCmd).toBe('golangci-lint run');
581
- expect(result.toolchain.runCmd).toBe('go run .');
582
- expect(result.toolchain.depsFile).toBe('go.mod');
583
- });
584
-
585
- it('should detect Ruby + Rails toolchain with rails commands', () => {
586
- const report = makeReport({
587
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Ruby'] },
588
- dependencyGraph: { nodes: ['app/controllers/application_controller.rb'], edges: [] },
589
- });
590
- writeFileSync(
591
- join(tempDir, 'Gemfile'),
592
- `source "https://rubygems.org"
593
- gem "rails", "~> 7.0.0"
594
- gem "rspec"`,
595
- );
596
-
597
- const result = detector.detect(tempDir, report);
598
-
599
- expect(result.toolchain.runCmd).toBe('rails server');
600
- expect(result.toolchain.testCmd).toBe('bundle exec rspec');
601
- expect(result.toolchain.migrateCmd).toBe('rails db:migrate');
602
- expect(result.toolchain.depsFile).toBe('Gemfile');
603
- });
604
-
605
- it('should detect Dart + Flutter toolchain with flutter commands', () => {
606
- const report = makeReport({
607
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Dart'] },
608
- dependencyGraph: { nodes: ['lib/main.dart'], edges: [] },
609
- });
610
- writeFileSync(
611
- join(tempDir, 'pubspec.yaml'),
612
- `name: myapp
613
- flutter:
614
- uses-material-design: true`,
615
- );
616
-
617
- const result = detector.detect(tempDir, report);
618
-
619
- expect(result.toolchain.buildCmd).toBe('flutter build');
620
- expect(result.toolchain.testCmd).toBe('flutter test');
621
- expect(result.toolchain.runCmd).toBe('flutter run');
622
- expect(result.toolchain.depsFile).toBe('pubspec.yaml');
623
- });
624
-
625
- it('should detect Rust toolchain with cargo commands', () => {
626
- const report = makeReport({
627
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Rust'] },
628
- dependencyGraph: { nodes: ['src/main.rs'], edges: [] },
629
- });
630
- writeFileSync(
631
- join(tempDir, 'Cargo.toml'),
632
- `[package]
633
- name = "myapp"
634
- [dependencies]
635
- actix-web = "4.4"`,
636
- );
637
-
638
- const result = detector.detect(tempDir, report);
639
-
640
- expect(result.toolchain.buildCmd).toBe('cargo build');
641
- expect(result.toolchain.testCmd).toBe('cargo test');
642
- expect(result.toolchain.lintCmd).toBe('cargo clippy');
643
- expect(result.toolchain.runCmd).toBe('cargo run');
644
- expect(result.toolchain.depsFile).toBe('Cargo.toml');
645
- });
646
-
647
- it('should fallback to Makefile commands when available', () => {
648
- const report = makeReport({
649
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Unknown'] },
650
- dependencyGraph: { nodes: [], edges: [] },
651
- });
652
- writeFileSync(
653
- join(tempDir, 'Makefile'),
654
- `build:
655
- @echo "Building..."
656
-
657
- test:
658
- @echo "Testing..."
659
-
660
- lint:
661
- @echo "Linting..."
662
-
663
- run:
664
- @echo "Running..."`,
665
- );
666
-
667
- const result = detector.detect(tempDir, report);
668
-
669
- expect(result.toolchain.buildCmd).toBe('make build');
670
- expect(result.toolchain.testCmd).toBe('make test');
671
- expect(result.toolchain.lintCmd).toBe('make lint');
672
- expect(result.toolchain.runCmd).toBe('make run');
673
- });
674
-
675
- it('should fallback to generic commands when no build tool detected', () => {
676
- const report = makeReport({
677
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Unknown'] },
678
- dependencyGraph: { nodes: [], edges: [] },
679
- });
680
-
681
- const result = detector.detect(tempDir, report);
682
-
683
- expect(result.toolchain.buildCmd).toContain('No build command detected');
684
- expect(result.toolchain.testCmd).toContain('No test command detected');
685
- expect(result.toolchain.depsFile).toBe('unknown');
686
- });
687
- });
688
-
689
- // ═══════════════════════════════════════════════════════════════════════
690
- // PROJECT STRUCTURE DETECTION
691
- // ═══════════════════════════════════════════════════════════════════════
692
-
693
- describe('Project structure detection', () => {
694
- it('should detect clean-architecture with domain/ and infrastructure/ directories', () => {
695
- const report = makeReport({
696
- dependencyGraph: {
697
- nodes: [
698
- 'src/domain/entities/user.ts',
699
- 'src/domain/repositories/user.repository.ts',
700
- 'src/infrastructure/database/connection.ts',
701
- 'src/application/services/user.service.ts',
702
- 'src/presentation/controllers/user.controller.ts',
703
- ],
704
- edges: [],
705
- },
706
- });
707
-
708
- const result = detector.detect(tempDir, report);
709
-
710
- expect(result.projectStructure).toBe('clean-architecture');
711
- });
712
-
713
- it('should detect mvc with models/, views/, controllers/ directories', () => {
714
- const report = makeReport({
715
- dependencyGraph: {
716
- nodes: [
717
- 'app/models/user.php',
718
- 'app/views/user/show.html',
719
- 'app/controllers/user_controller.php',
720
- ],
721
- edges: [],
722
- },
723
- });
724
-
725
- const result = detector.detect(tempDir, report);
726
-
727
- expect(result.projectStructure).toBe('mvc');
728
- });
729
-
730
- it('should detect modular with modules/ or features/ directories', () => {
731
- const report = makeReport({
732
- dependencyGraph: {
733
- nodes: [
734
- 'src/modules/auth/auth.module.ts',
735
- 'src/modules/users/users.module.ts',
736
- 'src/modules/auth/controllers/auth.controller.ts',
737
- ],
738
- edges: [],
739
- },
740
- });
741
-
742
- const result = detector.detect(tempDir, report);
743
-
744
- expect(result.projectStructure).toBe('modular');
745
- });
746
-
747
- it('should detect modular with features directory', () => {
748
- const report = makeReport({
749
- dependencyGraph: {
750
- nodes: [
751
- 'src/features/auth/auth.ts',
752
- 'src/features/users/users.ts',
753
- ],
754
- edges: [],
755
- },
756
- });
757
-
758
- const result = detector.detect(tempDir, report);
759
-
760
- expect(result.projectStructure).toBe('modular');
761
- });
762
-
763
- it('should detect monorepo with packages/ or apps/ directories', () => {
764
- const report = makeReport({
765
- dependencyGraph: {
766
- nodes: [
767
- 'src/packages/api/src/index.ts',
768
- 'src/packages/web/src/index.ts',
769
- 'src/packages/shared/src/types.ts',
770
- ],
771
- edges: [],
772
- },
773
- });
774
-
775
- const result = detector.detect(tempDir, report);
776
-
777
- expect(result.projectStructure).toBe('monorepo');
778
- });
779
-
780
- it('should detect monorepo with apps directory', () => {
781
- const report = makeReport({
782
- dependencyGraph: {
783
- nodes: [
784
- 'src/apps/api/src/index.ts',
785
- 'src/apps/web/src/index.ts',
786
- ],
787
- edges: [],
788
- },
789
- });
790
-
791
- const result = detector.detect(tempDir, report);
792
-
793
- expect(result.projectStructure).toBe('monorepo');
794
- });
795
-
796
- it('should detect flat structure with shallow directory depth', () => {
797
- const report = makeReport({
798
- dependencyGraph: {
799
- nodes: [
800
- 'src/index.ts',
801
- 'src/util.ts',
802
- 'src/config.ts',
803
- ],
804
- edges: [],
805
- },
806
- });
807
-
808
- const result = detector.detect(tempDir, report);
809
-
810
- expect(result.projectStructure).toBe('flat');
811
- });
812
-
813
- it('should return unknown for unmatched structures', () => {
814
- const report = makeReport({
815
- dependencyGraph: {
816
- nodes: [
817
- 'src/a/b/c/d/e/f/component.ts',
818
- 'src/x/y/z/util.ts',
819
- ],
820
- edges: [],
821
- },
822
- });
823
-
824
- const result = detector.detect(tempDir, report);
825
-
826
- expect(result.projectStructure).toBe('unknown');
827
- });
828
- });
829
-
830
- // ═══════════════════════════════════════════════════════════════════════
831
- // EDGE CASES
832
- // ═══════════════════════════════════════════════════════════════════════
833
-
834
- describe('Edge cases', () => {
835
- it('should handle empty project with no dependency files', () => {
836
- const report = makeReport();
837
-
838
- const result = detector.detect(tempDir, report);
839
-
840
- expect(result.frameworks.length).toBe(0);
841
- expect(result.primaryFramework).toBeNull();
842
- expect(result.toolchain).toBeDefined();
843
- });
844
-
845
- it('should deduplicate frameworks detected from multiple sources', () => {
846
- const report = makeReport({
847
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] },
848
- dependencyGraph: { nodes: ['package.json', 'yarn.lock'], edges: [] },
849
- });
850
- writeFileSync(
851
- join(tempDir, 'package.json'),
852
- JSON.stringify({
853
- name: 'test',
854
- dependencies: { jest: '^29.0.0', express: '^4.18.0' },
855
- devDependencies: { jest: '^29.0.0' }, // Jest in both deps and devDeps
856
- }),
857
- );
858
-
859
- const result = detector.detect(tempDir, report);
860
-
861
- const jestCount = result.frameworks.filter(f => f.name === 'Jest').length;
862
- expect(jestCount).toBe(1); // Should be deduplicated
863
- });
864
-
865
- it('should pick web framework as primaryFramework', () => {
866
- const report = makeReport({
867
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] },
868
- dependencyGraph: { nodes: [], edges: [] },
869
- });
870
- writeFileSync(
871
- join(tempDir, 'package.json'),
872
- JSON.stringify({
873
- name: 'test',
874
- dependencies: {
875
- express: '^4.18.0',
876
- jest: '^29.0.0',
877
- eslint: '^8.0.0',
878
- },
879
- }),
880
- );
881
-
882
- const result = detector.detect(tempDir, report);
883
-
884
- expect(result.primaryFramework?.name).toBe('Express');
885
- expect(result.primaryFramework?.category).toBe('web');
886
- });
887
-
888
- it('should sort frameworks: web first, then by confidence', () => {
889
- const report = makeReport({
890
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] },
891
- dependencyGraph: { nodes: [], edges: [] },
892
- });
893
- writeFileSync(
894
- join(tempDir, 'requirements.txt'),
895
- `pytest>=7.0
896
- fastapi>=0.100.0
897
- flask>=2.0
898
- black>=23.0`,
899
- );
900
-
901
- const result = detector.detect(tempDir, report);
902
-
903
- const frameworks = result.frameworks;
904
- // Web frameworks (FastAPI, Flask) should come before test/lint (pytest, Black)
905
- const webFrameworksIndices = frameworks
906
- .map((f, i) => (f.category === 'web' ? i : -1))
907
- .filter(i => i !== -1);
908
- const nonWebIndices = frameworks
909
- .map((f, i) => (f.category !== 'web' ? i : -1))
910
- .filter(i => i !== -1);
911
-
912
- if (webFrameworksIndices.length > 0 && nonWebIndices.length > 0) {
913
- expect(Math.max(...webFrameworksIndices)).toBeLessThan(Math.min(...nonWebIndices));
914
- }
915
- });
916
-
917
- it('should handle missing primaryLanguages gracefully', () => {
918
- const report = makeReport({
919
- projectInfo: {
920
- ...makeReport().projectInfo,
921
- primaryLanguages: [],
922
- },
923
- dependencyGraph: { nodes: [], edges: [] },
924
- });
925
-
926
- const result = detector.detect(tempDir, report);
927
-
928
- expect(result.toolchain).toBeDefined();
929
- });
930
-
931
- it('should handle files in subdirectories (e.g., requirements/prod.txt)', () => {
932
- const report = makeReport({
933
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] },
934
- dependencyGraph: { nodes: [], edges: [] },
935
- });
936
-
937
- // Create subdirectory
938
- const reqDir = join(tempDir, 'requirements');
939
- writeFileSync(
940
- join(tempDir, 'requirements'),
941
- 'placeholder',
942
- );
943
- rmSync(join(tempDir, 'requirements'), { force: true });
944
-
945
- // Instead, just test that reading non-existent file doesn't crash
946
- const result = detector.detect(tempDir, report);
947
-
948
- expect(result).toBeDefined();
949
- });
950
-
951
- it('should detect Vitest over Jest when both are present', () => {
952
- const report = makeReport({
953
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['TypeScript'] },
954
- dependencyGraph: { nodes: [], edges: [] },
955
- });
956
- writeFileSync(
957
- join(tempDir, 'package.json'),
958
- JSON.stringify({
959
- name: 'test',
960
- devDependencies: {
961
- jest: '^29.0.0',
962
- vitest: '^1.0.0',
963
- },
964
- }),
965
- );
966
-
967
- const result = detector.detect(tempDir, report);
968
-
969
- const frameworks = result.frameworks.map(f => f.name);
970
- expect(frameworks).toContain('Jest');
971
- expect(frameworks).toContain('Vitest');
972
- });
973
-
974
- it('should handle poetry.lock indicator for Poetry package manager', () => {
975
- const report = makeReport({
976
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] },
977
- dependencyGraph: { nodes: [], edges: [] },
978
- });
979
- writeFileSync(
980
- join(tempDir, 'pyproject.toml'),
981
- `[project]
982
- dependencies = ["fastapi>=0.100.0"]`,
983
- );
984
- writeFileSync(join(tempDir, 'poetry.lock'), '# poetry lock file\n');
985
-
986
- const result = detector.detect(tempDir, report);
987
-
988
- expect(result.toolchain.installCmd).toBe('poetry install');
989
- expect(result.toolchain.depsFile).toBe('pyproject.toml');
990
- });
991
-
992
- it('should handle Pipenv Pipfile.lock indicator', () => {
993
- const report = makeReport({
994
- projectInfo: { ...makeReport().projectInfo, primaryLanguages: ['Python'] },
995
- dependencyGraph: { nodes: [], edges: [] },
996
- });
997
- writeFileSync(
998
- join(tempDir, 'requirements.txt'),
999
- 'flask>=2.0',
1000
- );
1001
- writeFileSync(join(tempDir, 'Pipfile.lock'), '{}');
1002
-
1003
- const result = detector.detect(tempDir, report);
1004
-
1005
- expect(result.toolchain.installCmd).toBe('pipenv install');
1006
- });
1007
- });
1008
-
1009
- // ═══════════════════════════════════════════════════════════════════════
1010
- // INTEGRATION TESTS
1011
- // ═══════════════════════════════════════════════════════════════════════
1012
-
1013
- describe('Integration tests', () => {
1014
- it('should detect full Python FastAPI stack with clean-architecture structure', () => {
1015
- const report = makeReport({
1016
- projectInfo: {
1017
- ...makeReport().projectInfo,
1018
- primaryLanguages: ['Python'],
1019
- name: 'fastapi-app',
1020
- },
1021
- dependencyGraph: {
1022
- nodes: [
1023
- 'src/domain/entities/user.py',
1024
- 'src/infrastructure/database.py',
1025
- 'src/application/services/user.py',
1026
- 'src/main.py',
1027
- ],
1028
- edges: [],
1029
- },
1030
- });
1031
- writeFileSync(
1032
- join(tempDir, 'pyproject.toml'),
1033
- `[project]
1034
- dependencies = [
1035
- "fastapi>=0.109.0",
1036
- "sqlalchemy>=2.0",
1037
- "uvicorn[standard]>=0.27"
1038
- ]
1039
-
1040
- [project.optional-dependencies]
1041
- dev = ["pytest>=7.0", "ruff>=0.1.0"]`,
1042
- );
1043
-
1044
- const result = detector.detect(tempDir, report);
1045
-
1046
- expect(result.frameworks.map(f => f.name)).toContain('FastAPI');
1047
- expect(result.frameworks.map(f => f.name)).toContain('SQLAlchemy');
1048
- expect(result.primaryFramework?.name).toBe('FastAPI');
1049
- expect(result.toolchain.runCmd).toContain('uvicorn');
1050
- expect(result.toolchain.testCmd).toBe('pytest');
1051
- expect(result.projectStructure).toBe('clean-architecture');
1052
- });
1053
-
1054
- it('should detect full TypeScript NestJS stack with modular structure', () => {
1055
- const report = makeReport({
1056
- projectInfo: {
1057
- ...makeReport().projectInfo,
1058
- primaryLanguages: ['TypeScript'],
1059
- name: 'nestjs-app',
1060
- },
1061
- dependencyGraph: {
1062
- nodes: [
1063
- 'src/modules/auth/auth.module.ts',
1064
- 'src/modules/users/users.module.ts',
1065
- 'src/modules/auth/services/auth.service.ts',
1066
- 'src/app.module.ts',
1067
- 'src/main.ts',
1068
- ],
1069
- edges: [],
1070
- },
1071
- });
1072
- writeFileSync(
1073
- join(tempDir, 'package.json'),
1074
- JSON.stringify({
1075
- name: 'nestjs-app',
1076
- dependencies: {
1077
- '@nestjs/core': '^10.0.0',
1078
- '@nestjs/common': '^10.0.0',
1079
- typeorm: '^0.3.0',
1080
- },
1081
- devDependencies: {
1082
- jest: '^29.0.0',
1083
- eslint: '^8.0.0',
1084
- },
1085
- }),
1086
- );
1087
- writeFileSync(
1088
- join(tempDir, 'yarn.lock'),
1089
- '# yarn lockfile v1\n',
1090
- );
1091
-
1092
- const result = detector.detect(tempDir, report);
1093
-
1094
- expect(result.primaryFramework?.name).toBe('NestJS');
1095
- expect(result.frameworks.map(f => f.name)).toContain('TypeORM');
1096
- expect(result.toolchain.buildCmd).toContain('yarn');
1097
- expect(result.projectStructure).toBe('modular');
1098
- });
1099
-
1100
- it('should detect full Java Spring Boot stack', () => {
1101
- const report = makeReport({
1102
- projectInfo: {
1103
- ...makeReport().projectInfo,
1104
- primaryLanguages: ['Java'],
1105
- name: 'spring-app',
1106
- },
1107
- dependencyGraph: {
1108
- nodes: [
1109
- 'src/main/java/com/example/controller/UserController.java',
1110
- 'src/main/java/com/example/service/UserService.java',
1111
- 'src/main/java/com/example/repository/UserRepository.java',
1112
- 'pom.xml',
1113
- ],
1114
- edges: [],
1115
- },
1116
- });
1117
- writeFileSync(
1118
- join(tempDir, 'pom.xml'),
1119
- `<project>
1120
- <dependencies>
1121
- <dependency>
1122
- <artifactId>spring-boot-starter-web</artifactId>
1123
- </dependency>
1124
- <dependency>
1125
- <artifactId>spring-boot-starter-data-jpa</artifactId>
1126
- </dependency>
1127
- </dependencies>
1128
- </project>`,
1129
- );
1130
-
1131
- const result = detector.detect(tempDir, report);
1132
-
1133
- expect(result.primaryFramework?.name).toBe('Spring Boot');
1134
- expect(result.toolchain.buildCmd).toBe('mvn clean package');
1135
- expect(result.toolchain.runCmd).toBe('mvn spring-boot:run');
1136
- expect(result.projectStructure).not.toBe('clean-architecture');
1137
- });
1138
-
1139
- it('should detect full PHP Laravel stack with mvc structure', () => {
1140
- const report = makeReport({
1141
- projectInfo: {
1142
- ...makeReport().projectInfo,
1143
- primaryLanguages: ['PHP'],
1144
- name: 'laravel-app',
1145
- },
1146
- dependencyGraph: {
1147
- nodes: [
1148
- 'app/models/User.php',
1149
- 'app/views/users/show.blade.php',
1150
- 'app/Http/Controllers/UserController.php',
1151
- ],
1152
- edges: [],
1153
- },
1154
- });
1155
- writeFileSync(
1156
- join(tempDir, 'composer.json'),
1157
- JSON.stringify({
1158
- require: {
1159
- 'laravel/framework': '^10.0',
1160
- },
1161
- }),
1162
- );
1163
-
1164
- const result = detector.detect(tempDir, report);
1165
-
1166
- expect(result.primaryFramework?.name).toBe('Laravel');
1167
- expect(result.toolchain.runCmd).toBe('php artisan serve');
1168
- expect(result.toolchain.migrateCmd).toBe('php artisan migrate');
1169
- expect(result.projectStructure).toBe('mvc');
1170
- });
1171
- });
1172
- });