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

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 (1199) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +27 -27
  4. package/analyzer-template/packages/ai/index.ts +21 -5
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
  7. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +226 -24
  8. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  9. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +217 -13
  10. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +181 -23
  12. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  13. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
  14. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +15 -0
  15. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
  16. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1215 -29
  17. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  18. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +265 -6
  19. package/analyzer-template/packages/ai/src/lib/completionCall.ts +247 -66
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +2020 -334
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +54 -3
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +129 -20
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  32. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  33. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +393 -90
  34. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  35. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  36. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -0
  37. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  38. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  39. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +4 -3
  40. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +86 -149
  41. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +59 -3
  42. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1458 -65
  43. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +200 -196
  44. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +677 -0
  45. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  46. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  47. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  48. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +5 -5
  49. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
  50. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  51. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +111 -87
  52. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  53. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  54. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
  55. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +28 -170
  56. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  57. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  58. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
  59. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -89
  60. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  61. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +11 -11
  62. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  63. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  64. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
  65. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  66. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +122 -3
  67. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  68. package/analyzer-template/packages/analyze/index.ts +2 -0
  69. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  70. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  71. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  72. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  73. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  74. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  75. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  76. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  77. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  78. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  79. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  80. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +447 -255
  81. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +39 -4
  82. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  83. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  84. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  85. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +14 -14
  86. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +4 -4
  87. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
  88. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  89. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
  90. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  91. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  92. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +193 -76
  93. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +203 -41
  94. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -188
  95. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +355 -23
  96. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +166 -0
  97. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +1 -0
  98. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +2 -3
  99. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +845 -72
  100. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  101. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  102. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  103. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  104. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  105. package/analyzer-template/packages/aws/package.json +10 -10
  106. package/analyzer-template/packages/database/index.ts +1 -0
  107. package/analyzer-template/packages/database/package.json +4 -4
  108. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  109. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  110. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  111. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  112. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  113. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  114. package/analyzer-template/packages/database/src/lib/kysely/db.ts +22 -1
  115. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  116. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +17 -1
  117. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +138 -0
  118. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  119. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  120. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  121. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  122. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  123. package/analyzer-template/packages/database/src/lib/loadCommits.ts +58 -19
  124. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -9
  125. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  126. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +5 -6
  127. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  128. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  129. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  130. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +96 -152
  131. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  132. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  133. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  134. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  135. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  136. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  137. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  139. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  142. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  143. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  144. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  145. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  146. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  147. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  148. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  149. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  150. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  151. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  152. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  153. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  154. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +16 -1
  155. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  156. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -18
  157. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  158. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  159. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  160. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  161. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  162. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +17 -1
  163. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
  164. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  165. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +27 -0
  166. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  167. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  168. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  169. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  170. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  171. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  172. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  173. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +6 -6
  174. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  175. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  176. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  178. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  179. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  181. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  182. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  183. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  184. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  185. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  186. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  187. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  188. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  189. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +45 -14
  190. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  191. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  192. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  193. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -10
  194. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  195. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  196. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  197. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  198. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  199. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +5 -5
  200. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  201. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  202. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  203. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  204. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  205. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  206. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  207. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  208. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  209. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -89
  210. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  211. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  212. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  213. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  214. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  215. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  216. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  217. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  218. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  219. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  220. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  221. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  222. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  223. package/analyzer-template/packages/github/dist/types/index.d.ts +3 -4
  224. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  225. package/analyzer-template/packages/github/dist/types/index.js +0 -1
  226. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  227. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  228. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  229. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  230. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  231. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +71 -27
  232. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  233. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  234. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  235. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  236. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  237. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +13 -54
  238. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  239. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js +1 -21
  240. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js.map +1 -1
  241. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
  242. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  243. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  244. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  245. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
  246. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  247. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  248. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  249. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  250. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  251. package/analyzer-template/packages/github/package.json +2 -2
  252. package/analyzer-template/packages/types/index.ts +3 -6
  253. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  254. package/analyzer-template/packages/types/src/types/Analysis.ts +87 -27
  255. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  256. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  257. package/analyzer-template/packages/types/src/types/Scenario.ts +13 -77
  258. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +181 -5
  259. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  260. package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
  261. package/analyzer-template/packages/ui-components/package.json +1 -1
  262. package/analyzer-template/packages/utils/dist/types/index.d.ts +3 -4
  263. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  264. package/analyzer-template/packages/utils/dist/types/index.js +0 -1
  265. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  266. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  267. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  268. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  269. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  270. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +71 -27
  271. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  272. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  273. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  274. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  275. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  276. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +13 -54
  277. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  278. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js +1 -21
  279. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js.map +1 -1
  280. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
  281. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  282. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  283. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  284. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
  285. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  286. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  287. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  288. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  289. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  290. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  291. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  292. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  293. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  294. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  295. package/analyzer-template/playwright/capture.ts +20 -8
  296. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  297. package/analyzer-template/playwright/captureStatic.ts +1 -1
  298. package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
  299. package/analyzer-template/project/analyzeBaselineCommit.ts +9 -0
  300. package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
  301. package/analyzer-template/project/analyzeFileEntities.ts +4 -0
  302. package/analyzer-template/project/analyzeRegularCommit.ts +9 -0
  303. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  304. package/analyzer-template/project/constructMockCode.ts +593 -91
  305. package/analyzer-template/project/controller/startController.ts +16 -1
  306. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  307. package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
  308. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  309. package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
  310. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  311. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  312. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  313. package/analyzer-template/project/orchestrateCapture.ts +75 -7
  314. package/analyzer-template/project/reconcileMockDataKeys.ts +220 -1
  315. package/analyzer-template/project/runAnalysis.ts +6 -0
  316. package/analyzer-template/project/start.ts +49 -12
  317. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  318. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  319. package/analyzer-template/project/writeMockDataTsx.ts +312 -10
  320. package/analyzer-template/project/writeScenarioComponents.ts +314 -43
  321. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  322. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  323. package/analyzer-template/tsconfig.json +14 -1
  324. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  325. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  326. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +7 -1
  327. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  328. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
  329. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
  330. package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
  331. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  332. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +7 -1
  333. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  334. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  335. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  336. package/background/src/lib/virtualized/project/constructMockCode.js +493 -52
  337. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  338. package/background/src/lib/virtualized/project/controller/startController.js +11 -1
  339. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
  340. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  341. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  342. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
  343. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
  344. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  345. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  346. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
  347. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
  348. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  349. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  350. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  351. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  352. package/background/src/lib/virtualized/project/orchestrateCapture.js +62 -7
  353. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  354. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +184 -1
  355. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  356. package/background/src/lib/virtualized/project/runAnalysis.js +5 -0
  357. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  358. package/background/src/lib/virtualized/project/start.js +44 -12
  359. package/background/src/lib/virtualized/project/start.js.map +1 -1
  360. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  361. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  362. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  363. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  364. package/background/src/lib/virtualized/project/writeMockDataTsx.js +263 -6
  365. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  366. package/background/src/lib/virtualized/project/writeScenarioComponents.js +237 -41
  367. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  368. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  369. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  370. package/codeyam-cli/scripts/apply-setup.js +386 -9
  371. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  372. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  373. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  374. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  375. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  376. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  377. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  378. package/codeyam-cli/src/cli.js +35 -24
  379. package/codeyam-cli/src/cli.js.map +1 -1
  380. package/codeyam-cli/src/codeyam-cli.js +18 -2
  381. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  382. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  383. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  384. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  385. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  386. package/codeyam-cli/src/commands/analyze.js +21 -9
  387. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  388. package/codeyam-cli/src/commands/baseline.js +10 -11
  389. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  390. package/codeyam-cli/src/commands/debug.js +37 -23
  391. package/codeyam-cli/src/commands/debug.js.map +1 -1
  392. package/codeyam-cli/src/commands/default.js +43 -35
  393. package/codeyam-cli/src/commands/default.js.map +1 -1
  394. package/codeyam-cli/src/commands/editor.js +3375 -0
  395. package/codeyam-cli/src/commands/editor.js.map +1 -0
  396. package/codeyam-cli/src/commands/init.js +146 -292
  397. package/codeyam-cli/src/commands/init.js.map +1 -1
  398. package/codeyam-cli/src/commands/memory.js +278 -0
  399. package/codeyam-cli/src/commands/memory.js.map +1 -0
  400. package/codeyam-cli/src/commands/recapture.js +31 -18
  401. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  402. package/codeyam-cli/src/commands/report.js +46 -1
  403. package/codeyam-cli/src/commands/report.js.map +1 -1
  404. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  405. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  406. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  407. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  408. package/codeyam-cli/src/commands/start.js +8 -12
  409. package/codeyam-cli/src/commands/start.js.map +1 -1
  410. package/codeyam-cli/src/commands/test-startup.js +2 -0
  411. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  412. package/codeyam-cli/src/commands/verify.js +14 -2
  413. package/codeyam-cli/src/commands/verify.js.map +1 -1
  414. package/codeyam-cli/src/data/techStacks.js +77 -0
  415. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  416. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  417. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  418. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  419. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  420. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  421. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  422. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  423. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  424. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +987 -0
  425. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  426. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  427. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  428. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  429. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  430. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  431. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  432. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  433. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  434. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  435. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  436. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  437. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  438. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  439. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  440. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  441. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  442. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  443. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  444. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  445. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  446. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  447. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  448. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  449. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  450. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1059 -0
  451. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  452. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  453. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  454. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  455. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  456. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  457. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  458. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  459. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  460. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  461. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  462. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  463. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  464. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  465. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  466. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  467. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  468. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  469. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  470. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  471. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  472. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +454 -0
  473. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  474. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  475. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  476. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -82
  477. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  478. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  479. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  480. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  481. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  482. package/codeyam-cli/src/utils/analysisRunner.js +29 -15
  483. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  484. package/codeyam-cli/src/utils/analyzer.js +16 -0
  485. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  486. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  487. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  488. package/codeyam-cli/src/utils/backgroundServer.js +202 -29
  489. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  490. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  491. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  492. package/codeyam-cli/src/utils/database.js +37 -2
  493. package/codeyam-cli/src/utils/database.js.map +1 -1
  494. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  495. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  496. package/codeyam-cli/src/utils/devServerState.js +71 -0
  497. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  498. package/codeyam-cli/src/utils/editorApi.js +79 -0
  499. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  500. package/codeyam-cli/src/utils/editorAudit.js +210 -0
  501. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  502. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  503. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  504. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  505. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  506. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  507. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  508. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  509. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  510. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  511. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  512. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  513. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  514. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  515. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  516. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  517. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  518. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  519. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  520. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  521. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  522. package/codeyam-cli/src/utils/editorScenarios.js +387 -0
  523. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  524. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  525. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  526. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  527. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  528. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  529. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  530. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  531. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  532. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  533. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  534. package/codeyam-cli/src/utils/generateReport.js +4 -3
  535. package/codeyam-cli/src/utils/generateReport.js.map +1 -1
  536. package/codeyam-cli/src/utils/git.js +103 -0
  537. package/codeyam-cli/src/utils/git.js.map +1 -1
  538. package/codeyam-cli/src/utils/install-skills.js +120 -39
  539. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  540. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  541. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  542. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  543. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  544. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  545. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  546. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  547. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  548. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  549. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  550. package/codeyam-cli/src/utils/progress.js +8 -1
  551. package/codeyam-cli/src/utils/progress.js.map +1 -1
  552. package/codeyam-cli/src/utils/project.js +15 -5
  553. package/codeyam-cli/src/utils/project.js.map +1 -1
  554. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  555. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  556. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  557. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  558. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  559. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  560. package/codeyam-cli/src/utils/queue/job.js +75 -1
  561. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  562. package/codeyam-cli/src/utils/queue/manager.js +7 -0
  563. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  564. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  565. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  566. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  567. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  568. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  569. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  570. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  571. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  572. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  573. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  574. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  575. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  576. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  577. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  578. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  579. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  580. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  581. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  582. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  583. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  584. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  585. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  586. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  587. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  588. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  589. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  590. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  591. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  592. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  593. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  594. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  595. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  596. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  597. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  598. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  599. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  600. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  601. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  602. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  603. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  604. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  605. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  606. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  607. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  608. package/codeyam-cli/src/utils/rules/index.js +7 -0
  609. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  610. package/codeyam-cli/src/utils/rules/parser.js +93 -0
  611. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  612. package/codeyam-cli/src/utils/rules/pathMatcher.js +49 -0
  613. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  614. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  615. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  616. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  617. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  618. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  619. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  620. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  621. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  622. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  623. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  624. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  625. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  626. package/codeyam-cli/src/utils/scenariosManifest.js +241 -0
  627. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  628. package/codeyam-cli/src/utils/serverState.js +94 -12
  629. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  630. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -45
  631. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  632. package/codeyam-cli/src/utils/simulationGateMiddleware.js +166 -0
  633. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  634. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  635. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  636. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  637. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  638. package/codeyam-cli/src/utils/testRunner.js +158 -0
  639. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  640. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  641. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  642. package/codeyam-cli/src/utils/versionInfo.js +67 -15
  643. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  644. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  645. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  646. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  647. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  648. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  649. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  650. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  651. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  652. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +146 -0
  653. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  654. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  655. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  656. package/codeyam-cli/src/webserver/app/lib/database.js +63 -33
  657. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  658. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  659. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  660. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  661. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  662. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  663. package/codeyam-cli/src/webserver/bootstrap.js +51 -0
  664. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  665. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  666. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BcgbViKV.js +11 -0
  667. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  668. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CQIG2qda.js +41 -0
  669. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  670. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DYFW3lDD.js +25 -0
  671. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  672. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  673. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  674. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BzHcG7SE.js +11 -0
  675. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  676. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-TSD3C211.js +10 -0
  677. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  678. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  679. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  680. package/codeyam-cli/src/webserver/build/client/assets/_index-DLxKhri3.js +11 -0
  681. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BcY3q6nt.js +27 -0
  682. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  683. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  684. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  685. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  686. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  687. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  688. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  689. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  690. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  691. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  692. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  693. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  694. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  695. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  696. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  697. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  698. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  699. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  700. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  701. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  702. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  703. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  704. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  705. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  706. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  707. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  708. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  709. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  710. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  711. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  712. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  713. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  714. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  715. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  716. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  717. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  718. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  719. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  720. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  721. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
  722. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  723. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Ii3inc0_.js +1 -0
  724. package/codeyam-cli/src/webserver/build/client/assets/editor-COWCNVyV.js +10 -0
  725. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CNB06EIa.js +41 -0
  726. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-D0-YwkBh.js → entity._sha._-DwCV5__E.js} +13 -13
  727. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-CXSi2aeZ.js +6 -0
  728. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CHMiAog3.js +6 -0
  729. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  730. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-C1H_a_Y3.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  731. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  732. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  733. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  734. package/codeyam-cli/src/webserver/build/client/assets/files-BZrlFE1F.js +1 -0
  735. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  736. package/codeyam-cli/src/webserver/build/client/assets/globals-phvmGvat.css +1 -0
  737. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  738. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  739. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  740. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  741. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  742. package/codeyam-cli/src/webserver/build/client/assets/manifest-6134dc40.js +1 -0
  743. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  744. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  745. package/codeyam-cli/src/webserver/build/client/assets/root-BWAyuj0r.js +67 -0
  746. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  747. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  748. package/codeyam-cli/src/webserver/build/client/assets/simulations-DWT-CvLy.js +1 -0
  749. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  750. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  751. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C-_hOl_g.js +1 -0
  752. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  753. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-O-jkvSPx.js +1 -0
  754. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  755. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  756. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  757. package/codeyam-cli/src/webserver/build/server/assets/index-ChX0hPcu.js +1 -0
  758. package/codeyam-cli/src/webserver/build/server/assets/init-kSNsMjj8.js +10 -0
  759. package/codeyam-cli/src/webserver/build/server/assets/server-build-Bm2xIhmh.js +439 -0
  760. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  761. package/codeyam-cli/src/webserver/build-info.json +5 -5
  762. package/codeyam-cli/src/webserver/devServer.js +39 -5
  763. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  764. package/codeyam-cli/src/webserver/editorProxy.js +877 -0
  765. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  766. package/codeyam-cli/src/webserver/idleDetector.js +73 -0
  767. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  768. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  769. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  770. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  771. package/codeyam-cli/src/webserver/server.js +335 -26
  772. package/codeyam-cli/src/webserver/server.js.map +1 -1
  773. package/codeyam-cli/src/webserver/terminalServer.js +735 -0
  774. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  775. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  776. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  777. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  778. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  779. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  780. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  781. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  782. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  783. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  784. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  785. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  786. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  787. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  788. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  789. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  790. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  791. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  792. package/codeyam-cli/templates/editor-step-hook.py +237 -0
  793. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  794. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  795. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  796. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  797. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  798. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  799. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  800. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  801. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  802. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  803. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  804. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  805. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  806. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  807. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  808. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  809. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  810. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  811. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  812. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  813. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  814. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  815. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  816. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  817. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  818. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  819. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  820. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  821. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  822. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  823. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  824. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  825. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  826. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  827. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  828. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  829. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  830. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  831. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  832. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  833. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  834. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  835. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  836. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  837. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  838. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  839. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  840. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  841. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  842. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  843. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  844. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  845. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  846. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  847. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  848. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  849. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  850. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  851. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  852. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  853. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  854. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  855. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  856. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  857. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  858. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  859. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  860. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  861. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  862. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  863. package/codeyam-cli/templates/rules-instructions.md +78 -0
  864. package/codeyam-cli/templates/{codeyam-debug-skill.md → skills/codeyam-debug/SKILL.md} +48 -4
  865. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  866. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +149 -0
  867. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  868. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  869. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  870. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  871. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  872. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  873. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  874. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  875. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  876. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  877. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  878. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  879. package/codeyam-cli/templates/{codeyam-setup-skill.md → skills/codeyam-setup/SKILL.md} +13 -1
  880. package/codeyam-cli/templates/{codeyam-sim-skill.md → skills/codeyam-sim/SKILL.md} +1 -1
  881. package/codeyam-cli/templates/{codeyam-test-skill.md → skills/codeyam-test/SKILL.md} +1 -1
  882. package/codeyam-cli/templates/{codeyam-verify-skill.md → skills/codeyam-verify/SKILL.md} +1 -1
  883. package/package.json +32 -22
  884. package/packages/ai/index.js +8 -6
  885. package/packages/ai/index.js.map +1 -1
  886. package/packages/ai/src/lib/analyzeScope.js +179 -13
  887. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  888. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  889. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  890. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +160 -13
  891. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  892. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  893. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  894. package/packages/ai/src/lib/astScopes/methodSemantics.js +138 -23
  895. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  896. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  897. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  898. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
  899. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
  900. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +7 -0
  901. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
  902. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
  903. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  904. package/packages/ai/src/lib/astScopes/processExpression.js +931 -29
  905. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  906. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  907. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  908. package/packages/ai/src/lib/completionCall.js +188 -38
  909. package/packages/ai/src/lib/completionCall.js.map +1 -1
  910. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1600 -189
  911. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  912. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  913. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  914. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
  915. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  916. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
  917. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  918. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  919. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  920. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  921. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  922. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +52 -3
  923. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  924. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +111 -14
  925. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  926. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  927. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  928. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  929. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  930. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  931. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  932. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  933. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  934. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  935. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  936. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +333 -81
  937. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  938. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  939. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  940. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  941. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  942. package/packages/ai/src/lib/dataStructureChunking.js +130 -0
  943. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  944. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  945. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  946. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  947. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  948. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +4 -3
  949. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
  950. package/packages/ai/src/lib/generateChangesEntityScenarios.js +78 -120
  951. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
  952. package/packages/ai/src/lib/generateEntityDataStructure.js +47 -2
  953. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  954. package/packages/ai/src/lib/generateEntityScenarioData.js +1153 -60
  955. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  956. package/packages/ai/src/lib/generateEntityScenarios.js +177 -163
  957. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  958. package/packages/ai/src/lib/generateExecutionFlows.js +484 -0
  959. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  960. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  961. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  962. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  963. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  964. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  965. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  966. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -2
  967. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
  968. package/packages/ai/src/lib/isolateScopes.js +270 -7
  969. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  970. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  971. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  972. package/packages/ai/src/lib/mergeStatements.js +88 -46
  973. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  974. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  975. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  976. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  977. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  978. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
  979. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
  980. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -119
  981. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
  982. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  983. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  984. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
  985. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  986. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -70
  987. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
  988. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  989. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  990. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +9 -9
  991. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
  992. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  993. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  994. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  995. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  996. package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
  997. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
  998. package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
  999. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  1000. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  1001. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  1002. package/packages/analyze/index.js +1 -0
  1003. package/packages/analyze/index.js.map +1 -1
  1004. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  1005. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  1006. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  1007. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  1008. package/packages/analyze/src/lib/analysisContext.js +30 -5
  1009. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  1010. package/packages/analyze/src/lib/asts/index.js +4 -2
  1011. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  1012. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  1013. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  1014. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  1015. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  1016. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  1017. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  1018. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  1019. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  1020. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  1021. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  1022. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  1023. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  1024. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  1025. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  1026. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +189 -41
  1027. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  1028. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +28 -4
  1029. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  1030. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  1031. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  1032. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  1033. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  1034. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  1035. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  1036. package/packages/analyze/src/lib/files/analyzeChange.js +10 -10
  1037. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  1038. package/packages/analyze/src/lib/files/analyzeEntity.js +4 -4
  1039. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
  1040. package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
  1041. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  1042. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  1043. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  1044. package/packages/analyze/src/lib/files/enums/steps.js +1 -1
  1045. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
  1046. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  1047. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  1048. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  1049. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  1050. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +164 -68
  1051. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  1052. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +178 -31
  1053. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  1054. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -129
  1055. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
  1056. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +252 -21
  1057. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  1058. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +104 -0
  1059. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  1060. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +1 -0
  1061. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
  1062. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +2 -3
  1063. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
  1064. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +686 -55
  1065. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  1066. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  1067. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  1068. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  1069. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  1070. package/packages/analyze/src/lib/index.js +1 -0
  1071. package/packages/analyze/src/lib/index.js.map +1 -1
  1072. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  1073. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  1074. package/packages/database/index.js +1 -0
  1075. package/packages/database/index.js.map +1 -1
  1076. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  1077. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  1078. package/packages/database/src/lib/analysisToDb.js +1 -1
  1079. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  1080. package/packages/database/src/lib/branchToDb.js +1 -1
  1081. package/packages/database/src/lib/branchToDb.js.map +1 -1
  1082. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  1083. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  1084. package/packages/database/src/lib/commitToDb.js +1 -1
  1085. package/packages/database/src/lib/commitToDb.js.map +1 -1
  1086. package/packages/database/src/lib/fileToDb.js +1 -1
  1087. package/packages/database/src/lib/fileToDb.js.map +1 -1
  1088. package/packages/database/src/lib/kysely/db.js +16 -1
  1089. package/packages/database/src/lib/kysely/db.js.map +1 -1
  1090. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  1091. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  1092. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  1093. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  1094. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  1095. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  1096. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  1097. package/packages/database/src/lib/loadAnalyses.js +45 -2
  1098. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  1099. package/packages/database/src/lib/loadAnalysis.js +8 -0
  1100. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  1101. package/packages/database/src/lib/loadBranch.js +11 -1
  1102. package/packages/database/src/lib/loadBranch.js.map +1 -1
  1103. package/packages/database/src/lib/loadCommit.js +7 -0
  1104. package/packages/database/src/lib/loadCommit.js.map +1 -1
  1105. package/packages/database/src/lib/loadCommits.js +45 -14
  1106. package/packages/database/src/lib/loadCommits.js.map +1 -1
  1107. package/packages/database/src/lib/loadEntities.js +23 -10
  1108. package/packages/database/src/lib/loadEntities.js.map +1 -1
  1109. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  1110. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  1111. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +5 -5
  1112. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  1113. package/packages/database/src/lib/projectToDb.js +1 -1
  1114. package/packages/database/src/lib/projectToDb.js.map +1 -1
  1115. package/packages/database/src/lib/saveFiles.js +1 -1
  1116. package/packages/database/src/lib/saveFiles.js.map +1 -1
  1117. package/packages/database/src/lib/scenarioToDb.js +1 -1
  1118. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  1119. package/packages/database/src/lib/updateCommitMetadata.js +76 -89
  1120. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  1121. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  1122. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  1123. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  1124. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  1125. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  1126. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  1127. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  1128. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  1129. package/packages/types/index.js +0 -1
  1130. package/packages/types/index.js.map +1 -1
  1131. package/packages/types/src/enums/ProjectFramework.js +2 -0
  1132. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  1133. package/packages/types/src/types/Scenario.js +1 -21
  1134. package/packages/types/src/types/Scenario.js.map +1 -1
  1135. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  1136. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  1137. package/packages/utils/src/lib/safeFileName.js +29 -3
  1138. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  1139. package/scripts/npm-post-install.cjs +34 -0
  1140. package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -109
  1141. package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -584
  1142. package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -341
  1143. package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -495
  1144. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
  1145. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -120
  1146. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  1147. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  1148. package/codeyam-cli/src/commands/list.js +0 -31
  1149. package/codeyam-cli/src/commands/list.js.map +0 -1
  1150. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  1151. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  1152. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  1153. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  1154. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-Cmysw5OP.js +0 -1
  1155. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CAneekK2.js +0 -41
  1156. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-Cu16OUmx.js +0 -25
  1157. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DcAUIpD_.js +0 -11
  1158. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-BMKg0SAF.js +0 -15
  1159. package/codeyam-cli/src/webserver/build/client/assets/_index-DSmTpjmK.js +0 -11
  1160. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BF_aK4y6.js +0 -32
  1161. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  1162. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CKnwPCDr.js +0 -1
  1163. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-RJCf3Tvw.js +0 -1
  1164. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-EylcgScH.js +0 -1
  1165. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DMe7kvgo.js +0 -1
  1166. package/codeyam-cli/src/webserver/build/client/assets/files-BW7Cyeyi.js +0 -1
  1167. package/codeyam-cli/src/webserver/build/client/assets/git-CZu4fif0.js +0 -15
  1168. package/codeyam-cli/src/webserver/build/client/assets/globals-wHVy_II5.css +0 -1
  1169. package/codeyam-cli/src/webserver/build/client/assets/keyAttributeCoverage-CTlFMihX.js +0 -1
  1170. package/codeyam-cli/src/webserver/build/client/assets/manifest-2d191949.js +0 -1
  1171. package/codeyam-cli/src/webserver/build/client/assets/root-FHgpM6gc.js +0 -56
  1172. package/codeyam-cli/src/webserver/build/client/assets/settings-6D8k8Jp5.js +0 -1
  1173. package/codeyam-cli/src/webserver/build/client/assets/simulations-CDJZnWhN.js +0 -1
  1174. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-Dv18q8LD.js +0 -1
  1175. package/codeyam-cli/src/webserver/build/client/assets/useInteractiveMode-0ToGk4K3.js +0 -1
  1176. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  1177. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-1BX144Eg.js +0 -1
  1178. package/codeyam-cli/src/webserver/build/server/assets/index-pU0o5t1o.js +0 -1
  1179. package/codeyam-cli/src/webserver/build/server/assets/server-build-YzfkRwdn.js +0 -178
  1180. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  1181. package/codeyam-cli/templates/debug-codeyam.md +0 -625
  1182. package/packages/ai/src/lib/findMatchingAttribute.js +0 -81
  1183. package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
  1184. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -425
  1185. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
  1186. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -267
  1187. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
  1188. package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -408
  1189. package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
  1190. package/packages/ai/src/lib/isFrontend.js +0 -5
  1191. package/packages/ai/src/lib/isFrontend.js.map +0 -1
  1192. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
  1193. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
  1194. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -77
  1195. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
  1196. package/scripts/finalize-analyzer.cjs +0 -81
  1197. /package/codeyam-cli/src/webserver/build/client/assets/{api.link-scenario-value-l0sNRNKZ.js → api.agent-transcripts-l0sNRNKZ.js} +0 -0
  1198. /package/codeyam-cli/src/webserver/build/client/assets/{api.update-key-attributes-l0sNRNKZ.js → api.dev-mode-events-l0sNRNKZ.js} +0 -0
  1199. /package/codeyam-cli/src/webserver/build/client/assets/{api.update-valid-values-l0sNRNKZ.js → api.editor-audit-l0sNRNKZ.js} +0 -0
