@codeyam/codeyam-cli 0.1.0-staging.323686 → 0.1.0-staging.4684848

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 (451) 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 +6 -6
  4. package/analyzer-template/packages/ai/index.ts +7 -1
  5. package/analyzer-template/packages/ai/package.json +2 -2
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +62 -18
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +67 -9
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +409 -50
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +21 -6
  12. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +992 -249
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +31 -3
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +37 -15
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -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 +179 -0
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +367 -96
  23. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +33 -15
  24. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  25. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +315 -6
  26. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +9 -5
  27. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +49 -5
  28. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  29. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +649 -142
  30. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +1 -1
  31. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  32. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  33. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  34. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  35. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  36. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  37. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +25 -13
  38. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +4 -3
  39. package/analyzer-template/packages/analyze/index.ts +2 -0
  40. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  41. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
  42. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  43. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  44. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  45. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  46. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  47. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  48. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +89 -9
  49. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +19 -4
  50. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  51. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +0 -3
  52. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  53. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  54. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
  55. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +61 -13
  56. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
  57. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +229 -19
  58. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +117 -9
  59. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +571 -74
  60. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  61. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  62. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  63. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  64. package/analyzer-template/packages/aws/package.json +1 -1
  65. package/analyzer-template/packages/database/package.json +1 -1
  66. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  67. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  68. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  69. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  70. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  71. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  72. package/analyzer-template/packages/database/src/lib/kysely/db.ts +6 -0
  73. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  74. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  75. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  76. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  77. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  78. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  88. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  90. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +3 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  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/projectToDb.js +1 -1
  101. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  104. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  106. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  107. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  108. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  109. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  110. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  111. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  112. package/analyzer-template/packages/github/package.json +1 -1
  113. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
  114. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +6 -5
  115. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  116. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  117. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  118. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  119. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  120. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  121. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  122. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  123. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +93 -2
  124. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  125. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +108 -2
  126. package/analyzer-template/project/constructMockCode.ts +90 -10
  127. package/analyzer-template/project/writeMockDataTsx.ts +181 -8
  128. package/analyzer-template/project/writeScenarioComponents.ts +60 -12
  129. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  130. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  131. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  132. package/background/src/lib/virtualized/project/constructMockCode.js +75 -4
  133. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  134. package/background/src/lib/virtualized/project/writeMockDataTsx.js +162 -4
  135. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  136. package/background/src/lib/virtualized/project/writeScenarioComponents.js +60 -15
  137. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  138. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  139. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  140. package/codeyam-cli/scripts/apply-setup.js +180 -0
  141. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  142. package/codeyam-cli/src/cli.js +2 -0
  143. package/codeyam-cli/src/cli.js.map +1 -1
  144. package/codeyam-cli/src/codeyam-cli.js +18 -2
  145. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  146. package/codeyam-cli/src/commands/analyze.js +4 -2
  147. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  148. package/codeyam-cli/src/commands/baseline.js +2 -0
  149. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  150. package/codeyam-cli/src/commands/debug.js +9 -5
  151. package/codeyam-cli/src/commands/debug.js.map +1 -1
  152. package/codeyam-cli/src/commands/default.js +31 -20
  153. package/codeyam-cli/src/commands/default.js.map +1 -1
  154. package/codeyam-cli/src/commands/detect-universal-mocks.js +2 -0
  155. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -1
  156. package/codeyam-cli/src/commands/init.js +49 -257
  157. package/codeyam-cli/src/commands/init.js.map +1 -1
  158. package/codeyam-cli/src/commands/memory.js +17 -26
  159. package/codeyam-cli/src/commands/memory.js.map +1 -1
  160. package/codeyam-cli/src/commands/recapture.js +2 -0
  161. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  162. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  163. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  164. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  165. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  166. package/codeyam-cli/src/commands/test-startup.js +2 -0
  167. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  168. package/codeyam-cli/src/commands/verify.js +14 -2
  169. package/codeyam-cli/src/commands/verify.js.map +1 -1
  170. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +128 -86
  171. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  172. package/codeyam-cli/src/utils/analyzer.js +7 -0
  173. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  174. package/codeyam-cli/src/utils/backgroundServer.js +9 -0
  175. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  176. package/codeyam-cli/src/utils/generateReport.js +2 -2
  177. package/codeyam-cli/src/utils/install-skills.js +70 -45
  178. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  179. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  180. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  181. package/codeyam-cli/src/utils/progress.js +7 -0
  182. package/codeyam-cli/src/utils/progress.js.map +1 -1
  183. package/codeyam-cli/src/utils/queue/job.js +4 -0
  184. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  185. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  186. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  187. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  188. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  189. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
  190. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  191. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  192. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  193. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  194. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  195. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  196. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  197. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  198. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  199. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
  200. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  201. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +378 -0
  202. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  203. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
  204. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  205. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  206. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  207. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  208. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  209. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  210. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  211. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  212. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  213. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  214. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  215. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  216. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  217. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  218. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  219. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  220. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  221. package/codeyam-cli/src/utils/rules/index.js +1 -0
  222. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  223. package/codeyam-cli/src/utils/rules/parser.js +2 -25
  224. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  225. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  226. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  227. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  228. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  229. package/codeyam-cli/src/utils/serverState.js +37 -10
  230. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  231. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +21 -44
  232. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  233. package/codeyam-cli/src/webserver/app/lib/database.js +15 -3
  234. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  235. package/codeyam-cli/src/webserver/backgroundServer.js +24 -0
  236. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  237. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CQ-wF3Tv.js +1 -0
  238. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-HdckCi0m.js} +1 -1
  239. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-Dh5RJMOE.js} +1 -1
  240. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-BnjjBHJu.js} +1 -1
  241. package/codeyam-cli/src/webserver/build/client/assets/{InlineSpinner-C8lyxW9k.js → InlineSpinner-CUSfu6W5.js} +1 -1
  242. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-Coll1aD6.js} +2 -2
  243. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-lYMY8h-y.js} +1 -1
  244. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-ay8XeA59.js} +1 -1
  245. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-Dpul1_ik.js} +1 -1
  246. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-CRBCfV2W.js} +3 -8
  247. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-DRTFDNFt.js} +1 -1
  248. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-d6PSFxhS.js} +2 -2
  249. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-DDEOQ6Iw.js} +1 -1
  250. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-CkziGg5F.js} +1 -1
  251. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-B2v1pm9w.js} +6 -11
  252. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-BXIaK8Md.js +11 -0
  253. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  254. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  255. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  256. package/codeyam-cli/src/webserver/build/client/assets/book-open-qbapxy6o.js +6 -0
  257. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C-mKrwr1.js} +1 -1
  258. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-BAvUl1nT.js} +12 -12
  259. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-DlrT-SzI.js} +1 -1
  260. package/codeyam-cli/src/webserver/build/client/assets/copy-clIxnCqQ.js +11 -0
  261. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-BdhJEx6B.js → createLucideIcon-B931Etud.js} +1 -1
  262. package/codeyam-cli/src/webserver/build/client/assets/{dev.empty-BBnGWYga.js → dev.empty-BoPM6KnE.js} +1 -1
  263. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-oVRMh9Hl.js +16 -0
  264. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js → entity._sha.scenarios._scenarioId.fullscreen-BjyzwQ7H.js} +1 -1
  265. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.create-scenario-D1T4TGjf.js → entity._sha_.create-scenario-DxuyDmZA.js} +1 -1
  266. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-DESSZGQp.js} +1 -1
  267. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-D5Yb90Ad.js} +1 -1
  268. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-DuObVYgh.js} +1 -1
  269. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-CDfz4Y-i.js} +1 -1
  270. package/codeyam-cli/src/webserver/build/client/assets/{git-CPTZZ-JZ.js → git-D6jOlDQw.js} +1 -1
  271. package/codeyam-cli/src/webserver/build/client/assets/globals-CKT08Djd.css +1 -0
  272. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-DvOt1KIt.js} +1 -1
  273. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-WfQFdoWK.js} +1 -1
  274. package/codeyam-cli/src/webserver/build/client/assets/labs-BbGyC1RY.js +1 -0
  275. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-Bb7Y9k5O.js} +1 -1
  276. package/codeyam-cli/src/webserver/build/client/assets/manifest-fd06e67a.js +1 -0
  277. package/codeyam-cli/src/webserver/build/client/assets/memory-BXebUPaL.js +78 -0
  278. package/codeyam-cli/src/webserver/build/client/assets/pause-DaAHX2on.js +11 -0
  279. package/codeyam-cli/src/webserver/build/client/assets/root-CvNE9MaT.js +62 -0
  280. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-DIqAPIrO.js} +1 -1
  281. package/codeyam-cli/src/webserver/build/client/assets/settings-DCIzBZM9.js +1 -0
  282. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-C6n_fNQY.js} +1 -1
  283. package/codeyam-cli/src/webserver/build/client/assets/terminal-CmPsszJy.js +11 -0
  284. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-Beg-oV50.js} +1 -1
  285. package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-C1v1PQzo.js → useCustomSizes-D7TLbP3M.js} +1 -1
  286. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-aSv48UbS.js → useLastLogLine-Ce5rnai3.js} +1 -1
  287. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-B4D3wj27.js} +1 -1
  288. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-BDt_-DnY.js} +1 -1
  289. package/codeyam-cli/src/webserver/build/server/assets/{index-DVzYx8PN.js → index-DDr9Cp9M.js} +1 -1
  290. package/codeyam-cli/src/webserver/build/server/assets/server-build-DjwiujaU.js +257 -0
  291. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  292. package/codeyam-cli/src/webserver/build-info.json +5 -5
  293. package/codeyam-cli/templates/{codeyam:debug.md → codeyam-debug.md} +1 -1
  294. package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
  295. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  296. package/codeyam-cli/templates/codeyam-memory.md +392 -0
  297. package/codeyam-cli/templates/codeyam-new-rule.md +13 -0
  298. package/codeyam-cli/templates/{codeyam:setup.md → codeyam-setup.md} +13 -1
  299. package/codeyam-cli/templates/{codeyam:sim.md → codeyam-sim.md} +1 -1
  300. package/codeyam-cli/templates/{codeyam:test.md → codeyam-test.md} +1 -1
  301. package/codeyam-cli/templates/{codeyam:verify.md → codeyam-verify.md} +1 -1
  302. package/codeyam-cli/templates/rule-notification-hook.py +56 -0
  303. package/codeyam-cli/templates/rule-reflection-hook.py +627 -0
  304. package/codeyam-cli/templates/rules-instructions.md +132 -0
  305. package/package.json +10 -10
  306. package/packages/ai/index.js +3 -2
  307. package/packages/ai/index.js.map +1 -1
  308. package/packages/ai/src/lib/analyzeScope.js +50 -13
  309. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  310. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +54 -8
  311. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  312. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  313. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  314. package/packages/ai/src/lib/astScopes/processExpression.js +317 -44
  315. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  316. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  317. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  318. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +763 -171
  319. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  320. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  321. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  322. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  323. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  324. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  325. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  326. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +33 -3
  327. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  328. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +36 -11
  329. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  330. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  331. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  332. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  333. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  334. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  335. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  336. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  337. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  338. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +309 -84
  339. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  340. package/packages/ai/src/lib/dataStructureChunking.js +26 -11
  341. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  342. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  343. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  344. package/packages/ai/src/lib/generateEntityScenarioData.js +227 -4
  345. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  346. package/packages/ai/src/lib/generateEntityScenarios.js +7 -1
  347. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  348. package/packages/ai/src/lib/generateExecutionFlows.js +26 -4
  349. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  350. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +447 -80
  351. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  352. package/packages/ai/src/lib/isolateScopes.js +39 -3
  353. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  354. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  355. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  356. package/packages/ai/src/lib/mergeStatements.js +70 -51
  357. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  358. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  359. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  360. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  361. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  362. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  363. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  364. package/packages/ai/src/lib/resolvePathToControllable.js +24 -14
  365. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  366. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  367. package/packages/analyze/index.js +1 -0
  368. package/packages/analyze/index.js.map +1 -1
  369. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  370. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  371. package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
  372. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  373. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  374. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  375. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  376. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  377. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  378. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  379. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  380. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  381. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  382. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  383. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  384. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  385. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +65 -7
  386. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  387. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +17 -4
  388. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  389. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  390. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  391. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +0 -3
  392. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  393. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  394. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  395. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  396. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  397. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
  398. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  399. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +56 -10
  400. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  401. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
  402. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  403. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +150 -17
  404. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  405. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +56 -8
  406. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  407. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +478 -54
  408. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  409. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  410. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  411. package/packages/analyze/src/lib/index.js +1 -0
  412. package/packages/analyze/src/lib/index.js.map +1 -1
  413. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  414. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  415. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  416. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  417. package/packages/database/src/lib/analysisToDb.js +1 -1
  418. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  419. package/packages/database/src/lib/branchToDb.js +1 -1
  420. package/packages/database/src/lib/branchToDb.js.map +1 -1
  421. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  422. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  423. package/packages/database/src/lib/commitToDb.js +1 -1
  424. package/packages/database/src/lib/commitToDb.js.map +1 -1
  425. package/packages/database/src/lib/fileToDb.js +1 -1
  426. package/packages/database/src/lib/fileToDb.js.map +1 -1
  427. package/packages/database/src/lib/kysely/db.js +3 -0
  428. package/packages/database/src/lib/kysely/db.js.map +1 -1
  429. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  430. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  431. package/packages/database/src/lib/projectToDb.js +1 -1
  432. package/packages/database/src/lib/projectToDb.js.map +1 -1
  433. package/packages/database/src/lib/saveFiles.js +1 -1
  434. package/packages/database/src/lib/saveFiles.js.map +1 -1
  435. package/packages/database/src/lib/scenarioToDb.js +1 -1
  436. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  437. package/packages/utils/src/lib/fs/rsyncCopy.js +93 -2
  438. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  439. package/scripts/finalize-analyzer.cjs +8 -76
  440. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  441. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-BJUiQqZF.js +0 -23
  442. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  443. package/codeyam-cli/src/webserver/build/client/assets/globals-D3yhhV8x.css +0 -1
  444. package/codeyam-cli/src/webserver/build/client/assets/manifest-7522edd4.js +0 -1
  445. package/codeyam-cli/src/webserver/build/client/assets/memory-yxFcrxBX.js +0 -92
  446. package/codeyam-cli/src/webserver/build/client/assets/root-eVAaavTS.js +0 -62
  447. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  448. package/codeyam-cli/src/webserver/build/server/assets/server-build-4Cr0uToj.js +0 -257
  449. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  450. package/codeyam-cli/templates/codeyam:memory.md +0 -462
  451. package/codeyam-cli/templates/codeyam:new-rule.md +0 -13
