@codeyam/codeyam-cli 0.1.0-staging.ae0de75 → 0.1.0-staging.b147f46

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 (571) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +7 -7
  4. package/analyzer-template/packages/ai/package.json +1 -1
  5. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +135 -0
  6. package/analyzer-template/packages/ai/src/lib/astScopes/nodeToSource.ts +19 -0
  7. package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +11 -4
  8. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +36 -9
  9. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +10 -3
  10. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +16 -6
  11. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +0 -33
  12. package/analyzer-template/packages/analyze/index.ts +4 -1
  13. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +13 -7
  14. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  15. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +28 -2
  16. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +5 -36
  17. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +10 -6
  18. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +9 -12
  19. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +21 -0
  20. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +82 -10
  21. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +4 -0
  22. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +4 -0
  23. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +8 -3
  24. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +239 -58
  25. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  26. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1684 -1462
  27. package/analyzer-template/packages/aws/package.json +2 -2
  28. package/analyzer-template/packages/database/package.json +2 -2
  29. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +102 -0
  30. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +19 -15
  31. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  32. package/analyzer-template/packages/database/src/lib/loadEntity.ts +19 -8
  33. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +0 -65
  34. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +9 -0
  35. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -1
  36. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +104 -0
  37. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
  38. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  39. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +1 -1
  40. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  41. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  42. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  43. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  44. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +4 -1
  45. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
  46. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +5 -5
  47. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -1
  48. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  49. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +0 -25
  50. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  51. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  52. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  53. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  54. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  55. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  56. package/analyzer-template/packages/ui-components/package.json +1 -1
  57. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  58. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  59. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  60. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  61. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +3 -1
  62. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  63. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +22 -1
  64. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  65. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +27 -0
  66. package/analyzer-template/project/analyzeFileEntities.ts +26 -0
  67. package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
  68. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  69. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  70. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  71. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  72. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  73. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  74. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  75. package/codeyam-cli/src/cli.js +24 -0
  76. package/codeyam-cli/src/cli.js.map +1 -1
  77. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js +47 -0
  78. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js.map +1 -0
  79. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js +71 -0
  80. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js.map +1 -0
  81. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  82. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  83. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  84. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  85. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  86. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  87. package/codeyam-cli/src/commands/default.js +3 -46
  88. package/codeyam-cli/src/commands/default.js.map +1 -1
  89. package/codeyam-cli/src/commands/editor.js +4654 -836
  90. package/codeyam-cli/src/commands/editor.js.map +1 -1
  91. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js +23 -0
  92. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js.map +1 -0
  93. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  94. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  95. package/codeyam-cli/src/commands/init.js +69 -34
  96. package/codeyam-cli/src/commands/init.js.map +1 -1
  97. package/codeyam-cli/src/commands/telemetry.js +37 -0
  98. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  99. package/codeyam-cli/src/data/techStacks.js +77 -0
  100. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  101. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  102. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  103. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  104. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  105. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  106. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  107. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  108. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  109. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +3769 -1
  110. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -1
  111. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  112. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  113. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  114. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  115. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js +137 -0
  116. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
  117. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  118. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  119. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +181 -3
  120. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -1
  121. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  122. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  123. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
  124. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  125. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
  126. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js.map +1 -0
  127. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  128. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  129. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +249 -2
  130. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -1
  131. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  132. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  133. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  134. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  135. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +118 -1
  136. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -1
  137. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +217 -3
  138. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -1
  139. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  140. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  141. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  142. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  143. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +291 -0
  144. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  145. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1694 -2
  146. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -1
  147. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +329 -0
  148. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  149. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  150. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  151. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  152. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  153. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  154. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  155. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2121 -0
  156. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  157. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js +177 -0
  158. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
  159. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
  160. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  161. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js +302 -0
  162. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js.map +1 -0
  163. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  164. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  165. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js +127 -0
  166. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js.map +1 -0
  167. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  168. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  169. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  170. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  171. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  172. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  173. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
  174. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
  175. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +26 -5
  176. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  177. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  178. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  179. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  180. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  181. package/codeyam-cli/src/utils/__tests__/testRunner.test.js +217 -0
  182. package/codeyam-cli/src/utils/__tests__/testRunner.test.js.map +1 -0
  183. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  184. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  185. package/codeyam-cli/src/utils/analysisRunner.js +39 -8
  186. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  187. package/codeyam-cli/src/utils/analyzer.js +19 -0
  188. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  189. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  190. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  191. package/codeyam-cli/src/utils/backgroundServer.js +95 -19
  192. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  193. package/codeyam-cli/src/utils/database.js +37 -2
  194. package/codeyam-cli/src/utils/database.js.map +1 -1
  195. package/codeyam-cli/src/utils/devServerState.js +71 -0
  196. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  197. package/codeyam-cli/src/utils/editorApi.js +79 -0
  198. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  199. package/codeyam-cli/src/utils/editorAudit.js +753 -8
  200. package/codeyam-cli/src/utils/editorAudit.js.map +1 -1
  201. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  202. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  203. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  204. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  205. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  206. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  207. package/codeyam-cli/src/utils/editorDevServer.js +100 -1
  208. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -1
  209. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  210. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  211. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  212. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  213. package/codeyam-cli/src/utils/editorGuard.js +36 -0
  214. package/codeyam-cli/src/utils/editorGuard.js.map +1 -0
  215. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  216. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  217. package/codeyam-cli/src/utils/editorJournal.js +92 -4
  218. package/codeyam-cli/src/utils/editorJournal.js.map +1 -1
  219. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  220. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  221. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  222. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  223. package/codeyam-cli/src/utils/editorMockState.js +1 -1
  224. package/codeyam-cli/src/utils/editorPreloadHelpers.js +72 -1
  225. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -1
  226. package/codeyam-cli/src/utils/editorPreview.js +74 -1
  227. package/codeyam-cli/src/utils/editorPreview.js.map +1 -1
  228. package/codeyam-cli/src/utils/editorRecapture.js +109 -0
  229. package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
  230. package/codeyam-cli/src/utils/editorScenarioSwitch.js +134 -0
  231. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  232. package/codeyam-cli/src/utils/editorScenarios.js +620 -0
  233. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -1
  234. package/codeyam-cli/src/utils/editorSeedAdapter.js +462 -0
  235. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  236. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  237. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  238. package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
  239. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  240. package/codeyam-cli/src/utils/entityChangeStatus.server.js +212 -0
  241. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  242. package/codeyam-cli/src/utils/fileWatcher.js +38 -0
  243. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  244. package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
  245. package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
  246. package/codeyam-cli/src/utils/install-skills.js +15 -1
  247. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  248. package/codeyam-cli/src/utils/manualEntityAnalysis.js +196 -0
  249. package/codeyam-cli/src/utils/manualEntityAnalysis.js.map +1 -0
  250. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  251. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  252. package/codeyam-cli/src/utils/progress.js +2 -2
  253. package/codeyam-cli/src/utils/progress.js.map +1 -1
  254. package/codeyam-cli/src/utils/queue/job.js +26 -5
  255. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  256. package/codeyam-cli/src/utils/registerScenarioResult.js +52 -0
  257. package/codeyam-cli/src/utils/registerScenarioResult.js.map +1 -0
  258. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  259. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  260. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  261. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  262. package/codeyam-cli/src/utils/scenariosManifest.js +307 -0
  263. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  264. package/codeyam-cli/src/utils/screenshotHash.js +26 -0
  265. package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
  266. package/codeyam-cli/src/utils/serverState.js +30 -0
  267. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  268. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +47 -16
  269. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  270. package/codeyam-cli/src/utils/simulationGateMiddleware.js +17 -1
  271. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -1
  272. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  273. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  274. package/codeyam-cli/src/utils/syncMocksMiddleware.js +2 -2
  275. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  276. package/codeyam-cli/src/utils/telemetry.js +106 -0
  277. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  278. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  279. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  280. package/codeyam-cli/src/utils/testRunner.js +199 -1
  281. package/codeyam-cli/src/utils/testRunner.js.map +1 -1
  282. package/codeyam-cli/src/utils/webappDetection.js +21 -0
  283. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  284. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  285. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  286. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
  287. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  288. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +647 -0
  289. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  290. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +283 -0
  291. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  292. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  293. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  294. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
  295. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  296. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  297. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  298. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  299. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  300. package/codeyam-cli/src/webserver/backgroundServer.js +60 -61
  301. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  302. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  303. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-C76mRRiF.js → EntityItem-Crt_KN_U.js} +5 -5
  304. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  305. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-CobE682z.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  306. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  307. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-CKeQT5Ty.js +25 -0
  308. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  309. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BU_OAEMP.js → LoadingDots-By5zI316.js} +1 -1
  310. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-ceAyBX-H.js → LogViewer-CM5zg40N.js} +3 -3
  311. package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-CQENLSrF.js +36 -0
  312. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-djPLI-WV.js → ReportIssueModal-C2PLkej3.js} +4 -4
  313. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  314. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-B76aig_2.js → ScenarioViewer-DUMfcNVK.js} +3 -3
  315. package/codeyam-cli/src/webserver/build/client/assets/Spinner-D0LgAaSa.js +34 -0
  316. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  317. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  318. package/codeyam-cli/src/webserver/build/client/assets/{_index-C96V0n15.js → _index-BAWd-Xjf.js} +4 -4
  319. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BpKzcsJz.js → activity.(_tab)-BOARiB-g.js} +8 -8
  320. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  321. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  322. package/codeyam-cli/src/webserver/build/client/assets/{addon-web-links-Duc5hnl7.js → addon-web-links-CHx25PAe.js} +1 -1
  323. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  324. package/codeyam-cli/src/webserver/build/client/assets/{agent-transcripts-D9hemwl6.js → agent-transcripts-Bg3e7q4S.js} +7 -7
  325. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  326. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  327. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  328. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  329. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  330. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
  331. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  332. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  333. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  334. package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
  335. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  336. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D_nMCFmP.js → book-open-CL-lMgHh.js} +2 -2
  337. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-BH2h1Ea2.js → chevron-down-GmAjGS9-.js} +2 -2
  338. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  339. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-DyIKORY6.js → circle-check-DFcQkN5j.js} +2 -2
  340. package/codeyam-cli/src/webserver/build/client/assets/{copy-NDbZjXao.js → copy-C6iF61Xs.js} +3 -3
  341. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  342. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
  343. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
  344. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C8y4mmyv.js +1 -0
  345. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  346. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DMv5ESGo.js +96 -0
  347. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CluPkvXJ.js +41 -0
  348. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CrjR3zZW.js → entity._sha._-ByHz6rAQ.js} +14 -13
  349. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-CmLO432x.js +6 -0
  350. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Bz9sCUF_.js +6 -0
  351. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DQM8E7L4.js +6 -0
  352. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMvVHNXU.js → entity._sha_.edit._scenarioId-CAoXLsQr.js} +2 -2
  353. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-DTvKq3TY.js → entry.client-SuW9syRS.js} +6 -6
  354. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  355. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  356. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  357. package/codeyam-cli/src/webserver/build/client/assets/globals-oyPmV37k.css +1 -0
  358. package/codeyam-cli/src/webserver/build/client/assets/{index-BcvgDzbZ.js → index-Bp1l4hSv.js} +1 -1
  359. package/codeyam-cli/src/webserver/build/client/assets/{index-10oVnAAH.js → index-CWV9XZiG.js} +1 -1
  360. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  361. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  362. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  363. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BAXYRVEO.js → loader-circle-De-7qQ2u.js} +2 -2
  364. package/codeyam-cli/src/webserver/build/client/assets/manifest-1a45e154.js +1 -0
  365. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  366. package/codeyam-cli/src/webserver/build/client/assets/{pause-DTAcYxBt.js → pause-CFxEKL1u.js} +3 -3
  367. package/codeyam-cli/src/webserver/build/client/assets/root-D2_tktnk.js +80 -0
  368. package/codeyam-cli/src/webserver/build/client/assets/{search-fKo7v0Zo.js → search-BdBb5aqc.js} +2 -2
  369. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  370. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  371. package/codeyam-cli/src/webserver/build/client/assets/{terminal-BG4heKCG.js → terminal-CrplD4b1.js} +3 -3
  372. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-DtSmdtM4.js → triangle-alert-DqJ0j69l.js} +2 -2
  373. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  374. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-C14nCb1q.js → useLastLogLine-BNd5hYuW.js} +1 -1
  375. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  376. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  377. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  378. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-By5slFjw.js +16 -0
  379. package/codeyam-cli/src/webserver/build/server/assets/index-DXaOwBnm.js +1 -0
  380. package/codeyam-cli/src/webserver/build/server/assets/init-CLG1LjQM.js +10 -0
  381. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  382. package/codeyam-cli/src/webserver/build/server/assets/server-build-NZmUqQv6.js +688 -0
  383. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  384. package/codeyam-cli/src/webserver/build-info.json +5 -5
  385. package/codeyam-cli/src/webserver/editorProxy.js +638 -50
  386. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -1
  387. package/codeyam-cli/src/webserver/idleDetector.js +121 -0
  388. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  389. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  390. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  391. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  392. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +242 -3
  393. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +147 -4
  394. package/codeyam-cli/src/webserver/server.js +169 -16
  395. package/codeyam-cli/src/webserver/server.js.map +1 -1
  396. package/codeyam-cli/src/webserver/terminalServer.js +321 -49
  397. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -1
  398. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  399. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  400. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  401. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  402. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  403. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  404. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  405. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  406. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  407. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  408. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  409. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  410. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  411. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  412. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  413. package/codeyam-cli/templates/codeyam-editor-claude.md +86 -5
  414. package/codeyam-cli/templates/codeyam-editor-reference.md +216 -0
  415. package/codeyam-cli/templates/editor-step-hook.py +262 -41
  416. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  417. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  418. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  419. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  420. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  421. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  422. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  423. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  424. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  425. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  426. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  427. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  428. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  429. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  430. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  431. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  432. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  433. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  434. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  435. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  436. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  437. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  438. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +9 -4
  439. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  440. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +21 -0
  441. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +6 -2
  442. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +4 -1
  443. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +135 -0
  444. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  445. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  446. package/codeyam-cli/templates/{nextjs-prisma-sqlite/PRISMA_SETUP.md → nextjs-prisma-supabase/SUPABASE_SETUP.md} +37 -17
  447. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  448. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  449. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  450. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  451. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  452. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  453. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  454. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  455. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  456. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  457. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  458. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  459. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  460. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  461. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  462. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  463. package/codeyam-cli/templates/seed-adapters/supabase.ts +282 -0
  464. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +2 -2
  465. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +177 -17
  466. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +10 -10
  467. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  468. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  469. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  470. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  471. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  472. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  473. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  474. package/package.json +16 -10
  475. package/packages/ai/src/lib/astScopes/methodSemantics.js +99 -0
  476. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  477. package/packages/ai/src/lib/astScopes/nodeToSource.js +16 -0
  478. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -1
  479. package/packages/ai/src/lib/astScopes/paths.js +12 -3
  480. package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
  481. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +27 -10
  482. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  483. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
  484. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
  485. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +14 -4
  486. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  487. package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
  488. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  489. package/packages/analyze/index.js +1 -1
  490. package/packages/analyze/index.js.map +1 -1
  491. package/packages/analyze/src/lib/ProjectAnalyzer.js +10 -4
  492. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  493. package/packages/analyze/src/lib/asts/index.js +4 -2
  494. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  495. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +16 -2
  496. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  497. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +6 -26
  498. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  499. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +3 -2
  500. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  501. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +9 -7
  502. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  503. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
  504. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
  505. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -11
  506. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  507. package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
  508. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  509. package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
  510. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  511. package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
  512. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
  513. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +120 -28
  514. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  515. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  516. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  517. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1368 -1193
  518. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  519. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +104 -0
  520. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
  521. package/packages/database/src/lib/loadAnalysis.js +1 -1
  522. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  523. package/packages/database/src/lib/loadEntities.js +0 -6
  524. package/packages/database/src/lib/loadEntities.js.map +1 -1
  525. package/packages/database/src/lib/loadEntity.js +5 -5
  526. package/packages/database/src/lib/loadEntity.js.map +1 -1
  527. package/packages/database/src/lib/updateCommitMetadata.js +0 -25
  528. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  529. package/packages/types/src/enums/ProjectFramework.js +2 -0
  530. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  531. package/packages/utils/src/lib/fs/rsyncCopy.js +22 -1
  532. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  533. package/scripts/npm-post-install.cjs +22 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-DmJveP3T.js +0 -1
  535. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-g3saevPb.js +0 -1
  536. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +0 -1
  537. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DYFW3lDD.js +0 -25
  538. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DLeucoVX.js +0 -3
  539. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-BED4B6sP.js +0 -1
  540. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +0 -34
  541. package/codeyam-cli/src/webserver/build/client/assets/Terminal-wkqC0AQk.js +0 -41
  542. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-C8OKAR5x.js +0 -1
  543. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +0 -1
  544. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-C4pqxYJB.js +0 -51
  545. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CMT1jU2q.js +0 -21
  546. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
  547. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +0 -1
  548. package/codeyam-cli/src/webserver/build/client/assets/editor-CdjF_fX6.js +0 -8
  549. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-D8ILZMR0.js +0 -6
  550. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.js +0 -6
  551. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +0 -6
  552. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-cPo8LiG3.js +0 -1
  553. package/codeyam-cli/src/webserver/build/client/assets/files-DO4CZ16O.js +0 -1
  554. package/codeyam-cli/src/webserver/build/client/assets/git-CFCTYk9I.js +0 -15
  555. package/codeyam-cli/src/webserver/build/client/assets/globals-B17TBSS6.css +0 -1
  556. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +0 -1
  557. package/codeyam-cli/src/webserver/build/client/assets/manifest-b8fd6b07.js +0 -1
  558. package/codeyam-cli/src/webserver/build/client/assets/memory-FweZHj5U.js +0 -93
  559. package/codeyam-cli/src/webserver/build/client/assets/root-DUKqhFlb.js +0 -67
  560. package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +0 -1
  561. package/codeyam-cli/src/webserver/build/client/assets/simulations-B3aOzpCZ.js +0 -1
  562. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-ByhSyh0W.js +0 -1
  563. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-O-jkvSPx.js +0 -1
  564. package/codeyam-cli/src/webserver/build/client/assets/useToast-9FIWuYfK.js +0 -1
  565. package/codeyam-cli/src/webserver/build/server/assets/index-BLhjL9Xi.js +0 -1
  566. package/codeyam-cli/src/webserver/build/server/assets/server-build-DyMuI5mU.js +0 -363
  567. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.sh +0 -108
  568. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh +0 -69
  569. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.sh +0 -12
  570. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter.jq +0 -45
  571. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.sh +0 -139