@@ -4,6 +4,7 @@ import {
4
4
  } from '~codeyam/ai';
5
5
  import { cleanKnownObjectFunctionsFromMapping } from '~codeyam/ai';
6
6
  import { DataStructure, Entity, ReadonlyAnalysis } from '~codeyam/types';
7
+ import { transformationTracer } from './TransformationTracer';
7
8
 
8
9
  export interface DataStructureInfo {
9
10
  signatureSchema: { [key: string]: string };
@@ -40,6 +41,66 @@ function getTypeParameter(functionName: string): string | null {
40
41
  return null;
41
42
  }
42
43
 
44
+ // Primitive types that should not have child paths
45
+ const PRIMITIVE_TYPES = new Set([
46
+ 'number',
47
+ 'string',
48
+ 'boolean',
49
+ 'null',
50
+ 'undefined',
51
+ ]);
52
+
53
+ // Check if a type string represents a primitive type
54
+ // Handles union types like "string | undefined" or "number | null"
55
+ // Also handles string literal unions like "'suggestion' | 'warning' | 'tip'"
56
+ function isPrimitiveType(typeStr: string): boolean {
57
+ if (PRIMITIVE_TYPES.has(typeStr)) {
58
+ return true;
59
+ }
60
+ // Check union types - if ALL parts of the union are primitives, it's primitive
61
+ // e.g., "string | undefined" -> ["string", "undefined"] -> both are primitive -> true
62
+ // e.g., "object | null" -> ["object", "null"] -> object is not primitive -> false
63
+ // e.g., "'suggestion' | 'warning'" -> string literal union -> true
64
+ if (typeStr.includes('|')) {
65
+ const parts = typeStr.split('|').map((p) => p.trim());
66
+ return parts.every(
67
+ (part) =>
68
+ PRIMITIVE_TYPES.has(part) ||
69
+ // String literal values like 'suggestion', 'warning' are primitives
70
+ (part.startsWith("'") && part.endsWith("'")),
71
+ );
72
+ }
73
+ return false;
74
+ }
75
+
76
+ // Extract signature index from a path like "signature[0]" or "signature[0].foo"
77
+ // Returns the index number or undefined if not a signature path
78
+ function extractSignatureIndex(path: string): number | undefined {
79
+ const match = path.match(/^signature\[(\d+)\]/);
80
+ return match ? parseInt(match[1], 10) : undefined;
81
+ }
82
+
83
+ // Check if a new schema path would go through a primitive type
84
+ // e.g., if schema has 'entities[].scenarioCount': 'number', then
85
+ // 'entities[].scenarioCount.sha' would go through a primitive and should be rejected
86
+ function wouldGoThroughPrimitive(
87
+ newPath: string,
88
+ schema: { [key: string]: string },
89
+ ): boolean {
90
+ const pathParts = splitOutsideParenthesesAndArrays(newPath);
91
+
92
+ // Check each prefix of the path (excluding the full path itself)
93
+ for (let i = 1; i < pathParts.length; i++) {
94
+ const prefixPath = joinParenthesesAndArrays(pathParts.slice(0, i));
95
+ const prefixType = schema[prefixPath];
96
+ if (prefixType && isPrimitiveType(prefixType)) {
97
+ return true;
98
+ }
99
+ }
100
+
101
+ return false;
102
+ }
103
+
43
104
  // Check if schemaPathPart matches or is a function call variant of pathPart
44
105
  // e.g., 'isEntityBeingAnalyzed(entity.sha)' matches 'isEntityBeingAnalyzed'
45
106
  function pathPartMatches(pathPart: string, schemaPathPart: string): boolean {
@@ -56,11 +117,27 @@ function pathPartMatches(pathPart: string, schemaPathPart: string): boolean {
56
117
  function bestValueFromOptions(options: Array<string | undefined>) {
57
118
  options = options.filter(Boolean) as string[];
58
119
 
59
- const known = options.find((o) => !o.includes('unknown'));
60
- if (known) return known;
120
+ const known = options.filter((o) => !o.includes('unknown'));
121
+ if (known.length > 0) {
122
+ // Among known values, prefer string literal unions over bare primitives.
123
+ // e.g., "'draft' | 'inProgress' | 'paused' | 'completed'" is more specific than "string".
124
+ // This handles cases where a dependency schema has a bare type like "string" but the
125
+ // child entity's analysis has the actual literal union from TypeScript type resolution.
126
+ if (known.length > 1 && known.some((o) => PRIMITIVE_TYPES.has(o))) {
127
+ const literalUnion = known.find(
128
+ (o) => !PRIMITIVE_TYPES.has(o) && o.includes("'"),
129
+ );
130
+ if (literalUnion) {
131
+ return literalUnion;
132
+ }
133
+ }
134
+ return known[0];
135
+ }
61
136
 
62
137
  const notUnknown = options.find((o) => o !== 'unknown');
63
- if (notUnknown) return notUnknown;
138
+ if (notUnknown) {
139
+ return notUnknown;
140
+ }
64
141
 
65
142
  return options[0] ?? 'unknown';
66
143
  }
@@ -152,10 +229,38 @@ export default function mergeInDependentDataStructure({
152
229
  equivalentPostfixes: Record<string, string>;
153
230
  }[] = [];
154
231
 
232
+ // O(1) index for findOrCreateEquivalentSchemaPathsEntry.
233
+ // Maps "(rootPath)::(normalizedFuncName)" → the entry containing that root.
234
+ // This replaces the O(E) linear search that was causing O(E²) gather performance.
235
+ const espIndex = new Map<string, (typeof equivalentSchemaPaths)[0]>();
236
+ const espIndexKey = (path: string, functionName: string | undefined) => {
237
+ const normalized = cleanFunctionName(functionName);
238
+ const funcKey =
239
+ normalized === rootScopeName ? '__self__' : normalized || '__self__';
240
+ return `${path}::${funcKey}`;
241
+ };
242
+ const updateEspIndex = (entry: (typeof equivalentSchemaPaths)[0]) => {
243
+ for (const root of entry.equivalentRoots) {
244
+ const funcName = root.function?.name ?? rootScopeName;
245
+ espIndex.set(espIndexKey(root.schemaRootPath, funcName), entry);
246
+ }
247
+ };
248
+
249
+ // Pre-build a lookup map from cleaned function name to dependency for O(1) lookups.
250
+ // This avoids O(n) linear search in findRelevantDependency which was causing O(n²) performance.
251
+ const dependencyByCleanedName = new Map<
252
+ string,
253
+ (typeof importedExports)[0]
254
+ >();
255
+ for (const dep of importedExports) {
256
+ const cleanedName = cleanFunctionName(dep.name);
257
+ if (!dependencyByCleanedName.has(cleanedName)) {
258
+ dependencyByCleanedName.set(cleanedName, dep);
259
+ }
260
+ }
261
+
155
262
  const findRelevantDependency = (functionName: any) => {
156
- return importedExports.find(
157
- (d) => cleanFunctionName(d.name) === cleanFunctionName(functionName),
158
- );
263
+ return dependencyByCleanedName.get(cleanFunctionName(functionName));
159
264
  };
160
265
 
161
266
  const findRelevantDependentDataStructure = (functionName: any) => {
@@ -192,8 +297,17 @@ export default function mergeInDependentDataStructure({
192
297
  return mergedDataStructure.dependencySchemas[filePath][name];
193
298
  };
194
299
 
195
- const cleanSchema = (schema: { [key: string]: string }) => {
196
- cleanKnownObjectFunctionsFromMapping(schema);
300
+ const cleanSchema = (
301
+ schema: { [key: string]: string },
302
+ context?: Record<string, any>,
303
+ ) => {
304
+ transformationTracer.traceSchemaTransform(
305
+ rootScopeName,
306
+ 'cleanKnownObjectFunctionsFromMapping',
307
+ schema,
308
+ cleanKnownObjectFunctionsFromMapping,
309
+ context,
310
+ );
197
311
  };
198
312
 
199
313
  const translatePath = (path: string, dependencyName: string) => {
@@ -246,6 +360,54 @@ export default function mergeInDependentDataStructure({
246
360
  ) => {
247
361
  if (!sourceAndUsageEquivalencies) return;
248
362
 
363
+ // Pre-computed normalized schema index cache.
364
+ // Avoids repeated splitOutsideParenthesesAndArrays calls and function-name
365
+ // normalization for the same schema paths across multiple equivalency iterations.
366
+ // The normalization depends on `functionName` (constant per gatherAllEquivalentSchemaPaths call),
367
+ // so this cache is scoped to this call.
368
+ type NormalizedEntry = { path: string; parts: string[] };
369
+ const normalizedSchemaCache = new Map<
370
+ object,
371
+ {
372
+ byFirstPart: Map<string, NormalizedEntry[]>;
373
+ }
374
+ >();
375
+ const getSchemaIndex = (
376
+ schema: Record<string, string> | undefined,
377
+ ): { byFirstPart: Map<string, NormalizedEntry[]> } => {
378
+ if (!schema) return { byFirstPart: new Map() };
379
+ const cached = normalizedSchemaCache.get(schema);
380
+ if (cached) return cached;
381
+ const byFirstPart = new Map<string, NormalizedEntry[]>();
382
+ for (const path in schema) {
383
+ let parts = splitOutsideParenthesesAndArrays(path);
384
+ if (parts[0].startsWith(functionName)) {
385
+ const baseName = cleanFunctionName(parts[0]);
386
+ if (!functionsWithMultipleTypeParams.has(baseName)) {
387
+ parts =
388
+ parts[1] === 'functionCallReturnValue'
389
+ ? ['returnValue', ...parts.slice(2)]
390
+ : parts.slice(1);
391
+ }
392
+ }
393
+ const entry: NormalizedEntry = { path, parts };
394
+ // Index by the base of the first part (before any function call args)
395
+ const firstPart = parts[0] ?? '';
396
+ const parenIdx = firstPart.indexOf('(');
397
+ const firstPartBase =
398
+ parenIdx >= 0 ? firstPart.slice(0, parenIdx) : firstPart;
399
+ let bucket = byFirstPart.get(firstPartBase);
400
+ if (!bucket) {
401
+ bucket = [];
402
+ byFirstPart.set(firstPartBase, bucket);
403
+ }
404
+ bucket.push(entry);
405
+ }
406
+ const result = { byFirstPart };
407
+ normalizedSchemaCache.set(schema, result);
408
+ return result;
409
+ };
410
+
249
411
  const findOrCreateEquivalentSchemaPathsEntry = (
250
412
  allPaths: { path: string; functionName?: string }[],
251
413
  ) => {
@@ -266,59 +428,320 @@ export default function mergeInDependentDataStructure({
266
428
  let equivalentSchemaPathsEntry:
267
429
  | (typeof equivalentSchemaPaths)[0]
268
430
  | undefined;
431
+
432
+ // Collect the signature indices from the new roots we want to add
433
+ const newRootSignatureIndices = new Set<number>();
434
+ for (const root of equivalentRoots) {
435
+ const idx = extractSignatureIndex(root.schemaRootPath);
436
+ if (idx !== undefined) {
437
+ newRootSignatureIndices.add(idx);
438
+ }
439
+ }
440
+
441
+ // Use espIndex Map for O(1) lookup instead of O(E) linear search.
442
+ // Falls back to linear search only when Map hit has a signature index conflict.
269
443
  for (const pathInfo of allPaths) {
270
- if (!equivalentSchemaPathsEntry) {
271
- equivalentSchemaPathsEntry = equivalentSchemaPaths.find((esp) =>
272
- esp.equivalentRoots.some(
273
- (er) =>
274
- er.schemaRootPath === pathInfo.path &&
275
- (er.function?.name ===
276
- cleanFunctionName(pathInfo.functionName) ||
277
- (!er.function &&
278
- cleanFunctionName(pathInfo.functionName) ===
279
- rootScopeName)),
280
- ),
281
- );
444
+ if (equivalentSchemaPathsEntry) break;
445
+ const candidate = espIndex.get(
446
+ espIndexKey(pathInfo.path, pathInfo.functionName),
447
+ );
448
+ if (!candidate) continue;
449
+
450
+ // Verify no signature index conflict with the candidate entry
451
+ if (newRootSignatureIndices.size > 0) {
452
+ const existingIndicesByFunction = new Map<string, Set<number>>();
453
+ for (const er of candidate.equivalentRoots) {
454
+ const funcKey = er.function
455
+ ? `${er.function.name}::${er.function.filePath}`
456
+ : '__self__';
457
+ const idx = extractSignatureIndex(er.schemaRootPath);
458
+ if (idx !== undefined) {
459
+ if (!existingIndicesByFunction.has(funcKey)) {
460
+ existingIndicesByFunction.set(funcKey, new Set());
461
+ }
462
+ existingIndicesByFunction.get(funcKey)!.add(idx);
463
+ }
464
+ }
465
+
466
+ let hasConflict = false;
467
+ for (const newRoot of equivalentRoots) {
468
+ const funcKey = newRoot.function
469
+ ? `${newRoot.function.name}::${newRoot.function.filePath}`
470
+ : '__self__';
471
+ const newIdx = extractSignatureIndex(newRoot.schemaRootPath);
472
+ if (newIdx !== undefined) {
473
+ const existingIndices = existingIndicesByFunction.get(funcKey);
474
+ if (existingIndices && existingIndices.size > 0) {
475
+ if (!existingIndices.has(newIdx)) {
476
+ hasConflict = true;
477
+ break;
478
+ }
479
+ }
480
+ }
481
+ }
482
+
483
+ if (hasConflict) continue;
282
484
  }
485
+
486
+ equivalentSchemaPathsEntry = candidate;
283
487
  }
284
488
 
285
489
  if (!equivalentSchemaPathsEntry) {
490
+ // Before creating a new entry, filter out roots that have conflicting
491
+ // signature indices from the same function. An entry should never contain
492
+ // roots with different signature indices from the same function.
493
+ // This prevents the bug where signature[1], signature[2], signature[4]
494
+ // all get merged together due to incorrect sourceEquivalencies.
495
+ let filteredRoots = equivalentRoots;
496
+ if (newRootSignatureIndices.size > 1) {
497
+ // There are multiple signature indices - we need to filter to keep only
498
+ // one consistent set. We'll keep the roots that match the PRIMARY index
499
+ // (the first signature index we encounter from self, or the lowest index).
500
+
501
+ // First, determine the primary index - prefer the self root's index
502
+ let primaryIndex: number | undefined;
503
+ for (const root of equivalentRoots) {
504
+ if (!root.function) {
505
+ // This is a self root
506
+ const idx = extractSignatureIndex(root.schemaRootPath);
507
+ if (idx !== undefined) {
508
+ primaryIndex = idx;
509
+ break;
510
+ }
511
+ }
512
+ }
513
+ // If no self root has a signature index, use the lowest index
514
+ if (primaryIndex === undefined) {
515
+ primaryIndex = Math.min(...newRootSignatureIndices);
516
+ }
517
+
518
+ // Filter roots: keep if no signature index OR signature index matches primary
519
+ filteredRoots = equivalentRoots.filter((root) => {
520
+ const idx = extractSignatureIndex(root.schemaRootPath);
521
+ return idx === undefined || idx === primaryIndex;
522
+ });
523
+ }
524
+
286
525
  equivalentSchemaPathsEntry = {
287
- equivalentRoots,
526
+ equivalentRoots: filteredRoots,
288
527
  equivalentPostfixes: {},
289
528
  };
290
529
  equivalentSchemaPaths.push(equivalentSchemaPathsEntry);
291
530
  } else {
292
531
  equivalentSchemaPathsEntry.equivalentRoots.push(...equivalentRoots);
293
532
  }
533
+
534
+ // Deduplicate roots using a Set for O(n) instead of O(n²)
535
+ const seenRoots = new Set<string>();
294
536
  equivalentSchemaPathsEntry.equivalentRoots =
295
- equivalentSchemaPathsEntry.equivalentRoots.filter(
296
- (er, index, self) =>
297
- index ===
298
- self.findIndex(
299
- (e) =>
300
- e.schemaRootPath === er.schemaRootPath &&
301
- e.function?.name === er.function?.name,
302
- ),
303
- );
537
+ equivalentSchemaPathsEntry.equivalentRoots.filter((er) => {
538
+ const key = er.schemaRootPath + '::' + (er.function?.name ?? '');
539
+ if (seenRoots.has(key)) return false;
540
+ seenRoots.add(key);
541
+ return true;
542
+ });
543
+
544
+ // Keep the espIndex in sync after adding/deduplicating roots
545
+ updateEspIndex(equivalentSchemaPathsEntry);
304
546
 
305
547
  return equivalentSchemaPathsEntry;
306
548
  };
307
549
 
308
- for (const equivalencies of [
550
+ // Helper to extract function name from a path that starts with a function call.
551
+ // e.g., 'ScenarioViewer().signature[0].scenario' -> 'ScenarioViewer'
552
+ // Returns undefined if the path doesn't start with a function call or the function isn't a dependency.
553
+ const extractFunctionNameFromPath = (path: string): string | undefined => {
554
+ const parts = splitOutsideParenthesesAndArrays(path);
555
+ if (parts.length > 0 && parts[0].endsWith(')')) {
556
+ // Extract the function name without the () suffix and type params
557
+ const funcCallPart = parts[0];
558
+ const funcName = cleanFunctionName(funcCallPart.replace(/\(\)$/, ''));
559
+ // Check if this function is a dependency
560
+ if (findRelevantDependency(funcName)) {
561
+ return funcName;
562
+ }
563
+ }
564
+ return undefined;
565
+ };
566
+
567
+ const allEquivalencies = [
309
568
  sourceAndUsageEquivalencies.usageEquivalencies,
310
569
  sourceAndUsageEquivalencies.sourceEquivalencies,
311
- ].filter(Boolean)) {
312
- for (const [schemaPath, usages] of Object.entries(equivalencies)) {
570
+ ].filter(Boolean);
571
+
572
+ for (const equivalencies of allEquivalencies) {
573
+ const schemaPathEntries = Object.entries(equivalencies);
574
+ for (const [schemaPath, usages] of schemaPathEntries) {
575
+ // First, check if the raw schemaPath starts with a function call to a dependency.
576
+ // If so, use that dependency name for translation (so translatePath can strip the prefix).
577
+ const extractedFuncName = extractFunctionNameFromPath(schemaPath);
578
+ const effectiveFunctionName = extractedFuncName || functionName;
579
+ const translatedPath = translatePath(schemaPath, effectiveFunctionName);
580
+
313
581
  const allPaths: { path: string; functionName?: string }[] = [
314
- { path: translatePath(schemaPath, functionName), functionName },
582
+ { path: translatedPath, functionName: effectiveFunctionName },
315
583
  ...usages.map((u) => ({
316
584
  path: translatePath(u.schemaPath, u.scopeNodeName),
317
585
  functionName: u.scopeNodeName,
318
586
  })),
319
587
  ].filter((pathInfo) => !pathInfo.path.includes('.map('));
320
588
 
589
+ // Fix 38: Derive base paths from property access paths.
590
+ // When we have equivalent paths like:
591
+ // Parent: signature[0].scenarios[].name
592
+ // Child: signature[0].selectedScenario.name
593
+ // We want to derive the base paths by finding the common suffix:
594
+ // Common suffix: .name
595
+ // Parent base: signature[0].scenarios[]
596
+ // Child base: signature[0].selectedScenario
597
+ // This allows the merge to find nested child schema fields under the base prop.
598
+
599
+ // Find child signature paths (paths from child components)
600
+ const childPaths = allPaths.filter(
601
+ (p) =>
602
+ p.functionName &&
603
+ p.functionName !== rootScopeName &&
604
+ p.functionName !== effectiveFunctionName,
605
+ );
606
+ // Find parent paths (paths from this component)
607
+ const parentPaths = allPaths.filter(
608
+ (p) =>
609
+ !p.functionName ||
610
+ p.functionName === rootScopeName ||
611
+ p.functionName === effectiveFunctionName,
612
+ );
613
+
614
+ const derivedBasePaths: { path: string; functionName?: string }[] = [];
615
+ const allPathSet = new Set(allPaths.map((p) => p.path));
616
+ const derivedBasePathSet = new Set<string>();
617
+
618
+ // For each child path, find its equivalent parent path and derive bases
619
+ for (const childPathInfo of childPaths) {
620
+ const childParts = splitOutsideParenthesesAndArrays(
621
+ childPathInfo.path,
622
+ );
623
+
624
+ // Look for a parent path that shares a common suffix with this child path
625
+ for (const parentPathInfo of parentPaths) {
626
+ const parentParts = splitOutsideParenthesesAndArrays(
627
+ parentPathInfo.path,
628
+ );
629
+
630
+ // Find the common suffix (from the end)
631
+ let commonSuffixLength = 0;
632
+ const minLen = Math.min(childParts.length, parentParts.length);
633
+ for (let i = 1; i <= minLen; i++) {
634
+ if (
635
+ childParts[childParts.length - i] ===
636
+ parentParts[parentParts.length - i]
637
+ ) {
638
+ commonSuffixLength = i;
639
+ } else {
640
+ break;
641
+ }
642
+ }
643
+
644
+ // If there's a common suffix and both paths have more parts than the suffix
645
+ if (
646
+ commonSuffixLength > 0 &&
647
+ childParts.length > commonSuffixLength &&
648
+ parentParts.length > commonSuffixLength
649
+ ) {
650
+ const childBaseParts = childParts.slice(
651
+ 0,
652
+ childParts.length - commonSuffixLength,
653
+ );
654
+ const parentBaseParts = parentParts.slice(
655
+ 0,
656
+ parentParts.length - commonSuffixLength,
657
+ );
658
+
659
+ // Only derive if BOTH paths look like signature paths.
660
+ // This ensures we're handling JSX child-to-parent prop mappings,
661
+ // not other complex equivalencies like function call returns.
662
+ const isChildSignaturePath =
663
+ childBaseParts[0]?.startsWith('signature[') ||
664
+ (childBaseParts[0]?.endsWith(')') &&
665
+ childBaseParts[1]?.startsWith('signature['));
666
+ const isParentSignaturePath =
667
+ parentBaseParts[0]?.startsWith('signature[');
668
+
669
+ if (isChildSignaturePath && isParentSignaturePath) {
670
+ const childBase = joinParenthesesAndArrays(childBaseParts);
671
+ const parentBase = joinParenthesesAndArrays(parentBaseParts);
672
+
673
+ // Only derive if:
674
+ // 1. Parent has array iteration (e.g., scenarios[]) and child does NOT
675
+ // 2. Bases are different
676
+ // 3. Child base is NOT just "signature[N]" (too generic - every component has this)
677
+ // We only want specific prop paths like "signature[0].selectedScenario"
678
+ // This targets array-to-object mappings like scenarios[] -> selectedScenario
679
+ const parentHasArrayIterator = parentBase.includes('[]');
680
+ const childHasArrayIterator = childBase.includes('[]');
681
+
682
+ // Skip if child base is just the generic signature marker (e.g., "signature[0]")
683
+ const childBaseIsGenericSignature = /^signature\[\d+\]$/.test(
684
+ childBase,
685
+ );
686
+
687
+ if (
688
+ childBase !== parentBase &&
689
+ parentHasArrayIterator &&
690
+ !childHasArrayIterator &&
691
+ !childBaseIsGenericSignature
692
+ ) {
693
+ // Add child base if not already present (O(1) Set lookup)
694
+ if (
695
+ !allPathSet.has(childBase) &&
696
+ !derivedBasePathSet.has(childBase)
697
+ ) {
698
+ derivedBasePaths.push({
699
+ path: childBase,
700
+ functionName: childPathInfo.functionName,
701
+ });
702
+ derivedBasePathSet.add(childBase);
703
+ }
704
+
705
+ // Add parent base if not already present (O(1) Set lookup)
706
+ if (
707
+ !allPathSet.has(parentBase) &&
708
+ !derivedBasePathSet.has(parentBase)
709
+ ) {
710
+ derivedBasePaths.push({
711
+ path: parentBase,
712
+ functionName: parentPathInfo.functionName,
713
+ });
714
+ derivedBasePathSet.add(parentBase);
715
+ }
716
+ }
717
+ }
718
+ }
719
+ }
720
+ }
721
+
722
+ allPaths.push(...derivedBasePaths);
723
+
321
724
  const entry = findOrCreateEquivalentSchemaPathsEntry(allPaths);
725
+
726
+ // Trace equivalency gathering - helps debug why paths may not be connected
727
+ if (allPaths.length > 1) {
728
+ transformationTracer.operation(rootScopeName, {
729
+ operation: 'gatherEquivalency',
730
+ stage: 'gathering',
731
+ path: translatedPath,
732
+ context: {
733
+ sourceFunction: functionName,
734
+ equivalentPaths: allPaths.map((p) => ({
735
+ path: p.path,
736
+ function: p.functionName,
737
+ })),
738
+ equivalentRoots: entry.equivalentRoots.map((r) => ({
739
+ path: r.schemaRootPath,
740
+ function: r.function?.name,
741
+ })),
742
+ },
743
+ });
744
+ }
322
745
  for (const equivalentRoot of entry.equivalentRoots) {
323
746
  const dataStructures =
324
747
  equivalentRoot.function &&
@@ -333,32 +756,53 @@ export default function mergeInDependentDataStructure({
333
756
  ]
334
757
  : [dataStructure];
335
758
 
759
+ // Determine if this is a signature schema path.
760
+ // The path might be 'signature[0]...' directly, or 'FuncName().signature[0]...' if it has a function prefix.
761
+ const schemaRootParts = splitOutsideParenthesesAndArrays(
762
+ equivalentRoot.schemaRootPath,
763
+ );
764
+ const isSignaturePath =
765
+ equivalentRoot.schemaRootPath.startsWith('signature[') ||
766
+ (schemaRootParts[0]?.endsWith(')') &&
767
+ schemaRootParts[1]?.startsWith('signature['));
768
+
336
769
  const schemas = dataStructures.map((dataStructure) =>
337
- equivalentRoot.schemaRootPath.startsWith('signature[')
770
+ isSignaturePath
338
771
  ? dataStructure?.signatureSchema
339
772
  : dataStructure?.returnValueSchema,
340
773
  );
341
774
 
342
- const pathParts = splitOutsideParenthesesAndArrays(
775
+ let pathParts = splitOutsideParenthesesAndArrays(
343
776
  equivalentRoot.schemaRootPath,
344
777
  );
345
778
 
346
- for (const schema of schemas) {
347
- for (const schemaPath in schema) {
348
- let schemaPathParts =
349
- splitOutsideParenthesesAndArrays(schemaPath);
350
-
351
- if (schemaPathParts[0].startsWith(functionName)) {
352
- // Only normalize if the function doesn't have multiple different type parameters
353
- const baseName = cleanFunctionName(schemaPathParts[0]);
354
- if (!functionsWithMultipleTypeParams.has(baseName)) {
355
- schemaPathParts =
356
- schemaPathParts[1] === 'functionCallReturnValue'
357
- ? ['returnValue', ...schemaPathParts.slice(2)]
358
- : schemaPathParts.slice(1);
359
- }
360
- }
779
+ // Fix: When processing a child component's schema, the schemaRootPath has the function
780
+ // prefix (e.g., 'ScenarioViewer().signature[0].scenario'), but the child's schema paths
781
+ // don't have that prefix (e.g., 'signature[0].scenario.metadata.screenshotPaths').
782
+ // Strip the function prefix from pathParts so they can match.
783
+ if (
784
+ equivalentRoot.function &&
785
+ pathParts[0].endsWith(')') &&
786
+ pathParts[1]?.startsWith('signature[')
787
+ ) {
788
+ pathParts = pathParts.slice(1);
789
+ }
361
790
 
791
+ for (const schema of schemas) {
792
+ // Use pre-computed index to only iterate schema entries whose
793
+ // normalized first part matches pathParts[0], instead of all entries.
794
+ const schemaIndex = getSchemaIndex(schema);
795
+ const lookupPart = pathParts[0] ?? '';
796
+ const lookupParenIdx = lookupPart.indexOf('(');
797
+ const lookupBase =
798
+ lookupParenIdx >= 0
799
+ ? lookupPart.slice(0, lookupParenIdx)
800
+ : lookupPart;
801
+ const candidates = schemaIndex.byFirstPart.get(lookupBase) || [];
802
+ for (const {
803
+ path: schemaPath,
804
+ parts: schemaPathParts,
805
+ } of candidates) {
362
806
  if (schemaPathParts.length < pathParts.length) continue;
363
807
 
364
808
  // Check if all path parts match (allowing function call variants)
@@ -427,13 +871,29 @@ export default function mergeInDependentDataStructure({
427
871
  schemaPathParts.slice(matchedUpToIndex),
428
872
  );
429
873
 
430
- entry.equivalentPostfixes[postfix] = entry
431
- .equivalentPostfixes[postfix]
432
- ? bestValueFromOptions([
433
- entry.equivalentPostfixes[postfix],
434
- schema[schemaPath],
435
- ])
436
- : schema[schemaPath];
874
+ const previousValue = entry.equivalentPostfixes[postfix];
875
+ const newValue = schema[schemaPath];
876
+ entry.equivalentPostfixes[postfix] = previousValue
877
+ ? bestValueFromOptions([previousValue, newValue])
878
+ : newValue;
879
+
880
+ // Trace postfix gathering - shows where type info comes from
881
+ if (entry.equivalentPostfixes[postfix] !== previousValue) {
882
+ transformationTracer.operation(rootScopeName, {
883
+ operation: 'gatherPostfix',
884
+ stage: 'gathering',
885
+ path: postfix || '(root)',
886
+ before: previousValue,
887
+ after: entry.equivalentPostfixes[postfix],
888
+ context: {
889
+ sourceSchemaPath: schemaPath,
890
+ sourceFunction:
891
+ equivalentRoot.function?.name || rootScopeName,
892
+ equivalentRootPath: equivalentRoot.schemaRootPath,
893
+ rawValue: newValue,
894
+ },
895
+ });
896
+ }
437
897
  }
438
898
  }
439
899
  }
@@ -470,10 +930,17 @@ export default function mergeInDependentDataStructure({
470
930
  const entry = findOrCreateEquivalentSchemaPathsEntry([
471
931
  { path: translatedBasePath, functionName: functionName },
472
932
  ]);
473
- entry.equivalentRoots.push({
933
+ const newRoot = {
474
934
  schemaRootPath: translatedBasePath,
475
935
  function: findRelevantDependency(functionName),
476
- });
936
+ };
937
+ entry.equivalentRoots.push(newRoot);
938
+ // Update index for the newly added root
939
+ const newRootFuncName = newRoot.function?.name ?? rootScopeName;
940
+ espIndex.set(
941
+ espIndexKey(newRoot.schemaRootPath, newRootFuncName),
942
+ entry,
943
+ );
477
944
 
478
945
  const basePathParts = splitOutsideParenthesesAndArrays(basePath);
479
946
  for (const schemaPath in dataStructure.returnValueSchema) {
@@ -493,14 +960,14 @@ export default function mergeInDependentDataStructure({
493
960
  const postfix = joinParenthesesAndArrays(
494
961
  schemaPathParts.slice(basePathParts.length),
495
962
  );
496
- entry.equivalentPostfixes[postfix] = entry.equivalentPostfixes[
497
- postfix
498
- ]
963
+ const newValue = entry.equivalentPostfixes[postfix]
499
964
  ? bestValueFromOptions([
500
965
  entry.equivalentPostfixes[postfix],
501
966
  dataStructure.returnValueSchema[schemaPath],
502
967
  ])
503
968
  : dataStructure.returnValueSchema[schemaPath];
969
+
970
+ entry.equivalentPostfixes[postfix] = newValue;
504
971
  }
505
972
  }
506
973
  }
@@ -555,6 +1022,10 @@ export default function mergeInDependentDataStructure({
555
1022
  equivalentRootFunction: (typeof equivalentSchemaPaths)[0]['equivalentRoots'][0]['function'],
556
1023
  ) => {
557
1024
  let postfix: string | undefined;
1025
+
1026
+ // Get the signature index we're looking for (if any)
1027
+ const lookingForSignatureIndex = extractSignatureIndex(schemaSubPath);
1028
+
558
1029
  const equivalentEntry = mergedEquivalentSchemaPaths.find((esp) =>
559
1030
  esp.equivalentRoots.some((er) => {
560
1031
  if (
@@ -567,6 +1038,35 @@ export default function mergeInDependentDataStructure({
567
1038
  }
568
1039
 
569
1040
  if (schemaSubPath === er.schemaRootPath) {
1041
+ // Additional check: if we're looking for a signature path, make sure
1042
+ // the entry doesn't already have DIFFERENT signature indices.
1043
+ // This prevents entries with signature[1], signature[2], signature[4]
1044
+ // from all being merged together.
1045
+ if (lookingForSignatureIndex !== undefined) {
1046
+ const hasConflictingSignatureIndex = esp.equivalentRoots.some(
1047
+ (otherRoot) => {
1048
+ // Only check roots from the same function
1049
+ if (
1050
+ otherRoot.function?.name !== equivalentRootFunction?.name ||
1051
+ otherRoot.function?.filePath !==
1052
+ equivalentRootFunction?.filePath
1053
+ ) {
1054
+ return false;
1055
+ }
1056
+ const otherIndex = extractSignatureIndex(
1057
+ otherRoot.schemaRootPath,
1058
+ );
1059
+ return (
1060
+ otherIndex !== undefined &&
1061
+ otherIndex !== lookingForSignatureIndex
1062
+ );
1063
+ },
1064
+ );
1065
+ if (hasConflictingSignatureIndex) {
1066
+ return false;
1067
+ }
1068
+ }
1069
+
570
1070
  postfix = er.postfix;
571
1071
  return true;
572
1072
  }
@@ -691,16 +1191,58 @@ export default function mergeInDependentDataStructure({
691
1191
  continue;
692
1192
  }
693
1193
 
694
- const mergedDataStructure =
1194
+ const childMergedDataStructure =
695
1195
  dependentAnalyses[filePath][name].metadata?.mergedDataStructure || {};
696
- gatherAllEquivalentSchemaPaths(name, mergedDataStructure);
1196
+
1197
+ gatherAllEquivalentSchemaPaths(name, childMergedDataStructure as any);
697
1198
  }
698
1199
  }
699
1200
 
700
1201
  equivalentSchemaPaths = mergeAllEquivalentSchemaPaths();
701
1202
 
1203
+ // Collect schemas that need cleaning — batch the calls for the end instead of
1204
+ // calling cleanSchema inside the inner root loop (which was O(roots * schemaSize)).
1205
+ const schemasToClean = new Set<{ [key: string]: string }>();
1206
+
702
1207
  for (const esp of equivalentSchemaPaths) {
703
- for (const equivalentRoot of esp.equivalentRoots) {
1208
+ // Pre-compute which postfixes have children to avoid O(n²) lookups in the inner loop.
1209
+ // A postfix "has children" if there are other postfixes that extend it.
1210
+ const postfixesWithChildren = new Set<string>();
1211
+ const postfixKeys = Object.keys(esp.equivalentPostfixes);
1212
+
1213
+ // Check for empty postfix having children (any other postfixes exist)
1214
+ if (postfixKeys.length > 1 && '' in esp.equivalentPostfixes) {
1215
+ postfixesWithChildren.add('');
1216
+ }
1217
+
1218
+ // Check for array element postfixes having children using a prefix set.
1219
+ // This avoids O(n²) scans across large postfix lists.
1220
+ // e.g., 'currentEntities[]' has children if a path like 'currentEntities[].sha' exists.
1221
+ const postfixPrefixSet = new Set<string>();
1222
+ for (const postfixPath of postfixKeys) {
1223
+ if (!postfixPath) continue;
1224
+ const parts = splitOutsideParenthesesAndArrays(postfixPath);
1225
+ for (let i = 1; i < parts.length; i++) {
1226
+ postfixPrefixSet.add(joinParenthesesAndArrays(parts.slice(0, i)));
1227
+ }
1228
+ }
1229
+ for (const postfixPath of postfixKeys) {
1230
+ if (postfixPath.endsWith('[]') && postfixPrefixSet.has(postfixPath)) {
1231
+ postfixesWithChildren.add(postfixPath);
1232
+ }
1233
+ }
1234
+
1235
+ // Deduplicate equivalentRoots that would write to the same schema paths.
1236
+ // Roots with the same (function, schemaRootPath, postfix) are redundant.
1237
+ const seenRootKeys = new Set<string>();
1238
+ const uniqueRoots = esp.equivalentRoots.filter((root) => {
1239
+ const key = `${root.function?.filePath ?? ''}::${root.function?.name ?? ''}::${root.schemaRootPath}::${root.postfix ?? ''}`;
1240
+ if (seenRootKeys.has(key)) return false;
1241
+ seenRootKeys.add(key);
1242
+ return true;
1243
+ });
1244
+
1245
+ for (const equivalentRoot of uniqueRoots) {
704
1246
  let merged:
705
1247
  | {
706
1248
  signatureSchema: { [key: string]: string };
@@ -725,9 +1267,21 @@ export default function mergeInDependentDataStructure({
725
1267
  )) {
726
1268
  let relevantPostfix = postfixPath;
727
1269
  if (equivalentRoot.postfix) {
1270
+ // Check if postfixPath starts with equivalentRoot.postfix at a path boundary.
1271
+ // Must ensure exact path part match - "entityCode" should NOT match "entity" prefix.
1272
+ // Valid: "entity.foo" starts with "entity" (boundary at '.')
1273
+ // Valid: "entity[0]" starts with "entity" (boundary at '[')
1274
+ // Invalid: "entityCode" starts with "entity" (no boundary, different property)
728
1275
  if (!postfixPath.startsWith(equivalentRoot.postfix)) {
729
1276
  continue;
730
1277
  }
1278
+ // Additional check: ensure the match is at a path boundary
1279
+ const nextChar = postfixPath[equivalentRoot.postfix.length];
1280
+ if (nextChar !== undefined && nextChar !== '.' && nextChar !== '[') {
1281
+ // The postfixPath continues with more characters that aren't a path separator.
1282
+ // This means "entity" matched "entityCode" which is wrong - they're different properties.
1283
+ continue;
1284
+ }
731
1285
 
732
1286
  const postFixPathParts =
733
1287
  splitOutsideParenthesesAndArrays(postfixPath);
@@ -744,13 +1298,98 @@ export default function mergeInDependentDataStructure({
744
1298
  relevantPostfix,
745
1299
  ]);
746
1300
 
1301
+ // Skip paths that would go through a primitive type
1302
+ // e.g., if schema has 'entities[].scenarioCount': 'number', skip 'entities[].scenarioCount.sha'
1303
+ if (wouldGoThroughPrimitive(newSchemaPath, schema)) {
1304
+ transformationTracer.operation(rootScopeName, {
1305
+ operation: 'skipPrimitivePath',
1306
+ stage: 'merged',
1307
+ path: newSchemaPath,
1308
+ context: {
1309
+ reason: 'would go through primitive type',
1310
+ postfixValue,
1311
+ },
1312
+ });
1313
+ continue;
1314
+ }
1315
+
1316
+ // Skip setting primitive type when there are child postfixes that indicate structure.
1317
+ // This prevents downgrading an object/array element to a primitive type.
1318
+ // Uses pre-computed postfixesWithChildren Set for O(1) lookup instead of O(n) iteration.
1319
+ const hasChildPostfixes =
1320
+ (relevantPostfix === '' || relevantPostfix.endsWith('[]')) &&
1321
+ postfixesWithChildren.has(postfixPath);
1322
+ if (PRIMITIVE_TYPES.has(postfixValue) && hasChildPostfixes) {
1323
+ continue;
1324
+ }
1325
+
1326
+ // Don't overwrite a more specific type with a less specific one
1327
+ // This can happen when nested roots share entries with their parent roots
1328
+ const existingType = schema[newSchemaPath];
1329
+ if (existingType) {
1330
+ // Don't overwrite a primitive type with 'object' or 'array'
1331
+ // e.g., if schema has 'entities[].scenarioCount': 'number', don't overwrite with 'object'
1332
+ if (
1333
+ PRIMITIVE_TYPES.has(existingType) &&
1334
+ (postfixValue === 'object' || postfixValue === 'array')
1335
+ ) {
1336
+ transformationTracer.operation(rootScopeName, {
1337
+ operation: 'skipTypeDowngrade',
1338
+ stage: 'merged',
1339
+ path: newSchemaPath,
1340
+ context: {
1341
+ reason: 'would overwrite primitive with object/array',
1342
+ existingType,
1343
+ newType: postfixValue,
1344
+ },
1345
+ });
1346
+ continue;
1347
+ }
1348
+ // Don't overwrite a complex/union type with a primitive
1349
+ // e.g., if schema has 'scenarios[]': 'Scenario | null', don't overwrite with 'string'
1350
+ if (
1351
+ !PRIMITIVE_TYPES.has(existingType) &&
1352
+ PRIMITIVE_TYPES.has(postfixValue)
1353
+ ) {
1354
+ transformationTracer.operation(rootScopeName, {
1355
+ operation: 'skipTypeDowngrade',
1356
+ stage: 'merged',
1357
+ path: newSchemaPath,
1358
+ context: {
1359
+ reason: 'would overwrite complex type with primitive',
1360
+ existingType,
1361
+ newType: postfixValue,
1362
+ },
1363
+ });
1364
+ continue;
1365
+ }
1366
+ }
1367
+
1368
+ // Log the successful postfix merge
1369
+ transformationTracer.operation(rootScopeName, {
1370
+ operation: 'mergePostfix',
1371
+ stage: 'merged',
1372
+ path: newSchemaPath,
1373
+ before: existingType,
1374
+ after: postfixValue,
1375
+ context: {
1376
+ schemaRootPath: equivalentRoot.schemaRootPath,
1377
+ postfix: relevantPostfix,
1378
+ dependency: equivalentRoot.function?.name,
1379
+ },
1380
+ });
747
1381
  schema[newSchemaPath] = postfixValue;
748
1382
  }
749
1383
 
750
- cleanSchema(schema);
1384
+ schemasToClean.add(schema);
751
1385
  }
752
1386
  }
753
1387
 
1388
+ // Batch-clean all modified schemas once (instead of once per root per ESP entry)
1389
+ for (const schema of schemasToClean) {
1390
+ cleanSchema(schema, { stage: 'afterMergePostfix' });
1391
+ }
1392
+
754
1393
  // Propagate equivalency-derived attributes to generic function call variants.
755
1394
  // When attributes are traced via equivalencies (e.g., fileComparisons from buildDataMap.signature[2]),
756
1395
  // they get written to non-generic paths (returnValue.data.x or funcName().functionCallReturnValue.data.x).
@@ -869,6 +1508,14 @@ export default function mergeInDependentDataStructure({
869
1508
  `${dependency.name}().functionCallReturnValue`,
870
1509
  );
871
1510
  }
1511
+ transformationTracer.operation(rootScopeName, {
1512
+ operation: 'normalizeReturnValuePath',
1513
+ stage: 'merged',
1514
+ path: normalizedPath,
1515
+ before: path,
1516
+ after: normalizedPath,
1517
+ context: { dependency: dependency.name, value },
1518
+ });
872
1519
  depSchema.returnValueSchema[normalizedPath] = value;
873
1520
  }
874
1521
 
@@ -953,7 +1600,90 @@ export default function mergeInDependentDataStructure({
953
1600
  }
954
1601
  }
955
1602
 
956
- cleanSchema(depSchema.returnValueSchema);
1603
+ cleanSchema(depSchema.returnValueSchema, {
1604
+ stage: 'afterMockedDependencyMerge',
1605
+ dependency: dependency.name,
1606
+ });
1607
+
1608
+ // Pull signature requirements from downstream functions into the mocked return value.
1609
+ // When a mocked function's return flows into another function's signature (via usageEquivalencies),
1610
+ // we need to include that function's signature requirements in the mock.
1611
+ //
1612
+ // Example: fromE5() returns a currency object that flows to calculateTotalPrice(price, quantity).
1613
+ // calculateTotalPrice's signatureSchema shows signature[0].multiply() is required.
1614
+ // We need to add multiply() to fromE5's mock return value.
1615
+ const usageEquivalencies = srcSchema.usageEquivalencies ?? {};
1616
+ for (const [returnPath, equivalencies] of Object.entries(
1617
+ usageEquivalencies,
1618
+ )) {
1619
+ // Only process return value paths (functionCallReturnValue)
1620
+ if (!returnPath.includes('.functionCallReturnValue')) continue;
1621
+
1622
+ for (const equiv of equivalencies) {
1623
+ // Check if this equivalency points to a signature path
1624
+ const signatureMatch = equiv.schemaPath.match(/\.signature\[(\d+)\]$/);
1625
+ if (!signatureMatch) continue;
1626
+
1627
+ const targetFunctionName = cleanFunctionName(equiv.scopeNodeName);
1628
+ const signatureIndex = signatureMatch[1];
1629
+
1630
+ // Look up the target function's analysis to get its signature requirements
1631
+ // First try dependentAnalyses, then dependencySchemas
1632
+ let targetSignatureSchema: Record<string, string> | undefined;
1633
+
1634
+ // Check dependentAnalyses first (has the full merged analysis)
1635
+ for (const depFilePath in dependentAnalyses) {
1636
+ const analysis = dependentAnalyses[depFilePath]?.[targetFunctionName];
1637
+ if (analysis?.metadata?.mergedDataStructure?.signatureSchema) {
1638
+ targetSignatureSchema =
1639
+ analysis.metadata.mergedDataStructure.signatureSchema;
1640
+ break;
1641
+ }
1642
+ }
1643
+
1644
+ // Fallback to dependencySchemas if not found
1645
+ if (!targetSignatureSchema) {
1646
+ for (const depFilePath in dependencySchemas) {
1647
+ const schema = dependencySchemas[depFilePath]?.[targetFunctionName];
1648
+ if (schema?.signatureSchema) {
1649
+ targetSignatureSchema = schema.signatureSchema;
1650
+ break;
1651
+ }
1652
+ }
1653
+ }
1654
+
1655
+ if (!targetSignatureSchema) continue;
1656
+
1657
+ // Find all paths in the target's signatureSchema that extend from signature[N]
1658
+ // e.g., signature[0].multiply(quantity) -> .multiply(quantity)
1659
+ const signaturePrefix = `signature[${signatureIndex}]`;
1660
+ for (const [sigPath, sigType] of Object.entries(
1661
+ targetSignatureSchema,
1662
+ )) {
1663
+ if (!sigPath.startsWith(signaturePrefix)) continue;
1664
+
1665
+ // Skip the base signature[N] path itself - we only want the method/property extensions
1666
+ if (sigPath === signaturePrefix) continue;
1667
+
1668
+ // Extract the suffix after signature[N] (e.g., ".multiply(quantity)")
1669
+ const suffix = sigPath.slice(signaturePrefix.length);
1670
+
1671
+ // Build the path for the mocked return value
1672
+ // e.g., fromE5(priceE5).functionCallReturnValue.multiply(quantity)
1673
+ const returnValuePath = returnPath + suffix;
1674
+
1675
+ // Add to the mocked dependency's return value schema if not already present
1676
+ if (!(returnValuePath in depSchema.returnValueSchema)) {
1677
+ depSchema.returnValueSchema[returnValuePath] = sigType;
1678
+ }
1679
+ }
1680
+ }
1681
+ }
1682
+
1683
+ cleanSchema(depSchema.returnValueSchema, {
1684
+ stage: 'afterSignatureRequirementsMerge',
1685
+ dependency: dependency.name,
1686
+ });
957
1687
  }
958
1688
 
959
1689
  // Process the input dependencySchemas FIRST (before child dependentAnalyses).
@@ -994,7 +1724,45 @@ export default function mergeInDependentDataStructure({
994
1724
  // from the copied schema. Without this, method call paths on primitives like
995
1725
  // "projectSlug.replace(...)" would cause convertDotNotation to create nested
996
1726
  // object structures instead of preserving the primitive type.
997
- cleanSchema(depSchema.returnValueSchema);
1727
+ cleanSchema(depSchema.returnValueSchema, {
1728
+ stage: 'afterDependencySchemaCopy',
1729
+ filePath,
1730
+ dependency: name,
1731
+ });
1732
+ }
1733
+
1734
+ // TYPE REFINEMENT: Check if dependentAnalyses has a more specific type for this dependency.
1735
+ // When a parent passes `entity.filePath` (string | undefined) to a child component
1736
+ // that requires `filePath: string`, we should use the child's more specific type.
1737
+ // This prevents mock data from having undefined values for required props.
1738
+ //
1739
+ // This runs REGARDLESS of whether equivalencies already processed the schema,
1740
+ // because equivalencies copy the parent's type (string | undefined), not the child's
1741
+ // required type (string).
1742
+ const depSchema = findOrCreateDependentSchemas({ filePath, name });
1743
+ const childAnalysis = dependentAnalyses[filePath]?.[name];
1744
+ const childSignatureSchema =
1745
+ childAnalysis?.metadata?.mergedDataStructure?.signatureSchema;
1746
+
1747
+ if (childSignatureSchema) {
1748
+ for (const path in depSchema.signatureSchema) {
1749
+ const parentType = depSchema.signatureSchema[path];
1750
+ const childType = childSignatureSchema[path];
1751
+
1752
+ if (parentType && childType) {
1753
+ // Check if parent has optional type and child has required type
1754
+ const parentIsOptional =
1755
+ parentType.includes('| undefined') ||
1756
+ parentType.includes('| null');
1757
+ const childIsOptional =
1758
+ childType.includes('| undefined') || childType.includes('| null');
1759
+
1760
+ // If child requires a more specific type (not optional), use it
1761
+ if (parentIsOptional && !childIsOptional) {
1762
+ depSchema.signatureSchema[path] = childType;
1763
+ }
1764
+ }
1765
+ }
998
1766
  }
999
1767
 
1000
1768
  // For functions with multiple different type parameters, also create separate entries
@@ -1031,7 +1799,12 @@ export default function mergeInDependentDataStructure({
1031
1799
  srcSchema.returnValueSchema[path];
1032
1800
  }
1033
1801
  }
1034
- cleanSchema(variantSchema.returnValueSchema);
1802
+ cleanSchema(variantSchema.returnValueSchema, {
1803
+ stage: 'afterTypeVariantCopy',
1804
+ filePath,
1805
+ dependency: name,
1806
+ variant,
1807
+ });
1035
1808
  }
1036
1809
  }
1037
1810
  }
@@ -1095,8 +1868,8 @@ export default function mergeInDependentDataStructure({
1095
1868
  // Merge in the nested dependency schemas
1096
1869
  for (const path in nestedDepSchema.returnValueSchema) {
1097
1870
  if (!(path in targetDepSchema.returnValueSchema)) {
1098
- targetDepSchema.returnValueSchema[path] =
1099
- nestedDepSchema.returnValueSchema[path];
1871
+ const value = nestedDepSchema.returnValueSchema[path];
1872
+ targetDepSchema.returnValueSchema[path] = value;
1100
1873
  }
1101
1874
  }
1102
1875