@codeyam/codeyam-cli 0.1.0-staging.bd4126b → 0.1.0-staging.c276166

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 (648) hide show
  1. package/analyzer-template/.build-info.json +7 -7
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +10 -10
  4. package/analyzer-template/packages/ai/package.json +2 -2
  5. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  6. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  7. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +27 -0
  8. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  9. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +78 -2
  10. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +0 -33
  11. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  12. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  13. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +9 -1
  14. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  15. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  16. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +65 -28
  17. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +83 -0
  18. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  19. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +23 -4
  20. package/analyzer-template/packages/aws/package.json +2 -2
  21. package/analyzer-template/packages/database/index.ts +1 -0
  22. package/analyzer-template/packages/database/package.json +3 -3
  23. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
  24. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +138 -0
  25. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  26. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  27. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  28. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  29. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  30. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  31. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  32. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  33. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  34. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  35. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  36. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  37. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  38. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  39. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  40. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  41. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +27 -0
  42. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  43. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  44. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  45. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  46. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  47. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  48. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  49. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  50. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  51. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  52. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  53. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  54. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  55. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  56. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  57. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  58. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  59. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  60. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  61. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  62. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  63. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  64. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  65. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  66. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  67. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  68. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  69. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  70. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  71. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  72. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  74. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  76. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  77. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  78. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/package.json +1 -1
  80. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  81. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  82. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  83. package/analyzer-template/packages/ui-components/package.json +1 -1
  84. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  85. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  86. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  87. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  88. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  89. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  90. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  91. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  92. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  93. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +6 -2
  94. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  95. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +14 -2
  96. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  97. package/analyzer-template/project/constructMockCode.ts +136 -43
  98. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  99. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  100. package/analyzer-template/project/start.ts +3 -0
  101. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  102. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  103. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  104. package/analyzer-template/project/writeScenarioComponents.ts +36 -7
  105. package/analyzer-template/tsconfig.json +13 -1
  106. package/background/src/lib/virtualized/project/constructMockCode.js +115 -34
  107. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  108. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  109. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  110. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  111. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  112. package/background/src/lib/virtualized/project/start.js +2 -0
  113. package/background/src/lib/virtualized/project/start.js.map +1 -1
  114. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  115. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  116. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  117. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  118. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  119. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  120. package/background/src/lib/virtualized/project/writeScenarioComponents.js +29 -7
  121. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  122. package/codeyam-cli/scripts/apply-setup.js +208 -11
  123. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  124. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  125. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  126. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  127. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  128. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  129. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  130. package/codeyam-cli/src/cli.js +9 -12
  131. package/codeyam-cli/src/cli.js.map +1 -1
  132. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  133. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  134. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  135. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  136. package/codeyam-cli/src/commands/analyze.js +17 -7
  137. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  138. package/codeyam-cli/src/commands/default.js +14 -2
  139. package/codeyam-cli/src/commands/default.js.map +1 -1
  140. package/codeyam-cli/src/commands/editor.js +3374 -0
  141. package/codeyam-cli/src/commands/editor.js.map +1 -0
  142. package/codeyam-cli/src/commands/init.js +107 -45
  143. package/codeyam-cli/src/commands/init.js.map +1 -1
  144. package/codeyam-cli/src/commands/memory.js +29 -58
  145. package/codeyam-cli/src/commands/memory.js.map +1 -1
  146. package/codeyam-cli/src/data/techStacks.js +77 -0
  147. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  148. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  149. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  150. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  151. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  152. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  153. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  154. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  155. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  156. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +855 -0
  157. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  158. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  159. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  160. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  161. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  162. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  163. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  164. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  165. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  166. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  167. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  168. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  169. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  170. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  171. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  172. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  173. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  174. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  175. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  176. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  177. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  178. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  179. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  180. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  181. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  182. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1029 -0
  183. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  184. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  185. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  186. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  187. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  188. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  189. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  190. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  191. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  192. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +6 -0
  193. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -1
  194. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  195. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  196. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  197. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  198. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  199. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  200. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  201. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  202. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  203. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  204. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +454 -0
  205. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  206. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +50 -4
  207. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  208. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  209. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  210. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  211. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  212. package/codeyam-cli/src/utils/analyzer.js +9 -0
  213. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  214. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  215. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  216. package/codeyam-cli/src/utils/backgroundServer.js +104 -12
  217. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  218. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  219. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  220. package/codeyam-cli/src/utils/database.js +37 -2
  221. package/codeyam-cli/src/utils/database.js.map +1 -1
  222. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  223. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  224. package/codeyam-cli/src/utils/devServerState.js +71 -0
  225. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  226. package/codeyam-cli/src/utils/editorApi.js +73 -0
  227. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  228. package/codeyam-cli/src/utils/editorAudit.js +176 -0
  229. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  230. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  231. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  232. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  233. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  234. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  235. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  236. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  237. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  238. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  239. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  240. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  241. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  242. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  243. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  244. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  245. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  246. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  247. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  248. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  249. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  250. package/codeyam-cli/src/utils/editorScenarios.js +375 -0
  251. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  252. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  253. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  254. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  255. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  256. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  257. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  258. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  259. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  260. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  261. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  262. package/codeyam-cli/src/utils/git.js +103 -0
  263. package/codeyam-cli/src/utils/git.js.map +1 -1
  264. package/codeyam-cli/src/utils/install-skills.js +57 -15
  265. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  266. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  267. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  268. package/codeyam-cli/src/utils/npmVersionCheck.js +2 -2
  269. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -1
  270. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  271. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  272. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  273. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  274. package/codeyam-cli/src/utils/progress.js +2 -2
  275. package/codeyam-cli/src/utils/progress.js.map +1 -1
  276. package/codeyam-cli/src/utils/project.js +15 -5
  277. package/codeyam-cli/src/utils/project.js.map +1 -1
  278. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  279. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  280. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  281. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  282. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  283. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  284. package/codeyam-cli/src/utils/queue/job.js +70 -1
  285. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  286. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  287. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  288. package/codeyam-cli/src/utils/requireSimulations.js +1 -1
  289. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -1
  290. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +5 -6
  291. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
  292. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +2 -5
  293. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
  294. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  295. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  296. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  297. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  298. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  299. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  300. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  301. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  302. package/codeyam-cli/src/utils/rules/index.js +1 -0
  303. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  304. package/codeyam-cli/src/utils/rules/parser.js +14 -4
  305. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  306. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  307. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  308. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  309. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  310. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  311. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  312. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  313. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  314. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  315. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  316. package/codeyam-cli/src/utils/scenariosManifest.js +241 -0
  317. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  318. package/codeyam-cli/src/utils/serverState.js +57 -2
  319. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  320. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +82 -11
  321. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  322. package/codeyam-cli/src/utils/simulationGateMiddleware.js +71 -43
  323. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -1
  324. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  325. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  326. package/codeyam-cli/src/utils/syncMocksMiddleware.js +2 -2
  327. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  328. package/codeyam-cli/src/utils/testRunner.js +158 -0
  329. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  330. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  331. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  332. package/codeyam-cli/src/utils/versionInfo.js +21 -0
  333. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  334. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  335. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  336. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  337. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  338. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  339. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  340. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +146 -0
  341. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  342. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  343. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  344. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  345. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  346. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  347. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  348. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  349. package/codeyam-cli/src/webserver/backgroundServer.js +118 -18
  350. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  351. package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-jNYXRRNI.js → CopyButton-BPXZwM4t.js} +1 -1
  352. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-bwuHPyTa.js → EntityItem-BcgbViKV.js} +3 -3
  353. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-CvzqMxcu.js → EntityTypeBadge-g3saevPb.js} +1 -1
  354. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BH0XDim7.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  355. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  356. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-yjIHlOGa.js → InteractivePreview-DYFW3lDD.js} +3 -3
  357. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-Cq5o8jL4.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  358. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BvMu2i-g.js → LoadingDots-BU_OAEMP.js} +1 -1
  359. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-kgBTLoJD.js → LogViewer-ceAyBX-H.js} +1 -1
  360. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-BzPgx-xO.js → ReportIssueModal-BzHcG7SE.js} +3 -3
  361. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CwZrv-Ok.js → SafeScreenshot-BED4B6sP.js} +1 -1
  362. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BX2Ny2Qj.js → ScenarioViewer-TSD3C211.js} +3 -3
  363. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  364. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-CDpEprKa.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  365. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  366. package/codeyam-cli/src/webserver/build/client/assets/{_index-BRx8ZGZo.js → _index-DLxKhri3.js} +3 -3
  367. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-4S4yPfFw.js → activity.(_tab)-BcY3q6nt.js} +6 -6
  368. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  369. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  370. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  371. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  372. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  373. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  374. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  375. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  376. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  377. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  378. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  379. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  380. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  381. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  382. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  383. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  384. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  385. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  386. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  387. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  388. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  389. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  390. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  391. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  392. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  393. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  394. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  395. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  396. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  397. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  398. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D4IPYH_y.js → book-open-BYOypzCa.js} +2 -2
  399. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-CG65viiV.js → chevron-down-C_Pmso5S.js} +2 -2
  400. package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-DB3aFuEO.js → chunk-JZWAC4HX-C4pqxYJB.js} +1 -1
  401. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-igfMr5DY.js → circle-check-BVMi9VA5.js} +2 -2
  402. package/codeyam-cli/src/webserver/build/client/assets/{copy-Coc4o_8c.js → copy-n2FB0_Sw.js} +3 -3
  403. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  404. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Ii3inc0_.js +1 -0
  405. package/codeyam-cli/src/webserver/build/client/assets/editor-CtRVY4nn.js +10 -0
  406. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CNB06EIa.js +41 -0
  407. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-B0h9AqE6.js → entity._sha._-DwCV5__E.js} +11 -11
  408. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-CXSi2aeZ.js +6 -0
  409. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CHMiAog3.js +6 -0
  410. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  411. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-PePWg17F.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  412. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-I-Wo99C_.js → entry.client-DTvKq3TY.js} +1 -1
  413. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-9sMMAiWJ.js → fileTableUtils-cPo8LiG3.js} +1 -1
  414. package/codeyam-cli/src/webserver/build/client/assets/{files-Co65J0s3.js → files-BZrlFE1F.js} +1 -1
  415. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  416. package/codeyam-cli/src/webserver/build/client/assets/globals-DozjVXrE.css +1 -0
  417. package/codeyam-cli/src/webserver/build/client/assets/{index-CUM5iXwc.js → index-10oVnAAH.js} +1 -1
  418. package/codeyam-cli/src/webserver/build/client/assets/{index-_417gcQW.js → index-BcvgDzbZ.js} +1 -1
  419. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  420. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  421. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-TzRHMVog.js → loader-circle-DaAZ_H2w.js} +2 -2
  422. package/codeyam-cli/src/webserver/build/client/assets/manifest-b431cb81.js +1 -0
  423. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  424. package/codeyam-cli/src/webserver/build/client/assets/{pause-hjzB7t2z.js → pause-f5-1lKBt.js} +3 -3
  425. package/codeyam-cli/src/webserver/build/client/assets/root-20m9-3-z.js +67 -0
  426. package/codeyam-cli/src/webserver/build/client/assets/{search-DcAwD_Ln.js → search-Di64LWVb.js} +2 -2
  427. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  428. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DVNJVQgD.js → simulations-DWT-CvLy.js} +1 -1
  429. package/codeyam-cli/src/webserver/build/client/assets/{terminal-DbEAHMbA.js → terminal-Br7MOqts.js} +3 -3
  430. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CAD5b1o_.js → triangle-alert-BLdiCuG-.js} +2 -2
  431. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C-_hOl_g.js +1 -0
  432. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  433. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DZlYx2c4.js → useReportContext-O-jkvSPx.js} +1 -1
  434. package/codeyam-cli/src/webserver/build/client/assets/{useToast-ihdMtlf6.js → useToast-9FIWuYfK.js} +1 -1
  435. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  436. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  437. package/codeyam-cli/src/webserver/build/server/assets/index-WJ6ysHIA.js +1 -0
  438. package/codeyam-cli/src/webserver/build/server/assets/init-3Om_In9B.js +10 -0
  439. package/codeyam-cli/src/webserver/build/server/assets/server-build-kfIP9lFK.js +439 -0
  440. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  441. package/codeyam-cli/src/webserver/build-info.json +5 -5
  442. package/codeyam-cli/src/webserver/devServer.js +39 -5
  443. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  444. package/codeyam-cli/src/webserver/editorProxy.js +877 -0
  445. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  446. package/codeyam-cli/src/webserver/idleDetector.js +73 -0
  447. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  448. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  449. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  450. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  451. package/codeyam-cli/src/webserver/server.js +300 -1
  452. package/codeyam-cli/src/webserver/server.js.map +1 -1
  453. package/codeyam-cli/src/webserver/terminalServer.js +735 -0
  454. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  455. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  456. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  457. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  458. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  459. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  460. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  461. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  462. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  463. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  464. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  465. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  466. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  467. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  468. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  469. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  470. package/codeyam-cli/templates/editor-step-hook.py +236 -0
  471. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  472. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  473. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  474. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  475. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  476. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  477. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  478. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  479. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  480. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  481. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  482. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  483. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  484. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  485. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  486. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  487. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  488. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  489. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  490. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  491. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  492. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  493. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  494. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  495. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  496. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  497. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  498. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  499. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  500. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  501. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  502. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  503. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  504. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  505. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  506. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  507. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  508. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  509. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  510. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  511. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  512. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  513. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  514. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  515. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  516. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  517. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  518. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  519. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  520. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  521. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  522. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  523. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  524. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  525. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  526. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  527. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  528. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  529. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  530. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  531. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  532. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  533. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  534. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  535. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  536. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  537. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  538. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  539. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  540. package/codeyam-cli/templates/rule-reflection-hook.py +24 -4
  541. package/codeyam-cli/templates/rules-instructions.md +34 -88
  542. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  543. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +149 -0
  544. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  545. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  546. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  547. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  548. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  549. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  550. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  551. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  552. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  553. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  554. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  555. package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -2
  556. package/package.json +17 -10
  557. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  558. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  559. package/packages/ai/src/lib/completionCall.js +10 -7
  560. package/packages/ai/src/lib/completionCall.js.map +1 -1
  561. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +21 -0
  562. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  563. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  564. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  565. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  566. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  567. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  568. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  569. package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
  570. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  571. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  572. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  573. package/packages/analyze/src/lib/asts/index.js +4 -2
  574. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  575. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +8 -1
  576. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  577. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  578. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  579. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  580. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  581. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  582. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  583. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +65 -0
  584. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  585. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  586. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  587. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +18 -4
  588. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  589. package/packages/database/index.js +1 -0
  590. package/packages/database/index.js.map +1 -1
  591. package/packages/database/src/lib/kysely/db.js +5 -0
  592. package/packages/database/src/lib/kysely/db.js.map +1 -1
  593. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  594. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  595. package/packages/database/src/lib/loadCommits.js +23 -13
  596. package/packages/database/src/lib/loadCommits.js.map +1 -1
  597. package/packages/database/src/lib/loadEntities.js +0 -6
  598. package/packages/database/src/lib/loadEntities.js.map +1 -1
  599. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  600. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  601. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  602. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  603. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  604. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  605. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  606. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  607. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  608. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  609. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  610. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  611. package/packages/types/src/enums/ProjectFramework.js +2 -0
  612. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  613. package/packages/utils/src/lib/fs/rsyncCopy.js +6 -2
  614. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  615. package/scripts/npm-post-install.cjs +34 -0
  616. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -120
  617. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  618. package/codeyam-cli/src/commands/list.js +0 -31
  619. package/codeyam-cli/src/commands/list.js.map +0 -1
  620. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  621. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  622. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  623. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  624. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +0 -34
  625. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +0 -17
  626. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-D1zB-pYc.js +0 -21
  627. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +0 -1
  628. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +0 -6
  629. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +0 -6
  630. package/codeyam-cli/src/webserver/build/client/assets/git-BdHOxVfg.js +0 -15
  631. package/codeyam-cli/src/webserver/build/client/assets/globals-BSZfYCkU.css +0 -1
  632. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +0 -1
  633. package/codeyam-cli/src/webserver/build/client/assets/manifest-040dab1c.js +0 -1
  634. package/codeyam-cli/src/webserver/build/client/assets/memory-UIDVz141.js +0 -92
  635. package/codeyam-cli/src/webserver/build/client/assets/root-D1WadSdf.js +0 -62
  636. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +0 -1
  637. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +0 -1
  638. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DAFqfEDH.js +0 -2
  639. package/codeyam-cli/src/webserver/build/server/assets/index-B3dE0r28.js +0 -1
  640. package/codeyam-cli/src/webserver/build/server/assets/server-build-DYbfdxa3.js +0 -273
  641. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  642. package/scripts/finalize-analyzer.cjs +0 -13
  643. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  644. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  645. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  646. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  647. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  648. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -1,10 +1,10 @@
