@codeyam/codeyam-cli 0.1.0-staging.323686 → 0.1.0-staging.3ef993e

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 (924) 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 +25 -25
  4. package/analyzer-template/packages/ai/index.ts +7 -1
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +62 -18
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +101 -12
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +409 -50
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +21 -6
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1250 -253
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +31 -3
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +37 -15
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +367 -96
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  26. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  27. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  28. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +393 -8
  29. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +9 -5
  30. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +112 -5
  31. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  32. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +649 -142
  33. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +1 -1
  34. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  35. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  36. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  37. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  38. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  39. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  40. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +25 -13
  41. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +4 -3
  42. package/analyzer-template/packages/analyze/index.ts +2 -0
  43. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  44. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  45. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  46. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  47. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  48. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  49. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  50. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  51. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  52. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  53. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +89 -9
  54. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +27 -4
  55. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  56. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  57. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  58. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +0 -3
  59. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  60. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  61. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  62. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +61 -13
  63. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
  64. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +312 -19
  65. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +19 -9
  66. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +591 -75
  67. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  68. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  69. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  70. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  71. package/analyzer-template/packages/aws/package.json +10 -10
  72. package/analyzer-template/packages/database/index.ts +1 -0
  73. package/analyzer-template/packages/database/package.json +4 -4
  74. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  75. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  76. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  77. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  78. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  79. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  80. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  81. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  82. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +138 -0
  83. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  84. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  85. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  86. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  87. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  88. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  89. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  90. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  91. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  92. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  93. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  94. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  95. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  96. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  97. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  98. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  99. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  100. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  101. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  104. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  107. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  113. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  115. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  116. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +27 -0
  118. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  119. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  120. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  121. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  122. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  123. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  124. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  125. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  126. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  127. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  128. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  129. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  130. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  132. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  134. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  135. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  136. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  137. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  139. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  142. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  143. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  144. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  145. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  146. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  147. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  148. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  149. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  150. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  151. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  152. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  153. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  154. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  155. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  156. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  157. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  158. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  159. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  160. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  161. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  162. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  163. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  164. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  165. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  166. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  167. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  168. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  169. package/analyzer-template/packages/github/package.json +2 -2
  170. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  171. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  172. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  173. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +6 -5
  174. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  175. package/analyzer-template/packages/ui-components/package.json +1 -1
  176. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  177. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  178. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  179. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  180. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  181. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  182. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  183. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  184. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  185. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  186. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  187. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  188. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  189. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  190. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  191. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  192. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  193. package/analyzer-template/project/constructMockCode.ts +260 -60
  194. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  195. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  196. package/analyzer-template/project/start.ts +3 -0
  197. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  198. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  199. package/analyzer-template/project/writeMockDataTsx.ts +198 -8
  200. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  201. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  202. package/analyzer-template/tsconfig.json +13 -1
  203. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  204. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  205. package/background/src/lib/virtualized/project/constructMockCode.js +220 -45
  206. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  207. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  208. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  209. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  210. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  211. package/background/src/lib/virtualized/project/start.js +2 -0
  212. package/background/src/lib/virtualized/project/start.js.map +1 -1
  213. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  214. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  215. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  216. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  217. package/background/src/lib/virtualized/project/writeMockDataTsx.js +174 -4
  218. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  219. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  220. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  221. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  222. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  223. package/codeyam-cli/scripts/apply-setup.js +386 -9
  224. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  225. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  226. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  227. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  228. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  229. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  230. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  231. package/codeyam-cli/src/cli.js +33 -24
  232. package/codeyam-cli/src/cli.js.map +1 -1
  233. package/codeyam-cli/src/codeyam-cli.js +18 -2
  234. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  235. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  236. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  237. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  238. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  239. package/codeyam-cli/src/commands/analyze.js +21 -9
  240. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  241. package/codeyam-cli/src/commands/baseline.js +2 -0
  242. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  243. package/codeyam-cli/src/commands/debug.js +9 -5
  244. package/codeyam-cli/src/commands/debug.js.map +1 -1
  245. package/codeyam-cli/src/commands/default.js +44 -21
  246. package/codeyam-cli/src/commands/default.js.map +1 -1
  247. package/codeyam-cli/src/commands/editor.js +3374 -0
  248. package/codeyam-cli/src/commands/editor.js.map +1 -0
  249. package/codeyam-cli/src/commands/init.js +146 -292
  250. package/codeyam-cli/src/commands/init.js.map +1 -1
  251. package/codeyam-cli/src/commands/memory.js +97 -92
  252. package/codeyam-cli/src/commands/memory.js.map +1 -1
  253. package/codeyam-cli/src/commands/recapture.js +2 -0
  254. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  255. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  256. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  257. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  258. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  259. package/codeyam-cli/src/commands/test-startup.js +2 -0
  260. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  261. package/codeyam-cli/src/commands/verify.js +14 -2
  262. package/codeyam-cli/src/commands/verify.js.map +1 -1
  263. package/codeyam-cli/src/data/techStacks.js +77 -0
  264. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  266. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  268. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  270. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  271. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  272. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +987 -0
  274. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  276. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  278. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  280. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  281. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  282. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  284. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  286. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  287. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  288. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  289. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  290. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  291. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  292. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  293. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  294. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  295. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  296. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  297. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  298. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  299. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1059 -0
  300. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  301. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  302. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  303. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  304. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  305. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  306. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  307. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  308. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  309. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  310. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  311. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  312. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  313. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  314. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  315. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  316. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  317. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  318. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  319. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  320. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  321. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +454 -0
  322. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  323. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
  324. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  325. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  326. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  327. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  328. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  329. package/codeyam-cli/src/utils/analyzer.js +16 -0
  330. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  331. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  332. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  333. package/codeyam-cli/src/utils/backgroundServer.js +192 -29
  334. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  335. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  336. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  337. package/codeyam-cli/src/utils/database.js +37 -2
  338. package/codeyam-cli/src/utils/database.js.map +1 -1
  339. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  340. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  341. package/codeyam-cli/src/utils/devServerState.js +71 -0
  342. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  343. package/codeyam-cli/src/utils/editorApi.js +73 -0
  344. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  345. package/codeyam-cli/src/utils/editorAudit.js +210 -0
  346. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  347. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  348. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  349. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  350. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  351. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  352. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  353. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  354. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  355. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  356. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  357. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  358. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  359. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  360. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  361. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  362. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  363. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  364. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  365. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  366. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  367. package/codeyam-cli/src/utils/editorScenarios.js +387 -0
  368. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  369. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  370. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  371. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  372. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  373. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  374. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  375. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  376. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  377. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  378. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  379. package/codeyam-cli/src/utils/generateReport.js +2 -2
  380. package/codeyam-cli/src/utils/git.js +103 -0
  381. package/codeyam-cli/src/utils/git.js.map +1 -1
  382. package/codeyam-cli/src/utils/install-skills.js +114 -47
  383. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  384. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  385. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  386. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  387. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  388. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  389. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  390. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  391. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  392. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  393. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  394. package/codeyam-cli/src/utils/progress.js +8 -1
  395. package/codeyam-cli/src/utils/progress.js.map +1 -1
  396. package/codeyam-cli/src/utils/project.js +15 -5
  397. package/codeyam-cli/src/utils/project.js.map +1 -1
  398. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  399. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  400. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  401. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  402. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  403. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  404. package/codeyam-cli/src/utils/queue/job.js +74 -1
  405. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  406. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  407. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  408. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  409. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  410. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  411. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  412. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  413. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  414. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  415. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  416. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  417. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  418. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  419. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  420. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  421. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  422. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  423. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  424. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  425. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  426. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  427. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  428. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  429. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  430. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  431. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  432. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  433. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  434. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  435. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  436. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  437. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  438. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  439. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  440. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  441. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  442. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  443. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  444. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  445. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  446. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  447. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  448. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  449. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  450. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  451. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  452. package/codeyam-cli/src/utils/rules/index.js +2 -0
  453. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  454. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  455. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  456. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  457. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  458. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  459. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  460. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  461. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  462. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  463. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  464. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  465. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  466. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  467. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  468. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  469. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  470. package/codeyam-cli/src/utils/scenariosManifest.js +241 -0
  471. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  472. package/codeyam-cli/src/utils/serverState.js +94 -12
  473. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  474. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
  475. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  476. package/codeyam-cli/src/utils/simulationGateMiddleware.js +166 -0
  477. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  478. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  479. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  480. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  481. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  482. package/codeyam-cli/src/utils/testRunner.js +158 -0
  483. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  484. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  485. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  486. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  487. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  488. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  489. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  490. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  491. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  492. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  493. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  494. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  495. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  496. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +146 -0
  497. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  498. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  499. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  500. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  501. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  502. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  503. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  504. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  505. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  506. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  507. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  508. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  509. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  510. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
  511. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  512. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  513. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  515. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  516. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  517. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  518. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
  519. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  520. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-TSD3C211.js} +3 -3
  521. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  522. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  523. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  524. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
  525. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
  526. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  527. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  528. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  531. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  536. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  538. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  540. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  543. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  544. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  545. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  546. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  547. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  548. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  549. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  550. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  551. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  552. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  553. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  554. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  555. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  556. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  558. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  559. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  560. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  561. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  562. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  563. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  564. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  565. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Ii3inc0_.js +1 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/editor-COWCNVyV.js +10 -0
  567. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CNB06EIa.js +41 -0
  568. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-DwCV5__E.js} +12 -12
  569. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-CXSi2aeZ.js +6 -0
  570. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CHMiAog3.js +6 -0
  571. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  572. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  573. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  574. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  575. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
  576. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  577. package/codeyam-cli/src/webserver/build/client/assets/globals-phvmGvat.css +1 -0
  578. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  579. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  580. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  581. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  582. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  583. package/codeyam-cli/src/webserver/build/client/assets/manifest-6134dc40.js +1 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  585. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  586. package/codeyam-cli/src/webserver/build/client/assets/root-BWAyuj0r.js +67 -0
  587. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  588. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  589. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
  590. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  591. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  592. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C-_hOl_g.js +1 -0
  593. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  594. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  595. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  596. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  597. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  598. package/codeyam-cli/src/webserver/build/server/assets/index-ChX0hPcu.js +1 -0
  599. package/codeyam-cli/src/webserver/build/server/assets/init-kSNsMjj8.js +10 -0
  600. package/codeyam-cli/src/webserver/build/server/assets/server-build-Bm2xIhmh.js +439 -0
  601. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  602. package/codeyam-cli/src/webserver/build-info.json +5 -5
  603. package/codeyam-cli/src/webserver/devServer.js +39 -5
  604. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  605. package/codeyam-cli/src/webserver/editorProxy.js +877 -0
  606. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  607. package/codeyam-cli/src/webserver/idleDetector.js +73 -0
  608. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  609. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  610. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  611. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  612. package/codeyam-cli/src/webserver/server.js +300 -1
  613. package/codeyam-cli/src/webserver/server.js.map +1 -1
  614. package/codeyam-cli/src/webserver/terminalServer.js +735 -0
  615. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  616. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  617. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  618. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  619. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  620. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  621. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  622. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  623. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  624. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  625. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  626. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  627. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  628. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  629. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  630. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  631. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  632. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  633. package/codeyam-cli/templates/editor-step-hook.py +237 -0
  634. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  635. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  636. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  637. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  638. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  639. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  640. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  641. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  642. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  643. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  644. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  645. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  646. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  647. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  648. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  649. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  650. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  651. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  652. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  653. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  654. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  655. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  656. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  657. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  658. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  659. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  660. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  661. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  662. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  663. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  664. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  665. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  666. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  667. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  668. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  669. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  670. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  671. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  672. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  673. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  674. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  675. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  676. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  677. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  678. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  679. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  680. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  681. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  682. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  683. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  684. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  685. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  686. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  687. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  688. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  689. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  690. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  691. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  692. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  693. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  694. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  695. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  696. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  697. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  698. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  699. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  700. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  701. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  702. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  703. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  704. package/codeyam-cli/templates/rules-instructions.md +78 -0
  705. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  706. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  707. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +149 -0
  708. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  709. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  710. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  711. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  712. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  713. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  714. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  715. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  716. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  717. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  718. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  719. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  720. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  721. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  722. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  723. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  724. package/package.json +28 -21
  725. package/packages/ai/index.js +3 -2
  726. package/packages/ai/index.js.map +1 -1
  727. package/packages/ai/src/lib/analyzeScope.js +50 -13
  728. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  729. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +76 -12
  730. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  731. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  732. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  733. package/packages/ai/src/lib/astScopes/processExpression.js +317 -44
  734. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  735. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  736. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  737. package/packages/ai/src/lib/completionCall.js +10 -7
  738. package/packages/ai/src/lib/completionCall.js.map +1 -1
  739. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +996 -173
  740. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  741. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  742. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  743. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  744. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  745. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  746. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  747. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +33 -3
  748. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  749. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +36 -11
  750. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  751. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  752. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  753. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  754. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  755. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  756. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  757. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  758. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  759. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  760. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  761. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +309 -84
  762. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  763. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  764. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  765. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  766. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  767. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  768. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  769. package/packages/ai/src/lib/generateEntityScenarioData.js +284 -6
  770. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  771. package/packages/ai/src/lib/generateEntityScenarios.js +7 -1
  772. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  773. package/packages/ai/src/lib/generateExecutionFlows.js +96 -4
  774. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  775. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +447 -80
  776. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  777. package/packages/ai/src/lib/isolateScopes.js +39 -3
  778. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  779. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  780. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  781. package/packages/ai/src/lib/mergeStatements.js +70 -51
  782. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  783. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  784. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  785. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  786. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  787. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  788. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  789. package/packages/ai/src/lib/resolvePathToControllable.js +24 -14
  790. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  791. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  792. package/packages/analyze/index.js +1 -0
  793. package/packages/analyze/index.js.map +1 -1
  794. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  795. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  796. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  797. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  798. package/packages/analyze/src/lib/asts/index.js +4 -2
  799. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  800. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  801. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  802. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  803. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  804. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  805. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  806. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  807. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  808. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  809. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  810. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  811. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  812. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  813. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  814. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +65 -7
  815. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  816. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +24 -4
  817. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  818. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  819. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  820. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  821. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  822. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  823. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  824. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +0 -3
  825. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  826. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  827. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  828. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  829. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  830. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  831. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  832. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +56 -10
  833. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  834. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
  835. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  836. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +215 -17
  837. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  838. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +16 -8
  839. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  840. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +494 -56
  841. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  842. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  843. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  844. package/packages/analyze/src/lib/index.js +1 -0
  845. package/packages/analyze/src/lib/index.js.map +1 -1
  846. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  847. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  848. package/packages/database/index.js +1 -0
  849. package/packages/database/index.js.map +1 -1
  850. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  851. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  852. package/packages/database/src/lib/analysisToDb.js +1 -1
  853. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  854. package/packages/database/src/lib/branchToDb.js +1 -1
  855. package/packages/database/src/lib/branchToDb.js.map +1 -1
  856. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  857. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  858. package/packages/database/src/lib/commitToDb.js +1 -1
  859. package/packages/database/src/lib/commitToDb.js.map +1 -1
  860. package/packages/database/src/lib/fileToDb.js +1 -1
  861. package/packages/database/src/lib/fileToDb.js.map +1 -1
  862. package/packages/database/src/lib/kysely/db.js +8 -0
  863. package/packages/database/src/lib/kysely/db.js.map +1 -1
  864. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  865. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  866. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  867. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  868. package/packages/database/src/lib/loadCommits.js +23 -13
  869. package/packages/database/src/lib/loadCommits.js.map +1 -1
  870. package/packages/database/src/lib/loadEntities.js +0 -6
  871. package/packages/database/src/lib/loadEntities.js.map +1 -1
  872. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  873. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  874. package/packages/database/src/lib/projectToDb.js +1 -1
  875. package/packages/database/src/lib/projectToDb.js.map +1 -1
  876. package/packages/database/src/lib/saveFiles.js +1 -1
  877. package/packages/database/src/lib/saveFiles.js.map +1 -1
  878. package/packages/database/src/lib/scenarioToDb.js +1 -1
  879. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  880. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  881. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  882. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  883. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  884. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  885. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  886. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  887. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  888. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  889. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  890. package/packages/types/src/enums/ProjectFramework.js +2 -0
  891. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  892. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  893. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  894. package/scripts/npm-post-install.cjs +34 -0
  895. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  896. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  897. package/codeyam-cli/src/commands/list.js +0 -31
  898. package/codeyam-cli/src/commands/list.js.map +0 -1
  899. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  900. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  901. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  902. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  903. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  904. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  905. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  906. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  907. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  908. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  909. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  910. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  911. package/codeyam-cli/src/webserver/build/client/assets/globals-D3yhhV8x.css +0 -1
  912. package/codeyam-cli/src/webserver/build/client/assets/manifest-7522edd4.js +0 -1
  913. package/codeyam-cli/src/webserver/build/client/assets/memory-yxFcrxBX.js +0 -92
  914. package/codeyam-cli/src/webserver/build/client/assets/root-eVAaavTS.js +0 -62
  915. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  916. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  917. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  918. package/codeyam-cli/src/webserver/build/server/assets/index-DVzYx8PN.js +0 -1
  919. package/codeyam-cli/src/webserver/build/server/assets/server-build-4Cr0uToj.js +0 -257
  920. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  921. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  922. package/codeyam-cli/templates/codeyam:memory.md +0 -462
  923. package/codeyam-cli/templates/codeyam:new-rule.md +0 -13
  924. package/scripts/finalize-analyzer.cjs +0 -81