@@ -1,10 +1,10 @@
1
1
  {
2
- "buildTimestamp": "2026-03-03T15:39:20.077Z",
3
- "buildTime": 1772552360077,
4
- "gitCommit": "ae0de758e679d36a7e66bc3b8c426c5ea24dcec5",
5
- "nodeVersion": "v20.20.0",
6
- "contentHash": "56095f026fcf9575b86866f4fe3d3d61b9466cf70e4d3f16001752fd1febd7c2",
7
- "buildNumber": 824,
8
- "semanticVersion": "0.1.824",
9
- "version": "0.1.824 (2026-03-03T15:39+56095f0)"
2
+ "buildTimestamp": "2026-03-25T14:06:41.149Z",
3
+ "buildTime": 1774447601149,
4
+ "gitCommit": "b147f467a128fd4f013eb4378bdfa29ea64f83ad",
5
+ "nodeVersion": "v20.20.1",
6
+ "contentHash": "1ef6e4857c54ba0e5ddecacacdd26bdc64e7a25cd41e9f154b5ea6e3cd5525dc",
7
+ "buildNumber": 1223,
8
+ "semanticVersion": "0.1.1223",
9
+ "version": "0.1.1223 (2026-03-25T14:06+1ef6e48)"
10
10
  }
@@ -1,7 +1,7 @@
1
1
 