1
1
  {
2
- "buildTimestamp": "2026-02-19T08:29:57.611Z",
3
- "buildTime": 1771489797611,
4
- "gitCommit": "bd4126bbd54a1b23f04969e37544b3c03acde084",
2
+ "buildTimestamp": "2026-03-13T15:02:19.275Z",
3
+ "buildTime": 1773414139275,
4
+ "gitCommit": "c27616677af6d43760242cadcf9021d31b2f9225",
5
5
  "nodeVersion": "v20.20.0",
6
- "contentHash": "4dfdb43772550ef44f8cdd768e38d72a07ca14fb3f7b3110a84fe60ab2637cbd",
7
- "buildNumber": 641,
8
- "semanticVersion": "0.1.641",
9
- "version": "0.1.641 (2026-02-19T08:29+4dfdb43)"
6
+ "contentHash": "68aada52a9e636008fb2f4fffc504ee4b3e09bd06eacbf40d008b536dcb9018b",
7
+ "buildNumber": 981,
8
+ "semanticVersion": "0.1.981",
9
+ "version": "0.1.981 (2026-03-13T15:02+68aada5)"
10
10
  }
@@ -1,7 +1,7 @@
1
1
 
2
- [2/19/2026, 8:29:57 AM] > codeyam-combo@1.0.0 mergeDependencies
3
- [2/19/2026, 8:29:57 AM] > node ./scripts/mergePackageJsonFiles.cjs
2
+ [3/13/2026, 3:02:19 PM] > codeyam-combo@1.0.0 mergeDependencies
3
+ [3/13/2026, 3:02:19 PM] > node ./scripts/mergePackageJsonFiles.cjs
4
4
 
