@codeyam/codeyam-cli 0.1.0-staging.1669d45 → 0.1.0-staging.2a88920

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 (437) 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 +5 -5
  4. package/analyzer-template/packages/ai/index.ts +15 -2
  5. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +87 -51
  6. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +98 -9
  8. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +139 -23
  9. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +6 -126
  10. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +555 -28
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +88 -7
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +198 -34
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +772 -243
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +43 -1
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +122 -15
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +160 -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 +319 -88
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  24. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +156 -0
  25. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  26. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  27. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +642 -7
  28. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +35 -6
  29. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +383 -6
  30. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  31. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +1299 -51
  32. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  33. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  34. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  35. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  36. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  37. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +23 -6
  38. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  39. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +179 -45
  40. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +26 -4
  41. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  42. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  43. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
  44. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  45. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  46. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  47. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  48. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  49. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  50. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  51. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +30 -19
  52. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +14 -4
  53. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -0
  54. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  55. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  56. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  57. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  58. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +189 -76
  59. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +29 -0
  60. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +77 -9
  61. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +118 -10
  62. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +276 -17
  63. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  64. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  65. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  66. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  67. package/analyzer-template/packages/aws/package.json +2 -2
  68. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -1
  69. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  70. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  71. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  72. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  73. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  74. package/analyzer-template/packages/database/src/lib/loadCommits.ts +28 -0
  75. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
  76. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  77. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +7 -14
  78. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  83. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  85. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  87. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  88. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  89. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  90. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  92. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  93. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  94. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  95. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  96. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  98. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  99. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  100. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +22 -1
  101. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  108. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  110. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +5 -4
  112. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  113. package/analyzer-template/packages/github/dist/types/index.d.ts +1 -1
  114. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  116. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +25 -1
  117. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  119. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  120. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +56 -6
  121. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  122. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  123. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  125. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  126. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  127. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  128. package/analyzer-template/packages/github/package.json +1 -1
  129. package/analyzer-template/packages/types/index.ts +1 -0
  130. package/analyzer-template/packages/types/src/types/Analysis.ts +25 -0
  131. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  132. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +70 -6
  133. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  134. package/analyzer-template/packages/utils/dist/types/index.d.ts +1 -1
  135. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  136. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  137. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +25 -1
  138. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  139. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  140. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  141. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +56 -6
  142. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  143. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  144. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  145. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  146. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  147. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  148. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  149. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  150. package/analyzer-template/playwright/capture.ts +20 -8
  151. package/analyzer-template/playwright/captureStatic.ts +1 -1
  152. package/analyzer-template/project/analyzeBaselineCommit.ts +5 -0
  153. package/analyzer-template/project/analyzeRegularCommit.ts +5 -0
  154. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  155. package/analyzer-template/project/constructMockCode.ts +367 -37
  156. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  157. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  158. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  159. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  160. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  161. package/analyzer-template/project/orchestrateCapture.ts +71 -6
  162. package/analyzer-template/project/reconcileMockDataKeys.ts +152 -9
  163. package/analyzer-template/project/runAnalysis.ts +4 -0
  164. package/analyzer-template/project/start.ts +35 -11
  165. package/analyzer-template/project/writeMockDataTsx.ts +127 -4
  166. package/analyzer-template/project/writeScenarioComponents.ts +101 -8
  167. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  168. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +5 -0
  169. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  170. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +5 -0
  171. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  172. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  173. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  174. package/background/src/lib/virtualized/project/constructMockCode.js +300 -7
  175. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  176. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  177. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  178. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  179. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  180. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  181. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  182. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  183. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  184. package/background/src/lib/virtualized/project/orchestrateCapture.js +58 -6
  185. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  186. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +126 -9
  187. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  188. package/background/src/lib/virtualized/project/runAnalysis.js +3 -0
  189. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  190. package/background/src/lib/virtualized/project/start.js +32 -11
  191. package/background/src/lib/virtualized/project/start.js.map +1 -1
  192. package/background/src/lib/virtualized/project/writeMockDataTsx.js +101 -4
  193. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  194. package/background/src/lib/virtualized/project/writeScenarioComponents.js +57 -8
  195. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  196. package/codeyam-cli/src/cli.js +2 -0
  197. package/codeyam-cli/src/cli.js.map +1 -1
  198. package/codeyam-cli/src/commands/debug.js +7 -5
  199. package/codeyam-cli/src/commands/debug.js.map +1 -1
  200. package/codeyam-cli/src/commands/memory.js +273 -0
  201. package/codeyam-cli/src/commands/memory.js.map +1 -0
  202. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +4 -0
  203. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  204. package/codeyam-cli/src/utils/analysisRunner.js +21 -2
  205. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  206. package/codeyam-cli/src/utils/install-skills.js +42 -6
  207. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  208. package/codeyam-cli/src/utils/queue/job.js +1 -0
  209. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  210. package/codeyam-cli/src/utils/queue/manager.js +6 -0
  211. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  212. package/codeyam-cli/src/utils/rules/index.js +5 -0
  213. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  214. package/codeyam-cli/src/utils/rules/parser.js +106 -0
  215. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  216. package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
  217. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  218. package/codeyam-cli/src/utils/rules/staleness.js +132 -0
  219. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  220. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +2 -0
  221. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  222. package/codeyam-cli/src/webserver/app/lib/database.js +7 -3
  223. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  224. package/codeyam-cli/src/webserver/bootstrap.js +40 -0
  225. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  226. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-DsN1wKrm.js +11 -0
  227. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-COi5OvsN.js → EntityTypeBadge-DLqD3qNt.js} +1 -1
  228. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BwdQv49w.js → EntityTypeIcon-Ba2JVPzP.js} +1 -1
  229. package/codeyam-cli/src/webserver/build/client/assets/{InlineSpinner-CEleMv_j.js → InlineSpinner-C8lyxW9k.js} +1 -1
  230. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-D68KarMg.js → InteractivePreview-aht4aafF.js} +2 -2
  231. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-L75Wvqgw.js → LibraryFunctionPreview-CVtiBnY5.js} +1 -1
  232. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-C53WM8qn.js → LoadingDots-B0GLXMsr.js} +1 -1
  233. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CrNkmy4i.js → LogViewer-xgeCVgSM.js} +1 -1
  234. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-OApQuNyq.js +16 -0
  235. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CQifa1n-.js → SafeScreenshot-DuDvi0jm.js} +1 -1
  236. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-CyaBFX7l.js → ScenarioViewer-DzccYyI8.js} +3 -13
  237. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-D36O1rzU.js → TruncatedFilePath-DyFZkK0l.js} +1 -1
  238. package/codeyam-cli/src/webserver/build/client/assets/_index-BwqWJOgH.js +11 -0
  239. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BwavGCpm.js +32 -0
  240. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  241. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  242. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  243. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-DgTPh8H-.js → chevron-down-Cx24_aWc.js} +1 -1
  244. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-DdQKK6on.js → chunk-EPOLDU6W-CXRTFQ3F.js} +1 -1
  245. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-Dmr2bb1R.js → circle-check-BOARzkeR.js} +1 -1
  246. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +6 -0
  247. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-Do4ZLUYa.js → createLucideIcon-BdhJEx6B.js} +1 -1
  248. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +1 -0
  249. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CbdFyxZh.js → entity._sha._-BJUiQqZF.js} +12 -12
  250. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha.scenarios._scenarioId.fullscreen-B4iCfs5M.js → entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js} +1 -1
  251. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.create-scenario-wDWZZO1W.js → entity._sha_.create-scenario-D1T4TGjf.js} +1 -1
  252. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMbl7MeQ.js → entity._sha_.edit._scenarioId-CTBG2mmz.js} +1 -1
  253. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-5wRKRIH9.js → entry.client-CS2cb_eZ.js} +1 -1
  254. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +6 -0
  255. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DD3SDH7t.js → fileTableUtils-DMJ7zii9.js} +1 -1
  256. package/codeyam-cli/src/webserver/build/client/assets/files-CJ6lTdTA.js +1 -0
  257. package/codeyam-cli/src/webserver/build/client/assets/{git-zXjT7J0G.js → git-CPTZZ-JZ.js} +8 -8
  258. package/codeyam-cli/src/webserver/build/client/assets/globals-D3yhhV8x.css +1 -0
  259. package/codeyam-cli/src/webserver/build/client/assets/{index-DLbXwndH.js → index-B1h680n5.js} +1 -1
  260. package/codeyam-cli/src/webserver/build/client/assets/{index-gPZ-lad1.js → index-lzqtyFU8.js} +1 -1
  261. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BsPXJ81F.js → loader-circle-B7B9V-bu.js} +1 -1
  262. package/codeyam-cli/src/webserver/build/client/assets/manifest-a78b90a2.js +1 -0
  263. package/codeyam-cli/src/webserver/build/client/assets/memory--GCbFsBE.js +92 -0
  264. package/codeyam-cli/src/webserver/build/client/assets/root-eVAaavTS.js +62 -0
  265. package/codeyam-cli/src/webserver/build/client/assets/{search-P2FKIUql.js → search-CxXUmBSd.js} +1 -1
  266. package/codeyam-cli/src/webserver/build/client/assets/{settings-B2eDuBj8.js → settings-CS5f3WzT.js} +1 -1
  267. package/codeyam-cli/src/webserver/build/client/assets/{simulations-L18M6-kN.js → simulations-DwFIBT09.js} +1 -1
  268. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BDz7kbVA.js → triangle-alert-B6LgvRJg.js} +1 -1
  269. package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-29dDmbH8.js → useCustomSizes-C1v1PQzo.js} +1 -1
  270. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-BUm0UVJm.js → useLastLogLine-aSv48UbS.js} +1 -1
  271. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-CkIOKTrZ.js → useReportContext-DYxHZQuP.js} +1 -1
  272. package/codeyam-cli/src/webserver/build/client/assets/{useToast-KKw5kTn-.js → useToast-mBRpZPiu.js} +1 -1
  273. package/codeyam-cli/src/webserver/build/server/assets/index-BM6TDT1Y.js +1 -0
  274. package/codeyam-cli/src/webserver/build/server/assets/server-build-dYC34MHw.js +257 -0
  275. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  276. package/codeyam-cli/src/webserver/build-info.json +5 -5
  277. package/codeyam-cli/templates/codeyam-memory-hook.sh +200 -0
  278. package/codeyam-cli/templates/codeyam:debug.md +47 -3
  279. package/codeyam-cli/templates/codeyam:diagnose.md +203 -25
  280. package/codeyam-cli/templates/codeyam:memory.md +341 -0
  281. package/codeyam-cli/templates/codeyam:new-rule.md +13 -0
  282. package/codeyam-cli/templates/rule-reflection-hook.py +160 -0
  283. package/codeyam-cli/templates/rules-instructions.md +93 -0
  284. package/package.json +8 -5
  285. package/packages/ai/index.js +7 -3
  286. package/packages/ai/index.js.map +1 -1
  287. package/packages/ai/src/lib/analyzeScope.js +70 -29
  288. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  289. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  290. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  291. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +78 -8
  292. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  293. package/packages/ai/src/lib/astScopes/methodSemantics.js +109 -23
  294. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  295. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +1 -102
  296. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  297. package/packages/ai/src/lib/astScopes/processExpression.js +440 -27
  298. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  299. package/packages/ai/src/lib/completionCall.js +161 -30
  300. package/packages/ai/src/lib/completionCall.js.map +1 -1
  301. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +589 -166
  302. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  303. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
  304. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  305. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
  306. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  307. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  308. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  309. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  310. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  311. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +41 -1
  312. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  313. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +104 -11
  314. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  315. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +159 -0
  316. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  317. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  318. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  319. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +265 -79
  320. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  321. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  322. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  323. package/packages/ai/src/lib/dataStructureChunking.js +111 -0
  324. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  325. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  326. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  327. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  328. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  329. package/packages/ai/src/lib/generateEntityScenarioData.js +525 -8
  330. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  331. package/packages/ai/src/lib/generateEntityScenarios.js +26 -2
  332. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  333. package/packages/ai/src/lib/generateExecutionFlows.js +281 -4
  334. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  335. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +946 -42
  336. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  337. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  338. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  339. package/packages/ai/src/lib/mergeStatements.js +70 -51
  340. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  341. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  342. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  343. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  344. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  345. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +15 -7
  346. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  347. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  348. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  349. package/packages/ai/src/lib/resolvePathToControllable.js +155 -41
  350. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  351. package/packages/ai/src/lib/worker/SerializableDataStructure.js +7 -0
  352. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  353. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  354. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  355. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  356. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  357. package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
  358. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  359. package/packages/analyze/src/lib/analysisContext.js +30 -5
  360. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  361. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  362. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  363. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  364. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  365. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  366. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  367. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  368. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  369. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  370. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  371. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  372. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  373. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +21 -9
  374. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  375. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +14 -4
  376. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  377. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +5 -0
  378. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  379. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  380. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  381. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  382. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  383. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  384. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  385. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  386. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  387. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +160 -68
  388. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  389. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +25 -8
  390. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  391. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +71 -9
  392. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  393. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +57 -9
  394. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  395. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +233 -9
  396. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  397. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  398. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  399. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  400. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  401. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  402. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  403. package/packages/database/src/lib/kysely/db.js +8 -1
  404. package/packages/database/src/lib/kysely/db.js.map +1 -1
  405. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  406. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  407. package/packages/database/src/lib/loadAnalyses.js +45 -2
  408. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  409. package/packages/database/src/lib/loadAnalysis.js +8 -0
  410. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  411. package/packages/database/src/lib/loadBranch.js +11 -1
  412. package/packages/database/src/lib/loadBranch.js.map +1 -1
  413. package/packages/database/src/lib/loadCommit.js +7 -0
  414. package/packages/database/src/lib/loadCommit.js.map +1 -1
  415. package/packages/database/src/lib/loadCommits.js +22 -1
  416. package/packages/database/src/lib/loadCommits.js.map +1 -1
  417. package/packages/database/src/lib/loadEntities.js +23 -4
  418. package/packages/database/src/lib/loadEntities.js.map +1 -1
  419. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  420. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  421. package/packages/database/src/lib/updateCommitMetadata.js +5 -4
  422. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  423. package/packages/types/index.js.map +1 -1
  424. package/packages/utils/src/lib/safeFileName.js +29 -3
  425. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  426. package/scripts/finalize-analyzer.cjs +3 -3
  427. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-vauWK972.js +0 -1
  428. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DzJRkCkr.js +0 -11
  429. package/codeyam-cli/src/webserver/build/client/assets/_index-Be83mo_j.js +0 -11
  430. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BN6wu6Y-.js +0 -37
  431. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Bn6aCAy_.js +0 -1
  432. package/codeyam-cli/src/webserver/build/client/assets/files-DKyMFI90.js +0 -1
  433. package/codeyam-cli/src/webserver/build/client/assets/globals-DTTQ3gY7.css +0 -1
  434. package/codeyam-cli/src/webserver/build/client/assets/manifest-22590fcf.js +0 -1
  435. package/codeyam-cli/src/webserver/build/client/assets/root-BsAarjAM.js +0 -57
  436. package/codeyam-cli/src/webserver/build/server/assets/index-BND5I5fv.js +0 -1
  437. package/codeyam-cli/src/webserver/build/server/assets/server-build-CFXnd7MG.js +0 -228