2
- [3/3/2026, 3:39:19 PM] > codeyam-combo@1.0.0 mergeDependencies
3
- [3/3/2026, 3:39:19 PM] > node ./scripts/mergePackageJsonFiles.cjs
2
+ [3/25/2026, 2:06:41 PM] > codeyam-combo@1.0.0 mergeDependencies
3
+ [3/25/2026, 2:06:41 PM] > node ./scripts/mergePackageJsonFiles.cjs
4
4
 
5
5
 
6
- [3/3/2026, 3:39:20 PM] Merged dependencies into root package.json
6
+ [3/25/2026, 2:06:41 PM] Merged dependencies into root package.json
7
7
 
@@ -9,7 +9,7 @@
9
9
  "dependencies": {
10
10
  "@aws-sdk/client-cloudwatch-logs": "^3.990.0",
11
11
  "@aws-sdk/client-cloudfront": "^3.990.0",
12
- "@aws-sdk/client-codebuild": "^3.990.0",
12
+ "@aws-sdk/client-codebuild": "^3.1014.0",
13
13
  "@aws-sdk/client-dynamodb": "^3.990.0",
14
14
  "@aws-sdk/client-ec2": "^3.990.0",
15
15
  "@aws-sdk/client-ecr": "^3.990.0",
@@ -30,7 +30,7 @@
30
30
  "jest": "^30.2.0",
31
31
  "jsdom": "^27.4.0",
32
32
  "jsonc-parser": "^3.2.1",
33
- "lru-cache": "^11.2.5",
33
+ "lru-cache": "^11.2.7",
34
34
  "openai": "^6.16.0",
35
35
  "p-queue": "^9.1.0",
36
36
  "p-retry": "^7.1.1",
@@ -38,7 +38,7 @@
38
38
  "pixelmatch": "^5.3.0",
39
39
  "playwright": "1.58.0",
40
40
  "sharp": "^0.34.5",
41
- "simple-git": "^3.28.0",
41
+ "simple-git": "^3.32.2",
42
42
  "undici": "^7.18.2",
43
43
  "uuid": "^11.1.0",
44
44
  "pluralize": "^8.0.0",
@@ -48,16 +48,16 @@
48
48
  "@aws-sdk/s3-request-presigner": "^3.990.0",
49
49
  "better-sqlite3": "^12.6.2",
50
50
  "fetch-retry": "^6.0.0",
51
- "kysely": "^0.28.11",
52
- "pg": "^8.19.0",
51
+ "kysely": "^0.28.14",
52
+ "pg": "^8.20.0",
53
53
  "@octokit/request": "^10.0.3",
54
- "lucide-react": "^0.556.0",
54
+ "lucide-react": "^0.577.0",
55
55
  "react-resizable": "^3.0.5"
56
56
  },
