@codeyam/codeyam-cli 0.1.0-staging.483fdc2 → 0.1.0-staging.57cd50f

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 (822) 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 +24 -24
  4. package/analyzer-template/packages/ai/index.ts +1 -0
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +588 -13
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +20 -1
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  24. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  25. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +124 -7
  26. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +101 -2
  27. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
  28. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  29. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  30. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  31. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  32. package/analyzer-template/packages/analyze/index.ts +2 -0
  33. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  34. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  35. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  36. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
  37. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +13 -0
  38. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  39. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  40. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  41. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
  42. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
  43. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
  44. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  45. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
  46. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  47. package/analyzer-template/packages/aws/package.json +10 -10
  48. package/analyzer-template/packages/database/index.ts +1 -0
  49. package/analyzer-template/packages/database/package.json +4 -4
  50. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  51. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  52. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  53. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  54. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  55. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  56. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  57. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  58. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +82 -0
  59. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  60. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  61. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  62. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  63. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  64. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  65. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  66. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  67. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  68. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  69. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  70. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  71. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  72. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  74. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  77. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  88. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  90. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +24 -0
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  96. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  98. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  99. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  100. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  101. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  116. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  119. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  122. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  125. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  126. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  127. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  128. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  129. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  130. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  132. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  134. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  135. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  136. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  137. package/analyzer-template/packages/github/package.json +1 -1
  138. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  139. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  140. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  141. package/analyzer-template/packages/ui-components/package.json +1 -1
  142. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  143. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  144. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  145. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  146. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  147. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  148. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  149. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  150. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  151. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  152. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  153. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  154. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  155. package/analyzer-template/project/constructMockCode.ts +206 -51
  156. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  157. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  158. package/analyzer-template/project/start.ts +3 -0
  159. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  160. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  161. package/analyzer-template/project/writeMockDataTsx.ts +136 -17
  162. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  163. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  164. package/analyzer-template/tsconfig.json +13 -1
  165. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  166. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  167. package/background/src/lib/virtualized/project/constructMockCode.js +175 -42
  168. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  169. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  170. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  171. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  172. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  173. package/background/src/lib/virtualized/project/start.js +2 -0
  174. package/background/src/lib/virtualized/project/start.js.map +1 -1
  175. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  176. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  177. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  178. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  179. package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
  180. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  181. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  182. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  183. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  184. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  185. package/codeyam-cli/scripts/apply-setup.js +252 -21
  186. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  187. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  188. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  189. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  190. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  191. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  192. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  193. package/codeyam-cli/src/cli.js +33 -24
  194. package/codeyam-cli/src/cli.js.map +1 -1
  195. package/codeyam-cli/src/codeyam-cli.js +18 -2
  196. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  197. package/codeyam-cli/src/commands/analyze.js +21 -9
  198. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  199. package/codeyam-cli/src/commands/baseline.js +2 -0
  200. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  201. package/codeyam-cli/src/commands/debug.js +2 -0
  202. package/codeyam-cli/src/commands/debug.js.map +1 -1
  203. package/codeyam-cli/src/commands/default.js +44 -21
  204. package/codeyam-cli/src/commands/default.js.map +1 -1
  205. package/codeyam-cli/src/commands/editor.js +2868 -0
  206. package/codeyam-cli/src/commands/editor.js.map +1 -0
  207. package/codeyam-cli/src/commands/init.js +81 -260
  208. package/codeyam-cli/src/commands/init.js.map +1 -1
  209. package/codeyam-cli/src/commands/memory.js +97 -92
  210. package/codeyam-cli/src/commands/memory.js.map +1 -1
  211. package/codeyam-cli/src/commands/recapture.js +2 -0
  212. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  213. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  214. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  215. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  216. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  217. package/codeyam-cli/src/commands/test-startup.js +2 -0
  218. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  219. package/codeyam-cli/src/commands/verify.js +14 -2
  220. package/codeyam-cli/src/commands/verify.js.map +1 -1
  221. package/codeyam-cli/src/data/techStacks.js +77 -0
  222. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  223. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  224. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  225. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  226. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  227. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  228. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  229. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  230. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  231. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  232. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  233. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  234. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  235. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  236. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  237. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  238. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  239. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  240. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  241. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  242. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  243. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  244. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  245. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  246. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  247. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
  248. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  249. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  250. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  251. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  252. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  253. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  254. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  255. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +275 -0
  256. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  257. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  258. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  259. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  260. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  261. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  262. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  263. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  264. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  266. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  268. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  270. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  271. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  272. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
  280. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  281. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  282. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  284. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/analyzer.js +7 -0
  286. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  287. package/codeyam-cli/src/utils/backgroundServer.js +198 -29
  288. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  289. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  290. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  291. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  292. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  293. package/codeyam-cli/src/utils/devServerState.js +71 -0
  294. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  295. package/codeyam-cli/src/utils/editorApi.js +73 -0
  296. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  297. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  298. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  299. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  300. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  301. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  302. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  303. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  304. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  305. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  306. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  307. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  308. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  309. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  310. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  311. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  312. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  313. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  314. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  315. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  316. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  317. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  318. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  319. package/codeyam-cli/src/utils/editorScenarios.js +126 -0
  320. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  321. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  322. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  323. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  324. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  325. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  326. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  327. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  328. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  329. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  330. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  331. package/codeyam-cli/src/utils/generateReport.js +2 -2
  332. package/codeyam-cli/src/utils/git.js +103 -0
  333. package/codeyam-cli/src/utils/git.js.map +1 -1
  334. package/codeyam-cli/src/utils/install-skills.js +101 -56
  335. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  336. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  337. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  338. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  339. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  340. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  341. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  342. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  343. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  344. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  345. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  346. package/codeyam-cli/src/utils/progress.js +7 -0
  347. package/codeyam-cli/src/utils/progress.js.map +1 -1
  348. package/codeyam-cli/src/utils/project.js +15 -5
  349. package/codeyam-cli/src/utils/project.js.map +1 -1
  350. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  351. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  352. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  353. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  354. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  355. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  356. package/codeyam-cli/src/utils/queue/job.js +74 -1
  357. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  358. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  359. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  360. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  361. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  362. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  363. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  364. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  365. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  366. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  367. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  368. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  369. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  370. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  371. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  372. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  373. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  374. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  375. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  376. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  377. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  378. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  379. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  380. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  381. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  383. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  384. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  385. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  386. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  387. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  388. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  389. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  390. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  391. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  392. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  393. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  394. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  395. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  396. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  397. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  398. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  399. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  400. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  401. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  402. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  403. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  404. package/codeyam-cli/src/utils/rules/index.js +2 -0
  405. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  406. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  407. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  409. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  410. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  411. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  413. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  415. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  417. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  418. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  419. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  420. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  421. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  422. package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
  423. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  424. package/codeyam-cli/src/utils/serverState.js +94 -12
  425. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  426. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
  427. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  428. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  429. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  430. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  431. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  432. package/codeyam-cli/src/utils/testRunner.js +158 -0
  433. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  434. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  435. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  436. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  437. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  438. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  439. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  440. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +31 -0
  441. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  442. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  443. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  444. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +487 -0
  445. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  446. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  447. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  448. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  449. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  450. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  451. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  452. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  453. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  454. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  455. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  456. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  457. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
  459. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  460. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  461. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  462. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  463. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  464. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  466. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
  467. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  468. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-0DY_NKil.js} +3 -3
  469. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  471. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
  473. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
  474. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  477. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  479. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  480. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  481. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  483. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  484. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  486. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  487. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  489. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  491. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  493. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  497. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  500. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  502. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  506. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  507. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  509. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  510. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  511. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/editor-vgc8jrQL.js +10 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-BF4oLwaE.js} +12 -12
  517. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  521. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  522. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  523. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
  524. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  527. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  528. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  531. package/codeyam-cli/src/webserver/build/client/assets/manifest-05e71e0b.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +96 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/root-ClvYBUSA.js +67 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  536. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
  538. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  540. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  543. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  544. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  545. package/codeyam-cli/src/webserver/build/server/assets/index-B4lc-hKc.js +1 -0
  546. package/codeyam-cli/src/webserver/build/server/assets/server-build-BbkD6mNV.js +426 -0
  547. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  548. package/codeyam-cli/src/webserver/build-info.json +5 -5
  549. package/codeyam-cli/src/webserver/devServer.js +39 -5
  550. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  551. package/codeyam-cli/src/webserver/editorProxy.js +846 -0
  552. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  553. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  554. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  555. package/codeyam-cli/src/webserver/server.js +258 -1
  556. package/codeyam-cli/src/webserver/server.js.map +1 -1
  557. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  558. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  559. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  560. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  561. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  562. package/codeyam-cli/templates/chrome-extension-react/package.json +26 -0
  563. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  564. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  565. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  566. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  567. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  568. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  569. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  570. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  571. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  572. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  573. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  574. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  575. package/codeyam-cli/templates/editor-step-hook.py +231 -0
  576. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  577. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  578. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  579. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  580. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  581. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  582. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  583. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  584. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  585. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  586. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  587. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  588. package/codeyam-cli/templates/expo-react-native/package.json +37 -0
  589. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  590. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  591. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  592. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  593. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  594. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  595. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  596. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  597. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  598. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  599. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  600. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  601. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  602. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  603. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  604. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  605. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  606. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  607. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  608. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  609. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  610. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  611. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  612. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
  613. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  614. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  615. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  616. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  617. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  618. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  619. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  620. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  621. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  622. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  623. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  624. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  625. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  626. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  627. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  628. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  629. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  630. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  631. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +36 -0
  632. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  633. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  634. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  635. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  636. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  637. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  638. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  639. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  640. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  641. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  642. package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
  643. package/codeyam-cli/templates/rules-instructions.md +45 -93
  644. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  645. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  646. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  647. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  648. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  649. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  650. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  651. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  652. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  653. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  654. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  655. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  656. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  657. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  658. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  659. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  660. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  661. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  662. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  663. package/package.json +28 -21
  664. package/packages/ai/index.js +1 -1
  665. package/packages/ai/index.js.map +1 -1
  666. package/packages/ai/src/lib/analyzeScope.js +21 -1
  667. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  668. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  669. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  670. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  671. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  672. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  673. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  674. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  675. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  676. package/packages/ai/src/lib/completionCall.js +10 -7
  677. package/packages/ai/src/lib/completionCall.js.map +1 -1
  678. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
  679. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  680. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  681. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
  683. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  684. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
  685. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  686. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  687. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  688. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  689. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  690. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  691. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  692. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
  693. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
  694. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
  695. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  696. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  697. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  698. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  699. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  700. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  701. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  702. package/packages/ai/src/lib/generateEntityScenarioData.js +89 -5
  703. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  704. package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
  705. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  706. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  707. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  708. package/packages/ai/src/lib/isolateScopes.js +39 -3
  709. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  710. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  711. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  712. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  713. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  714. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  715. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  716. package/packages/analyze/index.js +1 -0
  717. package/packages/analyze/index.js.map +1 -1
  718. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  719. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  720. package/packages/analyze/src/lib/asts/index.js +4 -2
  721. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  722. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  723. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  724. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
  725. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  726. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
  727. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  728. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  729. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  730. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  731. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  732. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  733. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  734. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
  735. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  736. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
  737. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  738. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
  739. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  740. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  741. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  742. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
  743. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  744. package/packages/analyze/src/lib/index.js +1 -0
  745. package/packages/analyze/src/lib/index.js.map +1 -1
  746. package/packages/database/index.js +1 -0
  747. package/packages/database/index.js.map +1 -1
  748. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  749. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  750. package/packages/database/src/lib/analysisToDb.js +1 -1
  751. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  752. package/packages/database/src/lib/branchToDb.js +1 -1
  753. package/packages/database/src/lib/branchToDb.js.map +1 -1
  754. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  755. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  756. package/packages/database/src/lib/commitToDb.js +1 -1
  757. package/packages/database/src/lib/commitToDb.js.map +1 -1
  758. package/packages/database/src/lib/fileToDb.js +1 -1
  759. package/packages/database/src/lib/fileToDb.js.map +1 -1
  760. package/packages/database/src/lib/kysely/db.js +8 -0
  761. package/packages/database/src/lib/kysely/db.js.map +1 -1
  762. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  763. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  764. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  765. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  766. package/packages/database/src/lib/loadCommits.js +23 -13
  767. package/packages/database/src/lib/loadCommits.js.map +1 -1
  768. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  769. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  770. package/packages/database/src/lib/projectToDb.js +1 -1
  771. package/packages/database/src/lib/projectToDb.js.map +1 -1
  772. package/packages/database/src/lib/saveFiles.js +1 -1
  773. package/packages/database/src/lib/saveFiles.js.map +1 -1
  774. package/packages/database/src/lib/scenarioToDb.js +1 -1
  775. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  776. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  777. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  778. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  779. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  780. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  781. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  782. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  783. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  784. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  785. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  786. package/packages/types/src/enums/ProjectFramework.js +2 -0
  787. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  788. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  789. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  790. package/scripts/npm-post-install.cjs +34 -0
  791. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  792. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  793. package/codeyam-cli/src/commands/list.js +0 -31
  794. package/codeyam-cli/src/commands/list.js.map +0 -1
  795. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  796. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  797. package/codeyam-cli/src/utils/reviewedRules.js +0 -92
  798. package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
  799. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  800. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  801. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  802. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  803. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  804. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  805. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  806. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  807. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  808. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  809. package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
  810. package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
  811. package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
  812. package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
  813. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  814. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  815. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  816. package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
  817. package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
  818. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  819. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  820. package/codeyam-cli/templates/codeyam:memory.md +0 -403
  821. package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
  822. package/scripts/finalize-analyzer.cjs +0 -81
