@codeyam/codeyam-cli 0.1.0-staging.323686 → 0.1.0-staging.39719f5

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 (1063) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +25 -25
  4. package/analyzer-template/packages/ai/index.ts +7 -1
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +62 -18
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +101 -12
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +409 -50
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +21 -6
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1286 -262
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +10 -3
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +47 -9
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +37 -15
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +367 -96
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  27. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  28. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  29. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +393 -8
  30. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +9 -5
  31. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +112 -5
  32. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  33. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +649 -142
  34. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +1 -1
  35. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  36. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  37. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  38. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  39. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  40. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  41. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +25 -13
  42. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +4 -3
  43. package/analyzer-template/packages/analyze/index.ts +6 -1
  44. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  45. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  46. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  47. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  48. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  49. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  50. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  51. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  52. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  53. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  54. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +117 -11
  55. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +32 -40
  56. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  57. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +22 -6
  58. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +13 -14
  59. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +21 -0
  60. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +82 -13
  61. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +4 -0
  62. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +4 -0
  63. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +8 -3
  64. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  65. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  66. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  67. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +61 -13
  68. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
  69. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +498 -28
  70. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +19 -9
  71. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +760 -100
  72. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  73. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  74. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  75. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  76. package/analyzer-template/packages/aws/package.json +10 -10
  77. package/analyzer-template/packages/database/index.ts +1 -0
  78. package/analyzer-template/packages/database/package.json +4 -4
  79. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  80. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  81. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  82. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  83. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  84. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  85. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  86. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  87. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  88. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  89. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +19 -15
  90. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  91. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  92. package/analyzer-template/packages/database/src/lib/loadEntity.ts +19 -8
  93. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  94. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  95. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  96. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  97. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  98. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  99. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  100. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  101. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  102. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  103. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  104. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  105. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  106. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  107. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  116. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  119. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  120. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  122. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  124. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  125. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  126. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  127. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  128. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  129. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  130. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  131. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  132. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  133. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  134. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  135. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +1 -1
  136. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  137. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  139. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  142. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  143. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +4 -1
  144. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
  145. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +5 -5
  146. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -1
  147. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  148. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  149. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  150. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  151. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  152. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  153. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  154. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  155. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  156. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  157. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  158. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  159. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  160. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  161. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  162. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  163. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  164. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  165. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  166. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  167. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  168. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  169. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  170. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  171. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  172. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  173. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  174. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  175. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  176. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  177. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  178. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  179. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  180. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  181. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  182. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  183. package/analyzer-template/packages/github/package.json +2 -2
  184. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  185. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  186. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  187. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +6 -5
  188. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  189. package/analyzer-template/packages/ui-components/package.json +1 -1
  190. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  191. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  192. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  193. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  194. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  195. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  196. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  197. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  198. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  199. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  200. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  201. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  202. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +3 -1
  203. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  204. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +120 -4
  205. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  206. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +148 -3
  207. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  208. package/analyzer-template/project/analyzeFileEntities.ts +26 -0
  209. package/analyzer-template/project/constructMockCode.ts +260 -60
  210. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  211. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  212. package/analyzer-template/project/start.ts +3 -0
  213. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  214. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  215. package/analyzer-template/project/writeMockDataTsx.ts +198 -8
  216. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  217. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  218. package/analyzer-template/tsconfig.json +13 -1
  219. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  220. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  221. package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
  222. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  223. package/background/src/lib/virtualized/project/constructMockCode.js +220 -45
  224. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  225. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  226. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  227. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  228. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  229. package/background/src/lib/virtualized/project/start.js +2 -0
  230. package/background/src/lib/virtualized/project/start.js.map +1 -1
  231. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  232. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  233. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  234. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  235. package/background/src/lib/virtualized/project/writeMockDataTsx.js +174 -4
  236. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  237. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  238. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  239. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  240. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  241. package/codeyam-cli/scripts/apply-setup.js +386 -9
  242. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  243. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  244. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  245. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  246. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  247. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  248. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  249. package/codeyam-cli/src/cli.js +57 -24
  250. package/codeyam-cli/src/cli.js.map +1 -1
  251. package/codeyam-cli/src/codeyam-cli.js +18 -2
  252. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  253. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js +63 -0
  254. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js.map +1 -0
  255. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  256. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  257. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  258. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  259. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  260. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  261. package/codeyam-cli/src/commands/analyze.js +21 -9
  262. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  263. package/codeyam-cli/src/commands/baseline.js +2 -0
  264. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  265. package/codeyam-cli/src/commands/debug.js +9 -5
  266. package/codeyam-cli/src/commands/debug.js.map +1 -1
  267. package/codeyam-cli/src/commands/default.js +44 -21
  268. package/codeyam-cli/src/commands/default.js.map +1 -1
  269. package/codeyam-cli/src/commands/editor.js +5540 -0
  270. package/codeyam-cli/src/commands/editor.js.map +1 -0
  271. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  272. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  273. package/codeyam-cli/src/commands/init.js +148 -292
  274. package/codeyam-cli/src/commands/init.js.map +1 -1
  275. package/codeyam-cli/src/commands/memory.js +97 -92
  276. package/codeyam-cli/src/commands/memory.js.map +1 -1
  277. package/codeyam-cli/src/commands/recapture.js +2 -0
  278. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  279. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  280. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  281. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  282. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  283. package/codeyam-cli/src/commands/telemetry.js +37 -0
  284. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  285. package/codeyam-cli/src/commands/test-startup.js +2 -0
  286. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  287. package/codeyam-cli/src/commands/verify.js +14 -2
  288. package/codeyam-cli/src/commands/verify.js.map +1 -1
  289. package/codeyam-cli/src/data/techStacks.js +77 -0
  290. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  291. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  292. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  293. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  294. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  295. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  296. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  297. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  298. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  299. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +3912 -0
  300. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  301. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  302. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  303. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  304. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  305. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js +137 -0
  306. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
  307. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  308. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  309. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  310. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  311. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  312. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  313. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
  314. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  315. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
  316. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js.map +1 -0
  317. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  318. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  319. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  320. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  321. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  322. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  323. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  324. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  325. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  326. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  327. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  328. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  329. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +361 -0
  330. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  331. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  332. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  333. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  334. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  335. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +291 -0
  336. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  337. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1629 -0
  338. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  339. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +280 -0
  340. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  341. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  342. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  343. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  344. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  345. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  346. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  347. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2121 -0
  348. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  349. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  350. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  351. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js +177 -0
  352. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
  353. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
  354. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  355. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js +302 -0
  356. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js.map +1 -0
  357. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  358. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  359. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  360. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  361. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  362. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  363. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  364. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  365. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js +127 -0
  366. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js.map +1 -0
  367. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  368. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  369. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  370. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  371. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  372. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  373. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  374. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  375. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
  376. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
  377. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +175 -86
  378. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  379. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  380. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  381. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  382. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  383. package/codeyam-cli/src/utils/__tests__/testRunner.test.js +217 -0
  384. package/codeyam-cli/src/utils/__tests__/testRunner.test.js.map +1 -0
  385. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  386. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  387. package/codeyam-cli/src/utils/analysisRunner.js +39 -8
  388. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  389. package/codeyam-cli/src/utils/analyzer.js +26 -0
  390. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  391. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  392. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  393. package/codeyam-cli/src/utils/backgroundServer.js +193 -30
  394. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  395. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  396. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  397. package/codeyam-cli/src/utils/database.js +37 -2
  398. package/codeyam-cli/src/utils/database.js.map +1 -1
  399. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  400. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  401. package/codeyam-cli/src/utils/devServerState.js +71 -0
  402. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  403. package/codeyam-cli/src/utils/editorApi.js +79 -0
  404. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  405. package/codeyam-cli/src/utils/editorAudit.js +791 -0
  406. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  407. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  408. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  409. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  410. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  411. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  412. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  413. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  414. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  415. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  416. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  417. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  418. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  419. package/codeyam-cli/src/utils/editorGuard.js +36 -0
  420. package/codeyam-cli/src/utils/editorGuard.js.map +1 -0
  421. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  422. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  423. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  424. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  425. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  426. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  427. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  428. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  429. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  430. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  431. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  432. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  433. package/codeyam-cli/src/utils/editorPreview.js +139 -0
  434. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  435. package/codeyam-cli/src/utils/editorRecapture.js +109 -0
  436. package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
  437. package/codeyam-cli/src/utils/editorScenarioSwitch.js +134 -0
  438. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  439. package/codeyam-cli/src/utils/editorScenarios.js +616 -0
  440. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  441. package/codeyam-cli/src/utils/editorSeedAdapter.js +422 -0
  442. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  443. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  444. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  445. package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
  446. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  447. package/codeyam-cli/src/utils/entityChangeStatus.server.js +212 -0
  448. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  449. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  450. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  451. package/codeyam-cli/src/utils/fileWatcher.js +63 -9
  452. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  453. package/codeyam-cli/src/utils/generateReport.js +2 -2
  454. package/codeyam-cli/src/utils/git.js +103 -0
  455. package/codeyam-cli/src/utils/git.js.map +1 -1
  456. package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
  457. package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
  458. package/codeyam-cli/src/utils/install-skills.js +128 -47
  459. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  460. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  461. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  462. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  463. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  464. package/codeyam-cli/src/utils/manualEntityAnalysis.js +196 -0
  465. package/codeyam-cli/src/utils/manualEntityAnalysis.js.map +1 -0
  466. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  467. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  468. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  469. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  470. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  471. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  472. package/codeyam-cli/src/utils/progress.js +8 -1
  473. package/codeyam-cli/src/utils/progress.js.map +1 -1
  474. package/codeyam-cli/src/utils/project.js +15 -5
  475. package/codeyam-cli/src/utils/project.js.map +1 -1
  476. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  477. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  478. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  479. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  480. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  481. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  482. package/codeyam-cli/src/utils/queue/job.js +100 -6
  483. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  484. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  485. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  486. package/codeyam-cli/src/utils/registerScenarioResult.js +52 -0
  487. package/codeyam-cli/src/utils/registerScenarioResult.js.map +1 -0
  488. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  489. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  490. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  491. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  492. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  493. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  494. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  495. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  496. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  497. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  498. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  499. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  500. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  501. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  502. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  503. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  504. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  505. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  506. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  507. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  508. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  509. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  510. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  511. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  512. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  513. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  514. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  515. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  516. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  517. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  518. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  519. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  520. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  521. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  522. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  523. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  524. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  525. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  526. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  527. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  528. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  529. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  530. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  531. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  532. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  533. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  534. package/codeyam-cli/src/utils/rules/index.js +2 -0
  535. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  536. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  537. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  538. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  539. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  540. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  541. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  542. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  543. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  544. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  545. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  546. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  547. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  548. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  549. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  550. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  551. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  552. package/codeyam-cli/src/utils/scenariosManifest.js +307 -0
  553. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  554. package/codeyam-cli/src/utils/screenshotHash.js +26 -0
  555. package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
  556. package/codeyam-cli/src/utils/serverState.js +94 -12
  557. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  558. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +96 -47
  559. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  560. package/codeyam-cli/src/utils/simulationGateMiddleware.js +175 -0
  561. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  562. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  563. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  564. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  565. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  566. package/codeyam-cli/src/utils/telemetry.js +106 -0
  567. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  568. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  569. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  570. package/codeyam-cli/src/utils/testRunner.js +356 -0
  571. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  572. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  573. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  574. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  575. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  576. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  577. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  578. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  579. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  580. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
  581. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  582. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  583. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  584. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +628 -0
  585. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  586. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +283 -0
  587. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  588. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  589. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  590. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
  591. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  592. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  593. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  594. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  595. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  596. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  597. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  598. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  599. package/codeyam-cli/src/webserver/backgroundServer.js +186 -37
  600. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  601. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  602. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  603. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  604. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-Crt_KN_U.js} +5 -5
  605. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  606. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  607. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  608. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-CKeQT5Ty.js +25 -0
  609. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  610. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-By5zI316.js} +1 -1
  611. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-CM5zg40N.js} +3 -3
  612. package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-CQENLSrF.js +36 -0
  613. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-C2PLkej3.js} +5 -10
  614. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  615. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-DUMfcNVK.js} +3 -3
  616. package/codeyam-cli/src/webserver/build/client/assets/Spinner-D0LgAaSa.js +34 -0
  617. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  618. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  619. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-BAWd-Xjf.js} +4 -4
  620. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BOARiB-g.js} +10 -15
  621. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  622. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  623. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-CHx25PAe.js +1 -0
  624. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  625. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bg3e7q4S.js +22 -0
  626. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  627. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  628. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  629. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  630. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  631. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  632. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  633. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  634. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  635. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  636. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  637. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  638. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  639. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  640. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  641. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  642. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  643. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  644. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  645. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  646. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  647. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
  648. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  649. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  650. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  651. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  652. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  653. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  654. package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
  655. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  656. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  657. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  658. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  659. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  660. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  661. package/codeyam-cli/src/webserver/build/client/assets/book-open-CL-lMgHh.js +6 -0
  662. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-GmAjGS9-.js} +2 -2
  663. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  664. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-DFcQkN5j.js} +2 -2
  665. package/codeyam-cli/src/webserver/build/client/assets/copy-C6iF61Xs.js +11 -0
  666. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  667. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
  668. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
  669. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C8y4mmyv.js +1 -0
  670. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  671. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-aIHKLB-m.js +96 -0
  672. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CluPkvXJ.js +41 -0
  673. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-ByHz6rAQ.js} +14 -13
  674. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-CmLO432x.js +6 -0
  675. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Bz9sCUF_.js +6 -0
  676. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DQM8E7L4.js +6 -0
  677. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-CAoXLsQr.js} +2 -2
  678. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-SuW9syRS.js} +6 -6
  679. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  680. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  681. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  682. package/codeyam-cli/src/webserver/build/client/assets/globals-oyPmV37k.css +1 -0
  683. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-Bp1l4hSv.js} +1 -1
  684. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-CWV9XZiG.js} +1 -1
  685. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  686. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  687. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  688. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-De-7qQ2u.js} +2 -2
  689. package/codeyam-cli/src/webserver/build/client/assets/manifest-bcbb3d49.js +1 -0
  690. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  691. package/codeyam-cli/src/webserver/build/client/assets/pause-CFxEKL1u.js +11 -0
  692. package/codeyam-cli/src/webserver/build/client/assets/root-D2_tktnk.js +80 -0
  693. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-BdBb5aqc.js} +2 -2
  694. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  695. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  696. package/codeyam-cli/src/webserver/build/client/assets/terminal-CrplD4b1.js +11 -0
  697. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-DqJ0j69l.js} +2 -2
  698. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  699. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-BNd5hYuW.js +2 -0
  700. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  701. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  702. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  703. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  704. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-DjF-soOH.js +16 -0
  705. package/codeyam-cli/src/webserver/build/server/assets/index-nAvHGWbz.js +1 -0
  706. package/codeyam-cli/src/webserver/build/server/assets/init-XhpIt-OT.js +10 -0
  707. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  708. package/codeyam-cli/src/webserver/build/server/assets/server-build-DVwiibFu.js +644 -0
  709. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  710. package/codeyam-cli/src/webserver/build-info.json +5 -5
  711. package/codeyam-cli/src/webserver/devServer.js +39 -5
  712. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  713. package/codeyam-cli/src/webserver/editorProxy.js +976 -0
  714. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  715. package/codeyam-cli/src/webserver/idleDetector.js +121 -0
  716. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  717. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  718. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  719. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  720. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  721. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +283 -0
  722. package/codeyam-cli/src/webserver/server.js +379 -1
  723. package/codeyam-cli/src/webserver/server.js.map +1 -1
  724. package/codeyam-cli/src/webserver/terminalServer.js +951 -0
  725. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  726. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  727. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  728. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  729. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  730. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  731. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  732. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  733. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  734. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  735. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  736. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  737. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  738. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  739. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  740. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  741. package/codeyam-cli/templates/codeyam-editor-claude.md +149 -0
  742. package/codeyam-cli/templates/codeyam-editor-reference.md +214 -0
  743. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  744. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  745. package/codeyam-cli/templates/editor-step-hook.py +368 -0
  746. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  747. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  748. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  749. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  750. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  751. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  752. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  753. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  754. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  755. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  756. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  757. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  758. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  759. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  760. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  761. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  762. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  763. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  764. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  765. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  766. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  767. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  768. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  769. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  770. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  771. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  772. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  773. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  774. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  775. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  776. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  777. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  778. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  779. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  780. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  781. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  782. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  783. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  784. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  785. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  786. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  787. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  788. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  789. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +127 -0
  790. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  791. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  792. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  793. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  794. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  795. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  796. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  797. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  798. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  799. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  800. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  801. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  802. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  803. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  804. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  805. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  806. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  807. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  808. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  809. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  810. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  811. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  812. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  813. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  814. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  815. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  816. package/codeyam-cli/templates/rules-instructions.md +78 -0
  817. package/codeyam-cli/templates/seed-adapters/supabase.ts +282 -0
  818. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  819. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  820. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +229 -0
  821. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  822. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  823. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  824. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  825. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  826. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  827. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  828. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  829. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  830. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  831. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  832. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  833. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  834. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  835. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  836. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  837. package/package.json +29 -21
  838. package/packages/ai/index.js +3 -2
  839. package/packages/ai/index.js.map +1 -1
  840. package/packages/ai/src/lib/analyzeScope.js +50 -13
  841. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  842. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +76 -12
  843. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  844. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  845. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  846. package/packages/ai/src/lib/astScopes/processExpression.js +317 -44
  847. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  848. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  849. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  850. package/packages/ai/src/lib/completionCall.js +10 -7
  851. package/packages/ai/src/lib/completionCall.js.map +1 -1
  852. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1023 -183
  853. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  854. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
  855. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
  856. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  857. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  858. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  859. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  860. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  861. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  862. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +47 -7
  863. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  864. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +36 -11
  865. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  866. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  867. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  868. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  869. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  870. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  871. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  872. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  873. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  874. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  875. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  876. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +309 -84
  877. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  878. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  879. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  880. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  881. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  882. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  883. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  884. package/packages/ai/src/lib/generateEntityScenarioData.js +284 -6
  885. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  886. package/packages/ai/src/lib/generateEntityScenarios.js +7 -1
  887. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  888. package/packages/ai/src/lib/generateExecutionFlows.js +96 -4
  889. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  890. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +447 -80
  891. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  892. package/packages/ai/src/lib/isolateScopes.js +39 -3
  893. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  894. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  895. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  896. package/packages/ai/src/lib/mergeStatements.js +70 -51
  897. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  898. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  899. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  900. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  901. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  902. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  903. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  904. package/packages/ai/src/lib/resolvePathToControllable.js +24 -14
  905. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  906. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  907. package/packages/analyze/index.js +2 -1
  908. package/packages/analyze/index.js.map +1 -1
  909. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  910. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  911. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  912. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  913. package/packages/analyze/src/lib/asts/index.js +4 -2
  914. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  915. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  916. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  917. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  918. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  919. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  920. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  921. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  922. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  923. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  924. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  925. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  926. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  927. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  928. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  929. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +81 -9
  930. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  931. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +30 -30
  932. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  933. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  934. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  935. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +12 -2
  936. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  937. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +11 -8
  938. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  939. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
  940. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
  941. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -14
  942. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  943. package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
  944. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  945. package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
  946. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  947. package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
  948. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
  949. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  950. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  951. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  952. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  953. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  954. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  955. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +56 -10
  956. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  957. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
  958. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  959. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +309 -23
  960. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  961. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +16 -8
  962. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  963. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +632 -79
  964. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  965. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  966. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  967. package/packages/analyze/src/lib/index.js +1 -0
  968. package/packages/analyze/src/lib/index.js.map +1 -1
  969. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  970. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  971. package/packages/database/index.js +1 -0
  972. package/packages/database/index.js.map +1 -1
  973. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  974. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  975. package/packages/database/src/lib/analysisToDb.js +1 -1
  976. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  977. package/packages/database/src/lib/branchToDb.js +1 -1
  978. package/packages/database/src/lib/branchToDb.js.map +1 -1
  979. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  980. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  981. package/packages/database/src/lib/commitToDb.js +1 -1
  982. package/packages/database/src/lib/commitToDb.js.map +1 -1
  983. package/packages/database/src/lib/fileToDb.js +1 -1
  984. package/packages/database/src/lib/fileToDb.js.map +1 -1
  985. package/packages/database/src/lib/kysely/db.js +8 -0
  986. package/packages/database/src/lib/kysely/db.js.map +1 -1
  987. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  988. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  989. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  990. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  991. package/packages/database/src/lib/loadAnalysis.js +1 -1
  992. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  993. package/packages/database/src/lib/loadCommits.js +23 -13
  994. package/packages/database/src/lib/loadCommits.js.map +1 -1
  995. package/packages/database/src/lib/loadEntities.js +0 -6
  996. package/packages/database/src/lib/loadEntities.js.map +1 -1
  997. package/packages/database/src/lib/loadEntity.js +5 -5
  998. package/packages/database/src/lib/loadEntity.js.map +1 -1
  999. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  1000. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  1001. package/packages/database/src/lib/projectToDb.js +1 -1
  1002. package/packages/database/src/lib/projectToDb.js.map +1 -1
  1003. package/packages/database/src/lib/saveFiles.js +1 -1
  1004. package/packages/database/src/lib/saveFiles.js.map +1 -1
  1005. package/packages/database/src/lib/scenarioToDb.js +1 -1
  1006. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  1007. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  1008. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  1009. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  1010. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  1011. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  1012. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  1013. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  1014. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  1015. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  1016. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  1017. package/packages/types/src/enums/ProjectFramework.js +2 -0
  1018. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  1019. package/packages/utils/src/lib/fs/rsyncCopy.js +120 -4
  1020. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  1021. package/scripts/npm-post-install.cjs +34 -0
  1022. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  1023. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  1024. package/codeyam-cli/src/commands/list.js +0 -31
  1025. package/codeyam-cli/src/commands/list.js.map +0 -1
  1026. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  1027. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  1028. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  1029. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  1030. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-DLqD3qNt.js +0 -1
  1031. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  1032. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-aht4aafF.js +0 -25
  1033. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-CVtiBnY5.js +0 -3
  1034. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DuDvi0jm.js +0 -1
  1035. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-DyFZkK0l.js +0 -1
  1036. package/codeyam-cli/src/webserver/build/client/assets/chunk-EPOLDU6W-CXRTFQ3F.js +0 -51
  1037. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  1038. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  1039. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
  1040. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  1041. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  1042. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  1043. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  1044. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-DMJ7zii9.js +0 -1
  1045. package/codeyam-cli/src/webserver/build/client/assets/files-CJ6lTdTA.js +0 -1
  1046. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  1047. package/codeyam-cli/src/webserver/build/client/assets/globals-D3yhhV8x.css +0 -1
  1048. package/codeyam-cli/src/webserver/build/client/assets/manifest-7522edd4.js +0 -1
  1049. package/codeyam-cli/src/webserver/build/client/assets/memory-yxFcrxBX.js +0 -92
  1050. package/codeyam-cli/src/webserver/build/client/assets/root-eVAaavTS.js +0 -62
  1051. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  1052. package/codeyam-cli/src/webserver/build/client/assets/simulations-DwFIBT09.js +0 -1
  1053. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  1054. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  1055. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DYxHZQuP.js +0 -1
  1056. package/codeyam-cli/src/webserver/build/client/assets/useToast-mBRpZPiu.js +0 -1
  1057. package/codeyam-cli/src/webserver/build/server/assets/index-DVzYx8PN.js +0 -1
  1058. package/codeyam-cli/src/webserver/build/server/assets/server-build-4Cr0uToj.js +0 -257
  1059. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  1060. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  1061. package/codeyam-cli/templates/codeyam:memory.md +0 -462
  1062. package/codeyam-cli/templates/codeyam:new-rule.md +0 -13
  1063. package/scripts/finalize-analyzer.cjs +0 -81
