@codeyam/codeyam-cli 0.1.0-staging.73a4bf4 → 0.1.0-staging.78c1cad

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 (864) 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 +5923 -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 +4024 -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 +185 -0
  263. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  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 +216 -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 +120 -45
  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 +844 -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 +76 -0
  369. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  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 +350 -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__/dependency-smoke.test.js +66 -0
  471. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  472. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +647 -0
  473. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  474. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +315 -0
  475. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  476. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  477. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  478. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
  479. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  480. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  481. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  482. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  483. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  484. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  485. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js +34 -0
  486. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js.map +1 -0
  487. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  488. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  489. package/codeyam-cli/src/webserver/backgroundServer.js +141 -42
  490. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  491. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  492. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  493. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-BLlhOa3C.js → EntityItem-Crt_KN_U.js} +5 -5
  495. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-CzdG5I7z.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  497. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DtYTSPL2.js +25 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  500. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B1LNGboS.js → LoadingDots-By5zI316.js} +1 -1
  501. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-B0Ll1DjK.js → LogViewer-CM5zg40N.js} +3 -3
  502. package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-CQENLSrF.js +36 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-CVOvmCKb.js → ReportIssueModal-C2PLkej3.js} +4 -4
  504. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-D54Mmpwi.js → ScenarioViewer-CefgqbCr.js} +3 -3
  506. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bc8BG-Lw.js +34 -0
  507. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  509. package/codeyam-cli/src/webserver/build/client/assets/{_index-CKTtYlBU.js → _index-C1YkzTAV.js} +4 -4
  510. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-CdziRIWU.js → activity.(_tab)-yH46LLUz.js} +8 -8
  511. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-CHx25PAe.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bg3e7q4S.js +22 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  517. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  521. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  522. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  523. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  524. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  527. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  528. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  531. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  536. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  538. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  540. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  543. package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
  544. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  545. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  546. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  547. package/codeyam-cli/src/webserver/build/client/assets/api.editor-verify-routes-l0sNRNKZ.js +1 -0
  548. package/codeyam-cli/src/webserver/build/client/assets/api.interactive-switch-scenario-l0sNRNKZ.js +1 -0
  549. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  550. package/codeyam-cli/src/webserver/build/client/assets/{book-open-Ch8b7GyQ.js → book-open-CL-lMgHh.js} +2 -2
  551. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-vJHJExlT.js → chevron-down-GmAjGS9-.js} +2 -2
  552. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  553. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-rwynPZTW.js → circle-check-DFcQkN5j.js} +2 -2
  554. package/codeyam-cli/src/webserver/build/client/assets/{copy-BBSpeBYf.js → copy-C6iF61Xs.js} +3 -3
  555. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  556. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
  558. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CRepiabR.js +1 -0
  559. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  560. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-CRxPi2BB.js +96 -0
  561. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CluPkvXJ.js +41 -0
  562. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-DYJRGiDI.js +24 -0
  563. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-wdiwx5-Z.js +6 -0
  564. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-BrkN-40Y.js +6 -0
  565. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DxfhekTZ.js +6 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BEqewwtZ.js → entity._sha_.edit._scenarioId-CRXJWmpB.js} +2 -2
  567. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-Dxqz8ygt.js → entry.client-SuW9syRS.js} +6 -6
  568. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  569. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  570. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  571. package/codeyam-cli/src/webserver/build/client/assets/globals-BsGHu8WX.css +1 -0
  572. package/codeyam-cli/src/webserver/build/client/assets/{index-DgAAopZk.js → index-Bp1l4hSv.js} +1 -1
  573. package/codeyam-cli/src/webserver/build/client/assets/{index-viijWaN6.js → index-CWV9XZiG.js} +1 -1
  574. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  575. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  576. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  577. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-LGi2eKI5.js → loader-circle-De-7qQ2u.js} +2 -2
  578. package/codeyam-cli/src/webserver/build/client/assets/manifest-9032538f.js +1 -0
  579. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  580. package/codeyam-cli/src/webserver/build/client/assets/{pause-DxJFmMsK.js → pause-CFxEKL1u.js} +3 -3
  581. package/codeyam-cli/src/webserver/build/client/assets/root-dKFRTYcy.js +80 -0
  582. package/codeyam-cli/src/webserver/build/client/assets/{search-Cu3QE9E5.js → search-BdBb5aqc.js} +2 -2
  583. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  585. package/codeyam-cli/src/webserver/build/client/assets/{terminal-dAhIBEcd.js → terminal-CrplD4b1.js} +3 -3
  586. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-C4CYTEeP.js → triangle-alert-DqJ0j69l.js} +2 -2
  587. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  588. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-D9QZKaLJ.js +2 -0
  589. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  590. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  591. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  592. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  593. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-B6HnVI5u.js +16 -0
  594. package/codeyam-cli/src/webserver/build/server/assets/index-rV_xLS1u.js +1 -0
  595. package/codeyam-cli/src/webserver/build/server/assets/init-BdWDvetv.js +10 -0
  596. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  597. package/codeyam-cli/src/webserver/build/server/assets/server-build-B_jdq5dT.js +689 -0
  598. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  599. package/codeyam-cli/src/webserver/build-info.json +5 -5
  600. package/codeyam-cli/src/webserver/devServer.js +39 -5
  601. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  602. package/codeyam-cli/src/webserver/editorProxy.js +1028 -0
  603. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  604. package/codeyam-cli/src/webserver/idleDetector.js +130 -0
  605. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  606. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  607. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  608. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  609. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  610. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +283 -0
  611. package/codeyam-cli/src/webserver/server.js +379 -1
  612. package/codeyam-cli/src/webserver/server.js.map +1 -1
  613. package/codeyam-cli/src/webserver/terminalServer.js +952 -0
  614. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  615. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  616. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  617. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  618. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  619. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  620. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  621. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  622. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  623. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  624. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  625. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  626. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  627. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  628. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  629. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  630. package/codeyam-cli/templates/codeyam-editor-claude.md +149 -0
  631. package/codeyam-cli/templates/codeyam-editor-reference.md +216 -0
  632. package/codeyam-cli/templates/design-systems/clean-dashboard-design-system.md +255 -0
  633. package/codeyam-cli/templates/design-systems/editorial-design-system.md +267 -0
  634. package/codeyam-cli/templates/design-systems/mono-brutalist-design-system.md +256 -0
  635. package/codeyam-cli/templates/design-systems/neo-brutalist-design-system.md +294 -0
  636. package/codeyam-cli/templates/editor-step-hook.py +368 -0
  637. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +203 -0
  638. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  639. package/codeyam-cli/templates/expo-react-native/__tests__/.gitkeep +0 -0
  640. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +13 -0
  641. package/codeyam-cli/templates/expo-react-native/app/index.tsx +36 -0
  642. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  643. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  644. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  645. package/codeyam-cli/templates/expo-react-native/global.css +10 -0
  646. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  647. package/codeyam-cli/templates/expo-react-native/lib/theme.ts +73 -0
  648. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  649. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  650. package/codeyam-cli/templates/expo-react-native/package.json +48 -0
  651. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  652. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  653. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  654. package/codeyam-cli/templates/isolation-route/expo-router.tsx.template +54 -0
  655. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  656. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  657. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  658. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  659. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  660. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  661. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  662. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  663. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  664. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  665. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  666. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  667. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  668. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  669. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  670. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  671. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  672. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  673. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  674. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  675. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  676. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  677. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  678. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  679. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  680. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  681. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +140 -0
  682. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  683. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  684. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  685. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  686. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  687. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  688. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  689. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  690. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  691. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  692. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  693. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  694. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  695. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  696. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  697. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  698. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  699. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  700. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  701. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  702. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  703. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  704. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  705. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  706. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  707. package/codeyam-cli/templates/rule-reflection-hook.py +25 -5
  708. package/codeyam-cli/templates/rules-instructions.md +34 -88
  709. package/codeyam-cli/templates/seed-adapters/supabase.ts +291 -0
  710. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  711. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +244 -0
  712. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  713. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  714. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  715. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  716. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  717. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  718. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  719. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  720. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  721. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  722. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  723. package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -2
  724. package/package.json +23 -15
  725. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  726. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  727. package/packages/ai/src/lib/astScopes/methodSemantics.js +99 -0
  728. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  729. package/packages/ai/src/lib/astScopes/nodeToSource.js +16 -0
  730. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -1
  731. package/packages/ai/src/lib/astScopes/paths.js +12 -3
  732. package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
  733. package/packages/ai/src/lib/completionCall.js +10 -7
  734. package/packages/ai/src/lib/completionCall.js.map +1 -1
  735. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +261 -13
  736. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  737. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
  738. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
  739. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +14 -4
  740. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  741. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  742. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  743. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  744. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  745. package/packages/ai/src/lib/dataStructureChunking.js +9 -5
  746. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  747. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  748. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  749. package/packages/ai/src/lib/generateExecutionFlows.js +81 -11
  750. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  751. package/packages/analyze/index.js +1 -1
  752. package/packages/analyze/index.js.map +1 -1
  753. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  754. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  755. package/packages/analyze/src/lib/asts/index.js +4 -2
  756. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  757. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  758. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  759. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +16 -2
  760. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  761. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +14 -27
  762. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  763. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  764. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  765. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +12 -2
  766. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  767. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +9 -7
  768. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  769. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
  770. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
  771. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -11
  772. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  773. package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
  774. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  775. package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
  776. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  777. package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
  778. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
  779. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  780. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  781. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +185 -28
  782. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  783. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  784. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  785. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1386 -1197
  786. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  787. package/packages/database/index.js +1 -0
  788. package/packages/database/index.js.map +1 -1
  789. package/packages/database/src/lib/kysely/db.js +5 -0
  790. package/packages/database/src/lib/kysely/db.js.map +1 -1
  791. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  792. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  793. package/packages/database/src/lib/loadAnalysis.js +7 -1
  794. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  795. package/packages/database/src/lib/loadCommits.js +23 -13
  796. package/packages/database/src/lib/loadCommits.js.map +1 -1
  797. package/packages/database/src/lib/loadEntities.js +0 -6
  798. package/packages/database/src/lib/loadEntities.js.map +1 -1
  799. package/packages/database/src/lib/loadEntity.js +5 -5
  800. package/packages/database/src/lib/loadEntity.js.map +1 -1
  801. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  802. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  803. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  804. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  805. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  806. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  807. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  808. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  809. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  810. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  811. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  812. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  813. package/packages/types/src/enums/ProjectFramework.js +2 -0
  814. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  815. package/packages/utils/src/lib/fs/rsyncCopy.js +28 -3
  816. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  817. package/scripts/npm-post-install.cjs +34 -0
  818. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -120
  819. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  820. package/codeyam-cli/src/commands/list.js +0 -31
  821. package/codeyam-cli/src/commands/list.js.map +0 -1
  822. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  823. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  824. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  825. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  826. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-D9i_zSlY.js +0 -1
  827. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-De5b5pC7.js +0 -1
  828. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bclf8Hka.js +0 -34
  829. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-Ce-byqKl.js +0 -25
  830. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DEMHrl7v.js +0 -3
  831. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-L0DWHa_L.js +0 -1
  832. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-C7PFQfXy.js +0 -1
  833. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-CPXtdaWm.js +0 -17
  834. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BEyX4X6_.js +0 -51
  835. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-DHVDauuc.js +0 -21
  836. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
  837. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-B9_ZqelV.js +0 -1
  838. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-BOPComvD.js +0 -16
  839. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Cfw__yQa.js +0 -6
  840. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-BIDUUrI3.js +0 -6
  841. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-CYnF5KWN.js +0 -1
  842. package/codeyam-cli/src/webserver/build/client/assets/files-B_dAq2PQ.js +0 -1
  843. package/codeyam-cli/src/webserver/build/client/assets/git-BHPqH3Ch.js +0 -15
  844. package/codeyam-cli/src/webserver/build/client/assets/globals-BJGhRykz.css +0 -1
  845. package/codeyam-cli/src/webserver/build/client/assets/labs-ChoAe3xq.js +0 -1
  846. package/codeyam-cli/src/webserver/build/client/assets/manifest-87493a32.js +0 -1
  847. package/codeyam-cli/src/webserver/build/client/assets/memory-D9eA6kTo.js +0 -78
  848. package/codeyam-cli/src/webserver/build/client/assets/root-C3r0p_7H.js +0 -62
  849. package/codeyam-cli/src/webserver/build/client/assets/settings-KH9TdArD.js +0 -1
  850. package/codeyam-cli/src/webserver/build/client/assets/simulations-D9Fkx0-d.js +0 -1
  851. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CLPnITMB.js +0 -1
  852. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DmGI38Et.js +0 -2
  853. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-BK0S88PB.js +0 -1
  854. package/codeyam-cli/src/webserver/build/client/assets/useToast-CJ-JqR0l.js +0 -1
  855. package/codeyam-cli/src/webserver/build/server/assets/index-CkkmL6r5.js +0 -1
  856. package/codeyam-cli/src/webserver/build/server/assets/server-build-iBGjHYtO.js +0 -259
  857. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  858. package/scripts/finalize-analyzer.cjs +0 -13
  859. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  860. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  861. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  862. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  863. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  864. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -19,6 +19,8 @@ import convertNullToUndefinedBySchema from './dataStructure/helpers/convertNullT