57
57
  "devDependencies": {
58
58
  "typescript": "^5.9.3",
59
59
  "@jest/types": "^30.2.0",
60
- "@types/node": "^25.0.2",
60
+ "@types/node": "^25.3.3",
61
61
  "@types/yargs": "^17.0.34",
62
62
  "@types/jsdom": "^27.0.0",
63
63
  "@types/better-sqlite3": "^7.6.13",
@@ -14,7 +14,7 @@
14
14
  "p-queue": "^9.1.0",
15
15
  "p-retry": "^7.1.1",
16
16
  "piscina": "^5.1.4",
17
- "lru-cache": "^11.2.5"
17
+ "lru-cache": "^11.2.7"
18
18
  },
19
19
  "devDependencies": {
20
20
  "@types/jsdom": "^27.0.0"
@@ -895,6 +895,132 @@ export class UseStateSemantics implements MethodSemantics {
895
895
  }
896
896
  }
897
897
 
898
+ // ─── Set/Map method semantics ──────────────────────────────────────────
899
+ //
900
+ // Set/Map membership operations (.has, .delete, .add, .get, .set, .clear)
901
+ // don't create data flow equivalencies — they're membership checks or
902
+ // mutations, not transformations that propagate schema structure.
903
+ // Without these semantics, code like `filterRatings.has(articleId)` creates
904
+ // spurious equivalencies (332 entries in the Margo LibraryPage case).
905
+
906
+ /**
907
+ * Set.has() / Map.has() — membership check, returns boolean
908
+ */
909
+ export class CollectionHasSemantics implements MethodSemantics {
910
+ getReturnType(): string {
911
+ return 'boolean';
912
+ }
913
+
914
+ addEquivalences(
915
+ methodCallPath: StructuredPath,
916
+ _sourcePath: StructuredPath,
917
+ context: AnalysisContext,
918
+ ): void {
919
+ context.addType(methodCallPath, 'boolean');
920
+ }
921
+
922
+ isComplete(): boolean {
923
+ return true;
924
+ }
925
+ }
926
+
927
+ /**
928
+ * Set.delete() / Map.delete() — removal, returns boolean
929
+ */
930
+ export class CollectionDeleteSemantics implements MethodSemantics {
931
+ getReturnType(): string {
932
+ return 'boolean';
933
+ }
934
+
935
+ addEquivalences(
936
+ methodCallPath: StructuredPath,
937
+ _sourcePath: StructuredPath,
938
+ context: AnalysisContext,
939
+ ): void {
940
+ context.addType(methodCallPath, 'boolean');
941
+ }
942
+
943
+ isComplete(): boolean {
944
+ return true;
945
+ }
946
+ }
947
+
948
+ /**
949
+ * Set.add() — adds an element, returns the Set (for chaining)
950
+ */
951
+ export class SetAddSemantics implements MethodSemantics {
952
+ getReturnType(): string {
953
+ return 'object'; // Returns the Set itself
954
+ }
955
+
956
+ addEquivalences(
957
+ _methodCallPath: StructuredPath,
958
+ _sourcePath: StructuredPath,
959
+ _context: AnalysisContext,
960
+ ): void {
961
+ // No equivalencies — add() doesn't create data flow
962
+ }
963
+
964
+ isComplete(): boolean {
965
+ return true;
966
+ }
967
+ }
968
+
969
+ /**
970
+ * Set.clear() / Map.clear() — removes all elements, returns void
971
+ */
972
+ export class CollectionClearSemantics implements MethodSemantics {
973
+ getReturnType(): string {
974
+ return 'void';
975
+ }
976
+
977
+ addEquivalences(): void {
978
+ // No equivalencies
979
+ }
980
+
981
+ isComplete(): boolean {
982
+ return true;
983
+ }
984
+ }
985
+
986
+ /**
987
+ * Map.get() — retrieves a value by key, returns unknown (value type)
988
+ */
989
+ export class MapGetSemantics implements MethodSemantics {
990
+ getReturnType(): string {
991
+ return 'unknown';
992
+ }
993
+
994
+ addEquivalences(
995
+ _methodCallPath: StructuredPath,
996
+ _sourcePath: StructuredPath,
997
+ _context: AnalysisContext,
998
+ ): void {
999
+ // No equivalencies — the return value type depends on the map contents
1000
+ }
1001
+
1002
+ isComplete(): boolean {
1003
+ return true;
1004
+ }
1005
+ }
1006
+
1007
+ /**
1008
+ * Map.set() — sets a key-value pair, returns the Map (for chaining)
1009
+ */
1010
+ export class MapSetSemantics implements MethodSemantics {
1011
+ getReturnType(): string {
1012
+ return 'object'; // Returns the Map itself
1013
+ }
1014
+
1015
+ addEquivalences(): void {
1016
+ // No equivalencies
1017
+ }
1018
+
1019
+ isComplete(): boolean {
1020
+ return true;
1021
+ }
1022
+ }
1023
+
898
1024
  /**
899
1025
  * Create and populate the registry with method semantics
900
1026
  */