5
5
 
6
- [2/19/2026, 8:29:57 AM] Merged dependencies into root package.json
6
+ [3/13/2026, 3:02:19 PM] Merged dependencies into root package.json
7
7
 
@@ -9,7 +9,7 @@
9
9
  "dependencies": {
10
10
  "@aws-sdk/client-cloudwatch-logs": "^3.990.0",
11
11
  "@aws-sdk/client-cloudfront": "^3.990.0",
12
- "@aws-sdk/client-codebuild": "^3.990.0",
12
+ "@aws-sdk/client-codebuild": "^3.1000.0",
13
13
  "@aws-sdk/client-dynamodb": "^3.990.0",
14
14
  "@aws-sdk/client-ec2": "^3.990.0",
15
15
  "@aws-sdk/client-ecr": "^3.990.0",
@@ -18,7 +18,7 @@
18
18
  "@aws-sdk/client-sqs": "^3.990.0",
19
19
  "@aws-sdk/lib-storage": "^3.990.0",
20
20
  "@aws-sdk/util-dynamodb": "^3.990.0",
21
- "@octokit/auth-app": "^8.1.0",
21
+ "@octokit/auth-app": "^8.2.0",
22
22
  "@octokit/rest": "^22.0.0",
23
23
  "@sendgrid/mail": "^8.1.4",
24
24
  "@supabase/supabase-js": "2.88.0",
@@ -32,37 +32,37 @@
32
32
  "jsonc-parser": "^3.2.1",
33
33
  "lru-cache": "^11.2.5",
34
34
  "openai": "^6.16.0",
35
- "p-queue": "^8.1.0",
35
+ "p-queue": "^9.1.0",
36
36
  "p-retry": "^7.1.1",
37
37
  "piscina": "^5.1.4",
38
38
  "pixelmatch": "^5.3.0",
39
39
  "playwright": "1.58.0",
40
40
  "sharp": "^0.34.5",
41
- "simple-git": "^3.28.0",
41
+ "simple-git": "^3.32.2",
42
42
  "undici": "^7.18.2",
43
43
  "uuid": "^11.1.0",
44
44
  "pluralize": "^8.0.0",
45
45
  "yargs": "^18.0.0",
46
46
  "json5": "^2.2.3",
47
- "@anthropic-ai/sdk": "^0.74.0",
47
+ "@anthropic-ai/sdk": "^0.78.0",
48
48
  "@aws-sdk/s3-request-presigner": "^3.990.0",
49
- "better-sqlite3": "^12.4.1",
49
+ "better-sqlite3": "^12.6.2",
50
50
  "fetch-retry": "^6.0.0",
51
51
  "kysely": "^0.28.11",
52
- "pg": "^8.16.3",
52
+ "pg": "^8.19.0",
53
53
  "@octokit/request": "^10.0.3",
54
- "lucide-react": "^0.556.0",
54
+ "lucide-react": "^0.577.0",
55
55
  "react-resizable": "^3.0.5"
56
56
  },