@@ -1,10 +1,10 @@
1
1
  {
2
- "buildTimestamp": "2026-01-30T00:55:52.181Z",
3
- "buildTime": 1769734552181,
4
- "gitCommit": "03236865a7602ab6d30df31e0ad3bee876906fb9",
2
+ "buildTimestamp": "2026-02-13T12:46:15.997Z",
3
+ "buildTime": 1770986775997,
4
+ "gitCommit": "4684848f0720e8d6673ec5479d17c6a1d40ce733",
5
5
  "nodeVersion": "v20.20.0",
6
- "contentHash": "05d53efd18fbc545b72ac5e31193346a32efa60861ecfb3bf24454bef6533f43",
7
- "buildNumber": 549,
8
- "semanticVersion": "0.1.549",
9
- "version": "0.1.549 (2026-01-30T00:55+05d53ef)"
6
+ "contentHash": "4e94e73e9be6ff27f80a8345110fe1d31d9863861a8966e4b17887ad7c6eff67",
7
+ "buildNumber": 619,
8
+ "semanticVersion": "0.1.619",
9
+ "version": "0.1.619 (2026-02-13T12:46+4e94e73)"
10
10
  }
@@ -1,7 +1,7 @@
1
1
 
2
- [1/30/2026, 12:55:52 AM] > codeyam-combo@1.0.0 mergeDependencies
3
- [1/30/2026, 12:55:52 AM] > node ./scripts/mergePackageJsonFiles.cjs
2
+ [2/13/2026, 12:46:15 PM] > codeyam-combo@1.0.0 mergeDependencies
3
+ [2/13/2026, 12:46:15 PM] > node ./scripts/mergePackageJsonFiles.cjs
4
4
 
