@codeyam/codeyam-cli 0.1.0-staging.d0ad4ae → 0.1.0-staging.d3e886e

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 (798) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +10 -10
  4. package/analyzer-template/packages/ai/index.ts +21 -5
  5. package/analyzer-template/packages/ai/package.json +2 -2
  6. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
  7. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +226 -24
  8. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  9. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +183 -10
  10. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +181 -23
  12. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  13. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
  14. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +15 -0
  15. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
  16. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1215 -29
  17. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  18. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +265 -6
  19. package/analyzer-template/packages/ai/src/lib/completionCall.ts +216 -36
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1750 -318
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +54 -3
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +129 -20
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  32. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +393 -90
  33. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  34. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -0
  35. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  36. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  37. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +4 -3
  38. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +86 -149
  39. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +59 -3
  40. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1382 -65
  41. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +200 -196
  42. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +710 -0
  43. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  44. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  45. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  46. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +5 -5
  47. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
  48. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  49. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +111 -87
  50. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  51. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  52. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
  53. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +28 -170
  54. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  55. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  56. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
  57. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -89
  58. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  59. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +11 -11
  60. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  61. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  62. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
  63. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  64. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +122 -3
  65. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  66. package/analyzer-template/packages/analyze/index.ts +2 -0
  67. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  68. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
  69. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  70. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  71. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  72. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  73. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  74. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  75. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  76. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +447 -255
  77. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +31 -4
  78. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -0
  79. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  80. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  81. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +14 -14
  82. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +4 -4
  83. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
  84. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  85. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
  86. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  87. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
  88. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +193 -76
  89. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +203 -41
  90. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -188
  91. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +272 -23
  92. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +264 -0
  93. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +1 -0
  94. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +2 -3
  95. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +825 -71
  96. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  97. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  98. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  99. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  100. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  101. package/analyzer-template/packages/aws/package.json +3 -3
  102. package/analyzer-template/packages/database/package.json +1 -1
  103. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  104. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  105. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  106. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  107. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  108. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  109. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -1
  110. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  111. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +17 -1
  112. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  113. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  114. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  115. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  116. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  117. package/analyzer-template/packages/database/src/lib/loadCommits.ts +28 -0
  118. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
  119. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  120. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +7 -3
  121. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  122. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  123. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  124. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +7 -14
  125. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  126. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  127. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  128. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  129. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  130. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  131. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  132. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  133. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  134. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  135. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  136. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  137. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  139. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +11 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  142. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -18
  143. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  144. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  145. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  146. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  147. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  148. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +17 -1
  149. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
  150. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  151. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  152. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  153. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  154. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  155. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +1 -6
  156. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  157. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  158. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  159. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  160. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  161. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  162. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  163. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  164. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  165. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  166. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  167. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  168. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  169. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  170. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  171. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +22 -1
  172. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  173. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  174. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  175. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
  176. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  178. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  179. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  181. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
  182. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  183. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  184. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  185. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  186. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  187. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  188. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  189. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  190. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  191. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +5 -4
  192. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  193. package/analyzer-template/packages/github/dist/types/index.d.ts +3 -4
  194. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  195. package/analyzer-template/packages/github/dist/types/index.js +0 -1
  196. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  197. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +71 -27
  198. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  199. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  200. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  201. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  202. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  203. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +3 -54
  204. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  205. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js +1 -21
  206. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js.map +1 -1
  207. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
  208. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  209. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  210. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  211. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
  212. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  213. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  214. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  215. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  216. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  217. package/analyzer-template/packages/github/package.json +1 -1
  218. package/analyzer-template/packages/types/index.ts +3 -6
  219. package/analyzer-template/packages/types/src/types/Analysis.ts +87 -27
  220. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  221. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
  222. package/analyzer-template/packages/types/src/types/Scenario.ts +3 -77
  223. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +181 -5
  224. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  225. package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
  226. package/analyzer-template/packages/utils/dist/types/index.d.ts +3 -4
  227. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  228. package/analyzer-template/packages/utils/dist/types/index.js +0 -1
  229. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  230. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +71 -27
  231. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  232. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  233. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  234. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  235. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  236. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +3 -54
  237. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  238. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js +1 -21
  239. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js.map +1 -1
  240. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
  241. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  242. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  243. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  244. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
  245. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  246. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  247. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +93 -2
  248. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  249. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  250. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  251. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  252. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  253. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +108 -2
  254. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  255. package/analyzer-template/playwright/capture.ts +20 -8
  256. package/analyzer-template/playwright/captureStatic.ts +1 -1
  257. package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
  258. package/analyzer-template/project/analyzeBaselineCommit.ts +9 -0
  259. package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
  260. package/analyzer-template/project/analyzeFileEntities.ts +4 -0
  261. package/analyzer-template/project/analyzeRegularCommit.ts +9 -0
  262. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  263. package/analyzer-template/project/constructMockCode.ts +425 -43
  264. package/analyzer-template/project/controller/startController.ts +16 -1
  265. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  266. package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
  267. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  268. package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
  269. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  270. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  271. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  272. package/analyzer-template/project/orchestrateCapture.ts +71 -6
  273. package/analyzer-template/project/reconcileMockDataKeys.ts +214 -0
  274. package/analyzer-template/project/runAnalysis.ts +6 -0
  275. package/analyzer-template/project/start.ts +46 -12
  276. package/analyzer-template/project/writeMockDataTsx.ts +295 -10
  277. package/analyzer-template/project/writeScenarioComponents.ts +218 -26
  278. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  279. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  280. package/analyzer-template/tsconfig.json +2 -1
  281. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  282. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  283. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +7 -1
  284. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  285. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
  286. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
  287. package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
  288. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  289. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +7 -1
  290. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  291. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  292. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  293. package/background/src/lib/virtualized/project/constructMockCode.js +350 -13
  294. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  295. package/background/src/lib/virtualized/project/controller/startController.js +11 -1
  296. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
  297. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  298. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  299. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
  300. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
  301. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  302. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  303. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
  304. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
  305. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  306. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  307. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  308. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  309. package/background/src/lib/virtualized/project/orchestrateCapture.js +58 -6
  310. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  311. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +177 -0
  312. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  313. package/background/src/lib/virtualized/project/runAnalysis.js +5 -0
  314. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  315. package/background/src/lib/virtualized/project/start.js +42 -12
  316. package/background/src/lib/virtualized/project/start.js.map +1 -1
  317. package/background/src/lib/virtualized/project/writeMockDataTsx.js +251 -6
  318. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  319. package/background/src/lib/virtualized/project/writeScenarioComponents.js +164 -29
  320. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  321. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  322. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  323. package/codeyam-cli/scripts/apply-setup.js +180 -0
  324. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  325. package/codeyam-cli/src/cli.js +4 -0
  326. package/codeyam-cli/src/cli.js.map +1 -1
  327. package/codeyam-cli/src/codeyam-cli.js +18 -2
  328. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  329. package/codeyam-cli/src/commands/analyze.js +4 -2
  330. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  331. package/codeyam-cli/src/commands/baseline.js +10 -11
  332. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  333. package/codeyam-cli/src/commands/debug.js +37 -23
  334. package/codeyam-cli/src/commands/debug.js.map +1 -1
  335. package/codeyam-cli/src/commands/default.js +30 -34
  336. package/codeyam-cli/src/commands/default.js.map +1 -1
  337. package/codeyam-cli/src/commands/detect-universal-mocks.js +2 -0
  338. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -1
  339. package/codeyam-cli/src/commands/init.js +49 -257
  340. package/codeyam-cli/src/commands/init.js.map +1 -1
  341. package/codeyam-cli/src/commands/memory.js +264 -0
  342. package/codeyam-cli/src/commands/memory.js.map +1 -0
  343. package/codeyam-cli/src/commands/recapture.js +31 -18
  344. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  345. package/codeyam-cli/src/commands/report.js +46 -1
  346. package/codeyam-cli/src/commands/report.js.map +1 -1
  347. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  348. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  349. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  350. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  351. package/codeyam-cli/src/commands/start.js +8 -12
  352. package/codeyam-cli/src/commands/start.js.map +1 -1
  353. package/codeyam-cli/src/commands/test-startup.js +2 -0
  354. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  355. package/codeyam-cli/src/commands/verify.js +14 -2
  356. package/codeyam-cli/src/commands/verify.js.map +1 -1
  357. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +179 -0
  358. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  359. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  360. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  361. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +128 -82
  362. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  363. package/codeyam-cli/src/utils/analysisRunner.js +29 -15
  364. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  365. package/codeyam-cli/src/utils/analyzer.js +7 -0
  366. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  367. package/codeyam-cli/src/utils/backgroundServer.js +102 -21
  368. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  369. package/codeyam-cli/src/utils/generateReport.js +4 -3
  370. package/codeyam-cli/src/utils/generateReport.js.map +1 -1
  371. package/codeyam-cli/src/utils/install-skills.js +76 -37
  372. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  373. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  374. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  375. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  376. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  377. package/codeyam-cli/src/utils/progress.js +7 -0
  378. package/codeyam-cli/src/utils/progress.js.map +1 -1
  379. package/codeyam-cli/src/utils/queue/job.js +5 -0
  380. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  381. package/codeyam-cli/src/utils/queue/manager.js +6 -0
  382. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  383. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  384. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  385. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  386. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  387. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
  388. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  389. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  390. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  391. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  392. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  393. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  394. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  395. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  396. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  397. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
  398. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  399. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +378 -0
  400. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  401. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
  402. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  403. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  404. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  405. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  406. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  407. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  408. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  409. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  410. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  411. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  412. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  413. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  414. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  415. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  416. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  417. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  418. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  419. package/codeyam-cli/src/utils/rules/index.js +6 -0
  420. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  421. package/codeyam-cli/src/utils/rules/parser.js +83 -0
  422. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  423. package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
  424. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  425. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  426. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  427. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  428. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  429. package/codeyam-cli/src/utils/serverState.js +37 -10
  430. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  431. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +21 -42
  432. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  433. package/codeyam-cli/src/utils/versionInfo.js +25 -19
  434. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  435. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  436. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  437. package/codeyam-cli/src/webserver/app/lib/database.js +22 -6
  438. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  439. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  440. package/codeyam-cli/src/webserver/backgroundServer.js +50 -0
  441. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  442. package/codeyam-cli/src/webserver/bootstrap.js +51 -0
  443. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  444. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-jNYXRRNI.js +1 -0
  445. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-bwuHPyTa.js +11 -0
  446. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-CvzqMxcu.js} +1 -1
  447. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-BH0XDim7.js +41 -0
  448. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +34 -0
  449. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-yjIHlOGa.js +25 -0
  450. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-Cq5o8jL4.js} +1 -1
  451. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BvMu2i-g.js} +1 -1
  452. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-kgBTLoJD.js} +1 -1
  453. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BzPgx-xO.js +11 -0
  454. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-CwZrv-Ok.js} +1 -1
  455. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-BX2Ny2Qj.js +10 -0
  456. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-CDpEprKa.js} +1 -1
  457. package/codeyam-cli/src/webserver/build/client/assets/_index-BRx8ZGZo.js +11 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-4S4yPfFw.js +27 -0
  459. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +17 -0
  460. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  461. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  462. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  463. package/codeyam-cli/src/webserver/build/client/assets/book-open-D4IPYH_y.js +6 -0
  464. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-CG65viiV.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-DB3aFuEO.js} +12 -12
  466. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-igfMr5DY.js} +1 -1
  467. package/codeyam-cli/src/webserver/build/client/assets/copy-Coc4o_8c.js +11 -0
  468. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-BdhJEx6B.js → createLucideIcon-D1zB-pYc.js} +1 -1
  469. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
  470. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  471. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +1 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-D0-YwkBh.js → entity._sha._-B0h9AqE6.js} +12 -12
  473. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +6 -0
  474. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +6 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-C1H_a_Y3.js → entity._sha_.edit._scenarioId-PePWg17F.js} +1 -1
  476. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-I-Wo99C_.js} +1 -1
  477. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-9sMMAiWJ.js} +1 -1
  479. package/codeyam-cli/src/webserver/build/client/assets/files-Co65J0s3.js +1 -0
  480. package/codeyam-cli/src/webserver/build/client/assets/{git-CZu4fif0.js → git-BdHOxVfg.js} +8 -8
  481. package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +1 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-CUM5iXwc.js} +1 -1
  483. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-_417gcQW.js} +1 -1
  484. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-TzRHMVog.js} +1 -1
  486. package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +1 -0
  487. package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +78 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/pause-hjzB7t2z.js +11 -0
  489. package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +62 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-DcAwD_Ln.js} +1 -1
  491. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/simulations-DVNJVQgD.js +1 -0
  493. package/codeyam-cli/src/webserver/build/client/assets/terminal-DbEAHMbA.js +11 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-CAD5b1o_.js} +1 -1
  495. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-aSv48UbS.js → useLastLogLine-DAFqfEDH.js} +1 -1
  497. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DZlYx2c4.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-ihdMtlf6.js} +1 -1
  499. package/codeyam-cli/src/webserver/build/server/assets/index-CxaRxKVt.js +1 -0
  500. package/codeyam-cli/src/webserver/build/server/assets/server-build-D4DT0nM_.js +259 -0
  501. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  502. package/codeyam-cli/src/webserver/build-info.json +5 -5
  503. package/codeyam-cli/src/webserver/server.js +35 -25
  504. package/codeyam-cli/src/webserver/server.js.map +1 -1
  505. package/codeyam-cli/templates/{codeyam-debug-skill.md → codeyam-debug.md} +48 -4
  506. package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
  507. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  508. package/codeyam-cli/templates/codeyam-memory.md +396 -0
  509. package/codeyam-cli/templates/codeyam-new-rule.md +13 -0
  510. package/codeyam-cli/templates/{codeyam-setup-skill.md → codeyam-setup.md} +13 -1
  511. package/codeyam-cli/templates/{codeyam-sim-skill.md → codeyam-sim.md} +1 -1
  512. package/codeyam-cli/templates/{codeyam-test-skill.md → codeyam-test.md} +1 -1
  513. package/codeyam-cli/templates/{codeyam-verify-skill.md → codeyam-verify.md} +1 -1
  514. package/codeyam-cli/templates/rule-notification-hook.py +56 -0
  515. package/codeyam-cli/templates/rule-reflection-hook.py +627 -0
  516. package/codeyam-cli/templates/rules-instructions.md +132 -0
  517. package/package.json +15 -12
  518. package/packages/ai/index.js +8 -6
  519. package/packages/ai/index.js.map +1 -1
  520. package/packages/ai/src/lib/analyzeScope.js +179 -13
  521. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  522. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  523. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  524. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +138 -9
  525. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  526. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  527. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  528. package/packages/ai/src/lib/astScopes/methodSemantics.js +138 -23
  529. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  530. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  531. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  532. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
  533. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
  534. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +7 -0
  535. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
  536. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
  537. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  538. package/packages/ai/src/lib/astScopes/processExpression.js +931 -29
  539. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  540. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  541. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  542. package/packages/ai/src/lib/completionCall.js +178 -31
  543. package/packages/ai/src/lib/completionCall.js.map +1 -1
  544. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1367 -187
  545. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  546. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  547. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  548. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
  549. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  550. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
  551. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  552. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  553. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  554. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  555. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  556. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +52 -3
  557. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  558. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +111 -14
  559. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  560. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  561. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  562. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  563. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  564. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  565. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  566. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  567. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  568. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +333 -81
  569. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  570. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  571. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  572. package/packages/ai/src/lib/dataStructureChunking.js +130 -0
  573. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  574. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  575. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  576. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  577. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  578. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +4 -3
  579. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
  580. package/packages/ai/src/lib/generateChangesEntityScenarios.js +78 -120
  581. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
  582. package/packages/ai/src/lib/generateEntityDataStructure.js +47 -2
  583. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  584. package/packages/ai/src/lib/generateEntityScenarioData.js +1098 -60
  585. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  586. package/packages/ai/src/lib/generateEntityScenarios.js +177 -163
  587. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  588. package/packages/ai/src/lib/generateExecutionFlows.js +495 -0
  589. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  590. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  591. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  592. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  593. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  594. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  595. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  596. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -2
  597. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
  598. package/packages/ai/src/lib/isolateScopes.js +270 -7
  599. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  600. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  601. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  602. package/packages/ai/src/lib/mergeStatements.js +88 -46
  603. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  604. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  605. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  606. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  607. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  608. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
  609. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
  610. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -119
  611. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
  612. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  613. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  614. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
  615. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  616. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -70
  617. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
  618. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  619. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  620. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +9 -9
  621. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
  622. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  623. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  624. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  625. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  626. package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
  627. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
  628. package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
  629. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  630. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  631. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  632. package/packages/analyze/index.js +1 -0
  633. package/packages/analyze/index.js.map +1 -1
  634. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  635. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  636. package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
  637. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  638. package/packages/analyze/src/lib/analysisContext.js +30 -5
  639. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  640. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  641. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  642. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  643. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  644. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  645. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  646. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  647. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  648. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  649. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  650. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  651. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  652. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +189 -41
  653. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  654. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +21 -4
  655. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  656. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +5 -0
  657. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  658. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  659. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  660. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  661. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  662. package/packages/analyze/src/lib/files/analyzeChange.js +10 -10
  663. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  664. package/packages/analyze/src/lib/files/analyzeEntity.js +4 -4
  665. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
  666. package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
  667. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  668. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  669. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  670. package/packages/analyze/src/lib/files/enums/steps.js +1 -1
  671. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
  672. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  673. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  674. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
  675. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  676. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +164 -68
  677. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  678. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +178 -31
  679. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  680. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -129
  681. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
  682. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +187 -21
  683. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  684. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +144 -0
  685. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  686. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +1 -0
  687. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
  688. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +2 -3
  689. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
  690. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +670 -53
  691. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  692. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  693. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  694. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  695. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  696. package/packages/analyze/src/lib/index.js +1 -0
  697. package/packages/analyze/src/lib/index.js.map +1 -1
  698. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  699. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  700. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  701. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  702. package/packages/database/src/lib/analysisToDb.js +1 -1
  703. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  704. package/packages/database/src/lib/branchToDb.js +1 -1
  705. package/packages/database/src/lib/branchToDb.js.map +1 -1
  706. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  707. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  708. package/packages/database/src/lib/commitToDb.js +1 -1
  709. package/packages/database/src/lib/commitToDb.js.map +1 -1
  710. package/packages/database/src/lib/fileToDb.js +1 -1
  711. package/packages/database/src/lib/fileToDb.js.map +1 -1
  712. package/packages/database/src/lib/kysely/db.js +11 -1
  713. package/packages/database/src/lib/kysely/db.js.map +1 -1
  714. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  715. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  716. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  717. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  718. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  719. package/packages/database/src/lib/loadAnalyses.js +45 -2
  720. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  721. package/packages/database/src/lib/loadAnalysis.js +8 -0
  722. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  723. package/packages/database/src/lib/loadBranch.js +11 -1
  724. package/packages/database/src/lib/loadBranch.js.map +1 -1
  725. package/packages/database/src/lib/loadCommit.js +7 -0
  726. package/packages/database/src/lib/loadCommit.js.map +1 -1
  727. package/packages/database/src/lib/loadCommits.js +22 -1
  728. package/packages/database/src/lib/loadCommits.js.map +1 -1
  729. package/packages/database/src/lib/loadEntities.js +23 -4
  730. package/packages/database/src/lib/loadEntities.js.map +1 -1
  731. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  732. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  733. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
  734. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  735. package/packages/database/src/lib/projectToDb.js +1 -1
  736. package/packages/database/src/lib/projectToDb.js.map +1 -1
  737. package/packages/database/src/lib/saveFiles.js +1 -1
  738. package/packages/database/src/lib/saveFiles.js.map +1 -1
  739. package/packages/database/src/lib/scenarioToDb.js +1 -1
  740. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  741. package/packages/database/src/lib/updateCommitMetadata.js +5 -4
  742. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  743. package/packages/types/index.js +0 -1
  744. package/packages/types/index.js.map +1 -1
  745. package/packages/types/src/types/Scenario.js +1 -21
  746. package/packages/types/src/types/Scenario.js.map +1 -1
  747. package/packages/utils/src/lib/fs/rsyncCopy.js +93 -2
  748. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  749. package/packages/utils/src/lib/safeFileName.js +29 -3
  750. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  751. package/scripts/finalize-analyzer.cjs +8 -76
  752. package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -109
  753. package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -584
  754. package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -341
  755. package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -495
  756. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
  757. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -120
  758. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-Cmysw5OP.js +0 -1
  759. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CAneekK2.js +0 -41
  760. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-Cu16OUmx.js +0 -25
  761. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DcAUIpD_.js +0 -11
  762. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-BMKg0SAF.js +0 -15
  763. package/codeyam-cli/src/webserver/build/client/assets/_index-DSmTpjmK.js +0 -11
  764. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BF_aK4y6.js +0 -32
  765. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CKnwPCDr.js +0 -1
  766. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-RJCf3Tvw.js +0 -1
  767. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-EylcgScH.js +0 -1
  768. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DMe7kvgo.js +0 -1
  769. package/codeyam-cli/src/webserver/build/client/assets/files-BW7Cyeyi.js +0 -1
  770. package/codeyam-cli/src/webserver/build/client/assets/globals-wHVy_II5.css +0 -1
  771. package/codeyam-cli/src/webserver/build/client/assets/keyAttributeCoverage-CTlFMihX.js +0 -1
  772. package/codeyam-cli/src/webserver/build/client/assets/manifest-2d191949.js +0 -1
  773. package/codeyam-cli/src/webserver/build/client/assets/root-FHgpM6gc.js +0 -56
  774. package/codeyam-cli/src/webserver/build/client/assets/settings-6D8k8Jp5.js +0 -1
  775. package/codeyam-cli/src/webserver/build/client/assets/simulations-CDJZnWhN.js +0 -1
  776. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-Dv18q8LD.js +0 -1
  777. package/codeyam-cli/src/webserver/build/client/assets/useInteractiveMode-0ToGk4K3.js +0 -1
  778. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-1BX144Eg.js +0 -1
  779. package/codeyam-cli/src/webserver/build/server/assets/index-pU0o5t1o.js +0 -1
  780. package/codeyam-cli/src/webserver/build/server/assets/server-build-YzfkRwdn.js +0 -178
  781. package/codeyam-cli/templates/debug-codeyam.md +0 -625
  782. package/packages/ai/src/lib/findMatchingAttribute.js +0 -81
  783. package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
  784. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -425
  785. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
  786. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -267
  787. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
  788. package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -408
  789. package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
  790. package/packages/ai/src/lib/isFrontend.js +0 -5
  791. package/packages/ai/src/lib/isFrontend.js.map +0 -1
  792. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
  793. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
  794. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -77
  795. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
  796. /package/codeyam-cli/src/webserver/build/client/assets/{api.link-scenario-value-l0sNRNKZ.js → api.agent-transcripts-l0sNRNKZ.js} +0 -0
  797. /package/codeyam-cli/src/webserver/build/client/assets/{api.update-key-attributes-l0sNRNKZ.js → api.health-l0sNRNKZ.js} +0 -0
  798. /package/codeyam-cli/src/webserver/build/client/assets/{api.update-valid-values-l0sNRNKZ.js → api.labs-unlock-l0sNRNKZ.js} +0 -0