@@ -930,6 +1056,15 @@ export function createMethodRegistry(): MethodSemanticsRegistry {
930
1056
  registry.register('useState', new UseStateSemantics(), 'React');
931
1057
  registry.register('useMemo', new UseMemoSemantics(), 'React');
932
1058
 
1059
+ // Register Set/Map collection methods.
1060
+ // Only .has() and .delete() are safe to register by method name — they always
1061
+ // return boolean regardless of the collection type (Set, Map, WeakSet, WeakMap,
1062
+ // FormData, URLSearchParams, etc.).
1063
+ // .add(), .clear(), .get(), .set() are too ambiguous across different types
1064
+ // and can't be registered until the lookup code supports class-aware resolution.
1065
+ registry.register('has', new CollectionHasSemantics());
1066
+ registry.register('delete', new CollectionDeleteSemantics());
1067
+
933
1068
  return registry;
934
1069
  }
935
1070
 
@@ -54,6 +54,25 @@ export function nodeToSource(
54
54
  // return serializeBindingElement(node, sourceFile, options);
55
55
  // }
56
56
 
57
+ // Object/array/function literals should be marked as literal paths.
58
+ // This prevents them from creating sourceEquivalencies when used as
59
+ // function call arguments (e.g., setUndoEntry({ label: '...', undo: ... })).
60
+ // Without this, the full source text of the literal (300-500 chars for complex
61
+ // objects) gets embedded in path strings, creating expensive-to-parse
62
+ // equivalency entries that don't contribute useful schema information.
63
+ if (ts.isObjectLiteralExpression(node)) {
64
+ return StructuredPath.createLiteralPath(node.getText(sourceFile), 'object');
65
+ }
66
+ if (ts.isArrayLiteralExpression(node)) {
67
+ return StructuredPath.createLiteralPath(node.getText(sourceFile), 'array');
68
+ }
69
+ if (ts.isArrowFunction(node) || ts.isFunctionExpression(node)) {
70
+ return StructuredPath.createLiteralPath(
71
+ node.getText(sourceFile),
72
+ 'function',
73
+ );
74
+ }
75
+
57
76
  // Fallback for unsupported node types
58
77
  return StructuredPath.fromBase(node.getText(sourceFile));
59
78
  }