57
57
  "devDependencies": {
58
58
  "typescript": "^5.9.3",
59
59
  "@jest/types": "^30.2.0",
60
- "@types/node": "^25.0.2",
60
+ "@types/node": "^25.3.3",
61
61
  "@types/yargs": "^17.0.34",
62
62
  "@types/jsdom": "^27.0.0",
63
63
  "@types/better-sqlite3": "^7.6.13",
64
64
  "@types/jest": "^30.0.0",
65
- "@types/pg": "^8.15.5",
65
+ "@types/pg": "^8.18.0",
66
66
  "@types/ws": "^8.18.1",
67
67
  "@octokit/types": "^16.0.0",
68
68
  "@types/react": "^19.2.7",
@@ -9,9 +9,9 @@
9
9
  "author": "",
10
10
  "license": "ISC",
11
11
  "dependencies": {
12
- "@anthropic-ai/sdk": "^0.74.0",
12
+ "@anthropic-ai/sdk": "^0.78.0",
13
13
  "jsdom": "^27.4.0",
14
- "p-queue": "^8.1.0",
14
+ "p-queue": "^9.1.0",
15
15
  "p-retry": "^7.1.1",
16
16
  "piscina": "^5.1.4",
17
17
  "lru-cache": "^11.2.5"
@@ -909,11 +909,42 @@ export class ASTScopeAnalyzer {
909
909
  if (tsType.flags & ts.TypeFlags.Union) {
910
910
  const unionType = tsType as ts.UnionType;
911
911
 
912
- // Check if it's a string literal union
913
- const isAllStringLiterals = unionType.types.every(
912
+ // Check if it's a string literal union (optionally with null/undefined).
913
+ // Preserve literal values so the LLM knows which values are valid when
914
+ // generating mock data. Without this, types like
915
+ // 'suggestion' | 'warning' | 'achievement' | 'tip' become just 'string'
916
+ // and the LLM generates invalid values (e.g. "Motivational").
917
+ const stringLiterals = unionType.types.filter(
914
918
  (t) => (t.flags & ts.TypeFlags.StringLiteral) !== 0,
915
919
  );
916
- if (isAllStringLiterals) return 'string';
920
+ const nullishTypes = unionType.types.filter(
921
+ (t) =>
922
+ (t.flags & ts.TypeFlags.Undefined) !== 0 ||
923
+ (t.flags & ts.TypeFlags.Null) !== 0,
924
+ );
925
+
926
+ if (
927
+ stringLiterals.length > 0 &&
928
+ stringLiterals.length + nullishTypes.length === unionType.types.length
929
+ ) {
930
+ const literalValues = stringLiterals.map(
931
+ (t) => `'${(t as ts.LiteralType).value}'`,
932
+ );
933
+ const literalUnion = literalValues.join(' | ');
934
+
935
+ if (nullishTypes.length > 0) {
936
+ const nullishParts: string[] = [];
937
+ if (nullishTypes.some((t) => (t.flags & ts.TypeFlags.Null) !== 0))
938
+ nullishParts.push('null');
939
+ if (
940
+ nullishTypes.some((t) => (t.flags & ts.TypeFlags.Undefined) !== 0)
941
+ )
942
+ nullishParts.push('undefined');
943
+ return `${literalUnion} | ${nullishParts.join(' | ')}`;
944
+ }
945
+
946
+ return literalUnion;
947
+ }
917
948
 
918
949
  // Check if it's a number literal union
919
950
  const isAllNumberLiterals = unionType.types.every(
@@ -36,7 +36,6 @@ interface CompletionCallProps {
36
36
  const queue = new PQueue({
37
37
  concurrency: 100,
38
38
  timeout: 20 * 60 * 1000, // 20 minutes
39
- throwOnTimeout: true,
40
39
  autoStart: true,
41
40
  });
42
41
 
@@ -135,62 +134,63 @@ export default async function completionCall({
135
134
  };
136
135
  const params = lib.openai.chatRequestToOpenAIChatParams(chatRequest);
137
136
 
138
- const chatCompletion = await queue.add(
139
- () => {
140
- queueEndTime = Date.now();
141
- return PRetry(
142
- async () => {
143
- const callStartTime = Date.now();
144
- const waitingMessages = [
145
- 'Waiting for LLM response',
146
- 'Still waiting for LLM response',
147
- 'LLM call in progress',
148
- 'Processing LLM request',
149
- 'Awaiting LLM completion',
150
- ];
151
-
152
- const logInterval = setInterval(() => {
153
- const elapsedSeconds = Math.floor(
154
- (Date.now() - callStartTime) / 1000,
155
- );
156
- const messageIndex =
157
- Math.floor(elapsedSeconds / 10) % waitingMessages.length;
158
- awsLogDebugLevel(
159
- 1,
160
- `${waitingMessages[messageIndex]} [type=${type}, model=${model}, elapsed=${elapsedSeconds}s]`,
161
- );
162
- }, 10000);
137
+ const chatCompletionResult = await queue.add(() => {
138
+ queueEndTime = Date.now();
139
+ return PRetry(
140
+ async () => {
141
+ const callStartTime = Date.now();
142
+ const waitingMessages = [
143
+ 'Waiting for LLM response',
144
+ 'Still waiting for LLM response',
145
+ 'LLM call in progress',
146
+ 'Processing LLM request',
147
+ 'Awaiting LLM completion',
148
+ ];
149
+
150
+ const logInterval = setInterval(() => {
151
+ const elapsedSeconds = Math.floor(
152
+ (Date.now() - callStartTime) / 1000,
153
+ );
154
+ const messageIndex =
155
+ Math.floor(elapsedSeconds / 10) % waitingMessages.length;
156
+ awsLogDebugLevel(
157
+ 1,
158
+ `${waitingMessages[messageIndex]} [type=${type}, model=${model}, elapsed=${elapsedSeconds}s]`,
159
+ );
160
+ }, 10000);
163
161
 
164
- try {
165
- return await openai.chat.completions.create(params, {
166
- timeout: 5 * 60 * 1000, // 5 minute timeout
167
- });
168
- } finally {
169
- clearInterval(logInterval);
170
- }
171
- },
172
- {
173
- ...defaultRetryOptions,
174
- onFailedAttempt: (error) => {
175
- retryCount++;
176
- console.log(
177
- `CodeYam Error: Completion call failed [model=${model}]`,
178
- {
179
- error,
180
- prompt,
181
- systemMessage,
182
- attempts,
183
- retryCount,
184
- },
185
- );
186
- },
162
+ try {
163
+ return await openai.chat.completions.create(params, {
164
+ timeout: 5 * 60 * 1000, // 5 minute timeout
165
+ });
166
+ } finally {
167
+ clearInterval(logInterval);
168
+ }
169
+ },
170
+ {
171
+ ...defaultRetryOptions,
172
+ onFailedAttempt: (error) => {
173
+ retryCount++;
174
+ console.log(
175
+ `CodeYam Error: Completion call failed [model=${model}]`,
176
+ {
177
+ error,
178
+ prompt,
179
+ systemMessage,
180
+ attempts,
181
+ retryCount,
182
+ },
183
+ );
187
184
  },
188
- );
189
- },
190
- {
191
- throwOnTimeout: true,
192
- },
193
- );
185
+ },
186
+ );
187
+ });
188
+
189
+ if (!chatCompletionResult) {
190
+ throw new Error('Completion call returned no result');
191
+ }
192
+
193
+ const chatCompletion = chatCompletionResult;
194
194
  const endTime = Date.now();
195
195
 
196
196
  const llmCallStats = getLLMCallStats({
@@ -310,65 +310,66 @@ ${completion}
310
310
 
311
311
  Please provide a corrected version with valid JSON only. Do not include any explanatory text, just the valid JSON object.`;
312
312
 
313
- const correctionChatCompletion = await queue.add(
314
- () => {
315
- return PRetry(
316
- async () => {
317
- const correctionStartTime = Date.now();
318
- const waitingMessages = [
319
- 'Waiting for LLM correction response',
320
- 'Still waiting for LLM correction',
321
- 'LLM correction in progress',
322
- 'Processing LLM correction request',
323
- 'Awaiting LLM correction completion',
324
- ];
325
-
326
- const logInterval = setInterval(() => {
327
- const elapsedSeconds = Math.floor(
328
- (Date.now() - correctionStartTime) / 1000,
329
- );
330
- const messageIndex =
331
- Math.floor(elapsedSeconds / 10) % waitingMessages.length;
332
- awsLogDebugLevel(
333
- 1,
334
- `${waitingMessages[messageIndex]} [type=${type}, model=${model}, elapsed=${elapsedSeconds}s]`,
335
- );
336
- }, 10000);
337
-
338
- try {
339
- return await openai.chat.completions.create(
340
- {
341
- ...params,
342
- messages: [
343
- { role: 'system', content: systemMessage },
344
- { role: 'user', content: prompt },
345
- { role: 'assistant', content: completion },
346
- { role: 'user', content: correctionPrompt },
347
- ],
348
- },
349
- {
350
- timeout: 5 * 60 * 1000,
351
- },
352
- );
353
- } finally {
354
- clearInterval(logInterval);
355
- }
313
+ const correctionChatCompletionResult = await queue.add(() => {
314
+ return PRetry(
315
+ async () => {
316
+ const correctionStartTime = Date.now();
317
+ const waitingMessages = [
318
+ 'Waiting for LLM correction response',
319
+ 'Still waiting for LLM correction',
320
+ 'LLM correction in progress',
321
+ 'Processing LLM correction request',
322
+ 'Awaiting LLM correction completion',
323
+ ];
324
+
325
+ const logInterval = setInterval(() => {
326
+ const elapsedSeconds = Math.floor(
327
+ (Date.now() - correctionStartTime) / 1000,
328
+ );
329
+ const messageIndex =
330
+ Math.floor(elapsedSeconds / 10) % waitingMessages.length;
331
+ awsLogDebugLevel(
332
+ 1,
333
+ `${waitingMessages[messageIndex]} [type=${type}, model=${model}, elapsed=${elapsedSeconds}s]`,
334
+ );
335
+ }, 10000);
336
+
337
+ try {
338
+ return await openai.chat.completions.create(
339
+ {
340
+ ...params,
341
+ messages: [
342
+ { role: 'system', content: systemMessage },
343
+ { role: 'user', content: prompt },
344
+ { role: 'assistant', content: completion },
345
+ { role: 'user', content: correctionPrompt },
346
+ ],
347
+ },
348
+ {
349
+ timeout: 5 * 60 * 1000,
350
+ },
351
+ );
352
+ } finally {
353
+ clearInterval(logInterval);
354
+ }
355
+ },
356
+ {
357
+ ...defaultRetryOptions,
358
+ onFailedAttempt: (error) => {
359
+ console.log('CodeYam Error: Correction call failed', {
360
+ error,
361
+ attempts,
362
+ });
356
363
  },
357
- {
358
- ...defaultRetryOptions,
359
- onFailedAttempt: (error) => {
360
- console.log('CodeYam Error: Correction call failed', {
361
- error,
362
- attempts,
363
- });
364
- },
365
- },
366
- );
367
- },
368
- {
369
- throwOnTimeout: true,
370
- },
371
- );
364
+ },
365
+ );
366
+ });
367
+
368
+ if (!correctionChatCompletionResult) {
369
+ throw new Error('Correction call returned no result');
370
+ }
371
+
372
+ const correctionChatCompletion = correctionChatCompletionResult;
372
373
 
373
374
  const correctedRawCompletion =
374
375
  correctionChatCompletion.choices?.[0]?.message?.content;
@@ -1108,6 +1108,33 @@ export class ScopeDataStructure {
1108
1108
  return;
1109
1109
  }
1110
1110
 
1111
+ // Case 3: Circular reference through scope-suffixed names (____cyScope pattern)
1112
+ // When a named arrow function is defined inside a scope (e.g., useEffect callback):
1113
+ // const identifyUser = async () => { ... };
1114
+ // identifyUser();
1115
+ // This creates a variable "identifyUser" and a scope "identifyUser____cyScope9F".
1116
+ // Mutual equivalencies between these cause infinite loops in Phase 2 because
1117
+ // processing one triggers addToSchema → followEquivalencies → addEquivalency
1118
+ // on the reverse, which repeats indefinitely.
1119
+ // Only block when the REVERSE direction already exists (creating a cycle).
1120
+ // The initial one-directional equivalency is necessary for scope resolution.
1121
+ if (
1122
+ path &&
1123
+ equivalentPath &&
1124
+ (equivalentPath.startsWith(path + '____') ||
1125
+ path.startsWith(equivalentPath + '____'))
1126
+ ) {
1127
+ // Check if the reverse equivalency already exists
1128
+ const reverseEquivalencies =
1129
+ scopeNode.equivalencies[equivalentPath] || [];
1130
+ const reverseExists = reverseEquivalencies.some(
1131
+ (v) => v.schemaPath === path,
1132
+ );
1133
+ if (reverseExists) {
1134
+ return;
1135
+ }
1136
+ }
1137
+
1111
1138
  if (!equivalentScopeName) {
1112
1139
  console.error(
1113
1140
  'CodeYam Error: Missing equivalent scope name - FULL CONTEXT:',
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Coerces primitive values to empty arrays when the schema expects an array.
3
+ *
4
+ * The LLM sometimes generates a primitive (boolean, number, string) where the
5
+ * schema expects an array. For example:
6
+ * Schema: { webapps: [{ name: "string" }] }
7
+ * LLM output: { webapps: true }
8
+ *
9
+ * This causes runtime errors like `TypeError: config.webapps?.forEach is not a function`
10
+ * because the code expects an array but gets a boolean.
11
+ *
12
+ * Coercion rule:
13
+ * - primitive → array: replace with []
14
+ *
15
+ * Null and undefined values are preserved (they may be intentionally nullable).
16
+ *
17
+ * @param data The mock data object to coerce (mutated in place)
18
+ * @param schema The schema describing expected types
19
+ */
20
+ export default function coercePrimitivesToArraysBySchema<T>(
21
+ data: T,
22
+ schema: unknown,
23
+ ): T {
24
+ if (data === null || data === undefined) {
25
+ return data;
26
+ }
27
+
28
+ if (typeof data !== 'object') {
29
+ return data;
30
+ }
31
+
32
+ if (Array.isArray(data)) {
33
+ const itemSchema = Array.isArray(schema) ? schema[0] : undefined;
34
+ for (let i = 0; i < data.length; i++) {
35
+ data[i] = coercePrimitivesToArraysBySchema(data[i], itemSchema);
36
+ }
37
+ return data;
38
+ }
39
+
40
+ const dataObj = data as Record<string, unknown>;
41
+ const schemaObj = schema as Record<string, unknown> | undefined;
42
+
43
+ for (const key of Object.keys(dataObj)) {
44
+ const value = dataObj[key];
45
+ const fieldSchema = schemaObj?.[key];
46
+
47
+ if (value === null || value === undefined) {
48
+ continue;
49
+ }
50
+
51
+ if (typeof value !== 'object' && Array.isArray(fieldSchema)) {
52
+ // Schema expects an array but the value is a primitive.
53
+ // Replace with an empty array.
54
+ dataObj[key] = [];
55
+ } else if (typeof value === 'object' && value !== null) {
56
+ // Both value and schema are objects — recurse
57
+ coercePrimitivesToArraysBySchema(value, fieldSchema);
58
+ }
59
+ }
60
+
61
+ return data;
62
+ }
@@ -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