@@ -9,8 +9,12 @@ import { DataStructure } from '~codeyam/types';
9
9
  * enriches the mocked dependency's returnValueSchema so the LLM knows what fields
10
10
  * to generate for array elements.
11
11
  *
12
+ * Uses usageEquivalencies to trace data flow and ONLY enrich arrays with fields
13
+ * from children that actually receive elements from that array.
14
+ *
12
15
  * Example:
13
16
  * - getSurveysAction returns { data: array }
17
+ * - usageEquivalencies shows: surveys[] -> SurveyCard().signature[0].survey
14
18
  * - SurveyCard expects signature[0].survey.updatedAt: date
15
19
  * - After enrichment: getSurveysAction().data[]: object, data[].updatedAt: date
16
20
  */
@@ -21,6 +25,7 @@ export default function enrichArrayTypesFromChildSignatures(
21
25
  isMocked?: boolean;
22
26
  }[],
23
27
  dependencySchemas: DataStructure['dependencySchemas'],
28
+ usageEquivalencies?: DataStructure['usageEquivalencies'],
24
29
  ): void {
25
30
  // Find all mocked dependencies with array return types
26
31
  const mockedArrayPaths: {
@@ -43,7 +48,8 @@ export default function enrichArrayTypesFromChildSignatures(
43
48
  // - wrapThrows().data.createdBy (deeply nested)
44
49
  // - getStatusOptions().functionCallReturnValue (direct array return - usually options/primitives)
45
50
  for (const [path, type] of Object.entries(schema)) {
46
- if (type !== 'array') continue;
51
+ // Check if type is array (including nullable/optional variants like 'array | undefined')
52
+ if (!type.startsWith('array')) continue;
47
53
 
48
54
  // Skip paths with computed property patterns like [key], [i], [0], etc.
49
55
  // These represent dynamic access patterns, not simple data arrays
@@ -81,115 +87,226 @@ export default function enrichArrayTypesFromChildSignatures(
81
87
 
82
88
  if (mockedArrayPaths.length === 0) return;
83
89
 
84
- // Find all non-mocked child components and extract their signature fields
85
- // We check both direct imports AND all schemas in dependencySchemas because
86
- // transitive dependencies (e.g., SurveyCard imported by SurveysList imported by SurveysPage)
87
- // may have signature schemas that we need to use for enrichment.
88
- const childSignatureFields: {
89
- filePath: string;
90
- entityName: string;
91
- // Map of prop paths to types, e.g., { "survey.id": "string", "survey.updatedAt": "date" }
92
- propFields: Record<string, string>;
93
- }[] = [];
90
+ // Build a map from child component signature paths to their prop fields
91
+ // e.g., "SurveyCard().signature[0].survey" -> { "id": "string", "updatedAt": "date" }
92
+ const childSignatureFieldsByPath: Map<
93
+ string,
94
+ { propName: string; fields: Record<string, string> }
95
+ > = new Map();
94
96
 
95
- // Helper to extract prop fields from a signature schema
96
- const extractPropFields = (
97
+ // Helper to extract prop name and fields from a signature schema
98
+ const extractSignatureInfo = (
99
+ entityName: string,
97
100
  schema: Record<string, string>,
98
- ): Record<string, string> => {
99
- const propFields: Record<string, string> = {};
101
+ ): void => {
102
+ // Group by prop name (e.g., signature[0].survey.id, signature[0].survey.name -> "survey")
103
+ const propGroups: Record<string, Record<string, string>> = {};
104
+ // Also collect direct fields on signature[0] (e.g., signature[0].filePath -> "filePath")
105
+ const directFields: Record<string, string> = {};
106
+
100
107
  for (const [path, type] of Object.entries(schema)) {
101
- // Match signature[0].propName.field patterns
102
- const match = path.match(/^signature\[0\]\.(\w+)\.(.+)$/);
103
- if (match) {
104
- const [, , fieldPath] = match;
105
- // Store as "fieldPath" without the prop name prefix
106
- // e.g., signature[0].survey.updatedAt -> updatedAt
107
- propFields[fieldPath] = type;
108
+ // Match signature[0].propName.field or signature[0].propName[].field patterns
109
+ // The (?:\[\])? makes array props optional, handling both:
110
+ // - signature[0].survey.updatedAt (object prop)
111
+ // - signature[0].questionAnswers[].question.questionText (array prop)
112
+ const nestedMatch = path.match(/^signature\[0\]\.(\w+)(?:\[\])?\.(.+)$/);
113
+ if (nestedMatch) {
114
+ const [, propName, fieldPath] = nestedMatch;
115
+ propGroups[propName] ||= {};
116
+ propGroups[propName][fieldPath] = type;
117
+ continue;
108
118
  }
109
- }
110
- return propFields;
111
- };
112
-
113
- // First, check direct imports (non-mocked)
114
- const processedSchemas = new Set<string>();
115
- for (const importedExport of importedExports) {
116
- // Skip mocked dependencies - we want child components
117
- if (importedExport.isMocked || !importedExport.filePath) continue;
118
119
 
119
- const schemaKey = `${importedExport.filePath}::${importedExport.name}`;
120
- processedSchemas.add(schemaKey);
120
+ // Also match direct fields: signature[0].fieldName (single level, no nested path)
121
+ // This handles cases like TruncatedFilePath where filePath is passed directly
122
+ const directMatch = path.match(/^signature\[0\]\.(\w+)$/);
123
+ if (directMatch) {
124
+ const [, fieldName] = directMatch;
125
+ directFields[fieldName] = type;
126
+ }
127
+ }
121
128
 
122
- const schema =
123
- dependencySchemas?.[importedExport.filePath]?.[importedExport.name]
124
- ?.signatureSchema;
125
- if (!schema) continue;
129
+ // Store nested prop groups with the full signature path as key
130
+ for (const [propName, fields] of Object.entries(propGroups)) {
131
+ if (Object.keys(fields).length > 0) {
132
+ const signaturePath = `${entityName}().signature[0].${propName}`;
133
+ childSignatureFieldsByPath.set(signaturePath, { propName, fields });
134
+ }
135
+ }
126
136
 
127
- const propFields = extractPropFields(schema);
128
- if (Object.keys(propFields).length > 0) {
129
- childSignatureFields.push({
130
- filePath: importedExport.filePath,
131
- entityName: importedExport.name,
132
- propFields,
137
+ // Store direct fields with signature[0] as key (for when entire object is passed)
138
+ if (Object.keys(directFields).length > 0) {
139
+ const signaturePath = `${entityName}().signature[0]`;
140
+ childSignatureFieldsByPath.set(signaturePath, {
141
+ propName: '',
142
+ fields: directFields,
133
143
  });
134
144
  }
135
- }
145
+ };
136
146
 
137
- // Also check all schemas in dependencySchemas for transitive child components
138
- // that may not be in importedExports but have signature schemas with prop fields
147
+ // Process all schemas in dependencySchemas
139
148
  if (dependencySchemas) {
140
- for (const [filePath, entities] of Object.entries(dependencySchemas)) {
149
+ for (const [, entities] of Object.entries(dependencySchemas)) {
141
150
  for (const [entityName, schemas] of Object.entries(entities)) {
142
- const schemaKey = `${filePath}::${entityName}`;
143
- // Skip already processed schemas
144
- if (processedSchemas.has(schemaKey)) continue;
145
-
146
151
  const signatureSchema = schemas?.signatureSchema;
147
- if (!signatureSchema) continue;
148
-
149
- const propFields = extractPropFields(signatureSchema);
150
- if (Object.keys(propFields).length > 0) {
151
- childSignatureFields.push({
152
- filePath,
153
- entityName,
154
- propFields,
155
- });
152
+ if (signatureSchema) {
153
+ extractSignatureInfo(entityName, signatureSchema);
156
154
  }
157
155
  }
158
156
  }
159
157
  }
160
158
 
161
- if (childSignatureFields.length === 0) return;
159
+ if (childSignatureFieldsByPath.size === 0) return;
160
+
161
+ // Helper to check if a local variable name could be derived from a mocked function name
162
+ // e.g., "getSurveys" -> "surveys", "fetchUsers" -> "users", "loadData" -> "data"
163
+ // e.g., "getSurveysAction" -> "surveys" (removes "Action" suffix too)
164
+ const couldBeDerivedFrom = (
165
+ localVarName: string,
166
+ mockedFunctionName: string,
167
+ ): boolean => {
168
+ const normalizedVar = localVarName.toLowerCase().replace(/\[\]$/, '');
169
+ let normalizedFunc = mockedFunctionName.toLowerCase();
162
170
 
163
- // Enrich mocked dependency arrays with child signature fields
164
- // Only enrich arrays that don't already have element types defined
165
- // A more sophisticated approach would trace the data flow to match specific arrays to specific children
171
+ // Direct match (e.g., "surveys" from function "surveys")
172
+ if (normalizedFunc === normalizedVar) return true;
173
+
174
+ // Remove common prefixes like "get", "fetch", "load", "use"
175
+ const prefixPattern = /^(get|fetch|load|use)/i;
176
+ normalizedFunc = normalizedFunc.replace(prefixPattern, '');
177
+
178
+ // Remove common suffixes like "Action", "Query", "Mutation", "Handler"
179
+ const suffixPattern = /(action|query|mutation|handler)$/i;
180
+ normalizedFunc = normalizedFunc.replace(suffixPattern, '');
181
+
182
+ // Check if function name (without prefix/suffix) matches the variable name
183
+ if (normalizedFunc === normalizedVar) return true;
184
+
185
+ // Check for singular/plural relationship
186
+ // e.g., "survey" from "getSurveys" or "surveys" from "getSurvey"
187
+ if (
188
+ normalizedFunc.endsWith('s') &&
189
+ normalizedFunc.slice(0, -1) === normalizedVar
190
+ )
191
+ return true;
192
+ if (
193
+ normalizedVar.endsWith('s') &&
194
+ normalizedVar.slice(0, -1) === normalizedFunc
195
+ )
196
+ return true;
197
+
198
+ // Check if the array property name (like "data") is in the variable
199
+ // This handles cases like "const { data: surveys } = getSurveys()" where
200
+ // the local var might be the renamed destructured property
201
+ // Skip this for now as it's too loose
202
+
203
+ return false;
204
+ };
205
+
206
+ // For each mocked array, find which child signatures it flows to via usageEquivalencies
166
207
  for (const { filePath, entityName, arrayPath } of mockedArrayPaths) {
167
208
  const schema = dependencySchemas[filePath][entityName].returnValueSchema;
168
209
 
169
- // Check if this array already has element type definitions
210
+ // Check if this array already has INDEXED element type definitions (e.g., [0]: null)
170
211
  // If so, skip it - it's likely a specialized array like [null] for refs
212
+ // But DON'T skip if it only has general [] element types - those can be enriched
171
213
  const elementPathPrefix = `${arrayPath}[`;
172
- const hasExistingElementType = Object.keys(schema).some((path) =>
173
- path.startsWith(elementPathPrefix),
174
- );
214
+ const hasIndexedElementType = Object.keys(schema).some((path) => {
215
+ if (!path.startsWith(elementPathPrefix)) return false;
216
+ // Check if it's an indexed type like [0], [1], etc. vs general []
217
+ const afterPrefix = path.slice(elementPathPrefix.length);
218
+ // Indexed types start with a digit: [0], [1], etc.
219
+ return /^\d/.test(afterPrefix);
220
+ });
175
221
 
176
- if (hasExistingElementType) {
177
- // Array already has element type info (e.g., useAutoAnimate()[0]: null)
222
+ if (hasIndexedElementType) {
223
+ // Array already has indexed element type info (e.g., useAutoAnimate()[0]: null)
178
224
  // Don't override it with child signature fields
179
225
  continue;
180
226
  }
181
227
 
182
- // Add array element type
228
+ // Find matching child signatures via usageEquivalencies
229
+ // Look for equivalencies where this array (or local variables derived from it)
230
+ // flows to a child component's signature
231
+ const matchedFields: Record<string, string> = {};
232
+
233
+ if (usageEquivalencies) {
234
+ // Check all equivalency entries for paths that could be derived from this array
235
+ for (const [sourcePath, targets] of Object.entries(usageEquivalencies)) {
236
+ // Check if this source path relates to our mocked array
237
+ // Direct match: "getSurveysAction().functionCallReturnValue.data[]"
238
+ // Indirect match: local variable like "surveys[]" that comes from the array
239
+ if (!sourcePath.endsWith('[]')) continue;
240
+
241
+ // Get the local variable name from the source path (e.g., "surveys[]" -> "surveys")
242
+ const localVarName = sourcePath.replace(/\[\]$/, '');
243
+
244
+ // Check if this local variable could have come from this mocked function
245
+ // Use heuristics: name matching (getSurveys -> surveys, getUsers -> users)
246
+ // Also check if the array path ends with the local variable name
247
+ // e.g., useLoaderData().functionCallReturnValue.entities ends with .entities
248
+ const arrayEndsWithLocalVar = arrayPath.endsWith(`.${localVarName}`);
249
+ // Full-path usageEquivalencies (e.g., from same-file child components) use
250
+ // the complete call path as the local var name, which matches arrayPath exactly
251
+ const exactPathMatch = localVarName === arrayPath;
252
+ if (
253
+ !exactPathMatch &&
254
+ !couldBeDerivedFrom(localVarName, entityName) &&
255
+ !arrayEndsWithLocalVar
256
+ ) {
257
+ continue;
258
+ }
259
+
260
+ for (const target of targets) {
261
+ // Target should be something like "SurveyCard().signature[0].survey"
262
+ // or "SurveyCard().signature[0].surveys[]"
263
+ const { schemaPath } = target;
264
+
265
+ // Look for signature fields that match this target
266
+ // Handle both singular (survey) and plural (surveys[]) forms
267
+ const normalizedTarget = schemaPath.replace(/\[\]$/, '');
268
+
269
+ for (const [signaturePath, info] of childSignatureFieldsByPath) {
270
+ if (normalizedTarget === signaturePath) {
271
+ // Found a match! Add all fields from this child signature
272
+ for (const [fieldPath, type] of Object.entries(info.fields)) {
273
+ if (!matchedFields[fieldPath]) {
274
+ matchedFields[fieldPath] = type;
275
+ }
276
+ }
277
+ }
278
+ }
279
+ }
280
+ }
281
+ }
282
+
283
+ // If no equivalencies matched, skip this array entirely
284
+ // This prevents the bug where ALL child signatures get merged into ALL arrays
285
+ if (Object.keys(matchedFields).length === 0) {
286
+ continue;
287
+ }
288
+
289
+ // Add array element type and matched fields
183
290
  const elementPath = `${arrayPath}[]`;
184
291
  schema[elementPath] = 'object';
185
292
 
186
- // Add fields from all child signatures to the array element
187
- for (const { propFields } of childSignatureFields) {
188
- for (const [fieldPath, type] of Object.entries(propFields)) {
189
- const fullPath = `${elementPath}.${fieldPath}`;
190
- if (!schema[fullPath]) {
293
+ for (const [fieldPath, type] of Object.entries(matchedFields)) {
294
+ const fullPath = `${elementPath}.${fieldPath}`;
295
+ const existingType = schema[fullPath];
296
+ if (!existingType) {
297
+ schema[fullPath] = type;
298
+ } else {
299
+ // Prefer the more specific (narrower) type
300
+ const existingIsOptional =
301
+ existingType.includes('| undefined') ||
302
+ existingType.includes('| null');
303
+ const newIsOptional =
304
+ type.includes('| undefined') || type.includes('| null');
305
+ if (existingIsOptional && !newIsOptional) {
306
+ // Use the new type - it's more specific
191
307
  schema[fullPath] = type;
192
308
  }
309
+ // Otherwise keep existing (same specificity or existing is more specific)
193
310
  }
194
311
  }
195
312
  }
@@ -1,7 +1,8 @@
1
- // import { writeFile } from 'fs/promises';
2
1
  import {
3
2
  convertDotNotation,
4
3
  fillInDirectSchemaGapsAndUnknowns,
4
+ buildSchemaIndexes,
5
+ type SchemaIndexes,
5
6
  joinParenthesesAndArrays,
6
7
  mergeJsonTypeDefinitions,
7
8
  splitOutsideParenthesesAndArrays,
@@ -166,6 +167,7 @@ function processCall(
166
167
  variableNameOccurrence: number | undefined,
167
168
  options: GatherDataForMocksOptions | undefined,
168
169
  hookCallIndex: number,
170
+ prebuiltIndexes?: SchemaIndexes,
169
171
  ): { key: string; value: JsonTypeDefinition } | null {
170
172
  const callName = importedExport.calls?.[callIndex] ?? importedExport.name;
171
173
 
@@ -270,21 +272,87 @@ function processCall(
270
272
  baseHasMultipleTypeParamVariants = typeParamVariantsInBase.size > 1;
271
273
  }
272
274
 
273
- // For type-parameterized calls where the base schema has MULTIPLE different type
274
- // parameter variants, use ONLY the call-specific schema to avoid contamination.
275
- // Otherwise, merge with base schema for complete coverage (e.g., array element details).
276
- const mergedSchema =
277
- hasCallSpecificSchema && hasTypeParams && baseHasMultipleTypeParamVariants
278
- ? rawSchema // Use ONLY the call-specific schema when base has mixed type params
279
- : Object.keys(rawSchema).length === 0
280
- ? baseSchema
281
- : { ...baseSchema, ...rawSchema };
275
+ // For type-parameterized calls where we have a call-specific schema, we need to
276
+ // be careful about merging with the base schema. The base schema may contain
277
+ // merged data from ALL type parameter variants, which would pollute the result.
278
+ let mergedSchema: Record<string, string>;
279
+ if (hasCallSpecificSchema && hasTypeParams) {
280
+ if (baseHasMultipleTypeParamVariants) {
281
+ // Base schema has paths with different type parameters - filter to only
282
+ // include paths matching the current type parameter.
283
+ const typeParamMatch = callName.match(/<([^>]+)>/);
284
+ const currentTypeParam = typeParamMatch ? typeParamMatch[1] : null;
285
+ const baseFunctionName = cleanFunctionName(callName.split('(')[0]);
286
+
287
+ if (currentTypeParam) {
288
+ // Filter base schema to only include paths that:
289
+ // 1. Match current type param (e.g., useLoaderData<LoaderData>())
290
+ // 2. OR don't have any type param (generic paths like useLoaderData())
291
+ const filteredBaseSchema: Record<string, string> = {};
292
+ for (const [path, type] of Object.entries(baseSchema)) {
293
+ // Check if path has a type parameter for this function
294
+ const pathTypeParamMatch = path.match(
295
+ new RegExp(`^${escapeRegExp(baseFunctionName)}<([^>]+)>\\(`),
296
+ );
297
+ if (pathTypeParamMatch) {
298
+ // Path has a type param - only include if it matches current
299
+ if (pathTypeParamMatch[1] === currentTypeParam) {
300
+ filteredBaseSchema[path] = type;
301
+ }
302
+ // Otherwise skip (it's for a different type param variant)
303
+ } else {
304
+ // Path doesn't have a type param for this function - include it
305
+ // (could be generic paths or paths for other functions)
306
+ filteredBaseSchema[path] = type;
307
+ }
308
+ }
309
+ mergedSchema = { ...filteredBaseSchema, ...rawSchema };
310
+ } else {
311
+ // Couldn't extract type param - fall back to rawSchema only
312
+ mergedSchema = rawSchema;
313
+ }
314
+ } else {
315
+ // Base schema has zero or one type-parameterized variant.
316
+ // When there's only one variant, the base schema paths are safe to merge
317
+ // (no contamination from other variants). This is important for cases like:
318
+ // - Array element details (gitStatus[].path) that are in base but not call-specific
319
+ // - Enriched paths that should be preserved
320
+ // Filter to only include paths matching current type param or generic paths.
321
+ const typeParamMatch = callName.match(/<([^>]+)>/);
322
+ const currentTypeParam = typeParamMatch ? typeParamMatch[1] : null;
323
+ const baseFunctionName = cleanFunctionName(callName.split('(')[0]);
324
+
325
+ if (currentTypeParam) {
326
+ const filteredBaseSchema: Record<string, string> = {};
327
+ for (const [path, type] of Object.entries(baseSchema)) {
328
+ const pathTypeParamMatch = path.match(
329
+ new RegExp(`^${escapeRegExp(baseFunctionName)}<([^>]+)>\\(`),
330
+ );
331
+ if (pathTypeParamMatch) {
332
+ // Path has a type param - only include if it matches current
333
+ if (pathTypeParamMatch[1] === currentTypeParam) {
334
+ filteredBaseSchema[path] = type;
335
+ }
336
+ } else {
337
+ // Path doesn't have a type param - include generic paths
338
+ filteredBaseSchema[path] = type;
339
+ }
340
+ }
341
+ mergedSchema = { ...filteredBaseSchema, ...rawSchema };
342
+ } else {
343
+ // No type param to extract - merge normally
344
+ mergedSchema = { ...baseSchema, ...rawSchema };
345
+ }
346
+ }
347
+ } else if (Object.keys(rawSchema).length === 0) {
348
+ mergedSchema = baseSchema;
349
+ } else {
350
+ mergedSchema = { ...baseSchema, ...rawSchema };
351
+ }
282
352
 
283
353
  // Preprocess to filter signatures and extract functionCallReturnValue
284
354
  let preprocessedSchema = preprocessSchemaForMocks(mergedSchema);
285
355
 
286
- const functionNames: string[] = [];
287
-
288
356
  const isFunctionNameWithoutFunction = (
289
357
  path: string,
290
358
  functionName: string,
@@ -369,38 +437,66 @@ function processCall(
369
437
  }
370
438
  }
371
439
 
372
- const relevantMergedDependencySchema = Object.keys(preprocessedSchema).reduce(
373
- (acc, path) => {
374
- if (path.endsWith(')')) {
375
- const pathParts = splitOutsideParenthesesAndArrays(path);
376
- const functionName = joinParenthesesAndArrays([
377
- ...pathParts.slice(0, -1),
378
- pathParts[pathParts.length - 1].split('(')[0],
379
- ]);
380
- functionNames.push(functionName);
381
- for (const existingPath in acc) {
382
- if (isFunctionNameWithoutFunction(existingPath, functionName)) {
383
- delete acc[existingPath];
384
- }
385
- }
386
- }
440
+ // Two-pass function name filtering to avoid O() retroactive deletion.
441
+ // Pass 1: Discover all unique function names from paths ending with ')'
442
+ const functionNameSet = new Set<string>();
443
+ const schemaKeys = Object.keys(preprocessedSchema);
444
+ for (const path of schemaKeys) {
445
+ if (path.endsWith(')')) {
446
+ const pathParts = splitOutsideParenthesesAndArrays(path);
447
+ const functionName = joinParenthesesAndArrays([
448
+ ...pathParts.slice(0, -1),
449
+ pathParts[pathParts.length - 1].split('(')[0],
450
+ ]);
451
+ functionNameSet.add(functionName);
452
+ }
453
+ }
387
454
 
388
- if (functionNames.some((fn) => isFunctionNameWithoutFunction(path, fn))) {
389
- return acc;
390
- }
455
+ // Index function names by first segment for O(1) bucket lookup instead of
456
+ // checking all function names for every path. Most paths only need to check
457
+ // 1-2 function names instead of all F.
458
+ const fnByFirstSegment = new Map<string, string[]>();
459
+ for (const fn of functionNameSet) {
460
+ const dotIdx = fn.indexOf('.');
461
+ const firstSeg = dotIdx >= 0 ? fn.slice(0, dotIdx) : fn;
462
+ let bucket = fnByFirstSegment.get(firstSeg);
463
+ if (!bucket) {
464
+ bucket = [];
465
+ fnByFirstSegment.set(firstSeg, bucket);
466
+ }
467
+ bucket.push(fn);
468
+ }
391
469
 
392
- acc[path] = preprocessedSchema[path];
393
- return acc;
394
- },
395
- {} as Record<string, string>,
396
- );
470
+ // Pass 2: Filter paths that match any discovered function name prefix.
471
+ // Use indexed lookup: extract path's first segment, check only matching function names.
472
+ const relevantMergedDependencySchema: Record<string, string> = {};
473
+ for (const path of schemaKeys) {
474
+ // Extract first segment of path (before first '.', '(', or '<')
475
+ const dotIdx = path.indexOf('.');
476
+ const parenIdx = path.indexOf('(');
477
+ const angleIdx = path.indexOf('<');
478
+ let minIdx = path.length;
479
+ if (dotIdx >= 0 && dotIdx < minIdx) minIdx = dotIdx;
480
+ if (parenIdx >= 0 && parenIdx < minIdx) minIdx = parenIdx;
481
+ if (angleIdx >= 0 && angleIdx < minIdx) minIdx = angleIdx;
482
+ const firstSeg = path.slice(0, minIdx);
483
+
484
+ const candidates = fnByFirstSegment.get(firstSeg);
485
+ if (
486
+ !candidates ||
487
+ !candidates.some((fn) => isFunctionNameWithoutFunction(path, fn))
488
+ ) {
489
+ relevantMergedDependencySchema[path] = preprocessedSchema[path];
490
+ }
491
+ }
397
492
 
398
- const schema = convertDotNotation(
399
- fillInDirectSchemaGapsAndUnknowns({
400
- scopeName: importedExport.name,
401
- schema: relevantMergedDependencySchema,
402
- }),
403
- );
493
+ const filledSchema = fillInDirectSchemaGapsAndUnknowns({
494
+ scopeName: importedExport.name,
495
+ schema: relevantMergedDependencySchema,
496
+ prebuiltIndexes,
497
+ });
498
+
499
+ const schema = convertDotNotation(filledSchema);
404
500
 
405
501
  // Determine if this is an object-style or hook-style dependency:
406
502
  // - Hook-style: calls = ['useAuth()'] - call starts with name + '('
@@ -501,6 +597,33 @@ export default function gatherDataForMocks(
501
597
  dependencySchemas: DataStructure['dependencySchemas'],
502
598
  options?: GatherDataForMocksOptions,
503
599
  ) {
600
+ // Build schema indexes ONCE from all dependency schemas combined.
601
+ // This avoids rebuilding indexes (~1-2 seconds for 18k keys) for each processCall.
602
+ //
603
+ // IMPORTANT: We must preprocess schemas BEFORE building indexes!
604
+ // The schemas contain .functionCallReturnValue paths that get stripped during processing.
605
+ // If we build indexes from original paths, lookups with preprocessed paths will fail.
606
+ // Example: 'hook().functionCallReturnValue.x.length' → index maps 'hook().functionCallReturnValue.x' → ['length']
607
+ // But preprocessed path 'hook().x.length' looks for 'hook().x' which doesn't exist in the index.
608
+ const allSchemaKeys: Record<string, string> = {};
609
+ if (dependencySchemas) {
610
+ for (const filePath in dependencySchemas) {
611
+ for (const entityName in dependencySchemas[filePath]) {
612
+ const schema =
613
+ dependencySchemas[filePath][entityName]?.returnValueSchema;
614
+ if (schema) {
615
+ // Preprocess each schema to remove .functionCallReturnValue before collecting
616
+ const preprocessed = preprocessSchemaForMocks(schema);
617
+ Object.assign(allSchemaKeys, preprocessed);
618
+ }
619
+ }
620
+ }
621
+ }
622
+ const prebuiltIndexes =
623
+ Object.keys(allSchemaKeys).length > 0
624
+ ? buildSchemaIndexes(allSchemaKeys)
625
+ : undefined;
626
+
504
627
  // Track the global index for each hook name across all imports
505
628
  // This enables canonical keys like EntityName::useLoaderData::0, EntityName::useFetcher::0, etc.
506
629
  const hookCallIndices: Record<string, number> = {};
@@ -586,6 +709,7 @@ export default function gatherDataForMocks(
586
709
  undefined,
587
710
  options,
588
711
  hookCallIndex,
712
+ prebuiltIndexes,
589
713
  );
590
714
 
591
715
  if (processResult) {
@@ -650,7 +774,42 @@ export default function gatherDataForMocks(
650
774
  occurrence,
651
775
  options,
652
776
  hookCallIndex,
777
+ prebuiltIndexes,
778
+ );
779
+ if (processResult) {
780
+ addResultToAccumulator(acc, processResult.key, processResult.value);
781
+ }
782
+ }
783
+ } else if (
784
+ // Handle multiple UNIQUE type-parameterized direct calls when variable count doesn't match.
785
+ // This happens when a hook is called with different type parameters (useFetcher<TypeA>(), useFetcher<TypeB>()),
786
+ // but the callVariableNames count doesn't match directCallCount (common with rest spread patterns).
787
+ // Each unique call signature should get its own entry in dataForMocks.
788
+ uniqueDirectCalls.length > 1 &&
789
+ !allDirectCallsIdentical(directCalls) &&
790
+ hasDirectFunctionCall
791
+ ) {
792
+ // Process each UNIQUE direct call signature
793
+ for (let i = 0; i < uniqueDirectCalls.length; i++) {
794
+ const callSignature = uniqueDirectCalls[i];
795
+
796
+ // Find the index of this call in the original calls array
797
+ const callIndex = (importedExport.calls ?? []).indexOf(callSignature);
798
+ if (callIndex === -1) continue;
799
+
800
+ const hookCallIndex = hookCallIndices[hookName] ?? 0;
801
+ hookCallIndices[hookName] = hookCallIndex + 1;
802
+
803
+ const processResult = processCall(
804
+ importedExport,
805
+ dependencySchemas,
806
+ callIndex,
807
+ undefined,
808
+ options,
809
+ hookCallIndex,
810
+ prebuiltIndexes,
653
811
  );
812
+
654
813
  if (processResult) {
655
814
  addResultToAccumulator(acc, processResult.key, processResult.value);
656
815
  }
@@ -669,6 +828,7 @@ export default function gatherDataForMocks(
669
828
  undefined,
670
829
  options,
671
830
  hookCallIndex,
831
+ prebuiltIndexes,
672
832
  );
673
833
 
674
834
  // Check if we got a meaningful result (not empty object or null)
@@ -713,6 +873,7 @@ export default function gatherDataForMocks(
713
873
  0, // Use 0 to trigger variable-qualified lookup
714
874
  options,
715
875
  hookCallIndex,
876
+ prebuiltIndexes,
716
877
  );
717
878
  if (varQualifiedResult && varQualifiedResult.value) {
718
879
  mergedValue = mergeJsonTypeDefinitions(
@@ -749,6 +910,7 @@ export default function gatherDataForMocks(
749
910
  0, // Use 0 to trigger variable-qualified lookup
750
911
  options,
751
912
  hookCallIndex,
913
+ prebuiltIndexes,
752
914
  );
753
915
  if (varQualifiedResult && varQualifiedResult.value) {
754
916
  // Deep merge the value into the accumulated result