@codeyam/codeyam-cli 0.1.0-staging.4c0c3c9 → 0.1.0-staging.5370992

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 (861) 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 +24 -24
  4. package/analyzer-template/packages/ai/package.json +3 -3
  5. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  6. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +135 -0
  7. package/analyzer-template/packages/ai/src/lib/astScopes/nodeToSource.ts +19 -0
  8. package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +11 -4
  9. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  10. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +295 -14
  11. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +10 -3
  12. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +16 -6
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  15. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +15 -6
  16. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +78 -2
  17. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +96 -33
  18. package/analyzer-template/packages/analyze/index.ts +4 -1
  19. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  20. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  21. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  22. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +28 -2
  23. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +14 -37
  24. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  25. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +22 -6
  26. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +9 -12
  27. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +21 -0
  28. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +82 -10
  29. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +4 -0
  30. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +4 -0
  31. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +8 -3
  32. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +65 -28
  33. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +322 -58
  34. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  35. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1707 -1466
  36. package/analyzer-template/packages/aws/package.json +10 -10
  37. package/analyzer-template/packages/database/index.ts +1 -0
  38. package/analyzer-template/packages/database/package.json +4 -4
  39. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
  40. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  41. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +25 -15
  42. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  43. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  44. package/analyzer-template/packages/database/src/lib/loadEntity.ts +19 -8
  45. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  46. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  47. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  48. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  49. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  50. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  51. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  52. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  53. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  54. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  55. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  56. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  57. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  58. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  59. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  60. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  61. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  62. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  63. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  64. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  65. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  66. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +7 -1
  67. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  68. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  69. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  70. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  71. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  72. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  73. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  74. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +4 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +5 -5
  77. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  80. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  83. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  86. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  88. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  89. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  90. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  91. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  92. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  93. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  94. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  95. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  96. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  97. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  98. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  99. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  100. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  101. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  103. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  104. package/analyzer-template/packages/github/package.json +1 -1
  105. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  106. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  107. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  108. package/analyzer-template/packages/ui-components/package.json +1 -1
  109. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  110. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  111. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  112. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  113. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  114. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  116. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  117. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +3 -1
  118. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  119. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +28 -3
  120. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  121. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +41 -2
  122. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  123. package/analyzer-template/project/analyzeFileEntities.ts +26 -0
  124. package/analyzer-template/project/constructMockCode.ts +168 -48
  125. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  126. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  127. package/analyzer-template/project/runMultiScenarioServer.ts +26 -3
  128. package/analyzer-template/project/start.ts +3 -0
  129. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  130. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  131. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  132. package/analyzer-template/project/writeScenarioComponents.ts +110 -17
  133. package/analyzer-template/tsconfig.json +13 -1
  134. package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
  135. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  136. package/background/src/lib/virtualized/project/constructMockCode.js +143 -39
  137. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  138. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  139. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  140. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  141. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  142. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +23 -3
  143. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -1
  144. package/background/src/lib/virtualized/project/start.js +2 -0
  145. package/background/src/lib/virtualized/project/start.js.map +1 -1
  146. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  147. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  148. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  149. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  150. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  151. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  152. package/background/src/lib/virtualized/project/writeScenarioComponents.js +83 -12
  153. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  154. package/codeyam-cli/scripts/apply-setup.js +208 -11
  155. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  156. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  157. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  158. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  159. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  160. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  161. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  162. package/codeyam-cli/src/cli.js +56 -25
  163. package/codeyam-cli/src/cli.js.map +1 -1
  164. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js +47 -0
  165. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js.map +1 -0
  166. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js +71 -0
  167. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js.map +1 -0
  168. package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js +30 -0
  169. package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js.map +1 -0
  170. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  171. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  172. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  173. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  174. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  175. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  176. package/codeyam-cli/src/commands/analyze.js +17 -7
  177. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  178. package/codeyam-cli/src/commands/default.js +14 -2
  179. package/codeyam-cli/src/commands/default.js.map +1 -1
  180. package/codeyam-cli/src/commands/editor.js +5900 -0
  181. package/codeyam-cli/src/commands/editor.js.map +1 -0
  182. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js +23 -0
  183. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js.map +1 -0
  184. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  185. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  186. package/codeyam-cli/src/commands/init.js +109 -45
  187. package/codeyam-cli/src/commands/init.js.map +1 -1
  188. package/codeyam-cli/src/commands/memory.js +89 -75
  189. package/codeyam-cli/src/commands/memory.js.map +1 -1
  190. package/codeyam-cli/src/commands/telemetry.js +37 -0
  191. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  192. package/codeyam-cli/src/data/designSystems.js +27 -0
  193. package/codeyam-cli/src/data/designSystems.js.map +1 -0
  194. package/codeyam-cli/src/data/techStacks.js +77 -0
  195. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  196. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  197. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  198. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  199. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  200. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  201. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  202. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +181 -0
  203. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  204. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +4014 -0
  205. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  206. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  207. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  208. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  209. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  210. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js +137 -0
  211. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
  212. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  213. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  214. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  215. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  216. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  217. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  218. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
  219. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  220. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
  221. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js.map +1 -0
  222. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  223. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  224. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  225. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  226. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  227. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  228. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  229. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  230. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  231. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  232. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  233. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  234. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +361 -0
  235. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  236. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  237. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  238. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  239. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  240. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +291 -0
  241. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  242. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1768 -0
  243. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  244. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +329 -0
  245. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  246. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  247. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  248. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  249. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  250. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  251. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  252. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2121 -0
  253. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  254. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  255. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  256. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js +177 -0
  257. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
  258. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
  259. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  260. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js +302 -0
  261. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js.map +1 -0
  262. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +26 -20
  263. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -1
  264. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  265. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  266. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  267. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  268. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  269. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  270. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js +127 -0
  271. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js.map +1 -0
  272. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  273. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  277. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  279. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  280. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
  281. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
  282. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +51 -4
  283. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  284. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  285. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  286. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  287. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  288. package/codeyam-cli/src/utils/__tests__/testRunner.test.js +217 -0
  289. package/codeyam-cli/src/utils/__tests__/testRunner.test.js.map +1 -0
  290. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +148 -0
  291. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  292. package/codeyam-cli/src/utils/analysisRunner.js +39 -8
  293. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  294. package/codeyam-cli/src/utils/analyzer.js +19 -0
  295. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  296. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  297. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  298. package/codeyam-cli/src/utils/backgroundServer.js +105 -13
  299. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  300. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  301. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  302. package/codeyam-cli/src/utils/database.js +37 -2
  303. package/codeyam-cli/src/utils/database.js.map +1 -1
  304. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  305. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  306. package/codeyam-cli/src/utils/devServerState.js +71 -0
  307. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  308. package/codeyam-cli/src/utils/editorApi.js +95 -0
  309. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  310. package/codeyam-cli/src/utils/editorAudit.js +827 -0
  311. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  312. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  313. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  314. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  315. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  316. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  317. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  318. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  319. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  320. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  321. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  322. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  323. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  324. package/codeyam-cli/src/utils/editorGuard.js +36 -0
  325. package/codeyam-cli/src/utils/editorGuard.js.map +1 -0
  326. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  327. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  328. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  329. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  330. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  331. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  332. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  333. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  334. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  335. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  336. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  337. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  338. package/codeyam-cli/src/utils/editorPreview.js +139 -0
  339. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  340. package/codeyam-cli/src/utils/editorRecapture.js +109 -0
  341. package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
  342. package/codeyam-cli/src/utils/editorScenarioSwitch.js +134 -0
  343. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  344. package/codeyam-cli/src/utils/editorScenarios.js +677 -0
  345. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  346. package/codeyam-cli/src/utils/editorSeedAdapter.js +462 -0
  347. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  348. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  349. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  350. package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
  351. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  352. package/codeyam-cli/src/utils/entityChangeStatus.server.js +227 -0
  353. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  354. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  355. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  356. package/codeyam-cli/src/utils/fileWatcher.js +63 -9
  357. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  358. package/codeyam-cli/src/utils/git.js +103 -0
  359. package/codeyam-cli/src/utils/git.js.map +1 -1
  360. package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
  361. package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
  362. package/codeyam-cli/src/utils/install-skills.js +71 -15
  363. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  364. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  365. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  366. package/codeyam-cli/src/utils/manualEntityAnalysis.js +196 -0
  367. package/codeyam-cli/src/utils/manualEntityAnalysis.js.map +1 -0
  368. package/codeyam-cli/src/utils/npmVersionCheck.js +2 -2
  369. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -1
  370. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  371. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  372. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  373. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  374. package/codeyam-cli/src/utils/progress.js +2 -2
  375. package/codeyam-cli/src/utils/progress.js.map +1 -1
  376. package/codeyam-cli/src/utils/project.js +15 -5
  377. package/codeyam-cli/src/utils/project.js.map +1 -1
  378. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  379. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  380. package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js +159 -0
  381. package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  383. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  384. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  385. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  386. package/codeyam-cli/src/utils/queue/job.js +105 -7
  387. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  388. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  389. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  390. package/codeyam-cli/src/utils/registerScenarioResult.js +52 -0
  391. package/codeyam-cli/src/utils/registerScenarioResult.js.map +1 -0
  392. package/codeyam-cli/src/utils/requireSimulations.js +1 -1
  393. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -1
  394. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  395. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  396. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +5 -6
  397. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
  398. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +1 -1
  399. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -1
  400. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +0 -1
  401. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -1
  402. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +2 -4
  403. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -1
  404. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +4 -6
  405. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
  406. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +1 -1
  407. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  409. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  410. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  411. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  413. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  415. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/index.js +1 -0
  417. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  418. package/codeyam-cli/src/utils/rules/parser.js +14 -4
  419. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  420. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  421. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  422. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  423. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  424. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  425. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  426. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  427. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  428. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  429. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  430. package/codeyam-cli/src/utils/scenariosManifest.js +313 -0
  431. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  432. package/codeyam-cli/src/utils/screenshotHash.js +26 -0
  433. package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
  434. package/codeyam-cli/src/utils/serverState.js +57 -2
  435. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  436. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +83 -11
  437. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  438. package/codeyam-cli/src/utils/simulationGateMiddleware.js +175 -0
  439. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  440. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  441. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  442. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  443. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  444. package/codeyam-cli/src/utils/telemetry.js +106 -0
  445. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  446. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  447. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  448. package/codeyam-cli/src/utils/testResultCache.js +53 -0
  449. package/codeyam-cli/src/utils/testResultCache.js.map +1 -0
  450. package/codeyam-cli/src/utils/testResultCache.server.js +81 -0
  451. package/codeyam-cli/src/utils/testResultCache.server.js.map +1 -0
  452. package/codeyam-cli/src/utils/testResultCache.server.test.js +187 -0
  453. package/codeyam-cli/src/utils/testResultCache.server.test.js.map +1 -0
  454. package/codeyam-cli/src/utils/testResultCache.test.js +230 -0
  455. package/codeyam-cli/src/utils/testResultCache.test.js.map +1 -0
  456. package/codeyam-cli/src/utils/testRunner.js +356 -0
  457. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  458. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  459. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  460. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  461. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  462. package/codeyam-cli/src/utils/webappDetection.js +38 -3
  463. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  464. package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js +98 -0
  465. package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js.map +1 -0
  466. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  467. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  468. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
  469. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  470. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +647 -0
  471. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  472. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +315 -0
  473. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  474. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  475. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  476. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
  477. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  478. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  479. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  480. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  481. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  482. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  483. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js +34 -0
  484. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js.map +1 -0
  485. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  486. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  487. package/codeyam-cli/src/webserver/backgroundServer.js +141 -42
  488. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  489. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-bwuHPyTa.js → EntityItem-Crt_KN_U.js} +5 -5
  491. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BH0XDim7.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  493. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DtYTSPL2.js +25 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BvMu2i-g.js → LoadingDots-By5zI316.js} +1 -1
  497. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-kgBTLoJD.js → LogViewer-CM5zg40N.js} +3 -3
  498. package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-CQENLSrF.js +36 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-BzPgx-xO.js → ReportIssueModal-C2PLkej3.js} +4 -4
  500. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BX2Ny2Qj.js → ScenarioViewer-CefgqbCr.js} +3 -3
  502. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bc8BG-Lw.js +34 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/{_index-BRx8ZGZo.js → _index-C1YkzTAV.js} +4 -4
  506. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-4S4yPfFw.js → activity.(_tab)-yH46LLUz.js} +8 -8
  507. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  509. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-CHx25PAe.js +1 -0
  510. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  511. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bg3e7q4S.js +22 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  517. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  521. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  522. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  523. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  524. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  527. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  528. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  531. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  536. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  538. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
  540. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  543. package/codeyam-cli/src/webserver/build/client/assets/api.editor-verify-routes-l0sNRNKZ.js +1 -0
  544. package/codeyam-cli/src/webserver/build/client/assets/api.interactive-switch-scenario-l0sNRNKZ.js +1 -0
  545. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  546. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D4IPYH_y.js → book-open-CL-lMgHh.js} +2 -2
  547. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-CG65viiV.js → chevron-down-GmAjGS9-.js} +2 -2
  548. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  549. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-igfMr5DY.js → circle-check-DFcQkN5j.js} +2 -2
  550. package/codeyam-cli/src/webserver/build/client/assets/{copy-Coc4o_8c.js → copy-C6iF61Xs.js} +3 -3
  551. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  552. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
  553. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
  554. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CRepiabR.js +1 -0
  555. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  556. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DLM1-ZMt.js +96 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CluPkvXJ.js +41 -0
  558. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-B0h9AqE6.js → entity._sha._-DYJRGiDI.js} +14 -13
  559. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-wdiwx5-Z.js +6 -0
  560. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-BrkN-40Y.js +6 -0
  561. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DxfhekTZ.js +6 -0
  562. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-PePWg17F.js → entity._sha_.edit._scenarioId-CRXJWmpB.js} +2 -2
  563. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-I-Wo99C_.js → entry.client-SuW9syRS.js} +6 -6
  564. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  565. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  567. package/codeyam-cli/src/webserver/build/client/assets/globals-9EkC9j9I.css +1 -0
  568. package/codeyam-cli/src/webserver/build/client/assets/{index-_417gcQW.js → index-Bp1l4hSv.js} +1 -1
  569. package/codeyam-cli/src/webserver/build/client/assets/{index-CUM5iXwc.js → index-CWV9XZiG.js} +1 -1
  570. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  571. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  572. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  573. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-TzRHMVog.js → loader-circle-De-7qQ2u.js} +2 -2
  574. package/codeyam-cli/src/webserver/build/client/assets/manifest-7e749098.js +1 -0
  575. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  576. package/codeyam-cli/src/webserver/build/client/assets/{pause-hjzB7t2z.js → pause-CFxEKL1u.js} +3 -3
  577. package/codeyam-cli/src/webserver/build/client/assets/root-DGtly3mb.js +80 -0
  578. package/codeyam-cli/src/webserver/build/client/assets/{search-DcAwD_Ln.js → search-BdBb5aqc.js} +2 -2
  579. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  580. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  581. package/codeyam-cli/src/webserver/build/client/assets/{terminal-DbEAHMbA.js → terminal-CrplD4b1.js} +3 -3
  582. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CAD5b1o_.js → triangle-alert-DqJ0j69l.js} +2 -2
  583. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-D9QZKaLJ.js +2 -0
  585. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  586. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  587. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  588. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  589. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-CO8xocj3.js +16 -0
  590. package/codeyam-cli/src/webserver/build/server/assets/index-QKPqlUgg.js +1 -0
  591. package/codeyam-cli/src/webserver/build/server/assets/init-DlspChIk.js +10 -0
  592. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  593. package/codeyam-cli/src/webserver/build/server/assets/server-build-ChzicV-B.js +689 -0
  594. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  595. package/codeyam-cli/src/webserver/build-info.json +5 -5
  596. package/codeyam-cli/src/webserver/devServer.js +39 -5
  597. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  598. package/codeyam-cli/src/webserver/editorProxy.js +1028 -0
  599. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  600. package/codeyam-cli/src/webserver/idleDetector.js +130 -0
  601. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  602. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  603. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  604. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  605. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  606. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +283 -0
  607. package/codeyam-cli/src/webserver/server.js +379 -1
  608. package/codeyam-cli/src/webserver/server.js.map +1 -1
  609. package/codeyam-cli/src/webserver/terminalServer.js +952 -0
  610. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  611. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  612. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  613. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  614. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  615. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  616. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  617. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  618. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  619. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  620. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  621. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  622. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  623. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  624. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  625. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  626. package/codeyam-cli/templates/codeyam-editor-claude.md +149 -0
  627. package/codeyam-cli/templates/codeyam-editor-reference.md +216 -0
  628. package/codeyam-cli/templates/design-systems/clean-dashboard-design-system.md +255 -0
  629. package/codeyam-cli/templates/design-systems/editorial-design-system.md +267 -0
  630. package/codeyam-cli/templates/design-systems/mono-brutalist-design-system.md +256 -0
  631. package/codeyam-cli/templates/design-systems/neo-brutalist-design-system.md +294 -0
  632. package/codeyam-cli/templates/editor-step-hook.py +368 -0
  633. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +204 -0
  634. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  635. package/codeyam-cli/templates/expo-react-native/__tests__/.gitkeep +0 -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 +13 -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 +10 -0
  644. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  645. package/codeyam-cli/templates/expo-react-native/lib/theme.ts +73 -0
  646. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  647. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  648. package/codeyam-cli/templates/expo-react-native/package.json +48 -0
  649. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  650. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  651. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  652. package/codeyam-cli/templates/isolation-route/expo-router.tsx.template +54 -0
  653. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  654. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  655. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  656. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  657. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  658. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  659. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  660. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  661. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  662. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  663. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  664. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  665. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  666. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  667. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  668. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  669. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  670. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  671. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  672. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  673. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  674. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  675. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  676. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  677. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  678. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  679. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +140 -0
  680. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  681. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  682. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  683. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  684. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  685. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  686. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  687. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  688. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  689. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  690. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  691. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  692. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  693. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  694. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  695. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  696. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  697. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  698. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  699. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  700. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  701. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  702. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  703. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  704. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  705. package/codeyam-cli/templates/rule-reflection-hook.py +25 -5
  706. package/codeyam-cli/templates/rules-instructions.md +34 -88
  707. package/codeyam-cli/templates/seed-adapters/supabase.ts +291 -0
  708. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  709. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +244 -0
  710. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  711. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  712. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  713. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  714. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  715. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  716. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  717. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  718. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  719. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  720. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  721. package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -2
  722. package/package.json +22 -14
  723. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  724. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  725. package/packages/ai/src/lib/astScopes/methodSemantics.js +99 -0
  726. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  727. package/packages/ai/src/lib/astScopes/nodeToSource.js +16 -0
  728. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -1
  729. package/packages/ai/src/lib/astScopes/paths.js +12 -3
  730. package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
  731. package/packages/ai/src/lib/completionCall.js +10 -7
  732. package/packages/ai/src/lib/completionCall.js.map +1 -1
  733. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +261 -13
  734. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  735. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
  736. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
  737. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +14 -4
  738. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  739. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  740. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  741. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  742. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  743. package/packages/ai/src/lib/dataStructureChunking.js +9 -5
  744. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  745. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  746. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  747. package/packages/ai/src/lib/generateExecutionFlows.js +81 -11
  748. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  749. package/packages/analyze/index.js +1 -1
  750. package/packages/analyze/index.js.map +1 -1
  751. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  752. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  753. package/packages/analyze/src/lib/asts/index.js +4 -2
  754. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  755. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  756. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  757. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +16 -2
  758. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  759. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +14 -27
  760. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  761. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  762. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  763. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +12 -2
  764. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  765. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +9 -7
  766. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  767. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
  768. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
  769. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -11
  770. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  771. package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
  772. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  773. package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
  774. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  775. package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
  776. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
  777. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  778. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  779. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +185 -28
  780. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  781. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  782. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  783. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1386 -1197
  784. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  785. package/packages/database/index.js +1 -0
  786. package/packages/database/index.js.map +1 -1
  787. package/packages/database/src/lib/kysely/db.js +5 -0
  788. package/packages/database/src/lib/kysely/db.js.map +1 -1
  789. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  790. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  791. package/packages/database/src/lib/loadAnalysis.js +7 -1
  792. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  793. package/packages/database/src/lib/loadCommits.js +23 -13
  794. package/packages/database/src/lib/loadCommits.js.map +1 -1
  795. package/packages/database/src/lib/loadEntities.js +0 -6
  796. package/packages/database/src/lib/loadEntities.js.map +1 -1
  797. package/packages/database/src/lib/loadEntity.js +5 -5
  798. package/packages/database/src/lib/loadEntity.js.map +1 -1
  799. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  800. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  801. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  802. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  803. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  804. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  805. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  806. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  807. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  808. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  809. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  810. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  811. package/packages/types/src/enums/ProjectFramework.js +2 -0
  812. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  813. package/packages/utils/src/lib/fs/rsyncCopy.js +28 -3
  814. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  815. package/scripts/npm-post-install.cjs +34 -0
  816. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -120
  817. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  818. package/codeyam-cli/src/commands/list.js +0 -31
  819. package/codeyam-cli/src/commands/list.js.map +0 -1
  820. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  821. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  822. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  823. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  824. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-jNYXRRNI.js +0 -1
  825. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CvzqMxcu.js +0 -1
  826. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +0 -34
  827. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-yjIHlOGa.js +0 -25
  828. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-Cq5o8jL4.js +0 -3
  829. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CwZrv-Ok.js +0 -1
  830. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CDpEprKa.js +0 -1
  831. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +0 -17
  832. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-DB3aFuEO.js +0 -51
  833. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-D1zB-pYc.js +0 -21
  834. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
  835. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +0 -1
  836. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +0 -6
  837. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +0 -6
  838. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-9sMMAiWJ.js +0 -1
  839. package/codeyam-cli/src/webserver/build/client/assets/files-Co65J0s3.js +0 -1
  840. package/codeyam-cli/src/webserver/build/client/assets/git-BdHOxVfg.js +0 -15
  841. package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +0 -1
  842. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +0 -1
  843. package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +0 -1
  844. package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +0 -78
  845. package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +0 -62
  846. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +0 -1
  847. package/codeyam-cli/src/webserver/build/client/assets/simulations-DVNJVQgD.js +0 -1
  848. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +0 -1
  849. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DAFqfEDH.js +0 -2
  850. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DZlYx2c4.js +0 -1
  851. package/codeyam-cli/src/webserver/build/client/assets/useToast-ihdMtlf6.js +0 -1
  852. package/codeyam-cli/src/webserver/build/server/assets/index-CxaRxKVt.js +0 -1
  853. package/codeyam-cli/src/webserver/build/server/assets/server-build-D4DT0nM_.js +0 -259
  854. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  855. package/scripts/finalize-analyzer.cjs +0 -13
  856. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  857. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  858. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  859. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  860. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  861. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -398,6 +398,7 @@ const SILENTLY_IGNORED_EQUIVALENCY_REASONS = new Set([
398
398
  'transformed non-object function equivalency - Array.from() equivalency',
399
399
  'Spread operator equivalency key update: Explicit array deconstruction equivalency value',
400
400
  // 'transformed non-object function equivalency - Explicit array deconstruction equivalency value',
401
+ 'useState setter call equivalency (direct)',
401
402
  ]);
