@codeyam/codeyam-cli 0.1.0-staging.1669d45 → 0.1.0-staging.27d5a59

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 (898) 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 +26 -26
  4. package/analyzer-template/packages/ai/index.ts +16 -2
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +110 -52
  7. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  8. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +132 -12
  9. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +139 -23
  10. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  11. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +6 -126
  12. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +656 -28
  13. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  14. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +94 -7
  15. package/analyzer-template/packages/ai/src/lib/completionCall.ts +229 -64
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1358 -254
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +54 -3
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +124 -17
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +393 -97
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  32. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -0
  33. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  34. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  35. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  36. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1012 -7
  37. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +35 -6
  38. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +515 -6
  39. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  40. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +1540 -75
  41. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  42. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  43. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  44. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  45. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  46. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  47. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  48. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  49. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +44 -7
  50. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  51. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +179 -45
  52. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +26 -4
  53. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  54. package/analyzer-template/packages/analyze/index.ts +2 -0
  55. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  56. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  57. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  58. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  59. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  60. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  61. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  62. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  63. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  64. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  65. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  66. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +99 -22
  67. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +27 -4
  68. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  69. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  70. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  71. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  72. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  73. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  74. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +193 -76
  75. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
  76. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +352 -22
  77. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +118 -10
  78. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +667 -74
  79. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  80. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  81. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  82. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  83. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  84. package/analyzer-template/packages/aws/package.json +10 -10
  85. package/analyzer-template/packages/database/index.ts +1 -0
  86. package/analyzer-template/packages/database/package.json +4 -4
  87. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  88. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  89. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  90. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  91. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  92. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  93. package/analyzer-template/packages/database/src/lib/kysely/db.ts +22 -1
  94. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  95. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  96. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +62 -0
  97. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  98. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  99. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  100. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  101. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  102. package/analyzer-template/packages/database/src/lib/loadCommits.ts +58 -19
  103. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
  104. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  105. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  106. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  107. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  108. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  109. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +153 -144
  110. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  111. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  112. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  113. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  114. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  115. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  116. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  118. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  119. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  122. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  124. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  125. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  126. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  127. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  128. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  129. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  130. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  131. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  132. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  133. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +16 -1
  134. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  135. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  136. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  137. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  139. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +20 -0
  142. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  143. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
  144. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  145. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  146. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  147. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  148. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  149. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  150. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  151. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  152. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  153. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  154. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  155. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  156. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  157. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  158. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  159. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  160. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  161. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  162. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  163. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  164. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  165. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +45 -14
  166. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  167. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  168. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  169. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
  170. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  171. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  172. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  173. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  174. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  175. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  176. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  178. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  179. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  181. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  182. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  183. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  184. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  185. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -88
  186. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  187. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  188. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  189. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  190. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  191. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  192. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  193. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  194. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  195. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  196. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  197. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  198. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  199. package/analyzer-template/packages/github/dist/types/index.d.ts +1 -1
  200. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  201. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  202. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +25 -1
  203. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  204. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  205. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  206. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  207. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  208. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  209. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  210. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +56 -6
  211. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  212. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  213. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  214. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  215. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  216. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  217. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  218. package/analyzer-template/packages/github/package.json +2 -2
  219. package/analyzer-template/packages/types/index.ts +1 -0
  220. package/analyzer-template/packages/types/src/types/Analysis.ts +25 -0
  221. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  222. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  223. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  224. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +70 -6
  225. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  226. package/analyzer-template/packages/utils/dist/types/index.d.ts +1 -1
  227. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  228. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  229. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +25 -1
  230. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  231. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  232. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  233. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  234. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  235. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  236. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  237. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +56 -6
  238. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  239. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  240. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  241. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  242. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  243. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  244. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  245. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  246. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  247. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  248. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  249. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  250. package/analyzer-template/playwright/capture.ts +20 -8
  251. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  252. package/analyzer-template/playwright/captureStatic.ts +1 -1
  253. package/analyzer-template/project/analyzeBaselineCommit.ts +5 -0
  254. package/analyzer-template/project/analyzeRegularCommit.ts +5 -0
  255. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  256. package/analyzer-template/project/constructMockCode.ts +572 -87
  257. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  258. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  259. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  260. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  261. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  262. package/analyzer-template/project/orchestrateCapture.ts +75 -7
  263. package/analyzer-template/project/reconcileMockDataKeys.ts +158 -10
  264. package/analyzer-template/project/runAnalysis.ts +4 -0
  265. package/analyzer-template/project/start.ts +38 -11
  266. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  267. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  268. package/analyzer-template/project/writeMockDataTsx.ts +312 -10
  269. package/analyzer-template/project/writeScenarioComponents.ts +271 -37
  270. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  271. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  272. package/analyzer-template/tsconfig.json +13 -1
  273. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  274. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  275. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +5 -0
  276. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  277. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +5 -0
  278. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  279. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  280. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  281. package/background/src/lib/virtualized/project/constructMockCode.js +474 -48
  282. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  283. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  284. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  285. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  286. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  287. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  288. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  289. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  290. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  291. package/background/src/lib/virtualized/project/orchestrateCapture.js +62 -7
  292. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  293. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +133 -10
  294. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  295. package/background/src/lib/virtualized/project/runAnalysis.js +3 -0
  296. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  297. package/background/src/lib/virtualized/project/start.js +34 -11
  298. package/background/src/lib/virtualized/project/start.js.map +1 -1
  299. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  300. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  301. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  302. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  303. package/background/src/lib/virtualized/project/writeMockDataTsx.js +263 -6
  304. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  305. package/background/src/lib/virtualized/project/writeScenarioComponents.js +200 -35
  306. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  307. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  308. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  309. package/codeyam-cli/scripts/apply-setup.js +386 -9
  310. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  311. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  312. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  313. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  314. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  315. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  316. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  317. package/codeyam-cli/src/cli.js +35 -24
  318. package/codeyam-cli/src/cli.js.map +1 -1
  319. package/codeyam-cli/src/codeyam-cli.js +18 -2
  320. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  321. package/codeyam-cli/src/commands/analyze.js +21 -9
  322. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  323. package/codeyam-cli/src/commands/baseline.js +2 -0
  324. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  325. package/codeyam-cli/src/commands/debug.js +9 -5
  326. package/codeyam-cli/src/commands/debug.js.map +1 -1
  327. package/codeyam-cli/src/commands/default.js +37 -21
  328. package/codeyam-cli/src/commands/default.js.map +1 -1
  329. package/codeyam-cli/src/commands/editor.js +1982 -0
  330. package/codeyam-cli/src/commands/editor.js.map +1 -0
  331. package/codeyam-cli/src/commands/init.js +81 -260
  332. package/codeyam-cli/src/commands/init.js.map +1 -1
  333. package/codeyam-cli/src/commands/memory.js +278 -0
  334. package/codeyam-cli/src/commands/memory.js.map +1 -0
  335. package/codeyam-cli/src/commands/recapture.js +2 -0
  336. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  337. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  338. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  339. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  340. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  341. package/codeyam-cli/src/commands/test-startup.js +2 -0
  342. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  343. package/codeyam-cli/src/commands/verify.js +14 -2
  344. package/codeyam-cli/src/commands/verify.js.map +1 -1
  345. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +246 -0
  346. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  347. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +126 -0
  348. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  349. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +295 -0
  350. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  351. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  352. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  353. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +100 -0
  354. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  355. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +147 -0
  356. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  357. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +76 -0
  358. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  359. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  360. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  361. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  362. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  363. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  364. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  365. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  366. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  367. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  368. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  369. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +154 -82
  370. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  371. package/codeyam-cli/src/utils/analysisRunner.js +21 -2
  372. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  373. package/codeyam-cli/src/utils/analyzer.js +7 -0
  374. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  375. package/codeyam-cli/src/utils/backgroundServer.js +109 -22
  376. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  377. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  378. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  379. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  380. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  381. package/codeyam-cli/src/utils/editorAudit.js +82 -0
  382. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  383. package/codeyam-cli/src/utils/editorDevServer.js +98 -0
  384. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  385. package/codeyam-cli/src/utils/editorJournal.js +137 -0
  386. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  387. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  388. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  389. package/codeyam-cli/src/utils/editorPreloadHelpers.js +64 -0
  390. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  391. package/codeyam-cli/src/utils/editorPreview.js +66 -0
  392. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  393. package/codeyam-cli/src/utils/editorScenarios.js +56 -0
  394. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  395. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  396. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  397. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  398. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  399. package/codeyam-cli/src/utils/generateReport.js +2 -2
  400. package/codeyam-cli/src/utils/git.js +103 -0
  401. package/codeyam-cli/src/utils/git.js.map +1 -1
  402. package/codeyam-cli/src/utils/install-skills.js +120 -39
  403. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  404. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  405. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  406. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  407. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  408. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  409. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  410. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  411. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  412. package/codeyam-cli/src/utils/progress.js +7 -0
  413. package/codeyam-cli/src/utils/progress.js.map +1 -1
  414. package/codeyam-cli/src/utils/project.js +15 -5
  415. package/codeyam-cli/src/utils/project.js.map +1 -1
  416. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  417. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  418. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  419. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  420. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  421. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  422. package/codeyam-cli/src/utils/queue/job.js +75 -1
  423. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  424. package/codeyam-cli/src/utils/queue/manager.js +7 -0
  425. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  426. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  427. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  428. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  429. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  430. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  431. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  432. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  433. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  434. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  435. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  436. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  437. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  438. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  439. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  440. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  441. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  442. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  443. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  444. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  445. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  446. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  447. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  448. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  449. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  450. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  451. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  452. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  453. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  454. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  455. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  456. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  457. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  458. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  459. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  460. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  461. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  462. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  463. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  464. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  465. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  466. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  467. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  468. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  469. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  470. package/codeyam-cli/src/utils/rules/index.js +7 -0
  471. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  472. package/codeyam-cli/src/utils/rules/parser.js +93 -0
  473. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  474. package/codeyam-cli/src/utils/rules/pathMatcher.js +49 -0
  475. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  476. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  477. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  478. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  479. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  480. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  481. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  482. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  483. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  484. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  485. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  486. package/codeyam-cli/src/utils/serverState.js +64 -12
  487. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  488. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +61 -41
  489. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  490. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  491. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  492. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  493. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  494. package/codeyam-cli/src/utils/testRunner.js +158 -0
  495. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  496. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  497. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  498. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  499. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  500. package/codeyam-cli/src/utils/webappDetection.js +14 -2
  501. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  502. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  503. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  504. package/codeyam-cli/src/webserver/app/lib/database.js +63 -33
  505. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  506. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  507. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  508. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  509. package/codeyam-cli/src/webserver/bootstrap.js +51 -0
  510. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  511. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-DmJveP3T.js +1 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-C76mRRiF.js +11 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-COi5OvsN.js → EntityTypeBadge-g3saevPb.js} +1 -1
  514. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BwdQv49w.js → EntityTypeIcon-CobE682z.js} +1 -1
  515. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-D68KarMg.js → InteractivePreview-DYFW3lDD.js} +3 -3
  517. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-L75Wvqgw.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  518. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-C53WM8qn.js → LoadingDots-BU_OAEMP.js} +1 -1
  519. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CrNkmy4i.js → LogViewer-ceAyBX-H.js} +1 -1
  520. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-djPLI-WV.js +11 -0
  521. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CQifa1n-.js → SafeScreenshot-BED4B6sP.js} +1 -1
  522. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-CyaBFX7l.js → ScenarioViewer-B76aig_2.js} +3 -13
  523. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  524. package/codeyam-cli/src/webserver/build/client/assets/Terminal-nZNBALox.js +41 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-D36O1rzU.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  526. package/codeyam-cli/src/webserver/build/client/assets/_index-C96V0n15.js +11 -0
  527. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BpKzcsJz.js +27 -0
  528. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +1 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-D9hemwl6.js +22 -0
  531. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  536. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  538. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  540. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  543. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  544. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  545. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  546. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  547. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  548. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  549. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  550. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  551. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  552. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  553. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  554. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  555. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  556. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  558. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  559. package/codeyam-cli/src/webserver/build/client/assets/book-open-D_nMCFmP.js +6 -0
  560. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-DgTPh8H-.js → chevron-down-BH2h1Ea2.js} +1 -1
  561. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-DdQKK6on.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  562. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-Dmr2bb1R.js → circle-check-DyIKORY6.js} +1 -1
  563. package/codeyam-cli/src/webserver/build/client/assets/copy-NDbZjXao.js +11 -0
  564. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-Do4ZLUYa.js → createLucideIcon-CMT1jU2q.js} +1 -1
  565. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +1 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/editor-B2KwhQph.js +8 -0
  567. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CbdFyxZh.js → entity._sha._-CrjR3zZW.js} +12 -12
  568. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-DjACbfdI.js +6 -0
  569. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.js +6 -0
  570. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  571. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMbl7MeQ.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  572. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-5wRKRIH9.js → entry.client-DTvKq3TY.js} +1 -1
  573. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DD3SDH7t.js → fileTableUtils-cPo8LiG3.js} +1 -1
  574. package/codeyam-cli/src/webserver/build/client/assets/files-DO4CZ16O.js +1 -0
  575. package/codeyam-cli/src/webserver/build/client/assets/{git-zXjT7J0G.js → git-CFCTYk9I.js} +8 -8
  576. package/codeyam-cli/src/webserver/build/client/assets/globals-B17TBSS6.css +1 -0
  577. package/codeyam-cli/src/webserver/build/client/assets/{index-DLbXwndH.js → index-10oVnAAH.js} +1 -1
  578. package/codeyam-cli/src/webserver/build/client/assets/{index-gPZ-lad1.js → index-BcvgDzbZ.js} +1 -1
  579. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  580. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BsPXJ81F.js → loader-circle-BAXYRVEO.js} +1 -1
  581. package/codeyam-cli/src/webserver/build/client/assets/manifest-af20abcd.js +1 -0
  582. package/codeyam-cli/src/webserver/build/client/assets/memory-Dg0mvYrI.js +96 -0
  583. package/codeyam-cli/src/webserver/build/client/assets/pause-DTAcYxBt.js +11 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/root-DUKqhFlb.js +67 -0
  585. package/codeyam-cli/src/webserver/build/client/assets/{search-P2FKIUql.js → search-fKo7v0Zo.js} +1 -1
  586. package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +1 -0
  587. package/codeyam-cli/src/webserver/build/client/assets/{simulations-L18M6-kN.js → simulations-B3aOzpCZ.js} +1 -1
  588. package/codeyam-cli/src/webserver/build/client/assets/terminal-BG4heKCG.js +11 -0
  589. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BDz7kbVA.js → triangle-alert-DtSmdtM4.js} +1 -1
  590. package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-29dDmbH8.js → useCustomSizes-ByhSyh0W.js} +1 -1
  591. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  592. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-CkIOKTrZ.js → useReportContext-O-jkvSPx.js} +1 -1
  593. package/codeyam-cli/src/webserver/build/client/assets/{useToast-KKw5kTn-.js → useToast-9FIWuYfK.js} +1 -1
  594. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  595. package/codeyam-cli/src/webserver/build/server/assets/index-D_kZbNJs.js +1 -0
  596. package/codeyam-cli/src/webserver/build/server/assets/server-build-CWy5OIH9.js +366 -0
  597. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  598. package/codeyam-cli/src/webserver/build-info.json +5 -5
  599. package/codeyam-cli/src/webserver/devServer.js +39 -5
  600. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  601. package/codeyam-cli/src/webserver/editorProxy.js +440 -0
  602. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  603. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +175 -0
  604. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +140 -0
  605. package/codeyam-cli/src/webserver/server.js +226 -1
  606. package/codeyam-cli/src/webserver/server.js.map +1 -1
  607. package/codeyam-cli/src/webserver/terminalServer.js +698 -0
  608. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  609. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  610. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  611. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  612. package/codeyam-cli/templates/editor-step-hook.py +147 -0
  613. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  614. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  615. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  616. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  617. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  618. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  619. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  620. package/codeyam-cli/templates/nextjs-prisma-sqlite/PRISMA_SETUP.md +84 -0
  621. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  622. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  623. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  624. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +19 -0
  625. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  626. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  627. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +43 -0
  628. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  629. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +35 -0
  630. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  631. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  632. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +37 -0
  633. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  634. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  635. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  636. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  637. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  638. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  639. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  640. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  641. package/codeyam-cli/templates/rules-instructions.md +78 -0
  642. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +48 -4
  643. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  644. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +69 -0
  645. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  646. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  647. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  648. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  649. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  650. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  651. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  652. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  653. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  654. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  655. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  656. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  657. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  658. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  659. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  660. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  661. package/package.json +27 -22
  662. package/packages/ai/index.js +7 -3
  663. package/packages/ai/index.js.map +1 -1
  664. package/packages/ai/src/lib/analyzeScope.js +91 -30
  665. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  666. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  667. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  668. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +100 -12
  669. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  670. package/packages/ai/src/lib/astScopes/methodSemantics.js +109 -23
  671. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  672. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  673. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  674. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +1 -102
  675. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  676. package/packages/ai/src/lib/astScopes/processExpression.js +518 -28
  677. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  678. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  679. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  680. package/packages/ai/src/lib/completionCall.js +171 -37
  681. package/packages/ai/src/lib/completionCall.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1082 -174
  683. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  684. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  685. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  686. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
  687. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  688. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
  689. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  690. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  691. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  692. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  693. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  694. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +52 -3
  695. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  696. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +106 -13
  697. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  698. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  699. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  700. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  701. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  702. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  703. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  704. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  705. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  706. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  707. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  708. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +333 -86
  709. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  710. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  711. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  712. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  713. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  714. package/packages/ai/src/lib/dataStructureChunking.js +130 -0
  715. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  716. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  717. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  718. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  719. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  720. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  721. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  722. package/packages/ai/src/lib/generateEntityScenarioData.js +789 -8
  723. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  724. package/packages/ai/src/lib/generateEntityScenarios.js +26 -2
  725. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  726. package/packages/ai/src/lib/generateExecutionFlows.js +376 -4
  727. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  728. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1124 -59
  729. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  730. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  731. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  732. package/packages/ai/src/lib/isolateScopes.js +39 -3
  733. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  734. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  735. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  736. package/packages/ai/src/lib/mergeStatements.js +70 -51
  737. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  738. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  739. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  740. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  741. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  742. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  743. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  744. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +30 -7
  745. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  746. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  747. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  748. package/packages/ai/src/lib/resolvePathToControllable.js +155 -41
  749. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  750. package/packages/ai/src/lib/worker/SerializableDataStructure.js +7 -0
  751. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  752. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  753. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  754. package/packages/analyze/index.js +1 -0
  755. package/packages/analyze/index.js.map +1 -1
  756. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  757. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  758. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  759. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  760. package/packages/analyze/src/lib/analysisContext.js +30 -5
  761. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  762. package/packages/analyze/src/lib/asts/index.js +4 -2
  763. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  764. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  765. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  766. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  767. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  768. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  769. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  770. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  771. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  772. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  773. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  774. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  775. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  776. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  777. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  778. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +72 -10
  779. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  780. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +24 -4
  781. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  782. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  783. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  784. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  785. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  786. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  787. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  788. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  789. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  790. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  791. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  792. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  793. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  794. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +164 -68
  795. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  796. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
  797. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  798. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +250 -20
  799. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  800. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +57 -9
  801. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  802. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +558 -55
  803. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  804. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  805. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  806. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  807. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  808. package/packages/analyze/src/lib/index.js +1 -0
  809. package/packages/analyze/src/lib/index.js.map +1 -1
  810. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  811. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  812. package/packages/database/index.js +1 -0
  813. package/packages/database/index.js.map +1 -1
  814. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  815. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  816. package/packages/database/src/lib/analysisToDb.js +1 -1
  817. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  818. package/packages/database/src/lib/branchToDb.js +1 -1
  819. package/packages/database/src/lib/branchToDb.js.map +1 -1
  820. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  821. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  822. package/packages/database/src/lib/commitToDb.js +1 -1
  823. package/packages/database/src/lib/commitToDb.js.map +1 -1
  824. package/packages/database/src/lib/fileToDb.js +1 -1
  825. package/packages/database/src/lib/fileToDb.js.map +1 -1
  826. package/packages/database/src/lib/kysely/db.js +16 -1
  827. package/packages/database/src/lib/kysely/db.js.map +1 -1
  828. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  829. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  830. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
  831. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  832. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  833. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  834. package/packages/database/src/lib/loadAnalyses.js +45 -2
  835. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  836. package/packages/database/src/lib/loadAnalysis.js +8 -0
  837. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  838. package/packages/database/src/lib/loadBranch.js +11 -1
  839. package/packages/database/src/lib/loadBranch.js.map +1 -1
  840. package/packages/database/src/lib/loadCommit.js +7 -0
  841. package/packages/database/src/lib/loadCommit.js.map +1 -1
  842. package/packages/database/src/lib/loadCommits.js +45 -14
  843. package/packages/database/src/lib/loadCommits.js.map +1 -1
  844. package/packages/database/src/lib/loadEntities.js +23 -4
  845. package/packages/database/src/lib/loadEntities.js.map +1 -1
  846. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  847. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  848. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  849. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  850. package/packages/database/src/lib/projectToDb.js +1 -1
  851. package/packages/database/src/lib/projectToDb.js.map +1 -1
  852. package/packages/database/src/lib/saveFiles.js +1 -1
  853. package/packages/database/src/lib/saveFiles.js.map +1 -1
  854. package/packages/database/src/lib/scenarioToDb.js +1 -1
  855. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  856. package/packages/database/src/lib/updateCommitMetadata.js +100 -88
  857. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  858. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  859. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  860. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  861. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  862. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  863. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  864. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  865. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  866. package/packages/types/index.js.map +1 -1
  867. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  868. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  869. package/packages/utils/src/lib/safeFileName.js +29 -3
  870. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  871. package/scripts/npm-post-install.cjs +34 -0
  872. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  873. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  874. package/codeyam-cli/src/commands/list.js +0 -31
  875. package/codeyam-cli/src/commands/list.js.map +0 -1
  876. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  877. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  878. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  879. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  880. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-vauWK972.js +0 -1
  881. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CEleMv_j.js +0 -34
  882. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DzJRkCkr.js +0 -11
  883. package/codeyam-cli/src/webserver/build/client/assets/_index-Be83mo_j.js +0 -11
  884. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BN6wu6Y-.js +0 -37
  885. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Bn6aCAy_.js +0 -1
  886. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-B4iCfs5M.js +0 -6
  887. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-wDWZZO1W.js +0 -6
  888. package/codeyam-cli/src/webserver/build/client/assets/files-DKyMFI90.js +0 -1
  889. package/codeyam-cli/src/webserver/build/client/assets/globals-DTTQ3gY7.css +0 -1
  890. package/codeyam-cli/src/webserver/build/client/assets/manifest-22590fcf.js +0 -1
  891. package/codeyam-cli/src/webserver/build/client/assets/root-BsAarjAM.js +0 -57
  892. package/codeyam-cli/src/webserver/build/client/assets/settings-B2eDuBj8.js +0 -1
  893. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-BUm0UVJm.js +0 -2
  894. package/codeyam-cli/src/webserver/build/server/assets/index-BND5I5fv.js +0 -1
  895. package/codeyam-cli/src/webserver/build/server/assets/server-build-CFXnd7MG.js +0 -228
  896. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  897. package/codeyam-cli/templates/codeyam:diagnose.md +0 -625
  898. package/scripts/finalize-analyzer.cjs +0 -81