@@ -406,11 +406,18 @@ export class StructuredPath {
406
406
  } else {
407
407
  // Convert each argument to its string representation
408
408
  const argsStr = funcSegment.args
409
- .map((arg) =>
410
- arg.toStringWithSegments(arg.base, arg.segments, {
409
+ .map((arg) => {
410
+ // For literal arguments (object/array/function literals),
411
+ // use a compact placeholder instead of the full source text.
412
+ // This prevents 300-500 char inline objects from being embedded
413
+ // in call signature paths, which creates expensive equivalencies.
414
+ if (arg.isLiteral()) {
415
+ return `{...}`;
416
+ }
417
+ return arg.toStringWithSegments(arg.base, arg.segments, {
411
418
  withReturnValues: doRenderNestedFunctionCallReturnValue,
412
- }),
413
- )
419
+ });
420
+ })
414
421
  .join(', ');
415
422
  result += `(${argsStr})`;
416
423
  }
@@ -398,6 +398,7 @@ const SILENTLY_IGNORED_EQUIVALENCY_REASONS = new Set([
398
398
  'transformed non-object function equivalency - Array.from() equivalency',
399
399
  'Spread operator equivalency key update: Explicit array deconstruction equivalency value',
400
400
  // 'transformed non-object function equivalency - Explicit array deconstruction equivalency value',
401
+ 'useState setter call equivalency (direct)',
401
402
  ]);
402
403
 