402
403
 
403
404
  export class ScopeDataStructure {
@@ -1048,9 +1049,38 @@ export class ScopeDataStructure {
1048
1049
  equivalencyValueChain?: EquivalencyValueChainItem[],
1049
1050
  traceId?: number,
1050
1051
  ) {
1052
+ // Fast early exits that don't count toward the limit.
1053
+ // These are "no-op" calls that would be caught further below anyway,
1054
+ // but checking them first prevents counter inflation from redundant calls
1055
+ // generated by managers and followEquivalencies during scope processing.
1056
+
1057
+ // Skip silently-ignored reasons before counting
1058
+ if (SILENTLY_IGNORED_EQUIVALENCY_REASONS.has(equivalencyReason)) {
1059
+ return;
1060
+ }
1061
+
1062
+ // Skip exact duplicates before counting (Phase 1 only — Phase 2 needs
1063
+ // to process duplicates for database chain tracking)
1064
+ if (this.onlyEquivalencies) {
1065
+ const existing = scopeNode.equivalencies[path];
1066
+ if (
1067
+ existing?.some(
1068
+ (v) =>
1069
+ v.schemaPath === equivalentPath &&
1070
+ v.scopeNodeName === equivalentScopeName,
1071
+ )
1072
+ ) {
1073
+ return;
1074
+ }
1075
+ }
1076
+
1051
1077
  addEquivalencyCallCount++;
1052
1078
 
1053
- if (addEquivalencyCallCount > 50000) {
1079
+ const limit =
1080
+ typeof (globalThis as any).__CODEYAM_EQUIVALENCY_LIMIT === 'number'
1081
+ ? (globalThis as any).__CODEYAM_EQUIVALENCY_LIMIT
1082
+ : 50000;
1083
+ if (addEquivalencyCallCount > limit) {
1054
1084
  console.error('INFINITE LOOP DETECTED in addEquivalency', {
1055
1085
  callCount: addEquivalencyCallCount,
1056
1086
  path,
@@ -1065,14 +1095,11 @@ export class ScopeDataStructure {
1065
1095
  }
1066
1096
  // Filter equivalency reasons - use pre-computed Sets for O(1) lookup
1067
1097
  if (!ALLOWED_EQUIVALENCY_REASONS.has(equivalencyReason)) {
1068
- if (SILENTLY_IGNORED_EQUIVALENCY_REASONS.has(equivalencyReason)) {
1069
- return;
1070
- } else {
1071
- // Log and skip - if an equivalency reason isn't in ALLOWED or SILENTLY_IGNORED,
1072
- // it shouldn't be stored (was previously missing the return)
1073
- console.info('Not tracked equivalency reason', { equivalencyReason });
1074
- return;
1075
- }
1098
+ // Silently-ignored reasons already handled above
1099
+ // Log and skip - if an equivalency reason isn't in ALLOWED or SILENTLY_IGNORED,
1100
+ // it shouldn't be stored (was previously missing the return)
1101
+ console.info('Not tracked equivalency reason', { equivalencyReason });
1102
+ return;
1076
1103
  }
1077
1104
 
1078
1105
  // Skip self-referential equivalencies that would create infinite loops.
@@ -1108,6 +1135,33 @@ export class ScopeDataStructure {
1108
1135
  return;
1109
1136
  }
1110
1137
 
1138
+ // Case 3: Circular reference through scope-suffixed names (____cyScope pattern)
1139
+ // When a named arrow function is defined inside a scope (e.g., useEffect callback):
1140
+ // const identifyUser = async () => { ... };
1141
+ // identifyUser();
1142
+ // This creates a variable "identifyUser" and a scope "identifyUser____cyScope9F".
1143
+ // Mutual equivalencies between these cause infinite loops in Phase 2 because
1144
+ // processing one triggers addToSchema → followEquivalencies → addEquivalency
1145
+ // on the reverse, which repeats indefinitely.
1146
+ // Only block when the REVERSE direction already exists (creating a cycle).
1147
+ // The initial one-directional equivalency is necessary for scope resolution.
1148
+ if (
1149
+ path &&
1150
+ equivalentPath &&
1151
+ (equivalentPath.startsWith(path + '____') ||
1152
+ path.startsWith(equivalentPath + '____'))
1153
+ ) {
1154
+ // Check if the reverse equivalency already exists
1155
+ const reverseEquivalencies =
1156
+ scopeNode.equivalencies[equivalentPath] || [];
1157
+ const reverseExists = reverseEquivalencies.some(
1158
+ (v) => v.schemaPath === path,
1159
+ );
1160
+ if (reverseExists) {
1161
+ return;
1162
+ }
1163
+ }
1164
+
1111
1165
  if (!equivalentScopeName) {
1112
1166
  console.error(
1113
1167
  'CodeYam Error: Missing equivalent scope name - FULL CONTEXT:',
@@ -3360,6 +3414,22 @@ export class ScopeDataStructure {
3360
3414
  * ensure all sub-paths of that variable are reflected under signature[N].
3361
3415
  */
3362
3416
  private propagateParameterToSignaturePaths(scopeNode: ScopeNode) {
3417
+ // Helper: check if a type is a concrete scalar that cannot have sub-properties.
3418
+ const SCALAR_TYPES = new Set([
3419
+ 'string',
3420
+ 'number',
3421
+ 'boolean',
3422
+ 'bigint',
3423
+ 'symbol',
3424
+ 'void',
3425
+ 'never',
3426
+ ]);
3427
+ const isDefinitelyScalar = (type: string): boolean => {
3428
+ const parts = type.split('|').map((s) => s.trim());
3429
+ const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
3430
+ return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
3431
+ };
3432
+
3363
3433
  // Find variable → signature[N] equivalencies
3364
3434
  for (const [varName, equivalencies] of Object.entries(
3365
3435
  scopeNode.equivalencies,
@@ -3390,7 +3460,38 @@ export class ScopeDataStructure {
3390
3460
 
3391
3461
  // Only add if the signature path doesn't already exist
3392
3462
  if (!scopeNode.schema[sigKey]) {
3393
- scopeNode.schema[sigKey] = scopeNode.schema[key];
3463
+ // Check if this path represents variable conflation:
3464
+ // When a standalone variable (e.g., showWorkoutForm from useState)
3465
+ // appears as a sub-property of a scalar-typed ancestor (e.g.,
3466
+ // activity_type = "string"), it's from scope conflation, not real
3467
+ // property access. Block these while allowing legitimate built-in
3468
+ // accesses like string.length or string.slice.
3469
+ let isConflatedPath = false;
3470
+ let checkPos = signaturePath.length;
3471
+ while (true) {
3472
+ checkPos = sigKey.indexOf('.', checkPos + 1);
3473
+ if (checkPos === -1) break;
3474
+ const ancestorPath = sigKey.substring(0, checkPos);
3475
+ const ancestorType = scopeNode.schema[ancestorPath];
3476
+ if (ancestorType && isDefinitelyScalar(ancestorType)) {
3477
+ // Ancestor is scalar — check if the immediate sub-property
3478
+ // is also a standalone variable (indicating conflation)
3479
+ const afterDot = sigKey.substring(checkPos + 1);
3480
+ const nextSep = afterDot.search(/[.\[]/);
3481
+ const subPropName =
3482
+ nextSep === -1
3483
+ ? afterDot
3484
+ : afterDot.substring(0, nextSep);
3485
+ if (scopeNode.schema[subPropName] !== undefined) {
3486
+ isConflatedPath = true;
3487
+ break;
3488
+ }
3489
+ }
3490
+ }
3491
+
3492
+ if (!isConflatedPath) {
3493
+ scopeNode.schema[sigKey] = scopeNode.schema[key];
3494
+ }
3394
3495
  }
3395
3496
  }
3396
3497
  }
@@ -4165,6 +4266,24 @@ export class ScopeDataStructure {
4165
4266
  }
4166
4267
  }
4167
4268
 
4269
+ // Helper: check if a type is a concrete scalar that cannot have sub-properties.
4270
+ // e.g., "string", "number | undefined", "boolean | null" are scalar.
4271
+ // "object", "array", "function", "unknown", "Workout", etc. are NOT scalar.
4272
+ const SCALAR_TYPES = new Set([
4273
+ 'string',
4274
+ 'number',
4275
+ 'boolean',
4276
+ 'bigint',
4277
+ 'symbol',
4278
+ 'void',
4279
+ 'never',
4280
+ ]);
4281
+ const isDefinitelyScalarType = (type: string): boolean => {
4282
+ const parts = type.split('|').map((s) => s.trim());
4283
+ const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
4284
+ return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
4285
+ };
4286
+
4168
4287
  // Propagate nested paths from variables to their signature equivalents
4169
4288
  // e.g., if workouts = signature[0].workouts, then workouts[].title becomes
4170
4289
  // signature[0].workouts[].title
@@ -4189,7 +4308,69 @@ export class ScopeDataStructure {
4189
4308
 
4190
4309
  // Add to schema if not already present
4191
4310
  if (!tempScopeNode.schema[signatureKey]) {
4192
- tempScopeNode.schema[signatureKey] = schema[schemaKey];
4311
+ // Check if this path represents variable conflation:
4312
+ // When a standalone variable (e.g., showWorkoutForm from useState)
4313
+ // appears as a sub-property of a scalar-typed ancestor (e.g.,
4314
+ // activity_type = "string"), it's from scope conflation, not real
4315
+ // property access. Block these while allowing legitimate built-in
4316
+ // accesses like string.length or string.slice.
4317
+ let isConflatedPath = false;
4318
+ let checkPos = signaturePath.length;
4319
+ while (true) {
4320
+ checkPos = signatureKey.indexOf('.', checkPos + 1);
4321
+ if (checkPos === -1) break;
4322
+ const ancestorPath = signatureKey.substring(0, checkPos);
4323
+ const ancestorType = tempScopeNode.schema[ancestorPath];
4324
+ if (ancestorType && isDefinitelyScalarType(ancestorType)) {
4325
+ // Ancestor is scalar — check if the immediate sub-property
4326
+ // is also a standalone variable (indicating conflation)
4327
+ const afterDot = signatureKey.substring(checkPos + 1);
4328
+ const nextSep = afterDot.search(/[.\[]/);
4329
+ const subPropName =
4330
+ nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
4331
+ if (schema[subPropName] !== undefined) {
4332
+ isConflatedPath = true;
4333
+ break;
4334
+ }
4335
+ }
4336
+ }
4337
+
4338
+ if (!isConflatedPath) {
4339
+ tempScopeNode.schema[signatureKey] = schema[schemaKey];
4340
+ }
4341
+ }
4342
+ }
4343
+ }
4344
+ }
4345
+
4346
+ // Post-process: filter out conflated signature paths.
4347
+ // During phase 2 scope analysis, useState(false) conflation can create
4348
+ // bad paths like signature[0].mockWorkouts[].activity_type.showWorkoutForm
4349
+ // directly in scopeNode.schema. These flow through signatureInSchema into
4350
+ // tempScopeNode.schema without any guard. Filter them out here by checking:
4351
+ // 1. An ancestor in the path has a concrete scalar type (string, number, boolean, etc.)
4352
+ // 2. The immediate sub-property of that scalar ancestor is also a standalone
4353
+ // variable in the schema (indicating conflation, not a real property access)
4354
+ for (const key of Object.keys(tempScopeNode.schema)) {
4355
+ if (!key.startsWith('signature[')) continue;
4356
+
4357
+ // Walk through the path looking for scalar-typed ancestors
4358
+ let pos = 0;
4359
+ while (true) {
4360
+ pos = key.indexOf('.', pos + 1);
4361
+ if (pos === -1) break;
4362
+ const ancestorPath = key.substring(0, pos);
4363
+ const ancestorType = tempScopeNode.schema[ancestorPath];
4364
+ if (ancestorType && isDefinitelyScalarType(ancestorType)) {
4365
+ // Found a scalar ancestor — check if the sub-property name
4366
+ // is a standalone variable in the getSchema() result
4367
+ const afterDot = key.substring(pos + 1);
4368
+ const nextSep = afterDot.search(/[.\[]/);
4369
+ const subPropName =
4370
+ nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
4371
+ if (schema[subPropName] !== undefined) {
4372
+ delete tempScopeNode.schema[key];
4373
+ break;
4193
4374
  }
4194
4375
  }
4195
4376
  }
@@ -4929,9 +5110,109 @@ export class ScopeDataStructure {
4929
5110
  // Replace cyScope placeholders in all external function call data
4930
5111
  // This ensures call signatures and schema paths use actual callback text
4931
5112
  // instead of internal cyScope names, preventing mock data merge conflicts.
4932
- return this.externalFunctionCalls.map((efc) =>
4933
- this.cleanCyScopeFromFunctionCallInfo(efc),
4934
- );
5113
+ const rootScopeName = this.scopeTreeManager.getRootName();
5114
+ const rootSchema = this.scopeNodes[rootScopeName]?.schema ?? {};
5115
+
5116
+ return this.externalFunctionCalls.map((efc) => {
5117
+ const cleaned = this.cleanCyScopeFromFunctionCallInfo(efc);
5118
+ return this.filterConflatedExternalPaths(cleaned, rootSchema);
5119
+ });
5120
+ }
5121
+
5122
+ /**
5123
+ * Filters out conflated paths from external function call schemas.
5124
+ *
5125
+ * When multiple useState(false) calls create equivalency conflation during
5126
+ * Phase 1 analysis, standalone boolean state variables (like showWorkoutForm,
5127
+ * showGoalForm) can bleed into external function call schemas as sub-properties
5128
+ * of unrelated data fields (like data[].activity_type.showWorkoutForm).
5129
+ *
5130
+ * Detection: group sub-properties by parent path. If 2+ sub-properties of
5131
+ * the same parent all match standalone root scope variable names, treat them
5132
+ * as conflation artifacts and remove them.
5133
+ */
5134
+ private filterConflatedExternalPaths(
5135
+ efc: FunctionCallInfo,
5136
+ rootSchema: Record<string, string>,
5137
+ ): FunctionCallInfo {
5138
+ // Build a set of top-level root scope variable names (simple names, no dots/brackets)
5139
+ const topLevelRootVars = new Set<string>();
5140
+ for (const key of Object.keys(rootSchema)) {
5141
+ if (!key.includes('.') && !key.includes('[')) {
5142
+ topLevelRootVars.add(key);
5143
+ }
5144
+ }
5145
+
5146
+ if (topLevelRootVars.size === 0) return efc;
5147
+
5148
+ // Group sub-property matches by their parent path.
5149
+ // For a path like "...data[].activity_type.showWorkoutForm",
5150
+ // parent = "...data[].activity_type", child = "showWorkoutForm"
5151
+ const parentToConflatedKeys = new Map<string, string[]>();
5152
+
5153
+ for (const key of Object.keys(efc.schema)) {
5154
+ const lastDot = key.lastIndexOf('.');
5155
+ if (lastDot === -1) continue;
5156
+
5157
+ const parent = key.substring(0, lastDot);
5158
+ const child = key.substring(lastDot + 1);
5159
+
5160
+ // Skip array access or function call patterns
5161
+ if (child.includes('[') || child.includes('(')) continue;
5162
+
5163
+ // Only consider paths inside array element chains (contains []).
5164
+ // Direct children of functionCallReturnValue are legitimate destructured
5165
+ // return values, not conflation. Conflation happens deeper in the chain
5166
+ // when array element fields get corrupted sub-properties.
5167
+ if (!parent.includes('[')) continue;
5168
+
5169
+ if (topLevelRootVars.has(child)) {
5170
+ if (!parentToConflatedKeys.has(parent)) {
5171
+ parentToConflatedKeys.set(parent, []);
5172
+ }
5173
+ parentToConflatedKeys.get(parent)!.push(key);
5174
+ }
5175
+ }
5176
+
5177
+ // Only filter when 2+ sub-properties of the same parent match root scope vars.
5178
+ // This threshold avoids false positives from coincidental name matches.
5179
+ const keysToRemove = new Set<string>();
5180
+ const parentsToRestore = new Set<string>();
5181
+
5182
+ for (const [parent, conflatedKeys] of parentToConflatedKeys) {
5183
+ if (conflatedKeys.length >= 2) {
5184
+ for (const key of conflatedKeys) {
5185
+ keysToRemove.add(key);
5186
+ }
5187
+ parentsToRestore.add(parent);
5188
+ }
5189
+ }
5190
+
5191
+ if (keysToRemove.size === 0) return efc;
5192
+
5193
+ // Create a new schema without the conflated paths
5194
+ const newSchema: Record<string, string> = {};
5195
+ for (const [key, value] of Object.entries(efc.schema)) {
5196
+ if (keysToRemove.has(key)) continue;
5197
+
5198
+ // Restore parent type: if it was changed to "object" because of conflated
5199
+ // sub-properties, and now all those sub-properties are removed, change it
5200
+ // back to "unknown" (we don't know the original type)
5201
+ if (parentsToRestore.has(key) && value === 'object') {
5202
+ // Check if there are any remaining sub-properties
5203
+ const hasRemainingSubProps = Object.keys(efc.schema).some(
5204
+ (k) =>
5205
+ !keysToRemove.has(k) &&
5206
+ k !== key &&
5207
+ (k.startsWith(key + '.') || k.startsWith(key + '[')),
5208
+ );
5209
+ newSchema[key] = hasRemainingSubProps ? value : 'unknown';
5210
+ } else {
5211
+ newSchema[key] = value;
5212
+ }
5213
+ }
5214
+
5215
+ return { ...efc, schema: newSchema };
4935
5216
  }
4936
5217
 
4937
5218
  /**
@@ -97,6 +97,16 @@ export default class ParentScopeManager implements EquivalencyManager {
97
97
  }
98
98
 
99
99
  if (instantiatedInParent || returnValueFromChildScope) {
100
+ // Skip if we've already propagated this variable to the parent scope.
101
+ // Without this guard, nested scopes trigger redundant addEquivalency calls
102
+ // for the same variable on every addToSchema pass (e.g., 'a' and 'b' in sort
103
+ // callbacks get propagated 30+ times per scope instead of once).
104
+ this.addedToParent[scopeNode.name] ||= new Set<string>();
105
+ if (this.addedToParent[scopeNode.name].has(rootPath)) {
106
+ return false;
107
+ }
108
+ this.addedToParent[scopeNode.name].add(rootPath);
109
+
100
110
  if (traceId && debugLevel > 0) {
101
111
  console.info(
102
112
  'Debug Propagation: parentScope executed',
@@ -114,9 +124,6 @@ export default class ParentScopeManager implements EquivalencyManager {
114
124
  );
115
125
  }
116
126
 
117
- this.addedToParent[scopeNode.name] ||= new Set<string>();
118
- this.addedToParent[scopeNode.name].add(rootPath);
119
-
120
127
  scopeDataStructure.addEquivalency(
121
128
  rootPath,
122
129
  rootPath,
@@ -6,7 +6,7 @@ import { ScopeNode, ScopeDataStructure } from '../ScopeDataStructure';
6
6
 
7
7
  type PrimitiveKind = 'array' | 'string' | 'number' | 'boolean' | 'date';
8
8
 
9
- const IGNORE_CLASSES_AND_OBJECTS = [
9
+ const IGNORE_CLASSES_AND_OBJECTS_SET = new Set([
10
10
  'Math',
11
11
  'JSON',
12
12
  'Reflect',
@@ -22,7 +22,7 @@ const IGNORE_CLASSES_AND_OBJECTS = [
22
22
  'useContext',
23
23
  'useReducer',
24
24
  'useLayoutEffect',
25
- ];
25
+ ]);
26
26
 
27
27
  /** cache the tokenised representation of every path we touch */
28
28
  const partsCache = new Map<string, string[]>();
@@ -147,16 +147,26 @@ function scrub(
147
147
  rootTable: Map<string, PrimitiveKind>,
148
148
  onRemove: (key: string) => void,
149
149
  ): void {
150
- const sortedKeys = Object.keys(mapping).sort((a, b) => a.localeCompare(b));
150
+ // Early exit: if no primitive types exist in the schema, there are no
151
+ // built-in methods to clean. Saves sorting + walking 10K+ keys.
152
+ if (rootTable.size === 0) return;
153
+
154
+ // Use direct comparison instead of localeCompare (3-5x faster for large arrays)
155
+ const sortedKeys = Object.keys(mapping).sort((a, b) =>
156
+ a < b ? -1 : a > b ? 1 : 0,
157
+ );
151
158
 
152
159
  for (const keyPath of sortedKeys) {
153
160
  const keyParts = getParts(keyPath);
154
161
  const prefixParts = buildPrefixParts(keyParts);
155
162
 
163
+ const firstPart = keyParts[0];
164
+ const firstPartBase = firstPart.includes('(')
165
+ ? firstPart.split('(')[0]
166
+ : firstPart;
156
167
  if (
157
- IGNORE_CLASSES_AND_OBJECTS.find(
158
- (m) => keyParts[0] === m || keyParts[0].startsWith(`${m}(`),
159
- )
168
+ IGNORE_CLASSES_AND_OBJECTS_SET.has(firstPart) ||
169
+ IGNORE_CLASSES_AND_OBJECTS_SET.has(firstPartBase)
160
170
  ) {
161
171
  delete mapping[keyPath];
162
172
  continue;
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Coerces primitive values to empty arrays when the schema expects an array.
3
+ *
4
+ * The LLM sometimes generates a primitive (boolean, number, string) where the
5
+ * schema expects an array. For example:
6
+ * Schema: { webapps: [{ name: "string" }] }
7
+ * LLM output: { webapps: true }
8
+ *
9
+ * This causes runtime errors like `TypeError: config.webapps?.forEach is not a function`
10
+ * because the code expects an array but gets a boolean.
11
+ *
12
+ * Coercion rule:
13
+ * - primitive → array: replace with []
14
+ *
15
+ * Null and undefined values are preserved (they may be intentionally nullable).
16
+ *
17
+ * @param data The mock data object to coerce (mutated in place)
18
+ * @param schema The schema describing expected types
19
+ */
20
+ export default function coercePrimitivesToArraysBySchema<T>(
21
+ data: T,
22
+ schema: unknown,
23
+ ): T {
24
+ if (data === null || data === undefined) {
25
+ return data;
26
+ }
27
+
28
+ if (typeof data !== 'object') {
29
+ return data;
30
+ }
31
+
32
+ if (Array.isArray(data)) {
33
+ const itemSchema = Array.isArray(schema) ? schema[0] : undefined;
34
+ for (let i = 0; i < data.length; i++) {
35
+ data[i] = coercePrimitivesToArraysBySchema(data[i], itemSchema);
36
+ }
37
+ return data;
38
+ }
39
+
40
+ const dataObj = data as Record<string, unknown>;
41
+ const schemaObj = schema as Record<string, unknown> | undefined;
42
+
43
+ for (const key of Object.keys(dataObj)) {
44
+ const value = dataObj[key];
45
+ const fieldSchema = schemaObj?.[key];
46
+
47
+ if (value === null || value === undefined) {
48
+ continue;
49
+ }
50
+
51
+ if (typeof value !== 'object' && Array.isArray(fieldSchema)) {
52
+ // Schema expects an array but the value is a primitive.
53
+ // Replace with an empty array.
54
+ dataObj[key] = [];
55
+ } else if (typeof value === 'object' && value !== null) {
56
+ // Both value and schema are objects — recurse
57
+ coercePrimitivesToArraysBySchema(value, fieldSchema);
58
+ }
59
+ }
60
+
61
+ return data;
62
+ }
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Recursively strips `_nullable` keys from LLM-generated mock data.
3
+ *
4
+ * The `_nullable` marker is an internal CodeYam concept used in type definitions
5
+ * to indicate that a field can be null/undefined. The LLM sometimes includes
6
+ * these markers in its generated scenario data, which causes runtime errors
7
+ * when code iterates over object keys (e.g., `Object.keys(importedBy)` picks
8
+ * up `_nullable` as a key alongside real data).
9
+ *
10
+ * This function mutates the input object in-place, consistent with other
11
+ * post-processing helpers like `convertNullToUndefinedBySchema`.
12
+ */
13
+ export default function stripNullableMarkers(
14
+ data: Record<string, unknown>,
15
+ ): void {
16
+ if (data == null || typeof data !== 'object') return;
17
+
18
+ // Delete _nullable from this level
19
+ if ('_nullable' in data) {
20
+ delete data._nullable;
21
+ }
22
+
23
+ // Recurse into nested objects and arrays
24
+ for (const value of Object.values(data)) {
25
+ if (Array.isArray(value)) {
26
+ for (const item of value) {
27
+ if (item !== null && typeof item === 'object' && !Array.isArray(item)) {
28
+ stripNullableMarkers(item as Record<string, unknown>);
29
+ }
30
+ }
31
+ } else if (value !== null && typeof value === 'object') {
32
+ stripNullableMarkers(value as Record<string, unknown>);
33
+ }
34
+ }
35
+ }
@@ -4,10 +4,10 @@ import type { ExecutionFlow, ScenariosDataStructure } from '~codeyam/types';
4
4
  type RequiredValue = NonNullable<ExecutionFlow['requiredValues']>[number];
5
5
 
6
6
  const DEFAULT_MAX_CHUNK_SIZE = 10_000; // ~10K chars per chunk
7
+ const DEFAULT_MAX_KEYS_PER_CHUNK = 20;
7
8
 
8
9
  export interface ChunkOptions {
9
10
  maxChunkSize?: number;
10
- /** @deprecated Use maxChunkSize instead. Kept for backward compatibility in tests. */
11
11
  maxKeysPerChunk?: number;
12
12
  }
13
13
 
@@ -33,16 +33,19 @@ export function chunkDataStructure(
33
33
  return [dataForMocks];
34
34
  }
35
35
 
36
- const { maxChunkSize = DEFAULT_MAX_CHUNK_SIZE } = options;
36
+ const {
37
+ maxChunkSize = DEFAULT_MAX_CHUNK_SIZE,
38
+ maxKeysPerChunk = DEFAULT_MAX_KEYS_PER_CHUNK,
39
+ } = options;
37
40
  const keys = Object.keys(dataForMocks);
38
41
 
39
42
  // Calculate total size to see if chunking is needed
40
43
  const totalSize = JSON.stringify(dataForMocks).length;
41
- if (totalSize <= maxChunkSize) {
44
+ if (totalSize <= maxChunkSize && keys.length <= maxKeysPerChunk) {
42
45
  return [dataForMocks];
43
46
  }
44
47
 
45
- // Greedily pack keys into chunks by cumulative size
48
+ // Greedily pack keys into chunks by cumulative size and key count
46
49
  const chunks: Array<ScenariosDataStructure['dataForMocks']> = [];
47
50
  let currentChunk: Record<string, unknown> = {};
48
51
  let currentSize = 0;
@@ -52,8 +55,14 @@ export function chunkDataStructure(
52
55
  (dataForMocks as Record<string, unknown>)[key],
53
56
  ).length;
54
57
 
55
- // If adding this key would exceed the limit AND chunk isn't empty, start a new chunk
56
- if (currentSize > 0 && currentSize + keySize > maxChunkSize) {
58
+ const currentKeyCount = Object.keys(currentChunk).length;
59
+
60
+ // If adding this key would exceed size or key count limit AND chunk isn't empty, start a new chunk
61
+ if (
62
+ currentSize > 0 &&
63
+ (currentSize + keySize > maxChunkSize ||
64
+ currentKeyCount >= maxKeysPerChunk)
65
+ ) {
57
66
  chunks.push(currentChunk as ScenariosDataStructure['dataForMocks']);
58
67
  currentChunk = {};
59
68
  currentSize = 0;