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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (822) hide show
  1. package/analyzer-template/.build-info.json +7 -7
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +24 -24
  4. package/analyzer-template/packages/ai/index.ts +1 -0
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +588 -13
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +20 -1
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  24. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  25. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +124 -7
  26. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +101 -2
  27. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
  28. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  29. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  30. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  31. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  32. package/analyzer-template/packages/analyze/index.ts +2 -0
  33. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  34. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  35. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  36. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
  37. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +13 -0
  38. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  39. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  40. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  41. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
  42. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
  43. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
  44. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  45. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
  46. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  47. package/analyzer-template/packages/aws/package.json +10 -10
  48. package/analyzer-template/packages/database/index.ts +1 -0
  49. package/analyzer-template/packages/database/package.json +4 -4
  50. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  51. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  52. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  53. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  54. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  55. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  56. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  57. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  58. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +82 -0
  59. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  60. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  61. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  62. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  63. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  64. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  65. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  66. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  67. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  68. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  69. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  70. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  71. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  72. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  74. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  77. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  88. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  90. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +24 -0
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  96. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  98. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  99. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  100. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  101. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  116. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  119. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  122. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  125. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  126. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  127. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  128. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  129. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  130. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  132. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  134. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  135. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  136. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  137. package/analyzer-template/packages/github/package.json +1 -1
  138. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  139. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  140. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  141. package/analyzer-template/packages/ui-components/package.json +1 -1
  142. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  143. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  144. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  145. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  146. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  147. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  148. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  149. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  150. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  151. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  152. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  153. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  154. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  155. package/analyzer-template/project/constructMockCode.ts +206 -51
  156. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  157. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  158. package/analyzer-template/project/start.ts +3 -0
  159. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  160. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  161. package/analyzer-template/project/writeMockDataTsx.ts +136 -17
  162. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  163. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  164. package/analyzer-template/tsconfig.json +13 -1
  165. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  166. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  167. package/background/src/lib/virtualized/project/constructMockCode.js +175 -42
  168. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  169. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  170. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  171. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  172. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  173. package/background/src/lib/virtualized/project/start.js +2 -0
  174. package/background/src/lib/virtualized/project/start.js.map +1 -1
  175. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  176. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  177. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  178. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  179. package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
  180. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  181. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  182. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  183. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  184. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  185. package/codeyam-cli/scripts/apply-setup.js +252 -21
  186. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  187. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  188. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  189. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  190. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  191. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  192. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  193. package/codeyam-cli/src/cli.js +33 -24
  194. package/codeyam-cli/src/cli.js.map +1 -1
  195. package/codeyam-cli/src/codeyam-cli.js +18 -2
  196. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  197. package/codeyam-cli/src/commands/analyze.js +21 -9
  198. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  199. package/codeyam-cli/src/commands/baseline.js +2 -0
  200. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  201. package/codeyam-cli/src/commands/debug.js +2 -0
  202. package/codeyam-cli/src/commands/debug.js.map +1 -1
  203. package/codeyam-cli/src/commands/default.js +44 -21
  204. package/codeyam-cli/src/commands/default.js.map +1 -1
  205. package/codeyam-cli/src/commands/editor.js +2868 -0
  206. package/codeyam-cli/src/commands/editor.js.map +1 -0
  207. package/codeyam-cli/src/commands/init.js +81 -260
  208. package/codeyam-cli/src/commands/init.js.map +1 -1
  209. package/codeyam-cli/src/commands/memory.js +97 -92
  210. package/codeyam-cli/src/commands/memory.js.map +1 -1
  211. package/codeyam-cli/src/commands/recapture.js +2 -0
  212. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  213. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  214. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  215. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  216. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  217. package/codeyam-cli/src/commands/test-startup.js +2 -0
  218. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  219. package/codeyam-cli/src/commands/verify.js +14 -2
  220. package/codeyam-cli/src/commands/verify.js.map +1 -1
  221. package/codeyam-cli/src/data/techStacks.js +77 -0
  222. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  223. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  224. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  225. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  226. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  227. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  228. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  229. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  230. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  231. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  232. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  233. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  234. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  235. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  236. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  237. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  238. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  239. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  240. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  241. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  242. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  243. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  244. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  245. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  246. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  247. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
  248. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  249. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  250. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  251. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  252. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  253. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  254. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  255. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +275 -0
  256. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  257. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  258. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  259. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  260. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  261. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  262. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  263. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  264. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  266. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  268. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  270. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  271. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  272. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
  280. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  281. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  282. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  284. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/analyzer.js +7 -0
  286. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  287. package/codeyam-cli/src/utils/backgroundServer.js +198 -29
  288. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  289. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  290. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  291. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  292. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  293. package/codeyam-cli/src/utils/devServerState.js +71 -0
  294. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  295. package/codeyam-cli/src/utils/editorApi.js +73 -0
  296. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  297. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  298. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  299. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  300. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  301. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  302. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  303. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  304. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  305. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  306. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  307. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  308. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  309. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  310. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  311. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  312. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  313. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  314. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  315. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  316. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  317. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  318. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  319. package/codeyam-cli/src/utils/editorScenarios.js +126 -0
  320. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  321. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  322. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  323. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  324. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  325. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  326. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  327. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  328. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  329. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  330. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  331. package/codeyam-cli/src/utils/generateReport.js +2 -2
  332. package/codeyam-cli/src/utils/git.js +103 -0
  333. package/codeyam-cli/src/utils/git.js.map +1 -1
  334. package/codeyam-cli/src/utils/install-skills.js +101 -56
  335. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  336. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  337. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  338. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  339. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  340. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  341. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  342. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  343. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  344. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  345. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  346. package/codeyam-cli/src/utils/progress.js +7 -0
  347. package/codeyam-cli/src/utils/progress.js.map +1 -1
  348. package/codeyam-cli/src/utils/project.js +15 -5
  349. package/codeyam-cli/src/utils/project.js.map +1 -1
  350. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  351. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  352. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  353. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  354. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  355. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  356. package/codeyam-cli/src/utils/queue/job.js +74 -1
  357. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  358. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  359. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  360. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  361. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  362. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  363. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  364. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  365. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  366. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  367. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  368. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  369. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  370. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  371. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  372. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  373. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  374. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  375. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  376. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  377. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  378. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  379. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  380. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  381. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  383. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  384. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  385. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  386. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  387. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  388. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  389. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  390. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  391. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  392. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  393. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  394. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  395. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  396. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  397. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  398. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  399. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  400. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  401. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  402. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  403. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  404. package/codeyam-cli/src/utils/rules/index.js +2 -0
  405. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  406. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  407. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  409. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  410. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  411. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  413. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  415. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  417. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  418. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  419. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  420. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  421. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  422. package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
  423. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  424. package/codeyam-cli/src/utils/serverState.js +94 -12
  425. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  426. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
  427. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  428. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  429. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  430. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  431. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  432. package/codeyam-cli/src/utils/testRunner.js +158 -0
  433. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  434. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  435. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  436. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  437. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  438. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  439. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  440. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +31 -0
  441. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  442. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  443. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  444. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +487 -0
  445. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  446. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  447. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  448. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  449. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  450. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  451. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  452. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  453. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  454. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  455. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  456. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  457. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
  459. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  460. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  461. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  462. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  463. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  464. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  466. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
  467. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  468. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-0DY_NKil.js} +3 -3
  469. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  471. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
  473. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
  474. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  477. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  479. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  480. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  481. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  483. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  484. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  486. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  487. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  489. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  491. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  493. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  497. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  500. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  502. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  506. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  507. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  509. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  510. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  511. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/editor-vgc8jrQL.js +10 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-BF4oLwaE.js} +12 -12
  517. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  521. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  522. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  523. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
  524. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  527. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  528. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  531. package/codeyam-cli/src/webserver/build/client/assets/manifest-05e71e0b.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +96 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/root-ClvYBUSA.js +67 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  536. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
  538. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  540. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  543. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  544. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  545. package/codeyam-cli/src/webserver/build/server/assets/index-B4lc-hKc.js +1 -0
  546. package/codeyam-cli/src/webserver/build/server/assets/server-build-BbkD6mNV.js +426 -0
  547. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  548. package/codeyam-cli/src/webserver/build-info.json +5 -5
  549. package/codeyam-cli/src/webserver/devServer.js +39 -5
  550. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  551. package/codeyam-cli/src/webserver/editorProxy.js +846 -0
  552. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  553. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  554. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  555. package/codeyam-cli/src/webserver/server.js +258 -1
  556. package/codeyam-cli/src/webserver/server.js.map +1 -1
  557. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  558. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  559. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  560. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  561. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  562. package/codeyam-cli/templates/chrome-extension-react/package.json +26 -0
  563. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  564. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  565. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  566. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  567. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  568. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  569. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  570. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  571. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  572. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  573. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  574. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  575. package/codeyam-cli/templates/editor-step-hook.py +231 -0
  576. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  577. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  578. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  579. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  580. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  581. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  582. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  583. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  584. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  585. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  586. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  587. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  588. package/codeyam-cli/templates/expo-react-native/package.json +37 -0
  589. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  590. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  591. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  592. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  593. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  594. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  595. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  596. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  597. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  598. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  599. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  600. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  601. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  602. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  603. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  604. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  605. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  606. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  607. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  608. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  609. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  610. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  611. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  612. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
  613. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  614. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  615. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  616. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  617. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  618. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  619. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  620. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  621. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  622. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  623. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  624. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  625. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  626. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  627. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  628. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  629. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  630. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  631. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +36 -0
  632. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  633. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  634. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  635. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  636. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  637. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  638. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  639. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  640. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  641. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  642. package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
  643. package/codeyam-cli/templates/rules-instructions.md +45 -93
  644. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  645. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  646. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  647. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  648. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  649. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  650. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  651. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  652. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  653. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  654. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  655. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  656. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  657. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  658. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  659. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  660. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  661. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  662. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  663. package/package.json +28 -21
  664. package/packages/ai/index.js +1 -1
  665. package/packages/ai/index.js.map +1 -1
  666. package/packages/ai/src/lib/analyzeScope.js +21 -1
  667. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  668. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  669. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  670. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  671. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  672. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  673. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  674. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  675. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  676. package/packages/ai/src/lib/completionCall.js +10 -7
  677. package/packages/ai/src/lib/completionCall.js.map +1 -1
  678. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
  679. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  680. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  681. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
  683. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  684. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
  685. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  686. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  687. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  688. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  689. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  690. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  691. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  692. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
  693. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
  694. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
  695. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  696. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  697. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  698. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  699. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  700. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  701. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  702. package/packages/ai/src/lib/generateEntityScenarioData.js +89 -5
  703. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  704. package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
  705. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  706. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  707. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  708. package/packages/ai/src/lib/isolateScopes.js +39 -3
  709. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  710. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  711. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  712. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  713. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  714. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  715. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  716. package/packages/analyze/index.js +1 -0
  717. package/packages/analyze/index.js.map +1 -1
  718. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  719. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  720. package/packages/analyze/src/lib/asts/index.js +4 -2
  721. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  722. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  723. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  724. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
  725. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  726. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
  727. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  728. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  729. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  730. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  731. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  732. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  733. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  734. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
  735. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  736. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
  737. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  738. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
  739. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  740. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  741. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  742. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
  743. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  744. package/packages/analyze/src/lib/index.js +1 -0
  745. package/packages/analyze/src/lib/index.js.map +1 -1
  746. package/packages/database/index.js +1 -0
  747. package/packages/database/index.js.map +1 -1
  748. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  749. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  750. package/packages/database/src/lib/analysisToDb.js +1 -1
  751. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  752. package/packages/database/src/lib/branchToDb.js +1 -1
  753. package/packages/database/src/lib/branchToDb.js.map +1 -1
  754. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  755. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  756. package/packages/database/src/lib/commitToDb.js +1 -1
  757. package/packages/database/src/lib/commitToDb.js.map +1 -1
  758. package/packages/database/src/lib/fileToDb.js +1 -1
  759. package/packages/database/src/lib/fileToDb.js.map +1 -1
  760. package/packages/database/src/lib/kysely/db.js +8 -0
  761. package/packages/database/src/lib/kysely/db.js.map +1 -1
  762. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  763. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  764. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  765. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  766. package/packages/database/src/lib/loadCommits.js +23 -13
  767. package/packages/database/src/lib/loadCommits.js.map +1 -1
  768. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  769. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  770. package/packages/database/src/lib/projectToDb.js +1 -1
  771. package/packages/database/src/lib/projectToDb.js.map +1 -1
  772. package/packages/database/src/lib/saveFiles.js +1 -1
  773. package/packages/database/src/lib/saveFiles.js.map +1 -1
  774. package/packages/database/src/lib/scenarioToDb.js +1 -1
  775. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  776. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  777. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  778. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  779. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  780. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  781. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  782. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  783. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  784. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  785. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  786. package/packages/types/src/enums/ProjectFramework.js +2 -0
  787. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  788. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  789. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  790. package/scripts/npm-post-install.cjs +34 -0
  791. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  792. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  793. package/codeyam-cli/src/commands/list.js +0 -31
  794. package/codeyam-cli/src/commands/list.js.map +0 -1
  795. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  796. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  797. package/codeyam-cli/src/utils/reviewedRules.js +0 -92
  798. package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
  799. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  800. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  801. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  802. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  803. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  804. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  805. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  806. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  807. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  808. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  809. package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
  810. package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
  811. package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
  812. package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
  813. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  814. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  815. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  816. package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
  817. package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
  818. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  819. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  820. package/codeyam-cli/templates/codeyam:memory.md +0 -403
  821. package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
  822. package/scripts/finalize-analyzer.cjs +0 -81