@@ -72,7 +72,11 @@ export class JavascriptFrameworkManager implements EquivalencyManager {
72
72
  }
73
73
 
74
74
  finalize(scopeNode: ScopeNode, scopeDataStructure: ScopeDataStructure) {
75
- cleanNonObjectFunctions(scopeNode, scopeDataStructure, true);
75
+ // Don't call cleanNonObjectFunctions with final=true here.
76
+ // The aggressive cleanup (transformKeyMapping, clearAttributes) removes method call
77
+ // evidence like .includes() before type inference can use it.
78
+ // Instead, defer final cleanup to toSerializable() when we're done with inference.
79
+ cleanNonObjectFunctions(scopeNode, scopeDataStructure, false);
76
80
  cleanKnownObjectFunctions(scopeNode, scopeDataStructure);
77
81
  this.handleUniformArrays(scopeNode, scopeDataStructure);
78
82
  }
@@ -172,9 +172,18 @@ function scrub(
172
172
  const rawMethod = rawToken.split('(')[0];
173
173
 
174
174
  // Check if it's a prototype method (e.g., map, filter, toString)
175
+ // Only match when the token is actually a method reference/call:
176
+ // - Has parentheses (explicit call like map(), filter(x => x))
177
+ // - OR is typed as "function" (method reference like .split)
178
+ // Bare property names that happen to match method names
179
+ // (like .entries = "array", .values = "object") are preserved.
175
180
  if (protoMethodSets[rootKind].has(rawMethod)) {
176
- onRemove(keyPath);
177
- break;
181
+ const isMethodCall = rawToken.includes('(');
182
+ const isMethodReference = mapping[keyPath] === 'function';
183
+ if (isMethodCall || isMethodReference) {
184
+ onRemove(keyPath);
185
+ break;
186
+ }
178
187
  }
179
188
 
180
189
  // Check if it's a built-in property (e.g., length on arrays/strings)
@@ -510,7 +510,7 @@ function removeNonTransformingArrayMethods(variablePath: string): string {
510
510
  const part = keyParts[i];
511
511
 
512
512
  const arrayMethod = getMethodName(part);
513
- if (isValidArrayMethod(arrayMethod)) {
513
+ if (isValidFunctionCall(part) && isValidArrayMethod(arrayMethod)) {
514
514
  const nextPart = keyParts[i + 1];
515
515
  if (
516
516
  !nonTransformingArrayMethodsSet.has(arrayMethod) ||
@@ -550,7 +550,7 @@ function removeIsolatingArrayMethods(
550
550
  const part = keyParts[i];
551
551
 
552
552
  const arrayMethod = getMethodName(part);
553
- if (isValidArrayMethod(arrayMethod)) {
553
+ if (isValidFunctionCall(part) && isValidArrayMethod(arrayMethod)) {
554
554
  const nextPart = keyParts[i + 1];
555
555
  const prevPart = i > 1 ? keyParts[i - 1] : undefined;
556
556
  if (
@@ -0,0 +1,70 @@
1
+ /**
2
+ * Coerces object/array values to primitive types when the schema expects a primitive.
3
+ *
4
+ * The LLM sometimes generates an object or array where the schema expects a primitive
5
+ * type like "string", "number", or "boolean". For example:
6
+ * Schema: { body: "string" }
7
+ * LLM output: { body: { "env": "production" } }
8
+ *
9
+ * This causes runtime errors like `TypeError: body.match is not a function` because
10
+ * the code expects a string but gets an object.
11
+ *
12
+ * Coercion rules:
13
+ * - object/array → string: JSON.stringify
14
+ * - object/array → number: 0
15
+ * - object/array → boolean: false
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 coerceObjectsToPrimitivesBySchema<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] = coerceObjectsToPrimitivesBySchema(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' && typeof fieldSchema === 'string') {
52
+ // Schema expects a primitive but the value is an object/array.
53
+ // Coerce to the expected type.
54
+ const schemaType = fieldSchema.toLowerCase();
55
+
56
+ if (schemaType.includes('string')) {
57
+ dataObj[key] = JSON.stringify(value);
58
+ } else if (schemaType.includes('number')) {
59
+ dataObj[key] = 0;
60
+ } else if (schemaType.includes('boolean')) {
61
+ dataObj[key] = false;
62
+ }
63
+ } else if (typeof value === 'object' && value !== null) {
64
+ // Both value and schema are objects — recurse
65
+ coerceObjectsToPrimitivesBySchema(value, fieldSchema);
66
+ }
67
+ }
68
+
69
+ return data;
70
+ }
@@ -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
+ }
@@ -14,23 +14,112 @@ const isStandaloneIndex = (s?: string) => !!s && STANDALONE_INDEX_RE.test(s);
14
14
  // The regex matches any path ending with .length that has [] somewhere before it
15
15
  const DYNAMIC_LENGTH_RE = /\[\].*\.length$/;
16
16
 
17
+ // Cache for type string analysis to avoid repeated split/filter operations.
18
+ // These functions are called multiple times per path segment across thousands of paths.
19
+ const typeAnalysisCache = new Map<
20
+ string,
21
+ { isSkippable: boolean; baseType: string; isNullable: boolean }
22
+ >();
23
+
24
+ function getTypeAnalysis(t: string) {
25
+ const cached = typeAnalysisCache.get(t);
26
+ if (cached) return cached;
27
+ const parts = t.split('|').map((s) => s.trim());
28
+ const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
29
+ const result = {
30
+ isSkippable:
31
+ base.length === 1 &&
32
+ (base[0] === 'object' ||
33
+ base[0] === 'array' ||
34
+ base[0] === 'function' ||
35
+ base[0] === 'unknown'),
36
+ baseType: base[0],
37
+ isNullable: parts.includes('undefined') || parts.includes('null'),
38
+ };
39
+ typeAnalysisCache.set(t, result);
40
+ return result;
41
+ }
42
+
17
43
  // Treat these as structural placeholders (don't commit them as concrete leaves)
18
44
  function isSkippableLeafType(t: string) {
19
- // 'unknown' by itself is a placeholder (but 'boolean | unknown' is not)
20
- return (
21
- t === 'object' ||
22
- t === 'array' ||
23
- t === 'function' ||
24
- t.trim() === 'unknown'
25
- );
45
+ return getTypeAnalysis(t).isSkippable;
46
+ }
47
+
48
+ // Extract the base structural type from a potentially nullable type string.
49
+ // e.g., 'object | undefined' → 'object', 'array | null' → 'array'
50
+ function getBaseSkippableType(t: string): string {
51
+ return getTypeAnalysis(t).baseType;
52
+ }
53
+
54
+ // Check if a type string has nullable annotations (| undefined or | null)
55
+ function isNullableType(t: string): boolean {
56
+ return getTypeAnalysis(t).isNullable;
57
+ }
58
+
59
+ // Matches paths containing [][] — e.g., "items[][]" or "items[][].text"
60
+ const DOUBLE_ARRAY_RE = /\[\]\[\]/;
61
+
62
+ // Matches a [].property segment — e.g., "items[].name" (but not "items[][]")
63
+ const ARRAY_OBJECT_PROPERTY_RE = /\[\]\.[^[\]]/;
64
+
65
+ /**
66
+ * When scope analysis produces both `prefix[].property` (array of objects) and
67
+ * `prefix[][]` (array of arrays) for the same prefix, there's a conflict about
68
+ * what the array elements are. Object-property paths are more specific and come
69
+ * from actual property access; double-array paths come from mixed iteration
70
+ * patterns in the scope analysis. Drop the double-array paths when both exist.
71
+ */
72
+ function resolveDoubleArrayConflicts(
73
+ schema: Record<string, string>,
74
+ ): Record<string, string> {
75
+ // Collect prefixes that end in [] and have object property children
76
+ const objectArrayPrefixes = new Set<string>();
77
+ for (const path of Object.keys(schema)) {
78
+ if (!ARRAY_OBJECT_PROPERTY_RE.test(path)) continue;
79
+ // Extract every "...[]" prefix that is followed by ".prop"
80
+ let idx = 0;
81
+ while ((idx = path.indexOf('[].', idx)) !== -1) {
82
+ objectArrayPrefixes.add(path.slice(0, idx + 2)); // includes the "[]"
83
+ idx += 3;
84
+ }
85
+ }
86
+
87
+ if (objectArrayPrefixes.size === 0) return schema;
88
+
89
+ // Check if any double-array paths actually conflict
90
+ let hasConflict = false;
91
+ for (const path of Object.keys(schema)) {
92
+ if (!DOUBLE_ARRAY_RE.test(path)) continue;
93
+ const idx = path.indexOf('[][]');
94
+ if (idx !== -1 && objectArrayPrefixes.has(path.slice(0, idx + 2))) {
95
+ hasConflict = true;
96
+ break;
97
+ }
98
+ }
99
+
100
+ if (!hasConflict) return schema;
101
+
102
+ // Filter out conflicting double-array paths
103
+ const resolved: Record<string, string> = {};
104
+ for (const [path, value] of Object.entries(schema)) {
105
+ if (DOUBLE_ARRAY_RE.test(path)) {
106
+ const idx = path.indexOf('[][]');
107
+ if (idx !== -1 && objectArrayPrefixes.has(path.slice(0, idx + 2))) {
108
+ continue; // drop this conflicting path
109
+ }
110
+ }
111
+ resolved[path] = value;
112
+ }
113
+ return resolved;
26
114
  }
27
115
 
28
116
  export default function convertDotNotation(
29
117
  schema: Record<string, string>,
30
118
  ): JsonTypeDefinition {
119
+ const resolved = resolveDoubleArrayConflicts(schema);
31
120
  const result: JsonTypeDefinition = {};
32
121
 
33
- for (const [rawPath, typ] of Object.entries(schema)) {
122
+ for (const [rawPath, typ] of Object.entries(resolved)) {
34
123
  // Skip paths with .length after array notation from dynamic iteration
35
124
  // e.g., metadata[].length, metadata[][].length
36
125
  if (DYNAMIC_LENGTH_RE.test(rawPath)) continue;
@@ -218,6 +307,17 @@ export default function convertDotNotation(
218
307
  // If the next segment after '[]' is another '[]' or a standalone index,
219
308
  // we need an array at cursor[key][0], not an object (for patterns like "key[][]" or "key[][0]")
220
309
  if (afterArray === '[]' || isStandaloneIndex(afterArray)) {
310
+ // But don't overwrite an existing populated object — object properties
311
+ // (from paths like key[].property) take precedence over double-array hints
312
+ // (from paths like key[][]) which come from mixed access patterns in scope analysis
313
+ if (
314
+ cursor[key][0] &&
315
+ typeof cursor[key][0] === 'object' &&
316
+ !Array.isArray(cursor[key][0]) &&
317
+ Object.keys(cursor[key][0]).length > 0
318
+ ) {
319
+ break;
320
+ }
221
321
  if (!Array.isArray(cursor[key][0])) cursor[key][0] = [];
222
322
  } else {
223
323
  // Default case: create an object
@@ -242,15 +342,41 @@ export default function convertDotNotation(
242
342
  cursor[key] = typ;
243
343
  } else {
244
344
  // Structural/placeholder terminal
245
- if (typ === 'array') {
345
+ const nullable = isNullableType(typ);
346
+ const baseType = getBaseSkippableType(typ);
347
+
348
+ if (baseType === 'array') {
246
349
  if (!Array.isArray(cursor[key])) cursor[key] = [];
350
+ if (nullable) {
351
+ (cursor[key] as any)._nullable = true;
352
+ }
247
353
  } else if (
248
- typ === 'object' ||
249
- typ === 'function' ||
250
- typ.trim() === 'unknown'
354
+ baseType === 'object' ||
355
+ baseType === 'function' ||
356
+ baseType === 'unknown'
251
357
  ) {
252
- if (cursor[key] === undefined) {
253
- cursor[key] = typ;
358
+ if (nullable) {
359
+ // Nullable object: ensure it's an actual object (not a string
360
+ // placeholder) so _nullable can be set and child paths can
361
+ // populate properties on it.
362
+ if (
363
+ cursor[key] === undefined ||
364
+ typeof cursor[key] === 'string'
365
+ ) {
366
+ cursor[key] = {};
367
+ }
368
+ if (
369
+ typeof cursor[key] === 'object' &&
370
+ cursor[key] !== null &&
371
+ !Array.isArray(cursor[key])
372
+ ) {
373
+ (cursor[key] as any)._nullable = true;
374
+ }
375
+ } else {
376
+ // Non-nullable: preserve existing behavior (string placeholder)
377
+ if (cursor[key] === undefined) {
378
+ cursor[key] = typ;
379
+ }
254
380
  }
255
381
  }
256
382
  }
@@ -81,7 +81,23 @@ function isTypeAnnotation(value: string): boolean {
81
81
  'string | number | undefined',
82
82
  ];
83
83
 
84
- return commonTypePatterns.includes(trimmed);
84
+ if (commonTypePatterns.includes(trimmed)) return true;
85
+
86
+ // Check for arrow function type annotations like "() => void", "(event: MouseEvent) => void"
87
+ // These contain '=>' but the body is a type keyword, not a JS expression
88
+ if (trimmed.includes('=>')) {
89
+ const arrowIndex = trimmed.indexOf('=>');
90
+ const body = trimmed.slice(arrowIndex + 2).trim();
91
+ if (
92
+ /^(void|string|number|boolean|any|unknown|never|null|undefined|object|Date|Promise<\w+>)$/i.test(
93
+ body,
94
+ )
95
+ ) {
96
+ return true;
97
+ }
98
+ }
99
+
100
+ return false;
85
101
  }
86
102
 
87
103
  /**
@@ -105,6 +121,9 @@ function typeAnnotationToValue(typeAnnotation: string): unknown {
105
121
  return [];
106
122
  }
107
123
 
124
+ // Handle arrow function type annotations like "() => void"
125
+ if (trimmed.includes('=>')) return () => {};
126
+
108
127
  // Handle primitive types
109
128
  if (trimmed === 'string') return '';
110
129
  if (trimmed === 'number') return 0;
@@ -152,8 +152,11 @@ export default function fillInSchemaGapsAndUnknowns(
152
152
  schema[previousSubPath],
153
153
  )
154
154
  ) {
155
- const newValue =
156
- checkIfKnownType(previousSubPath, functionKeysMapping) ?? 'object';
155
+ // When fillInUnknowns=false, add missing gaps as 'unknown' to preserve raw schema.
156
+ // When fillInUnknowns=true, infer the type using checkIfKnownType.
157
+ const newValue = fillInUnknowns
158
+ ? (checkIfKnownType(previousSubPath, functionKeysMapping) ?? 'object')
159
+ : 'unknown';
157
160
 
158
161
  if (
159
162
  !schema[previousSubPath] ||
@@ -166,10 +169,14 @@ export default function fillInSchemaGapsAndUnknowns(
166
169
 
167
170
  // Handle the wrong function chaining function().function()
168
171
  if (isFunction && !existingSchema(previousSubPath)) {
172
+ // When fillInUnknowns=false, use 'unknown' for non-function paths.
173
+ // When fillInUnknowns=true, infer the type.
169
174
  schema[previousSubPath] = previousSubPath.endsWith(')')
170
175
  ? 'function'
171
- : (checkIfKnownType(previousSubPath, functionKeysMapping) ??
172
- 'object');
176
+ : fillInUnknowns
177
+ ? (checkIfKnownType(previousSubPath, functionKeysMapping) ??
178
+ 'object')
179
+ : 'unknown';
173
180
  changeMade = true;
174
181
  }
175
182
 
@@ -458,7 +465,10 @@ export function fillInDirectSchemaGapsAndUnknowns({
458
465
  }
459
466
  } else if (schema[key] === 'unknown') {
460
467
  const newType = guessTypeForPath(key, 'string');
461
- if (newType && schema[key] !== newType) {
468
+ // Don't convert 'unknown' to 'object' — 'object' is just inferred from
469
+ // having child properties, which isn't more useful than 'unknown' and
470
+ // prevents enrichment from filling in the actual type later.
471
+ if (newType && newType !== 'object' && schema[key] !== newType) {
462
472
  schema[key] = newType;
463
473
  changeMade = true;
464
474
  }
@@ -481,12 +491,44 @@ export function fillInDirectSchemaGapsAndUnknowns({
481
491
  // This handles spurious [] paths from components like JsonNode that handle
482
492
  // both arrays and objects. When metadata is explicitly typed as 'object',
483
493
  // paths like metadata[] (from dynamic iteration) should not change it.
494
+ const existingType = schema[previousSubPath];
495
+ const baseType = existingType?.split(' | ')[0];
496
+
497
+ // Also check if this path has meaningful object property children (non-[] children).
498
+ // If it does, it's an object with mixed access patterns (e.g., agent.entries
499
+ // AND agent[].type), not a pure array. Don't infer 'array' in that case.
500
+ // Exclude .length since it exists on arrays too and is NOT evidence of object-ness.
501
+ let hasObjectPropertyChildren = false;
502
+ if (baseType !== 'array' && baseType !== 'object') {
503
+ const dotPrefix = previousSubPath + '.';
504
+ const lengthPath = previousSubPath + '.length';
505
+ for (const schemaKey in schema) {
506
+ if (
507
+ schemaKey.startsWith(dotPrefix) &&
508
+ schemaKey !== lengthPath
509
+ ) {
510
+ hasObjectPropertyChildren = true;
511
+ break;
512
+ }
513
+ }
514
+ }
515
+
484
516
  if (
485
- schema[previousSubPath] !== 'array' &&
486
- schema[previousSubPath] !== 'object'
517
+ baseType !== 'array' &&
518
+ baseType !== 'object' &&
519
+ !hasObjectPropertyChildren
487
520
  ) {
488
- schema[previousSubPath] = 'array';
489
- changeMade = true;
521
+ // Preserve nullability from existing type (e.g., 'unknown | undefined' -> 'array | undefined')
522
+ let newType = 'array';
523
+ if (existingType?.includes(' | undefined')) {
524
+ newType = 'array | undefined';
525
+ } else if (existingType?.includes(' | null')) {
526
+ newType = 'array | null';
527
+ }
528
+ if (schema[previousSubPath] !== newType) {
529
+ schema[previousSubPath] = newType;
530
+ changeMade = true;
531
+ }
490
532
  }
491
533
  }
492
534
  }
@@ -502,14 +544,36 @@ export function fillInDirectSchemaGapsAndUnknowns({
502
544
  schema[previousSubPath],
503
545
  )
504
546
  ) {
505
- const newValue = getKnownType(previousSubPath) ?? 'object';
506
-
547
+ const existingType = schema[previousSubPath];
548
+ const baseExistingType = existingType?.split(' | ')[0];
549
+ // Skip if the base type is already a structured type
507
550
  if (
508
- !schema[previousSubPath] ||
509
- schema[previousSubPath] !== newValue
551
+ !['object', 'array', 'function', 'async-function'].includes(
552
+ baseExistingType,
553
+ )
510
554
  ) {
511
- schema[previousSubPath] = newValue;
512
- changeMade = true;
555
+ let newValue = getKnownType(previousSubPath) ?? 'object';
556
+ // Don't overwrite 'unknown' with 'object' — 'object' is just
557
+ // inferred from child properties and isn't more useful than 'unknown'
558
+ if (
559
+ newValue === 'object' &&
560
+ existingType &&
561
+ existingType.split(' | ')[0] === 'unknown'
562
+ ) {
563
+ // preserve existing 'unknown' (possibly with nullability)
564
+ } else {
565
+ // Preserve nullability from existing type
566
+ if (existingType?.includes(' | undefined')) {
567
+ newValue = `${newValue} | undefined`;
568
+ } else if (existingType?.includes(' | null')) {
569
+ newValue = `${newValue} | null`;
570
+ }
571
+
572
+ if (!existingType || existingType !== newValue) {
573
+ schema[previousSubPath] = newValue;
574
+ changeMade = true;
575
+ }
576
+ }
513
577
  }
514
578
  }
515
579
 
@@ -778,10 +842,11 @@ function checkIfKnownType(
778
842
  return 'array';
779
843
  }
780
844
 
781
- // When .includes() or .indexOf() is called with a variable argument AND we have .length,
782
- // prefer array. This pattern (arr.length > 0 && arr.includes(item)) is common for arrays.
783
- // But str.includes('literal') is common for strings - that case is handled by hasStringLiteralArgument.
784
- if (isArray && hasLengthAccess && hasIncludesOrIndexOfWithVariable) {
845
+ // When .includes() or .indexOf() is called with a variable argument, prefer array.
846
+ // Pattern: arr.includes(item) -> likely array (checking if item exists in collection)
847
+ // String literals are already filtered by hasStringLiteralArgument, so if we get here
848
+ // with a variable argument, it's strong evidence of array membership testing.
849
+ if (isArray && hasIncludesOrIndexOfWithVariable) {
785
850
  return 'array';
786
851
  }
787
852
 
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Recursively strips `_nullable` keys from LLM-generated mock data.
3
+ *
4
+ * The `_nullable` marker is an internal CodeYam concept used in type definitions
5
+ * to indicate that a field can be null/undefined. The LLM sometimes includes
6
+ * these markers in its generated scenario data, which causes runtime errors
7
+ * when code iterates over object keys (e.g., `Object.keys(importedBy)` picks
8
+ * up `_nullable` as a key alongside real data).
9
+ *
10
+ * This function mutates the input object in-place, consistent with other
11
+ * post-processing helpers like `convertNullToUndefinedBySchema`.
12
+ */
13
+ export default function stripNullableMarkers(
14
+ data: Record<string, unknown>,
15
+ ): void {
16
+ if (data == null || typeof data !== 'object') return;
17
+
18
+ // Delete _nullable from this level
19
+ if ('_nullable' in data) {
20
+ delete data._nullable;
21
+ }
22
+
23
+ // Recurse into nested objects and arrays
24
+ for (const value of Object.values(data)) {
25
+ if (Array.isArray(value)) {
26
+ for (const item of value) {
27
+ if (item !== null && typeof item === 'object' && !Array.isArray(item)) {
28
+ stripNullableMarkers(item as Record<string, unknown>);
29
+ }
30
+ }
31
+ } else if (value !== null && typeof value === 'object') {
32
+ stripNullableMarkers(value as Record<string, unknown>);
33
+ }
34
+ }
35
+ }