@@ -685,8 +685,17 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
685
685
  // e.g., useFetcher() -> useFetcher_reportFetcher()
686
686
  // Escape special regex characters in the call signature
687
687
  const escapedCallSignature = callSignature.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
688
- // Create regex that matches the call (with optional whitespace variations)
689
- const callRegex = new RegExp(escapedCallSignature.replace(/\s+/g, '\\s*'), 'g');
688
+ // Create regex that matches the call (with optional whitespace variations).
689
+ // TypeScript formatters commonly break type parameters across lines, e.g.:
690
+ // useLoaderData<
691
+ // typeof loader
692
+ // >()
693
+ // So we allow optional whitespace around < and > delimiters, not just
694
+ // where whitespace already exists in the call signature string.
695
+ const callRegex = new RegExp(escapedCallSignature
696
+ .replace(/\s+/g, '\\s*')
697
+ .replace(/</g, '\\s*<\\s*')
698
+ .replace(/>/g, '\\s*>\\s*'), 'gs');
690
699
  fileContent = fileContent.replace(callRegex, `${mockFunctionName}()`);
691
700
  }
692
701
  }
@@ -704,15 +713,28 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
704
713
  // For single variable assignments, use the call signature directly from dataForMocks
705
714
  const dataForMocks = rootAnalysis.metadata?.scenariosDataStructure?.dataForMocks;
