@codeyam/codeyam-cli 0.1.0-staging.6e699e5 → 0.1.0-staging.7481014

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 (1197) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +27 -27
  4. package/analyzer-template/packages/ai/index.ts +11 -2
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +100 -18
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +101 -12
  8. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +176 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/nodeToSource.ts +19 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +11 -4
  11. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  12. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +409 -50
  13. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  14. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +21 -6
  15. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1301 -262
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +10 -3
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +70 -9
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +60 -15
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +393 -97
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  30. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  31. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  32. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +393 -8
  33. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +9 -5
  34. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +112 -5
  35. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  36. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +649 -142
  37. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +1 -1
  38. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  39. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  40. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  41. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  42. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  43. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  44. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +25 -13
  45. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +4 -3
  46. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  47. package/analyzer-template/packages/analyze/index.ts +6 -1
  48. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  49. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  50. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  51. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  52. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  53. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  54. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  55. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  56. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  57. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  58. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +117 -11
  59. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +32 -40
  60. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +22 -6
  61. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +13 -14
  62. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +21 -0
  63. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +82 -13
  64. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +4 -0
  65. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +4 -0
  66. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +8 -3
  67. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  68. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  69. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  70. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +61 -13
  71. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
  72. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +502 -28
  73. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +19 -9
  74. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1813 -1075
  75. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  76. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  77. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  78. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  79. package/analyzer-template/packages/aws/package.json +10 -10
  80. package/analyzer-template/packages/database/index.ts +1 -0
  81. package/analyzer-template/packages/database/package.json +4 -4
  82. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  83. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  84. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  85. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  86. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  87. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  88. package/analyzer-template/packages/database/src/lib/kysely/db.ts +22 -1
  89. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  90. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  91. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  92. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  93. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  94. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +38 -15
  95. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  96. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  97. package/analyzer-template/packages/database/src/lib/loadCommits.ts +58 -19
  98. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -9
  99. package/analyzer-template/packages/database/src/lib/loadEntity.ts +19 -8
  100. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  101. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  102. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  103. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  104. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  105. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +96 -152
  106. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  107. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  108. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  109. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  110. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  111. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  112. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  113. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  114. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  116. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  119. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  122. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  124. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  125. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  126. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  127. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  128. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  129. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +16 -1
  130. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  131. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  132. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  133. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  134. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  135. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  136. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  137. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  138. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  139. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  140. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  141. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  142. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  143. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  144. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  145. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  146. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  147. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  148. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  149. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  150. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  151. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +15 -1
  152. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  153. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  154. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  155. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  156. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  157. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  158. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  159. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  160. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +45 -14
  161. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  162. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  163. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  164. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -10
  165. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  166. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +4 -1
  167. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
  168. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +5 -5
  169. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -1
  170. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  171. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  172. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  173. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  174. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  175. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  176. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  178. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  179. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  181. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  182. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  183. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  184. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -89
  185. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  186. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  187. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  188. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  189. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  190. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  191. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  192. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  193. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  194. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  195. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  196. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  197. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  198. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  199. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  200. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  201. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  202. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  203. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  204. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  205. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  206. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  207. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  208. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  209. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  210. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  211. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  212. package/analyzer-template/packages/github/package.json +2 -2
  213. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  214. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  215. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  216. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  217. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +6 -5
  218. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  219. package/analyzer-template/packages/ui-components/package.json +1 -1
  220. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  221. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  222. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  223. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  224. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  225. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  226. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  227. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  228. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  229. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  230. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  231. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  232. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  233. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  234. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +3 -1
  235. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  236. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +120 -4
  237. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  238. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +148 -3
  239. package/analyzer-template/playwright/capture.ts +20 -8
  240. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  241. package/analyzer-template/playwright/captureStatic.ts +1 -1
  242. package/analyzer-template/project/analyzeBaselineCommit.ts +5 -0
  243. package/analyzer-template/project/analyzeFileEntities.ts +26 -0
  244. package/analyzer-template/project/analyzeRegularCommit.ts +5 -0
  245. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  246. package/analyzer-template/project/constructMockCode.ts +260 -60
  247. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  248. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  249. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  250. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +11 -6
  251. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  252. package/analyzer-template/project/orchestrateCapture.ts +49 -7
  253. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  254. package/analyzer-template/project/runMultiScenarioServer.ts +26 -3
  255. package/analyzer-template/project/start.ts +38 -11
  256. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  257. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  258. package/analyzer-template/project/writeMockDataTsx.ts +198 -8
  259. package/analyzer-template/project/writeScenarioComponents.ts +213 -29
  260. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  261. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  262. package/analyzer-template/tsconfig.json +13 -1
  263. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  264. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  265. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +5 -0
  266. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  267. package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
  268. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  269. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +5 -0
  270. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  271. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  272. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  273. package/background/src/lib/virtualized/project/constructMockCode.js +220 -45
  274. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  275. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  276. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  277. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  278. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  279. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  280. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  281. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +4 -4
  282. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  283. package/background/src/lib/virtualized/project/orchestrateCapture.js +42 -7
  284. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  285. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  286. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  287. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +23 -3
  288. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -1
  289. package/background/src/lib/virtualized/project/start.js +34 -11
  290. package/background/src/lib/virtualized/project/start.js.map +1 -1
  291. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  292. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  293. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  294. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  295. package/background/src/lib/virtualized/project/writeMockDataTsx.js +174 -4
  296. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  297. package/background/src/lib/virtualized/project/writeScenarioComponents.js +168 -27
  298. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  299. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  300. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  301. package/codeyam-cli/scripts/apply-setup.js +386 -9
  302. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  303. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  304. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  305. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  306. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  307. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  308. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  309. package/codeyam-cli/src/cli.js +59 -24
  310. package/codeyam-cli/src/cli.js.map +1 -1
  311. package/codeyam-cli/src/codeyam-cli.js +18 -2
  312. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  313. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js +47 -0
  314. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js.map +1 -0
  315. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js +71 -0
  316. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js.map +1 -0
  317. package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js +30 -0
  318. package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js.map +1 -0
  319. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  320. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  321. package/codeyam-cli/src/commands/__tests__/editor.statePersistence.test.js +55 -0
  322. package/codeyam-cli/src/commands/__tests__/editor.statePersistence.test.js.map +1 -0
  323. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  324. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  325. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +137 -47
  326. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  327. package/codeyam-cli/src/commands/analyze.js +21 -9
  328. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  329. package/codeyam-cli/src/commands/baseline.js +2 -0
  330. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  331. package/codeyam-cli/src/commands/debug.js +9 -5
  332. package/codeyam-cli/src/commands/debug.js.map +1 -1
  333. package/codeyam-cli/src/commands/default.js +44 -21
  334. package/codeyam-cli/src/commands/default.js.map +1 -1
  335. package/codeyam-cli/src/commands/editor.js +6313 -0
  336. package/codeyam-cli/src/commands/editor.js.map +1 -0
  337. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js +23 -0
  338. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js.map +1 -0
  339. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  340. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  341. package/codeyam-cli/src/commands/init.js +168 -292
  342. package/codeyam-cli/src/commands/init.js.map +1 -1
  343. package/codeyam-cli/src/commands/memory.js +278 -0
  344. package/codeyam-cli/src/commands/memory.js.map +1 -0
  345. package/codeyam-cli/src/commands/recapture.js +2 -0
  346. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  347. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  348. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  349. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  350. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  351. package/codeyam-cli/src/commands/telemetry.js +37 -0
  352. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  353. package/codeyam-cli/src/commands/test-startup.js +2 -0
  354. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  355. package/codeyam-cli/src/commands/verify.js +14 -2
  356. package/codeyam-cli/src/commands/verify.js.map +1 -1
  357. package/codeyam-cli/src/data/designSystems.js +27 -0
  358. package/codeyam-cli/src/data/designSystems.js.map +1 -0
  359. package/codeyam-cli/src/data/techStacks.js +77 -0
  360. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  361. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  362. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  363. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  364. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  365. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +226 -0
  366. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  367. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +181 -0
  368. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  369. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +4160 -0
  370. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  371. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  372. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  373. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  374. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  375. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js +137 -0
  376. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
  377. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  378. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  379. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  380. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  381. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  382. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  383. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
  384. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  385. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
  386. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js.map +1 -0
  387. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  388. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  389. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  390. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  391. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  392. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  393. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  394. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  395. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  396. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  397. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  398. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  399. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +361 -0
  400. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  401. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +250 -0
  402. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  403. package/codeyam-cli/src/utils/__tests__/editorRoadmap.test.js +1108 -0
  404. package/codeyam-cli/src/utils/__tests__/editorRoadmap.test.js.map +1 -0
  405. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  406. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  407. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +411 -0
  408. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  409. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1768 -0
  410. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  411. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +413 -0
  412. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  413. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  414. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  415. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  416. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  417. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  418. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  419. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2121 -0
  420. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  421. package/codeyam-cli/src/utils/__tests__/envFile.test.js +125 -0
  422. package/codeyam-cli/src/utils/__tests__/envFile.test.js.map +1 -0
  423. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  424. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  425. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js +177 -0
  426. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
  427. package/codeyam-cli/src/utils/__tests__/handoffContext.test.js +500 -0
  428. package/codeyam-cli/src/utils/__tests__/handoffContext.test.js.map +1 -0
  429. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
  430. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  431. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js +302 -0
  432. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js.map +1 -0
  433. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  434. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  435. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  436. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  437. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  438. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  439. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  440. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  441. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js +127 -0
  442. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js.map +1 -0
  443. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  444. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  445. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  446. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  447. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  448. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  449. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  450. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  451. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
  452. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
  453. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +175 -86
  454. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  455. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  456. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  457. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  458. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  459. package/codeyam-cli/src/utils/__tests__/testRunner.test.js +216 -0
  460. package/codeyam-cli/src/utils/__tests__/testRunner.test.js.map +1 -0
  461. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +148 -0
  462. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  463. package/codeyam-cli/src/utils/analysisRunner.js +59 -9
  464. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  465. package/codeyam-cli/src/utils/analyzer.js +26 -0
  466. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  467. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  468. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  469. package/codeyam-cli/src/utils/backgroundServer.js +193 -30
  470. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  471. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  472. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  473. package/codeyam-cli/src/utils/database.js +37 -2
  474. package/codeyam-cli/src/utils/database.js.map +1 -1
  475. package/codeyam-cli/src/utils/designSystemShowcase.js +810 -0
  476. package/codeyam-cli/src/utils/designSystemShowcase.js.map +1 -0
  477. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  478. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  479. package/codeyam-cli/src/utils/devServerState.js +103 -0
  480. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  481. package/codeyam-cli/src/utils/editorApi.js +95 -0
  482. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  483. package/codeyam-cli/src/utils/editorAudit.js +849 -0
  484. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  485. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  486. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  487. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  488. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  489. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  490. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  491. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  492. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  493. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  494. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  495. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  496. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  497. package/codeyam-cli/src/utils/editorGuard.js +36 -0
  498. package/codeyam-cli/src/utils/editorGuard.js.map +1 -0
  499. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  500. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  501. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  502. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  503. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  504. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  505. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  506. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  507. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  508. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  509. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  510. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  511. package/codeyam-cli/src/utils/editorPreview.js +139 -0
  512. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  513. package/codeyam-cli/src/utils/editorRecapture.js +109 -0
  514. package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
  515. package/codeyam-cli/src/utils/editorRoadmap.js +574 -0
  516. package/codeyam-cli/src/utils/editorRoadmap.js.map +1 -0
  517. package/codeyam-cli/src/utils/editorScenarioSwitch.js +149 -0
  518. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  519. package/codeyam-cli/src/utils/editorScenarios.js +687 -0
  520. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  521. package/codeyam-cli/src/utils/editorSeedAdapter.js +475 -0
  522. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  523. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  524. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  525. package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
  526. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  527. package/codeyam-cli/src/utils/entityChangeStatus.server.js +227 -0
  528. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  529. package/codeyam-cli/src/utils/envFile.js +90 -0
  530. package/codeyam-cli/src/utils/envFile.js.map +1 -0
  531. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  532. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  533. package/codeyam-cli/src/utils/fileWatcher.js +63 -9
  534. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  535. package/codeyam-cli/src/utils/generateReport.js +2 -2
  536. package/codeyam-cli/src/utils/git.js +103 -0
  537. package/codeyam-cli/src/utils/git.js.map +1 -1
  538. package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
  539. package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
  540. package/codeyam-cli/src/utils/handoffContext.js +257 -0
  541. package/codeyam-cli/src/utils/handoffContext.js.map +1 -0
  542. package/codeyam-cli/src/utils/install-skills.js +159 -48
  543. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  544. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  545. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  546. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  547. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  548. package/codeyam-cli/src/utils/manualEntityAnalysis.js +196 -0
  549. package/codeyam-cli/src/utils/manualEntityAnalysis.js.map +1 -0
  550. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  551. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  552. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  553. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  554. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  555. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  556. package/codeyam-cli/src/utils/progress.js +8 -1
  557. package/codeyam-cli/src/utils/progress.js.map +1 -1
  558. package/codeyam-cli/src/utils/project.js +15 -5
  559. package/codeyam-cli/src/utils/project.js.map +1 -1
  560. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  561. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  562. package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js +159 -0
  563. package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js.map +1 -0
  564. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  565. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  566. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  567. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  568. package/codeyam-cli/src/utils/queue/job.js +109 -7
  569. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  570. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  571. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  572. package/codeyam-cli/src/utils/registerScenarioResult.js +52 -0
  573. package/codeyam-cli/src/utils/registerScenarioResult.js.map +1 -0
  574. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  575. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  576. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  577. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  578. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  579. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  580. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  581. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  582. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  583. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  584. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  585. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  586. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  587. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  588. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  589. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  590. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  591. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  592. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  593. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  594. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  595. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  596. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  597. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  598. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  599. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  600. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  601. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  602. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  603. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  604. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  605. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  606. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  607. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  608. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  609. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  610. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  611. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  612. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  613. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  614. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  615. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  616. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  617. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  618. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  619. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  620. package/codeyam-cli/src/utils/rules/index.js +7 -0
  621. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  622. package/codeyam-cli/src/utils/rules/parser.js +93 -0
  623. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  624. package/codeyam-cli/src/utils/rules/pathMatcher.js +49 -0
  625. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  626. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  627. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  628. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  629. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  630. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  631. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  632. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  633. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  634. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  635. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  636. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  637. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  638. package/codeyam-cli/src/utils/scenariosManifest.js +313 -0
  639. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  640. package/codeyam-cli/src/utils/screenshotHash.js +26 -0
  641. package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
  642. package/codeyam-cli/src/utils/serverState.js +94 -12
  643. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  644. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +96 -47
  645. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  646. package/codeyam-cli/src/utils/simulationGateMiddleware.js +175 -0
  647. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  648. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  649. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  650. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  651. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  652. package/codeyam-cli/src/utils/techStackConfig.js +38 -0
  653. package/codeyam-cli/src/utils/techStackConfig.js.map +1 -0
  654. package/codeyam-cli/src/utils/techStackConfig.test.js +85 -0
  655. package/codeyam-cli/src/utils/techStackConfig.test.js.map +1 -0
  656. package/codeyam-cli/src/utils/telemetry.js +106 -0
  657. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  658. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  659. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  660. package/codeyam-cli/src/utils/testResultCache.js +53 -0
  661. package/codeyam-cli/src/utils/testResultCache.js.map +1 -0
  662. package/codeyam-cli/src/utils/testResultCache.server.js +81 -0
  663. package/codeyam-cli/src/utils/testResultCache.server.js.map +1 -0
  664. package/codeyam-cli/src/utils/testResultCache.server.test.js +187 -0
  665. package/codeyam-cli/src/utils/testResultCache.server.test.js.map +1 -0
  666. package/codeyam-cli/src/utils/testResultCache.test.js +230 -0
  667. package/codeyam-cli/src/utils/testResultCache.test.js.map +1 -0
  668. package/codeyam-cli/src/utils/testRunner.js +350 -0
  669. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  670. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  671. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  672. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  673. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  674. package/codeyam-cli/src/utils/webappDetection.js +38 -3
  675. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  676. package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js +99 -0
  677. package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js.map +1 -0
  678. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +153 -0
  679. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  680. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
  681. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  682. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  683. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  684. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +1000 -0
  685. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  686. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +315 -0
  687. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  688. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  689. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  690. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
  691. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  692. package/codeyam-cli/src/webserver/app/lib/database.js +62 -33
  693. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  694. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  695. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  696. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  697. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js +34 -0
  698. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js.map +1 -0
  699. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  700. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  701. package/codeyam-cli/src/webserver/backgroundServer.js +186 -37
  702. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  703. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  704. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  705. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-DTBZZfSk.js +1 -0
  706. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BxclONWq.js +11 -0
  707. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  708. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-BsnEOJZ_.js} +9 -9
  709. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-ByaELMbv.js +1 -0
  710. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-6WjVfhxX.js +25 -0
  711. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-ChX-Hp7W.js +3 -0
  712. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-By5zI316.js} +1 -1
  713. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-C-9zQdXg.js} +3 -3
  714. package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-Bs2_Oua4.js +36 -0
  715. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-D4TZhLuw.js → ReportIssueModal-DQsceHVv.js} +5 -15
  716. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DThcm_9M.js +1 -0
  717. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DEx02QDa.js → ScenarioViewer-Cl4oOA3A.js} +3 -3
  718. package/codeyam-cli/src/webserver/build/client/assets/Spinner-CIil5-gb.js +34 -0
  719. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  720. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BqkA9zyZ.js +1 -0
  721. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DnOgyseQ.js} +4 -4
  722. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-DoLIqZX2.js → activity.(_tab)-DqM9hbNE.js} +10 -20
  723. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  724. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  725. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-C58dYPwR.js +1 -0
  726. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  727. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-B8NCeOrm.js +22 -0
  728. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  729. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  730. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  731. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  732. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  733. package/codeyam-cli/src/webserver/build/client/assets/api.editor-database-verify-l0sNRNKZ.js +1 -0
  734. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  735. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  736. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  737. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  738. package/codeyam-cli/src/webserver/build/client/assets/api.editor-github-verify-l0sNRNKZ.js +1 -0
  739. package/codeyam-cli/src/webserver/build/client/assets/api.editor-handoff-l0sNRNKZ.js +1 -0
  740. package/codeyam-cli/src/webserver/build/client/assets/api.editor-hosting-verify-l0sNRNKZ.js +1 -0
  741. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  742. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  743. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  744. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  745. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  746. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  747. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  748. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  749. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  750. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  751. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  752. package/codeyam-cli/src/webserver/build/client/assets/api.editor-roadmap-l0sNRNKZ.js +1 -0
  753. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
  754. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  755. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  756. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  757. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  758. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  759. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  760. package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
  761. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  762. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  763. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  764. package/codeyam-cli/src/webserver/build/client/assets/api.editor-verify-routes-l0sNRNKZ.js +1 -0
  765. package/codeyam-cli/src/webserver/build/client/assets/api.interactive-switch-scenario-l0sNRNKZ.js +1 -0
  766. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  767. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  768. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  769. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  770. package/codeyam-cli/src/webserver/build/client/assets/book-open-BFSIqZgO.js +6 -0
  771. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-B9fDzFVh.js} +2 -2
  772. package/codeyam-cli/src/webserver/build/client/assets/chunk-UVKPFVEO-Bmq2apuh.js +43 -0
  773. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-DLPObLUx.js} +2 -2
  774. package/codeyam-cli/src/webserver/build/client/assets/copy-DXEmO0TD.js +11 -0
  775. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BwyFiRot.js +41 -0
  776. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
  777. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
  778. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-iRhRIFlp.js +1 -0
  779. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-BZPBzV73.js +1 -0
  780. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DhtVC4aI.js +161 -0
  781. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-C6fEYHrh.js +41 -0
  782. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-C2N4Op8e.js → entity._sha._-pc-vc6wO.js} +14 -13
  783. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C8AyYgYT.js +6 -0
  784. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DziaVQX1.js +6 -0
  785. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-BTcpgIpC.js +6 -0
  786. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-D_O_ajfZ.js} +2 -2
  787. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-j1Vi0bco.js} +6 -6
  788. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  789. package/codeyam-cli/src/webserver/build/client/assets/files-kuny2Q_s.js +1 -0
  790. package/codeyam-cli/src/webserver/build/client/assets/git-DgCZPMie.js +1 -0
  791. package/codeyam-cli/src/webserver/build/client/assets/globals-L-aUIeux.css +1 -0
  792. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BliGSSpl.js} +1 -1
  793. package/codeyam-cli/src/webserver/build/client/assets/index-SqjQKTdH.js +15 -0
  794. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-vyrZD2g4.js} +1 -1
  795. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  796. package/codeyam-cli/src/webserver/build/client/assets/labs-c3yLxSEp.js +1 -0
  797. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-D-q28GLF.js} +2 -2
  798. package/codeyam-cli/src/webserver/build/client/assets/manifest-b0d69c06.js +1 -0
  799. package/codeyam-cli/src/webserver/build/client/assets/memory-CEWIUC4t.js +101 -0
  800. package/codeyam-cli/src/webserver/build/client/assets/pause-BP6fitdh.js +11 -0
  801. package/codeyam-cli/src/webserver/build/client/assets/root-CLedrjXQ.js +80 -0
  802. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-BooqacKS.js} +2 -2
  803. package/codeyam-cli/src/webserver/build/client/assets/settings-BM0nbryO.js +1 -0
  804. package/codeyam-cli/src/webserver/build/client/assets/simulations-ovy6FjRY.js +1 -0
  805. package/codeyam-cli/src/webserver/build/client/assets/terminal-DHemCJIs.js +11 -0
  806. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-D87ekDl8.js} +2 -2
  807. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-Dk0Tciqg.js +1 -0
  808. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C8QvIe05.js +2 -0
  809. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-jkCytuYz.js +1 -0
  810. package/codeyam-cli/src/webserver/build/client/assets/useToast-BgqkixU9.js +1 -0
  811. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  812. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  813. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-DPUEhrWo.js +16 -0
  814. package/codeyam-cli/src/webserver/build/server/assets/index-oF2amaGI.js +1 -0
  815. package/codeyam-cli/src/webserver/build/server/assets/init-C42BvUGp.js +14 -0
  816. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  817. package/codeyam-cli/src/webserver/build/server/assets/server-build-DiCdDL5d.js +853 -0
  818. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  819. package/codeyam-cli/src/webserver/build-info.json +5 -5
  820. package/codeyam-cli/src/webserver/devServer.js +39 -5
  821. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  822. package/codeyam-cli/src/webserver/editorProxy.js +1263 -0
  823. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  824. package/codeyam-cli/src/webserver/idleDetector.js +130 -0
  825. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  826. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  827. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  828. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  829. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  830. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +283 -0
  831. package/codeyam-cli/src/webserver/server.js +446 -1
  832. package/codeyam-cli/src/webserver/server.js.map +1 -1
  833. package/codeyam-cli/src/webserver/terminalServer.js +1043 -0
  834. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  835. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  836. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  837. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  838. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  839. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  840. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  841. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  842. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  843. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  844. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  845. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  846. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  847. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  848. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  849. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  850. package/codeyam-cli/templates/codeyam-editor-claude.md +149 -0
  851. package/codeyam-cli/templates/codeyam-editor-codex.md +61 -0
  852. package/codeyam-cli/templates/codeyam-editor-gemini.md +59 -0
  853. package/codeyam-cli/templates/codeyam-editor-reference.md +216 -0
  854. package/codeyam-cli/templates/{codeyam-power-rules-hook.sh → codeyam-memory-hook.sh} +22 -23
  855. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  856. package/codeyam-cli/templates/design-systems/clean-dashboard-design-system.md +255 -0
  857. package/codeyam-cli/templates/design-systems/editorial-design-system.md +267 -0
  858. package/codeyam-cli/templates/design-systems/mono-brutalist-design-system.md +256 -0
  859. package/codeyam-cli/templates/design-systems/neo-brutalist-design-system.md +294 -0
  860. package/codeyam-cli/templates/editor-step-hook.py +368 -0
  861. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +288 -0
  862. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  863. package/codeyam-cli/templates/expo-react-native/__tests__/.gitkeep +0 -0
  864. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +15 -0
  865. package/codeyam-cli/templates/expo-react-native/app/index.tsx +36 -0
  866. package/codeyam-cli/templates/expo-react-native/app.json +29 -0
  867. package/codeyam-cli/templates/expo-react-native/babel.config.js +10 -0
  868. package/codeyam-cli/templates/expo-react-native/gitignore +14 -0
  869. package/codeyam-cli/templates/expo-react-native/global.css +10 -0
  870. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  871. package/codeyam-cli/templates/expo-react-native/lib/theme.ts +73 -0
  872. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  873. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  874. package/codeyam-cli/templates/expo-react-native/package.json +54 -0
  875. package/codeyam-cli/templates/expo-react-native/patches/expo-modules-autolinking+3.0.24.patch +29 -0
  876. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  877. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  878. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  879. package/codeyam-cli/templates/isolation-route/expo-router.tsx.template +54 -0
  880. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  881. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  882. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  883. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  884. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  885. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  886. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  887. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  888. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  889. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  890. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  891. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  892. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  893. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  894. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  895. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  896. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  897. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  898. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  899. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +65 -0
  900. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  901. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  902. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  903. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  904. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  905. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  906. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +140 -0
  907. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  908. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  909. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  910. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  911. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  912. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  913. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  914. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  915. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  916. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  917. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  918. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  919. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  920. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  921. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  922. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  923. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  924. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  925. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  926. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  927. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  928. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  929. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  930. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  931. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  932. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  933. package/codeyam-cli/templates/rules-instructions.md +78 -0
  934. package/codeyam-cli/templates/seed-adapters/supabase.ts +475 -0
  935. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  936. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  937. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +244 -0
  938. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  939. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  940. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  941. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  942. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  943. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  944. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  945. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  946. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  947. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  948. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  949. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  950. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  951. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  952. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  953. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  954. package/package.json +32 -22
  955. package/packages/ai/index.js +3 -2
  956. package/packages/ai/index.js.map +1 -1
  957. package/packages/ai/src/lib/analyzeScope.js +82 -13
  958. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  959. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +76 -12
  960. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  961. package/packages/ai/src/lib/astScopes/methodSemantics.js +140 -17
  962. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  963. package/packages/ai/src/lib/astScopes/nodeToSource.js +16 -0
  964. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -1
  965. package/packages/ai/src/lib/astScopes/paths.js +12 -3
  966. package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
  967. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  968. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  969. package/packages/ai/src/lib/astScopes/processExpression.js +317 -44
  970. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  971. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  972. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  973. package/packages/ai/src/lib/completionCall.js +10 -7
  974. package/packages/ai/src/lib/completionCall.js.map +1 -1
  975. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1036 -183
  976. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  977. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
  978. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
  979. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  980. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  981. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  982. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  983. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  984. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  985. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +66 -7
  986. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  987. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +55 -11
  988. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  989. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  990. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  991. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  992. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  993. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  994. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  995. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  996. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  997. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  998. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  999. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +333 -86
  1000. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  1001. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  1002. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  1003. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  1004. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  1005. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  1006. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  1007. package/packages/ai/src/lib/generateEntityScenarioData.js +284 -6
  1008. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  1009. package/packages/ai/src/lib/generateEntityScenarios.js +7 -1
  1010. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  1011. package/packages/ai/src/lib/generateExecutionFlows.js +96 -4
  1012. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  1013. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +447 -80
  1014. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  1015. package/packages/ai/src/lib/isolateScopes.js +39 -3
  1016. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  1017. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  1018. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  1019. package/packages/ai/src/lib/mergeStatements.js +70 -51
  1020. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  1021. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  1022. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  1023. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  1024. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  1025. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  1026. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  1027. package/packages/ai/src/lib/resolvePathToControllable.js +24 -14
  1028. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  1029. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  1030. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  1031. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  1032. package/packages/analyze/index.js +2 -1
  1033. package/packages/analyze/index.js.map +1 -1
  1034. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  1035. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  1036. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  1037. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  1038. package/packages/analyze/src/lib/asts/index.js +4 -2
  1039. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  1040. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  1041. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  1042. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  1043. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  1044. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  1045. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  1046. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  1047. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  1048. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  1049. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  1050. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  1051. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  1052. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  1053. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  1054. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +81 -9
  1055. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  1056. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +30 -30
  1057. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  1058. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +12 -2
  1059. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  1060. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +11 -8
  1061. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  1062. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
  1063. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
  1064. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -14
  1065. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  1066. package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
  1067. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  1068. package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
  1069. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  1070. package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
  1071. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
  1072. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  1073. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  1074. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  1075. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  1076. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  1077. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  1078. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +56 -10
  1079. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  1080. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
  1081. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  1082. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +313 -23
  1083. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  1084. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +16 -8
  1085. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  1086. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1459 -846
  1087. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  1088. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  1089. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  1090. package/packages/analyze/src/lib/index.js +1 -0
  1091. package/packages/analyze/src/lib/index.js.map +1 -1
  1092. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  1093. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  1094. package/packages/database/index.js +1 -0
  1095. package/packages/database/index.js.map +1 -1
  1096. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  1097. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  1098. package/packages/database/src/lib/analysisToDb.js +1 -1
  1099. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  1100. package/packages/database/src/lib/branchToDb.js +1 -1
  1101. package/packages/database/src/lib/branchToDb.js.map +1 -1
  1102. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  1103. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  1104. package/packages/database/src/lib/commitToDb.js +1 -1
  1105. package/packages/database/src/lib/commitToDb.js.map +1 -1
  1106. package/packages/database/src/lib/fileToDb.js +1 -1
  1107. package/packages/database/src/lib/fileToDb.js.map +1 -1
  1108. package/packages/database/src/lib/kysely/db.js +16 -1
  1109. package/packages/database/src/lib/kysely/db.js.map +1 -1
  1110. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  1111. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  1112. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  1113. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  1114. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  1115. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  1116. package/packages/database/src/lib/loadAnalyses.js +45 -2
  1117. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  1118. package/packages/database/src/lib/loadAnalysis.js +15 -1
  1119. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  1120. package/packages/database/src/lib/loadBranch.js +11 -1
  1121. package/packages/database/src/lib/loadBranch.js.map +1 -1
  1122. package/packages/database/src/lib/loadCommit.js +7 -0
  1123. package/packages/database/src/lib/loadCommit.js.map +1 -1
  1124. package/packages/database/src/lib/loadCommits.js +45 -14
  1125. package/packages/database/src/lib/loadCommits.js.map +1 -1
  1126. package/packages/database/src/lib/loadEntities.js +23 -10
  1127. package/packages/database/src/lib/loadEntities.js.map +1 -1
  1128. package/packages/database/src/lib/loadEntity.js +5 -5
  1129. package/packages/database/src/lib/loadEntity.js.map +1 -1
  1130. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  1131. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  1132. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  1133. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  1134. package/packages/database/src/lib/projectToDb.js +1 -1
  1135. package/packages/database/src/lib/projectToDb.js.map +1 -1
  1136. package/packages/database/src/lib/saveFiles.js +1 -1
  1137. package/packages/database/src/lib/saveFiles.js.map +1 -1
  1138. package/packages/database/src/lib/scenarioToDb.js +1 -1
  1139. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  1140. package/packages/database/src/lib/updateCommitMetadata.js +76 -89
  1141. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  1142. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  1143. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  1144. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  1145. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  1146. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  1147. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  1148. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  1149. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  1150. package/packages/types/src/enums/ProjectFramework.js +2 -0
  1151. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  1152. package/packages/utils/src/lib/fs/rsyncCopy.js +120 -4
  1153. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  1154. package/scripts/npm-post-install.cjs +34 -0
  1155. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  1156. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  1157. package/codeyam-cli/src/commands/list.js +0 -31
  1158. package/codeyam-cli/src/commands/list.js.map +0 -1
  1159. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  1160. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  1161. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  1162. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  1163. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BXhEawa3.js +0 -1
  1164. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-DLqD3qNt.js +0 -1
  1165. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  1166. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-aht4aafF.js +0 -25
  1167. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-CVtiBnY5.js +0 -3
  1168. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DuDvi0jm.js +0 -1
  1169. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-DyFZkK0l.js +0 -1
  1170. package/codeyam-cli/src/webserver/build/client/assets/chunk-EPOLDU6W-CXRTFQ3F.js +0 -51
  1171. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  1172. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
  1173. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BRb-0kQl.js +0 -1
  1174. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  1175. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  1176. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-DMJ7zii9.js +0 -1
  1177. package/codeyam-cli/src/webserver/build/client/assets/files-Cs4MdYtv.js +0 -1
  1178. package/codeyam-cli/src/webserver/build/client/assets/git-B4RJRvYB.js +0 -15
  1179. package/codeyam-cli/src/webserver/build/client/assets/git-commit-horizontal-CysbcZxi.js +0 -6
  1180. package/codeyam-cli/src/webserver/build/client/assets/globals-DMUaGAqV.css +0 -1
  1181. package/codeyam-cli/src/webserver/build/client/assets/manifest-f874c610.js +0 -1
  1182. package/codeyam-cli/src/webserver/build/client/assets/root-Bz5TunQg.js +0 -57
  1183. package/codeyam-cli/src/webserver/build/client/assets/rules-hEkvVw2-.js +0 -97
  1184. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  1185. package/codeyam-cli/src/webserver/build/client/assets/simulations-DwFIBT09.js +0 -1
  1186. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  1187. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  1188. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DYxHZQuP.js +0 -1
  1189. package/codeyam-cli/src/webserver/build/client/assets/useToast-mBRpZPiu.js +0 -1
  1190. package/codeyam-cli/src/webserver/build/server/assets/index-967OuJoF.js +0 -1
  1191. package/codeyam-cli/src/webserver/build/server/assets/server-build-DRTmerg9.js +0 -257
  1192. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  1193. package/codeyam-cli/templates/codeyam:diagnose.md +0 -650
  1194. package/codeyam-cli/templates/codeyam:new-rule.md +0 -13
  1195. package/codeyam-cli/templates/codeyam:power-rules.md +0 -447
  1196. package/scripts/finalize-analyzer.cjs +0 -81
  1197. /package/codeyam-cli/src/webserver/build/client/assets/{api.rules-l0sNRNKZ.js → api.agent-transcripts-l0sNRNKZ.js} +0 -0