@@ -3,9 +3,11 @@ import type { ExecutionFlow, ScenariosDataStructure } from '~codeyam/types';
3
3
  // Type for a single required value from ExecutionFlow
4
4
  type RequiredValue = NonNullable<ExecutionFlow['requiredValues']>[number];
5
5
 
6
- const DEFAULT_MAX_KEYS_PER_CHUNK = 8;
6
+ const DEFAULT_MAX_CHUNK_SIZE = 10_000; // ~10K chars per chunk
7
+ const DEFAULT_MAX_KEYS_PER_CHUNK = 20;
7
8
 
8
9
  export interface ChunkOptions {
10
+ maxChunkSize?: number;
9
11
  maxKeysPerChunk?: number;
10
12
  }
11
13
 
@@ -15,8 +17,12 @@ export interface ChunkOptions {
15
17
  * Large schemas overwhelm LLMs, causing them to make mistakes on some keys.
16
18
  * By processing smaller chunks, each key gets more focused attention.
17
19
  *
20
+ * Uses cumulative JSON size to decide chunk boundaries rather than a fixed
21
+ * key count, so a single oversized key gets its own chunk while many small
22
+ * keys are grouped together efficiently.
23
+ *
18
24
  * @param dataForMocks - The full data structure schema
19
- * @param options - Chunking options (maxKeysPerChunk defaults to 8)
25
+ * @param options - Chunking options (maxChunkSize defaults to 10_000)
20
26
  * @returns Array of smaller data structure chunks
21
27
  */
22
28
  export function chunkDataStructure(
@@ -27,27 +33,48 @@ export function chunkDataStructure(
27
33
  return [dataForMocks];
28
34
  }
29
35
 
30
- const { maxKeysPerChunk = DEFAULT_MAX_KEYS_PER_CHUNK } = options;
36
+ const {
37
+ maxChunkSize = DEFAULT_MAX_CHUNK_SIZE,
38
+ maxKeysPerChunk = DEFAULT_MAX_KEYS_PER_CHUNK,
39
+ } = options;
31
40
  const keys = Object.keys(dataForMocks);
32
41
 
33
- // Don't chunk if already small enough
34
- if (keys.length <= maxKeysPerChunk) {
42
+ // Calculate total size to see if chunking is needed
43
+ const totalSize = JSON.stringify(dataForMocks).length;
44
+ if (totalSize <= maxChunkSize && keys.length <= maxKeysPerChunk) {
35
45
  return [dataForMocks];
36
46
  }
37
47
 
48
+ // Greedily pack keys into chunks by cumulative size and key count
38
49
  const chunks: Array<ScenariosDataStructure['dataForMocks']> = [];
50
+ let currentChunk: Record<string, unknown> = {};
51
+ let currentSize = 0;
52
+
53
+ for (const key of keys) {
54
+ const keySize = JSON.stringify(
55
+ (dataForMocks as Record<string, unknown>)[key],
56
+ ).length;
39
57
 
40
- for (let i = 0; i < keys.length; i += maxKeysPerChunk) {
41
- const chunkKeys = keys.slice(i, i + maxKeysPerChunk);
42
- const chunk: ScenariosDataStructure['dataForMocks'] = {};
58
+ const currentKeyCount = Object.keys(currentChunk).length;
43
59
 
44
- for (const key of chunkKeys) {
45
- (chunk as Record<string, unknown>)[key] = (
46
- dataForMocks as Record<string, unknown>
47
- )[key];
60
+ // If adding this key would exceed size or key count limit AND chunk isn't empty, start a new chunk
61
+ if (
62
+ currentSize > 0 &&
63
+ (currentSize + keySize > maxChunkSize ||
64
+ currentKeyCount >= maxKeysPerChunk)
65
+ ) {
66
+ chunks.push(currentChunk as ScenariosDataStructure['dataForMocks']);
67
+ currentChunk = {};
68
+ currentSize = 0;
48
69
  }
49
70
 
50
- chunks.push(chunk);
71
+ currentChunk[key] = (dataForMocks as Record<string, unknown>)[key];
72
+ currentSize += keySize;
73
+ }
74
+
75
+ // Push the last chunk
76
+ if (Object.keys(currentChunk).length > 0) {
77
+ chunks.push(currentChunk as ScenariosDataStructure['dataForMocks']);
51
78
  }
52
79
 
53
80
  return chunks;
@@ -1,9 +1,12 @@
1
1
  import { Entity } from '~codeyam/types';
2
2
  import isolateScopes from './isolateScopes';
3
3
  import analyzeScope from './analyzeScope';
4
- import { FileAnalyzer } from '~codeyam/analyze';
4
+ import { FileAnalyzer, transformationTracer } from '~codeyam/analyze';
5
5
  import { AI, SerializableDataStructure } from '~codeyam/ai';
6
- import { resetScopeDataStructureMetrics } from './dataStructure/ScopeDataStructure';
6
+ import {
7
+ resetScopeDataStructureMetrics,
8
+ ScopeDataStructure,
9
+ } from './dataStructure/ScopeDataStructure';
7
10
 
8
11
  // import { awsLog } from '~codeyam/utils';
9
12
 
@@ -91,8 +94,60 @@ export default async function generateEntityDataStructure({
91
94
  }
92
95
 
93
96
  // Inspect the runtime type of dataStructure to see if it must be serialized
97
+ // Note: When worker threads are used, dataStructure is already serialized (no toSerializable).
98
+ // Workers are disabled when CODEYAM_TRACE_TRANSFORMS=1 to enable full tracing.
94
99
  if ('toSerializable' in entityScope.dataStructure) {
95
- return entityScope.dataStructure.toSerializable();
100
+ const scopeDataStructure =
101
+ entityScope.dataStructure as unknown as ScopeDataStructure;
102
+
103
+ // Trace the internal state BEFORE serialization - captures what methods return
104
+ if (transformationTracer.isEnabled()) {
105
+ transformationTracer.startEntity({
106
+ name: entity.name,
107
+ entityType: entity.entityType ?? 'unknown',
108
+ filePath: entity.filePath,
109
+ });
110
+
111
+ // Capture internal state - this is what getReturnValue/getFunctionSignature return
112
+ transformationTracer.snapshot(entity.name, 'scopeDataStructure', {
113
+ signatureSchema: scopeDataStructure.getFunctionSignature({
114
+ fillInUnknowns: true,
115
+ }),
116
+ returnValueSchema: scopeDataStructure.getReturnValue({
117
+ fillInUnknowns: true,
118
+ }),
119
+ });
120
+ }
121
+
122
+ const serialized = scopeDataStructure.toSerializable();
123
+
124
+ // Trace AFTER serialization - shows what gets output
125
+ if (transformationTracer.isEnabled()) {
126
+ // Build schema from external function calls for comparison
127
+ const externalSchemas: Record<string, string> = {};
128
+ for (const efc of serialized.externalFunctionCalls ?? []) {
129
+ for (const [path, type] of Object.entries(efc.schema ?? {})) {
130
+ externalSchemas[path] = type;
131
+ }
132
+ }
133
+
134
+ transformationTracer.snapshot(entity.name, 'serialized', {
135
+ signatureSchema:
136
+ serialized.functionResults?.[entity.name]?.signatureWithUnknowns,
137
+ returnValueSchema:
138
+ serialized.functionResults?.[entity.name]?.returnValueWithUnknowns,
139
+ // Include external function schemas to detect serialization gaps
140
+ dependencySchemas: {
141
+ externalFunctions: {
142
+ combined: {
143
+ returnValueSchema: externalSchemas,
144
+ },
145
+ },
146
+ },
147
+ });
148
+ }
149
+
150
+ return serialized;
96
151
  }
97
152
  return entityScope.dataStructure;
98
153
  }
@@ -16,7 +16,11 @@ import validateJson from './validateJson';
16
16
  import { awsLog, awsLogDebugLevel } from '~codeyam/utils';
17
17
  import { AI, parseJsonSafe } from '~codeyam/ai';
18
18
  import convertNullToUndefinedBySchema from './dataStructure/helpers/convertNullToUndefinedBySchema';
19
+ import convertTypeAnnotationsToValues from './dataStructure/helpers/convertTypeAnnotationsToValues';
19
20
  import fixNullIdsBySchema from './dataStructure/helpers/fixNullIdsBySchema';
21
+ import coerceObjectsToPrimitivesBySchema from './dataStructure/helpers/coerceObjectsToPrimitivesBySchema';
22
+ import coercePrimitivesToArraysBySchema from './dataStructure/helpers/coercePrimitivesToArraysBySchema';
23
+ import stripNullableMarkers from './dataStructure/helpers/stripNullableMarkers';
20
24
  import { JsonTypeDefinition } from '~codeyam/types';
21
25
  import { deepMerge } from '~codeyam/generate';
22
26
  import {
@@ -170,6 +174,46 @@ function findKeyPath(
170
174
  return null;
171
175
  }
172
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
+
173
217
  /**
174
218
  * Relocate misplaced nested keys in mockData to their correct position
175
219
  * based on the dataForMocks structure.
@@ -231,12 +275,22 @@ function relocateMisplacedNestedKeys(
231
275
  }
232
276
 
233
277
  // Deep merge the value into the correct location
234
- // 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.
235
283
  if (current[key] !== undefined && typeof current[key] === 'object') {
236
- current[key] = deepMerge(
284
+ const safeValue = stripPrimitivesOverwritingComplexValues(
237
285
  current[key] as Record<string, unknown>,
238
286
  value as Record<string, unknown>,
239
287
  );
288
+ if (safeValue !== null) {
289
+ current[key] = deepMerge(
290
+ current[key] as Record<string, unknown>,
291
+ safeValue,
292
+ );
293
+ }
240
294
  } else {
241
295
  current[key] = value;
242
296
  }
@@ -292,11 +346,13 @@ function generateDefaultForSchemaType(schemaType: unknown): unknown {
292
346
  if (schemaType.includes('| null')) return null;
293
347
  return schemaType; // Return the type as a string placeholder
294
348
  }
295
- if (
296
- typeof schemaType === 'object' &&
297
- schemaType !== null &&
298
- !Array.isArray(schemaType)
299
- ) {
349
+ if (Array.isArray(schemaType)) {
350
+ if (schemaType.length === 0) return [];
351
+ // Generate a single default element based on the first element's schema
352
+ const elementDefault = generateDefaultForSchemaType(schemaType[0]);
353
+ return elementDefault !== undefined ? [elementDefault] : [];
354
+ }
355
+ if (typeof schemaType === 'object' && schemaType !== null) {
300
356
  // Recursively generate defaults for nested objects
301
357
  const result: Record<string, unknown> = {};
302
358
  for (const [key, value] of Object.entries(schemaType)) {
@@ -424,6 +480,8 @@ function fillMissingMockDataKeysWithDefaults(
424
480
  const missingKeys: string[] = [];
425
481
 
426
482
  for (const key of Object.keys(dataForMocks)) {
483
+ if (key === '_nullable') continue; // Internal marker, not a data key
484
+
427
485
  const fullPath = pathPrefix ? `${pathPrefix}.${key}` : key;
428
486
 
429
487
  if (mockData[key] === undefined) {
@@ -459,6 +517,193 @@ function fillMissingMockDataKeysWithDefaults(
459
517
  }
460
518
  }
461
519
 
520
+ /**
521
+ * Enforce execution flow requiredValues by setting falsy paths to null.
522
+ *
523
+ * The LLM doesn't reliably generate null for `comparison: 'falsy'` requirements.
524
+ * For example, a flow like "diffView: falsy" should hide a modal, but the LLM
525
+ * might generate a truthy object, causing the modal to show in all screenshots.
526
+ *
527
+ * This function:
528
+ * 1. Gets requiredValues from covered flows
529
+ * 2. For 'falsy' comparisons: sets the value to null
530
+ * 3. For 'truthy' comparisons with falsy values: generates a default truthy value
531
+ */
532
+ function enforceRequiredValues(
533
+ mockData: Record<string, unknown>,
534
+ coveredFlowIds: string[],
535
+ executionFlows: ExecutionFlow[],
536
+ ): void {
537
+ if (!coveredFlowIds.length || !executionFlows.length) {
538
+ return;
539
+ }
540
+
541
+ // Get all requiredValues from covered flows
542
+ const coveredFlows = executionFlows.filter((flow) =>
543
+ coveredFlowIds.includes(flow.id),
544
+ );
545
+
546
+ for (const flow of coveredFlows) {
547
+ if (!flow.requiredValues) continue;
548
+
549
+ for (const rv of flow.requiredValues) {
550
+ if (!rv.attributePath) continue;
551
+
552
+ // Find the value in mockData - the path could be nested
553
+ // e.g., attributePath: "diffView" could be at mockData['useDiffModal()'].diffView
554
+ const result = findAndSetValueInMockData(
555
+ mockData,
556
+ rv.attributePath,
557
+ rv.comparison,
558
+ rv.valueType,
559
+ );
560
+
561
+ if (result.found) {
562
+ awsLog(
563
+ `CodeYam: Enforced ${rv.comparison} for ${rv.attributePath} (set to ${result.newValue === null ? 'null' : typeof result.newValue})`,
564
+ );
565
+ }
566
+ }
567
+ }
568
+ }
569
+
570
+ /**
571
+ * Find a value in mockData by attributePath and enforce the comparison.
572
+ * The attributePath could be a simple key or a nested path.
573
+ *
574
+ * Returns { found: boolean, newValue: unknown }
575
+ */
576
+ function findAndSetValueInMockData(
577
+ mockData: Record<string, unknown>,
578
+ attributePath: string,
579
+ comparison: string,
580
+ valueType?: string,
581
+ ): { found: boolean; newValue?: unknown } {
582
+ // Try to find the path at various nesting levels
583
+ // The attributePath might be "diffView" but the actual location is
584
+ // mockData['useDiffModal()'].diffView
585
+
586
+ // Strategy 1: Direct path (e.g., mockData[attributePath])
587
+ if (attributePath in mockData) {
588
+ const currentValue = mockData[attributePath];
589
+ const { shouldChange, newValue } = getEnforcedValue(
590
+ currentValue,
591
+ comparison,
592
+ valueType,
593
+ );
594
+ if (shouldChange) {
595
+ mockData[attributePath] = newValue;
596
+ return { found: true, newValue };
597
+ }
598
+ return { found: true, newValue: currentValue };
599
+ }
600
+
601
+ // Strategy 2: Search in nested objects
602
+ for (const [key, value] of Object.entries(mockData)) {
603
+ if (value && typeof value === 'object' && !Array.isArray(value)) {
604
+ const nestedObj = value as Record<string, unknown>;
605
+
606
+ // Check if attributePath exists in this nested object
607
+ if (attributePath in nestedObj) {
608
+ const currentValue = nestedObj[attributePath];
609
+ const { shouldChange, newValue } = getEnforcedValue(
610
+ currentValue,
611
+ comparison,
612
+ valueType,
613
+ );
614
+ if (shouldChange) {
615
+ nestedObj[attributePath] = newValue;
616
+ return { found: true, newValue };
617
+ }
618
+ return { found: true, newValue: currentValue };
619
+ }
620
+
621
+ // Also check dot-notation paths (e.g., "diffView.type")
622
+ if (attributePath.includes('.')) {
623
+ const parts = attributePath.split('.');
624
+ const firstPart = parts[0];
625
+ if (firstPart in nestedObj) {
626
+ // Recurse with the rest of the path
627
+ const result = findAndSetValueInMockData(
628
+ nestedObj,
629
+ attributePath,
630
+ comparison,
631
+ valueType,
632
+ );
633
+ if (result.found) return result;
634
+ }
635
+ }
636
+
637
+ // Recursively search deeper
638
+ const result = findAndSetValueInMockData(
639
+ nestedObj,
640
+ attributePath,
641
+ comparison,
642
+ valueType,
643
+ );
644
+ if (result.found) return result;
645
+ }
646
+ }
647
+
648
+ return { found: false };
649
+ }
650
+
651
+ /**
652
+ * Determine if a value should be changed to match a comparison requirement.
653
+ *
654
+ * For 'falsy' comparison: truthy values should become null
655
+ * For 'truthy' comparison: falsy values should become a default truthy value
656
+ */
657
+ function getEnforcedValue(
658
+ currentValue: unknown,
659
+ comparison: string,
660
+ valueType?: string,
661
+ ): { shouldChange: boolean; newValue: unknown } {
662
+ const isTruthy = Boolean(currentValue);
663
+
664
+ if (comparison === 'falsy') {
665
+ // Value should be falsy
666
+ if (isTruthy) {
667
+ return { shouldChange: true, newValue: null };
668
+ }
669
+ return { shouldChange: false, newValue: currentValue };
670
+ }
671
+
672
+ if (comparison === 'truthy') {
673
+ // Value should be truthy
674
+ if (!isTruthy) {
675
+ // Generate a default truthy value based on valueType
676
+ const defaultValue = generateDefaultTruthyValue(valueType);
677
+ return { shouldChange: true, newValue: defaultValue };
678
+ }
679
+ return { shouldChange: false, newValue: currentValue };
680
+ }
681
+
682
+ // For other comparisons (equals, exists, etc.), don't auto-enforce
683
+ return { shouldChange: false, newValue: currentValue };
684
+ }
685
+
686
+ /**
687
+ * Generate a default truthy value for a given type.
688
+ */
689
+ function generateDefaultTruthyValue(valueType?: string): unknown {
690
+ if (!valueType) return { _placeholder: true };
691
+
692
+ switch (valueType.toLowerCase()) {
693
+ case 'string':
694
+ return 'default-value';
695
+ case 'number':
696
+ return 1;
697
+ case 'boolean':
698
+ return true;
699
+ case 'array':
700
+ return [{ _placeholder: true }];
701
+ case 'object':
702
+ default:
703
+ return { _placeholder: true };
704
+ }
705
+ }
706
+
462
707
  type ScenarioDataWithoutDescription = Omit<ScenarioData, 'scenarioDescription'>;
463
708
 
464
709
  interface GenerateEntityScenarioDataArgs {
@@ -652,6 +897,29 @@ export async function generateDataForScenario({
652
897
  }
653
898
  }
654
899
 
900
+ // Detect keys that were lost from failed or partial chunk responses
901
+ // and fill them with schema-based defaults so they aren't permanently lost.
902
+ const allChunkedKeys = chunks.flatMap((c) => Object.keys(c || {}));
903
+ const returnedKeys = new Set(Object.keys(chunkedMockData));
904
+ const missingChunkKeys = allChunkedKeys.filter(
905
+ (k) => !returnedKeys.has(k),
906
+ );
907
+
908
+ if (missingChunkKeys.length > 0) {
909
+ awsLog(
910
+ `Chunked processing: ${missingChunkKeys.length} key(s) missing from chunk results, filling with defaults: ${missingChunkKeys.join(', ')}`,
911
+ );
912
+ const dataForMocksRecord = structure.dataForMocks as Record<
913
+ string,
914
+ unknown
915
+ >;
916
+ for (const key of missingChunkKeys) {
917
+ chunkedMockData[key] = generateDefaultForSchemaType(
918
+ dataForMocksRecord[key],
919
+ );
920
+ }
921
+ }
922
+
655
923
  awsLog(
656
924
  `Chunked processing complete. Generated ${Object.keys(chunkedMockData).length} keys total`,
657
925
  );
@@ -847,6 +1115,18 @@ export async function generateDataForScenario({
847
1115
  );
848
1116
  }
849
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
+
850
1130
  // Relocate misplaced nested keys to their correct position.
851
1131
  // The LLM sometimes places nested keys at root level instead of inside their
852
1132
  // parent object (e.g., 'fastener' at root instead of inside 'trpc').
@@ -869,6 +1149,31 @@ export async function generateDataForScenario({
869
1149
  );
870
1150
  }
871
1151
 
1152
+ // Coerce objects/arrays to primitives when the schema expects a primitive type.
1153
+ // The LLM sometimes generates an object where the schema expects "string",
1154
+ // e.g., { body: { "env": "production" } } instead of { body: "some string" }.
1155
+ // This causes runtime errors like "TypeError: body.match is not a function".
1156
+ // Must run BEFORE convertCommaSeparatedStringsToArrays, which intentionally
1157
+ // overrides schema types for array-like field names.
1158
+ if (structure.dataForMocks && fullScenarioData.data.mockData) {
1159
+ coerceObjectsToPrimitivesBySchema(
1160
+ fullScenarioData.data.mockData,
1161
+ structure.dataForMocks,
1162
+ );
1163
+ }
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
+
872
1177
  // Convert comma-separated strings to arrays when appropriate.
873
1178
  // The LLM sometimes generates strings like "color,size" instead of arrays
874
1179
  // like ["color", "size"] when the schema type is incorrectly inferred as
@@ -878,6 +1183,16 @@ export async function generateDataForScenario({
878
1183
  convertCommaSeparatedStringsToArrays(fullScenarioData.data.mockData);
879
1184
  }
880
1185
 
1186
+ // Convert type annotation strings that appear as values to actual values.
1187
+ // The LLM sometimes echoes the schema type annotation as the value.
1188
+ // For example, if the schema says { filePath: "string | undefined" },
1189
+ // the LLM might return { filePath: "string | undefined" } instead of
1190
+ // generating an actual value. This converts those type strings to
1191
+ // appropriate default values (e.g., "string | undefined" → undefined).
1192
+ if (fullScenarioData.data.mockData) {
1193
+ convertTypeAnnotationsToValues(fullScenarioData.data.mockData);
1194
+ }
1195
+
881
1196
  // Fix null values for ID fields when the schema indicates they should be non-null.
882
1197
  // The LLM sometimes generates `null` for ID fields (e.g., `"id": null`) when
883
1198
  // the schema type is `"number"`. This causes runtime issues when code checks
@@ -886,6 +1201,18 @@ export async function generateDataForScenario({
886
1201
  fixNullIdsBySchema(fullScenarioData.data.mockData, structure.dataForMocks);
887
1202
  }
888
1203
 
1204
+ // Enforce execution flow requiredValues by setting falsy paths to null.
1205
+ // The LLM doesn't reliably generate null for falsy requirements (e.g., diffView: falsy
1206
+ // to hide a modal). This post-processing ensures that scenarios match their
1207
+ // covered flows' requiredValues.
1208
+ if (fullScenarioData.data.mockData && executionFlows) {
1209
+ enforceRequiredValues(
1210
+ fullScenarioData.data.mockData,
1211
+ scenario.metadata?.coveredFlows || [],
1212
+ executionFlows,
1213
+ );
1214
+ }
1215
+
889
1216
  if (structure.arguments && fullScenarioData.data.argumentsData) {
890
1217
  for (let i = 0; i < fullScenarioData.data.argumentsData.length; i++) {
891
1218
  if (structure.arguments[i]) {
@@ -1075,6 +1402,60 @@ export default async function generateEntityScenarioData({
1075
1402
  defaultScenarioData.data.argumentsData.map((arg) => ({ ...arg }));
1076
1403
  }
1077
1404
 
1405
+ // Enforce requiredValues AFTER merge for non-default scenarios
1406
+ // This ensures that if a non-default scenario doesn't cover a certain flow,
1407
+ // it inherits the enforcement from the default scenario
1408
+ if (scenarioData.data?.mockData && executionFlows) {
1409
+ // Get the flows covered by this scenario
1410
+ const scenarioCoveredFlows =
1411
+ nonDefaultScenarios.find(
1412
+ (s) => s.name === result.scenarioData.scenarioDescription,
1413
+ )?.metadata?.coveredFlows || [];
1414
+
1415
+ // Get the paths that the scenario's flows affect
1416
+ const scenarioAffectedPaths = new Set<string>();
1417
+ for (const flowId of scenarioCoveredFlows) {
1418
+ const flow = executionFlows.find((f) => f.id === flowId);
1419
+ if (flow?.requiredValues) {
1420
+ for (const rv of flow.requiredValues) {
1421
+ if (rv.attributePath) {
1422
+ // Extract base path (e.g., "diffView" from "diffView.type")
1423
+ const basePath = rv.attributePath.split('.')[0];
1424
+ scenarioAffectedPaths.add(basePath);
1425
+ }
1426
+ }
1427
+ }
1428
+ }
1429
+
1430
+ // Get the default scenario's flows
1431
+ const defaultCoveredFlows =
1432
+ defaultScenario.metadata?.coveredFlows || [];
1433
+
1434
+ // For paths NOT affected by the scenario, apply default's enforcement
1435
+ const defaultFlowsForUnaffectedPaths = defaultCoveredFlows.filter(
1436
+ (flowId) => {
1437
+ const flow = executionFlows.find((f) => f.id === flowId);
1438
+ if (!flow?.requiredValues) return false;
1439
+
1440
+ // Check if this flow affects a path that the scenario doesn't cover
1441
+ return flow.requiredValues.some((rv) => {
1442
+ if (!rv.attributePath) return false;
1443
+ const basePath = rv.attributePath.split('.')[0];
1444
+ return !scenarioAffectedPaths.has(basePath);
1445
+ });
1446
+ },
1447
+ );
1448
+
1449
+ // Apply enforcement from default scenario for unaffected paths
1450
+ if (defaultFlowsForUnaffectedPaths.length > 0) {
1451
+ enforceRequiredValues(
1452
+ scenarioData.data.mockData,
1453
+ defaultFlowsForUnaffectedPaths,
1454
+ executionFlows,
1455
+ );
1456
+ }
1457
+ }
1458
+
1078
1459
  return scenarioData;
1079
1460
  });
1080
1461
 
@@ -1104,7 +1485,8 @@ Generate COMPLETE, robust data for the entire data structure.
1104
1485
  : `## Non-Default Scenario
1105
1486
  Generate ONLY the differences from the default scenario.
1106
1487
  - Include only fields that need to change
1107
- - Set to \`null\` to remove data
1488
+ - For object/scalar fields: set to \`null\` to remove/unset the data
1489
+ - For array fields: use \`[]\` for empty arrays (not \`null\`) unless the schema type explicitly includes \`| null\`
1108
1490
  - Omit unchanged fields—they merge from default`;
1109
1491
 
1110
1492
  // Only include the "NO ERROR DATA" instruction when the scenario doesn't require error data
@@ -1188,6 +1570,7 @@ Use simple elements only (\`<div>\`, \`<span>\`). No custom components.
1188
1570
  - Arrays should have many items (at least 4) unless specified otherwise
1189
1571
  - Each item must follow the exact structure provided
1190
1572
  - In general we want robust data, not minimal data unless specified otherwise
1573
+ - For empty arrays, use \`[]\` (not \`null\`) unless the schema type explicitly includes \`| null\` and the scenario requires the attribute be removed
1191
1574
 
1192
1575
  ## CRITICAL: Preserve Exact Structure
1193
1576
  Your response MUST mirror the EXACT nested structure provided in mockData Structure.
@@ -1267,6 +1650,7 @@ Use simple elements only (\`<div>\`, \`<span>\`). No custom components.
1267
1650
  ### Arrays
1268
1651
  - Arrays should have many items (at least 4) unless specified otherwise
1269
1652
  - Each item must follow the exact structure provided
1653
+ - For empty arrays, use \`[]\` (not \`null\`) unless the schema type explicitly includes \`| null\` and the scenario requires the attribute be removed
1270
1654
 
1271
1655
  ## CRITICAL: Preserve Exact Structure
1272
1656
  Your response MUST mirror the EXACT nested structure provided for the missing keys.
@@ -1395,4 +1779,5 @@ NEVER include "error" fields in responses. Skip them entirely.
1395
1779
  - No \`undefined\`—use \`null\` or omit
1396
1780
  - Generate data for ALL keys in the chunk (don't skip any)
1397
1781
  - Arrays should have many items (at least 4) unless specified otherwise
1782
+ - For empty arrays, use \`[]\` (not \`null\`) unless the schema type explicitly includes \`| null\` and the scenario requires the attribute be removed
1398
1783
  `;