@@ -397,6 +397,7 @@ const SILENTLY_IGNORED_EQUIVALENCY_REASONS = new Set([
397
397
  'transformed non-object function equivalency - implicit parent equivalency - rerouted via useCallback',
398
398
  'transformed non-object function equivalency - Array.from() equivalency',
399
399
  'Spread operator equivalency key update: Explicit array deconstruction equivalency value',
400
+ // 'transformed non-object function equivalency - Explicit array deconstruction equivalency value',
400
401
  ]);
401
402
 
402
403
  export class ScopeDataStructure {
@@ -799,6 +800,11 @@ export class ScopeDataStructure {
799
800
  return;
800
801
  }
801
802
 
803
+ // PERF: Early exit for paths with repeated function-call signature patterns
804
+ if (this.hasExcessivePatternRepetition(path)) {
805
+ return;
806
+ }
807
+
802
808
  // Update chain metadata for database tracking
803
809
  if (equivalencyValueChain.length > 0) {
804
810
  equivalencyValueChain[equivalencyValueChain.length - 1].addToSchemaId =
@@ -1102,6 +1108,33 @@ export class ScopeDataStructure {
1102
1108
  return;
1103
1109
  }
1104
1110
 
1111
+ // Case 3: Circular reference through scope-suffixed names (____cyScope pattern)
1112
+ // When a named arrow function is defined inside a scope (e.g., useEffect callback):
1113
+ // const identifyUser = async () => { ... };
1114
+ // identifyUser();
1115
+ // This creates a variable "identifyUser" and a scope "identifyUser____cyScope9F".
1116
+ // Mutual equivalencies between these cause infinite loops in Phase 2 because
1117
+ // processing one triggers addToSchema → followEquivalencies → addEquivalency
1118
+ // on the reverse, which repeats indefinitely.
1119
+ // Only block when the REVERSE direction already exists (creating a cycle).
1120
+ // The initial one-directional equivalency is necessary for scope resolution.
1121
+ if (
1122
+ path &&
1123
+ equivalentPath &&
1124
+ (equivalentPath.startsWith(path + '____') ||
1125
+ path.startsWith(equivalentPath + '____'))
1126
+ ) {
1127
+ // Check if the reverse equivalency already exists
1128
+ const reverseEquivalencies =
1129
+ scopeNode.equivalencies[equivalentPath] || [];
1130
+ const reverseExists = reverseEquivalencies.some(
1131
+ (v) => v.schemaPath === path,
1132
+ );
1133
+ if (reverseExists) {
1134
+ return;
1135
+ }
1136
+ }
1137
+
1105
1138
  if (!equivalentScopeName) {
1106
1139
  console.error(
1107
1140
  'CodeYam Error: Missing equivalent scope name - FULL CONTEXT:',
@@ -1486,6 +1519,15 @@ export class ScopeDataStructure {
1486
1519
 
1487
1520
  const bestValue = selectBestValue(value1, value2);
1488
1521
 
1522
+ // PERF: Skip paths with repeated function-call signature patterns
1523
+ // to prevent recursive type expansion (e.g., string.localeCompare returns string)
1524
+ if (
1525
+ this.hasExcessivePatternRepetition(schemaPath) ||
1526
+ this.hasExcessivePatternRepetition(equivalentSchemaPath)
1527
+ ) {
1528
+ continue;
1529
+ }
1530
+
1489
1531
  scopeNode.schema[schemaPath] = bestValue;
1490
1532
  equivalentScopeNode.schema[equivalentSchemaPath] = bestValue;
1491
1533
  } else if (
@@ -1499,6 +1541,11 @@ export class ScopeDataStructure {
1499
1541
  ...remainingSchemaPathParts,
1500
1542
  ]);
1501
1543
 
1544
+ // PERF: Skip paths with repeated function-call signature patterns
1545
+ if (this.hasExcessivePatternRepetition(newEquivalentPath)) {
1546
+ continue;
1547
+ }
1548
+
1502
1549
  equivalentScopeNode.schema[newEquivalentPath] =
1503
1550
  scopeNode.schema[schemaPath];
1504
1551
  }
@@ -1618,6 +1665,23 @@ export class ScopeDataStructure {
1618
1665
  }
1619
1666
  }
1620
1667
 
1668
+ // Check for repeated function calls that indicate recursive type expansion.
1669
+ // E.g., localeCompare(b[])...localeCompare(b[]) means string.localeCompare
1670
+ // returns a type that again has localeCompare, causing infinite expansion.
1671
+ // We extract all function call patterns like "funcName(args)" and check if
1672
+ // the same normalized call appears more than once.
1673
+ const funcCallPattern = /(?:^|\.)[^.([]+\([^)]*\)/g;
1674
+ const funcCallMatches = path.match(funcCallPattern);
1675
+ if (funcCallMatches && funcCallMatches.length > 1) {
1676
+ const seen = new Set<string>();
1677
+ for (const match of funcCallMatches) {
1678
+ // Strip leading dot and normalize array indices
1679
+ const normalized = match.replace(/^\./, '').replace(/\[\d+\]/g, '[]');
1680
+ if (seen.has(normalized)) return true;
1681
+ seen.add(normalized);
1682
+ }
1683
+ }
1684
+
1621
1685
  // For longer paths, detect any repeated multi-part segments we haven't explicitly listed
1622
1686
  const pathParts = this.splitPath(path);
1623
1687
  if (pathParts.length <= 6) {
@@ -2574,6 +2638,7 @@ export class ScopeDataStructure {
2574
2638
  relevantSubPathParts.every((part, i) => part === schemaPathParts[i]) &&
2575
2639
  equivalentValue.scopeNodeName === scopeNode.name
2576
2640
  ) {
2641
+ // DEBUG
2577
2642
  continue;
2578
2643
  }
2579
2644
 
@@ -2760,6 +2825,8 @@ export class ScopeDataStructure {
2760
2825
  usageEquivalency.scopeNodeName,
2761
2826
  ) as ScopeNode;
2762
2827
 
2828
+ if (!usageScopeNode) continue;
2829
+
2763
2830
  // Guard against infinite recursion by tracking which paths we've already
2764
2831
  // added from addComplexSourcePathVariables
2765
2832
  if (
@@ -2839,6 +2906,8 @@ export class ScopeDataStructure {
2839
2906
  usageEquivalency.scopeNodeName,
2840
2907
  ) as ScopeNode;
2841
2908
 
2909
+ if (!usageScopeNode) continue;
2910
+
2842
2911
  // This is put in place to avoid propagating array functions like 'filter' through complex equivalencies
2843
2912
  // but may cause problems if the funtion call is not on a known object (e.g. string or array)
2844
2913
  if (
@@ -3291,6 +3360,14 @@ export class ScopeDataStructure {
3291
3360
  }
3292
3361
  }
3293
3362
 
3363
+ // Ensure parameter-to-signature equivalencies are fully propagated.
3364
+ // When a parameter variable (e.g., `node`) is equivalenced to `signature[N]`,
3365
+ // all sub-paths of that variable should also appear under `signature[N]`.
3366
+ // This handles cases where the sub-path was added to the schema via a propagation
3367
+ // chain that already included the variable↔signature equivalency, causing the
3368
+ // cycle detection to prevent the reverse mapping.
3369
+ this.propagateParameterToSignaturePaths(scopeNode);
3370
+
3294
3371
  fillInSchemaGapsAndUnknowns(scopeNode, fillInUnknowns);
3295
3372
 
3296
3373
  if (final) {
@@ -3305,6 +3382,97 @@ export class ScopeDataStructure {
3305
3382
  }
3306
3383
  }
3307
3384
 
3385
+ /**
3386
+ * For each equivalency where a simple variable maps to signature[N],
3387
+ * ensure all sub-paths of that variable are reflected under signature[N].
3388
+ */
3389
+ private propagateParameterToSignaturePaths(scopeNode: ScopeNode) {
3390
+ // Helper: check if a type is a concrete scalar that cannot have sub-properties.
3391
+ const SCALAR_TYPES = new Set([
3392
+ 'string',
3393
+ 'number',
3394
+ 'boolean',
3395
+ 'bigint',
3396
+ 'symbol',
3397
+ 'void',
3398
+ 'never',
3399
+ ]);
3400
+ const isDefinitelyScalar = (type: string): boolean => {
3401
+ const parts = type.split('|').map((s) => s.trim());
3402
+ const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
3403
+ return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
3404
+ };
3405
+
3406
+ // Find variable → signature[N] equivalencies
3407
+ for (const [varName, equivalencies] of Object.entries(
3408
+ scopeNode.equivalencies,
3409
+ )) {
3410
+ // Only process simple variable names (no dots, brackets, or parens)
3411
+ if (
3412
+ varName.includes('.') ||
3413
+ varName.includes('[') ||
3414
+ varName.includes('(')
3415
+ ) {
3416
+ continue;
3417
+ }
3418
+
3419
+ for (const equiv of equivalencies) {
3420
+ if (
3421
+ equiv.scopeNodeName === scopeNode.name &&
3422
+ equiv.schemaPath.startsWith('signature[')
3423
+ ) {
3424
+ const signaturePath = equiv.schemaPath;
3425
+ const varPrefix = varName + '.';
3426
+ const varBracketPrefix = varName + '[';
3427
+
3428
+ // Find all schema keys starting with the variable
3429
+ for (const key in scopeNode.schema) {
3430
+ if (key.startsWith(varPrefix) || key.startsWith(varBracketPrefix)) {
3431
+ const suffix = key.slice(varName.length);
3432
+ const sigKey = signaturePath + suffix;
3433
+
3434
+ // Only add if the signature path doesn't already exist
3435
+ if (!scopeNode.schema[sigKey]) {
3436
+ // Check if this path represents variable conflation:
3437
+ // When a standalone variable (e.g., showWorkoutForm from useState)
3438
+ // appears as a sub-property of a scalar-typed ancestor (e.g.,
3439
+ // activity_type = "string"), it's from scope conflation, not real
3440
+ // property access. Block these while allowing legitimate built-in
3441
+ // accesses like string.length or string.slice.
3442
+ let isConflatedPath = false;
3443
+ let checkPos = signaturePath.length;
3444
+ while (true) {
3445
+ checkPos = sigKey.indexOf('.', checkPos + 1);
3446
+ if (checkPos === -1) break;
3447
+ const ancestorPath = sigKey.substring(0, checkPos);
3448
+ const ancestorType = scopeNode.schema[ancestorPath];
3449
+ if (ancestorType && isDefinitelyScalar(ancestorType)) {
3450
+ // Ancestor is scalar — check if the immediate sub-property
3451
+ // is also a standalone variable (indicating conflation)
3452
+ const afterDot = sigKey.substring(checkPos + 1);
3453
+ const nextSep = afterDot.search(/[.\[]/);
3454
+ const subPropName =
3455
+ nextSep === -1
3456
+ ? afterDot
3457
+ : afterDot.substring(0, nextSep);
3458
+ if (scopeNode.schema[subPropName] !== undefined) {
3459
+ isConflatedPath = true;
3460
+ break;
3461
+ }
3462
+ }
3463
+ }
3464
+
3465
+ if (!isConflatedPath) {
3466
+ scopeNode.schema[sigKey] = scopeNode.schema[key];
3467
+ }
3468
+ }
3469
+ }
3470
+ }
3471
+ }
3472
+ }
3473
+ }
3474
+ }
3475
+
3308
3476
  private filterAndConvertSchema({
3309
3477
  filterPath,
3310
3478
  newPath,
@@ -3391,6 +3559,9 @@ export class ScopeDataStructure {
3391
3559
  equivalentValueSchemaPathParts.length,
3392
3560
  ),
3393
3561
  ]);
3562
+ // PERF: Skip keys with repeated function-call signature patterns
3563
+ // to prevent recursive type expansion (e.g., string.localeCompare returns string)
3564
+ if (this.hasExcessivePatternRepetition(newKey)) continue;
3394
3565
  resolvedSchema[newKey] = value;
3395
3566
  }
3396
3567
  }
@@ -3413,6 +3584,8 @@ export class ScopeDataStructure {
3413
3584
  if (!subSchema) continue;
3414
3585
 
3415
3586
  for (const resolvedKey in subSchema) {
3587
+ // PERF: Skip keys with repeated function-call signature patterns
3588
+ if (this.hasExcessivePatternRepetition(resolvedKey)) continue;
3416
3589
  if (
3417
3590
  !resolvedSchema[resolvedKey] ||
3418
3591
  subSchema[resolvedKey] === 'unknown'
@@ -3804,25 +3977,116 @@ export class ScopeDataStructure {
3804
3977
  return [source];
3805
3978
  };
3806
3979
 
3807
- return entries.reduce(
3808
- (acc, entry) => {
3809
- if (entry.sourceCandidates.length === 0) return acc;
3980
+ const acc = entries.reduce(
3981
+ (result, entry) => {
3982
+ if (entry.sourceCandidates.length === 0) return result;
3810
3983
  const usages = entry.usages.filter(usageMatchesScope);
3811
3984
  for (const usage of usages) {
3812
- acc[usage.schemaPath] ||= [];
3985
+ result[usage.schemaPath] ||= [];
3813
3986
  // Resolve each source candidate through the equivalency chain
3814
3987
  for (const source of entry.sourceCandidates) {
3815
3988
  const resolvedSources = resolveToSignature(source, new Set());
3816
- acc[usage.schemaPath].push(...resolvedSources);
3989
+ result[usage.schemaPath].push(...resolvedSources);
3817
3990
  }
3818
3991
  }
3819
- return acc;
3992
+ return result;
3820
3993
  },
3821
3994
  {} as Record<
3822
3995
  string,
3823
3996
  Pick<ScopeVariable, 'scopeNodeName' | 'schemaPath'>[]
3824
3997
  >,
3825
3998
  );
3999
+
4000
+ // Post-processing: enrich useState-backed sources with co-located external
4001
+ // function calls. When a useState value resolves to a setter variable that
4002
+ // lives in the same scope as a fetch/API call, that fetch is a data source.
4003
+ this.enrichUseStateSourcesWithCoLocatedCalls(acc);
4004
+
4005
+ return acc;
4006
+ }
4007
+
4008
+ /**
4009
+ * For each source that ends at a useState path, check if the setter was called
4010
+ * from a scope that also contains external function calls (like fetch).
4011
+ * If so, add those external calls as additional source candidates.
4012
+ */
4013
+ private enrichUseStateSourcesWithCoLocatedCalls(
4014
+ acc: Record<string, Pick<ScopeVariable, 'scopeNodeName' | 'schemaPath'>[]>,
4015
+ ) {
4016
+ const rootScopeName = this.scopeTreeManager.getRootName();
4017
+ const rootScope = this.scopeNodes[rootScopeName];
4018
+ if (!rootScope) return;
4019
+
4020
+ // Collect all descendants for each scope node
4021
+ const getAllDescendants = (
4022
+ node: import('./helpers/ScopeTreeManager').ScopeTreeNode,
4023
+ ): Set<string> => {
4024
+ const names = new Set<string>([node.name]);
4025
+ for (const child of node.children) {
4026
+ for (const name of getAllDescendants(child)) {
4027
+ names.add(name);
4028
+ }
4029
+ }
4030
+ return names;
4031
+ };
4032
+
4033
+ for (const [usagePath, sources] of Object.entries(acc)) {
4034
+ const additionalSources: Pick<
4035
+ ScopeVariable,
4036
+ 'scopeNodeName' | 'schemaPath'
4037
+ >[] = [];
4038
+
4039
+ for (const source of sources) {
4040
+ // Check if this source is a useState-related terminal path
4041
+ // (e.g., useState(X).functionCallReturnValue[1] or useState(X).signature[0])
4042
+ if (!source.schemaPath.match(/^useState\([^)]*\)\./)) continue;
4043
+
4044
+ // Find the useState call from the source path
4045
+ const useStateCallMatch = source.schemaPath.match(
4046
+ /^(useState\([^)]*\))\./,
4047
+ );
4048
+ if (!useStateCallMatch) continue;
4049
+ const useStateCall = useStateCallMatch[1];
4050
+
4051
+ // Look in the root scope for the useState value equivalency
4052
+ // which tells us where the setter was called from
4053
+ const valuePath = `${useStateCall}.functionCallReturnValue[0]`;
4054
+ const valueEquivs = rootScope.equivalencies[valuePath];
4055
+ if (!valueEquivs) continue;
4056
+
4057
+ for (const equiv of valueEquivs) {
4058
+ // Find the scope where the setter was called
4059
+ const setterScopeName = equiv.scopeNodeName;
4060
+ const setterScopeTree =
4061
+ this.scopeTreeManager.findNode(setterScopeName);
4062
+ if (!setterScopeTree) continue;
4063
+
4064
+ // Get all descendant scope names from the setter scope
4065
+ const relatedScopes = getAllDescendants(setterScopeTree);
4066
+
4067
+ // Find external function calls in those scopes whose return values
4068
+ // are actually consumed (assigned to a variable). This excludes
4069
+ // fire-and-forget calls like analytics.track() or console.log().
4070
+ const coLocatedCalls = this.externalFunctionCalls.filter(
4071
+ (efc) =>
4072
+ relatedScopes.has(efc.callScope) &&
4073
+ efc.receivingVariableNames &&
4074
+ efc.receivingVariableNames.length > 0,
4075
+ );
4076
+
4077
+ for (const call of coLocatedCalls) {
4078
+ additionalSources.push({
4079
+ scopeNodeName: call.callScope,
4080
+ schemaPath: `${call.callSignature}.functionCallReturnValue`,
4081
+ });
4082
+ }
4083
+ }
4084
+ }
4085
+
4086
+ if (additionalSources.length > 0) {
4087
+ acc[usagePath].push(...additionalSources);
4088
+ }
4089
+ }
3826
4090
  }
3827
4091
 
3828
4092
  getUsageEquivalencies(functionName?: string) {
@@ -3927,6 +4191,72 @@ export class ScopeDataStructure {
3927
4191
  }
3928
4192
  }
3929
4193
 
4194
+ // Enrich schema with deeply nested paths from internal function call scopes.
4195
+ // When a function call like traverse(tree) exists, and traverse's scope has
4196
+ // signature[0].children[path][entityName] (from propagateParameterToSignaturePaths),
4197
+ // we need to map those paths back to the argument variable (tree) in this scope.
4198
+ // This handles cases where cycle detection prevented the equivalency chain from
4199
+ // propagating deep paths during Phase 2 batch queue processing.
4200
+ for (const equivalenceKey in equivalencies ?? {}) {
4201
+ // Look for keys matching function call pattern: funcName(...).signature[N]
4202
+ const funcCallMatch = equivalenceKey.match(
4203
+ /^([^(]+)\(.*?\)\.(signature\[\d+\])$/,
4204
+ );
4205
+ if (!funcCallMatch) continue;
4206
+
4207
+ const calledFunctionName = funcCallMatch[1];
4208
+ const signatureParam = funcCallMatch[2]; // e.g., "signature[0]"
4209
+
4210
+ for (const equivalenceValue of equivalencies[equivalenceKey]) {
4211
+ if (equivalenceValue.scopeNodeName !== scopeName) continue;
4212
+
4213
+ const targetVariable = equivalenceValue.schemaPath;
4214
+
4215
+ // Get the called function's schema (includes propagated parameter paths)
4216
+ const childSchema = this.getSchema({
4217
+ scopeName: calledFunctionName,
4218
+ });
4219
+ if (!childSchema) continue;
4220
+
4221
+ // Map child function's signature paths to parent variable paths
4222
+ const sigPrefix = signatureParam + '.';
4223
+ const sigBracketPrefix = signatureParam + '[';
4224
+ for (const childKey in childSchema) {
4225
+ let suffix: string | null = null;
4226
+ if (childKey.startsWith(sigPrefix)) {
4227
+ suffix = childKey.slice(signatureParam.length);
4228
+ } else if (childKey.startsWith(sigBracketPrefix)) {
4229
+ suffix = childKey.slice(signatureParam.length);
4230
+ }
4231
+
4232
+ if (suffix !== null) {
4233
+ const parentKey = targetVariable + suffix;
4234
+ if (!schema[parentKey]) {
4235
+ schema[parentKey] = childSchema[childKey];
4236
+ }
4237
+ }
4238
+ }
4239
+ }
4240
+ }
4241
+
4242
+ // Helper: check if a type is a concrete scalar that cannot have sub-properties.
4243
+ // e.g., "string", "number | undefined", "boolean | null" are scalar.
4244
+ // "object", "array", "function", "unknown", "Workout", etc. are NOT scalar.
4245
+ const SCALAR_TYPES = new Set([
4246
+ 'string',
4247
+ 'number',
4248
+ 'boolean',
4249
+ 'bigint',
4250
+ 'symbol',
4251
+ 'void',
4252
+ 'never',
4253
+ ]);
4254
+ const isDefinitelyScalarType = (type: string): boolean => {
4255
+ const parts = type.split('|').map((s) => s.trim());
4256
+ const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
4257
+ return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
4258
+ };
4259
+
3930
4260
  // Propagate nested paths from variables to their signature equivalents
3931
4261
  // e.g., if workouts = signature[0].workouts, then workouts[].title becomes
3932
4262
  // signature[0].workouts[].title
@@ -3951,7 +4281,69 @@ export class ScopeDataStructure {
3951
4281
 
3952
4282
  // Add to schema if not already present
3953
4283
  if (!tempScopeNode.schema[signatureKey]) {
3954
- tempScopeNode.schema[signatureKey] = schema[schemaKey];
4284
+ // Check if this path represents variable conflation:
4285
+ // When a standalone variable (e.g., showWorkoutForm from useState)
4286
+ // appears as a sub-property of a scalar-typed ancestor (e.g.,
4287
+ // activity_type = "string"), it's from scope conflation, not real
4288
+ // property access. Block these while allowing legitimate built-in
4289
+ // accesses like string.length or string.slice.
4290
+ let isConflatedPath = false;
4291
+ let checkPos = signaturePath.length;
4292
+ while (true) {
4293
+ checkPos = signatureKey.indexOf('.', checkPos + 1);
4294
+ if (checkPos === -1) break;
4295
+ const ancestorPath = signatureKey.substring(0, checkPos);
4296
+ const ancestorType = tempScopeNode.schema[ancestorPath];
4297
+ if (ancestorType && isDefinitelyScalarType(ancestorType)) {
4298
+ // Ancestor is scalar — check if the immediate sub-property
4299
+ // is also a standalone variable (indicating conflation)
4300
+ const afterDot = signatureKey.substring(checkPos + 1);
4301
+ const nextSep = afterDot.search(/[.\[]/);
4302
+ const subPropName =
4303
+ nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
4304
+ if (schema[subPropName] !== undefined) {
4305
+ isConflatedPath = true;
4306
+ break;
4307
+ }
4308
+ }
4309
+ }
4310
+
4311
+ if (!isConflatedPath) {
4312
+ tempScopeNode.schema[signatureKey] = schema[schemaKey];
4313
+ }
4314
+ }
4315
+ }
4316
+ }
4317
+ }
4318
+
4319
+ // Post-process: filter out conflated signature paths.
4320
+ // During phase 2 scope analysis, useState(false) conflation can create
4321
+ // bad paths like signature[0].mockWorkouts[].activity_type.showWorkoutForm
4322
+ // directly in scopeNode.schema. These flow through signatureInSchema into
4323
+ // tempScopeNode.schema without any guard. Filter them out here by checking:
4324
+ // 1. An ancestor in the path has a concrete scalar type (string, number, boolean, etc.)
4325
+ // 2. The immediate sub-property of that scalar ancestor is also a standalone
4326
+ // variable in the schema (indicating conflation, not a real property access)
4327
+ for (const key of Object.keys(tempScopeNode.schema)) {
4328
+ if (!key.startsWith('signature[')) continue;
4329
+
4330
+ // Walk through the path looking for scalar-typed ancestors
4331
+ let pos = 0;
4332
+ while (true) {
4333
+ pos = key.indexOf('.', pos + 1);
4334
+ if (pos === -1) break;
4335
+ const ancestorPath = key.substring(0, pos);
4336
+ const ancestorType = tempScopeNode.schema[ancestorPath];
4337
+ if (ancestorType && isDefinitelyScalarType(ancestorType)) {
4338
+ // Found a scalar ancestor — check if the sub-property name
4339
+ // is a standalone variable in the getSchema() result
4340
+ const afterDot = key.substring(pos + 1);
4341
+ const nextSep = afterDot.search(/[.\[]/);
4342
+ const subPropName =
4343
+ nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
4344
+ if (schema[subPropName] !== undefined) {
4345
+ delete tempScopeNode.schema[key];
4346
+ break;
3955
4347
  }
3956
4348
  }
3957
4349
  }
@@ -4281,6 +4673,15 @@ export class ScopeDataStructure {
4281
4673
  !equivalentValue.schemaPath.startsWith('signature[') && // not a signature path
4282
4674
  !equivalentValue.schemaPath.endsWith('.functionCallReturnValue') // not already handled above
4283
4675
  ) {
4676
+ // Skip bare "returnValue" from child scopes — this is the child's return value,
4677
+ // not a meaningful data source path in the parent scope
4678
+ if (
4679
+ equivalentValue.schemaPath === 'returnValue' &&
4680
+ equivalentValue.scopeNodeName !==
4681
+ this.scopeTreeManager.getRootName()
4682
+ ) {
4683
+ continue;
4684
+ }
4284
4685
  // Add equivalency (will accumulate if multiple values for OR expressions)
4285
4686
  addEquivalency(path, equivalentValue.schemaPath);
4286
4687
  }
@@ -4682,9 +5083,109 @@ export class ScopeDataStructure {
4682
5083
  // Replace cyScope placeholders in all external function call data
4683
5084
  // This ensures call signatures and schema paths use actual callback text
4684
5085
  // instead of internal cyScope names, preventing mock data merge conflicts.
4685
- return this.externalFunctionCalls.map((efc) =>
4686
- this.cleanCyScopeFromFunctionCallInfo(efc),
4687
- );
5086
+ const rootScopeName = this.scopeTreeManager.getRootName();
5087
+ const rootSchema = this.scopeNodes[rootScopeName]?.schema ?? {};
5088
+
5089
+ return this.externalFunctionCalls.map((efc) => {
5090
+ const cleaned = this.cleanCyScopeFromFunctionCallInfo(efc);
5091
+ return this.filterConflatedExternalPaths(cleaned, rootSchema);
5092
+ });
5093
+ }
5094
+
5095
+ /**
5096
+ * Filters out conflated paths from external function call schemas.
5097
+ *
5098
+ * When multiple useState(false) calls create equivalency conflation during
5099
+ * Phase 1 analysis, standalone boolean state variables (like showWorkoutForm,
5100
+ * showGoalForm) can bleed into external function call schemas as sub-properties
5101
+ * of unrelated data fields (like data[].activity_type.showWorkoutForm).
5102
+ *
5103
+ * Detection: group sub-properties by parent path. If 2+ sub-properties of
5104
+ * the same parent all match standalone root scope variable names, treat them
5105
+ * as conflation artifacts and remove them.
5106
+ */
5107
+ private filterConflatedExternalPaths(
5108
+ efc: FunctionCallInfo,
5109
+ rootSchema: Record<string, string>,
5110
+ ): FunctionCallInfo {
5111
+ // Build a set of top-level root scope variable names (simple names, no dots/brackets)
5112
+ const topLevelRootVars = new Set<string>();
5113
+ for (const key of Object.keys(rootSchema)) {
5114
+ if (!key.includes('.') && !key.includes('[')) {
5115
+ topLevelRootVars.add(key);
5116
+ }
5117
+ }
5118
+
5119
+ if (topLevelRootVars.size === 0) return efc;
5120
+
5121
+ // Group sub-property matches by their parent path.
5122
+ // For a path like "...data[].activity_type.showWorkoutForm",
5123
+ // parent = "...data[].activity_type", child = "showWorkoutForm"
5124
+ const parentToConflatedKeys = new Map<string, string[]>();
5125
+
5126
+ for (const key of Object.keys(efc.schema)) {
5127
+ const lastDot = key.lastIndexOf('.');
5128
+ if (lastDot === -1) continue;
5129
+
5130
+ const parent = key.substring(0, lastDot);
5131
+ const child = key.substring(lastDot + 1);
5132
+
5133
+ // Skip array access or function call patterns
5134
+ if (child.includes('[') || child.includes('(')) continue;
5135
+
5136
+ // Only consider paths inside array element chains (contains []).
5137
+ // Direct children of functionCallReturnValue are legitimate destructured
5138
+ // return values, not conflation. Conflation happens deeper in the chain
5139
+ // when array element fields get corrupted sub-properties.
5140
+ if (!parent.includes('[')) continue;
5141
+
5142
+ if (topLevelRootVars.has(child)) {
5143
+ if (!parentToConflatedKeys.has(parent)) {
5144
+ parentToConflatedKeys.set(parent, []);
5145
+ }
5146
+ parentToConflatedKeys.get(parent)!.push(key);
5147
+ }
5148
+ }
5149
+
5150
+ // Only filter when 2+ sub-properties of the same parent match root scope vars.
5151
+ // This threshold avoids false positives from coincidental name matches.
5152
+ const keysToRemove = new Set<string>();
5153
+ const parentsToRestore = new Set<string>();
5154
+
5155
+ for (const [parent, conflatedKeys] of parentToConflatedKeys) {
5156
+ if (conflatedKeys.length >= 2) {
5157
+ for (const key of conflatedKeys) {
5158
+ keysToRemove.add(key);
5159
+ }
5160
+ parentsToRestore.add(parent);
5161
+ }
5162
+ }
5163
+
5164
+ if (keysToRemove.size === 0) return efc;
5165
+
5166
+ // Create a new schema without the conflated paths
5167
+ const newSchema: Record<string, string> = {};
5168
+ for (const [key, value] of Object.entries(efc.schema)) {
5169
+ if (keysToRemove.has(key)) continue;
5170
+
5171
+ // Restore parent type: if it was changed to "object" because of conflated
5172
+ // sub-properties, and now all those sub-properties are removed, change it
5173
+ // back to "unknown" (we don't know the original type)
5174
+ if (parentsToRestore.has(key) && value === 'object') {
5175
+ // Check if there are any remaining sub-properties
5176
+ const hasRemainingSubProps = Object.keys(efc.schema).some(
5177
+ (k) =>
5178
+ !keysToRemove.has(k) &&
5179
+ k !== key &&
5180
+ (k.startsWith(key + '.') || k.startsWith(key + '[')),
5181
+ );
5182
+ newSchema[key] = hasRemainingSubProps ? value : 'unknown';
5183
+ } else {
5184
+ newSchema[key] = value;
5185
+ }
5186
+ }
5187
+
5188
+ return { ...efc, schema: newSchema };
4688
5189
  }
4689
5190
 
4690
5191
  /**
@@ -4977,6 +5478,10 @@ export class ScopeDataStructure {
4977
5478
  getEnrichedConditionalUsages(): Record<string, EnrichedConditionalUsage[]> {
4978
5479
  const enriched: Record<string, EnrichedConditionalUsage[]> = {};
4979
5480
 
5481
+ console.log(
5482
+ `[getEnrichedConditionalUsages] Processing ${Object.keys(this.rawConditionalUsages).length} conditional paths: [${Object.keys(this.rawConditionalUsages).join(', ')}]`,
5483
+ );
5484
+
4980
5485
  for (const [path, usages] of Object.entries(this.rawConditionalUsages)) {
4981
5486
  // Try to trace this path back to a data source
4982
5487
  // First, try the root scope
@@ -4985,10 +5490,69 @@ export class ScopeDataStructure {
4985
5490
 
4986
5491
  let sourceDataPath: string | undefined;
4987
5492
  if (explanation.source) {
4988
- // Build the full data path: scopeName.path
4989
- sourceDataPath = `${explanation.source.scope}.${explanation.source.path}`;
5493
+ const { scope, path: sourcePath } = explanation.source;
5494
+
5495
+ // Build initial path — avoid redundant prefix when path already contains the scope call
5496
+ let fullPath: string;
5497
+ if (sourcePath.startsWith(`${scope}(`)) {
5498
+ fullPath = sourcePath;
5499
+ } else {
5500
+ fullPath = `${scope}.${sourcePath}`;
5501
+ }
5502
+
5503
+ sourceDataPath = fullPath;
5504
+ console.log(
5505
+ `[getEnrichedConditionalUsages] "${path}" explainPath → scope="${scope}", sourcePath="${sourcePath}" → sourceDataPath="${sourceDataPath}"`,
5506
+ );
5507
+ } else {
5508
+ console.log(
5509
+ `[getEnrichedConditionalUsages] "${path}" explainPath → no source found`,
5510
+ );
5511
+ }
5512
+
5513
+ // If explainPath didn't find a useful external source (e.g., it traced to
5514
+ // useState or just to the component scope itself), check sourceEquivalencies
5515
+ // for an external function call source like a fetch call
5516
+ const hasExternalSource = sourceDataPath?.includes(
5517
+ '.functionCallReturnValue',
5518
+ );
5519
+ if (!hasExternalSource) {
5520
+ console.log(
5521
+ `[getEnrichedConditionalUsages] "${path}" no external source (sourceDataPath="${sourceDataPath}"), checking sourceEquivalencies fallback...`,
5522
+ );
5523
+ const sourceEquiv = this.getSourceEquivalencies();
5524
+ const returnValueKey = `returnValue.${path}`;
5525
+ const sources = sourceEquiv[returnValueKey];
5526
+ if (sources) {
5527
+ console.log(
5528
+ `[getEnrichedConditionalUsages] "${path}" sourceEquivalencies["${returnValueKey}"] has ${sources.length} sources: [${sources.map((s: { schemaPath: string }) => s.schemaPath).join(', ')}]`,
5529
+ );
5530
+ const externalSource = sources.find(
5531
+ (s: { schemaPath: string }) =>
5532
+ s.schemaPath.includes('.functionCallReturnValue') &&
5533
+ !s.schemaPath.startsWith('useState('),
5534
+ );
5535
+ if (externalSource) {
5536
+ console.log(
5537
+ `[getEnrichedConditionalUsages] "${path}" sourceEquivalencies fallback found external source: "${externalSource.schemaPath}"`,
5538
+ );
5539
+ sourceDataPath = externalSource.schemaPath;
5540
+ } else {
5541
+ console.log(
5542
+ `[getEnrichedConditionalUsages] "${path}" sourceEquivalencies fallback found no external function call source`,
5543
+ );
5544
+ }
5545
+ } else {
5546
+ console.log(
5547
+ `[getEnrichedConditionalUsages] "${path}" sourceEquivalencies["${returnValueKey}"] not found`,
5548
+ );
5549
+ }
4990
5550
  }
4991
5551
 
5552
+ console.log(
5553
+ `[getEnrichedConditionalUsages] "${path}" FINAL sourceDataPath="${sourceDataPath ?? '(none)'}" (${usages.length} usages)`,
5554
+ );
5555
+
4992
5556
  enriched[path] = usages.map((usage) => ({
4993
5557
  ...usage,
4994
5558
  sourceDataPath,
@@ -5336,11 +5900,22 @@ export class ScopeDataStructure {
5336
5900
  }
5337
5901
  }
5338
5902
 
5903
+ // Enrich the schema with inferred types by applying fillInSchemaGapsAndUnknowns.
5904
+ // This ensures the serialized schema has the same type inference as getReturnValue().
5905
+ // Without this, evidence like "entities[].analyses: array" becomes "unknown".
5906
+ const enrichedSchema = { ...efc.schema };
5907
+ const tempScopeNode = {
5908
+ name: efc.name,
5909
+ schema: enrichedSchema,
5910
+ equivalencies: efc.equivalencies ?? {},
5911
+ };
5912
+ fillInSchemaGapsAndUnknowns(tempScopeNode, true);
5913
+
5339
5914
  return {
5340
5915
  name: efc.name,
5341
5916
  callSignature: efc.callSignature,
5342
5917
  callScope: efc.callScope,
5343
- schema: efc.schema,
5918
+ schema: enrichedSchema,
5344
5919
  equivalencies: efc.equivalencies
5345
5920
  ? Object.entries(efc.equivalencies).reduce(
5346
5921
  (acc, [key, vars]) => {