@codeyam/codeyam-cli 0.1.0-staging.dd216e0 → 0.1.0-staging.e090cb3

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 (958) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/common/execAsync.ts +1 -1
  3. package/analyzer-template/log.txt +3 -3
  4. package/analyzer-template/package.json +16 -13
  5. package/analyzer-template/packages/ai/index.ts +21 -5
  6. package/analyzer-template/packages/ai/package.json +3 -3
  7. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
  8. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +226 -24
  9. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +205 -10
  11. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  12. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +181 -23
  13. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  14. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
  15. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +38 -1
  16. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
  17. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1507 -117
  18. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  19. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +324 -5
  20. package/analyzer-template/packages/ai/src/lib/checkAllAttributes.ts +29 -10
  21. package/analyzer-template/packages/ai/src/lib/completionCall.ts +216 -36
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +2227 -350
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +7 -2
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +296 -35
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +120 -76
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +54 -3
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +161 -19
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +149 -11
  32. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
  33. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  34. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  35. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +396 -88
  36. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  37. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +174 -0
  38. package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
  39. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  40. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  41. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +74 -7
  42. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +89 -112
  43. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +59 -3
  44. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1421 -92
  45. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +216 -109
  46. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +614 -0
  47. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  48. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  49. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  50. package/analyzer-template/packages/ai/src/lib/getConditionalUsagesFromCode.ts +143 -31
  51. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +8 -2
  52. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
  53. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  54. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +111 -87
  55. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  56. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +17 -7
  57. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
  58. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +32 -102
  59. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  60. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  61. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
  62. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -53
  63. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  64. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +28 -2
  65. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  66. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  67. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
  68. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  69. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +127 -3
  70. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  71. package/analyzer-template/packages/analyze/index.ts +2 -0
  72. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +79 -59
  73. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
  74. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  75. package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +1 -0
  76. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
  77. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  78. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  79. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  80. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  81. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  82. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  83. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +532 -275
  84. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +34 -1
  85. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -0
  86. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +3 -0
  87. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  88. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  89. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +31 -15
  90. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +11 -7
  91. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
  92. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  93. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
  94. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  95. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
  96. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +201 -46
  97. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
  98. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +620 -49
  99. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.ts +1 -1
  100. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -62
  101. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +380 -45
  102. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +264 -0
  103. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +78 -83
  104. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +4 -8
  105. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +876 -123
  106. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  107. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  108. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  109. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  110. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  111. package/analyzer-template/packages/aws/codebuild/index.ts +1 -0
  112. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +11 -1
  113. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -1
  114. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +29 -18
  115. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -1
  116. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +2 -2
  117. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -1
  118. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +2 -2
  119. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -1
  120. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +8 -18
  121. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -1
  122. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +17 -61
  123. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -1
  124. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts +15 -0
  125. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts.map +1 -0
  126. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js +31 -0
  127. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js.map +1 -0
  128. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -1
  129. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +8 -1
  130. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -1
  131. package/analyzer-template/packages/aws/package.json +3 -3
  132. package/analyzer-template/packages/aws/s3/index.ts +1 -0
  133. package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +43 -19
  134. package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +3 -3
  135. package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +17 -69
  136. package/analyzer-template/packages/aws/src/lib/s3/checkS3ObjectExists.ts +47 -0
  137. package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +8 -1
  138. package/analyzer-template/packages/database/package.json +1 -1
  139. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  140. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  141. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  142. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  143. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  144. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  145. package/analyzer-template/packages/database/src/lib/kysely/db.ts +18 -5
  146. package/analyzer-template/packages/database/src/lib/kysely/tableRelations.ts +2 -2
  147. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  148. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +36 -9
  149. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  150. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  151. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  152. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  153. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  154. package/analyzer-template/packages/database/src/lib/loadCommits.ts +28 -0
  155. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
  156. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  157. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +7 -3
  158. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  159. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  160. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  161. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +7 -14
  162. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  163. package/analyzer-template/packages/generate/index.ts +3 -0
  164. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +17 -1
  165. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +193 -0
  166. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
  167. package/analyzer-template/packages/generate/src/lib/deepMerge.ts +26 -1
  168. package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
  169. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  170. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  171. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  172. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  173. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  174. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  175. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  176. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  178. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  179. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  181. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -2
  182. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  183. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +13 -3
  184. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  185. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts +2 -2
  186. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -11
  187. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  188. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  189. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  190. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  191. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  192. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +30 -7
  193. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
  194. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js +9 -3
  195. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  196. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +1 -0
  197. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -1
  198. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  199. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  200. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  201. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  202. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +2 -6
  203. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  204. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  205. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  206. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  207. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  208. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  209. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  210. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  211. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  212. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  213. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  214. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  215. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  216. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  217. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  218. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +22 -1
  219. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  220. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  221. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  222. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
  223. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  224. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  225. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  226. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  227. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  228. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
  229. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  230. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  231. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  232. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  233. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  234. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  235. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  236. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  237. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  238. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +5 -4
  239. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  240. package/analyzer-template/packages/github/dist/generate/index.d.ts +3 -0
  241. package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -1
  242. package/analyzer-template/packages/github/dist/generate/index.js +3 -0
  243. package/analyzer-template/packages/github/dist/generate/index.js.map +1 -1
  244. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -1
  245. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
  246. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
  247. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
  248. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
  249. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
  250. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  251. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
  252. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
  253. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  254. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  255. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts.map +1 -1
  256. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js +27 -1
  257. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js.map +1 -1
  258. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
  259. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
  260. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
  261. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  262. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -1
  263. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +10 -0
  264. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -1
  265. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -1
  266. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +3 -0
  267. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -1
  268. package/analyzer-template/packages/github/dist/types/index.d.ts +2 -2
  269. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  270. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  271. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +87 -13
  272. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  273. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  274. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  275. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +2 -0
  276. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -1
  277. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  278. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  279. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +11 -6
  280. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  281. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +199 -3
  282. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  283. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  284. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  285. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
  286. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  287. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  288. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  289. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  290. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  291. package/analyzer-template/packages/github/package.json +1 -1
  292. package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +14 -0
  293. package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +2 -0
  294. package/analyzer-template/packages/process/index.ts +2 -0
  295. package/analyzer-template/packages/process/package.json +12 -0
  296. package/analyzer-template/packages/process/tsconfig.json +8 -0
  297. package/analyzer-template/packages/types/index.ts +5 -0
  298. package/analyzer-template/packages/types/src/types/Analysis.ts +104 -13
  299. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  300. package/analyzer-template/packages/types/src/types/Entity.ts +2 -0
  301. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
  302. package/analyzer-template/packages/types/src/types/Scenario.ts +11 -10
  303. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +228 -3
  304. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  305. package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
  306. package/analyzer-template/packages/utils/dist/types/index.d.ts +2 -2
  307. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  308. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  309. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +87 -13
  310. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  311. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  312. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  313. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +2 -0
  314. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -1
  315. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  316. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  317. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +11 -6
  318. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  319. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +199 -3
  320. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  321. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  322. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  323. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
  324. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  325. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  326. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  327. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  328. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  329. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  330. package/analyzer-template/playwright/capture.ts +57 -26
  331. package/analyzer-template/playwright/captureStatic.ts +1 -1
  332. package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
  333. package/analyzer-template/playwright/waitForServer.ts +21 -6
  334. package/analyzer-template/project/analyzeBaselineCommit.ts +9 -0
  335. package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
  336. package/analyzer-template/project/analyzeFileEntities.ts +4 -0
  337. package/analyzer-template/project/analyzeRegularCommit.ts +9 -0
  338. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  339. package/analyzer-template/project/constructMockCode.ts +1199 -167
  340. package/analyzer-template/project/controller/startController.ts +16 -1
  341. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  342. package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
  343. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  344. package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
  345. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  346. package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +3 -6
  347. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  348. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  349. package/analyzer-template/project/orchestrateCapture.ts +81 -9
  350. package/analyzer-template/project/reconcileMockDataKeys.ts +245 -2
  351. package/analyzer-template/project/runAnalysis.ts +11 -0
  352. package/analyzer-template/project/serverOnlyModules.ts +127 -2
  353. package/analyzer-template/project/start.ts +51 -15
  354. package/analyzer-template/project/startScenarioCapture.ts +6 -0
  355. package/analyzer-template/project/writeMockDataTsx.ts +403 -61
  356. package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
  357. package/analyzer-template/project/writeScenarioComponents.ts +395 -98
  358. package/analyzer-template/project/writeScenarioFiles.ts +26 -0
  359. package/analyzer-template/project/writeSimpleRoot.ts +31 -23
  360. package/analyzer-template/scripts/comboWorkerLoop.cjs +99 -50
  361. package/analyzer-template/scripts/defaultCmd.sh +9 -0
  362. package/analyzer-template/tsconfig.json +2 -1
  363. package/background/src/lib/local/createLocalAnalyzer.js +2 -30
  364. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  365. package/background/src/lib/local/execAsync.js +1 -1
  366. package/background/src/lib/local/execAsync.js.map +1 -1
  367. package/background/src/lib/virtualized/common/execAsync.js +1 -1
  368. package/background/src/lib/virtualized/common/execAsync.js.map +1 -1
  369. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +7 -1
  370. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  371. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
  372. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
  373. package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
  374. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  375. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +7 -1
  376. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  377. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  378. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  379. package/background/src/lib/virtualized/project/constructMockCode.js +1060 -125
  380. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  381. package/background/src/lib/virtualized/project/controller/startController.js +11 -1
  382. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
  383. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  384. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  385. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
  386. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
  387. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  388. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  389. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
  390. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
  391. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  392. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  393. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +3 -2
  394. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -1
  395. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  396. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  397. package/background/src/lib/virtualized/project/orchestrateCapture.js +65 -10
  398. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  399. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +204 -2
  400. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  401. package/background/src/lib/virtualized/project/runAnalysis.js +9 -0
  402. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  403. package/background/src/lib/virtualized/project/serverOnlyModules.js +106 -3
  404. package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -1
  405. package/background/src/lib/virtualized/project/start.js +47 -15
  406. package/background/src/lib/virtualized/project/start.js.map +1 -1
  407. package/background/src/lib/virtualized/project/startScenarioCapture.js +7 -0
  408. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  409. package/background/src/lib/virtualized/project/writeMockDataTsx.js +350 -50
  410. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  411. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
  412. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
  413. package/background/src/lib/virtualized/project/writeScenarioComponents.js +303 -83
  414. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  415. package/background/src/lib/virtualized/project/writeScenarioFiles.js +19 -0
  416. package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -1
  417. package/background/src/lib/virtualized/project/writeSimpleRoot.js +31 -21
  418. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  419. package/codeyam-cli/scripts/apply-setup.js +180 -0
  420. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  421. package/codeyam-cli/src/cli.js +9 -1
  422. package/codeyam-cli/src/cli.js.map +1 -1
  423. package/codeyam-cli/src/codeyam-cli.js +18 -2
  424. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  425. package/codeyam-cli/src/commands/analyze.js +3 -1
  426. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  427. package/codeyam-cli/src/commands/baseline.js +176 -0
  428. package/codeyam-cli/src/commands/baseline.js.map +1 -0
  429. package/codeyam-cli/src/commands/debug.js +37 -23
  430. package/codeyam-cli/src/commands/debug.js.map +1 -1
  431. package/codeyam-cli/src/commands/default.js +30 -34
  432. package/codeyam-cli/src/commands/default.js.map +1 -1
  433. package/codeyam-cli/src/commands/detect-universal-mocks.js +2 -0
  434. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -1
  435. package/codeyam-cli/src/commands/init.js +49 -257
  436. package/codeyam-cli/src/commands/init.js.map +1 -1
  437. package/codeyam-cli/src/commands/memory.js +264 -0
  438. package/codeyam-cli/src/commands/memory.js.map +1 -0
  439. package/codeyam-cli/src/commands/recapture.js +31 -18
  440. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  441. package/codeyam-cli/src/commands/report.js +72 -24
  442. package/codeyam-cli/src/commands/report.js.map +1 -1
  443. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  444. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  445. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  446. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  447. package/codeyam-cli/src/commands/start.js +8 -12
  448. package/codeyam-cli/src/commands/start.js.map +1 -1
  449. package/codeyam-cli/src/commands/status.js +23 -1
  450. package/codeyam-cli/src/commands/status.js.map +1 -1
  451. package/codeyam-cli/src/commands/test-startup.js +3 -1
  452. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  453. package/codeyam-cli/src/commands/verify.js +14 -2
  454. package/codeyam-cli/src/commands/verify.js.map +1 -1
  455. package/codeyam-cli/src/commands/wipe.js +108 -0
  456. package/codeyam-cli/src/commands/wipe.js.map +1 -0
  457. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  458. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  459. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +128 -82
  460. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  461. package/codeyam-cli/src/utils/analysisRunner.js +29 -15
  462. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  463. package/codeyam-cli/src/utils/analyzer.js +7 -0
  464. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  465. package/codeyam-cli/src/utils/backgroundServer.js +16 -2
  466. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  467. package/codeyam-cli/src/utils/database.js +91 -5
  468. package/codeyam-cli/src/utils/database.js.map +1 -1
  469. package/codeyam-cli/src/utils/generateReport.js +253 -106
  470. package/codeyam-cli/src/utils/generateReport.js.map +1 -1
  471. package/codeyam-cli/src/utils/git.js +79 -0
  472. package/codeyam-cli/src/utils/git.js.map +1 -0
  473. package/codeyam-cli/src/utils/install-skills.js +76 -37
  474. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  475. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  476. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  477. package/codeyam-cli/src/utils/progress.js +7 -0
  478. package/codeyam-cli/src/utils/progress.js.map +1 -1
  479. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +38 -0
  480. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  481. package/codeyam-cli/src/utils/queue/job.js +138 -18
  482. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  483. package/codeyam-cli/src/utils/queue/manager.js +25 -7
  484. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  485. package/codeyam-cli/src/utils/queue/persistence.js.map +1 -1
  486. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  487. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  488. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  489. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  490. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
  491. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  492. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  493. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  494. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  495. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  496. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  497. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  498. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  499. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  500. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
  501. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  502. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +378 -0
  503. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  504. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
  505. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  506. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  507. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  508. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  509. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  510. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  511. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  512. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  513. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  514. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  515. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  516. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  517. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  518. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  519. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  520. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  521. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  522. package/codeyam-cli/src/utils/rules/index.js +6 -0
  523. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  524. package/codeyam-cli/src/utils/rules/parser.js +83 -0
  525. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  526. package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
  527. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  528. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  529. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  530. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  531. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  532. package/codeyam-cli/src/utils/serverState.js +37 -10
  533. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  534. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +21 -42
  535. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  536. package/codeyam-cli/src/utils/versionInfo.js +25 -19
  537. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  538. package/codeyam-cli/src/utils/wipe.js +128 -0
  539. package/codeyam-cli/src/utils/wipe.js.map +1 -0
  540. package/codeyam-cli/src/webserver/app/lib/database.js +88 -23
  541. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  542. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  543. package/codeyam-cli/src/webserver/backgroundServer.js +26 -5
  544. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  545. package/codeyam-cli/src/webserver/bootstrap.js +40 -0
  546. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  547. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CA3JxPb7.js +1 -0
  548. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-B86KKU7e.js +11 -0
  549. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-CMjhlvyu.js → EntityTypeBadge-B5ctlSYt.js} +1 -1
  550. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-BqY8gDAW.js +41 -0
  551. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-ClaLpuOo.js +34 -0
  552. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-BDhPilK7.js +25 -0
  553. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-DXN1aCbt.js → LibraryFunctionPreview-VeqEBv9v.js} +1 -1
  554. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BmEO4Lqa.js → LoadingDots-Bs7Nn1Jr.js} +1 -1
  555. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CI1VaB3F.js → LogViewer-Bm3PmcCz.js} +1 -1
  556. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-CgMEzchJ.js +11 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DQddU4F4.js → SafeScreenshot-Gq3Ocjo6.js} +1 -1
  558. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-CBui0id_.js +10 -0
  559. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-Dt7eySG0.js → TruncatedFilePath-CiwXDxLh.js} +1 -1
  560. package/codeyam-cli/src/webserver/build/client/assets/_index-B3TDXxnk.js +11 -0
  561. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BtBFH820.js +27 -0
  562. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-CN61MOMa.js +11 -0
  563. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  564. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  565. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  567. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  568. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  569. package/codeyam-cli/src/webserver/build/client/assets/book-open-PttOB2SF.js +6 -0
  570. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-ITTv_xL3.js → chevron-down-TJp6ofnp.js} +1 -1
  571. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-JE9ZIoBl.js +51 -0
  572. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-mMM0RzI0.js → circle-check-CXhHQYrI.js} +1 -1
  573. package/codeyam-cli/src/webserver/build/client/assets/copy-6y9ALfGT.js +11 -0
  574. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-en9_3LGg.js → createLucideIcon-Ca9fAY46.js} +1 -1
  575. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
  576. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  577. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C0epRiVn.js +1 -0
  578. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-DBgKdrTR.js → entity._sha._-BVnB8a9L.js} +12 -12
  579. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CBoafmVs.js +6 -0
  580. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DGgZjdFg.js +6 -0
  581. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-Sf59Z2Pa.js → entity._sha_.edit._scenarioId-38yPijoD.js} +2 -2
  582. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-BvGka1gZ.js → entry.client-BSHEfydn.js} +6 -6
  583. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-_IuKNgFH.js → fileTableUtils-DCPhhSMo.js} +1 -1
  585. package/codeyam-cli/src/webserver/build/client/assets/files-0N0YJQv7.js +1 -0
  586. package/codeyam-cli/src/webserver/build/client/assets/{git-8zM4ebXo.js → git-DXnyr8uP.js} +8 -8
  587. package/codeyam-cli/src/webserver/build/client/assets/globals-CKT08Djd.css +1 -0
  588. package/codeyam-cli/src/webserver/build/client/assets/{index-DFbRIdR_.js → index-CcsFv748.js} +1 -1
  589. package/codeyam-cli/src/webserver/build/client/assets/{index-CkpJhcNC.js → index-ChN9-fAY.js} +1 -1
  590. package/codeyam-cli/src/webserver/build/client/assets/labs-BLJ7HxOC.js +1 -0
  591. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-DEtRABV3.js → loader-circle-CTqLEAGU.js} +1 -1
  592. package/codeyam-cli/src/webserver/build/client/assets/manifest-b171b9d3.js +1 -0
  593. package/codeyam-cli/src/webserver/build/client/assets/memory-CCQd4aZA.js +78 -0
  594. package/codeyam-cli/src/webserver/build/client/assets/pause-D6vreykR.js +11 -0
  595. package/codeyam-cli/src/webserver/build/client/assets/root-CHhiHoo_.js +62 -0
  596. package/codeyam-cli/src/webserver/build/client/assets/{search-Clp3R4kH.js → search-B8VUL8nl.js} +1 -1
  597. package/codeyam-cli/src/webserver/build/client/assets/settings-BejnUJ6R.js +1 -0
  598. package/codeyam-cli/src/webserver/build/client/assets/simulations-CPoAg7Zo.js +1 -0
  599. package/codeyam-cli/src/webserver/build/client/assets/terminal-BrCP7uQo.js +11 -0
  600. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CUVskfkL.js → triangle-alert-BZz2NjYa.js} +1 -1
  601. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DNwUduNu.js +1 -0
  602. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-CHT-Bzx5.js → useLastLogLine-COky1GVF.js} +1 -1
  603. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-CpZgwliL.js +1 -0
  604. package/codeyam-cli/src/webserver/build/client/assets/{useToast-BCR_pi3-.js → useToast-Bv9JFvUO.js} +1 -1
  605. package/codeyam-cli/src/webserver/build/server/assets/index-8Fv-lH1-.js +1 -0
  606. package/codeyam-cli/src/webserver/build/server/assets/server-build-Akn3iYFP.js +257 -0
  607. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  608. package/codeyam-cli/src/webserver/build-info.json +5 -5
  609. package/codeyam-cli/src/webserver/devServer.js +1 -3
  610. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  611. package/codeyam-cli/src/webserver/server.js +35 -25
  612. package/codeyam-cli/src/webserver/server.js.map +1 -1
  613. package/codeyam-cli/templates/{codeyam-debug-skill.md → codeyam-debug.md} +48 -4
  614. package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
  615. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  616. package/codeyam-cli/templates/codeyam-memory.md +392 -0
  617. package/codeyam-cli/templates/codeyam-new-rule.md +13 -0
  618. package/codeyam-cli/templates/{codeyam-setup-skill.md → codeyam-setup.md} +151 -4
  619. package/codeyam-cli/templates/{codeyam-sim-skill.md → codeyam-sim.md} +1 -1
  620. package/codeyam-cli/templates/{codeyam-test-skill.md → codeyam-test.md} +1 -1
  621. package/codeyam-cli/templates/{codeyam-verify-skill.md → codeyam-verify.md} +1 -1
  622. package/codeyam-cli/templates/rule-notification-hook.py +56 -0
  623. package/codeyam-cli/templates/rule-reflection-hook.py +627 -0
  624. package/codeyam-cli/templates/rules-instructions.md +132 -0
  625. package/package.json +14 -11
  626. package/packages/ai/index.js +8 -6
  627. package/packages/ai/index.js.map +1 -1
  628. package/packages/ai/src/lib/analyzeScope.js +179 -13
  629. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  630. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  631. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  632. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +154 -9
  633. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  634. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  635. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  636. package/packages/ai/src/lib/astScopes/methodSemantics.js +138 -23
  637. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  638. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  639. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  640. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
  641. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
  642. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +23 -0
  643. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
  644. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
  645. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  646. package/packages/ai/src/lib/astScopes/processExpression.js +1137 -96
  647. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  648. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  649. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  650. package/packages/ai/src/lib/checkAllAttributes.js +24 -9
  651. package/packages/ai/src/lib/checkAllAttributes.js.map +1 -1
  652. package/packages/ai/src/lib/completionCall.js +178 -31
  653. package/packages/ai/src/lib/completionCall.js.map +1 -1
  654. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1741 -208
  655. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  656. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +7 -2
  657. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  658. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +230 -23
  659. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  660. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +77 -55
  661. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  662. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  663. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  664. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  665. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  666. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +52 -3
  667. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  668. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +139 -13
  669. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  670. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  671. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  672. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +133 -11
  673. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  674. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
  675. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
  676. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  677. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  678. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  679. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  680. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +334 -79
  681. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  683. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  684. package/packages/ai/src/lib/dataStructureChunking.js +126 -0
  685. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  686. package/packages/ai/src/lib/deepEqual.js +32 -0
  687. package/packages/ai/src/lib/deepEqual.js.map +1 -0
  688. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  689. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  690. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  691. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  692. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +62 -5
  693. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
  694. package/packages/ai/src/lib/generateChangesEntityScenarios.js +81 -90
  695. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
  696. package/packages/ai/src/lib/generateEntityDataStructure.js +47 -2
  697. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  698. package/packages/ai/src/lib/generateEntityScenarioData.js +1128 -85
  699. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  700. package/packages/ai/src/lib/generateEntityScenarios.js +193 -83
  701. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  702. package/packages/ai/src/lib/generateExecutionFlows.js +414 -0
  703. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  704. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  705. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  706. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  707. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  708. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  709. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  710. package/packages/ai/src/lib/getConditionalUsagesFromCode.js +84 -14
  711. package/packages/ai/src/lib/getConditionalUsagesFromCode.js.map +1 -1
  712. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -1
  713. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
  714. package/packages/ai/src/lib/isolateScopes.js +270 -7
  715. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  716. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  717. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  718. package/packages/ai/src/lib/mergeStatements.js +88 -46
  719. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  720. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  721. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  722. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +16 -4
  723. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  724. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
  725. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
  726. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -64
  727. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
  728. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  729. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  730. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
  731. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  732. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -34
  733. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
  734. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  735. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  736. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +16 -3
  737. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
  738. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  739. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  740. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  741. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  742. package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
  743. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
  744. package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
  745. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  746. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  747. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  748. package/packages/analyze/index.js +1 -0
  749. package/packages/analyze/index.js.map +1 -1
  750. package/packages/analyze/src/lib/FileAnalyzer.js +75 -36
  751. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  752. package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
  753. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  754. package/packages/analyze/src/lib/analysisContext.js +30 -5
  755. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  756. package/packages/analyze/src/lib/asts/nodes/index.js +1 -0
  757. package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -1
  758. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
  759. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
  760. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  761. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  762. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  763. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  764. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  765. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  766. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  767. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  768. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  769. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  770. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  771. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  772. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +268 -52
  773. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  774. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +24 -1
  775. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  776. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +5 -0
  777. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  778. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +2 -0
  779. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  780. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  781. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  782. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  783. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  784. package/packages/analyze/src/lib/files/analyzeChange.js +21 -11
  785. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  786. package/packages/analyze/src/lib/files/analyzeEntity.js +9 -8
  787. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
  788. package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
  789. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  790. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  791. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  792. package/packages/analyze/src/lib/files/enums/steps.js +1 -1
  793. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
  794. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  795. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  796. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
  797. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  798. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +170 -40
  799. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  800. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
  801. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
  802. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +480 -46
  803. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  804. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js +1 -1
  805. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js.map +1 -1
  806. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -34
  807. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
  808. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +268 -51
  809. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  810. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +144 -0
  811. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  812. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +56 -69
  813. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
  814. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +4 -8
  815. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
  816. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +738 -111
  817. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  818. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  819. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  820. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  821. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  822. package/packages/analyze/src/lib/index.js +1 -0
  823. package/packages/analyze/src/lib/index.js.map +1 -1
  824. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  825. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  826. package/packages/aws/src/lib/ecs/ecsDefineContainer.js +2 -2
  827. package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -1
  828. package/packages/aws/src/lib/ecs/ecsTaskFactory.js +17 -61
  829. package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -1
  830. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  831. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  832. package/packages/database/src/lib/analysisToDb.js +1 -1
  833. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  834. package/packages/database/src/lib/branchToDb.js +1 -1
  835. package/packages/database/src/lib/branchToDb.js.map +1 -1
  836. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  837. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  838. package/packages/database/src/lib/commitToDb.js +1 -1
  839. package/packages/database/src/lib/commitToDb.js.map +1 -1
  840. package/packages/database/src/lib/fileToDb.js +1 -1
  841. package/packages/database/src/lib/fileToDb.js.map +1 -1
  842. package/packages/database/src/lib/kysely/db.js +13 -3
  843. package/packages/database/src/lib/kysely/db.js.map +1 -1
  844. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  845. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  846. package/packages/database/src/lib/kysely/tables/debugReportsTable.js +9 -3
  847. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  848. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  849. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  850. package/packages/database/src/lib/loadAnalyses.js +45 -2
  851. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  852. package/packages/database/src/lib/loadAnalysis.js +8 -0
  853. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  854. package/packages/database/src/lib/loadBranch.js +11 -1
  855. package/packages/database/src/lib/loadBranch.js.map +1 -1
  856. package/packages/database/src/lib/loadCommit.js +7 -0
  857. package/packages/database/src/lib/loadCommit.js.map +1 -1
  858. package/packages/database/src/lib/loadCommits.js +22 -1
  859. package/packages/database/src/lib/loadCommits.js.map +1 -1
  860. package/packages/database/src/lib/loadEntities.js +23 -4
  861. package/packages/database/src/lib/loadEntities.js.map +1 -1
  862. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  863. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  864. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
  865. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  866. package/packages/database/src/lib/projectToDb.js +1 -1
  867. package/packages/database/src/lib/projectToDb.js.map +1 -1
  868. package/packages/database/src/lib/saveFiles.js +1 -1
  869. package/packages/database/src/lib/saveFiles.js.map +1 -1
  870. package/packages/database/src/lib/scenarioToDb.js +1 -1
  871. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  872. package/packages/database/src/lib/updateCommitMetadata.js +5 -4
  873. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  874. package/packages/generate/index.js +3 -0
  875. package/packages/generate/index.js.map +1 -1
  876. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
  877. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
  878. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
  879. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  880. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  881. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  882. package/packages/generate/src/lib/deepMerge.js +27 -1
  883. package/packages/generate/src/lib/deepMerge.js.map +1 -1
  884. package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
  885. package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  886. package/packages/github/src/lib/loadOrCreateCommit.js +10 -0
  887. package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -1
  888. package/packages/github/src/lib/syncPrimaryBranch.js +3 -0
  889. package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -1
  890. package/packages/process/index.js +3 -0
  891. package/packages/process/index.js.map +1 -0
  892. package/packages/process/src/GlobalProcessManager.js.map +1 -0
  893. package/{background/src/lib/process → packages/process/src}/ProcessManager.js +1 -1
  894. package/packages/process/src/ProcessManager.js.map +1 -0
  895. package/packages/process/src/index.js.map +1 -0
  896. package/packages/process/src/managedExecAsync.js.map +1 -0
  897. package/packages/types/index.js.map +1 -1
  898. package/packages/utils/src/lib/safeFileName.js +29 -3
  899. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  900. package/scripts/finalize-analyzer.cjs +8 -76
  901. package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -102
  902. package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -197
  903. package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -271
  904. package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -294
  905. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
  906. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -115
  907. package/analyzer-template/process/INTEGRATION_COMPLETE.md +0 -333
  908. package/analyzer-template/process/INTEGRATION_EXAMPLE.md +0 -525
  909. package/analyzer-template/process/README.md +0 -507
  910. package/background/src/lib/process/GlobalProcessManager.js.map +0 -1
  911. package/background/src/lib/process/ProcessManager.js.map +0 -1
  912. package/background/src/lib/process/index.js.map +0 -1
  913. package/background/src/lib/process/managedExecAsync.js.map +0 -1
  914. package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js +0 -238
  915. package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js.map +0 -1
  916. package/codeyam-cli/scripts/fixtures/formbricks/universal-mocks/apps/web/lib/instance/service.js +0 -7
  917. package/codeyam-cli/scripts/fixtures/formbricks/universal-mocks/apps/web/lib/instance/service.js.map +0 -1
  918. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-DpUOH11S.js +0 -1
  919. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-Cxs_KUEt.js +0 -41
  920. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-D_gPUolj.js +0 -25
  921. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-MbTu_hOR.js +0 -11
  922. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-Diqfd5nO.js +0 -15
  923. package/codeyam-cli/src/webserver/build/client/assets/_index-D0tNX0Y7.js +0 -11
  924. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-CV8R8fpo.js +0 -32
  925. package/codeyam-cli/src/webserver/build/client/assets/chunk-JMJ3UQ3L-Tv-88Jsz.js +0 -51
  926. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Cw7TE00E.js +0 -1
  927. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DUOKD0lj.js +0 -1
  928. package/codeyam-cli/src/webserver/build/client/assets/files-DMW0hD4L.js +0 -1
  929. package/codeyam-cli/src/webserver/build/client/assets/globals-D3y4cv7l.css +0 -1
  930. package/codeyam-cli/src/webserver/build/client/assets/manifest-18ff0544.js +0 -1
  931. package/codeyam-cli/src/webserver/build/client/assets/root-BuQ6JiJU.js +0 -51
  932. package/codeyam-cli/src/webserver/build/client/assets/settings-DzIyX7wI.js +0 -1
  933. package/codeyam-cli/src/webserver/build/client/assets/simulations-BKNqbrwU.js +0 -1
  934. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-By4FnEmE.js +0 -1
  935. package/codeyam-cli/src/webserver/build/server/assets/index-CzKXayO4.js +0 -1
  936. package/codeyam-cli/src/webserver/build/server/assets/server-build-CHRMAMo8.js +0 -166
  937. package/codeyam-cli/templates/debug-codeyam.md +0 -576
  938. package/packages/ai/src/lib/findMatchingAttribute.js +0 -77
  939. package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
  940. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -136
  941. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
  942. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -220
  943. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
  944. package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -241
  945. package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
  946. package/packages/ai/src/lib/isFrontend.js +0 -5
  947. package/packages/ai/src/lib/isFrontend.js.map +0 -1
  948. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
  949. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
  950. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -72
  951. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
  952. /package/analyzer-template/{process → packages/process/src}/GlobalProcessManager.ts +0 -0
  953. /package/analyzer-template/{process → packages/process/src}/ProcessManager.ts +0 -0
  954. /package/analyzer-template/{process → packages/process/src}/index.ts +0 -0
  955. /package/analyzer-template/{process → packages/process/src}/managedExecAsync.ts +0 -0
  956. /package/{background/src/lib/process → packages/process/src}/GlobalProcessManager.js +0 -0
  957. /package/{background/src/lib/process → packages/process/src}/index.js +0 -0
  958. /package/{background/src/lib/process → packages/process/src}/managedExecAsync.js +0 -0