403
404
  export class ScopeDataStructure {
@@ -1048,9 +1049,38 @@ export class ScopeDataStructure {
1048
1049
  equivalencyValueChain?: EquivalencyValueChainItem[],
1049
1050
  traceId?: number,
1050
1051
  ) {
1052
+ // Fast early exits that don't count toward the limit.
1053
+ // These are "no-op" calls that would be caught further below anyway,
1054
+ // but checking them first prevents counter inflation from redundant calls
1055
+ // generated by managers and followEquivalencies during scope processing.
1056
+
1057
+ // Skip silently-ignored reasons before counting
1058
+ if (SILENTLY_IGNORED_EQUIVALENCY_REASONS.has(equivalencyReason)) {
1059
+ return;
1060
+ }
1061
+
1062
+ // Skip exact duplicates before counting (Phase 1 only — Phase 2 needs
1063
+ // to process duplicates for database chain tracking)
1064
+ if (this.onlyEquivalencies) {
1065
+ const existing = scopeNode.equivalencies[path];
1066
+ if (
1067
+ existing?.some(
1068
+ (v) =>
1069
+ v.schemaPath === equivalentPath &&
1070
+ v.scopeNodeName === equivalentScopeName,
1071
+ )
1072
+ ) {
1073
+ return;
1074
+ }
1075
+ }
1076
+
1051
1077
  addEquivalencyCallCount++;
1052
1078
 
1053
- if (addEquivalencyCallCount > 50000) {
1079
+ const limit =
1080
+ typeof (globalThis as any).__CODEYAM_EQUIVALENCY_LIMIT === 'number'
1081
+ ? (globalThis as any).__CODEYAM_EQUIVALENCY_LIMIT
1082
+ : 50000;
1083
+ if (addEquivalencyCallCount > limit) {
1054
1084
  console.error('INFINITE LOOP DETECTED in addEquivalency', {
1055
1085
  callCount: addEquivalencyCallCount,
1056
1086
  path,
@@ -1065,14 +1095,11 @@ export class ScopeDataStructure {
1065
1095
  }
1066
1096
  // Filter equivalency reasons - use pre-computed Sets for O(1) lookup
1067
1097
  if (!ALLOWED_EQUIVALENCY_REASONS.has(equivalencyReason)) {
1068
- if (SILENTLY_IGNORED_EQUIVALENCY_REASONS.has(equivalencyReason)) {
1069
- return;
1070
- } else {
1071
- // Log and skip - if an equivalency reason isn't in ALLOWED or SILENTLY_IGNORED,
1072
- // it shouldn't be stored (was previously missing the return)
1073
- console.info('Not tracked equivalency reason', { equivalencyReason });
1074
- return;
1075
- }
1098
+ // Silently-ignored reasons already handled above
1099
+ // Log and skip - if an equivalency reason isn't in ALLOWED or SILENTLY_IGNORED,
1100
+ // it shouldn't be stored (was previously missing the return)
1101
+ console.info('Not tracked equivalency reason', { equivalencyReason });
1102
+ return;
1076
1103
  }
1077
1104
 
1078
1105
  // Skip self-referential equivalencies that would create infinite loops.
@@ -97,6 +97,16 @@ export default class ParentScopeManager implements EquivalencyManager {
97
97
  }
98
98
 
99
99
  if (instantiatedInParent || returnValueFromChildScope) {
100
+ // Skip if we've already propagated this variable to the parent scope.
101
+ // Without this guard, nested scopes trigger redundant addEquivalency calls
102
+ // for the same variable on every addToSchema pass (e.g., 'a' and 'b' in sort
103
+ // callbacks get propagated 30+ times per scope instead of once).
104
+ this.addedToParent[scopeNode.name] ||= new Set<string>();
105
+ if (this.addedToParent[scopeNode.name].has(rootPath)) {
106
+ return false;
107
+ }
108
+ this.addedToParent[scopeNode.name].add(rootPath);
109
+
100
110
  if (traceId && debugLevel > 0) {
101
111
  console.info(
102
112
  'Debug Propagation: parentScope executed',
@@ -114,9 +124,6 @@ export default class ParentScopeManager implements EquivalencyManager {
114
124
  );
115
125
  }
116
126
 
117
- this.addedToParent[scopeNode.name] ||= new Set<string>();
118
- this.addedToParent[scopeNode.name].add(rootPath);
119
-
120
127
  scopeDataStructure.addEquivalency(
121
128
  rootPath,
122
129
  rootPath,
@@ -6,7 +6,7 @@ import { ScopeNode, ScopeDataStructure } from '../ScopeDataStructure';
6
6
 
7
7
  type PrimitiveKind = 'array' | 'string' | 'number' | 'boolean' | 'date';
8
8
 
9
- const IGNORE_CLASSES_AND_OBJECTS = [
9
+ const IGNORE_CLASSES_AND_OBJECTS_SET = new Set([
10
10
  'Math',
11
11
  'JSON',
12
12
  'Reflect',
@@ -22,7 +22,7 @@ const IGNORE_CLASSES_AND_OBJECTS = [
22
22
  'useContext',
23
23
  'useReducer',
24
24
  'useLayoutEffect',
25
- ];
25
+ ]);
26
26
 
27
27
  /** cache the tokenised representation of every path we touch */
28
28
  const partsCache = new Map<string, string[]>();
@@ -147,16 +147,26 @@ function scrub(
147
147
  rootTable: Map<string, PrimitiveKind>,
148
148
  onRemove: (key: string) => void,
149
149
  ): void {
150
- const sortedKeys = Object.keys(mapping).sort((a, b) => a.localeCompare(b));
150
+ // Early exit: if no primitive types exist in the schema, there are no
151
+ // built-in methods to clean. Saves sorting + walking 10K+ keys.
152
+ if (rootTable.size === 0) return;
153
+
154
+ // Use direct comparison instead of localeCompare (3-5x faster for large arrays)
155
+ const sortedKeys = Object.keys(mapping).sort((a, b) =>
156
+ a < b ? -1 : a > b ? 1 : 0,
157
+ );
151
158
 
152
159
  for (const keyPath of sortedKeys) {
153
160
  const keyParts = getParts(keyPath);
154
161
  const prefixParts = buildPrefixParts(keyParts);
155
162
 
163
+ const firstPart = keyParts[0];
164
+ const firstPartBase = firstPart.includes('(')
165
+ ? firstPart.split('(')[0]
166
+ : firstPart;
156
167
  if (
157
- IGNORE_CLASSES_AND_OBJECTS.find(
158
- (m) => keyParts[0] === m || keyParts[0].startsWith(`${m}(`),
159
- )
168
+ IGNORE_CLASSES_AND_OBJECTS_SET.has(firstPart) ||
169
+ IGNORE_CLASSES_AND_OBJECTS_SET.has(firstPartBase)
160
170
  ) {
161
171
  delete mapping[keyPath];
162
172
  continue;
@@ -129,19 +129,6 @@ export default function generateExecutionFlows({
129
129
  fullToShortPathMap[fullPath] = shortPath;
130
130
  }
131
131
 
132
- console.log(
133
- `[generateExecutionFlows] ${entity.name}: attributesMap has ${Object.keys(resolvedAttributesMap).length} keys, fullToShortPathMap has ${Object.keys(fullToShortPathMap).length} entries`,
134
- );
135
- console.log(
136
- `[generateExecutionFlows] ${entity.name}: attributesMap keys: [${Object.keys(resolvedAttributesMap).join(', ')}]`,
137
- );
138
- console.log(
139
- `[generateExecutionFlows] ${entity.name}: fullToShortPathMap: ${JSON.stringify(fullToShortPathMap)}`,
140
- );
141
- console.log(
142
- `[generateExecutionFlows] ${entity.name}: equivalentSignatureVariables: ${JSON.stringify(equivalentSignatureVariables)}`,
143
- );
144
-
145
132
  // Get pre-computed conditional data from metadata
146
133
  const conditionalUsages: Record<string, ConditionalUsage[]> =
147
134
  entity.metadata?.isolatedDataStructure?.conditionalUsages ?? {};
@@ -186,26 +173,6 @@ export default function generateExecutionFlows({
186
173
  }
187
174
  }
188
175
 
189
- console.log(
190
- `[generateExecutionFlows] ${entity.name}: conditionalUsages keys: [${Object.keys(conditionalUsages).join(', ')}]`,
191
- );
192
- console.log(
193
- `[generateExecutionFlows] ${entity.name}: conditionalUsages sourceDataPaths: ${JSON.stringify(
194
- Object.fromEntries(
195
- Object.entries(conditionalUsages).map(([k, v]) => [
196
- k,
197
- (v as any[]).map((u: any) => u.sourceDataPath ?? '(none)'),
198
- ]),
199
- ),
200
- )}`,
201
- );
202
- console.log(
203
- `[generateExecutionFlows] ${entity.name}: compoundConditionals count: ${compoundConditionals.length}`,
204
- );
205
- console.log(
206
- `[generateExecutionFlows] ${entity.name}: sourceEquivalencies keys count: ${Object.keys(mergedDataStructure.sourceEquivalencies ?? {}).length}`,
207
- );
208
-
209
176
  const conditionalsBasedFlows = generateExecutionFlowsFromConditionals({
210
177
  conditionalUsages,
211
178
  compoundConditionals,
@@ -36,7 +36,10 @@ export { getAllEntityNodes } from './src/lib/asts/sourceFiles/getAllEntityNodes'
36
36
  export { default as fileAnalyzerFromCode } from './src/lib/files/fileAnalyzerFromCode';
37
37
 
38
38
  export { default as isolateDataStructure } from './src/lib/files/scenarios/isolateDataStructure';
39
- export { default as mergeInDependentDataStructure } from './src/lib/files/scenarios/mergeInDependentDataStructure';
39
+ export {
40
+ default as mergeInDependentDataStructure,
41
+ DataStructureTimeoutError,
42
+ } from './src/lib/files/scenarios/mergeInDependentDataStructure';
40
43
  export { default as mergeValidatedDataStructures } from './src/lib/files/scenarios/mergeValidatedDataStructures';
41
44
 
42
45
  export { discoverDirectDependencies } from './src/lib/files/analyze/dependencyResolver';
@@ -340,17 +340,23 @@ export class ProjectAnalyzer {
340
340
  * Refresh the TypeScript program to pick up file changes
341
341
  */
342
342
  refreshProgram(): void {
343
- // Memory logging: Capture state before refresh
344
- const memBefore = process.memoryUsage();
345
-
346
343
  // Apply the same unapprovedPaths filtering when refreshing
347
344
  const excludePatterns =
348
345
  this.project.metadata?.unapprovedPaths?.filter(Boolean) || [];
349
346
 
350
- // Refresh all programs
351
- this.programs = this.tsConfigPaths.map((configPath) =>
352
- lib.asts.createProgramFromTsConfigPath(configPath, excludePatterns),
353
- );
347
+ // Release old programs and caches BEFORE creating new ones to reduce peak memory.
348
+ // Without this, both old (~1.7GB) and new (~1.7GB) programs coexist during creation,
349
+ // causing OOM on monorepos with multiple tsconfigs.
350
+ this.programs = [];
351
+ this.sourceFileByPath.clear();
352
+ this.typeCheckerByPath.clear();
353
+
354
+ // Create programs one at a time so each old program can be GC'd before the next
355
+ for (const configPath of this.tsConfigPaths) {
356
+ this.programs.push(
357
+ lib.asts.createProgramFromTsConfigPath(configPath, excludePatterns),
358
+ );
359
+ }
354
360
 
355
361
  // Update primary program for backward compatibility
356
362
  this.program = this.programs[0];
@@ -95,8 +95,13 @@ export function createProgramFromTsConfigPath(
95
95
  throw new Error('Could not parse tsconfig.json');
96
96
  }
97
97
 
98
- // Filter file names based on exclude patterns to reduce memory usage
99
- let fileNames = parsedCommandLine.fileNames;
98
+ // Always filter out node_modules from root files to prevent OOM on large projects.
99
+ // This only removes them as root compilation targets — TypeScript's module resolution
100
+ // still follows imports into node_modules for type info when processing source files.
101
+ let fileNames = parsedCommandLine.fileNames.filter(
102
+ (f) => !f.includes('/node_modules/'),
103
+ );
104
+
100
105
  if (excludePatterns && excludePatterns.length > 0) {
101
106
  const regexPatterns = excludePatterns
102
107
  .map((pattern) => {
@@ -289,18 +289,44 @@ export default async function prepareEntityDataStructures(
289
289
  skipWorkerPool();
290
290
  }
291
291
 
292
+ awsLogDebugLevel(
293
+ 1,
294
+ `Preparing data structures for ${entities.length} entities (${entitiesNeedingGeneration} need generation)...`,
295
+ );
296
+ const startTime = Date.now();
297
+ let completedCount = 0;
298
+
299
+ // Wrap processEntity to track progress
300
+ const processEntityWithProgress = async (entity: Entity) => {
301
+ await processEntity(entity);
302
+ completedCount++;
303
+ // Emit progress every 10 entities
304
+ if (completedCount % 10 === 0) {
305
+ awsLogDebugLevel(
306
+ 1,
307
+ `Preparing data structures... (${completedCount}/${entities.length})`,
308
+ );
309
+ }
310
+ };
311
+
292
312
  const sequential =
293
313
  DEBUG_SEQUENTIAL_EXECUTION || options.sequentialDataStructurePrep;
294
314
 
295
315
  if (sequential) {
296
316
  // Sequential execution for debugging - process one entity at a time
297
317
  for (const entity of entities) {
298
- await processEntity(entity);
318
+ await processEntityWithProgress(entity);
299
319
  }
300
320
  } else {
301
321
  // Parallel execution for speed
302
- await Promise.all(entities.map(processEntity));
322
+ await Promise.all(entities.map(processEntityWithProgress));
303
323
  }
324
+
325
+ const elapsed = Date.now() - startTime;
326
+ awsLogDebugLevel(
327
+ 1,
328
+ `Data structure preparation complete: ${entities.length} entities in ${elapsed}ms`,
329
+ );
304
330
  }
305
331
 
306
332
  /**
@@ -8,13 +8,11 @@ import {
8
8
  import { transformationTracer } from '../scenarios/TransformationTracer';
9
9
  import { getFileByPathSafe } from '../../utils/getFileByPath';
10
10
  import trackEntityCircularDependencies from './trackEntityCircularDependencies';
11
- import validateDependencyAnalyses from './validateDependencyAnalyses';
12
11
  import extractClassMethods from './analyzeEntities/extractClassMethods';
13
12
  import prepareDataStructures from './analyzeEntities/prepareDataStructures';
14
13
  import { strategies, asyncComplex } from './analyzeEntities/strategies';
15
14
  import {
16
15
  updateCommitMetadata,
17
- updateFreshAnalysisMetadata,
18
16
  updateFreshAnalysisStatus,
19
17
  upsertAnalyses,
20
18
  upsertEntities,
@@ -263,40 +261,11 @@ export default async function analyzeEntities({
263
261
  }
264
262
  }
265
263
 
266
- awsLog(`CodeYam: analyzeEntities: Running patch-up dependency validation`);
267
- for (const analysis of analyses) {
268
- if (!analysis.entity) {
269
- throw new Error(
270
- `CodeYam: analyzeEntities: Internal error: Analysis entity is missing for ${analysis.filePath}:${analysis.entityName}.`,
271
- );
272
- }
273
-
274
- // Validate dependencies, which modifies analysis.metadata.dependentAnalyses
275
- validateDependencyAnalyses({ analysis, entity: analysis.entity, context });
276
-
277
- // Carefully update only the metadata field
278
- if (analysis.id) {
279
- const updatedMetadata = await updateFreshAnalysisMetadata(
280
- analysis.id,
281
- (metadata) => {
282
- metadata.dependentAnalyses =
283
- analysis.metadata?.dependentAnalyses || [];
284
- },
285
- );
286
-
287
- if (updatedMetadata) {
288
- analysis.metadata = updatedMetadata;
289
- } else {
290
- console.warn(
291
- `CodeYam: analyzeEntities: Failed to update metadata for analysis ${analysis.id}`,
292
- );
293
- }
294
- } else {
295
- console.warn(
296
- `CodeYam: analyzeEntities: Analysis ${analysis.filePath}:${analysis.entityName} has no ID, skipping metadata update`,
297
- );
298
- }
299
- }
264
+ // NOTE: patch-up dependency validation loop was removed here.
265
+ // analysis.metadata.dependentAnalyses is already populated by validateDependencyAnalyses
266
+ // inside analyzeEntity() (Call #1) and persisted via upsertAnalysesWithScenarios at the
267
+ // end of analyzeEntity, then again by upsertAnalyses in analyzeOneEntityKey. Re-validating
268
+ // every analysis from scratch was redundant work — especially costly for large projects.
300
269
 
301
270
  const newlyReady = await updateReadyAnalyses();
302
271
  if (newlyReady.length > 0) {