19
19
  import convertTypeAnnotationsToValues from './dataStructure/helpers/convertTypeAnnotationsToValues';
20
20
  import fixNullIdsBySchema from './dataStructure/helpers/fixNullIdsBySchema';
21
21
  import coerceObjectsToPrimitivesBySchema from './dataStructure/helpers/coerceObjectsToPrimitivesBySchema';
22
+ import coercePrimitivesToArraysBySchema from './dataStructure/helpers/coercePrimitivesToArraysBySchema';
23
+ import stripNullableMarkers from './dataStructure/helpers/stripNullableMarkers';
22
24
  import { JsonTypeDefinition } from '~codeyam/types';
23
25
  import { deepMerge } from '~codeyam/generate';
24
26
  import {
@@ -172,6 +174,46 @@ function findKeyPath(
172
174
  return null;
173
175
  }
174
176
 
177
+ /**
178
+ * Strip primitive values from `source` when the `destination` already has an
179
+ * array or object at the same key. Returns a cleaned copy of source (or null
180
+ * if nothing remains after stripping).
181
+ *
182
+ * This prevents misplaced LLM data (e.g., `{ webapps: true }`) from
183
+ * overwriting correct complex values (e.g., `{ webapps: [...] }`) during
184
+ * deep merge in relocateMisplacedNestedKeys.
185
+ */
186
+ function stripPrimitivesOverwritingComplexValues(
187
+ destination: Record<string, unknown>,
188
+ source: unknown,
189
+ ): Record<string, unknown> | null {
190
+ if (typeof source !== 'object' || source === null || Array.isArray(source)) {
191
+ return null;
192
+ }
193
+
194
+ const result: Record<string, unknown> = {};
195
+ let hasKeys = false;
196
+
197
+ for (const key of Object.keys(source as Record<string, unknown>)) {
198
+ const srcVal = (source as Record<string, unknown>)[key];
199
+ const dstVal = destination[key];
200
+
201
+ // If destination has an array or object but source has a primitive, skip it
202
+ if (
203
+ typeof dstVal === 'object' &&
204
+ dstVal !== null &&
205
+ typeof srcVal !== 'object'
206
+ ) {
207
+ continue;
208
+ }
209
+
210
+ result[key] = srcVal;
211
+ hasKeys = true;
212
+ }
213
+
214
+ return hasKeys ? result : null;
215
+ }
216
+
175
217
  /**
176
218
  * Relocate misplaced nested keys in mockData to their correct position
177
219
  * based on the dataForMocks structure.
@@ -233,12 +275,22 @@ function relocateMisplacedNestedKeys(
233
275
  }
234
276
 
235
277
  // Deep merge the value into the correct location
236
- // Use deep merge to preserve existing data at that location
278
+ // Use deep merge to preserve existing data at that location.
279
+ // Before merging, strip primitives from the misplaced value that would
280
+ // overwrite arrays/objects at the destination. The misplaced data is lower
281
+ // quality — the LLM put it in the wrong place — so primitives like `true`
282
+ // should not overwrite correct complex values like arrays.
237
283
  if (current[key] !== undefined && typeof current[key] === 'object') {
238
- current[key] = deepMerge(
284
+ const safeValue = stripPrimitivesOverwritingComplexValues(
239
285
  current[key] as Record<string, unknown>,
240
286
  value as Record<string, unknown>,
241
287
  );
288
+ if (safeValue !== null) {
289
+ current[key] = deepMerge(
290
+ current[key] as Record<string, unknown>,
291
+ safeValue,
292
+ );
293
+ }
242
294
  } else {
243
295
  current[key] = value;
244
296
  }
@@ -1063,6 +1115,18 @@ export async function generateDataForScenario({
1063
1115
  );
1064
1116
  }
1065
1117
 
1118
+ // Strip _nullable markers from LLM-generated mock data.
1119
+ // The _nullable marker is an internal CodeYam concept used in type definitions
1120
+ // to indicate that a field can be null/undefined. The LLM sometimes includes
1121
+ // these markers in its generated data, which causes runtime errors when code
1122
+ // iterates over object keys (e.g., Object.keys(importedBy) picks up "_nullable",
1123
+ // then Object.keys(importedBy["_nullable"]) calls Object.keys(null) and throws).
1124
+ if (fullScenarioData.data.mockData) {
1125
+ stripNullableMarkers(
1126
+ fullScenarioData.data.mockData as Record<string, unknown>,
1127
+ );
1128
+ }
1129
+
1066
1130
  // Relocate misplaced nested keys to their correct position.
1067
1131
  // The LLM sometimes places nested keys at root level instead of inside their
1068
1132
  // parent object (e.g., 'fastener' at root instead of inside 'trpc').
@@ -1098,6 +1162,18 @@ export async function generateDataForScenario({
1098
1162
  );
1099
1163
  }
1100
1164
 
1165
+ // Coerce primitives to empty arrays when the schema expects an array.
1166
+ // The LLM sometimes generates a primitive (e.g., `webapps: true`) where the
1167
+ // schema expects an array (e.g., `webapps: [{ name: "string" }]`).
1168
+ // This causes runtime errors like "TypeError: config.webapps?.forEach is not a function".
1169
+ // Must run AFTER coerceObjectsToPrimitivesBySchema and BEFORE convertCommaSeparatedStringsToArrays.
1170
+ if (structure.dataForMocks && fullScenarioData.data.mockData) {
1171
+ coercePrimitivesToArraysBySchema(
1172
+ fullScenarioData.data.mockData,
1173
+ structure.dataForMocks,
1174
+ );
1175
+ }
1176
+
1101
1177
  // Convert comma-separated strings to arrays when appropriate.
1102
1178
  // The LLM sometimes generates strings like "color,size" instead of arrays
1103
1179
  // like ["color", "size"] when the schema type is incorrectly inferred as
@@ -32,6 +32,30 @@ import resolvePathToControllable from './resolvePathToControllable';
32
32
  import { AI } from '~codeyam/ai';
33
33
  import type { JsxRenderingUsage, ConditionalUsage } from './astScopes/types';
34
34
 
35
+ /**
36
+ * Patterns that indicate a child component is a modal/overlay/blocking element.
37
+ * Same patterns used in generateExecutionFlowsFromConditionalEffects.ts for
38
+ * state variable names — here applied to child component names.
39
+ */
40
+ const BLOCKING_CHILD_PATTERNS = [
41
+ /modal/i,
42
+ /overlay/i,
43
+ /dialog/i,
44
+ /popup/i,
45
+ /drawer/i,
46
+ /sheet/i,
47
+ /lightbox/i,
48
+ /backdrop/i,
49
+ ];
50
+
51
+ /**
52
+ * Check if a child component name suggests it's a blocking/modal element.
53
+ * Exported for testing.
54
+ */
55
+ export function isBlockingChildComponent(componentName: string): boolean {
56
+ return BLOCKING_CHILD_PATTERNS.some((pattern) => pattern.test(componentName));
57
+ }
58
+
35
59
  interface GenerateExecutionFlowsArgs {
36
60
  entity: Pick<Entity, 'sha' | 'name' | 'filePath' | 'code' | 'metadata'>;
37
61
  mergedDataStructure: Omit<DataStructure, 'equivalentSignatureVariables'>;
@@ -105,19 +129,6 @@ export default function generateExecutionFlows({
105
129
  fullToShortPathMap[fullPath] = shortPath;
106
130
  }
107
131
 
108
- console.log(
109
- `[generateExecutionFlows] ${entity.name}: attributesMap has ${Object.keys(resolvedAttributesMap).length} keys, fullToShortPathMap has ${Object.keys(fullToShortPathMap).length} entries`,
110
- );
111
- console.log(
112
- `[generateExecutionFlows] ${entity.name}: attributesMap keys: [${Object.keys(resolvedAttributesMap).join(', ')}]`,
113
- );
114
- console.log(
115
- `[generateExecutionFlows] ${entity.name}: fullToShortPathMap: ${JSON.stringify(fullToShortPathMap)}`,
116
- );
117
- console.log(
118
- `[generateExecutionFlows] ${entity.name}: equivalentSignatureVariables: ${JSON.stringify(equivalentSignatureVariables)}`,
119
- );
120
-
121
132
  // Get pre-computed conditional data from metadata
122
133
  const conditionalUsages: Record<string, ConditionalUsage[]> =
123
134
  entity.metadata?.isolatedDataStructure?.conditionalUsages ?? {};
@@ -162,26 +173,6 @@ export default function generateExecutionFlows({
162
173
  }
163
174
  }
164
175
 
165
- console.log(
166
- `[generateExecutionFlows] ${entity.name}: conditionalUsages keys: [${Object.keys(conditionalUsages).join(', ')}]`,
167
- );
168
- console.log(
169
- `[generateExecutionFlows] ${entity.name}: conditionalUsages sourceDataPaths: ${JSON.stringify(
170
- Object.fromEntries(
171
- Object.entries(conditionalUsages).map(([k, v]) => [
172
- k,
173
- (v as any[]).map((u: any) => u.sourceDataPath ?? '(none)'),
174
- ]),
175
- ),
176
- )}`,
177
- );
178
- console.log(
179
- `[generateExecutionFlows] ${entity.name}: compoundConditionals count: ${compoundConditionals.length}`,
180
- );
181
- console.log(
182
- `[generateExecutionFlows] ${entity.name}: sourceEquivalencies keys count: ${Object.keys(mergedDataStructure.sourceEquivalencies ?? {}).length}`,
183
- );
184
-
185
176
  const conditionalsBasedFlows = generateExecutionFlowsFromConditionals({
186
177
  conditionalUsages,
187
178
  compoundConditionals,
@@ -273,6 +264,11 @@ export default function generateExecutionFlows({
273
264
  calculateFlowPriority(flow, gatingPathToChildren);
274
265
  }
275
266
 
267
+ // Assign exclusiveGroup for truthy/falsy flow pairs that control child components.
268
+ // When the same gating path produces both a truthy flow (show component) and a
269
+ // falsy flow (hide component), they are mutually exclusive and should be grouped.
270
+ assignExclusiveGroupsForGatingPairs(allFlows);
271
+
276
272
  // Sort flows by priority (highest first)
277
273
  allFlows.sort((a, b) => (b.priority ?? 0) - (a.priority ?? 0));
278
274
 
@@ -361,6 +357,60 @@ function buildGatingPathToChildrenMap(
361
357
  return gatingPathToChildren;
362
358
  }
363
359
 
360
+ /**
361
+ * Assign exclusiveGroup for truthy/falsy flow pairs that control child components.
362
+ *
363
+ * When the same attribute path produces both a truthy and falsy flow (e.g.,
364
+ * {diffView && <DiffModal/>}), they are mutually exclusive — only one can be
365
+ * active at a time. Grouping them ensures the scenario generator treats them
366
+ * as alternative states rather than combining them.
367
+ */
368
+ function assignExclusiveGroupsForGatingPairs(flows: ExecutionFlow[]): void {
369
+ // Build a map: attributePath -> flows with truthy or falsy comparison for that path
370
+ const pathToFlows = new Map<
371
+ string,
372
+ { truthy: ExecutionFlow[]; falsy: ExecutionFlow[] }
373
+ >();
374
+
375
+ for (const flow of flows) {
376
+ // Only consider flows that control child components
377
+ if (!flow.childComponentsControlled?.length) continue;
378
+
379
+ for (const rv of flow.requiredValues) {
380
+ if (rv.comparison === 'truthy' || rv.comparison === 'falsy') {
381
+ if (!pathToFlows.has(rv.attributePath)) {
382
+ pathToFlows.set(rv.attributePath, { truthy: [], falsy: [] });
383
+ }
384
+ pathToFlows.get(rv.attributePath)![rv.comparison].push(flow);
385
+ }
386
+ }
387
+ }
388
+
389
+ // Also check falsy flows that DON'T have childComponentsControlled —
390
+ // they still pair with truthy flows that do
391
+ for (const flow of flows) {
392
+ if (flow.childComponentsControlled?.length) continue; // Already processed
393
+
394
+ for (const rv of flow.requiredValues) {
395
+ if (rv.comparison === 'falsy' && pathToFlows.has(rv.attributePath)) {
396
+ pathToFlows.get(rv.attributePath)!.falsy.push(flow);
397
+ }
398
+ }
399
+ }
400
+
401
+ // Assign exclusiveGroup where both truthy and falsy flows exist
402
+ for (const [attributePath, { truthy, falsy }] of pathToFlows) {
403
+ if (truthy.length > 0 && falsy.length > 0) {
404
+ const groupName = `gating:${attributePath}`;
405
+ for (const flow of [...truthy, ...falsy]) {
406
+ if (!flow.exclusiveGroup) {
407
+ flow.exclusiveGroup = groupName;
408
+ }
409
+ }
410
+ }
411
+ }
412
+ }
413
+
364
414
  /**
365
415
  * Calculate priority and childComponentsControlled for a flow.
366
416
  *
@@ -415,6 +465,19 @@ function calculateFlowPriority(
415
465
  if (flow.impact !== 'high') {
416
466
  flow.impact = 'high';
417
467
  }
468
+
469
+ // Check if any controlled child component is a modal/dialog/overlay.
470
+ // Only truthy flows (which SHOW the component) should be marked as blocking.
471
+ // Falsy flows (which HIDE the component) should not be blocking.
472
+ const isTruthyFlow = flow.requiredValues.some(
473
+ (rv) => rv.comparison === 'truthy' || rv.comparison === 'equals',
474
+ );
475
+ if (
476
+ isTruthyFlow &&
477
+ Array.from(childComponentsControlled).some(isBlockingChildComponent)
478
+ ) {
479
+ flow.blocksOtherFlows = true;
480
+ }
418
481
  }
419
482
 
420
483
  // Calculate priority score
@@ -36,7 +36,10 @@ export { getAllEntityNodes } from './src/lib/asts/sourceFiles/getAllEntityNodes'
36
36
  export { default as fileAnalyzerFromCode } from './src/lib/files/fileAnalyzerFromCode';
37
37
 
38
38
  export { default as isolateDataStructure } from './src/lib/files/scenarios/isolateDataStructure';
39
- export { default as mergeInDependentDataStructure } from './src/lib/files/scenarios/mergeInDependentDataStructure';
39
+ export {
40
+ default as mergeInDependentDataStructure,
41
+ DataStructureTimeoutError,
42
+ } from './src/lib/files/scenarios/mergeInDependentDataStructure';
40
43
  export { default as mergeValidatedDataStructures } from './src/lib/files/scenarios/mergeValidatedDataStructures';
41
44
 
42
45
  export { discoverDirectDependencies } from './src/lib/files/analyze/dependencyResolver';
@@ -46,6 +46,12 @@ export class ProjectAnalyzer {
46
46
  lib.asts.createProgramFromTsConfigPath(configPath, excludePatterns),
47
47
  );
48
48
 
49
+ if (this.programs.length === 0) {
50
+ throw new Error(
51
+ 'No TypeScript programs could be created — no tsconfig.json found',
52
+ );
53
+ }
54
+
49
55
  // Primary program is the first one (usually root) for backward compatibility
50
56
  this.program = this.programs[0];
51
57
  this.typeChecker = this.program.getTypeChecker();
@@ -334,17 +340,23 @@ export class ProjectAnalyzer {
334
340
  * Refresh the TypeScript program to pick up file changes
335
341
  */
336
342
  refreshProgram(): void {
337
- // Memory logging: Capture state before refresh
338
- const memBefore = process.memoryUsage();
339
-
340
343
  // Apply the same unapprovedPaths filtering when refreshing
341
344
  const excludePatterns =
342
345
  this.project.metadata?.unapprovedPaths?.filter(Boolean) || [];
343
346
 
344
- // Refresh all programs
345
- this.programs = this.tsConfigPaths.map((configPath) =>
346
- lib.asts.createProgramFromTsConfigPath(configPath, excludePatterns),
347
- );
347
+ // Release old programs and caches BEFORE creating new ones to reduce peak memory.
348
+ // Without this, both old (~1.7GB) and new (~1.7GB) programs coexist during creation,
349
+ // causing OOM on monorepos with multiple tsconfigs.
350
+ this.programs = [];
351
+ this.sourceFileByPath.clear();
352
+ this.typeCheckerByPath.clear();
353
+
354
+ // Create programs one at a time so each old program can be GC'd before the next
355
+ for (const configPath of this.tsConfigPaths) {
356
+ this.programs.push(
357
+ lib.asts.createProgramFromTsConfigPath(configPath, excludePatterns),
358
+ );
359
+ }
348
360
 
349
361
  // Update primary program for backward compatibility
350
362
  this.program = this.programs[0];
@@ -95,8 +95,13 @@ export function createProgramFromTsConfigPath(
95
95
  throw new Error('Could not parse tsconfig.json');
96
96
  }
97
97
 
98
- // Filter file names based on exclude patterns to reduce memory usage
99
- let fileNames = parsedCommandLine.fileNames;
98
+ // Always filter out node_modules from root files to prevent OOM on large projects.
99
+ // This only removes them as root compilation targets — TypeScript's module resolution
100
+ // still follows imports into node_modules for type info when processing source files.
101
+ let fileNames = parsedCommandLine.fileNames.filter(
102
+ (f) => !f.includes('/node_modules/'),
103
+ );
104
+
100
105
  if (excludePatterns && excludePatterns.length > 0) {
101
106
  const regexPatterns = excludePatterns
102
107
  .map((pattern) => {
@@ -39,6 +39,7 @@ export function getNodeType(node: ts.Node, sourceFile: ts.SourceFile) {
39
39
  case 'StringLiteral':
40
40
  case 'NumericLiteral':
41
41
  case 'ObjectLiteralExpression':
42
+ case 'ArrayLiteralExpression':
42
43
  nodeType = 'data';
43
44
  break;
44
45
  case 'TypeAliasDeclaration':
@@ -289,18 +289,44 @@ export default async function prepareEntityDataStructures(
289
289
  skipWorkerPool();
290
290
  }
291
291
 
292
+ awsLogDebugLevel(
293
+ 1,
294
+ `Preparing data structures for ${entities.length} entities (${entitiesNeedingGeneration} need generation)...`,
295
+ );
296
+ const startTime = Date.now();
297
+ let completedCount = 0;
298
+
299
+ // Wrap processEntity to track progress
300
+ const processEntityWithProgress = async (entity: Entity) => {
301
+ await processEntity(entity);
302
+ completedCount++;
303
+ // Emit progress every 10 entities
304
+ if (completedCount % 10 === 0) {
305
+ awsLogDebugLevel(
306
+ 1,
307
+ `Preparing data structures... (${completedCount}/${entities.length})`,
308
+ );
309
+ }
310
+ };
311
+
292
312
  const sequential =
293
313
  DEBUG_SEQUENTIAL_EXECUTION || options.sequentialDataStructurePrep;
294
314
 
295
315
  if (sequential) {
296
316
  // Sequential execution for debugging - process one entity at a time
297
317
  for (const entity of entities) {
298
- await processEntity(entity);
318
+ await processEntityWithProgress(entity);
299
319
  }
300
320
  } else {
301
321
  // Parallel execution for speed
302
- await Promise.all(entities.map(processEntity));
322
+ await Promise.all(entities.map(processEntityWithProgress));
303
323
  }
324
+
325
+ const elapsed = Date.now() - startTime;
326
+ awsLogDebugLevel(
327
+ 1,
328
+ `Data structure preparation complete: ${entities.length} entities in ${elapsed}ms`,
329
+ );
304
330
  }
305
331
 
306
332
  /**
@@ -8,13 +8,11 @@ import {
8
8
  import { transformationTracer } from '../scenarios/TransformationTracer';
9
9
  import { getFileByPathSafe } from '../../utils/getFileByPath';
10
10
  import trackEntityCircularDependencies from './trackEntityCircularDependencies';
11
- import validateDependencyAnalyses from './validateDependencyAnalyses';
12
11
  import extractClassMethods from './analyzeEntities/extractClassMethods';
13
12
  import prepareDataStructures from './analyzeEntities/prepareDataStructures';
14
13
  import { strategies, asyncComplex } from './analyzeEntities/strategies';
15
14
  import {
16
15
  updateCommitMetadata,
17
- updateFreshAnalysisMetadata,
18
16
  updateFreshAnalysisStatus,
19
17
  upsertAnalyses,
20
18
  upsertEntities,
@@ -263,40 +261,11 @@ export default async function analyzeEntities({
263
261
  }
264
262
  }
265
263
 
266
- awsLog(`CodeYam: analyzeEntities: Running patch-up dependency validation`);
267
- for (const analysis of analyses) {
268
- if (!analysis.entity) {
269
- throw new Error(
270
- `CodeYam: analyzeEntities: Internal error: Analysis entity is missing for ${analysis.filePath}:${analysis.entityName}.`,
271
- );
272
- }
273
-
274
- // Validate dependencies, which modifies analysis.metadata.dependentAnalyses
275
- validateDependencyAnalyses({ analysis, entity: analysis.entity, context });
276
-
277
- // Carefully update only the metadata field
278
- if (analysis.id) {
279
- const updatedMetadata = await updateFreshAnalysisMetadata(
280
- analysis.id,
281
- (metadata) => {
282
- metadata.dependentAnalyses =
283
- analysis.metadata?.dependentAnalyses || [];
284
- },
285
- );
286
-
287
- if (updatedMetadata) {
288
- analysis.metadata = updatedMetadata;
289
- } else {
290
- console.warn(
291
- `CodeYam: analyzeEntities: Failed to update metadata for analysis ${analysis.id}`,
292
- );
293
- }
294
- } else {
295
- console.warn(
296
- `CodeYam: analyzeEntities: Analysis ${analysis.filePath}:${analysis.entityName} has no ID, skipping metadata update`,
297
- );
298
- }
299
- }
264
+ // NOTE: patch-up dependency validation loop was removed here.
265
+ // analysis.metadata.dependentAnalyses is already populated by validateDependencyAnalyses
266
+ // inside analyzeEntity() (Call #1) and persisted via upsertAnalysesWithScenarios at the
267
+ // end of analyzeEntity, then again by upsertAnalyses in analyzeOneEntityKey. Re-validating
268
+ // every analysis from scratch was redundant work — especially costly for large projects.
300
269
 
301
270
  const newlyReady = await updateReadyAnalyses();
302
271
  if (newlyReady.length > 0) {
@@ -310,7 +279,15 @@ export default async function analyzeEntities({
310
279
  );
311
280
 
312
281
  // Flush transformation trace if tracing is enabled
313
- transformationTracer.flush();
282
+ // Wrapped in try/catch because trace data can exceed V8's max string length
283
+ // for large projects, and we must not crash the analysis process over tracing.
284
+ try {
285
+ transformationTracer.flush();
286
+ } catch (e) {
287
+ console.warn(
288
+ `CodeYam Warning: Failed to flush transformation trace: ${e.message}`,
289
+ );
290
+ }
314
291
 
315
292
  return analyses;
316
293
 
@@ -100,12 +100,6 @@ export function getCandidatesReadyForCapture(
100
100
  continue;
101
101
  }
102
102
 
103
- // Skip notExported entities - they can't be imported into the simulation
104
- // environment and will always fail capture. Don't mark them as ready.
105
- if (candidate.entity?.metadata?.notExported) {
106
- continue;
107
- }
108
-
109
103
  // Get all transitive dependencies
110
104
  const candidateKey = `${candidate.filePath}:${candidate.entityName}`;
111
105
  const { missingDependencies } = getTransitiveDependencies(
@@ -94,12 +94,15 @@ export default async function findOrCreateEntity({
94
94
  try {
95
95
  code = fileAnalyzer.getEntityCode(localEntityName);
96
96
  } catch (e) {
97
- console.log('CodeYam Error: could not get entity code', {
98
- filePath: file.path,
99
- localEntityName,
100
- entityName,
101
- error: e,
102
- });
97
+ console.log(
98
+ `CodeYam Error: Could not extract code for "${localEntityName}" from ${file.path} — export not found in file, may have been moved or renamed during refactoring`,
99
+ {
100
+ filePath: file.path,
101
+ localEntityName,
102
+ entityName,
103
+ error: String(e),
104
+ },
105
+ );
103
106
  return null;
104
107
  }
105
108
  const sha = generateSha(file.path, entityName, code);
@@ -108,6 +111,7 @@ export default async function findOrCreateEntity({
108
111
  entity = await loadEntity({
109
112
  projectId: project.id,
110
113
  sha,
114
+ silent: true, // Entity not existing yet is the normal path — we create it below
111
115
  });
112
116
  }
113
117
 
@@ -138,6 +142,18 @@ export default async function findOrCreateEntity({
138
142
  break;
139
143
  }
140
144
  }
145
+
146
+ // Mark previous versions as superseded
147
+ const entitiesToSupersede = previousEntities.filter(
148
+ (e) => !e.metadata?.isSuperseded,
149
+ );
150
+ if (entitiesToSupersede.length > 0) {
151
+ for (const prev of entitiesToSupersede) {
152
+ prev.metadata = prev.metadata || {};
153
+ prev.metadata.isSuperseded = true;
154
+ }
155
+ await upsertEntities(entitiesToSupersede);
156
+ }
141
157
  }
142
158
 
143
159
  entity = {
@@ -111,18 +111,15 @@ export default async function gatherEntityMap({
111
111
  });
112
112
 
113
113
  if (!importedEntity) {
114
- console.log(
115
- `CodeYam Error: Entity not found while gathering entity map: ${importedFile.path}: ${importedExportName}`,
116
- {
117
- entityName: entity.name,
118
- entityFilePath: entity.filePath,
119
- importedFilePath: importedFile.path,
120
- importedExportName: importedExportName,
121
- },
122
- );
123
- throw new Error(
124
- `Entity not found while gathering entity map: ${importedFile.path}: ${importedExport.name}`,
125
- );
114
+ const msg = [
115
+ `Entity not found: "${importedExportName}" in ${importedFile.path}`,
116
+ ` While analyzing dependencies of: ${entity.name} (${entity.filePath})`,
117
+ ` This usually means "${importedExportName}" was moved or renamed but`,
118
+ ` ${entity.filePath} still has stale import metadata referencing the old location.`,
119
+ ` Fix: Update or re-analyze ${entity.filePath} so its importedExports reflect current code.`,
120
+ ].join('\n');
121
+ console.log(`CodeYam Error: ${msg}`);
122
+ throw new Error(msg);
126
123
  }
127
124
 
128
125
  // Add newly created entity to context
@@ -1,5 +1,6 @@
1
1
  import type { Entity } from '~codeyam/types';
2
2
  import { AnalysisContext } from '../../analysisContext';
3
+ import { awsLogDebugLevel } from '~codeyam/utils';
3
4
 
4
5
  /**
5
6
  * Optimized version that processes multiple root entities in a single traversal.
@@ -16,6 +17,8 @@ export default function trackEntityCircularDependencies(
16
17
  try {
17
18
  const allEntities = new Set<Entity>();
18
19
  const globalVisited = new Set<string>(); // Track by SHA to avoid duplicate traversals
20
+ let circularCount = 0;
21
+ const startTime = Date.now();
19
22
 
20
23
  // Process each root entity, but skip if already processed
21
24
  for (const rootEntity of rootEntities) {
@@ -32,8 +35,26 @@ export default function trackEntityCircularDependencies(
32
35
  globalVisited,
33
36
  allEntities,
34
37
  );
38
+
39
+ // Emit periodic progress for large projects
40
+ if (allEntities.size % 100 === 0 && allEntities.size > 0) {
41
+ awsLogDebugLevel(
42
+ 1,
43
+ `Mapping dependencies... (${allEntities.size} entities discovered)`,
44
+ );
45
+ }
35
46
  }
36
47
 
48
+ const elapsed = Date.now() - startTime;
49
+ // Count circular deps
50
+ for (const entity of allEntities) {
51
+ if (entity.metadata?.hasCircularDependency) circularCount++;
52
+ }
53
+ awsLogDebugLevel(
54
+ 1,
55
+ `Dependency mapping complete: ${allEntities.size} entities, ${circularCount} circular, ${elapsed}ms`,
56
+ );
57
+
37
58
  return allEntities;
38
59
  } catch (e) {
39
60
  console.log(