@@ -4,19 +4,27 @@ import { awsLog, awsLogDebugLevel } from '~codeyam/utils';
4
4
  import measureAndReportExecutionTime from '../../../utils/measureAndReportExecutionTime';
5
5
 
6
6
  import {
7
+ deduplicateFunctionSchemas,
8
+ detectWrapperRequirements,
7
9
  fillInDirectSchemaGapsAndUnknowns,
8
10
  generateEntityDataStructure,
9
- deduplicateFunctionSchemas,
11
+ getConditionalUsages,
10
12
  getEquivalentSignatureVariables,
11
13
  getFunctionSignature,
12
14
  getReturnValue,
13
15
  getSourceEquivalencies,
14
16
  getUsageEquivalencies,
15
- getConditionalUsages,
16
- detectWrapperRequirements,
17
+ getConditionalEffects,
18
+ getCompoundConditionals,
19
+ getChildBoundaryGatingConditions,
20
+ getJsxRenderingUsages,
21
+ skipWorkerPool,
17
22
  } from '~codeyam/ai';
18
23
  import type { AnalysisOptions } from '../analyzeEntities';
19
24
 
25
+ // Set to true to process entities one at a time for easier debugging.
26
+ const DEBUG_SEQUENTIAL_EXECUTION = false;
27
+
20
28
  // VERSION MARKER: server-only-detection-v2 (2025-12-28)