@@ -987,10 +987,19 @@ function addMockToContent(
987
987
  /[.*+?^${}()|[\]\\]/g,
988
988
  '\\$&',
989
989
  );
990
- // Create regex that matches the call (with optional whitespace variations)
990
+ // Create regex that matches the call (with optional whitespace variations).
991
+ // TypeScript formatters commonly break type parameters across lines, e.g.:
992
+ // useLoaderData<
993
+ // typeof loader
994
+ // >()
995
+ // So we allow optional whitespace around < and > delimiters, not just
996
+ // where whitespace already exists in the call signature string.
991
997
  const callRegex = new RegExp(
992
- escapedCallSignature.replace(/\s+/g, '\\s*'),
993
- 'g',
998
+ escapedCallSignature
999
+ .replace(/\s+/g, '\\s*')
1000
+ .replace(/</g, '\\s*<\\s*')
1001
+ .replace(/>/g, '\\s*>\\s*'),
1002
+ 'gs',
994
1003
  );
995
1004
  fileContent = fileContent.replace(callRegex, `${mockFunctionName}()`);
996
1005
  }
@@ -1012,15 +1021,29 @@ function addMockToContent(
1012
1021
  rootAnalysis.metadata?.scenariosDataStructure?.dataForMocks;
1013
1022
 
1014
1023
  // Find matching call signature key in dataForMocks
1024
+ // IMPORTANT: First try exact match with type parameters (e.g., "useLoaderData<LoaderData>()")
1025
+ // to avoid picking the wrong variant (e.g., "useLoaderData<typeof loader>()" which may
1026
+ // have different properties). Fall back to base name matching only if exact match fails.
1015
1027
  const hookBaseName = importedExport.name.split(/[<(]/)[0];
1016
- const callSignatureKey = dataForMocks
1017
- ? Object.keys(dataForMocks).find((key) => {
1028
+ const expectedKey = importedExport.calls?.[0];
1029
+ let callSignatureKey: string | undefined;
1030
+
1031
+ if (dataForMocks) {
1032
+ const keys = Object.keys(dataForMocks);
1033
+
1034
+ // First try exact match with the expected call signature
1035
+ if (expectedKey && keys.includes(expectedKey)) {
1036
+ callSignatureKey = expectedKey;
1037
+ } else {
1038
+ // Fall back to base name matching
1039
+ callSignatureKey = keys.find((key) => {
1018
1040
  // Split on ., <, or ( to get the true base name
1019
1041
  // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
1020
1042
  const keyBaseName = key.split(/[.<(]/)[0];
1021
1043
  return keyBaseName === hookBaseName;
1022
- })
1023
- : undefined;
1044
+ });
1045
+ }
1046
+ }
1024
1047
 
1025
1048
  // Use the call signature if found, otherwise construct it
1026
1049
  const dataKey =
@@ -1032,11 +1055,17 @@ function addMockToContent(
1032
1055
  // use the base name (e.g., "trpc") when calling constructMockCode. This ensures
1033
1056
  // constructMockCode generates a complete nested mock from the schema without
1034
1057
  // referencing __cyOriginal variables.
1058
+ // NOTE: Only check for dots BEFORE the first open paren. Function calls with
1059
+ // dotted arguments like "getSurveyWithMetadata(params.surveyId)" have dots
1060
+ // INSIDE parens — these are NOT method chains and should keep the full signature.
1035
1061
  const dataKeyBaseName = dataKey.split(/[.<(]/)[0];
1062
+ const firstParenIndex = dataKey.indexOf('(');
1063
+ const partBeforeFirstParen =
1064
+ firstParenIndex >= 0 ? dataKey.substring(0, firstParenIndex) : dataKey;
1036
1065
  const isMethodChainDataKey =
1037
1066
  dataKeyBaseName === importedExport.name &&
1038
1067
  dataKey !== importedExport.name &&
1039
- dataKey.includes('.');
1068
+ partBeforeFirstParen.includes('.');
1040
1069
  const mockNameToUse = isMethodChainDataKey
1041
1070
  ? importedExport.name
1042
1071
  : dataKey;
@@ -1061,18 +1090,36 @@ function addMockToContent(
1061
1090
  // IMPORTANT: We inline scenarios().data() inside the function rather than
1062
1091
  // storing in a const - see comment in constructMockCode.ts for why.
1063
1092
  if (!mockCode) {
1064
- mockCode = `function ${importedExport.name}(...args) {
1065
- return scenarios().data()?.["${dataKey}"];
1093
+ mockCode = `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)
1094
+ const _${importedExport.name}Ref = {
1095
+ current: null,
1096
+ };
1097
+ function ${importedExport.name}(...args) {
1098
+ if (!_${importedExport.name}Ref.current) {
1099
+ _${importedExport.name}Ref.current = scenarios().data()?.["${dataKey}"];
1100
+ }
1101
+ return _${importedExport.name}Ref.current;
1066
1102
  }`;
1067
1103
  }
1068
1104
  } else {
1069
1105
  // Helper to find matching call signature key from dataForMocks
1106
+ // IMPORTANT: First try exact match with type parameters (e.g., "useLoaderData<LoaderData>()")
1107
+ // to avoid picking the wrong variant. Fall back to base name matching only if needed.
1070
1108
  const hookBaseName = importedExport.name.split(/[<(]/)[0];
1109
+ const expectedKey = importedExport.calls?.[0];
1071
1110
  const findMatchingKey = (
1072
1111
  dataForMocks: Record<string, unknown> | undefined,
1073
1112
  ): string | undefined => {
1074
1113
  if (!dataForMocks) return undefined;
1075
- return Object.keys(dataForMocks).find((key) => {
1114
+ const keys = Object.keys(dataForMocks);
1115
+
1116
+ // First try exact match with the expected call signature
1117
+ if (expectedKey && keys.includes(expectedKey)) {
1118
+ return expectedKey;
1119
+ }
1120
+
1121
+ // Fall back to base name matching
1122
+ return keys.find((key) => {
1076
1123
  // Split on ., <, or ( to get the true base name
1077
1124
  // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
1078
1125
  const keyBaseName = key.split(/[.<(]/)[0];
@@ -1104,12 +1151,20 @@ function addMockToContent(
1104
1151
  // referencing __cyOriginal variables. The __cyOriginal pattern is only needed
1105
1152
  // for partial mocking where we preserve some original methods, not for complete
1106
1153
  // method-chain mocks where we provide all implementations.
1154
+ // NOTE: Only check for dots BEFORE the first open paren. Function calls with
1155
+ // dotted arguments like "getSurveyWithMetadata(params.surveyId)" have dots
1156
+ // INSIDE parens — these are NOT method chains and should keep the full signature.
1107
1157
  const dataKeyBaseName = dataKey?.split(/[.<(]/)[0];
1158
+ const elseFirstParenIndex = dataKey?.indexOf('(') ?? -1;
1159
+ const elsePartBeforeFirstParen =
1160
+ dataKey && elseFirstParenIndex >= 0
1161
+ ? dataKey.substring(0, elseFirstParenIndex)
1162
+ : dataKey;
1108
1163
  const isMethodChainDataKey =
1109
1164
  dataKey &&
1110
1165
  dataKeyBaseName === importedExport.name &&
1111
1166
  dataKey !== importedExport.name &&
1112
- dataKey.includes('.');
1167
+ (elsePartBeforeFirstParen?.includes('.') ?? false);
1113
1168
  const mockNameToUse = isMethodChainDataKey
1114
1169
  ? importedExport.name
1115
1170
  : (dataKey ?? importedExport.calls?.[0] ?? `${importedExport.name}()`);
@@ -1131,8 +1186,15 @@ function addMockToContent(
1131
1186
  // IMPORTANT: We inline scenarios().data() inside the function rather than
1132
1187
  // storing in a const - see comment in constructMockCode.ts for why.
1133
1188
  if (!mockCode && dataKey) {
1134
- mockCode = `function ${importedExport.name}(...args) {
1135
- return scenarios().data()?.["${dataKey}"];
1189
+ mockCode = `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)
1190
+ const _${importedExport.name}Ref = {
1191
+ current: null,
1192
+ };
1193
+ function ${importedExport.name}(...args) {
1194
+ if (!_${importedExport.name}Ref.current) {
1195
+ _${importedExport.name}Ref.current = scenarios().data()?.["${dataKey}"];
1196
+ }
1197
+ return _${importedExport.name}Ref.current;
1136
1198
  }`;
1137
1199
  }
1138
1200
  }
@@ -1205,6 +1267,21 @@ function addMockToContent(
1205
1267
  fileContent = fileContent.replace(importRegExp, '$1$2');
1206
1268
  }
1207
1269
 
1270
+ // Also handle namespace imports (import * as foo from '...')
1271
+ // These need to be renamed to foo__cyOriginal when the mock code spreads from the original.
1272
+ // Note: We match any path (not just escapedImportPath) because the import path may have
1273
+ // been rewritten by transitive import handling before this code runs.
1274
+ if (shouldRenameToOriginal) {
1275
+ const namespaceImportRegExp = new RegExp(
1276
+ `(import\\s+\\*\\s+as\\s+)${escapeRegExp(firstPart)}(\\s+from\\s+['"][^'"]*['"])`,
1277
+ 'm',
1278
+ );
1279
+ fileContent = fileContent.replace(
1280
+ namespaceImportRegExp,
1281
+ `$1${firstPart}__cyOriginal$2`,
1282
+ );
1283
+ }
1284
+
1208
1285
  // Remove empty imports entirely to avoid partial commenting issues with multiline imports
1209
1286
  // This handles both single-line and multiline empty imports
1210
1287
  fileContent = fileContent.replace(
@@ -1857,6 +1934,17 @@ export default async function writeScenarioComponents({
1857
1934
  dataFileContent = stripServerOnlyImport(dataFileContent);
1858
1935
  dataFileContent = applyServerOnlyMocks(dataFileContent);
1859
1936
 
1937
+ // Process transitive imports: if the data entity file imports from files
1938
+ // that have `import "server-only"`, rewrite those imports to transitive
1939
+ // copies with server-only stripped. Without this, data entity files that
1940
+ // end up in a client bundle (e.g., via a stripped "use server" boundary)
1941
+ // would pull in server-only code and cause build failures.
1942
+ dataFileContent = await processTransitiveImportsRecursively(
1943
+ dataFileContent,
1944
+ fileNotMocked.path,
1945
+ dataScenarioPath,
1946
+ );
1947
+
1860
1948
  // Write the transformed data entity file
1861
1949
  await writeFile(dataScenarioPath, dataFileContent);
1862
1950
  scenarioComponentPaths.push(dataScenarioPath);
@@ -1882,9 +1970,9 @@ export default async function writeScenarioComponents({
1882
1970
  importedExport.name,
1883
1971
  );
1884
1972
 
1885
- // Don't recurse - data entities don't need their dependencies processed
1886
- // The import rewriting will happen later in this same loop iteration
1887
- // (at lines ~1590-1702) to point imports to this transformed file
1973
+ // Don't recurse into full writeScenarioComponents - data entities don't
1974
+ // need mock generation for their dependencies. Transitive server-only
1975
+ // import processing is already handled above via processTransitiveImportsRecursively.
1888
1976
  } else {
1889
1977
  // For visual/library entities, recurse to process their dependencies
1890
1978
 
@@ -1957,20 +2045,25 @@ export default async function writeScenarioComponents({
1957
2045
  // that stubbing would break (e.g., Zod schemas with .superRefine())
1958
2046
  const isDataEntity = entityType === 'data' || entityType === 'type';
1959
2047
 
1960
- // Heuristic: Zod schemas are often misclassified as 'library' but should be preserved
1961
- // Detect by: name starts with Z + uppercase letter, AND has Zod method calls
1962
- const looksLikeZodSchema =
1963
- entityType === 'library' &&
1964
- /^Z[A-Z]/.test(importedExport.name) &&
1965
- importedExport.calls?.some((call: string) =>
1966
- /\.(superRefine|refine|transform|default|optional|nullable|array|object|string|number|boolean|parse|safeParse)\s*\(/.test(
1967
- call,
1968
- ),
1969
- );
2048
+ // If calls data shows the entity is only accessed via properties/methods
2049
+ // (e.g., formValidator.validate(), schema.superRefine()) and never directly
2050
+ // invoked (e.g., getInitialProps()), it's used as an object and should be
2051
+ // preserved rather than replaced with a Proxy stub.
2052
+ const onlyPropertyAccessed =
2053
+ importedExport.calls?.length > 0 &&
2054
+ !importedExport.calls.some((call: string) => {
2055
+ const afterName = call.slice(importedExport.name.length);
2056
+ return afterName.startsWith('(') || afterName.startsWith('<');
2057
+ });
1970
2058
 
1971
- // Callable entities can be safely stubbed (but not Zod schemas)
2059
+ // Callable entities can be safely stubbed. Entities that are only
2060
+ // property-accessed should be preserved (their methods need to work).
2061
+ // 'other' entities are unknown types — safer to preserve than stub.
1972
2062
  const isCallable =
1973
- !isDataEntity && !looksLikeZodSchema && entityType !== undefined;
2063
+ !isDataEntity &&
2064
+ !onlyPropertyAccessed &&
2065
+ entityType !== undefined &&
2066
+ entityType !== 'other';
1974
2067
 
1975
2068
  // Determine what action to take
1976
2069
  const shouldStripAndReplace = hasMock;
@@ -2670,6 +2763,20 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2670
2763
  debugLog(
2671
2764
  `[REMAINING LOOP] import ${remainingImportIndex}/${remainingImportPaths.length}: ${importPath}`,
2672
2765
  );
2766
+
2767
+ // Skip imports that point to generated CodeYam files (same skip logic as
2768
+ // rewriteRelativeModuleImports). Without this, MockData files from earlier
2769
+ // captures that get discovered by the TypeScript compiler would be treated as
2770
+ // regular imports, creating transitive copies with stale content.
2771
+ const scenarioFilePattern = /[a-f0-9]{64}_\w+_[A-Z]\w*$/;
2772
+ const mockDataPattern = /__codeyamMocks__\//;
2773
+ if (
2774
+ scenarioFilePattern.test(importPath) ||
2775
+ mockDataPattern.test(importPath)
2776
+ ) {
2777
+ continue;
2778
+ }
2779
+
2673
2780
  // Resolve the import path to a project file path
2674
2781
  const resolvedFilePath = resolveImportPath(importPath, file.path, project);
2675
2782
 
@@ -2916,6 +3023,83 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2916
3023
  // Scenario: ${scenario.id} - ${scenario.name}
2917
3024
  `;
2918
3025
 
3026
+ // Final pass: Rename any namespace imports (import * as X from '...') that have
3027
+ // corresponding mock code using ...X__cyOriginal spread pattern.
3028
+ // This handles cases where:
3029
+ // 1. The import path was rewritten by transitive import handling
3030
+ // 2. The import wasn't caught by the earlier renaming logic
3031
+ // We scan for all __cyOriginal references in the mock code and ensure the imports are renamed.
3032
+ const cyOriginalReferences = fileContent.match(/\.\.\.(\w+)__cyOriginal/g);
3033
+ if (cyOriginalReferences) {
3034
+ const uniqueNames = [
3035
+ ...new Set(
3036
+ cyOriginalReferences.map((ref) =>
3037
+ ref.replace('...', '').replace('__cyOriginal', ''),
3038
+ ),
3039
+ ),
3040
+ ];
3041
+ for (const name of uniqueNames) {
3042
+ // Match namespace imports for this name that haven't been renamed yet
3043
+ const namespaceImportRegex = new RegExp(
3044
+ `(import\\s+\\*\\s+as\\s+)${escapeRegExp(name)}(\\s+from\\s+['"][^'"]*['"])`,
3045
+ 'g',
3046
+ );
3047
+ fileContent = fileContent.replace(
3048
+ namespaceImportRegex,
3049
+ `$1${name}__cyOriginal$2`,
3050
+ );
3051
+ }
3052
+ }
3053
+
3054
+ // For route components (page.tsx, layout.tsx), the component IS the Next.js page.
3055
+ // There's no wrapper page to inject argumentsData as props (unlike non-route components
3056
+ // which get a scenarioComponent wrapper). We need to wrap the default export so that
3057
+ // the scenario's argumentsData is passed as props to the component.
3058
+ if (
3059
+ isFrameworkRoute(file, entity, framework, file === rootFile) &&
3060
+ rootAnalysis.metadata?.scenariosDataStructure?.arguments?.length > 0
3061
+ ) {
3062
+ const positionalArguments =
3063
+ rootAnalysis.metadata.scenariosDataStructure.arguments;
3064
+ const hasNamedArgs =
3065
+ positionalArguments.length === 1 &&
3066
+ typeof positionalArguments[0] === 'object';
3067
+
3068
+ if (hasNamedArgs) {
3069
+ // Match: export default function Name(
3070
+ // Also: export default async function Name(
3071
+ const defaultExportMatch = fileContent.match(
3072
+ /export\s+default\s+(async\s+)?function\s+(\w+)\s*\(/,
3073
+ );
3074
+
3075
+ if (defaultExportMatch) {
3076
+ const funcName = defaultExportMatch[2];
3077
+
3078
+ // Remove "export default" from the original function declaration
3079
+ fileContent = fileContent.replace(
3080
+ /export\s+default\s+(async\s+)?function\s+(\w+)\s*\(/,
3081
+ '$1function $2(',
3082
+ );
3083
+
3084
+ // Ensure scenarios import is present
3085
+ const mockDataPath = `${relativeMocksDir}/MockData_${safeFileName(scenario.name)}`;
3086
+ if (fileContent.indexOf('import { scenarios } from') === -1) {
3087
+ fileContent = `import { scenarios } from "${mockDataPath}";\n\n${fileContent}`;
3088
+ }
3089
+
3090
+ // Add wrapper default export that injects argumentsData as props.
3091
+ // Filter null values: the LLM uses null to mean "don't pass this prop"
3092
+ // but spreading { prop: null } explicitly passes null, which differs from
3093
+ // undefined (absent) and crashes components that check `prop !== undefined`.
3094
+ fileContent += `\n\nexport default function _CYRouteWrapper(props: any) {
3095
+ const _cyArgs = scenarios().data()?.['arguments']?.[0] ?? {};
3096
+ const _cyCleanArgs = Object.fromEntries(Object.entries(_cyArgs).filter(([_, v]) => v !== null));
3097
+ return <${funcName} {...props} {..._cyCleanArgs} />;
3098
+ }\n`;
3099
+ }
3100
+ }
3101
+ }
3102
+
2919
3103
  // Use the directive that was extracted at the beginning of processing
2920
3104
  // This ensures it stays at the very top even after imports are prepended
2921
3105
  // NOTE: We only preserve "use client" directives, NOT "use server" directives.
@@ -277,16 +277,17 @@ export default async function writeSimpleRoot(
277
277
  let mockKey: string | undefined;
278
278
 
279
279
  if (matchingKeys.length > 1) {
280
- // Parse root.tsx to find how this hook is used
281
- // Look for patterns like: const { prop1, prop2 } = useLoaderData()
282
- // or: const result = useLoaderData()
280
+ // Parse root.tsx to find how this hook is used, INCLUDING type parameters
281
+ // Look for patterns like: const { prop1, prop2 } = useLoaderData<LoaderData>()
282
+ // or: const result = useLoaderData<typeof loader>()
283
283
  const hookUsageRegex = new RegExp(
284
- `(?:const|let|var)\\s+(?:\\{([^}]+)\\}|([a-zA-Z_][a-zA-Z0-9_]*))\\s*=\\s*${entityName}(?:<[^>]*>)?\\s*\\(`,
284
+ `(?:const|let|var)\\s+(?:\\{([^}]+)\\}|([a-zA-Z_][a-zA-Z0-9_]*))\\s*=\\s*${entityName}(<[^>]+>)?\\s*\\(`,
285
285
  'g',
286
286
  );
287
287
 
288
288
  const matches = [...newContent.matchAll(hookUsageRegex)];
289
289
  const rootPropertyNames: string[] = [];
290
+ const typeParamsUsed: Set<string> = new Set();
290
291
 
291
292
  for (const match of matches) {
292
293
  if (match[1]) {
@@ -300,17 +301,26 @@ export default async function writeSimpleRoot(
300
301
  // Simple assignment: const result = ...
301
302
  rootPropertyNames.push(match[2]);
302
303
  }
304
+ // Capture type parameters used (e.g., "<LoaderData>", "<typeof loader>")
305
+ if (match[3]) {
306
+ typeParamsUsed.add(match[3]);
307
+ }
303
308
  }
304
309
 
305
- // Find a key that matches by call signature
306
- // For call signature format (e.g., "useLoaderData()"), just use the first match
307
- mockKey = matchingKeys[0];
310
+ // First, try to find a key that matches the exact type parameters used in the source
311
+ // e.g., if source has useLoaderData<LoaderData>(), prefer "useLoaderData<LoaderData>()" key
312
+ if (typeParamsUsed.size > 0) {
313
+ for (const typeParam of typeParamsUsed) {
314
+ const exactKey = `${entityName}${typeParam}()`;
315
+ if (matchingKeys.includes(exactKey)) {
316
+ mockKey = exactKey;
317
+ break;
318
+ }
319
+ }
320
+ }
308
321
 
309
- // Fallback: if no match found but there are multiple keys,
310
- // exclude the route's key (which we can identify from mockedImports variable names)
322
+ // Fallback: if no exact type parameter match, use the first match
311
323
  if (!mockKey) {
312
- // The route's variable names would be in its own analysis
313
- // For simplicity, just use the first key that's different from the most common pattern
314
324
  mockKey = matchingKeys[0];
315
325
  }
316
326
  } else if (matchingKeys.length === 1) {
@@ -121,10 +121,11 @@ const validateFiles = async () => {
121
121
  }
122
122
  };
123
123
 
124
- const createLinePrefixer = (stream, processName, outputStream) => {
124
+ const createLinePrefixer = (stream, processName, outputStream, onActivity) => {
125
125
  let buffer = '';
126
126
 
127
127
  stream.on('data', (chunk) => {
128
+ if (onActivity) onActivity();
128
129
  buffer += chunk.toString();
129
130
  const lines = buffer.split('\n');
130
131
 
@@ -147,19 +148,20 @@ const createLinePrefixer = (stream, processName, outputStream) => {
147
148
  };
148
149
 
149
150
  const spawnProcess = (command, args, processName, env = {}) => {
150
- return new Promise((resolve, reject) => {
151
- const childProcess = spawn(command, args, {
152
- shell: true,
153
- stdio: ['inherit', 'pipe', 'pipe'], // Inherit stdin, pipe stdout/stderr
154
- env: { ...process.env, ...env },
155
- });
151
+ const childProcess = spawn(command, args, {
152
+ stdio: ['inherit', 'pipe', 'pipe'],
153
+ env: { ...process.env, ...env },
154
+ });
156
155
 
157
- console.log(`Started ${processName} process with PID ${childProcess.pid}`);
158
- childProcesses.add(childProcess);
156
+ console.log(`Started ${processName} process with PID ${childProcess.pid}`);
157
+ childProcesses.add(childProcess);
159
158
 
160
- // Set up prefixed output for stdout and stderr
161
- createLinePrefixer(childProcess.stdout, processName, process.stdout);
162
- createLinePrefixer(childProcess.stderr, processName, process.stderr);
159
+ let lastActivityTime = Date.now();
160
+ const updateActivity = () => { lastActivityTime = Date.now(); };
161
+
162
+ const promise = new Promise((resolve, reject) => {
163
+ createLinePrefixer(childProcess.stdout, processName, process.stdout, updateActivity);
164
+ createLinePrefixer(childProcess.stderr, processName, process.stderr, updateActivity);
163
165
 
164
166
  childProcess.on('close', (code, signal) => {
165
167
  console.log(
@@ -169,7 +171,6 @@ const spawnProcess = (command, args, processName, env = {}) => {
169
171
  if (code === 0) {
170
172
  resolve();
171
173
  } else if (code === null && signal && isCleaningUp) {
172
- // Process was killed by signal during cleanup - this is expected, not an error
173
174
  console.log(
174
175
  `${processName} process was terminated by ${signal} during cleanup`,
175
176
  );
@@ -189,11 +190,13 @@ const spawnProcess = (command, args, processName, env = {}) => {
189
190
  reject(error);
190
191
  });
191
192
  });
193
+
194
+ return { promise, childProcess, getLastActivity: () => lastActivityTime };
192
195
  };
193
196
 
194
197
  const startPlaywrightCapture = () => {
195
198
  console.log('Starting Playwright capture service...');
196
- return spawnProcess(
199
+ const { promise } = spawnProcess(
197
200
  'node',
198
201
  [
199
202
  '--enable-source-maps',
@@ -204,40 +207,65 @@ const startPlaywrightCapture = () => {
204
207
  'playwright',
205
208
  { PROJECT_URL: 'http://localhost:3000' },
206
209
  );
210
+ return promise;
207
211
  };
208
212
 
209
213
  const runProjectSimulation = async (analysisIds) => {
210
- try {
211
- // server now uses rsync, so project directory is guaranteed clean, just ensure it exists
212
- await fs.mkdir(FIXED_PROJECT_PATH, { recursive: true });
214
+ await fs.mkdir(FIXED_PROJECT_PATH, { recursive: true });
213
215
 
214
- const analysisIdString = analysisIds.join(',');
215
- console.log(
216
- `Starting project simulation for analysis IDs: ${analysisIdString}`,
217
- );
216
+ const analysisIdString = analysisIds.join(',');
217
+ console.log(
218
+ `Starting project simulation for analysis IDs: ${analysisIdString}`,
219
+ );
218
220
 
219
- return spawnProcess(
220
- 'node',
221
- [
222
- '--enable-source-maps',
223
- './dist/project/start.js',
224
- '--packageManager',
225
- process.env.PACKAGE_MANAGER,
226
- '--absoluteProjectRootPath',
227
- FIXED_PROJECT_PATH,
228
- '--absoluteTempPath',
229
- FIXED_TEMP_PATH,
230
- '--port',
231
- '3000',
232
- '--framework',
233
- process.env.FRAMEWORK,
234
- ],
235
- 'project',
236
- { ANALYSIS_IDS: analysisIdString, READY_TO_BE_CAPTURED: 'true' },
237
- );
238
- } catch (error) {
239
- throw new Error(`Failed to run project simulation: ${error.message}`);
221
+ return spawnProcess(
222
+ 'node',
223
+ [
224
+ '--enable-source-maps',
225
+ './dist/project/start.js',
226
+ '--packageManager',
227
+ process.env.PACKAGE_MANAGER,
228
+ '--absoluteProjectRootPath',
229
+ FIXED_PROJECT_PATH,
230
+ '--absoluteTempPath',
231
+ FIXED_TEMP_PATH,
232
+ '--port',
233
+ '3000',
234
+ '--framework',
235
+ process.env.FRAMEWORK,
236
+ ],
237
+ 'project',
238
+ { ANALYSIS_IDS: analysisIdString, READY_TO_BE_CAPTURED: 'true' },
239
+ );
240
+ };
241
+
242
+ const killChildProcess = async (childProcess, processName) => {
243
+ if (!childProcess || childProcess.exitCode !== null || childProcess.killed) {
244
+ return;
240
245
  }
246
+ console.log(`Killing ${processName} process (PID ${childProcess.pid}) after timeout/stall`);
247
+ try {
248
+ process.kill(childProcess.pid, 'SIGTERM');
249
+ } catch (err) { /* already dead */ }
250
+
251
+ await new Promise((resolve) => {
252
+ const checkInterval = setInterval(() => {
253
+ if (!isProcessAlive(childProcess.pid)) {
254
+ clearInterval(checkInterval);
255
+ resolve();
256
+ }
257
+ }, 500);
258
+ setTimeout(() => {
259
+ clearInterval(checkInterval);
260
+ if (isProcessAlive(childProcess.pid)) {
261
+ try { process.kill(childProcess.pid, 'SIGKILL'); } catch (err) { /* ignore */ }
262
+ console.log(`Force-killed ${processName} process (PID ${childProcess.pid})`);
263
+ }
264
+ resolve();
265
+ }, 5000);
266
+ });
267
+
268
+ childProcesses.delete(childProcess);
241
269
  };
242
270
 
243
271
  const isQueueNotExistsError = (error) => {
@@ -317,19 +345,38 @@ const processWorkMessage = async (sqs, message, queueUrl, controlQueueUrl) => {
317
345
  }, timeoutMs);
318
346
  });
319
347
 
320
- try {
321
- // Race between the actual work and the timeout
322
- await Promise.race([
323
- runProjectSimulation(body.analysisIds),
324
- timeoutPromise,
325
- ]);
348
+ let projectProcess = null;
349
+ let stallHandle = null;
350
+ let batchSuccess = false;
326
351
 
352
+ try {
353
+ const { promise: simulationPromise, childProcess, getLastActivity } =
354
+ await runProjectSimulation(body.analysisIds);
355
+ projectProcess = childProcess;
356
+
357
+ // Stall detection: abort if no output for 10 minutes
358
+ const STALL_TIMEOUT_MS = 10 * 60 * 1000;
359
+ const stallPromise = new Promise((_, reject) => {
360
+ stallHandle = setInterval(() => {
361
+ const silentMs = Date.now() - getLastActivity();
362
+ if (silentMs >= STALL_TIMEOUT_MS) {
363
+ reject(new Error(`Project process stalled (no output for ${Math.round(silentMs / 60000)} min)`));
364
+ }
365
+ }, 60000);
366
+ });
367
+
368
+ await Promise.race([simulationPromise, timeoutPromise, stallPromise]);
369
+
370
+ batchSuccess = true;
327
371
  console.log(`Successfully processed analysis IDs: ${analysisIdString}`);
328
372
  } finally {
373
+ if (stallHandle) clearInterval(stallHandle);
329
374
  if (visibilityInterval) clearInterval(visibilityInterval);
330
375
  if (timeoutHandle) clearTimeout(timeoutHandle);
331
376
 
332
- // Send batch completion notification to control queue
377
+ await killChildProcess(projectProcess, 'project');
378
+
379
+ // Send batch completion notification to control queue with success/failure status
333
380
  try {
334
381
  await sqs.send(
335
382
  new SendMessageCommand({
@@ -337,11 +384,12 @@ const processWorkMessage = async (sqs, message, queueUrl, controlQueueUrl) => {
337
384
  MessageBody: JSON.stringify({
338
385
  type: 'batch_completed',
339
386
  analysisIds: body.analysisIds,
387
+ success: batchSuccess,
340
388
  }),
341
389
  }),
342
390
  );
343
391
  console.log(
344
- `Sent batch completion notification for ${body.analysisIds.length} analyses`,
392
+ `Sent batch completion notification (success=${batchSuccess}) for ${body.analysisIds.length} analyses`,
345
393
  );
346
394
  } catch (error) {
347
395
  // Log error but don't fail - orchestrator will eventually timeout/abandon
@@ -15,6 +15,18 @@
15
15
  "~codeyam/*": ["./packages/*"]
16
16
  },
17
17
  "sourceMap": true,
18
- "skipLibCheck": true
18
+ "skipLibCheck": true,
19
+ "types": [
20
+ "node",
21
+ "jest",
22
+ "jsdom",
23
+ "better-sqlite3",
24
+ "yargs",
25
+ "pg",
26
+ "ws",
27
+ "react",
28
+ "react-dom",
29
+ "react-resizable"
30
+ ]
19
31
  }
20
32
  }
@@ -16,7 +16,7 @@ export async function createAnalyzerTemplate(absoluteCodeyamRootPath) {
16
16
  await copyFolderToArchive({
17
17
  source: folder,
18
18
  destination: `${absoluteCodeyamRootPath}/${folderName}`,
19
- exclude: ['__tests__'],
19
+ exclude: ['__tests__', 'node_modules'],
20
20
  recursive: true,
21
21
  });
22
22
  }