5
5
 
6
- [1/30/2026, 12:55:52 AM] Merged dependencies into root package.json
6
+ [2/13/2026, 12:46:15 PM] Merged dependencies into root package.json
7
7
 
@@ -7,8 +7,8 @@
7
7
  "build": "tsc && node ./scripts/postbuild.cjs"
8
8
  },
9
9
  "dependencies": {
10
- "@aws-sdk/client-cloudwatch-logs": "^3.966.0",
11
- "@aws-sdk/client-cloudfront": "^3.966.0",
10
+ "@aws-sdk/client-cloudwatch-logs": "^3.980.0",
11
+ "@aws-sdk/client-cloudfront": "^3.985.0",
12
12
  "@aws-sdk/client-codebuild": "^3.948.0",
13
13
  "@aws-sdk/client-dynamodb": "^3.956.0",
14
14
  "@aws-sdk/client-ec2": "^3.899.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.4",
33
+ "lru-cache": "^11.2.5",
34
34
  "openai": "^6.16.0",
35
35
  "p-queue": "^8.1.0",
36
36
  "p-retry": "^7.1.1",
@@ -44,11 +44,11 @@
44
44
  "pluralize": "^8.0.0",
45
45
  "yargs": "^18.0.0",
46
46
  "json5": "^2.2.3",
47
- "@anthropic-ai/sdk": "^0.71.0",
47
+ "@anthropic-ai/sdk": "^0.74.0",
48
48
  "@aws-sdk/s3-request-presigner": "^3.940.0",
49
49
  "better-sqlite3": "^12.4.1",
50
50
  "fetch-retry": "^6.0.0",
51
- "kysely": "^0.28.5",
51
+ "kysely": "^0.28.11",
52
52
  "pg": "^8.16.3",
53
53
  "@octokit/request": "^10.0.3",
54
54
  "lucide-react": "^0.556.0",
@@ -64,7 +64,7 @@
64
64
  "@types/jest": "^30.0.0",
65
65
  "@types/pg": "^8.15.5",
66
66
  "@types/ws": "^8.18.1",
67
- "@octokit/types": "^15.0.0",
67
+ "@octokit/types": "^16.0.0",
68
68
  "@types/react": "^19.2.7",
69
69
  "@types/react-dom": "^19.2.3",
70
70
  "@types/react-resizable": "^3.0.7",
@@ -43,6 +43,7 @@ export { default as isolateScopes } from './src/lib/isolateScopes';
43
43
  export {
44
44
  default as analyzeScope,
45
45
  destroyWorkerPool,
46
+ skipWorkerPool,
46
47
  } from './src/lib/analyzeScope';
47
48
  export { default as logOrderedMap } from './src/lib/logOrderedMap';
48
49
  export {
@@ -57,8 +58,13 @@ export {
57
58
  removeDuplicateFunctionCalls,
58
59
  } from './src/lib/dataStructure/helpers/cleanNonObjectFunctions';
59
60
  export { default as convertDotNotation } from './src/lib/dataStructure/helpers/convertDotNotation';
61
+ export { default as convertTypeAnnotationsToValues } from './src/lib/dataStructure/helpers/convertTypeAnnotationsToValues';
60
62
  export { default as cleanOutBoundary } from './src/lib/cleanOutBoundary';
61
- export { fillInDirectSchemaGapsAndUnknowns } from './src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns';
63
+ export {
64
+ fillInDirectSchemaGapsAndUnknowns,
65
+ buildSchemaIndexes,
66
+ type SchemaIndexes,
67
+ } from './src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns';
62
68
  export { default as deduplicateFunctionSchemas } from './src/lib/dataStructure/helpers/deduplicateFunctionSchemas';
63
69
  export { default as getConditionalUsagesFromCode } from './src/lib/getConditionalUsagesFromCode';
64
70
  export type {
@@ -9,12 +9,12 @@
9
9
  "author": "",
10
10
  "license": "ISC",
11
11
  "dependencies": {
12
- "@anthropic-ai/sdk": "^0.71.0",
12
+ "@anthropic-ai/sdk": "^0.74.0",
13
13
  "jsdom": "^27.4.0",
14
14
  "p-queue": "^8.1.0",
15
15
  "p-retry": "^7.1.1",
16
16
  "piscina": "^5.1.4",
17
- "lru-cache": "^11.2.4"
17
+ "lru-cache": "^11.2.5"
18
18
  },
19
19
  "devDependencies": {
20
20
  "@types/jsdom": "^27.0.0"
@@ -50,6 +50,19 @@ let workerPool: Piscina<
50
50
  AnalyzeScopeWorkerOutput
51
51
  > | null = null;
52
52
  let workerPoolDestroyed = false;
53
+ let workerPoolSkipped = false;
54
+
55
+ /**
56
+ * Skip worker pool initialization for the current session.
57
+ *
58
+ * The worker thread creates its own ProjectAnalyzer (ts.Program), which takes
59
+ * 50-70s — far longer than the actual entity processing (<2s for typical batches).
60
+ * When the entity count is small, running analyzeScopeLocal on the main thread
61
+ * reuses the existing ProjectAnalyzer and avoids this overhead entirely.
62
+ */
63
+ export function skipWorkerPool() {
64
+ workerPoolSkipped = true;
65
+ }
53
66
 
54
67
  /**
55
68
  * Check if we're in Node.js main thread
@@ -108,6 +121,7 @@ function ensureWorkerPool() {
108
121
  'analyzeScope should not be called after data structure preparation completes.',
109
122
  );
110
123
  }
124
+ if (workerPoolSkipped) return;
111
125
  if (workerPool !== null) return;
112
126
 
113
127
  // Only initialize worker pool in Node.js environment
@@ -123,10 +137,17 @@ function ensureWorkerPool() {
123
137
  // Note: WORKER_PATH is null when __mocks__/analyzeScope.ts is active
124
138
  const { WORKER_PATH } = analyzeScopeWorkerPaths();
125
139
 
140
+ // Disable workers when tracing is enabled - we need access to ScopeDataStructure
141
+ // instance in the main thread to capture pre-serialization state
142
+ const tracingEnabled =
143
+ process.env.CODEYAM_TRACE_TRANSFORMS === '1' ||
144
+ process.env.CODEYAM_TRACE_TRANSFORMS === 'true';
145
+
126
146
  if (
127
147
  process.env.USE_WORKER_THREADS &&
128
148
  WORKER_PATH &&
129
- fs.existsSync(WORKER_PATH)
149
+ fs.existsSync(WORKER_PATH) &&
150
+ !tracingEnabled
130
151
  ) {
131
152
  console.log('CodeYam: Using worker threads for analyzeScope', {
132
153
  WORKER_PATH,
@@ -159,6 +180,7 @@ function ensureWorkerPool() {
159
180
  WORKER_PATH,
160
181
  workerExists: WORKER_PATH ? fs.existsSync(WORKER_PATH) : false,
161
182
  USE_WORKER_THREADS: process.env.USE_WORKER_THREADS,
183
+ tracingEnabled,
162
184
  });
163
185
  workerPool = null; // Explicitly set to indicate "no workers"
164
186
  }
@@ -372,7 +394,7 @@ export async function analyzeScopeLocal({
372
394
  }
373
395
 
374
396
  for (const mapping of [structure, equivalentVariables]) {
375
- for (let [key, value] of Object.entries(mapping)) {
397
+ for (let [key, rawValue] of Object.entries(mapping)) {
376
398
  for (const [childScopeId, childScope] of sortedEntries) {
377
399
  const scopeText = fileAnalyzer.sourceFile.text.slice(
378
400
  childScope.start,
@@ -392,27 +414,49 @@ export async function analyzeScopeLocal({
392
414
  return text;
393
415
  };
394
416
 
395
- if (value.includes(scopeText)) {
396
- // DEBUG: Log when replacement happens
397
- if (key.includes('Fetcher') || key.includes('fetcher')) {
398
- console.log(
399
- 'CodeYam DEBUG value replacement:',
400
- JSON.stringify({
401
- key,
402
- oldValue: value,
403
- childScopeId,
404
- scopeTextPreview: scopeText.slice(0, 50),
405
- }),
406
- );
417
+ // Handle both string and string[] values (for OR expressions)
418
+ const processValue = (value: string): string => {
419
+ if (value.includes(scopeText)) {
420
+ // DEBUG: Log when replacement happens
421
+ if (key.includes('Fetcher') || key.includes('fetcher')) {
422
+ console.log(
423
+ 'CodeYam DEBUG value replacement:',
424
+ JSON.stringify({
425
+ key,
426
+ oldValue: value,
427
+ childScopeId,
428
+ scopeTextPreview: scopeText.slice(0, 50),
429
+ }),
430
+ );
431
+ }
432
+ return replaceChildScopeId(value);
433
+ }
434
+ return value;
435
+ };
436
+
437
+ if (Array.isArray(rawValue)) {
438
+ const newValues = rawValue.map(processValue);
439
+ (mapping as Record<string, string | string[]>)[key] =
440
+ newValues;
441
+ rawValue = newValues;
442
+ } else if (typeof rawValue === 'string') {
443
+ const newValue = processValue(rawValue);
444
+ if (newValue !== rawValue) {
445
+ (mapping as Record<string, string | string[]>)[key] =
446
+ newValue;
447
+ rawValue = newValue;
407
448
  }
408
- value = replaceChildScopeId(value);
409
- mapping[key] = value;
410
449
  }
450
+
411
451
  if (key.includes(scopeText)) {
412
452
  const oldKey = key;
413
453
  key = replaceChildScopeId(key);
414
- mapping[key] = mapping[oldKey];
415
- delete mapping[oldKey];
454
+ (mapping as Record<string, string | string[]>)[key] = (
455
+ mapping as Record<string, string | string[]>
456
+ )[oldKey];
457
+ delete (mapping as Record<string, string | string[]>)[
458
+ oldKey
459
+ ];
416
460
  }
417
461
  }
418
462
  }
@@ -102,7 +102,7 @@ import { ThrowStatementHandler } from './patterns/throwStatementHandler';
102
102
  */
103
103
  export class ASTScopeAnalyzer {
104
104
  private structure: Record<string, string> = {};
105
- private equivalentVariables: Record<string, string> = {};
105
+ private equivalentVariables: Record<string, string | string[]> = {};
106
106
  private environmentVariables: string[] = [];
107
107
  private conditionalUsages: Record<string, ConditionalUsage[]> = {};
108
108
  private compoundConditionals: CompoundConditional[] = [];
@@ -235,6 +235,8 @@ export class ASTScopeAnalyzer {
235
235
  typeChecker: this.fileAnalyzer.typeChecker,
236
236
  addEquivalence: (leftSide, rightSide) =>
237
237
  this.addEquivalence(leftSide, rightSide),
238
+ addMultipleEquivalencies: (leftSide, rightSides) =>
239
+ this.addMultipleEquivalencies(leftSide, rightSides),
238
240
  addType: (path, type) => this.addType(path, type),
239
241
  addEnvironmentVariable: (variablePath) =>
240
242
  this.addEnvironmentVariable(variablePath),
@@ -592,7 +594,9 @@ export class ASTScopeAnalyzer {
592
594
  }
593
595
 
594
596
  /**
595
- * Adds an equivalence relationship between two variable paths
597
+ * Adds an equivalence relationship between two variable paths.
598
+ * Uses overwrite semantics - if an equivalence already exists, the new value replaces it
599
+ * (unless the new value is 'undefined' or 'null').
596
600
  */
597
601
  private addEquivalence(
598
602
  leftSide: StructuredPath,
@@ -622,6 +626,44 @@ export class ASTScopeAnalyzer {
622
626
  }
623
627
  }
624
628
 
629
+ /**
630
+ * Adds multiple equivalence relationships for a single variable path.
631
+ * Used for OR expressions like `x = a || b` where x is equivalent to both a and b.
632
+ * The values are stored as an array to track all possible sources.
633
+ */
634
+ private addMultipleEquivalencies(
635
+ leftSide: StructuredPath,
636
+ rightSides: StructuredPath[],
637
+ ): void {
638
+ if (leftSide?.isLiteral()) {
639
+ return;
640
+ }
641
+
642
+ const leftSideStr = leftSide?.toLeftHandSideString();
643
+ if (!leftSideStr) return;
644
+
645
+ // Filter out invalid paths and convert to strings
646
+ const validRightSides = rightSides
647
+ .map((r) => r?.toRightHandSideString())
648
+ .filter((r): r is string => !!r && r !== leftSideStr);
649
+
650
+ // Remove duplicates while preserving order
651
+ const uniqueRightSides = [...new Set(validRightSides)];
652
+
653
+ // Filter out 'undefined' and 'null' unless they're the only values
654
+ const meaningfulValues = uniqueRightSides.filter(
655
+ (v) => v !== 'undefined' && v !== 'null',
656
+ );
657
+ const finalValues =
658
+ meaningfulValues.length > 0 ? meaningfulValues : uniqueRightSides;
659
+
660
+ if (finalValues.length === 0) return;
661
+
662
+ // Store as single value if only one, otherwise as array
663
+ this.equivalentVariables[leftSideStr] =
664
+ finalValues.length === 1 ? finalValues[0] : finalValues;
665
+ }
666
+
625
667
  /**
626
668
  * Adds a type for a variable path
627
669
  */
@@ -785,22 +827,38 @@ export class ASTScopeAnalyzer {
785
827
  // Update the type for the given path
786
828
  this.structure[pathStr] = newType;
787
829
 
788
- // Also update the type for any equivalent path
830
+ // Also update the type for any equivalent path(s)
789
831
  // e.g., if "state" -> "signature[0]", update "signature[0]" as well
790
- const equivalentPath = this.equivalentVariables[pathStr];
791
- if (equivalentPath) {
792
- this.structure[equivalentPath] = newType;
832
+ const rawEquivalentPath = this.equivalentVariables[pathStr];
833
+ const equivalentPaths = Array.isArray(rawEquivalentPath)
834
+ ? rawEquivalentPath
835
+ : rawEquivalentPath
836
+ ? [rawEquivalentPath]
837
+ : [];
838
+ for (const equivalentPath of equivalentPaths) {
839
+ if (typeof equivalentPath === 'string') {
840
+ this.structure[equivalentPath] = newType;
841
+ }
793
842
  }
794
843
 
795
844
  // For property paths like "data.status", check if the base has an equivalence
796
845
  // e.g., if "data" -> "signature[0]", transform "data.status" to "signature[0].status"
797
- for (const [varPath, equivalence] of Object.entries(
846
+ for (const [varPath, rawEquivalence] of Object.entries(
798
847
  this.equivalentVariables,
799
848
  )) {
800
849
  if (pathStr.startsWith(varPath + '.')) {
850
+ const equivalences = Array.isArray(rawEquivalence)
851
+ ? rawEquivalence
852
+ : rawEquivalence
853
+ ? [rawEquivalence]
854
+ : [];
801
855
  const suffix = pathStr.slice(varPath.length);
802
- const transformedPath = equivalence + suffix;
803
- this.structure[transformedPath] = newType;
856
+ for (const equivalence of equivalences) {
857
+ if (typeof equivalence === 'string') {
858
+ const transformedPath = equivalence + suffix;
859
+ this.structure[transformedPath] = newType;
860
+ }
861
+ }
804
862
  }
805
863
  }
806
864
  }
@@ -22,11 +22,8 @@ export class ForInStatementHandler implements PatternHandler {
22
22
  // Process the expression being iterated over first (e.g., object)
23
23
  context.processExpression(node.expression);
24
24
 
25
- // Get the path of the object being iterated
26
- const expressionPath = context.getStructuralPath(node.expression);
27
-
28
- // If the initializer is a variable declaration with an identifier, establish equivalence
29
- // to indicate it's iterating over the keys of the expression
25
+ // If the initializer is a variable declaration with an identifier,
26
+ // type it as 'string' since for-in keys are always strings
30
27
  if (ts.isVariableDeclarationList(node.initializer)) {
31
28
  const declarations = node.initializer.declarations;
32
29
  if (
@@ -36,25 +33,21 @@ export class ForInStatementHandler implements PatternHandler {
36
33
  ) {
37
34
  const variableName = StructuredPath.fromBase(declarations[0].name.text);
38
35
 
39
- // Add type for the key variable (string for object keys)
36
+ // Type the key variable as 'string' for-in keys are always strings.
37
+ // Note: We intentionally do NOT equivalence the key variable to
38
+ // expressionPath[*key*]. The key variable is the KEY (a string),
39
+ // while [*key*] in the schema represents the VALUE at a dynamic key.
40
+ // Creating that equivalence would cause the 'string' type to propagate
41
+ // to the value path. The value access (e.g., obj[key]) is handled
42
+ // correctly by the element access handler in processExpression.
40
43
  context.addType(variableName, 'string');
41
-
42
- if (expressionPath) {
43
- // For for...in loops, the variable is equivalent to the keys of the object
44
- // We represent this with a *key* suffix to indicate it's a key, not a value
45
- context.addEquivalence(variableName, expressionPath.withKey('key'));
46
- }
47
44
  }
48
45
  } else if (ts.isIdentifier(node.initializer)) {
49
46
  // If the initializer is directly an identifier (rare but possible)
50
47
  const variableName = StructuredPath.fromBase(node.initializer.text);
51
48
 
52
- // Add type for the key variable
49
+ // See comment above — type as string but don't equivalence to value path
53
50
  context.addType(variableName, 'string');
54
-
55
- if (expressionPath) {
56
- context.addEquivalence(variableName, expressionPath.withKey('key'));
57
- }
58
51
  } else {
59
52
  context.processExpression(node.initializer);
60
53
  }