21
29
  // This version includes automatic detection of "use server" and "server-only" files
22
30
  // and runs server-only detection even for cached entities
@@ -31,266 +39,268 @@ export default async function prepareEntityDataStructures(
31
39
  projectAnalyzer: ProjectAnalyzer,
32
40
  options: AnalysisOptions,
33
41
  ): Promise<void> {
34
- console.log(
35
- 'CodeYam: prepareEntityDataStructures RUNNING (server-only-detection-v3)',
36
- );
37
- console.log(
38
- `CodeYam: prepareEntityDataStructures processing ${allEntities.size} entities`,
39
- );
40
-
41
- // Log all entity names for debugging
42
- const entityNames = Array.from(allEntities).map((e) => e.name);
43
- console.log(
44
- `CodeYam: prepareEntityDataStructures entity names: ${entityNames.join(', ')}`,
45
- );
46
-
47
- // Process entities in parallel for speed
48
- await Promise.all(
49
- Array.from(allEntities).map(async (entity) => {
50
- // Check if already has cached data structure (unless force is set)
51
- const hasCache = !!entity.metadata?.isolatedDataStructure;
52
- const shouldRegenerateDataStructure =
53
- !hasCache || options.force || options.forceAll;
54
-
55
- // PHASE 1: Generate data structure (only for non-cached entities or when forced)
56
- // Wrapped in its own try-catch so PHASE 2 always runs even if this fails
57
- if (shouldRegenerateDataStructure) {
58
- try {
59
- const fileAnalyzer = projectAnalyzer.getFileAnalyzerByPath(
60
- entity.resolvedFilePath ?? entity.filePath,
42
+ const processEntity = async (entity: Entity) => {
43
+ // Check if already has cached data structure (unless force is set)
44
+ const hasCache = !!entity.metadata?.isolatedDataStructure;
45
+ const shouldRegenerateDataStructure =
46
+ !hasCache || options.force || options.forceAll;
47
+
48
+ // PHASE 1: Generate data structure (only for non-cached entities or when forced)
49
+ // Wrapped in its own try-catch so PHASE 2 always runs even if this fails
50
+ if (shouldRegenerateDataStructure) {
51
+ try {
52
+ const fileAnalyzer = projectAnalyzer.getFileAnalyzerByPath(
53
+ entity.resolvedFilePath ?? entity.filePath,
54
+ );
55
+ if (!fileAnalyzer) {
56
+ awsLog(
57
+ `CodeYam: prepareEntityDataStructures: FileAnalyzer not found`,
58
+ {
59
+ entityFilePath: entity.filePath,
60
+ entityName: entity.name,
61
+ },
61
62
  );
62
- if (!fileAnalyzer) {
63
- awsLog(
64
- `CodeYam: prepareEntityDataStructures: FileAnalyzer not found`,
65
- {
66
- entityFilePath: entity.filePath,
67
- entityName: entity.name,
68
- },
69
- );
63
+ // Still continue to PHASE 2 for server-only detection
64
+ } else {
65
+ const dataStructureInfo =
66
+ await getEntityDataStructureAndFunctionCalls({
67
+ entity,
68
+ fileAnalyzer,
69
+ });
70
+
71
+ if (!dataStructureInfo?.isolatedDataStructure) {
72
+ // Data structure generation failed - entity will proceed with empty schemas
73
+ // This is okay - the entity can still be analyzed, just without detailed type info
74
+ if (['visual', 'library'].includes(entity.entityType)) {
75
+ // we'd really expect these to have data structures
76
+ awsLog(
77
+ `CodeYam: prepareEntityDataStructures: Failed to generate data structure for ${entity.filePath}:${entity.name}`,
78
+ );
79
+ }
70
80
  // Still continue to PHASE 2 for server-only detection
71
81
  } else {
72
- const dataStructureInfo =
73
- await getEntityDataStructureAndFunctionCalls({
74
- entity,
75
- fileAnalyzer,
76
- });
77
-
78
- if (!dataStructureInfo?.isolatedDataStructure) {
79
- // Data structure generation failed - entity will proceed with empty schemas
80
- // This is okay - the entity can still be analyzed, just without detailed type info
81
- if (['visual', 'library'].includes(entity.entityType)) {
82
- // we'd really expect these to have data structures
83
- awsLog(
84
- `CodeYam: prepareEntityDataStructures: Failed to generate data structure for ${entity.filePath}:${entity.name}`,
85
- );
82
+ const { isolatedDataStructure, functionCalls, callVariableNames } =
83
+ dataStructureInfo;
84
+
85
+ // Store data structure in entity metadata
86
+ entity.metadata ||= {};
87
+
88
+ // Deep clone dependencySchemas to avoid shared references
89
+ // We need to clone because getReturnValue() returns direct references to schema objects
90
+ // and multiple entities might reference the same dependency
91
+ const clonedDependencySchemas: typeof isolatedDataStructure.dependencySchemas =
92
+ {};
93
+ for (const filePath in isolatedDataStructure.dependencySchemas) {
94
+ clonedDependencySchemas[filePath] = {};
95
+ for (const entityName in isolatedDataStructure.dependencySchemas[
96
+ filePath
97
+ ]) {
98
+ const depSchema =
99
+ isolatedDataStructure.dependencySchemas[filePath][entityName];
100
+ clonedDependencySchemas[filePath][entityName] = {
101
+ signatureSchema: { ...depSchema.signatureSchema },
102
+ returnValueSchema: { ...depSchema.returnValueSchema },
103
+ usageEquivalencies: depSchema.usageEquivalencies,
104
+ sourceEquivalencies: depSchema.sourceEquivalencies,
105
+ };
86
106
  }
87
- // Still continue to PHASE 2 for server-only detection
88
- } else {
89
- const {
90
- isolatedDataStructure,
91
- functionCalls,
92
- callVariableNames,
93
- } = dataStructureInfo;
94
-
95
- // Store data structure in entity metadata
96
- entity.metadata ||= {};
97
-
98
- // Deep clone dependencySchemas to avoid shared references
99
- // We need to clone because getReturnValue() returns direct references to schema objects
100
- // and multiple entities might reference the same dependency
101
- const clonedDependencySchemas: typeof isolatedDataStructure.dependencySchemas =
102
- {};
103
- for (const filePath in isolatedDataStructure.dependencySchemas) {
104
- clonedDependencySchemas[filePath] = {};
105
- for (const entityName in isolatedDataStructure
106
- .dependencySchemas[filePath]) {
107
- const depSchema =
108
- isolatedDataStructure.dependencySchemas[filePath][
109
- entityName
110
- ];
111
- clonedDependencySchemas[filePath][entityName] = {
112
- signatureSchema: { ...depSchema.signatureSchema },
113
- returnValueSchema: { ...depSchema.returnValueSchema },
114
- usageEquivalencies: depSchema.usageEquivalencies,
115
- sourceEquivalencies: depSchema.sourceEquivalencies,
116
- };
117
- }
107
+ }
108
+
109
+ // LOGGING: Track dependencySchemas entity names for debugging :: format issues
110
+ const allEntityNames: string[] = [];
111
+ for (const filePath in clonedDependencySchemas) {
112
+ for (const entityName in clonedDependencySchemas[filePath]) {
113
+ allEntityNames.push(`${filePath}:${entityName}`);
118
114
  }
115
+ }
116
+ entity.metadata.isolatedDataStructure = {
117
+ signatureSchema: deduplicateFunctionSchemas(
118
+ isolatedDataStructure.signatureSchema,
119
+ ),
120
+ returnValueSchema: deduplicateFunctionSchemas(
121
+ isolatedDataStructure.returnValueSchema,
122
+ ),
123
+ equivalentSignatureVariables:
124
+ isolatedDataStructure.equivalentSignatureVariables,
125
+ dependencySchemas: clonedDependencySchemas,
126
+ environmentVariables: isolatedDataStructure.environmentVariables,
127
+ // Use enriched conditional usages with source tracing from analysis
128
+ conditionalUsages: isolatedDataStructure.conditionalUsages,
129
+ // Include conditional effects for execution flow generation
130
+ conditionalEffects: isolatedDataStructure.conditionalEffects,
131
+ // Include compound conditionals for complete execution flow generation
132
+ compoundConditionals: isolatedDataStructure.compoundConditionals,
133
+ // Include root entity's equivalencies for merge step
134
+ usageEquivalencies: isolatedDataStructure.usageEquivalencies,
135
+ sourceEquivalencies: isolatedDataStructure.sourceEquivalencies,
136
+ // Include child boundary gating conditions for child component flow merging
137
+ childBoundaryGatingConditions:
138
+ isolatedDataStructure.childBoundaryGatingConditions,
139
+ // Include JSX rendering usages for array size and text length flow generation
140
+ jsxRenderingUsages: isolatedDataStructure.jsxRenderingUsages,
141
+ };
142
+
143
+ // Detect wrapper requirements (Context providers, etc.)
144
+ const wrapperRequirements = detectWrapperRequirements({
145
+ entity,
146
+ fileAnalyzer,
147
+ });
148
+ if (wrapperRequirements.length > 0) {
149
+ entity.metadata.wrapperRequirements = wrapperRequirements;
150
+ }
119
151
 
120
- entity.metadata.isolatedDataStructure = {
121
- signatureSchema: deduplicateFunctionSchemas(
122
- isolatedDataStructure.signatureSchema,
123
- ),
124
- returnValueSchema: deduplicateFunctionSchemas(
125
- isolatedDataStructure.returnValueSchema,
126
- ),
127
- equivalentSignatureVariables:
128
- isolatedDataStructure.equivalentSignatureVariables,
129
- dependencySchemas: clonedDependencySchemas,
130
- environmentVariables:
131
- isolatedDataStructure.environmentVariables,
132
- // Use enriched conditional usages with source tracing from analysis
133
- conditionalUsages: isolatedDataStructure.conditionalUsages,
134
- // Include root entity's equivalencies for merge step
135
- usageEquivalencies: isolatedDataStructure.usageEquivalencies,
136
- sourceEquivalencies: isolatedDataStructure.sourceEquivalencies,
137
- };
138
-
139
- // Detect wrapper requirements (Context providers, etc.)
140
- const wrapperRequirements = detectWrapperRequirements({
141
- entity,
142
- fileAnalyzer,
143
- });
144
- if (wrapperRequirements.length > 0) {
145
- entity.metadata.wrapperRequirements = wrapperRequirements;
152
+ // Annotate imported exports with function call information
153
+ const importedExports = entity.metadata.importedExports ?? [];
154
+ for (const importedExport of importedExports) {
155
+ const relevantCalls = functionCalls[importedExport.name];
156
+ if (relevantCalls) {
157
+ importedExport.calls = relevantCalls;
146
158
  }
159
+ const relevantVariableNames =
160
+ callVariableNames[importedExport.name];
161
+ if (relevantVariableNames) {
162
+ importedExport.callVariableNames = relevantVariableNames;
163
+ }
164
+ }
147
165
 
148
- // Annotate imported exports with function call information
149
- const importedExports = entity.metadata.importedExports ?? [];
150
- for (const importedExport of importedExports) {
151
- const relevantCalls = functionCalls[importedExport.name];
166
+ // Annotate node module imports with function call information
167
+ for (const [path, infos] of Object.entries(
168
+ entity.metadata.nodeModuleImports ?? {},
169
+ )) {
170
+ for (const info of infos) {
171
+ const relevantCalls = functionCalls[info.name];
152
172
  if (relevantCalls) {
153
- importedExport.calls = relevantCalls;
173
+ info.calls = relevantCalls;
154
174
  }
155
- const relevantVariableNames =
156
- callVariableNames[importedExport.name];
175
+ const relevantVariableNames = callVariableNames[info.name];
157
176
  if (relevantVariableNames) {
158
- importedExport.callVariableNames = relevantVariableNames;
159
- }
160
- }
161
-
162
- // Annotate node module imports with function call information
163
- for (const [path, infos] of Object.entries(
164
- entity.metadata.nodeModuleImports ?? {},
165
- )) {
166
- for (const info of infos) {
167
- const relevantCalls = functionCalls[info.name];
168
- if (relevantCalls) {
169
- info.calls = relevantCalls;
170
- }
171
- const relevantVariableNames = callVariableNames[info.name];
172
- if (relevantVariableNames) {
173
- info.callVariableNames = relevantVariableNames;
174
- }
177
+ info.callVariableNames = relevantVariableNames;
175
178
  }
176
179
  }
177
180
  }
178
181
  }
179
- } catch (phase1Error) {
180
- console.warn(
181
- `CodeYam: prepareEntityDataStructures: PHASE 1 error for ${entity.filePath}:${entity.name}:`,
182
- phase1Error,
183
- );
184
- // Continue to PHASE 2 - server-only detection should still run
185
182
  }
186
- }
187
-
188
- try {
189
- // PHASE 2: Server-only detection and isMocked determination
190
- // This runs for ALL entities, even those with cached data structures
191
- // because server-only detection may have been added after the entity was cached
192
- const importedExports = entity.metadata?.importedExports ?? [];
193
- console.log(
194
- `CodeYam: [${entity.name}] Processing ${importedExports.length} importedExports for isMocked determination (cached: ${hasCache})`,
183
+ } catch (phase1Error) {
184
+ console.warn(
185
+ `CodeYam: prepareEntityDataStructures: PHASE 1 error for ${entity.filePath}:${entity.name}:`,
186
+ phase1Error,
195
187
  );
188
+ // Continue to PHASE 2 - server-only detection should still run
189
+ }
190
+ }
196
191
 
197
- const mockedDependencies = determineMockedDependencies(entity);
198
- for (const importedExport of importedExports) {
199
- // Skip if already has a definitive isMocked value (true or false, not null)
200
- // But re-check if isMocked is null or undefined - this handles previously cached entities
201
- if (
202
- importedExport.isMocked === true ||
203
- importedExport.isMocked === false
204
- ) {
205
- console.log(
206
- `CodeYam: [${entity.name}] SKIP ${importedExport.name} - already has isMocked=${importedExport.isMocked}`,
207
- );
208
- continue;
209
- }
210
-
211
- // Never mock visual components - they render UI and should use real implementation
212
- if (importedExport.entityType === 'visual') {
213
- console.log(
214
- `CodeYam: [${entity.name}] SKIP ${importedExport.name} - visual component, setting isMocked=false`,
215
- );
216
- importedExport.isMocked = false;
217
- continue;
218
- }
219
-
220
- // Always mock imports from server-only files ("use server" or import "server-only")
221
- // These files contain Server Actions or server-only code that cannot run on the client
222
- const importedFilePath =
223
- importedExport.resolvedFilePath ?? importedExport.filePath;
224
- const importedFileAnalyzer =
225
- projectAnalyzer.getFileAnalyzerByPath(importedFilePath);
226
- // Use sourceFile.getText() which is always available, unlike file.content which is lazy-loaded
227
- const importedFileContent =
228
- importedFileAnalyzer?.sourceFile?.getText();
229
-
230
- const isServerOnly = importedFileContent
231
- ? isServerOnlyFile(importedFileContent)
232
- : false;
233
- console.log(
234
- `CodeYam: [${entity.name}] CHECK ${importedExport.name} from ${importedFilePath}:`,
235
- {
236
- hasFileAnalyzer: !!importedFileAnalyzer,
237
- hasSourceFile: !!importedFileAnalyzer?.sourceFile,
238
- hasFileContent: !!importedFileContent,
239
- contentFirst50Chars: importedFileContent
240
- ?.substring(0, 50)
241
- ?.replace(/\n/g, '\\n'),
242
- isServerOnly,
243
- },
244
- );
192
+ try {
193
+ // PHASE 2: Server-only detection and isMocked determination
194
+ // This runs for ALL entities, even those with cached data structures
195
+ // because server-only detection may have been added after the entity was cached
196
+ const importedExports = entity.metadata?.importedExports ?? [];
197
+ const mockedDependencies = determineMockedDependencies(entity);
198
+ for (const importedExport of importedExports) {
199
+ // Skip if already has a definitive isMocked value (true or false, not null)
200
+ // But re-check if isMocked is null or undefined - this handles previously cached entities
201
+ if (
202
+ importedExport.isMocked === true ||
203
+ importedExport.isMocked === false
204
+ ) {
205
+ continue;
206
+ }
245
207
 
246
- if (importedFileContent && isServerOnly) {
247
- console.log(
248
- `CodeYam: [${entity.name}] ✓ MARKING ${importedExport.name} as isMocked=true (server-only file detected)`,
249
- );
250
- importedExport.isMocked = true;
251
- continue;
252
- }
208
+ // Never mock visual components - they render UI and should use real implementation
209
+ if (importedExport.entityType === 'visual') {
210
+ importedExport.isMocked = false;
211
+ continue;
212
+ }
253
213
 
254
- const matchesMockedDep = mockedDependencies.some(
255
- (dep) =>
256
- dep.filePath === importedExport.filePath &&
257
- dep.entityName === importedExport.name,
258
- );
259
- importedExport.isMocked = matchesMockedDep;
260
- console.log(
261
- `CodeYam: [${entity.name}] ${importedExport.name} isMocked=${matchesMockedDep} (from mockedDependencies)`,
262
- );
214
+ // Always mock imports from server-only files ("use server" or import "server-only")
215
+ // These files contain Server Actions or server-only code that cannot run on the client
216
+ const importedFilePath =
217
+ importedExport.resolvedFilePath ?? importedExport.filePath;
218
+ const importedFileAnalyzer =
219
+ projectAnalyzer.getFileAnalyzerByPath(importedFilePath);
220
+ // Use sourceFile.getText() which is always available, unlike file.content which is lazy-loaded
221
+ const importedFileContent = importedFileAnalyzer?.sourceFile?.getText();
222
+
223
+ const isServerOnly = importedFileContent
224
+ ? isServerOnlyFile(importedFileContent)
225
+ : false;
226
+
227
+ if (importedFileContent && isServerOnly) {
228
+ importedExport.isMocked = true;
229
+ continue;
263
230
  }
264
231
 
265
- // Browser globals that should always be mocked (they make network calls)
266
- const alwaysMockedBrowserGlobals = ['fetch', 'EventSource'];
267
-
268
- for (const [path, infos] of Object.entries(
269
- entity.metadata?.nodeModuleImports ?? {},
270
- )) {
271
- for (const info of infos) {
272
- if (info.isMocked === undefined || info.isMocked === null) {
273
- // Browser globals should always be mocked
274
- if (alwaysMockedBrowserGlobals.includes(path)) {
275
- info.isMocked = true;
276
- } else {
277
- info.isMocked = mockedDependencies.some(
278
- (dep) =>
279
- dep.filePath === path && dep.entityName === info.name,
280
- );
281
- }
232
+ const matchesMockedDep = mockedDependencies.some(
233
+ (dep) =>
234
+ dep.filePath === importedExport.filePath &&
235
+ dep.entityName === importedExport.name,
236
+ );
237
+ importedExport.isMocked = matchesMockedDep;
238
+ }
239
+
240
+ // Browser globals that should always be mocked (they make network calls)
241
+ const alwaysMockedBrowserGlobals = ['fetch', 'EventSource'];
242
+
243
+ for (const [path, infos] of Object.entries(
244
+ entity.metadata?.nodeModuleImports ?? {},
245
+ )) {
246
+ for (const info of infos) {
247
+ if (info.isMocked === undefined || info.isMocked === null) {
248
+ // Browser globals should always be mocked
249
+ if (alwaysMockedBrowserGlobals.includes(path)) {
250
+ info.isMocked = true;
251
+ } else {
252
+ // Check if this dependency should be mocked
253
+ // Match both exact entityName and variable-qualified entityNames
254
+ // e.g., "useFetcher" matches "useFetcher" OR "useFetcher::userFetcher"
255
+ info.isMocked = mockedDependencies.some(
256
+ (dep) =>
257
+ dep.filePath === path &&
258
+ (dep.entityName === info.name ||
259
+ dep.entityName.startsWith(info.name + '::')),
260
+ );
282
261
  }
283
262
  }
284
263
  }
285
- } catch (error) {
286
- console.warn(
287
- `CodeYam: prepareEntityDataStructures: Error preparing ${entity.filePath}:${entity.name}:`,
288
- error,
289
- );
290
- // Continue with other entities - this one will have empty schemas
291
264
  }
292
- }),
293
- );
265
+ } catch (error) {
266
+ console.warn(
267
+ `CodeYam: prepareEntityDataStructures: Error preparing ${entity.filePath}:${entity.name}:`,
268
+ error,
269
+ );
270
+ // Continue with other entities - this one will have empty schemas
271
+ }
272
+ };
273
+
274
+ const entities = Array.from(allEntities);
275
+
276
+ // The worker thread creates its own ProjectAnalyzer (ts.Program) on first use,
277
+ // which takes 50-70s. For small entity counts the overhead far exceeds the actual
278
+ // processing time (<2s). Skip the worker and run on the main thread instead,
279
+ // reusing the existing ProjectAnalyzer.
280
+ const entitiesNeedingGeneration = entities.filter(
281
+ (e) =>
282
+ !e.metadata?.isolatedDataStructure || options.force || options.forceAll,
283
+ ).length;
284
+ const WORKER_ENTITY_THRESHOLD = 500;
285
+ if (entitiesNeedingGeneration < WORKER_ENTITY_THRESHOLD) {
286
+ console.log(
287
+ `CodeYam: Skipping worker thread for DS prep (${entitiesNeedingGeneration} entities < ${WORKER_ENTITY_THRESHOLD} threshold)`,
288
+ );
289
+ skipWorkerPool();
290
+ }
291
+
292
+ const sequential =
293
+ DEBUG_SEQUENTIAL_EXECUTION || options.sequentialDataStructurePrep;
294
+
295
+ if (sequential) {
296
+ // Sequential execution for debugging - process one entity at a time
297
+ for (const entity of entities) {
298
+ await processEntity(entity);
299
+ }
300
+ } else {
301
+ // Parallel execution for speed
302
+ await Promise.all(entities.map(processEntity));
303
+ }
294
304
  }
295
305
 
296
306
  /**
@@ -340,19 +350,33 @@ async function getEntityDataStructureAndFunctionCalls({
340
350
  functionName: importedExport.name,
341
351
  });
342
352
 
343
- // If no signature found, this function doesn't exist in the analysis
344
- if (!signatureSchema) {
345
- return acc;
346
- }
347
-
348
353
  const returnValueSchema = getReturnValue(dataStructure, {
349
354
  functionName: importedExport.name,
350
355
  });
351
356
 
357
+ // If neither signature nor return value found, check if this function has matching
358
+ // external function calls. External functions (like useLoaderData from react-router)
359
+ // don't have entries in functionResults, so getReturnValue returns null for them.
360
+ // But their return values ARE traced in externalFunctionCalls via perVariableSchemas.
361
+ // We need to check for matching calls before skipping.
362
+ if (!signatureSchema && !returnValueSchema) {
363
+ const hasMatchingExternalCall =
364
+ dataStructure.externalFunctionCalls?.some(
365
+ (fc) =>
366
+ fc.name === importedExport.name ||
367
+ fc.name.startsWith(importedExport.name + '<'),
368
+ );
369
+
370
+ // Only skip if there are no matching external function calls
371
+ if (!hasMatchingExternalCall) {
372
+ return acc;
373
+ }
374
+ }
375
+
352
376
  // Clone schemas before deduplication to avoid mutating shared references
353
377
  // getReturnValue() and getFunctionSignature() return direct references, so we need
354
378
  // to clone them before passing to deduplicateFunctionSchemas (which may mutate)
355
- const clonedSignatureSchema = { ...signatureSchema };
379
+ const clonedSignatureSchema = { ...(signatureSchema ?? {}) };
356
380
  const clonedReturnValueSchema = { ...(returnValueSchema ?? {}) };
357
381
 
358
382
  acc[importedExport.filePath] ||= {};
@@ -365,6 +389,170 @@ async function getEntityDataStructureAndFunctionCalls({
365
389
  getSourceEquivalencies(dataStructure, importedExport.name) ?? {},
366
390
  };
367
391
 
392
+ // Also create variable-qualified entries to preserve distinct return type schemas
393
+ // when the same function is called multiple times with different type parameters
394
+ // (e.g., useFetcher<UserData>() vs useFetcher<ReportData>()).
395
+ //
396
+ // Each parameterized call is a SEPARATE entry in externalFunctionCalls, so we need
397
+ // to iterate over ALL matching calls (not just the first one).
398
+ const matchingCalls = dataStructure.externalFunctionCalls.filter(
399
+ (fc) =>
400
+ fc.name === importedExport.name ||
401
+ fc.name.startsWith(importedExport.name + '<'),
402
+ );
403
+
404
+ for (const efc of matchingCalls) {
405
+ // Check if this call has perVariableSchemas (multiple calls with variable tracking)
406
+ if (efc?.perVariableSchemas) {
407
+ // Check if perVariableSchemas has indexed keys (e.g., "fetcher[1]") which indicates
408
+ // variable reuse with DIFFERENT call signatures (e.g., let fetcher = useFetcher<A>(); fetcher = useFetcher<B>();)
409
+ // In this case, we need to create SEPARATE entries for each call signature.
410
+ const perVarKeys = Object.keys(efc.perVariableSchemas);
411
+ const hasIndexedKeys = perVarKeys.some((key) => /\[\d+\]$/.test(key));
412
+
413
+ if (
414
+ hasIndexedKeys &&
415
+ efc.callSignatureToVariable &&
416
+ efc.allCallSignatures
417
+ ) {
418
+ // Variable reuse case: create separate entries for each call signature
419
+ // Map from call signature to its variable key in perVariableSchemas
420
+ // e.g., useFetcher<ConfigData>() -> 'fetcher', useFetcher<SettingsData>() -> 'fetcher[1]'
421
+ const varNameCounts: Record<string, number> = {};
422
+ for (const callSig of efc.allCallSignatures) {
423
+ const varName = efc.callSignatureToVariable[callSig];
424
+ if (!varName) continue;
425
+
426
+ // Track occurrence count for this variable name
427
+ const occurrence = varNameCounts[varName] ?? 0;
428
+ varNameCounts[varName] = occurrence + 1;
429
+
430
+ // Get the key in perVariableSchemas (indexed if reused)
431
+ const perVarKey =
432
+ occurrence === 0 ? varName : `${varName}[${occurrence}]`;
433
+ const varSchema = efc.perVariableSchemas[perVarKey];
434
+
435
+ if (varSchema && Object.keys(varSchema).length > 0) {
436
+ // Create entry with this call signature as the key
437
+ const rewrittenSchema: Record<string, string> = {};
438
+ rewrittenSchema[`${callSig}.functionCallReturnValue`] =
439
+ 'object';
440
+
441
+ for (const [path, type] of Object.entries(varSchema)) {
442
+ const rewrittenPath = path.startsWith(callSig)
443
+ ? path
444
+ : `${callSig}.${path}`;
445
+ rewrittenSchema[rewrittenPath] = type;
446
+ }
447
+
448
+ acc[importedExport.filePath][callSig] = {
449
+ signatureSchema: deduplicateFunctionSchemas({
450
+ ...signatureSchema,
451
+ }),
452
+ returnValueSchema:
453
+ deduplicateFunctionSchemas(rewrittenSchema),
454
+ usageEquivalencies:
455
+ getUsageEquivalencies(dataStructure, importedExport.name) ??
456
+ {},
457
+ sourceEquivalencies:
458
+ getSourceEquivalencies(
459
+ dataStructure,
460
+ importedExport.name,
461
+ ) ?? {},
462
+ };
463
+ }
464
+ }
465
+ } else {
466
+ // Destructuring case: const { a, b, c } = useLoaderData()
467
+ // Merge all variable schemas into a single entry with the call signature as key
468
+ const callSignatureKey = efc.callSignature;
469
+
470
+ // Merge all variable schemas by prepending the call signature to each path.
471
+ // perVariableSchemas paths are like "functionCallReturnValue.entities.sha"
472
+ // We need to prefix them with the call signature to get:
473
+ // "useLoaderData<typeof loader>().functionCallReturnValue.entities.sha"
474
+ const mergedReturnValueSchema: Record<string, string> = {};
475
+
476
+ // Set the top-level return value as object since it contains named properties
477
+ mergedReturnValueSchema[
478
+ `${callSignatureKey}.functionCallReturnValue`
479
+ ] = 'object';
480
+
481
+ for (const [varName, perVarSchema] of Object.entries(
482
+ efc.perVariableSchemas,
483
+ )) {
484
+ for (const [path, type] of Object.entries(perVarSchema)) {
485
+ // Only prepend the call signature if the path doesn't already have it.
486
+ // perVariableSchemas paths may already include the call signature prefix
487
+ // (e.g., "useCustomSizes(projectSlug).functionCallReturnValue.customSizes")
488
+ // depending on how they were built. If so, use the path as-is.
489
+ const rewrittenPath = path.startsWith(callSignatureKey)
490
+ ? path
491
+ : `${callSignatureKey}.${path}`;
492
+ mergedReturnValueSchema[rewrittenPath] = type;
493
+ }
494
+ }
495
+
496
+ acc[importedExport.filePath][callSignatureKey] = {
497
+ signatureSchema: deduplicateFunctionSchemas({
498
+ ...signatureSchema,
499
+ }),
500
+ returnValueSchema: deduplicateFunctionSchemas(
501
+ mergedReturnValueSchema,
502
+ ),
503
+ usageEquivalencies:
504
+ getUsageEquivalencies(dataStructure, importedExport.name) ?? {},
505
+ sourceEquivalencies:
506
+ getSourceEquivalencies(dataStructure, importedExport.name) ??
507
+ {},
508
+ };
509
+ }
510
+ } else if (efc?.receivingVariableNames?.length === 1) {
511
+ // For parameterized calls like useFetcher<UserData>(), each is a separate entry
512
+ // with a single receivingVariableName. Use the call signature as the key.
513
+ const varName = efc.receivingVariableNames[0];
514
+
515
+ // Use the call signature as the key (e.g., "useFetcher<UserData>()")
516
+ const callSignatureKey = efc.callSignature;
517
+
518
+ // PREFER perVariableSchemas over getReturnValue() when available
519
+ // perVariableSchemas has the SPECIFIC schema for this parameterized call,
520
+ // while getReturnValue() may return merged schemas from multiple calls
521
+ let parameterizedReturnValue: Record<string, string> | null = null;
522
+
523
+ if (efc.perVariableSchemas && efc.perVariableSchemas[varName]) {
524
+ // Use the specific schema from perVariableSchemas
525
+ parameterizedReturnValue = efc.perVariableSchemas[varName] ?? null;
526
+ }
527
+
528
+ // Fallback to getReturnValue if perCallSignatureSchemas not available
529
+ if (!parameterizedReturnValue) {
530
+ parameterizedReturnValue = getReturnValue(dataStructure, {
531
+ functionName: efc.name, // Use the full parameterized name
532
+ });
533
+ }
534
+
535
+ if (
536
+ parameterizedReturnValue &&
537
+ Object.keys(parameterizedReturnValue).length > 0
538
+ ) {
539
+ acc[importedExport.filePath][callSignatureKey] = {
540
+ signatureSchema: deduplicateFunctionSchemas({
541
+ ...signatureSchema,
542
+ }),
543
+ returnValueSchema: deduplicateFunctionSchemas({
544
+ ...parameterizedReturnValue,
545
+ }),
546
+ usageEquivalencies:
547
+ getUsageEquivalencies(dataStructure, importedExport.name) ?? {},
548
+ sourceEquivalencies:
549
+ getSourceEquivalencies(dataStructure, importedExport.name) ??
550
+ {},
551
+ };
552
+ }
553
+ }
554
+ }
555
+
368
556
  return acc;
369
557
  },
370
558
  {} as {
@@ -385,6 +573,42 @@ async function getEntityDataStructureAndFunctionCalls({
385
573
  },
386
574
  );
387
575
 
576
+ // Add same-file child components to dependencySchemas.
577
+ // Same-file components (e.g., AgentCard defined in the same file as AgentTranscriptsPage)
578
+ // appear in externalFunctionCalls and functionResults but NOT in importedExports or
579
+ // nodeModuleImports. Without this, their signatures are missing from dependencySchemas
580
+ // and enrichArrayTypesFromChildSignatures can't find child component field accesses.
581
+ const allDependencyNames = new Set(allDependencies.map((d) => d.name));
582
+
583
+ for (const efc of dataStructure.externalFunctionCalls) {
584
+ // Skip if already covered by importedExports or nodeModuleImports
585
+ if (allDependencyNames.has(efc.name)) continue;
586
+
587
+ const signatureSchema = getFunctionSignature(dataStructure, {
588
+ functionName: efc.name,
589
+ });
590
+
591
+ const returnValueSchema = getReturnValue(dataStructure, {
592
+ functionName: efc.name,
593
+ });
594
+
595
+ // Only add if we have signature or return value data
596
+ if (!signatureSchema && !returnValueSchema) continue;
597
+
598
+ const clonedSignatureSchema = { ...(signatureSchema ?? {}) };
599
+ const clonedReturnValueSchema = { ...(returnValueSchema ?? {}) };
600
+
601
+ const entityFilePath = entity.filePath;
602
+ dependencySchemas[entityFilePath] ||= {};
603
+ dependencySchemas[entityFilePath][efc.name] = {
604
+ signatureSchema: deduplicateFunctionSchemas(clonedSignatureSchema),
605
+ returnValueSchema: deduplicateFunctionSchemas(clonedReturnValueSchema),
606
+ usageEquivalencies: getUsageEquivalencies(dataStructure, efc.name) ?? {},
607
+ sourceEquivalencies:
608
+ getSourceEquivalencies(dataStructure, efc.name) ?? {},
609
+ };
610
+ }
611
+
388
612
  const rawReturnValue =
389
613
  getReturnValue(dataStructure, { fillInUnknowns: false }) ?? {};
390
614
 
@@ -397,23 +621,54 @@ async function getEntityDataStructureAndFunctionCalls({
397
621
  // Get enriched conditional usages with source tracing
398
622
  const conditionalUsages = getConditionalUsages(dataStructure);
399
623
 
624
+ // Get conditional effects (setter calls inside conditionals)
625
+ const conditionalEffects = getConditionalEffects(dataStructure);
626
+
627
+ // Get compound conditionals (grouped conditions that must all be true)
628
+ const compoundConditionals = getCompoundConditionals(dataStructure);
400
629
  const rawUsageEquivalencies = getUsageEquivalencies(dataStructure);
401
630
  const rawSourceEquivalencies = getSourceEquivalencies(dataStructure);
402
631
 
632
+ // Get child boundary gating conditions for child component flow merging
633
+ const childBoundaryGatingConditions =
634
+ getChildBoundaryGatingConditions(dataStructure);
635
+
636
+ // Get JSX rendering usages for array size and text length flow generation
637
+ const jsxRenderingUsages = getJsxRenderingUsages(dataStructure);
638
+
639
+ const equivalentSignatureVariables =
640
+ getEquivalentSignatureVariables(dataStructure);
641
+
403
642
  const isolatedDataStructure = {
404
643
  signatureSchema: deduplicateFunctionSchemas(clonedRawSignature),
405
644
  returnValueSchema: deduplicateFunctionSchemas(clonedRawReturnValue),
406
- equivalentSignatureVariables:
407
- getEquivalentSignatureVariables(dataStructure),
645
+ equivalentSignatureVariables,
408
646
  dependencySchemas,
409
647
  environmentVariables: dataStructure.environmentVariables,
410
648
  conditionalUsages:
411
649
  Object.keys(conditionalUsages).length > 0 ? conditionalUsages : undefined,
650
+ // Include conditional effects for execution flow generation
651
+ conditionalEffects:
652
+ conditionalEffects.length > 0 ? conditionalEffects : undefined,
653
+ // Include compound conditionals for complete execution flow generation
654
+ // These capture grouped conditions like (a || b) && !c && !d
655
+ compoundConditionals:
656
+ compoundConditionals.length > 0 ? compoundConditionals : undefined,
412
657
  // Include root entity's equivalencies so they can be used during merge.
413
658
  // These show how the parent's data flows to/from child components.
414
659
  // E.g., for SurveysList, usageEquivalencies shows surveys[] → SurveyCard().signature[0].survey
415
660
  usageEquivalencies: rawUsageEquivalencies ?? {},
416
661
  sourceEquivalencies: rawSourceEquivalencies ?? {},
662
+ // Include child boundary gating conditions for child component flow merging
663
+ // Maps child component names to the conditions that must be true for them to render
664
+ childBoundaryGatingConditions:
665
+ Object.keys(childBoundaryGatingConditions).length > 0
666
+ ? childBoundaryGatingConditions
667
+ : undefined,
668
+ // Include JSX rendering usages for array size and text length flow generation
669
+ // These track arrays rendered via .map() and strings interpolated in JSX
670
+ jsxRenderingUsages:
671
+ jsxRenderingUsages.length > 0 ? jsxRenderingUsages : undefined,
417
672
  };
418
673
 
419
674
  const functionCalls: Record<string, string[]> = {};
@@ -426,31 +681,6 @@ async function getEntityDataStructureAndFunctionCalls({
426
681
  efc.callSignature.startsWith(entityName),
427
682
  );
428
683
 
429
- // DEBUG: Log external function calls info for useFetcher
430
- if (entityName === 'useFetcher' || entityName.includes('Fetcher')) {
431
- console.log(
432
- 'CodeYam DEBUG prepareDataStructures:',
433
- JSON.stringify(
434
- {
435
- entityName,
436
- filePath,
437
- totalExternalFunctionCalls:
438
- dataStructure.externalFunctionCalls.length,
439
- matchingCallsCount: matchingCalls.length,
440
- matchingCalls: matchingCalls.map((efc) => ({
441
- name: efc.name,
442
- callSignature: efc.callSignature,
443
- allCallSignatures: efc.allCallSignatures,
444
- receivingVariableNames: efc.receivingVariableNames,
445
- callSignatureToVariable: efc.callSignatureToVariable,
446
- })),
447
- },
448
- null,
449
- 2,
450
- ),
451
- );
452
- }
453
-
454
684
  // Collect all call signatures from all matching efc entries
455
685
  // Each efc may have just one callSignature, or allCallSignatures if merged
456
686
  const allSignatures: string[] = [];
@@ -496,6 +726,7 @@ async function getEntityDataStructureAndFunctionCalls({
496
726
  ) {
497
727
  variableNames.push(...aggregatedReceivingVariableNames);
498
728
  }
729
+
499
730
  if (variableNames.length > 0) {
500
731
  callVariableNames[entityName] = variableNames;
501
732
  }
@@ -693,9 +924,21 @@ export function determineMockedDependencies(entity: Entity) {
693
924
  // A schema with only "EntityName(): function" just indicates the entity is callable,
694
925
  // it doesn't mean there's actual return data to mock
695
926
  const hasReturnValue = hasActualReturnValueData(entityReturnValueSchema);
696
- const complexReturnValue = Object.values(
697
- entityReturnValueSchema ?? {},
698
- ).some((value) => value === 'object' || value === 'array');
927
+ // Check for complex return types (object/array), accounting for nullable types
928
+ // e.g., 'object', 'object | null', 'array | undefined' should all count as complex.
929
+ // Also detect when functionCallReturnValue has nested child properties — this
930
+ // proves it's a structured type even if its declared type is still 'unknown'.
931
+ const returnValueKeys = Object.keys(entityReturnValueSchema ?? {});
932
+ const complexReturnValue =
933
+ Object.values(entityReturnValueSchema ?? {}).some((value) => {
934
+ const baseType = value?.split(' | ')[0];
935
+ return baseType === 'object' || baseType === 'array';
936
+ }) ||
937
+ returnValueKeys.some(
938
+ (key) =>
939
+ key.includes('functionCallReturnValue.') ||
940
+ key.includes('functionCallReturnValue['),
941
+ );
699
942
 
700
943
  // Check if this is a validation function that should always be mocked
701
944
  const isValidationFn = isValidationFunction(entityName);
@@ -715,14 +958,28 @@ export function determineMockedDependencies(entity: Entity) {
715
958
  entityReturnValueSchema,
716
959
  );
717
960
 
961
+ // Check if returnValueSchema is completely empty (no traced calls at all)
962
+ // This indicates a side-effect function that we couldn't trace
963
+ const returnValueSchemaEmpty =
964
+ Object.keys(entityReturnValueSchema ?? {}).length === 0;
965
+
718
966
  const entityShouldBeMocked =
719
967
  !onlyHasJsxComponents &&
720
968
  (isValidationFn ||
721
969
  hasChainedCallsWithNoReturn ||
970
+ // If entity takes no args AND has return value, it reads from external source
971
+ // Examples: useParams(), useAuth(), getConfig()
972
+ (emptySignature && hasReturnValue) ||
973
+ // If entity takes no args AND returnValueSchema is completely empty,
974
+ // it's a side-effect function calling external services
975
+ // Examples: logPageView(), initializeAnalytics(), trackEvent()
976
+ // NOTE: We don't mock entities that have function markers but no return value
977
+ // (like React components: FileProvider() has 'function' type but no return data)
978
+ (emptySignature && returnValueSchemaEmpty) ||
722
979
  ((signatureHasFunctions || returnValueHasFunctions) &&
723
980
  hasReturnValue &&
724
- ((emptySignature && hasReturnValue) ||
725
- (!complexSignature && complexReturnValue))));
981
+ !complexSignature &&
982
+ complexReturnValue));
726
983
 
727
984
  if (entityShouldBeMocked) {
728
985
  mockedEntities.push({