@@ -341,8 +341,9 @@ export default function constructMockCode(
341
341
  let dataStructureValue: string | undefined;
342
342
  let foundEntityWithSignature = false;
343
343
  let signatureSchema: DataStructure['signatureSchema'] | undefined;
344
+ let baseSchemaHasMethodCalls = false;
344
345
 
345
- for (const filePath in dependencySchemas) {
346
+ entitySearch: for (const filePath in dependencySchemas) {
346
347
  for (const entityName in dependencySchemas[filePath]) {
347
348
  // Match entity by base name (without generics/args)
348
349
  const entityBaseName = entityName.split(/[<(]/)[0];
@@ -378,15 +379,60 @@ export default function constructMockCode(
378
379
  });
379
380
 
380
381
  if (dataStructurePath) {
382
+ // Start with the base entity's return value schema
383
+ const baseReturnValueSchema =
384
+ dependencySchemas[filePath][entityName]?.returnValueSchema;
385
+ const mergedSchema = {
386
+ ...baseReturnValueSchema,
387
+ };
388
+
389
+ // Check if the base schema has method-call entries (e.g., .map().functionCallReturnValue)
390
+ // When it does, the scenario data is stored as an object with method keys, and
391
+ // array prototype methods need mock implementations. When it doesn't, the data
392
+ // is a raw array and native methods like .includes() work directly.
393
+ if (baseReturnValueSchema) {
394
+ baseSchemaHasMethodCalls = Object.keys(baseReturnValueSchema).some(
395
+ (k) =>
396
+ k.startsWith(baseMockName + '.') &&
397
+ k.includes('(') &&
398
+ k.includes('.functionCallReturnValue'),
399
+ );
400
+ }
401
+
402
+ // Merge in method-call dependencies that are separate entries.
403
+ // e.g., "activityTypes.find((a) => a.value === type)" is a separate dependency
404
+ // for a .find() call on activityTypes. We need to include these with a
405
+ // .functionCallReturnValue path so constructMockCode generates callable mock methods.
406
+ for (const otherEntityName in dependencySchemas[filePath]) {
407
+ if (otherEntityName === entityName) continue;
408
+ if (
409
+ otherEntityName.startsWith(baseMockName + '.') &&
410
+ otherEntityName.includes('(')
411
+ ) {
412
+ // Add a functionCallReturnValue entry for this method call.
413
+ // This ensures constructMockCode treats it as a function that returns data,
414
+ // generating a proper mock method with data lookup.
415
+ const fcrvPath = `${otherEntityName}.functionCallReturnValue`;
416
+ if (!mergedSchema[fcrvPath]) {
417
+ // Infer the return type from the method-call dependency's schema
418
+ const otherSchema =
419
+ dependencySchemas[filePath][otherEntityName]?.returnValueSchema;
420
+ // Look for element type (baseMockName[]) or fall back to 'unknown'
421
+ const elementType = otherSchema?.[`${baseMockName}[]`];
422
+ mergedSchema[fcrvPath] = elementType || 'unknown';
423
+ }
424
+ }
425
+ }
426
+
381
427
  relevantReturnValueSchema = fillInDirectSchemaGapsAndUnknowns({
382
- schema: dependencySchemas[filePath][entityName]?.returnValueSchema,
428
+ schema: mergedSchema,
383
429
  });
384
430
  // NOTE: clearAttributesFromMapping is disabled because it deletes
385
431
  // method calls on arrays (like .eq() after functionCallReturnValue: 'array')
386
432
  // However, we still need to remove duplicate function calls that create invalid syntax
387
433
  removeDuplicateFunctionCalls(relevantReturnValueSchema);
388
434
  dataStructureValue = relevantReturnValueSchema?.[dataStructurePath];
389
- break;
435
+ break entitySearch;
390
436
  }
391
437
  }
392
438
  }
@@ -462,7 +508,10 @@ export default function constructMockCode(
462
508
  const argsString = args.join(', ');
463
509
 
464
510
  // Generate empty mock function
465
- return `function ${mockName}(${argsString}) {
511
+ // Use baseMockName (not mockName) because mockName may contain a full call
512
+ // signature with argument expressions (e.g., "logSignOutAction(sessionUser.id, ...)")
513
+ // which would produce invalid syntax as function parameter names.
514
+ return `function ${baseMockName}(${argsString}) {
466
515
  // Empty mock - original function mocked out
467
516
  }`;
468
517
  }
@@ -510,13 +559,13 @@ export default function constructMockCode(
510
559
 
511
560
  if (firstArgIsFunctionOrUnknown && returnsFunction) {
512
561
  // HOC pattern detected - return the first argument
513
- return `function ${mockName}(${argsString}) {
562
+ return `function ${baseMockName}(${argsString}) {
514
563
  return arg1;
515
564
  }`;
516
565
  }
517
566
 
518
567
  // Generate empty mock function
519
- return `function ${mockName}(${argsString}) {
568
+ return `function ${baseMockName}(${argsString}) {
520
569
  // Empty mock - original function mocked out
521
570
  }`;
522
571
  }
@@ -697,10 +746,6 @@ export default function constructMockCode(
697
746
  }
698
747
 
699
748
  const addReturnValueFunctionAccessor = (dataPath: string) => {
700
- // Add function call accessor if:
701
- // - There are actual arguments, OR
702
- // - This is a callable (not a method that returns an array directly)
703
- // For methods like getAll() that return arrays, the data is at ["getAll()"] not ["getAll()"]["()"]
704
749
  if (
705
750
  returnValue.returnsFunctionArgs &&
706
751
  (returnValue.returnsFunctionArgs.length > 0 ||
@@ -709,7 +754,17 @@ export default function constructMockCode(
709
754
  if (returnValue.isArray) {
710
755
  dataPath = `${dataPath}${optionalAccess('[0]')}`;
711
756
  }
712
- dataPath = `${dataPath}${optionalAccess(`(${safeString(returnValue.returnsFunctionArgs.join(', '))})`)}`;
757
+ // Only add the function call accessor ?.["(args)"] when there are actual
758
+ // arguments. When returnsFunctionArgs is empty [] (function-returns-function
759
+ // with no specific arg patterns), skip the ?.["()"] because:
760
+ // 1. preprocessSchemaForMocks collapses nested functionCallReturnValue chains
761
+ // into flat entries (e.g., getTranslate() = string, not {(): string})
762
+ // 2. The mock data is a flat value, so ?.["()"] on a string returns undefined
763
+ // 3. constructContent still wraps the return in a function (via returnsFunctionArgs)
764
+ // so the function-returns-function behavior is preserved without data nesting
765
+ if (returnValue.returnsFunctionArgs.length > 0) {
766
+ dataPath = `${dataPath}${optionalAccess(`(${safeString(returnValue.returnsFunctionArgs.join(', '))})`)}`;
767
+ }
713
768
  }
714
769
  return dataPath;
715
770
  };
@@ -750,29 +805,6 @@ export default function constructMockCode(
750
805
  hasNoReturnData,
751
806
  } = returnValue;
752
807
 
753
- // When an array has differentiated indices ([0], [1], etc.), filter out any
754
- // non-index items from nested. These non-index items come from generic [] paths
755
- // like [].filter or [].sort, which describe element properties, not array elements.
756
- // Including them would generate invalid syntax like "sort: ..." inside an array literal.
757
- const hasDifferentiatedIndices =
758
- isArray &&
759
- nested &&
760
- nested.some((n) => n.name.match(/^\[\d+\]$/) && n.name !== '[0]');
761
- const filteredNested =
762
- hasDifferentiatedIndices && nested
763
- ? nested.filter((n) => n.name.match(/^\[\d+\]$/))
764
- : nested;
765
-
766
- const nestedContent: (string | undefined)[] = (filteredNested ?? []).map(
767
- (nestedItem) => {
768
- const nestedContent = constructReturnValueString(
769
- nestedItem,
770
- dataPaths,
771
- );
772
- return nestedContent;
773
- },
774
- );
775
-
776
808
  // Array prototype methods that should be ignored when building mocks
777
809
  // (these work on any array - we don't need to mock them)
778
810
  const ARRAY_PROTOTYPE_METHODS = new Set([
@@ -817,6 +849,48 @@ export default function constructMockCode(
817
849
  'length',
818
850
  ]);
819
851
 
852
+ // When an array has differentiated indices ([0], [1], etc.), filter out any
853
+ // non-index items from nested. These non-index items come from generic [] paths
854
+ // like [].filter or [].sort, which describe element properties, not array elements.
855
+ // Including them would generate invalid syntax like "sort: ..." inside an array literal.
856
+ const hasDifferentiatedIndices =
857
+ isArray &&
858
+ nested &&
859
+ nested.some((n) => n.name.match(/^\[\d+\]$/) && n.name !== '[0]');
860
+ let filteredNested =
861
+ hasDifferentiatedIndices && nested
862
+ ? nested.filter((n) => n.name.match(/^\[\d+\]$/))
863
+ : nested;
864
+
865
+ // When a variable IS an array (not a function returning an array),
866
+ // filter out array prototype methods like .includes(), .filter(), etc.
867
+ // ONLY when the base schema has no method-call entries. When the base
868
+ // schema has methods (e.g., .map().functionCallReturnValue), the scenario
869
+ // data is stored as an object with method-call keys, and ALL methods
870
+ // need mock implementations. When the base schema has no methods, the
871
+ // data is a raw array and native methods like .includes() work directly.
872
+ if (
873
+ isArray &&
874
+ !returnsFunctionArray &&
875
+ !baseSchemaHasMethodCalls &&
876
+ filteredNested
877
+ ) {
878
+ filteredNested = filteredNested.filter((n) => {
879
+ const methodName = n.name.replace(/[<(].*$/, '');
880
+ return !ARRAY_PROTOTYPE_METHODS.has(methodName);
881
+ });
882
+ }
883
+
884
+ const nestedContent: (string | undefined)[] = (filteredNested ?? []).map(
885
+ (nestedItem) => {
886
+ const nestedContent = constructReturnValueString(
887
+ nestedItem,
888
+ dataPaths,
889
+ );
890
+ return nestedContent;
891
+ },
892
+ );
893
+
820
894
  const levelContentItems = [];
821
895
  // Add spread for data paths when:
822
896
  // - Not a function returning an array, OR function returns array with custom methods
@@ -1189,11 +1263,20 @@ export default function constructMockCode(
1189
1263
  // Valid patterns where arrow function is NOT bare:
1190
1264
  // 1. Property value: "key: (arg) => ..." - ends with ':'
1191
1265
  // 2. Function argument: ".map((arg) => ..." - ends with '('
1266
+ // 3. Method call: "?.map" followed directly by the arrow function
1267
+ // In this case, the '(' is consumed by the arrow function regex match,
1268
+ // so beforeTrimmed ends with the method name (e.g., 'map'), not '('.
1269
+ // We detect this by checking if beforeTrimmed ends with an identifier
1270
+ // that could be a method name (preceded by '.' or '?.').
1192
1271
  // NOTE: We don't include ',' because "{ prop, () => {} }" is invalid
1193
1272
  // (can't distinguish function argument from object property context)
1194
1273
  const isPropertyValue = beforeTrimmed.endsWith(':');
1195
1274
  const isFunctionArg = beforeTrimmed.endsWith('(');
1196
- const hasPropertyName = isPropertyValue || isFunctionArg;
1275
+ // Check if before ends with a method call pattern like ".map" or "?.map"
1276
+ // The '(' after the method name is consumed by the arrow function regex
1277
+ const isMethodCallArg = /\??\.\w+$/.test(beforeTrimmed);
1278
+ const hasPropertyName =
1279
+ isPropertyValue || isFunctionArg || isMethodCallArg;
1197
1280
 
1198
1281
  if (!hasPropertyName) {
1199
1282
  // This is a bare arrow function - filter it out
@@ -1404,6 +1487,17 @@ export default function constructMockCode(
1404
1487
  .replace(/,\s*$/, '');
1405
1488
  returnValueContents = `${arrayBasePath}?.map((__item__, __idx__) => (\n${indent(trimmedContent)}\n))`;
1406
1489
  } else {
1490
+ // When generating object-wrapped .map(), ensure original item data is preserved.
1491
+ // If no data spread was included (e.g., because this is a plain array property,
1492
+ // not a function return), add ...__item__ to spread the original item properties.
1493
+ // Without this, the .map() would create new objects with only nested function
1494
+ // properties, losing data like filePath, frontmatter, body, etc.
1495
+ const hasDataSpread =
1496
+ mappedContents.includes('...scenarios()') ||
1497
+ mappedContents.includes('...__item__');
1498
+ if (!hasDataSpread) {
1499
+ mappedContents = `...__item__,\n${mappedContents}`;
1500
+ }
1407
1501
  returnValueContents = `${arrayBasePath}?.map((__item__, __idx__) => ({\n${indent(mappedContents)}\n}))`;
1408
1502
  }
1409
1503
  } // Close the empty content check else block
@@ -1470,6 +1564,17 @@ export default function constructMockCode(
1470
1564
  mappedContents = filterOutArrowFunctions(mappedContents);
1471
1565
  mappedContents = filterOutBareObjects(mappedContents, true);
1472
1566
  mappedContents = cleanupContent(mappedContents);
1567
+ // Same as needsWrapper branch: ensure item data is preserved in .map()
1568
+ const hasDataSpreadInner =
1569
+ mappedContents.includes('...scenarios()') ||
1570
+ mappedContents.includes('...__item__');
1571
+ if (!hasDataSpreadInner && mappedContents.trim().length > 0) {
1572
+ // Insert ...__item__ after the opening brace
1573
+ mappedContents = mappedContents.replace(
1574
+ /^\s*\{/,
1575
+ '{\n...__item__,',
1576
+ );
1577
+ }
1473
1578
  returnValueContents = `${arrayBasePath}?.map((__item__, __idx__) => (\n${indent(mappedContents)}\n))`;
1474
1579
  }
1475
1580
  } else {
@@ -1605,19 +1710,38 @@ export default function constructMockCode(
1605
1710
  fallbackContent;
1606
1711
  content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1607
1712
  } else {
1608
- // No argument variants - use existing behavior
1609
- // But if there's nested content, we need to include it in the return object
1610
- // (similar to how argument variant branches handle this at line 1070-1072)
1611
- const hasNestedContent = validNestedContent.length > 0;
1612
- let funcReturnContents: string;
1613
- if (hasNestedContent && levelContentItems.length > 1) {
1614
- // Include both spread and nested content in the return
1615
- funcReturnContents = `{\n${indent(levelContents)}\n}`;
1713
+ // No argument variants
1714
+ // Check if this is an array method callback containing JSX.
1715
+ // JSX can't be serialized to JSON, so the LLM generates [{}] as data.
1716
+ // Instead of returning that unusable data, generate a passthrough that
1717
+ // calls the real callback on the best available array data from siblings.
1718
+ const containsJsx = dataPaths.some((p) => /<[A-Z]/.test(p));
1719
+ const isArrayMethod = ARRAY_PROTOTYPE_METHODS.has(name);
1720
+
1721
+ if (containsJsx && isArrayMethod && dataPaths.length > 0) {
1722
+ // Extract parent data path by removing the last ?.["..."] segment
1723
+ const parentPath = dataPaths[0].replace(/\?\.\["[^"]*"\]$/, '');
1724
+ const funcLines = [
1725
+ `const _d = ${parentPath};`,
1726
+ `const _a = Object.values(_d || {}).filter(v => Array.isArray(v) && v.length > 0 && v.some(i => i && typeof i === "object" && Object.keys(i).length > 0)).sort((a, b) => b.length - a.length);`,
1727
+ `return _a[0] ? _a[0].${name}(${argsString}) : []`,
1728
+ ];
1729
+ const funcContents = funcLines.join('\n');
1730
+ content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1616
1731
  } else {
1617
- funcReturnContents = returnValueContents;
1732
+ // But if there's nested content, we need to include it in the return object
1733
+ // (similar to how argument variant branches handle this at line 1070-1072)
1734
+ const hasNestedContent = validNestedContent.length > 0;
1735
+ let funcReturnContents: string;
1736
+ if (hasNestedContent && levelContentItems.length > 1) {
1737
+ // Include both spread and nested content in the return
1738
+ funcReturnContents = `{\n${indent(levelContents)}\n}`;
1739
+ } else {
1740
+ funcReturnContents = returnValueContents;
1741
+ }
1742
+ const funcContents = `return ${funcReturnContents}`;
1743
+ content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1618
1744
  }
1619
- const funcContents = `return ${funcReturnContents}`;
1620
- content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1621
1745
  }
1622
1746
  } else {
1623
1747
  if (!isValidKey(name)) {
@@ -1693,6 +1817,42 @@ export default function constructMockCode(
1693
1817
  return 0;
1694
1818
  });
1695
1819
 
1820
+ // OPTIMIZATION: Pre-compute prefix indexes for O(1) lookups instead of O(n) scans.
1821
+ // This reduces complexity from O(n²) to O(n) for large schemas (9k+ keys).
1822
+ //
1823
+ // 1. extendedReturnValuePrefixes: Set of all path prefixes that have a .functionCallReturnValue extension
1824
+ // Used by hasExtendedFunctionCallReturnValue check at line ~1754
1825
+ // 2. functionCallsWithReturnValue: Set of function call paths where .functionCallReturnValue IMMEDIATELY follows
1826
+ // Used by hasProperFunctionCallPath check at line ~1787
1827
+ // IMPORTANT: Only includes paths where the function call is directly followed by .functionCallReturnValue
1828
+ // e.g., "a.b().functionCallReturnValue" -> adds "a.b()" but NOT "a" even if "a" ends with ")"
1829
+ const extendedReturnValuePrefixes = new Set<string>();
1830
+ const functionCallsWithReturnValue = new Set<string>();
1831
+
1832
+ for (const k of relevantKeys) {
1833
+ const parts = splitOutsideParenthesesAndArrays(k);
1834
+ const returnValueIndex = parts.findIndex((part) =>
1835
+ part.startsWith(RETURN_VALUE),
1836
+ );
1837
+ if (returnValueIndex !== -1) {
1838
+ // Add all prefixes of k up to (but not including) functionCallReturnValue
1839
+ const prefix = joinParenthesesAndArrays(parts.slice(0, returnValueIndex));
1840
+ extendedReturnValuePrefixes.add(prefix);
1841
+
1842
+ // ONLY add to functionCallsWithReturnValue if functionCallReturnValue IMMEDIATELY follows
1843
+ if (prefix.endsWith(')')) {
1844
+ functionCallsWithReturnValue.add(prefix);
1845
+ }
1846
+
1847
+ // Also add intermediate prefixes for nested paths to extendedReturnValuePrefixes
1848
+ // This helps hasExtendedFunctionCallReturnValue which checks key + '.'
1849
+ for (let i = 1; i < returnValueIndex; i++) {
1850
+ const partialPrefix = joinParenthesesAndArrays(parts.slice(0, i));
1851
+ extendedReturnValuePrefixes.add(partialPrefix);
1852
+ }
1853
+ }
1854
+ }
1855
+
1696
1856
  for (const key of sortedKeys) {
1697
1857
  const value = relevantReturnValueSchema[key];
1698
1858
  const parts = splitOutsideParenthesesAndArrays(key);
@@ -1749,9 +1909,10 @@ export default function constructMockCode(
1749
1909
  // nested inside (e.g., methods on array elements passed as arguments).
1750
1910
  if (hasSignaturePath) continue;
1751
1911
 
1752
- const hasExtendedFunctionCallReturnValue = Object.keys(
1753
- relevantReturnValueSchema,
1754
- ).some((k) => k.startsWith(key + '.') && k.includes(`.${RETURN_VALUE}`));
1912
+ // OPTIMIZATION: Use pre-computed index instead of O(n) scan
1913
+ // Old code: Object.keys(relevantReturnValueSchema).some((k) => k.startsWith(key + '.') && k.includes('.functionCallReturnValue'))
1914
+ const hasExtendedFunctionCallReturnValue =
1915
+ extendedReturnValuePrefixes.has(key);
1755
1916
 
1756
1917
  // Skip JSX components - they look like function calls (e.g., Context.Provider())
1757
1918
  // but they're React components used in JSX, not functions that need mocking
@@ -1780,11 +1941,10 @@ export default function constructMockCode(
1780
1941
  const functionCallPath = joinParenthesesAndArrays(
1781
1942
  parts.slice(0, i + 1),
1782
1943
  );
1783
- const hasProperFunctionCallPath = Object.keys(
1784
- relevantReturnValueSchema,
1785
- ).some((k) =>
1786
- k.startsWith(functionCallPath + '.functionCallReturnValue'),
1787
- );
1944
+ // OPTIMIZATION: Use pre-computed index instead of O(n) scan
1945
+ // Old code: Object.keys(relevantReturnValueSchema).some((k) => k.startsWith(functionCallPath + '.functionCallReturnValue'))
1946
+ const hasProperFunctionCallPath =
1947
+ functionCallsWithReturnValue.has(functionCallPath);
1788
1948
  if (hasProperFunctionCallPath) {
1789
1949
  // Skip this path - the .functionCallReturnValue path will handle it correctly
1790
1950
  shouldSkipKey = true;
@@ -2221,6 +2381,23 @@ export default function constructMockCode(
2221
2381
  }
2222
2382
  }
2223
2383
 
2384
+ // Post-processing: When the root functionCallReturnValue is typed as "function" but the
2385
+ // return value also has nested properties (methods like .from(), .auth, etc.), it's actually
2386
+ // an object, not a function to be called. Clear returnsFunctionArgs to prevent double-wrapping
2387
+ // (adding an extra () => { return { ... } } wrapper and ["()"] data paths).
2388
+ // This handles cases like Supabase's createClient() which returns an object with methods.
2389
+ // Only applied to the root level - nested parts that are functions with methods (like
2390
+ // useSearchParams()[1] which is a setter function with .set() and .delete()) should keep
2391
+ // their returnsFunctionArgs since they genuinely ARE functions.
2392
+ if (
2393
+ returnValueParts.returnsFunctionArgs &&
2394
+ returnValueParts.returnsFunctionArgs.length === 0 &&
2395
+ returnValueParts.nested &&
2396
+ returnValueParts.nested.length > 0
2397
+ ) {
2398
+ returnValueParts.returnsFunctionArgs = undefined;
2399
+ }
2400
+
2224
2401
  const contents = constructReturnValueString(returnValueParts);
2225
2402
 
2226
2403
  if (mockNameParts.length > 1) {
@@ -2293,16 +2470,26 @@ export default function constructMockCode(
2293
2470
  const nameAssignment = isErrorSubclass
2294
2471
  ? `this.name = '${baseMockName}';`
2295
2472
  : '';
2296
- // Use the safe function name for the class definition
2297
- const className = mockNameIsCallSignature
2298
- ? derivedFunctionName
2299
- : baseMockName;
2473
+ // Use the base class name for the class definition, not the call-signature-derived name.
2474
+ // When mockName is "StatsCalculator(supabase)", baseMockName is "StatsCalculator"
2475
+ // and derivedFunctionName would be "StatsCalculator_supabase" which is wrong.
2476
+ // Classes are instantiated with `new ClassName(args)` so the name must match the original.
2477
+ const className = baseMockName;
2478
+
2479
+ // Use the already-generated contents (which has proper function wrappers for methods)
2480
+ // instead of raw scenarios().data() which would create non-callable string-keyed properties.
2481
+ // For classes with methods like calculateStats(), the contents will have:
2482
+ // { calculateStats: (...args) => scenarios().data()?.["key"]?.["calculateStats(...)"], ... }
2483
+ // which makes methods callable on the instance.
2484
+ const classContents = enhancedContents.trim().startsWith('{')
2485
+ ? enhancedContents
2486
+ : `scenarios().data()?.${quotePropertyKey(dataKey)} || {}`;
2300
2487
 
2301
2488
  return `class ${className}${isErrorSubclass ? ' extends Error' : ''} {
2302
2489
  constructor(message) {
2303
2490
  ${superCall}
2304
2491
  ${nameAssignment}
2305
- Object.assign(this, scenarios().data()?.${quotePropertyKey(dataKey)} || {});
2492
+ Object.assign(this, ${classContents});
2306
2493
  }
2307
2494
  }`;
2308
2495
  }
@@ -2383,7 +2570,20 @@ export default function constructMockCode(
2383
2570
  const safeReturnValue = isSimpleDataPath
2384
2571
  ? `${returnValue} ?? {}`
2385
2572
  : returnValue;
2386
- return `${isRootAsyncFunction ? 'async ' : ''}function ${safeFunctionName}(...args) {\n${indent(`return ${safeReturnValue};`)}\n}`;
2573
+ const refName = `_${safeFunctionName}Ref`;
2574
+ const assignment = `${refName}.current = ${safeReturnValue};`;
2575
+ const ifBlock = `if (!${refName}.current) {\n${indent(assignment)}\n}`;
2576
+ const body = `${ifBlock}\nreturn ${refName}.current;`;
2577
+
2578
+ return [
2579
+ `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)`,
2580
+ `const ${refName} = {`,
2581
+ ` current: null,`,
2582
+ `};`,
2583
+ `${isRootAsyncFunction ? 'async ' : ''}function ${safeFunctionName}(...args) {`,
2584
+ indent(body),
2585
+ `}`,
2586
+ ].join('\n');
2387
2587
  } else {
2388
2588
  // Generate safe const name:
2389
2589
  // 1. For call signatures: use derivedFunctionName
@@ -32,7 +32,10 @@ import type {
32
32
  } from './orchestrateCapture/taskRunner';
33
33
  import KyselyAnalysisLoader from './orchestrateCapture/KyselyAnalysisLoader';
34
34
 
35
- const MAX_BATCH_SIZE = 6;
35
+ // Temporarily set to 1 (effectively disabling batching) to work around reliability
36
+ // issues where multi-analysis batches cause cascading failures. Revisit once we
37
+ // reassess the SQS protocol and worker error handling.
38
+ const MAX_BATCH_SIZE = 1;
36
39
  const POLLING_INTERVAL = 30 * 1000; // 30 seconds
37
40
  const TASK_HEALTH_CHECK_INTERVAL = 60 * 1000; // 1 minute
38
41
  const ANALYSIS_TIMEOUT = 20 * 60 * 1000;
@@ -26,22 +26,21 @@ export function reconcileMockDataKeys(
26
26
  ? reconcileMockDataKeys(value as Record<string, unknown>, expectedKeys)
27
27
  : value;
28
28
 
29
- // Check if key matches an expected key exactly
30
- if (expectedKeys.includes(key)) {
31
- result[key] = reconciledValue;
32
- continue;
33
- }
34
-
35
- // Check if this is a flat dotted key that should be converted to nested structure
36
- // e.g., "trpc.fastener.getAttributeValues.useQuery({ ... })"
29
+ // Check if this is a flat dotted key (method chain) that should be nested.
30
+ // e.g., "ZId.safeParse(params.surveyId)" → { ZId: { "safeParse(params.surveyId)": ... } }
31
+ // e.g., "trpc.fastener.getAttributeValues.useQuery({ ... })" → nested structure
32
+ // constructMockCode generates nested lookups like data["ZId"]["safeParse(...)"]
33
+ // for method chains, so the data must be nested to match.
37
34
  const flatKeyParts = parseFlatDottedKey(key);
38
35
  if (flatKeyParts && flatKeyParts.length > 1) {
39
- // Check if the parts match expected keys (indicating this should be nested)
40
- const partsMatchExpected = flatKeyParts.some((part) =>
41
- expectedKeys.includes(part),
42
- );
43
- if (partsMatchExpected) {
44
- // Convert flat key to nested structure and merge
36
+ // Nest when:
37
+ // 1. The full key matches an expected key exactly (e.g., "ZId.safeParse(params.surveyId)")
38
+ // 2. OR individual parts match expected keys (e.g., "trpc" is an expected key)
39
+ // This handles LLM-generated flat keys that should be nested (Issue 8)
40
+ const shouldNest =
41
+ expectedKeys.includes(key) ||
42
+ flatKeyParts.some((part) => expectedKeys.includes(part));
43
+ if (shouldNest) {
45
44
  deepMergeIntoResult(
46
45
  result,
47
46
  flatKeyParts,
@@ -52,6 +51,12 @@ export function reconcileMockDataKeys(
52
51
  }
53
52
  }
54
53
 
54
+ // Check if key matches an expected key exactly (for non-dotted keys)
55
+ if (expectedKeys.includes(key)) {
56
+ result[key] = reconciledValue;
57
+ continue;
58
+ }
59
+
55
60
  // Try to find closest match using existing logic
56
61
  const closestKey = findClosestKey(key, expectedKeys);
57
62
  if (closestKey) {
@@ -313,6 +313,9 @@ async function main({
313
313
  : envConfig.entityShas,
314
314
  full: orchestrateCapture === 'local-sequential',
315
315
  taskRunner,
316
+ // Poll faster in local mode - no DB load concerns like in cloud
317
+ pollingInterval:
318
+ orchestrateCapture === 'local-sequential' ? 5 * 1000 : undefined,
316
319
  // Always track capture progress on the commit, even when not filtering by it.
317
320
  metadataCommit: sharedContext.commit ?? sharedContext.branchCommit,
318
321
  });
@@ -6,6 +6,7 @@ import writeUniversalMocks from './writeUniversalMocks';
6
6
  import writeScenario from './writeScenario';
7
7
  import writeSimpleRoot from './writeSimpleRoot';
8
8
  import writeCodeYamPage from './writeCodeYamPage';
9
+ import writeClientLogRoute from './writeClientLogRoute';
9
10
  import {
10
11
  runMultiScenarioServer,
11
12
  ScenarioToCapture,
@@ -497,6 +498,14 @@ export async function startScenarioCapture({
497
498
  );
498
499
  allGeneratedFiles.push(codeyamPagePath);
499
500
 
501
+ // Write client-log API route so client-side errors appear in the server log
502
+ const clientLogPath = await writeClientLogRoute(
503
+ project,
504
+ framework,
505
+ analysis.filePath,
506
+ );
507
+ if (clientLogPath) allGeneratedFiles.push(clientLogPath);
508
+
500
509
  // Persist file tracking for crash/debug recovery
501
510
  writeTrackingFile(allGeneratedFiles, backupFiles);
502
511
  }