706
715
  // Find matching call signature key in dataForMocks
716
+ // IMPORTANT: First try exact match with type parameters (e.g., "useLoaderData<LoaderData>()")
717
+ // to avoid picking the wrong variant (e.g., "useLoaderData<typeof loader>()" which may
718
+ // have different properties). Fall back to base name matching only if exact match fails.
707
719
  const hookBaseName = importedExport.name.split(/[<(]/)[0];
708
- const callSignatureKey = dataForMocks
709
- ? Object.keys(dataForMocks).find((key) => {
710
- // Split on ., <, or ( to get the true base name
711
- // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
712
- const keyBaseName = key.split(/[.<(]/)[0];
713
- return keyBaseName === hookBaseName;
714
- })
715
- : undefined;
720
+ const expectedKey = importedExport.calls?.[0];
721
+ let callSignatureKey;
722
+ if (dataForMocks) {
723
+ const keys = Object.keys(dataForMocks);
724
+ // First try exact match with the expected call signature
725
+ if (expectedKey && keys.includes(expectedKey)) {
726
+ callSignatureKey = expectedKey;
727
+ }
728
+ else {
729
+ // Fall back to base name matching
730
+ callSignatureKey = keys.find((key) => {
731
+ // Split on ., <, or ( to get the true base name
732
+ // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
733
+ const keyBaseName = key.split(/[.<(]/)[0];
734
+ return keyBaseName === hookBaseName;
735
+ });
736
+ }
737
+ }
716
738
  // Use the call signature if found, otherwise construct it
717
739
  const dataKey = callSignatureKey ??
718
740
  importedExport.calls?.[0] ??
@@ -721,10 +743,15 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
721
743
  // use the base name (e.g., "trpc") when calling constructMockCode. This ensures
722
744
  // constructMockCode generates a complete nested mock from the schema without
723
745
  // referencing __cyOriginal variables.
746
+ // NOTE: Only check for dots BEFORE the first open paren. Function calls with
747
+ // dotted arguments like "getSurveyWithMetadata(params.surveyId)" have dots
748
+ // INSIDE parens — these are NOT method chains and should keep the full signature.
724
749
  const dataKeyBaseName = dataKey.split(/[.<(]/)[0];
750
+ const firstParenIndex = dataKey.indexOf('(');
751
+ const partBeforeFirstParen = firstParenIndex >= 0 ? dataKey.substring(0, firstParenIndex) : dataKey;
725
752
  const isMethodChainDataKey = dataKeyBaseName === importedExport.name &&
726
753
  dataKey !== importedExport.name &&
727
- dataKey.includes('.');
754
+ partBeforeFirstParen.includes('.');
728
755
  const mockNameToUse = isMethodChainDataKey
729
756
  ? importedExport.name
730
757
  : dataKey;
@@ -741,18 +768,34 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
741
768
  // IMPORTANT: We inline scenarios().data() inside the function rather than
742
769
  // storing in a const - see comment in constructMockCode.ts for why.
743
770
  if (!mockCode) {
744
- mockCode = `function ${importedExport.name}(...args) {
745
- return scenarios().data()?.["${dataKey}"];
771
+ mockCode = `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)
772
+ const _${importedExport.name}Ref = {
773
+ current: null,
774
+ };
775
+ function ${importedExport.name}(...args) {
776
+ if (!_${importedExport.name}Ref.current) {
777
+ _${importedExport.name}Ref.current = scenarios().data()?.["${dataKey}"];
778
+ }
779
+ return _${importedExport.name}Ref.current;
746
780
  }`;
747
781
  }
748
782
  }
749
783
  else {
750
784
  // Helper to find matching call signature key from dataForMocks
785
+ // IMPORTANT: First try exact match with type parameters (e.g., "useLoaderData<LoaderData>()")
786
+ // to avoid picking the wrong variant. Fall back to base name matching only if needed.
751
787
  const hookBaseName = importedExport.name.split(/[<(]/)[0];
788
+ const expectedKey = importedExport.calls?.[0];
752
789
  const findMatchingKey = (dataForMocks) => {
753
790
  if (!dataForMocks)
754
791
  return undefined;
755
- return Object.keys(dataForMocks).find((key) => {
792
+ const keys = Object.keys(dataForMocks);
793
+ // First try exact match with the expected call signature
794
+ if (expectedKey && keys.includes(expectedKey)) {
795
+ return expectedKey;
796
+ }
797
+ // Fall back to base name matching
798
+ return keys.find((key) => {
756
799
  // Split on ., <, or ( to get the true base name
757
800
  // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
758
801
  const keyBaseName = key.split(/[.<(]/)[0];
@@ -778,11 +821,18 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
778
821
  // referencing __cyOriginal variables. The __cyOriginal pattern is only needed
779
822
  // for partial mocking where we preserve some original methods, not for complete
780
823
  // method-chain mocks where we provide all implementations.
824
+ // NOTE: Only check for dots BEFORE the first open paren. Function calls with
825
+ // dotted arguments like "getSurveyWithMetadata(params.surveyId)" have dots
826
+ // INSIDE parens — these are NOT method chains and should keep the full signature.
781
827
  const dataKeyBaseName = dataKey?.split(/[.<(]/)[0];
828
+ const elseFirstParenIndex = dataKey?.indexOf('(') ?? -1;
829
+ const elsePartBeforeFirstParen = dataKey && elseFirstParenIndex >= 0
830
+ ? dataKey.substring(0, elseFirstParenIndex)
831
+ : dataKey;
782
832
  const isMethodChainDataKey = dataKey &&
783
833
  dataKeyBaseName === importedExport.name &&
784
834
  dataKey !== importedExport.name &&
785
- dataKey.includes('.');
835
+ (elsePartBeforeFirstParen?.includes('.') ?? false);
786
836
  const mockNameToUse = isMethodChainDataKey
787
837
  ? importedExport.name
788
838
  : (dataKey ?? importedExport.calls?.[0] ?? `${importedExport.name}()`);
@@ -796,8 +846,15 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
796
846
  // IMPORTANT: We inline scenarios().data() inside the function rather than
797
847
  // storing in a const - see comment in constructMockCode.ts for why.
798
848
  if (!mockCode && dataKey) {
799
- mockCode = `function ${importedExport.name}(...args) {
800
- return scenarios().data()?.["${dataKey}"];
849
+ mockCode = `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)
850
+ const _${importedExport.name}Ref = {
851
+ current: null,
852
+ };
853
+ function ${importedExport.name}(...args) {
854
+ if (!_${importedExport.name}Ref.current) {
855
+ _${importedExport.name}Ref.current = scenarios().data()?.["${dataKey}"];
856
+ }
857
+ return _${importedExport.name}Ref.current;
801
858
  }`;
802
859
  }
803
860
  }
@@ -847,6 +904,14 @@ function addMockToContent(fileContent, importedExport, fileAnalyses, rootAnalysi
847
904
  else {
848
905
  fileContent = fileContent.replace(importRegExp, '$1$2');
849
906
  }
907
+ // Also handle namespace imports (import * as foo from '...')
908
+ // These need to be renamed to foo__cyOriginal when the mock code spreads from the original.
909
+ // Note: We match any path (not just escapedImportPath) because the import path may have
910
+ // been rewritten by transitive import handling before this code runs.
911
+ if (shouldRenameToOriginal) {
912
+ const namespaceImportRegExp = new RegExp(`(import\\s+\\*\\s+as\\s+)${escapeRegExp(firstPart)}(\\s+from\\s+['"][^'"]*['"])`, 'm');
913
+ fileContent = fileContent.replace(namespaceImportRegExp, `$1${firstPart}__cyOriginal$2`);
914
+ }
850
915
  // Remove empty imports entirely to avoid partial commenting issues with multiline imports
851
916
  // This handles both single-line and multiline empty imports
852
917
  fileContent = fileContent.replace(/import\s*\{\s*\}\s*from\s+['"][^'"]*['"];?\s*\n?/g, '');
@@ -1205,9 +1270,12 @@ export default async function writeScenarioComponents({ project, file, entity, r
1205
1270
  fileContentLength: fileContent.length,
1206
1271
  });
1207
1272
  let importedExportIndex = 0;
1273
+ const loopStartTime = Date.now();
1274
+ console.log(`[WriteScenario] Starting import loop for ${entity.name}: ${sortedImportedExports.length} imports`);
1208
1275
  for (const importedExport of sortedImportedExports) {
1209
1276
  importedExportIndex++;
1210
1277
  if (importedExportIndex % 5 === 0 || importedExportIndex === 1) {
1278
+ console.log(`[WriteScenario] ${entity.name} import ${importedExportIndex}/${sortedImportedExports.length}: ${importedExport.name} elapsed=${Date.now() - loopStartTime}ms`);
1211
1279
  debugLog(`Processing importedExport ${importedExportIndex}/${sortedImportedExports.length}`, {
1212
1280
  name: importedExport.name,
1213
1281
  filePath: importedExport.filePath,
@@ -1313,6 +1381,12 @@ export default async function writeScenarioComponents({ project, file, entity, r
1313
1381
  // Strip server-only imports - these break when imported by client components
1314
1382
  dataFileContent = stripServerOnlyImport(dataFileContent);
1315
1383
  dataFileContent = applyServerOnlyMocks(dataFileContent);
1384
+ // Process transitive imports: if the data entity file imports from files
1385
+ // that have `import "server-only"`, rewrite those imports to transitive
1386
+ // copies with server-only stripped. Without this, data entity files that
1387
+ // end up in a client bundle (e.g., via a stripped "use server" boundary)
1388
+ // would pull in server-only code and cause build failures.
1389
+ dataFileContent = await processTransitiveImportsRecursively(dataFileContent, fileNotMocked.path, dataScenarioPath);
1316
1390
  // Write the transformed data entity file
1317
1391
  await writeFile(dataScenarioPath, dataFileContent);
1318
1392
  scenarioComponentPaths.push(dataScenarioPath);
@@ -1329,9 +1403,9 @@ export default async function writeScenarioComponents({ project, file, entity, r
1329
1403
  writtenScenarioComponents[importedExportFilePath] = [];
1330
1404
  }
1331
1405
  writtenScenarioComponents[importedExportFilePath].push(importedExport.name);
1332
- // Don't recurse - data entities don't need their dependencies processed
1333
- // The import rewriting will happen later in this same loop iteration
1334
- // (at lines ~1590-1702) to point imports to this transformed file
1406
+ // Don't recurse into full writeScenarioComponents - data entities don't
1407
+ // need mock generation for their dependencies. Transitive server-only
1408
+ // import processing is already handled above via processTransitiveImportsRecursively.
1335
1409
  }
1336
1410
  else {
1337
1411
  // For visual/library entities, recurse to process their dependencies
@@ -1340,6 +1414,8 @@ export default async function writeScenarioComponents({ project, file, entity, r
1340
1414
  // e.g., if file has `export default X` but parent does `import { X } from '...'`
1341
1415
  const needsNamedReExport = importedExport.resolvedIsDefault === true &&
1342
1416
  importedExport.isDefault === false;
1417
+ console.log(`[WriteScenario] RECURSE START: ${entity.name} -> ${importedExportEntity.name}`);
1418
+ const recurseStartTime = Date.now();
1343
1419
  debugLog(`Recursing into writeScenarioComponents for ${importedExportEntity.name}`, {
1344
1420
  entityName: importedExportEntity.name,
1345
1421
  filePath: fileNotMocked.path,
@@ -1362,7 +1438,8 @@ export default async function writeScenarioComponents({ project, file, entity, r
1362
1438
  exportAsNamed: needsNamedReExport
1363
1439
  ? importedExport.name
1364
1440
  : undefined,
1365
- }), 60000);
1441
+ }), 180000);
1442
+ console.log(`[WriteScenario] RECURSE END: ${entity.name} -> ${importedExportEntity.name} took ${Date.now() - recurseStartTime}ms`);
1366
1443
  debugLog(`Completed recursive writeScenarioComponents for ${importedExportEntity.name}`);
1367
1444
  writtenScenarioComponents = updatedWrittenScenarioComponents;
1368
1445
  scenarioComponentPaths.push(...newScenarioComponentPaths);
@@ -1381,13 +1458,22 @@ export default async function writeScenarioComponents({ project, file, entity, r
1381
1458
  // Data and type entities should be preserved - they're not callable and may have methods
1382
1459
  // that stubbing would break (e.g., Zod schemas with .superRefine())
1383
1460
  const isDataEntity = entityType === 'data' || entityType === 'type';
1384
- // Heuristic: Zod schemas are often misclassified as 'library' but should be preserved
1385
- // Detect by: name starts with Z + uppercase letter, AND has Zod method calls
1386
- const looksLikeZodSchema = entityType === 'library' &&
1387
- /^Z[A-Z]/.test(importedExport.name) &&
1388
- importedExport.calls?.some((call) => /\.(superRefine|refine|transform|default|optional|nullable|array|object|string|number|boolean|parse|safeParse)\s*\(/.test(call));
1389
- // Callable entities can be safely stubbed (but not Zod schemas)
1390
- const isCallable = !isDataEntity && !looksLikeZodSchema && entityType !== undefined;
1461
+ // If calls data shows the entity is only accessed via properties/methods
1462
+ // (e.g., formValidator.validate(), schema.superRefine()) and never directly
1463
+ // invoked (e.g., getInitialProps()), it's used as an object and should be
1464
+ // preserved rather than replaced with a Proxy stub.
1465
+ const onlyPropertyAccessed = importedExport.calls?.length > 0 &&
1466
+ !importedExport.calls.some((call) => {
1467
+ const afterName = call.slice(importedExport.name.length);
1468
+ return afterName.startsWith('(') || afterName.startsWith('<');
1469
+ });
1470
+ // Callable entities can be safely stubbed. Entities that are only
1471
+ // property-accessed should be preserved (their methods need to work).
1472
+ // 'other' entities are unknown types — safer to preserve than stub.
1473
+ const isCallable = !isDataEntity &&
1474
+ !onlyPropertyAccessed &&
1475
+ entityType !== undefined &&
1476
+ entityType !== 'other';
1391
1477
  // Determine what action to take
1392
1478
  const shouldStripAndReplace = hasMock;
1393
1479
  const shouldStripAndStub = !hasMock && importedExport.isMocked && isCallable;
@@ -1624,6 +1710,9 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1624
1710
  }
1625
1711
  }
1626
1712
  }
1713
+ // Track post-import-loop timing
1714
+ const postLoopStartTime = Date.now();
1715
+ console.log(`[WriteScenario] POST-LOOP START: ${entity.name}`);
1627
1716
  // Collect universal mocks BEFORE processing nodeModuleImports
1628
1717
  // This is needed to check if a node module import is handled by a universal mock
1629
1718
  const universalMocks = project.metadata?.universalMocks ?? [];
@@ -1657,6 +1746,7 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1657
1746
  const importRegex = new RegExp(`(import\\s+(?:\\{[^}]*\\}|\\*\\s+as\\s+\\w+|\\w+)\\s+from\\s+)['"]${originalPath.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')}['"]`, 'g');
1658
1747
  fileContent = fileContent.replace(importRegex, `$1'${mockFileRelativePath}'`);
1659
1748
  }
1749
+ console.log(`[WriteScenario] POST-LOOP ${entity.name}: node+universal mocks took ${Date.now() - postLoopStartTime}ms`);
1660
1750
  if (rootAnalysis.entitySha === entity.sha &&
1661
1751
  entity.metadata?.notExported &&
1662
1752
  entity.name !== 'default') {
@@ -1716,6 +1806,7 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1716
1806
  debugLog('Starting rewriteRelativeModuleImports');
1717
1807
  fileContent = rewriteRelativeModuleImports(fileContent, `${PROJECT_RELATIVE_PATH}/${file.path}`, scenarioComponentPath);
1718
1808
  debugLog('Completed rewriteRelativeModuleImports');
1809
+ console.log(`[WriteScenario] POST-LOOP ${entity.name}: transformations took ${Date.now() - postLoopStartTime}ms`);
1719
1810
  /**
1720
1811
  * Recursively process a file's imports to create transitive copies with server-only stripped.
1721
1812
  * This handles chains of arbitrary depth: A -> B -> C -> D where each needs server-only removed.
@@ -1729,12 +1820,14 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1729
1820
  */
1730
1821
  async function processTransitiveImportsRecursively(content, sourceFilePath, targetFilePath, visitedPaths = new Set(), depth = 0, startTime = Date.now()) {
1731
1822
  // Global timeout for entire transitive processing
1732
- const GLOBAL_TIMEOUT_MS = 60000; // 1 minute max for all transitive processing
1823
+ const GLOBAL_TIMEOUT_MS = 180000; // 3 minutes max for all transitive processing (complex components need more time)
1733
1824
  const elapsed = Date.now() - startTime;
1734
1825
  if (elapsed > GLOBAL_TIMEOUT_MS) {
1735
1826
  throw new Error(`processTransitiveImportsRecursively exceeded ${GLOBAL_TIMEOUT_MS}ms (elapsed: ${elapsed}ms) at depth=${depth} for ${sourceFilePath}`);
1736
1827
  }
1737
1828
  const importPaths = extractInternalImportPaths(content);
1829
+ // Always log to help debug timeout issues
1830
+ console.log(`[TransitiveImports] depth=${depth} file=${path.basename(sourceFilePath)} imports=${importPaths.length} visited=${visitedPaths.size} elapsed=${Date.now() - startTime}ms`);
1738
1831
  debugLog(`processTransitiveImportsRecursively depth=${depth}`, {
1739
1832
  sourceFilePath,
1740
1833
  importCount: importPaths.length,
@@ -1771,8 +1864,10 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1771
1864
  const basePath = safeFolder(importFile.path.split('/').slice(0, -1).join('/'));
1772
1865
  const extension = importFile.name.split('.').pop();
1773
1866
  const isIndex = isIndexPath(importFile.path);
1774
- const pathHash = safeFileName(importFile.path);
1775
- const transitiveFilePath = `${PROJECT_RELATIVE_PATH}/${basePath}/${pathHash}_${isIndex ? 'index_' : ''}transitive_${safeFileName(scenario.name)}.${extension}`;
1867
+ // Limit pathHash length to prevent ENAMETOOLONG errors on macOS (255 char limit)
1868
+ const pathHash = safeFileName(importFile.path, { maxLength: 80 });
1869
+ const scenarioSlug = safeFileName(scenario.name, { maxLength: 60 });
1870
+ const transitiveFilePath = `${PROJECT_RELATIVE_PATH}/${basePath}/${pathHash}_${isIndex ? 'index_' : ''}transitive_${scenarioSlug}.${extension}`;
1776
1871
  // Check if this is a circular import (we're already processing this file)
1777
1872
  const isCircularImport = visitedPaths.has(resolvedPath);
1778
1873
  // Check if already processed
@@ -1850,6 +1945,7 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1850
1945
  debugLog(`Returning from processTransitiveImportsRecursively depth=${depth}`);
1851
1946
  return modifiedContent;
1852
1947
  }
1948
+ console.log(`[WriteScenario] POST-LOOP ${entity.name}: before remaining imports ${Date.now() - postLoopStartTime}ms`);
1853
1949
  // Process remaining internal imports that weren't in importedExports
1854
1950
  // This handles transitive dependencies: when the file content includes code (e.g., from
1855
1951
  // other functions in the same file) that imports from files with "server-only"
@@ -1869,6 +1965,16 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1869
1965
  for (const importPath of remainingImportPaths) {
1870
1966
  remainingImportIndex++;
1871
1967
  debugLog(`[REMAINING LOOP] import ${remainingImportIndex}/${remainingImportPaths.length}: ${importPath}`);
1968
+ // Skip imports that point to generated CodeYam files (same skip logic as
1969
+ // rewriteRelativeModuleImports). Without this, MockData files from earlier
1970
+ // captures that get discovered by the TypeScript compiler would be treated as
1971
+ // regular imports, creating transitive copies with stale content.
1972
+ const scenarioFilePattern = /[a-f0-9]{64}_\w+_[A-Z]\w*$/;
1973
+ const mockDataPattern = /__codeyamMocks__\//;
1974
+ if (scenarioFilePattern.test(importPath) ||
1975
+ mockDataPattern.test(importPath)) {
1976
+ continue;
1977
+ }
1872
1978
  // Resolve the import path to a project file path
1873
1979
  const resolvedFilePath = resolveImportPath(importPath, file.path, project);
1874
1980
  if (!resolvedFilePath) {
@@ -1907,8 +2013,10 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1907
2013
  const targetFileBasePath = safeFolder(targetFile.path.split('/').slice(0, -1).join('/'));
1908
2014
  const targetFileExtension = targetFile.name.split('.').pop();
1909
2015
  const targetFileIsIndex = isIndexPath(targetFile.path);
1910
- const filePathHash = safeFileName(targetFile.path);
1911
- const transformedFilePath = `${PROJECT_RELATIVE_PATH}/${targetFileBasePath}/${filePathHash}_${targetFileIsIndex ? 'index_' : ''}transitive_${safeFileName(scenario.name)}.${targetFileExtension}`;
2016
+ // Limit path hash length to prevent ENAMETOOLONG errors
2017
+ const filePathHash = safeFileName(targetFile.path, { maxLength: 80 });
2018
+ const targetScenarioSlug = safeFileName(scenario.name, { maxLength: 60 });
2019
+ const transformedFilePath = `${PROJECT_RELATIVE_PATH}/${targetFileBasePath}/${filePathHash}_${targetFileIsIndex ? 'index_' : ''}transitive_${targetScenarioSlug}.${targetFileExtension}`;
1912
2020
  // Check if we've already processed this file as a transitive copy
1913
2021
  // Note: __data_file_written__ is for entity-specific scenario files with different naming,
1914
2022
  // but we still need transitive copies for server-only stripping. Data entity files may
@@ -1947,8 +2055,12 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
1947
2055
  const nestedBasePath = safeFolder(nestedFile.path.split('/').slice(0, -1).join('/'));
1948
2056
  const nestedExtension = nestedFile.name.split('.').pop();
1949
2057
  const nestedIsIndex = isIndexPath(nestedFile.path);
1950
- const nestedPathHash = safeFileName(nestedFile.path);
1951
- const nestedTransformedPath = `${PROJECT_RELATIVE_PATH}/${nestedBasePath}/${nestedPathHash}_${nestedIsIndex ? 'index_' : ''}transitive_${safeFileName(scenario.name)}.${nestedExtension}`;
2058
+ // Limit path hash length to prevent ENAMETOOLONG errors
2059
+ const nestedPathHash = safeFileName(nestedFile.path, { maxLength: 80 });
2060
+ const nestedScenarioSlug = safeFileName(scenario.name, {
2061
+ maxLength: 60,
2062
+ });
2063
+ const nestedTransformedPath = `${PROJECT_RELATIVE_PATH}/${nestedBasePath}/${nestedPathHash}_${nestedIsIndex ? 'index_' : ''}transitive_${nestedScenarioSlug}.${nestedExtension}`;
1952
2064
  // Check if already processed as a transitive file (we can rewrite to point to it)
1953
2065
  // Note: __data_file_written__ is for entity-specific scenario files with different naming,
1954
2066
  // but we still need transitive copies for server-only stripping in the import chain
@@ -2014,6 +2126,7 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2014
2126
  const importRegex = new RegExp(`(from\\s*["'])${escapedImportPath}(["'])`, 'g');
2015
2127
  fileContent = fileContent.replace(importRegex, `$1${safeRelativePath}$2`);
2016
2128
  }
2129
+ console.log(`[WriteScenario] POST-LOOP ${entity.name}: remaining imports loop took ${Date.now() - postLoopStartTime}ms`);
2017
2130
  const scenarioComponentComment = `// This file is auto-generated by CodeYam. Do not edit this file manually.
2018
2131
  // This file contains content for a scenario component:
2019
2132
  // Analyses being written: ${JSON.stringify(fileAnalyses?.map((a) => ({ id: a.id, entityName: a.entityName })))}
@@ -2024,6 +2137,57 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2024
2137
  // Entity: ${rootAnalysis.entitySha} ${rootAnalysis.entityName}
2025
2138
  // Scenario: ${scenario.id} - ${scenario.name}
2026
2139
  `;
2140
+ // Final pass: Rename any namespace imports (import * as X from '...') that have
2141
+ // corresponding mock code using ...X__cyOriginal spread pattern.
2142
+ // This handles cases where:
2143
+ // 1. The import path was rewritten by transitive import handling
2144
+ // 2. The import wasn't caught by the earlier renaming logic
2145
+ // We scan for all __cyOriginal references in the mock code and ensure the imports are renamed.
2146
+ const cyOriginalReferences = fileContent.match(/\.\.\.(\w+)__cyOriginal/g);
2147
+ if (cyOriginalReferences) {
2148
+ const uniqueNames = [
2149
+ ...new Set(cyOriginalReferences.map((ref) => ref.replace('...', '').replace('__cyOriginal', ''))),
2150
+ ];
2151
+ for (const name of uniqueNames) {
2152
+ // Match namespace imports for this name that haven't been renamed yet
2153
+ const namespaceImportRegex = new RegExp(`(import\\s+\\*\\s+as\\s+)${escapeRegExp(name)}(\\s+from\\s+['"][^'"]*['"])`, 'g');
2154
+ fileContent = fileContent.replace(namespaceImportRegex, `$1${name}__cyOriginal$2`);
2155
+ }
2156
+ }
2157
+ // For route components (page.tsx, layout.tsx), the component IS the Next.js page.
2158
+ // There's no wrapper page to inject argumentsData as props (unlike non-route components
2159
+ // which get a scenarioComponent wrapper). We need to wrap the default export so that
2160
+ // the scenario's argumentsData is passed as props to the component.
2161
+ if (isFrameworkRoute(file, entity, framework, file === rootFile) &&
2162
+ rootAnalysis.metadata?.scenariosDataStructure?.arguments?.length > 0) {
2163
+ const positionalArguments = rootAnalysis.metadata.scenariosDataStructure.arguments;
2164
+ const hasNamedArgs = positionalArguments.length === 1 &&
2165
+ typeof positionalArguments[0] === 'object';
2166
+ if (hasNamedArgs) {
2167
+ // Match: export default function Name(
2168
+ // Also: export default async function Name(
2169
+ const defaultExportMatch = fileContent.match(/export\s+default\s+(async\s+)?function\s+(\w+)\s*\(/);
2170
+ if (defaultExportMatch) {
2171
+ const funcName = defaultExportMatch[2];
2172
+ // Remove "export default" from the original function declaration
2173
+ fileContent = fileContent.replace(/export\s+default\s+(async\s+)?function\s+(\w+)\s*\(/, '$1function $2(');
2174
+ // Ensure scenarios import is present
2175
+ const mockDataPath = `${relativeMocksDir}/MockData_${safeFileName(scenario.name)}`;
2176
+ if (fileContent.indexOf('import { scenarios } from') === -1) {
2177
+ fileContent = `import { scenarios } from "${mockDataPath}";\n\n${fileContent}`;
2178
+ }
2179
+ // Add wrapper default export that injects argumentsData as props.
2180
+ // Filter null values: the LLM uses null to mean "don't pass this prop"
2181
+ // but spreading { prop: null } explicitly passes null, which differs from
2182
+ // undefined (absent) and crashes components that check `prop !== undefined`.
2183
+ fileContent += `\n\nexport default function _CYRouteWrapper(props: any) {
2184
+ const _cyArgs = scenarios().data()?.['arguments']?.[0] ?? {};
2185
+ const _cyCleanArgs = Object.fromEntries(Object.entries(_cyArgs).filter(([_, v]) => v !== null));
2186
+ return <${funcName} {...props} {..._cyCleanArgs} />;
2187
+ }\n`;
2188
+ }
2189
+ }
2190
+ }
2027
2191
  // Use the directive that was extracted at the beginning of processing
2028
2192
  // This ensures it stays at the very top even after imports are prepended
2029
2193
  // NOTE: We only preserve "use client" directives, NOT "use server" directives.
@@ -2044,6 +2208,7 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2044
2208
  await writeFile(scenarioComponentPath, finalContent);
2045
2209
  debugLog('Successfully wrote scenario file');
2046
2210
  scenarioComponentPaths.push(scenarioComponentPath);
2211
+ console.log(`[WriteScenario] POST-LOOP ${entity.name}: COMPLETE total=${Date.now() - postLoopStartTime}ms`);
2047
2212
  return { scenarioComponentPaths, writtenScenarioComponents };
2048
2213
  }
2049
2214
  //# sourceMappingURL=writeScenarioComponents.js.map