@@ -102,13 +102,14 @@ 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[] = [];
109
109
  private conditionalEffects: import('./types').ConditionalEffect[] = [];
110
110
  private childBoundaryGatingConditions: Record<string, ConditionalUsage[]> =
111
111
  {};
112
+ private jsxRenderingUsages: import('./types').JsxRenderingUsage[] = [];
112
113
  /**
113
114
  * Tracks derived boolean variables and their source expressions.
114
115
  * Maps variable name to derivation info.
@@ -219,6 +220,7 @@ export class ASTScopeAnalyzer {
219
220
  conditionalEffects: this.conditionalEffects,
220
221
  derivedVariables: this.derivedVariables,
221
222
  childBoundaryGatingConditions: this.childBoundaryGatingConditions,
223
+ jsxRenderingUsages: this.jsxRenderingUsages,
222
224
  isComplete:
223
225
  completeness.equivalences === 'full' &&
224
226
  completeness.structures === 'full',
@@ -233,6 +235,8 @@ export class ASTScopeAnalyzer {
233
235
  typeChecker: this.fileAnalyzer.typeChecker,
234
236
  addEquivalence: (leftSide, rightSide) =>
235
237
  this.addEquivalence(leftSide, rightSide),
238
+ addMultipleEquivalencies: (leftSide, rightSides) =>
239
+ this.addMultipleEquivalencies(leftSide, rightSides),
236
240
  addType: (path, type) => this.addType(path, type),
237
241
  addEnvironmentVariable: (variablePath) =>
238
242
  this.addEnvironmentVariable(variablePath),
@@ -273,6 +277,8 @@ export class ASTScopeAnalyzer {
273
277
  updateSchemaType: (path, newType) => this.updateSchemaType(path, newType),
274
278
  addConditionalEffect: (effect) => this.addConditionalEffect(effect),
275
279
  getConditionalEffects: () => this.conditionalEffects,
280
+ addJsxRenderingUsage: (usage) => this.addJsxRenderingUsage(usage),
281
+ getJsxRenderingUsages: () => this.jsxRenderingUsages,
276
282
  };
277
283
  return context;
278
284
  }
@@ -588,7 +594,9 @@ export class ASTScopeAnalyzer {
588
594
  }
589
595
 
590
596
  /**
591
- * 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').
592
600
  */
593
601
  private addEquivalence(
594
602
  leftSide: StructuredPath,
@@ -603,10 +611,59 @@ export class ASTScopeAnalyzer {
603
611
  const rightSideStr = rightSide?.toRightHandSideString();
604
612
 
605
613
  if (leftSideStr && rightSideStr && leftSideStr !== rightSideStr) {
614
+ const existingValue = this.equivalentVariables[leftSideStr];
615
+ // Don't overwrite a meaningful value with 'undefined' or 'null'.
616
+ // This is critical for ternary conditionals like `const x = cond ? func() : undefined`
617
+ // or `const x = items.find(...) || null` where we want to preserve
618
+ // the equivalency to the more meaningful value (func()'s return value, items[]).
619
+ if (
620
+ existingValue &&
621
+ (rightSideStr === 'undefined' || rightSideStr === 'null')
622
+ ) {
623
+ return;
624
+ }
606
625
  this.equivalentVariables[leftSideStr] = rightSideStr;
607
626
  }
608
627
  }
609
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
+
610
667
  /**
611
668
  * Adds a type for a variable path
612
669
  */
@@ -734,6 +791,22 @@ export class ASTScopeAnalyzer {
734
791
  this.conditionalEffects.push(effect);
735
792
  }
736
793
 
794
+ /**
795
+ * Add a JSX rendering usage (array.map() or text interpolation)
796
+ * Deduplicates by path and rendering type
797
+ */
798
+ private addJsxRenderingUsage(
799
+ usage: import('./types').JsxRenderingUsage,
800
+ ): void {
801
+ // Deduplicate: don't add if we already have the same path + renderingType
802
+ const exists = this.jsxRenderingUsages.some(
803
+ (u) => u.path === usage.path && u.renderingType === usage.renderingType,
804
+ );
805
+ if (!exists) {
806
+ this.jsxRenderingUsages.push(usage);
807
+ }
808
+ }
809
+
737
810
  /**
738
811
  * Updates the schema type for a path, typically used when switch statements
739
812
  * reveal the valid values for a parameter (creating a union type like "'a' | 'b' | 'c'")
@@ -754,22 +827,38 @@ export class ASTScopeAnalyzer {
754
827
  // Update the type for the given path
755
828
  this.structure[pathStr] = newType;
756
829
 
757
- // Also update the type for any equivalent path
830
+ // Also update the type for any equivalent path(s)
758
831
  // e.g., if "state" -> "signature[0]", update "signature[0]" as well
759
- const equivalentPath = this.equivalentVariables[pathStr];
760
- if (equivalentPath) {
761
- 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
+ }
762
842
  }
763
843
 
764
844
  // For property paths like "data.status", check if the base has an equivalence
765
845
  // e.g., if "data" -> "signature[0]", transform "data.status" to "signature[0].status"
766
- for (const [varPath, equivalence] of Object.entries(
846
+ for (const [varPath, rawEquivalence] of Object.entries(
767
847
  this.equivalentVariables,
768
848
  )) {
769
849
  if (pathStr.startsWith(varPath + '.')) {
850
+ const equivalences = Array.isArray(rawEquivalence)
851
+ ? rawEquivalence
852
+ : rawEquivalence
853
+ ? [rawEquivalence]
854
+ : [];
770
855
  const suffix = pathStr.slice(varPath.length);
771
- const transformedPath = equivalence + suffix;
772
- 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
+ }
773
862
  }
774
863
  }
775
864
  }
@@ -139,6 +139,96 @@ export class ArrayFilterSemantics implements MethodSemantics {
139
139
  }
140
140
  }
141
141
 
142
+ /**
143
+ * Array some method semantics
144
+ *
145
+ * some() returns true if at least one element passes the test, false otherwise
146
+ * The callback receives array elements to test
147
+ */
148
+ export class ArraySomeSemantics implements MethodSemantics {
149
+ getReturnType(): string {
150
+ return 'boolean';
151
+ }
152
+
153
+ addEquivalences(
154
+ methodCallPath: StructuredPath,
155
+ sourcePath: StructuredPath,
156
+ context: AnalysisContext,
157
+ ): void {
158
+ // Mark source as array
159
+ context.addType(sourcePath, 'array');
160
+
161
+ // Mark return as boolean
162
+ context.addType(methodCallPath, 'boolean');
163
+
164
+ // Get the last function call segment to access the arguments
165
+ const lastFunctionCallSegment = methodCallPath.getLastFunctionCallSegment();
166
+
167
+ if (lastFunctionCallSegment && lastFunctionCallSegment.args.length > 0) {
168
+ // The first argument is the callback
169
+ const callbackPath = lastFunctionCallSegment.args[0];
170
+
171
+ // Add the callback to the structure
172
+ context.addType(callbackPath, 'function');
173
+
174
+ // Mark that the callback's first parameter receives array elements
175
+ context.addEquivalence(
176
+ callbackPath.withParameter(0),
177
+ sourcePath.withElement('*'),
178
+ );
179
+ }
180
+ }
181
+
182
+ isComplete(): boolean {
183
+ return true;
184
+ }
185
+ }
186
+
187
+ /**
188
+ * Array every method semantics
189
+ *
190
+ * every() returns true if all elements pass the test, false otherwise
191
+ * The callback receives array elements to test
192
+ */
193
+ export class ArrayEverySemantics implements MethodSemantics {
194
+ getReturnType(): string {
195
+ return 'boolean';
196
+ }
197
+
198
+ addEquivalences(
199
+ methodCallPath: StructuredPath,
200
+ sourcePath: StructuredPath,
201
+ context: AnalysisContext,
202
+ ): void {
203
+ // Mark source as array
204
+ context.addType(sourcePath, 'array');
205
+
206
+ // Mark return as boolean
207
+ context.addType(methodCallPath, 'boolean');
208
+
209
+ // Get the last function call segment to access the arguments
210
+ const lastFunctionCallSegment = methodCallPath.getLastFunctionCallSegment();
211
+
212
+ if (lastFunctionCallSegment && lastFunctionCallSegment.args.length > 0) {
213
+ // The first argument is the callback
214
+ const callbackPath = lastFunctionCallSegment.args[0];
215
+
216
+ // Add the callback to the structure
217
+ context.addType(callbackPath, 'function');
218
+
219
+ // Mark that the callback's first parameter receives array elements
220
+ context.addEquivalence(
221
+ callbackPath.withParameter(0),
222
+ sourcePath.withElement('*'),
223
+ );
224
+ }
225
+ }
226
+
227
+ isComplete(): boolean {
228
+ return true;
229
+ }
230
+ }
231
+
142
232
  /**
143
233
  * Array find method semantics
144
234
  *
@@ -173,12 +263,12 @@ export class ArrayFindSemantics implements MethodSemantics {
173
263
  sourcePath.withElement('*'),
174
264
  );
175
265
 
176
- // THIS IS PRODUCING STRANGE RESULTS SUCH AS
177
- // 'people.filter(cyScope2()).find(cyScope3())': 'people.filter(cyScope2()).functionCallReturnValue[]',
178
- // 'personWithHome.places.find(cyScope5())': 'personWithHome.places[]'
179
- // WHICH DO NOT MAKES SENSE
180
- // REMOVING BUT LEAVING IN PLACE IN CASE THERE IS A VALID USE CASE
181
- // The result is an element from the array that matches the callback condition
266
+ // NOTE: We intentionally do NOT create an equivalency from the find result
267
+ // to the array element here. While semantically correct (find returns an element),
268
+ // doing so causes type inference issues where the array element gets typed as
269
+ // 'function' instead of 'object'. The tracing back to source arrays happens
270
+ // through the || operator processing and null guard in addEquivalence.
271
+ // See: analyzeScopeNoAI1.test.ts for tests that break if this is uncommented.
182
272
  // context.addEquivalence(methodCallPath, sourcePath.withElement('*'));
183
273
  }
184
274
  }
@@ -239,11 +329,17 @@ export class ArrayReduceSemantics implements MethodSemantics {
239
329
  /**
240
330
  * Array concat method semantics
241
331
  *
242
- * concat() returns a new array combining the original array and additional items
332
+ * concat() returns a new array/string combining the original and additional items
333
+ *
334
+ * NOTE: We intentionally do NOT type the source as 'array' here because
335
+ * .concat() exists on both arrays AND strings. Typing the source prematurely
336
+ * causes type contamination when the source is equivalent to other paths
337
+ * via ?? chains. Type inference happens later in checkIfKnownType() based
338
+ * on accumulated evidence from all methods called on a path.
243
339
  */
244
340
  export class ArrayConcatSemantics implements MethodSemantics {
245
341
  getReturnType(): string {
246
- return 'array';
342
+ return 'unknown'; // Could be array or string depending on source
247
343
  }
248
344
 
249
345
  addEquivalences(
@@ -251,23 +347,24 @@ export class ArrayConcatSemantics implements MethodSemantics {
251
347
  sourcePath: StructuredPath,
252
348
  context: AnalysisContext,
253
349
  ): void {
254
- // Mark source as array
255
- context.addType(sourcePath, 'array');
350
+ // NOTE: We use 'unknown' instead of 'array' for the source because .concat()
351
+ // exists on both arrays AND strings. Using 'array' causes type contamination
352
+ // when the source is equivalent to other paths via ?? chains.
353
+ context.addType(sourcePath, 'unknown');
256
354
 
257
- // Any arguments are also added to the array
355
+ // Any arguments are also added to the result
258
356
  const functionCallSegment = methodCallPath.getLastFunctionCallSegment();
259
357
 
260
358
  if (functionCallSegment) {
261
359
  // Each argument could be an array or single element
262
360
  functionCallSegment.args.forEach((argPath) => {
263
361
  // No need to guess the type - we'll discover it through normal processing
264
- // But we can indicate that these elements will be in the result array
362
+ // But we can indicate that these elements will be in the result
265
363
  context.addEquivalence(methodCallPath, argPath);
266
364
  });
267
365
  }
268
366
 
269
- // The original array elements are also in the result
270
- context.addType(methodCallPath, 'array');
367
+ // The original elements are also in the result
271
368
  context.addEquivalence(methodCallPath, sourcePath.withElement('*'));
272
369
  }
273
370
 
@@ -279,11 +376,17 @@ export class ArrayConcatSemantics implements MethodSemantics {
279
376
  /**
280
377
  * Array slice method semantics
281
378
  *
282
- * slice() returns a shallow copy of a portion of an array
379
+ * slice() returns a shallow copy of a portion of an array (or string)
380
+ *
381
+ * NOTE: We intentionally do NOT type the source as 'array' here because
382
+ * .slice() exists on both arrays AND strings. Typing the source prematurely
383
+ * causes type contamination when the source is equivalent to other paths
384
+ * via ?? chains. Type inference happens later in checkIfKnownType() based
385
+ * on accumulated evidence from all methods called on a path.
283
386
  */
284
387
  export class ArraySliceSemantics implements MethodSemantics {
285
388
  getReturnType(): string {
286
- return 'array';
389
+ return 'unknown'; // Could be array or string depending on source
287
390
  }
288
391
 
289
392
  addEquivalences(
@@ -291,12 +394,15 @@ export class ArraySliceSemantics implements MethodSemantics {
291
394
  sourcePath: StructuredPath,
292
395
  context: AnalysisContext,
293
396
  ): void {
294
- // Mark source as array
295
- context.addType(sourcePath, 'array');
397
+ // NOTE: We use 'unknown' instead of 'array' for the source because .slice()
398
+ // exists on both arrays AND strings. Using 'array' causes type contamination
399
+ // when the source is equivalent to other paths via ?? chains.
400
+ // Type inference happens later in checkIfKnownType() based on accumulated evidence.
401
+ context.addType(sourcePath, 'unknown');
296
402
 
297
- // The elements in the result are the same type as the source array
403
+ // Still track the return value type for data structure tracking
298
404
  const methodCallPathWithReturnValues = methodCallPath.withReturnValues();
299
- context.addType(methodCallPathWithReturnValues, 'array');
405
+ context.addType(methodCallPathWithReturnValues, 'unknown');
300
406
  }
301
407
 
302
408
  isComplete(): boolean {
@@ -518,6 +624,12 @@ export class ArrayFlatMapSemantics implements MethodSemantics {
518
624
  * Array at method semantics
519
625
  *
520
626
  * at() returns the element at the given index, supporting negative indices
627
+ *
628
+ * NOTE: We intentionally do NOT type the source as 'array' here because
629
+ * .at() exists on both arrays AND strings. Typing the source prematurely
630
+ * causes type contamination when the source is equivalent to other paths
631
+ * via ?? chains. Type inference happens later in checkIfKnownType() based
632
+ * on accumulated evidence from all methods called on a path.
521
633
  */
522
634
  export class ArrayAtSemantics implements MethodSemantics {
523
635
  getReturnType(): string {
@@ -529,10 +641,12 @@ export class ArrayAtSemantics implements MethodSemantics {
529
641
  sourcePath: StructuredPath,
530
642
  context: AnalysisContext,
531
643
  ): void {
532
- // Mark source as array
533
- context.addType(sourcePath, 'array');
644
+ // NOTE: We use 'unknown' instead of 'array' for the source because .at()
645
+ // exists on both arrays AND strings. Using 'array' causes type contamination
646
+ // when the source is equivalent to other paths via ?? chains.
647
+ context.addType(sourcePath, 'unknown');
534
648
 
535
- // The return value is equivalent to an array element
649
+ // The return value is equivalent to an element
536
650
  context.addEquivalence(
537
651
  methodCallPath.withReturnValues(),
538
652
  sourcePath.withElement('*'),
@@ -800,6 +914,8 @@ export function createMethodRegistry(): MethodSemanticsRegistry {
800
914
  registry.register('slice', new ArraySliceSemantics(), 'Array');
801
915
  registry.register('splice', new ArraySpliceSemantics(), 'Array');
802
916
  registry.register('push', new ArrayPushSemantics(), 'Array');
917
+ registry.register('some', new ArraySomeSemantics(), 'Array');
918
+ registry.register('every', new ArrayEverySemantics(), 'Array');
803
919
 
804
920
  // Register Object methods
805
921
  registry.register('fromEntries', new ObjectFromEntriesSemantics(), 'Object');
@@ -3,131 +3,10 @@ import { AnalysisContext } from '../types';
3
3
  import { PatternHandler } from './patternHandler';
4
4
  import { StructuredPath } from '../paths';
5
5
  import { processBindingPattern } from '../processBindings';
6
-
7
- /**
8
- * Extracts a simple path string from an expression.
9
- * Returns the path for identifiers and property access chains.
10
- */
11
- function getSimplePath(node: ts.Expression): string | null {
12
- if (ts.isIdentifier(node)) {
13
- return node.text;
14
- }
15
- if (ts.isPropertyAccessExpression(node)) {
16
- const objectPath = getSimplePath(node.expression);
17
- if (objectPath) {
18
- return `${objectPath}.${node.name.text}`;
19
- }
20
- }
21
- // Handle optional chaining: a?.b
22
- if (ts.isNonNullExpression(node)) {
23
- return getSimplePath(node.expression);
24
- }
25
- return null;
26
- }
27
-
28
- /** Array methods that return boolean predicates */
29
- const ARRAY_PREDICATE_METHODS = ['includes', 'some', 'every'] as const;
30
- type ArrayPredicateMethod = (typeof ARRAY_PREDICATE_METHODS)[number];
31
-
32
- /**
33
- * Maps array method names to derivation operation names
34
- */
35
- function getArrayPredicateOperation(
36
- methodName: string,
37
- ): 'arrayIncludes' | 'arraySome' | 'arrayEvery' | null {
38
- switch (methodName) {
39
- case 'includes':
40
- return 'arrayIncludes';
41
- case 'some':
42
- return 'arraySome';
43
- case 'every':
44
- return 'arrayEvery';
45
- default:
46
- return null;
47
- }
48
- }
49
-
50
- /**
51
- * Detects if an expression is an array predicate call and extracts the array path.
52
- * Patterns detected:
53
- * - arr.includes(x) → { sourcePath: 'arr', operation: 'arrayIncludes' }
54
- * - arr?.includes(x) → { sourcePath: 'arr', operation: 'arrayIncludes' }
55
- * - arr.some(fn) → { sourcePath: 'arr', operation: 'arraySome' }
56
- * - arr.every(fn) → { sourcePath: 'arr', operation: 'arrayEvery' }
57
- * - Boolean(x && arr?.includes(y)) → { sourcePath: 'arr', operation: 'arrayIncludes' }
58
- */
59
- function detectArrayPredicatePattern(expr: ts.Expression): {
60
- sourcePath: string;
61
- operation: 'arrayIncludes' | 'arraySome' | 'arrayEvery';
62
- } | null {
63
- // Unwrap Boolean() calls: Boolean(x) → x
64
- if (
65
- ts.isCallExpression(expr) &&
66
- ts.isIdentifier(expr.expression) &&
67
- expr.expression.text === 'Boolean' &&
68
- expr.arguments.length === 1
69
- ) {
70
- return detectArrayPredicatePattern(expr.arguments[0]);
71
- }
72
-
73
- // Handle logical AND: a && b - check both sides for array predicates
74
- if (
75
- ts.isBinaryExpression(expr) &&
76
- expr.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
77
- ) {
78
- // Try the right side first (more likely to have the predicate)
79
- const rightResult = detectArrayPredicatePattern(expr.right);
80
- if (rightResult) return rightResult;
81
- // Try the left side
82
- const leftResult = detectArrayPredicatePattern(expr.left);
83
- if (leftResult) return leftResult;
84
- return null;
85
- }
86
-
87
- // Handle parenthesized expressions
88
- if (ts.isParenthesizedExpression(expr)) {
89
- return detectArrayPredicatePattern(expr.expression);
90
- }
91
-
92
- if (!ts.isCallExpression(expr)) {
93
- return null;
94
- }
95
-
96
- const callExpr = expr.expression;
97
-
98
- // Handle both regular property access (arr.includes) and optional chaining (arr?.includes)
99
- let objectExpr: ts.Expression | null = null;
100
- let methodName: string | null = null;
101
-
102
- if (ts.isPropertyAccessExpression(callExpr)) {
103
- objectExpr = callExpr.expression;
104
- methodName = callExpr.name.text;
105
- } else if (
106
- ts.isElementAccessExpression(callExpr) &&
107
- ts.isStringLiteral(callExpr.argumentExpression)
108
- ) {
109
- // Handle arr["includes"]() syntax (rare but possible)
110
- objectExpr = callExpr.expression;
111
- methodName = callExpr.argumentExpression.text;
112
- }
113
-
114
- if (!objectExpr || !methodName) {
115
- return null;
116
- }
117
-
118
- const operation = getArrayPredicateOperation(methodName);
119
- if (!operation) {
120
- return null;
121
- }
122
-
123
- // Get the source path for the array
124
- const sourcePath = getSimplePath(objectExpr);
125
- if (!sourcePath) {
126
- return null;
127
- }
128
-
129
- return { sourcePath, operation };
130
- }
6
+ import {
7
+ getSimplePath,
8
+ detectArrayPredicatePattern,
9
+ } from '../arrayDerivationDetector';
131
10
 
132
11
  /**
133
12
  * Detects if an expression is a boolean derivation pattern and extracts the info.
@@ -154,7 +33,8 @@ function detectDerivationPattern(expr: ts.Expression): {
154
33
  | 'and'
155
34
  | 'arrayIncludes'
156
35
  | 'arraySome'
157
- | 'arrayEvery';
36
+ | 'arrayEvery'
37
+ | 'arrayLength';
158
38
  comparedValue?: string;
159
39
  } | null {
160
40
  // Check for array predicate methods first