@codeyam/codeyam-cli 0.0.0 → 0.1.0-staging.036391e

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 (3610) hide show
  1. package/analyzer-template/.build-info.json +10 -0
  2. package/analyzer-template/common/checkPID.ts +9 -0
  3. package/analyzer-template/common/closePort.ts +19 -0
  4. package/analyzer-template/common/constants.ts +2 -0
  5. package/analyzer-template/common/copy.ts +20 -0
  6. package/analyzer-template/common/deleteFolder.ts +8 -0
  7. package/analyzer-template/common/execAsync.ts +191 -0
  8. package/analyzer-template/common/getPID.ts +41 -0
  9. package/analyzer-template/common/measureAndRepordExecutionTime.ts +16 -0
  10. package/analyzer-template/common/measureExecutionTime.ts +16 -0
  11. package/analyzer-template/common/openPage.ts +20 -0
  12. package/analyzer-template/common/readFile.ts +20 -0
  13. package/analyzer-template/common/removeQueryParamsFromFileNames.ts +34 -0
  14. package/analyzer-template/common/replacePaths.ts +88 -0
  15. package/analyzer-template/common/writeFile.ts +28 -0
  16. package/analyzer-template/log.txt +7 -0
  17. package/analyzer-template/package.json +74 -0
  18. package/analyzer-template/packages/ai/client.ts +23 -0
  19. package/analyzer-template/packages/ai/index.ts +117 -0
  20. package/analyzer-template/packages/ai/package.json +22 -0
  21. package/analyzer-template/packages/ai/scripts/ai-test-matrix.mjs +424 -0
  22. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +240 -0
  23. package/analyzer-template/packages/ai/src/lib/aiConfig.ts +30 -0
  24. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +790 -0
  25. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  26. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +1092 -0
  27. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  28. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +937 -0
  29. package/analyzer-template/packages/ai/src/lib/astScopes/nodeToSource.ts +59 -0
  30. package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +714 -0
  31. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/blockHandler.ts +28 -0
  32. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/breakStatementHandler.ts +21 -0
  33. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/doStatementHandler.ts +27 -0
  34. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +61 -0
  35. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forOfStatementHandler.ts +112 -0
  36. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forStatementHandler.ts +64 -0
  37. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/functionDeclarationHandler.ts +212 -0
  38. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +65 -0
  39. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/patternHandler.ts +32 -0
  40. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/returnStatementHandler.ts +63 -0
  41. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/standaloneExpressionHandler.ts +58 -0
  42. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +142 -0
  43. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/throwStatementHandler.ts +20 -0
  44. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/tryStatementHandler.ts +67 -0
  45. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/typeAndInterfaceHandler.ts +23 -0
  46. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +271 -0
  47. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/whileStatementHandler.ts +29 -0
  48. package/analyzer-template/packages/ai/src/lib/astScopes/processBindings.ts +255 -0
  49. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +3668 -0
  50. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +127 -0
  51. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +637 -0
  52. package/analyzer-template/packages/ai/src/lib/astScopes.ts +22 -0
  53. package/analyzer-template/packages/ai/src/lib/checkAllAttributes.ts +44 -0
  54. package/analyzer-template/packages/ai/src/lib/cleanOutBoundary.ts +33 -0
  55. package/analyzer-template/packages/ai/src/lib/cleanStructure.ts +201 -0
  56. package/analyzer-template/packages/ai/src/lib/codeQualityEntityAnalysis.ts +26 -0
  57. package/analyzer-template/packages/ai/src/lib/commitMessage.ts +16 -0
  58. package/analyzer-template/packages/ai/src/lib/completionCall.ts +681 -0
  59. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +6278 -0
  60. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/EquivalencyManager.ts +45 -0
  61. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/EquivalencyManagerTemplate.ts +18 -0
  62. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.ts +577 -0
  63. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +144 -0
  64. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +593 -0
  65. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +976 -0
  66. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +1341 -0
  67. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +152 -0
  68. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/DebugTracer.ts +224 -0
  69. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/PathManager.ts +203 -0
  70. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/README.md +294 -0
  71. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +163 -0
  72. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/VisitedTracker.ts +235 -0
  73. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +231 -0
  74. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +1192 -0
  75. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanPath.ts +25 -0
  76. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanPathOfNonTransformingFunctions.ts +58 -0
  77. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanScopeNodeName.ts +3 -0
  78. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  79. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +364 -0
  80. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
  81. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  82. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +153 -0
  83. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/determineIsFunctionCall.ts +16 -0
  84. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ensureSchemaConsistency.ts +83 -0
  85. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +1065 -0
  86. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  87. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.ts +41 -0
  88. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallScopeNodeName.ts +15 -0
  89. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallSignature.ts +17 -0
  90. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/isGenericArray.ts +83 -0
  91. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/knownMethodCalls.ts +138 -0
  92. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/selectBestValue.ts +70 -0
  93. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/uniqueIdUtils.ts +113 -0
  94. package/analyzer-template/packages/ai/src/lib/dataStructure/typeUtils.ts +161 -0
  95. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +156 -0
  96. package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
  97. package/analyzer-template/packages/ai/src/lib/describeCodeChange.ts +56 -0
  98. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  99. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  100. package/analyzer-template/packages/ai/src/lib/extractOverlappingMocks.ts +63 -0
  101. package/analyzer-template/packages/ai/src/lib/generateBranchSummary.ts +55 -0
  102. package/analyzer-template/packages/ai/src/lib/generateChangesEntityDocumentation.ts +82 -0
  103. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +488 -0
  104. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +386 -0
  105. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +153 -0
  106. package/analyzer-template/packages/ai/src/lib/generateEntityDocumentation.ts +84 -0
  107. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1680 -0
  108. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +447 -0
  109. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +578 -0
  110. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  111. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2267 -0
  112. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  113. package/analyzer-template/packages/ai/src/lib/generateStatementAnalysis.ts +1789 -0
  114. package/analyzer-template/packages/ai/src/lib/getCodeExplanation.ts +52 -0
  115. package/analyzer-template/packages/ai/src/lib/getConditionalUsagesFromCode.ts +442 -0
  116. package/analyzer-template/packages/ai/src/lib/getLLMCallCost.ts +26 -0
  117. package/analyzer-template/packages/ai/src/lib/getLLMCallStats.ts +40 -0
  118. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +125 -0
  119. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromName.ts +87 -0
  120. package/analyzer-template/packages/ai/src/lib/identifyReserved.ts +734 -0
  121. package/analyzer-template/packages/ai/src/lib/index.ts +26 -0
  122. package/analyzer-template/packages/ai/src/lib/instantiatedInScope.ts +212 -0
  123. package/analyzer-template/packages/ai/src/lib/isFrontend.ts +4 -0
  124. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +1219 -0
  125. package/analyzer-template/packages/ai/src/lib/isolateStatements.ts +1072 -0
  126. package/analyzer-template/packages/ai/src/lib/jsonTypeDefinitionToStandardTypeDefinition.ts +48 -0
  127. package/analyzer-template/packages/ai/src/lib/logOrderedMap.ts +49 -0
  128. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +53 -0
  129. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +289 -0
  130. package/analyzer-template/packages/ai/src/lib/modelInfo.ts +249 -0
  131. package/analyzer-template/packages/ai/src/lib/openai/index.ts +100 -0
  132. package/analyzer-template/packages/ai/src/lib/parsers/fileContentToLines.ts +12 -0
  133. package/analyzer-template/packages/ai/src/lib/parsers/parseJsonSafe.ts +45 -0
  134. package/analyzer-template/packages/ai/src/lib/promptGenerators/branchSummaryGenerator.ts +13 -0
  135. package/analyzer-template/packages/ai/src/lib/promptGenerators/codeQualityEntityAnalysisGenerator.ts +53 -0
  136. package/analyzer-template/packages/ai/src/lib/promptGenerators/commitMessageGenerator.ts +37 -0
  137. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +300 -0
  138. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityDocumentationGenerator.ts +22 -0
  139. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +120 -0
  140. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +106 -0
  141. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  142. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  143. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityDataMapGenerator.ts +20 -0
  144. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityDataStructureGenerator.ts +18 -0
  145. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityDocumentationGenerator.ts +16 -0
  146. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityPropsStructureGenerator.ts +24 -0
  147. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +139 -0
  148. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +30 -0
  149. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  150. package/analyzer-template/packages/ai/src/lib/promptGenerators/getComponentExamplesGenerator.ts +20 -0
  151. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessEditScenarioDataFromDescriptionGenerator.ts +56 -0
  152. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +50 -0
  153. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessScenarioDataFromNameGenerator.ts +41 -0
  154. package/analyzer-template/packages/ai/src/lib/promptGenerators/index.ts +10 -0
  155. package/analyzer-template/packages/ai/src/lib/promptGenerators/noErrorAttributes.ts +19 -0
  156. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  157. package/analyzer-template/packages/ai/src/lib/promptGenerators/summarizeDiffGenerator.ts +10 -0
  158. package/analyzer-template/packages/ai/src/lib/providers.ts +47 -0
  159. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  160. package/analyzer-template/packages/ai/src/lib/services/aiServiceMode.ts +166 -0
  161. package/analyzer-template/packages/ai/src/lib/services/claudeCliAIService.ts +283 -0
  162. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +337 -0
  163. package/analyzer-template/packages/ai/src/lib/summarizeDiff.ts +25 -0
  164. package/analyzer-template/packages/ai/src/lib/types/index.ts +96 -0
  165. package/analyzer-template/packages/ai/src/lib/validateDataStructure.ts +434 -0
  166. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  167. package/analyzer-template/packages/ai/src/lib/validateJson.ts +65 -0
  168. package/analyzer-template/packages/ai/src/lib/validatePlaywrightInstructions.ts +225 -0
  169. package/analyzer-template/packages/ai/src/lib/validateTypeStructure.ts +93 -0
  170. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +353 -0
  171. package/analyzer-template/packages/ai/src/lib/worker/__mocks__/analyzeScopeWorkerPaths.ts +5 -0
  172. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +218 -0
  173. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorkerPaths.ts +26 -0
  174. package/analyzer-template/packages/ai/src/lib/worker/fuzzyMatchFunctionName.ts +77 -0
  175. package/analyzer-template/packages/ai/src/lib/wrapperDetection/detectWrapperRequirements.ts +134 -0
  176. package/analyzer-template/packages/ai/src/lib/wrapperDetection/index.ts +9 -0
  177. package/analyzer-template/packages/ai/src/lib/wrapperDetection/knownLibraryHooks.ts +95 -0
  178. package/analyzer-template/packages/ai/src/lib/wrapperDetection/patterns/detectThrowOnMissingPatterns.ts +189 -0
  179. package/analyzer-template/packages/ai/src/lib/wrapperDetection/patterns/detectUseContextCalls.ts +127 -0
  180. package/analyzer-template/packages/ai/tsconfig.json +10 -0
  181. package/analyzer-template/packages/analyze/README.md +131 -0
  182. package/analyzer-template/packages/analyze/TODOS.md +46 -0
  183. package/analyzer-template/packages/analyze/index.ts +113 -0
  184. package/analyzer-template/packages/analyze/package.json +13 -0
  185. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +1135 -0
  186. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +411 -0
  187. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +348 -0
  188. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +241 -0
  189. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getCallExpressionNames.ts +37 -0
  190. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getFunctionNodeType.ts +25 -0
  191. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +130 -0
  192. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getReactComponentType.ts +39 -0
  193. package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +184 -0
  194. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
  195. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isDefaultExport.ts +76 -0
  196. package/analyzer-template/packages/analyze/src/lib/asts/nodes/propsNodeToPropsData.ts +540 -0
  197. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +257 -0
  198. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntities.ts +6 -0
  199. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +255 -0
  200. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.ts +133 -0
  201. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +254 -0
  202. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getComponentProps.ts +33 -0
  203. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getComponentType.ts +41 -0
  204. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getDeclaredEntityNode.ts +25 -0
  205. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getDefaultExportedFunctionNode.ts +53 -0
  206. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getEntityNode.ts +26 -0
  207. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportMappings.ts +40 -0
  208. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +135 -0
  209. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getPropsFromFunctionalComponent.ts +96 -0
  210. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getPseudoFile.ts +40 -0
  211. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedImportedTypes.ts +84 -0
  212. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +166 -0
  213. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFile.ts +13 -0
  214. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +26 -0
  215. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForImports.ts +21 -0
  216. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/index.ts +56 -0
  217. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/extractClassMethods.ts +139 -0
  218. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +1005 -0
  219. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncComplex.ts +165 -0
  220. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncSimple.ts +30 -0
  221. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/index.ts +23 -0
  222. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/sequential.ts +16 -0
  223. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/types.ts +20 -0
  224. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +595 -0
  225. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +126 -0
  226. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +267 -0
  227. package/analyzer-template/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.ts +31 -0
  228. package/analyzer-template/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.ts +25 -0
  229. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +141 -0
  230. package/analyzer-template/packages/analyze/src/lib/files/analyze/generateAnalysisTreeSha.ts +160 -0
  231. package/analyzer-template/packages/analyze/src/lib/files/analyze/generateAnalyzedTreeSha.ts +10 -0
  232. package/analyzer-template/packages/analyze/src/lib/files/analyze/guessDefaultWidth.ts +18 -0
  233. package/analyzer-template/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.ts +127 -0
  234. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +122 -0
  235. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +160 -0
  236. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +236 -0
  237. package/analyzer-template/packages/analyze/src/lib/files/analyzeCodeChange.ts +70 -0
  238. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +552 -0
  239. package/analyzer-template/packages/analyze/src/lib/files/analyzeFrameworkRoute.ts +19 -0
  240. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +195 -0
  241. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +112 -0
  242. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +140 -0
  243. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +16 -0
  244. package/analyzer-template/packages/analyze/src/lib/files/extractDiffLines.ts +21 -0
  245. package/analyzer-template/packages/analyze/src/lib/files/fileAnalyzerFromCode.ts +57 -0
  246. package/analyzer-template/packages/analyze/src/lib/files/findScenarioData.ts +43 -0
  247. package/analyzer-template/packages/analyze/src/lib/files/getEntityCode.ts +26 -0
  248. package/analyzer-template/packages/analyze/src/lib/files/getEntityType.ts +29 -0
  249. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +266 -0
  250. package/analyzer-template/packages/analyze/src/lib/files/getNodeModuleImports.ts +37 -0
  251. package/analyzer-template/packages/analyze/src/lib/files/newAnalysis.ts +43 -0
  252. package/analyzer-template/packages/analyze/src/lib/files/recordStep.ts +35 -0
  253. package/analyzer-template/packages/analyze/src/lib/files/relevantDiffPart.ts +74 -0
  254. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
  255. package/analyzer-template/packages/analyze/src/lib/files/scenarios/detectChangedDataStructureFields.ts +102 -0
  256. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +313 -0
  257. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
  258. package/analyzer-template/packages/analyze/src/lib/files/scenarios/findImportedEntity.ts +36 -0
  259. package/analyzer-template/packages/analyze/src/lib/files/scenarios/findRelevantExportInfo.ts +52 -0
  260. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +911 -0
  261. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.ts +176 -0
  262. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +232 -0
  263. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +826 -0
  264. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +264 -0
  265. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +234 -0
  266. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +134 -0
  267. package/analyzer-template/packages/analyze/src/lib/files/scenarios/isolateDataStructure.ts +71 -0
  268. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1793 -0
  269. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +244 -0
  270. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  271. package/analyzer-template/packages/analyze/src/lib/files/scenarios/reproduceImports.ts +60 -0
  272. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +313 -0
  273. package/analyzer-template/packages/analyze/src/lib/index.ts +7 -0
  274. package/analyzer-template/packages/analyze/src/lib/projects/index.ts +48 -0
  275. package/analyzer-template/packages/analyze/src/lib/types/index.ts +17 -0
  276. package/analyzer-template/packages/analyze/src/lib/utils/deepEqual.ts +30 -0
  277. package/analyzer-template/packages/analyze/src/lib/utils/getAnalysisError.ts +13 -0
  278. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  279. package/analyzer-template/packages/analyze/src/lib/utils/measureAndReportExecutionTime.ts +22 -0
  280. package/analyzer-template/packages/analyze/src/lib/utils/measureExecutionTime.ts +16 -0
  281. package/analyzer-template/packages/analyze/tsconfig.json +10 -0
  282. package/analyzer-template/packages/aws/cloudwatch/index.ts +6 -0
  283. package/analyzer-template/packages/aws/codebuild/index.ts +7 -0
  284. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.d.ts +10 -0
  285. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.d.ts.map +1 -0
  286. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.js +31 -0
  287. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.js.map +1 -0
  288. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.d.ts +2 -0
  289. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.d.ts.map +1 -0
  290. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.js +32 -0
  291. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.js.map +1 -0
  292. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.d.ts +2 -0
  293. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.d.ts.map +1 -0
  294. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.js +28 -0
  295. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.js.map +1 -0
  296. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.d.ts +2 -0
  297. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.d.ts.map +1 -0
  298. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.js +40 -0
  299. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.js.map +1 -0
  300. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.d.ts +14 -0
  301. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.d.ts.map +1 -0
  302. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.js +29 -0
  303. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.js.map +1 -0
  304. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +12 -0
  305. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -0
  306. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +61 -0
  307. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -0
  308. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.d.ts +3 -0
  309. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.d.ts.map +1 -0
  310. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.js +26 -0
  311. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.js.map +1 -0
  312. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.d.ts +3 -0
  313. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.d.ts.map +1 -0
  314. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.js +35 -0
  315. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.js.map +1 -0
  316. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.d.ts +2 -0
  317. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.d.ts.map +1 -0
  318. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.js +66 -0
  319. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.js.map +1 -0
  320. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.d.ts +25 -0
  321. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.d.ts.map +1 -0
  322. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.js +67 -0
  323. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.js.map +1 -0
  324. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.d.ts +2 -0
  325. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.d.ts.map +1 -0
  326. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.js +6 -0
  327. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.js.map +1 -0
  328. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.d.ts +25 -0
  329. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.d.ts.map +1 -0
  330. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.js +2 -0
  331. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.js.map +1 -0
  332. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.d.ts +9 -0
  333. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.d.ts.map +1 -0
  334. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.js +36 -0
  335. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.js.map +1 -0
  336. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.d.ts +2 -0
  337. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.d.ts.map +1 -0
  338. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.js +49 -0
  339. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.js.map +1 -0
  340. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.d.ts +2 -0
  341. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.d.ts.map +1 -0
  342. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.js +36 -0
  343. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.js.map +1 -0
  344. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.d.ts +11 -0
  345. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.d.ts.map +1 -0
  346. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.js +138 -0
  347. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.js.map +1 -0
  348. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +11 -0
  349. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -0
  350. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +30 -0
  351. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -0
  352. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.d.ts +3 -0
  353. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.d.ts.map +1 -0
  354. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.js +51 -0
  355. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.js.map +1 -0
  356. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +24 -0
  357. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -0
  358. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +43 -0
  359. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -0
  360. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts +15 -0
  361. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts.map +1 -0
  362. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js +31 -0
  363. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js.map +1 -0
  364. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.d.ts +23 -0
  365. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.d.ts.map +1 -0
  366. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.js +30 -0
  367. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.js.map +1 -0
  368. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts +9 -0
  369. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -0
  370. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +31 -0
  371. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -0
  372. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.d.ts +7 -0
  373. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.d.ts.map +1 -0
  374. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.js +15 -0
  375. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.js.map +1 -0
  376. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.d.ts +5 -0
  377. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.d.ts.map +1 -0
  378. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.js +9 -0
  379. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.js.map +1 -0
  380. package/analyzer-template/packages/aws/dist/types.d.ts +8 -0
  381. package/analyzer-template/packages/aws/dist/types.d.ts.map +1 -0
  382. package/analyzer-template/packages/aws/dist/types.js +2 -0
  383. package/analyzer-template/packages/aws/dist/types.js.map +1 -0
  384. package/analyzer-template/packages/aws/dynamodb/index.ts +10 -0
  385. package/analyzer-template/packages/aws/ecr/index.ts +4 -0
  386. package/analyzer-template/packages/aws/ecs/index.ts +6 -0
  387. package/analyzer-template/packages/aws/package.json +25 -0
  388. package/analyzer-template/packages/aws/s3/index.ts +7 -0
  389. package/analyzer-template/packages/aws/sqs/index.ts +3 -0
  390. package/analyzer-template/packages/aws/src/lib/cloudwatch/getTaskLogs.ts +50 -0
  391. package/analyzer-template/packages/aws/src/lib/codebuild/checkForCodeBuild.ts +43 -0
  392. package/analyzer-template/packages/aws/src/lib/codebuild/checkForCodeBuildProject.ts +30 -0
  393. package/analyzer-template/packages/aws/src/lib/codebuild/createCodeBuildProject.ts +51 -0
  394. package/analyzer-template/packages/aws/src/lib/codebuild/triggerCodeBuild.ts +52 -0
  395. package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +87 -0
  396. package/analyzer-template/packages/aws/src/lib/dynamodb/loadLlmCall.ts +31 -0
  397. package/analyzer-template/packages/aws/src/lib/dynamodb/loadLlmCalls.ts +44 -0
  398. package/analyzer-template/packages/aws/src/lib/dynamodb/provisionTable.ts +81 -0
  399. package/analyzer-template/packages/aws/src/lib/dynamodb/saveLlmCall.ts +118 -0
  400. package/analyzer-template/packages/aws/src/lib/dynamodb/tableNames.ts +5 -0
  401. package/analyzer-template/packages/aws/src/lib/dynamodb/types.ts +26 -0
  402. package/analyzer-template/packages/aws/src/lib/ecr/checkForECRImage.ts +55 -0
  403. package/analyzer-template/packages/aws/src/lib/ecr/createECRRepository.ts +63 -0
  404. package/analyzer-template/packages/aws/src/lib/ecs/ecsCheckTaskStatus.ts +43 -0
  405. package/analyzer-template/packages/aws/src/lib/ecs/ecsCreateTaskDefinition.ts +225 -0
  406. package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +43 -0
  407. package/analyzer-template/packages/aws/src/lib/ecs/ecsStartTask.ts +72 -0
  408. package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +57 -0
  409. package/analyzer-template/packages/aws/src/lib/s3/checkS3ObjectExists.ts +47 -0
  410. package/analyzer-template/packages/aws/src/lib/s3/getPresignedUrl.ts +62 -0
  411. package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +43 -0
  412. package/analyzer-template/packages/aws/src/lib/sqs/getSqsQueueSizeStats.ts +28 -0
  413. package/analyzer-template/packages/aws/src/lib/sqs/sendSqsMessage.ts +17 -0
  414. package/analyzer-template/packages/aws/tsconfig.json +11 -0
  415. package/analyzer-template/packages/aws/types.ts +11 -0
  416. package/analyzer-template/packages/database/__mocks__/index.ts +10 -0
  417. package/analyzer-template/packages/database/client.ts +35 -0
  418. package/analyzer-template/packages/database/index.ts +93 -0
  419. package/analyzer-template/packages/database/package.json +31 -0
  420. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +28 -0
  421. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +59 -0
  422. package/analyzer-template/packages/database/src/lib/backgroundJobToDb.ts +21 -0
  423. package/analyzer-template/packages/database/src/lib/branchToDb.ts +24 -0
  424. package/analyzer-template/packages/database/src/lib/client/listenForCommits_Client.ts +30 -0
  425. package/analyzer-template/packages/database/src/lib/client/loadAnalysesInClient.ts +146 -0
  426. package/analyzer-template/packages/database/src/lib/client/loadAnalysis_Client.ts +134 -0
  427. package/analyzer-template/packages/database/src/lib/client/loadBranches_Client.ts +45 -0
  428. package/analyzer-template/packages/database/src/lib/client/loadCommit_Client.ts +79 -0
  429. package/analyzer-template/packages/database/src/lib/client/upsertFiles_Client.ts +50 -0
  430. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +20 -0
  431. package/analyzer-template/packages/database/src/lib/commitToDb.ts +47 -0
  432. package/analyzer-template/packages/database/src/lib/createOrUpdateBranchCommitStats.ts +182 -0
  433. package/analyzer-template/packages/database/src/lib/createProject.ts +34 -0
  434. package/analyzer-template/packages/database/src/lib/createRetryFetch.ts +45 -0
  435. package/analyzer-template/packages/database/src/lib/dbToAnalysis.ts +76 -0
  436. package/analyzer-template/packages/database/src/lib/dbToAnalysisBranch.ts +28 -0
  437. package/analyzer-template/packages/database/src/lib/dbToBackgroundJob.ts +25 -0
  438. package/analyzer-template/packages/database/src/lib/dbToBranch.ts +39 -0
  439. package/analyzer-template/packages/database/src/lib/dbToCommit.ts +65 -0
  440. package/analyzer-template/packages/database/src/lib/dbToCommitBranch.ts +22 -0
  441. package/analyzer-template/packages/database/src/lib/dbToEntity.ts +42 -0
  442. package/analyzer-template/packages/database/src/lib/dbToEntityBranch.ts +17 -0
  443. package/analyzer-template/packages/database/src/lib/dbToFile.ts +16 -0
  444. package/analyzer-template/packages/database/src/lib/dbToProject.ts +30 -0
  445. package/analyzer-template/packages/database/src/lib/dbToScenario.ts +39 -0
  446. package/analyzer-template/packages/database/src/lib/dbToScenarioComment.ts +36 -0
  447. package/analyzer-template/packages/database/src/lib/dbToUserScenario.ts +32 -0
  448. package/analyzer-template/packages/database/src/lib/deleteBranch.ts +28 -0
  449. package/analyzer-template/packages/database/src/lib/deleteEntities.ts +32 -0
  450. package/analyzer-template/packages/database/src/lib/deleteFile.ts +19 -0
  451. package/analyzer-template/packages/database/src/lib/deleteScenarios.ts +41 -0
  452. package/analyzer-template/packages/database/src/lib/entityToDb.ts +83 -0
  453. package/analyzer-template/packages/database/src/lib/fileToDb.ts +17 -0
  454. package/analyzer-template/packages/database/src/lib/generateSha.ts +14 -0
  455. package/analyzer-template/packages/database/src/lib/jsonUpdateUtils.ts +43 -0
  456. package/analyzer-template/packages/database/src/lib/kysely/aggregationHelpers.ts +107 -0
  457. package/analyzer-template/packages/database/src/lib/kysely/db.ts +495 -0
  458. package/analyzer-template/packages/database/src/lib/kysely/schemaHelpers.ts +18 -0
  459. package/analyzer-template/packages/database/src/lib/kysely/sqliteBooleanPlugin.ts +46 -0
  460. package/analyzer-template/packages/database/src/lib/kysely/tableRelations.ts +108 -0
  461. package/analyzer-template/packages/database/src/lib/kysely/tableRelationsTypes.ts +26 -0
  462. package/analyzer-template/packages/database/src/lib/kysely/tables/analysesTable.ts +69 -0
  463. package/analyzer-template/packages/database/src/lib/kysely/tables/analysisBranchesTable.ts +46 -0
  464. package/analyzer-template/packages/database/src/lib/kysely/tables/backgroundJobsTable.ts +47 -0
  465. package/analyzer-template/packages/database/src/lib/kysely/tables/branchesTable.ts +49 -0
  466. package/analyzer-template/packages/database/src/lib/kysely/tables/commitBranchesTable.ts +36 -0
  467. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +67 -0
  468. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +88 -0
  469. package/analyzer-template/packages/database/src/lib/kysely/tables/entitiesTable.ts +55 -0
  470. package/analyzer-template/packages/database/src/lib/kysely/tables/entityBranchesTable.ts +42 -0
  471. package/analyzer-template/packages/database/src/lib/kysely/tables/entityStatementsTable.ts +44 -0
  472. package/analyzer-template/packages/database/src/lib/kysely/tables/filesTable.ts +47 -0
  473. package/analyzer-template/packages/database/src/lib/kysely/tables/githubPayloadsTable.ts +48 -0
  474. package/analyzer-template/packages/database/src/lib/kysely/tables/githubUsersTable.ts +36 -0
  475. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  476. package/analyzer-template/packages/database/src/lib/kysely/tables/projectsTable.ts +51 -0
  477. package/analyzer-template/packages/database/src/lib/kysely/tables/scenarioCommentsTable.ts +44 -0
  478. package/analyzer-template/packages/database/src/lib/kysely/tables/scenariosTable.ts +43 -0
  479. package/analyzer-template/packages/database/src/lib/kysely/tables/statementsTable.ts +38 -0
  480. package/analyzer-template/packages/database/src/lib/kysely/tables/teamsTable.ts +34 -0
  481. package/analyzer-template/packages/database/src/lib/kysely/tables/userScenariosTable.ts +44 -0
  482. package/analyzer-template/packages/database/src/lib/kysely/tables/userTeamsTable.ts +32 -0
  483. package/analyzer-template/packages/database/src/lib/kysely/tables/usersTable.ts +42 -0
  484. package/analyzer-template/packages/database/src/lib/kysely/upsertHelpers.ts +24 -0
  485. package/analyzer-template/packages/database/src/lib/kysely.ts +1 -0
  486. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +275 -0
  487. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +223 -0
  488. package/analyzer-template/packages/database/src/lib/loadAnalysisBranches.ts +238 -0
  489. package/analyzer-template/packages/database/src/lib/loadBackgroundJob.ts +23 -0
  490. package/analyzer-template/packages/database/src/lib/loadBranch.ts +137 -0
  491. package/analyzer-template/packages/database/src/lib/loadBranches.ts +52 -0
  492. package/analyzer-template/packages/database/src/lib/loadCommit.ts +173 -0
  493. package/analyzer-template/packages/database/src/lib/loadCommitBranches.ts +78 -0
  494. package/analyzer-template/packages/database/src/lib/loadCommitMetadata.ts +34 -0
  495. package/analyzer-template/packages/database/src/lib/loadCommits.ts +279 -0
  496. package/analyzer-template/packages/database/src/lib/loadEntities.ts +117 -0
  497. package/analyzer-template/packages/database/src/lib/loadEntity.ts +105 -0
  498. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +178 -0
  499. package/analyzer-template/packages/database/src/lib/loadFile.ts +42 -0
  500. package/analyzer-template/packages/database/src/lib/loadFiles.ts +134 -0
  501. package/analyzer-template/packages/database/src/lib/loadMostRecentPreviousAnalysis.ts +132 -0
  502. package/analyzer-template/packages/database/src/lib/loadProject.ts +70 -0
  503. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +101 -0
  504. package/analyzer-template/packages/database/src/lib/loadScenario.ts +38 -0
  505. package/analyzer-template/packages/database/src/lib/loadStatement.ts +23 -0
  506. package/analyzer-template/packages/database/src/lib/nullsToUndefines.ts +8 -0
  507. package/analyzer-template/packages/database/src/lib/projectToDb.ts +35 -0
  508. package/analyzer-template/packages/database/src/lib/saveBackgroundEvent.ts +19 -0
  509. package/analyzer-template/packages/database/src/lib/saveEntityStatements.ts +27 -0
  510. package/analyzer-template/packages/database/src/lib/saveFiles.ts +43 -0
  511. package/analyzer-template/packages/database/src/lib/saveStatement.ts +24 -0
  512. package/analyzer-template/packages/database/src/lib/scenarioCommentToDb.ts +35 -0
  513. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +35 -0
  514. package/analyzer-template/packages/database/src/lib/supabase.ts +85 -0
  515. package/analyzer-template/packages/database/src/lib/updateBackgroundJobProgress.ts +90 -0
  516. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +180 -0
  517. package/analyzer-template/packages/database/src/lib/updateEntityBranch.ts +29 -0
  518. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisMetadata.ts +63 -0
  519. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +64 -0
  520. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +94 -0
  521. package/analyzer-template/packages/database/src/lib/updateProjectMetadata.ts +95 -0
  522. package/analyzer-template/packages/database/src/lib/upsertAnalyses.ts +58 -0
  523. package/analyzer-template/packages/database/src/lib/upsertAnalysesWithScenarios.ts +94 -0
  524. package/analyzer-template/packages/database/src/lib/upsertAnalysisBranches.ts +96 -0
  525. package/analyzer-template/packages/database/src/lib/upsertBackgroundJob.ts +33 -0
  526. package/analyzer-template/packages/database/src/lib/upsertBranches.ts +32 -0
  527. package/analyzer-template/packages/database/src/lib/upsertCommitBranches.ts +36 -0
  528. package/analyzer-template/packages/database/src/lib/upsertCommits.ts +57 -0
  529. package/analyzer-template/packages/database/src/lib/upsertEntities.ts +105 -0
  530. package/analyzer-template/packages/database/src/lib/upsertEntityBranches.ts +40 -0
  531. package/analyzer-template/packages/database/src/lib/upsertFiles.ts +45 -0
  532. package/analyzer-template/packages/database/src/lib/upsertGithubUser.ts +32 -0
  533. package/analyzer-template/packages/database/src/lib/upsertProjects.ts +32 -0
  534. package/analyzer-template/packages/database/src/lib/upsertScenarios.ts +31 -0
  535. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +18 -0
  536. package/analyzer-template/packages/database/tsconfig.json +10 -0
  537. package/analyzer-template/packages/generate/index.ts +15 -0
  538. package/analyzer-template/packages/generate/jest.config.ts +11 -0
  539. package/analyzer-template/packages/generate/package.json +13 -0
  540. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +157 -0
  541. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.ts +119 -0
  542. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +193 -0
  543. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
  544. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +86 -0
  545. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getImageReplacementCode.ts +134 -0
  546. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.ts +66 -0
  547. package/analyzer-template/packages/generate/src/lib/constants.ts +3 -0
  548. package/analyzer-template/packages/generate/src/lib/deepMerge.ts +69 -0
  549. package/analyzer-template/packages/generate/src/lib/directExecutionScript.ts +185 -0
  550. package/analyzer-template/packages/generate/src/lib/escapeQuotes.ts +3 -0
  551. package/analyzer-template/packages/generate/src/lib/getComponentImportStatement.ts +60 -0
  552. package/analyzer-template/packages/generate/src/lib/getComponentImportStatements.ts +38 -0
  553. package/analyzer-template/packages/generate/src/lib/getComponentScenarioPath.ts +40 -0
  554. package/analyzer-template/packages/generate/src/lib/getRelativePath.ts +42 -0
  555. package/analyzer-template/packages/generate/src/lib/handleCmdk.ts +61 -0
  556. package/analyzer-template/packages/generate/src/lib/handleRadix.ts +362 -0
  557. package/analyzer-template/packages/generate/src/lib/handleWrappers.ts +30 -0
  558. package/analyzer-template/packages/generate/src/lib/libDemoComponent.ts +186 -0
  559. package/analyzer-template/packages/generate/src/lib/mergeRootRemix.ts +410 -0
  560. package/analyzer-template/packages/generate/src/lib/requiredNodeModuleImports.ts +55 -0
  561. package/analyzer-template/packages/generate/src/lib/safeFolder.ts +9 -0
  562. package/analyzer-template/packages/generate/src/lib/scenarioComponent.ts +122 -0
  563. package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
  564. package/analyzer-template/packages/generate/src/lib/simpleRootRemix.ts +74 -0
  565. package/analyzer-template/packages/generate/tsconfig.json +10 -0
  566. package/analyzer-template/packages/github/__mocks__/@octokit/auth-app.ts +4 -0
  567. package/analyzer-template/packages/github/__mocks__/@octokit/rest.ts +77 -0
  568. package/analyzer-template/packages/github/dist/database/index.d.ts +86 -0
  569. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -0
  570. package/analyzer-template/packages/github/dist/database/index.js +84 -0
  571. package/analyzer-template/packages/github/dist/database/index.js.map +1 -0
  572. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.d.ts +5 -0
  573. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.d.ts.map +1 -0
  574. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +19 -0
  575. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -0
  576. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.d.ts +5 -0
  577. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.d.ts.map +1 -0
  578. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +26 -0
  579. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -0
  580. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.d.ts +7 -0
  581. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.d.ts.map +1 -0
  582. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.js +13 -0
  583. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.js.map +1 -0
  584. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.d.ts +5 -0
  585. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.d.ts.map +1 -0
  586. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +18 -0
  587. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -0
  588. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.d.ts +5 -0
  589. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.d.ts.map +1 -0
  590. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +13 -0
  591. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -0
  592. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.d.ts +5 -0
  593. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.d.ts.map +1 -0
  594. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +26 -0
  595. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -0
  596. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.d.ts +18 -0
  597. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.d.ts.map +1 -0
  598. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.js +108 -0
  599. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.js.map +1 -0
  600. package/analyzer-template/packages/github/dist/database/src/lib/createProject.d.ts +2 -0
  601. package/analyzer-template/packages/github/dist/database/src/lib/createProject.d.ts.map +1 -0
  602. package/analyzer-template/packages/github/dist/database/src/lib/createProject.js +22 -0
  603. package/analyzer-template/packages/github/dist/database/src/lib/createProject.js.map +1 -0
  604. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.d.ts +5 -0
  605. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.d.ts.map +1 -0
  606. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.js +42 -0
  607. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.js.map +1 -0
  608. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.d.ts +4 -0
  609. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.d.ts.map +1 -0
  610. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.js +48 -0
  611. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.js.map +1 -0
  612. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.d.ts +4 -0
  613. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.d.ts.map +1 -0
  614. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.js +24 -0
  615. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.js.map +1 -0
  616. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.d.ts +4 -0
  617. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.d.ts.map +1 -0
  618. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.js +13 -0
  619. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.js.map +1 -0
  620. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.d.ts +4 -0
  621. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.d.ts.map +1 -0
  622. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.js +22 -0
  623. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.js.map +1 -0
  624. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.d.ts +4 -0
  625. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.d.ts.map +1 -0
  626. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.js +40 -0
  627. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.js.map +1 -0
  628. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.d.ts +4 -0
  629. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.d.ts.map +1 -0
  630. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.js +18 -0
  631. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.js.map +1 -0
  632. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.d.ts +4 -0
  633. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.d.ts.map +1 -0
  634. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.js +23 -0
  635. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.js.map +1 -0
  636. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.d.ts +4 -0
  637. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.d.ts.map +1 -0
  638. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.js +13 -0
  639. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.js.map +1 -0
  640. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.d.ts +4 -0
  641. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.d.ts.map +1 -0
  642. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.js +14 -0
  643. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.js.map +1 -0
  644. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.d.ts +4 -0
  645. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.d.ts.map +1 -0
  646. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.js +16 -0
  647. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.js.map +1 -0
  648. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.d.ts +4 -0
  649. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.d.ts.map +1 -0
  650. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.js +24 -0
  651. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.js.map +1 -0
  652. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.d.ts +4 -0
  653. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.d.ts.map +1 -0
  654. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.js +21 -0
  655. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.js.map +1 -0
  656. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.d.ts +4 -0
  657. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.d.ts.map +1 -0
  658. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.js +19 -0
  659. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.js.map +1 -0
  660. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.d.ts +5 -0
  661. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.d.ts.map +1 -0
  662. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.js +21 -0
  663. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.js.map +1 -0
  664. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.d.ts +7 -0
  665. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.d.ts.map +1 -0
  666. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.js +23 -0
  667. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.js.map +1 -0
  668. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.d.ts +32 -0
  669. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.d.ts.map +1 -0
  670. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.js +18 -0
  671. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.js.map +1 -0
  672. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.d.ts +7 -0
  673. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.d.ts.map +1 -0
  674. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.js +34 -0
  675. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.js.map +1 -0
  676. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.d.ts +5 -0
  677. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.d.ts.map +1 -0
  678. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.js +54 -0
  679. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.js.map +1 -0
  680. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.d.ts +5 -0
  681. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.d.ts.map +1 -0
  682. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +14 -0
  683. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -0
  684. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.d.ts +2 -0
  685. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.d.ts.map +1 -0
  686. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.js +15 -0
  687. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.js.map +1 -0
  688. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.d.ts +9 -0
  689. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.d.ts.map +1 -0
  690. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.js +28 -0
  691. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.js.map +1 -0
  692. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.d.ts +41 -0
  693. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.d.ts.map +1 -0
  694. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.js +66 -0
  695. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.js.map +1 -0
  696. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +71 -0
  697. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -0
  698. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +373 -0
  699. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -0
  700. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.d.ts +4 -0
  701. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.d.ts.map +1 -0
  702. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.js +17 -0
  703. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.js.map +1 -0
  704. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.d.ts +7 -0
  705. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.d.ts.map +1 -0
  706. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.js +34 -0
  707. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.js.map +1 -0
  708. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts +89 -0
  709. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts.map +1 -0
  710. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.js +2 -0
  711. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.js.map +1 -0
  712. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.d.ts +7 -0
  713. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.d.ts.map +1 -0
  714. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.js +7 -0
  715. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.js.map +1 -0
  716. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +97 -0
  717. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -0
  718. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.js +52 -0
  719. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.js.map +1 -0
  720. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.d.ts +17 -0
  721. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.d.ts.map +1 -0
  722. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.js +24 -0
  723. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.js.map +1 -0
  724. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.d.ts +27 -0
  725. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.d.ts.map +1 -0
  726. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.js +28 -0
  727. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.js.map +1 -0
  728. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.d.ts +42 -0
  729. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.d.ts.map +1 -0
  730. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.js +34 -0
  731. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.js.map +1 -0
  732. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.d.ts +16 -0
  733. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.d.ts.map +1 -0
  734. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.js +22 -0
  735. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.js.map +1 -0
  736. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +48 -0
  737. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -0
  738. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +47 -0
  739. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -0
  740. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +60 -0
  741. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -0
  742. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js +33 -0
  743. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -0
  744. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +68 -0
  745. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -0
  746. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.js +38 -0
  747. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.js.map +1 -0
  748. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.d.ts +14 -0
  749. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.d.ts.map +1 -0
  750. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.js +22 -0
  751. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.js.map +1 -0
  752. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.d.ts +16 -0
  753. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.d.ts.map +1 -0
  754. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.js +22 -0
  755. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.js.map +1 -0
  756. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.d.ts +40 -0
  757. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.d.ts.map +1 -0
  758. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.js +28 -0
  759. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.js.map +1 -0
  760. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.d.ts +21 -0
  761. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.d.ts.map +1 -0
  762. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.js +32 -0
  763. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.js.map +1 -0
  764. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.d.ts +16 -0
  765. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.d.ts.map +1 -0
  766. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.js +22 -0
  767. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.js.map +1 -0
  768. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  769. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  770. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  771. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  772. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.d.ts +25 -0
  773. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.d.ts.map +1 -0
  774. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.js +38 -0
  775. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.js.map +1 -0
  776. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.d.ts +19 -0
  777. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.d.ts.map +1 -0
  778. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.js +28 -0
  779. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.js.map +1 -0
  780. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +61 -0
  781. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -0
  782. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.js +30 -0
  783. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.js.map +1 -0
  784. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.d.ts +17 -0
  785. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.d.ts.map +1 -0
  786. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.js +24 -0
  787. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.js.map +1 -0
  788. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.d.ts +14 -0
  789. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.d.ts.map +1 -0
  790. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.js +18 -0
  791. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.js.map +1 -0
  792. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.d.ts +17 -0
  793. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.d.ts.map +1 -0
  794. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.js +24 -0
  795. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.js.map +1 -0
  796. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.d.ts +12 -0
  797. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.d.ts.map +1 -0
  798. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.js +17 -0
  799. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.js.map +1 -0
  800. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.d.ts +18 -0
  801. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.d.ts.map +1 -0
  802. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.js +26 -0
  803. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.js.map +1 -0
  804. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.d.ts +4 -0
  805. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.d.ts.map +1 -0
  806. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.js +9 -0
  807. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.js.map +1 -0
  808. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +16 -0
  809. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -0
  810. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +174 -0
  811. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -0
  812. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts +18 -0
  813. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -0
  814. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +138 -0
  815. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -0
  816. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.d.ts +26 -0
  817. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.d.ts.map +1 -0
  818. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.js +152 -0
  819. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.js.map +1 -0
  820. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.d.ts +4 -0
  821. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.d.ts.map +1 -0
  822. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.js +19 -0
  823. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.js.map +1 -0
  824. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.d.ts +12 -0
  825. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.d.ts.map +1 -0
  826. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +100 -0
  827. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -0
  828. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.d.ts +9 -0
  829. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.d.ts.map +1 -0
  830. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.js +37 -0
  831. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.js.map +1 -0
  832. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts +16 -0
  833. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -0
  834. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +118 -0
  835. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -0
  836. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.d.ts +11 -0
  837. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.d.ts.map +1 -0
  838. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.js +45 -0
  839. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.js.map +1 -0
  840. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.d.ts +23 -0
  841. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.d.ts.map +1 -0
  842. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.js +26 -0
  843. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.js.map +1 -0
  844. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +15 -0
  845. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -0
  846. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +209 -0
  847. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -0
  848. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +13 -0
  849. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -0
  850. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +82 -0
  851. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -0
  852. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +16 -0
  853. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -0
  854. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +72 -0
  855. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -0
  856. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts +17 -0
  857. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -0
  858. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +123 -0
  859. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -0
  860. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.d.ts +6 -0
  861. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.d.ts.map +1 -0
  862. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.js +28 -0
  863. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.js.map +1 -0
  864. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.d.ts +15 -0
  865. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.d.ts.map +1 -0
  866. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.js +101 -0
  867. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.js.map +1 -0
  868. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.d.ts +11 -0
  869. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.d.ts.map +1 -0
  870. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.js +80 -0
  871. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.js.map +1 -0
  872. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.d.ts +9 -0
  873. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.d.ts.map +1 -0
  874. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.js +52 -0
  875. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.js.map +1 -0
  876. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts +8 -0
  877. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -0
  878. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +68 -0
  879. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -0
  880. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.d.ts +5 -0
  881. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.d.ts.map +1 -0
  882. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.js +30 -0
  883. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.js.map +1 -0
  884. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.d.ts +3 -0
  885. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.d.ts.map +1 -0
  886. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.js +21 -0
  887. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.js.map +1 -0
  888. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.d.ts +2 -0
  889. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.d.ts.map +1 -0
  890. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.js +7 -0
  891. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.js.map +1 -0
  892. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.d.ts +5 -0
  893. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.d.ts.map +1 -0
  894. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +18 -0
  895. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -0
  896. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.d.ts +7 -0
  897. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.d.ts.map +1 -0
  898. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.js +10 -0
  899. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.js.map +1 -0
  900. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.d.ts +3 -0
  901. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.d.ts.map +1 -0
  902. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.js +20 -0
  903. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.js.map +1 -0
  904. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.d.ts +5 -0
  905. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.d.ts.map +1 -0
  906. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +33 -0
  907. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -0
  908. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.d.ts +3 -0
  909. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.d.ts.map +1 -0
  910. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.js +22 -0
  911. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.js.map +1 -0
  912. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.d.ts +5 -0
  913. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.d.ts.map +1 -0
  914. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +18 -0
  915. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -0
  916. package/analyzer-template/packages/github/dist/database/src/lib/supabase.d.ts +4 -0
  917. package/analyzer-template/packages/github/dist/database/src/lib/supabase.d.ts.map +1 -0
  918. package/analyzer-template/packages/github/dist/database/src/lib/supabase.js +57 -0
  919. package/analyzer-template/packages/github/dist/database/src/lib/supabase.js.map +1 -0
  920. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.d.ts +3 -0
  921. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.d.ts.map +1 -0
  922. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.js +61 -0
  923. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.js.map +1 -0
  924. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +13 -0
  925. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -0
  926. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +101 -0
  927. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -0
  928. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.d.ts +3 -0
  929. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.d.ts.map +1 -0
  930. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.js +21 -0
  931. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.js.map +1 -0
  932. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.d.ts +7 -0
  933. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.d.ts.map +1 -0
  934. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.js +42 -0
  935. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.js.map +1 -0
  936. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts +7 -0
  937. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -0
  938. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +42 -0
  939. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -0
  940. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts +10 -0
  941. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -0
  942. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +70 -0
  943. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -0
  944. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.d.ts +10 -0
  945. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.d.ts.map +1 -0
  946. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.js +60 -0
  947. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.js.map +1 -0
  948. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.d.ts +3 -0
  949. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.d.ts.map +1 -0
  950. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.js +53 -0
  951. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.js.map +1 -0
  952. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.d.ts +7 -0
  953. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.d.ts.map +1 -0
  954. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.js +62 -0
  955. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.js.map +1 -0
  956. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.d.ts +3 -0
  957. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.d.ts.map +1 -0
  958. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.js +72 -0
  959. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.js.map +1 -0
  960. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.d.ts +3 -0
  961. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.d.ts.map +1 -0
  962. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.js +22 -0
  963. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.js.map +1 -0
  964. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.d.ts +3 -0
  965. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.d.ts.map +1 -0
  966. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.js +29 -0
  967. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.js.map +1 -0
  968. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.d.ts +3 -0
  969. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.d.ts.map +1 -0
  970. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.js +29 -0
  971. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.js.map +1 -0
  972. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.d.ts +8 -0
  973. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.d.ts.map +1 -0
  974. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.js +41 -0
  975. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.js.map +1 -0
  976. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.d.ts +3 -0
  977. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.d.ts.map +1 -0
  978. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.js +82 -0
  979. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.js.map +1 -0
  980. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.d.ts +3 -0
  981. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.d.ts.map +1 -0
  982. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.js +27 -0
  983. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.js.map +1 -0
  984. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.d.ts +3 -0
  985. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.d.ts.map +1 -0
  986. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.js +32 -0
  987. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.js.map +1 -0
  988. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.d.ts +8 -0
  989. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.d.ts.map +1 -0
  990. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.js +27 -0
  991. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.js.map +1 -0
  992. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.d.ts +3 -0
  993. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.d.ts.map +1 -0
  994. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.js +27 -0
  995. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.js.map +1 -0
  996. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.d.ts +3 -0
  997. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.d.ts.map +1 -0
  998. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.js +28 -0
  999. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.js.map +1 -0
  1000. package/analyzer-template/packages/github/dist/generate/index.d.ts +16 -0
  1001. package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -0
  1002. package/analyzer-template/packages/github/dist/generate/index.js +16 -0
  1003. package/analyzer-template/packages/github/dist/generate/index.js.map +1 -0
  1004. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts +11 -0
  1005. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -0
  1006. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +136 -0
  1007. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -0
  1008. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.d.ts +3 -0
  1009. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.d.ts.map +1 -0
  1010. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js +108 -0
  1011. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js.map +1 -0
  1012. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
  1013. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
  1014. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
  1015. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  1016. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
  1017. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
  1018. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  1019. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  1020. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts +4 -0
  1021. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -0
  1022. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +82 -0
  1023. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -0
  1024. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.d.ts +7 -0
  1025. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.d.ts.map +1 -0
  1026. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.js +134 -0
  1027. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.js.map +1 -0
  1028. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.d.ts +2 -0
  1029. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.d.ts.map +1 -0
  1030. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js +67 -0
  1031. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js.map +1 -0
  1032. package/analyzer-template/packages/github/dist/generate/src/lib/constants.d.ts +2 -0
  1033. package/analyzer-template/packages/github/dist/generate/src/lib/constants.d.ts.map +1 -0
  1034. package/analyzer-template/packages/github/dist/generate/src/lib/constants.js +3 -0
  1035. package/analyzer-template/packages/github/dist/generate/src/lib/constants.js.map +1 -0
  1036. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts +2 -0
  1037. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts.map +1 -0
  1038. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js +72 -0
  1039. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js.map +1 -0
  1040. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.d.ts +14 -0
  1041. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.d.ts.map +1 -0
  1042. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js +165 -0
  1043. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js.map +1 -0
  1044. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.d.ts +2 -0
  1045. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.d.ts.map +1 -0
  1046. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.js +4 -0
  1047. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.js.map +1 -0
  1048. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.d.ts +13 -0
  1049. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.d.ts.map +1 -0
  1050. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.js +23 -0
  1051. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.js.map +1 -0
  1052. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.d.ts +10 -0
  1053. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.d.ts.map +1 -0
  1054. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.js +24 -0
  1055. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.js.map +1 -0
  1056. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.d.ts +4 -0
  1057. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.d.ts.map +1 -0
  1058. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js +25 -0
  1059. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js.map +1 -0
  1060. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.d.ts +2 -0
  1061. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.d.ts.map +1 -0
  1062. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.js +32 -0
  1063. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.js.map +1 -0
  1064. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.d.ts +8 -0
  1065. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.d.ts.map +1 -0
  1066. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.js +50 -0
  1067. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.js.map +1 -0
  1068. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.d.ts +18 -0
  1069. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.d.ts.map +1 -0
  1070. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.js +224 -0
  1071. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.js.map +1 -0
  1072. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.d.ts +3 -0
  1073. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.d.ts.map +1 -0
  1074. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.js +24 -0
  1075. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.js.map +1 -0
  1076. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.d.ts +3 -0
  1077. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.d.ts.map +1 -0
  1078. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.js +160 -0
  1079. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.js.map +1 -0
  1080. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.d.ts +9 -0
  1081. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.d.ts.map +1 -0
  1082. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.js +323 -0
  1083. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.js.map +1 -0
  1084. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.d.ts +11 -0
  1085. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.d.ts.map +1 -0
  1086. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.js +45 -0
  1087. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.js.map +1 -0
  1088. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.d.ts +2 -0
  1089. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.d.ts.map +1 -0
  1090. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.js +11 -0
  1091. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.js.map +1 -0
  1092. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.d.ts +6 -0
  1093. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.d.ts.map +1 -0
  1094. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.js +94 -0
  1095. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.js.map +1 -0
  1096. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
  1097. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
  1098. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
  1099. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  1100. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.d.ts +3 -0
  1101. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.d.ts.map +1 -0
  1102. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.js +73 -0
  1103. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.js.map +1 -0
  1104. package/analyzer-template/packages/github/dist/github/index.d.ts +23 -0
  1105. package/analyzer-template/packages/github/dist/github/index.d.ts.map +1 -0
  1106. package/analyzer-template/packages/github/dist/github/index.js +23 -0
  1107. package/analyzer-template/packages/github/dist/github/index.js.map +1 -0
  1108. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.d.ts +3 -0
  1109. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.d.ts.map +1 -0
  1110. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.js +8 -0
  1111. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.js.map +1 -0
  1112. package/analyzer-template/packages/github/dist/github/src/lib/constants.d.ts +4 -0
  1113. package/analyzer-template/packages/github/dist/github/src/lib/constants.d.ts.map +1 -0
  1114. package/analyzer-template/packages/github/dist/github/src/lib/constants.js +4 -0
  1115. package/analyzer-template/packages/github/dist/github/src/lib/constants.js.map +1 -0
  1116. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.d.ts +5 -0
  1117. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.d.ts.map +1 -0
  1118. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.js +48 -0
  1119. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.js.map +1 -0
  1120. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.d.ts +8 -0
  1121. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.d.ts.map +1 -0
  1122. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.js +11 -0
  1123. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.js.map +1 -0
  1124. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.d.ts +12 -0
  1125. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.d.ts.map +1 -0
  1126. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.js +24 -0
  1127. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.js.map +1 -0
  1128. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.d.ts +6 -0
  1129. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.d.ts.map +1 -0
  1130. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.js +14 -0
  1131. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.js.map +1 -0
  1132. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.d.ts +9 -0
  1133. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.d.ts.map +1 -0
  1134. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.js +12 -0
  1135. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.js.map +1 -0
  1136. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.d.ts +6 -0
  1137. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.d.ts.map +1 -0
  1138. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.js +57 -0
  1139. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.js.map +1 -0
  1140. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.d.ts +12 -0
  1141. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.d.ts.map +1 -0
  1142. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.js +37 -0
  1143. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.js.map +1 -0
  1144. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.d.ts +13 -0
  1145. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.d.ts.map +1 -0
  1146. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.js +163 -0
  1147. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.js.map +1 -0
  1148. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.d.ts +3 -0
  1149. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.d.ts.map +1 -0
  1150. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.js +26 -0
  1151. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.js.map +1 -0
  1152. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.d.ts +12 -0
  1153. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.d.ts.map +1 -0
  1154. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.js +14 -0
  1155. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.js.map +1 -0
  1156. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.d.ts +2 -0
  1157. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.d.ts.map +1 -0
  1158. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.js +22 -0
  1159. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.js.map +1 -0
  1160. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.d.ts +8 -0
  1161. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.d.ts.map +1 -0
  1162. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.js +28 -0
  1163. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.js.map +1 -0
  1164. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.d.ts +9 -0
  1165. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.d.ts.map +1 -0
  1166. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.js +28 -0
  1167. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.js.map +1 -0
  1168. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.d.ts +6 -0
  1169. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.d.ts.map +1 -0
  1170. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.js +12 -0
  1171. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.js.map +1 -0
  1172. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.d.ts +607 -0
  1173. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.d.ts.map +1 -0
  1174. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.js +21 -0
  1175. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.js.map +1 -0
  1176. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.d.ts +20 -0
  1177. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.d.ts.map +1 -0
  1178. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.js +35 -0
  1179. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.js.map +1 -0
  1180. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.d.ts +7 -0
  1181. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.d.ts.map +1 -0
  1182. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.js +53 -0
  1183. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.js.map +1 -0
  1184. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.d.ts +17 -0
  1185. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.d.ts.map +1 -0
  1186. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.js +13 -0
  1187. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.js.map +1 -0
  1188. package/analyzer-template/packages/github/dist/github/src/lib/getTree.d.ts +6 -0
  1189. package/analyzer-template/packages/github/dist/github/src/lib/getTree.d.ts.map +1 -0
  1190. package/analyzer-template/packages/github/dist/github/src/lib/getTree.js +14 -0
  1191. package/analyzer-template/packages/github/dist/github/src/lib/getTree.js.map +1 -0
  1192. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.d.ts +5 -0
  1193. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.d.ts.map +1 -0
  1194. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.js +20 -0
  1195. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.js.map +1 -0
  1196. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.d.ts +11 -0
  1197. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.d.ts.map +1 -0
  1198. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.js +10 -0
  1199. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.js.map +1 -0
  1200. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts +14 -0
  1201. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -0
  1202. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +149 -0
  1203. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -0
  1204. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.d.ts +12 -0
  1205. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.d.ts.map +1 -0
  1206. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.js +74 -0
  1207. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.js.map +1 -0
  1208. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.d.ts +6 -0
  1209. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.d.ts.map +1 -0
  1210. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.js +38 -0
  1211. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.js.map +1 -0
  1212. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts +9 -0
  1213. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -0
  1214. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +75 -0
  1215. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -0
  1216. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.d.ts +27 -0
  1217. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.d.ts.map +1 -0
  1218. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.js +48 -0
  1219. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.js.map +1 -0
  1220. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.d.ts +9 -0
  1221. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.d.ts.map +1 -0
  1222. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.js +26 -0
  1223. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.js.map +1 -0
  1224. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.d.ts +7 -0
  1225. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.d.ts.map +1 -0
  1226. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.js +40 -0
  1227. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.js.map +1 -0
  1228. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.d.ts +13 -0
  1229. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.d.ts.map +1 -0
  1230. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.js +74 -0
  1231. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.js.map +1 -0
  1232. package/analyzer-template/packages/github/dist/github/src/lib/urls.d.ts +11 -0
  1233. package/analyzer-template/packages/github/dist/github/src/lib/urls.d.ts.map +1 -0
  1234. package/analyzer-template/packages/github/dist/github/src/lib/urls.js +11 -0
  1235. package/analyzer-template/packages/github/dist/github/src/lib/urls.js.map +1 -0
  1236. package/analyzer-template/packages/github/dist/types/index.d.ts +47 -0
  1237. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -0
  1238. package/analyzer-template/packages/github/dist/types/index.js +4 -0
  1239. package/analyzer-template/packages/github/dist/types/index.js.map +1 -0
  1240. package/analyzer-template/packages/github/dist/types/src/constants.d.ts +2 -0
  1241. package/analyzer-template/packages/github/dist/types/src/constants.d.ts.map +1 -0
  1242. package/analyzer-template/packages/github/dist/types/src/constants.js +2 -0
  1243. package/analyzer-template/packages/github/dist/types/src/constants.js.map +1 -0
  1244. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +9 -0
  1245. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -0
  1246. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +10 -0
  1247. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -0
  1248. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +207 -0
  1249. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -0
  1250. package/analyzer-template/packages/github/dist/types/src/types/Analysis.js +3 -0
  1251. package/analyzer-template/packages/github/dist/types/src/types/Analysis.js.map +1 -0
  1252. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.d.ts +15 -0
  1253. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.d.ts.map +1 -0
  1254. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.js +2 -0
  1255. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.js.map +1 -0
  1256. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.d.ts +12 -0
  1257. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.d.ts.map +1 -0
  1258. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.js +2 -0
  1259. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.js.map +1 -0
  1260. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.d.ts +19 -0
  1261. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.d.ts.map +1 -0
  1262. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.js +2 -0
  1263. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.js.map +1 -0
  1264. package/analyzer-template/packages/github/dist/types/src/types/Branch.d.ts +43 -0
  1265. package/analyzer-template/packages/github/dist/types/src/types/Branch.d.ts.map +1 -0
  1266. package/analyzer-template/packages/github/dist/types/src/types/Branch.js +2 -0
  1267. package/analyzer-template/packages/github/dist/types/src/types/Branch.js.map +1 -0
  1268. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.d.ts +4 -0
  1269. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.d.ts.map +1 -0
  1270. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.js +2 -0
  1271. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.js.map +1 -0
  1272. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +88 -0
  1273. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -0
  1274. package/analyzer-template/packages/github/dist/types/src/types/Commit.js +2 -0
  1275. package/analyzer-template/packages/github/dist/types/src/types/Commit.js.map +1 -0
  1276. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.d.ts +11 -0
  1277. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.d.ts.map +1 -0
  1278. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.js +2 -0
  1279. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.js.map +1 -0
  1280. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.d.ts +9 -0
  1281. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.d.ts.map +1 -0
  1282. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.js +2 -0
  1283. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.js.map +1 -0
  1284. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.d.ts +4 -0
  1285. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.d.ts.map +1 -0
  1286. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.js +2 -0
  1287. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.js.map +1 -0
  1288. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.d.ts +4 -0
  1289. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.d.ts.map +1 -0
  1290. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.js +2 -0
  1291. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.js.map +1 -0
  1292. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.d.ts +8 -0
  1293. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.d.ts.map +1 -0
  1294. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.js +2 -0
  1295. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.js.map +1 -0
  1296. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +100 -0
  1297. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -0
  1298. package/analyzer-template/packages/github/dist/types/src/types/Entity.js +2 -0
  1299. package/analyzer-template/packages/github/dist/types/src/types/Entity.js.map +1 -0
  1300. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.d.ts +8 -0
  1301. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.d.ts.map +1 -0
  1302. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.js +2 -0
  1303. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.js.map +1 -0
  1304. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.d.ts +7 -0
  1305. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.d.ts.map +1 -0
  1306. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.js +2 -0
  1307. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.js.map +1 -0
  1308. package/analyzer-template/packages/github/dist/types/src/types/EntityType.d.ts +2 -0
  1309. package/analyzer-template/packages/github/dist/types/src/types/EntityType.d.ts.map +1 -0
  1310. package/analyzer-template/packages/github/dist/types/src/types/EntityType.js +2 -0
  1311. package/analyzer-template/packages/github/dist/types/src/types/EntityType.js.map +1 -0
  1312. package/analyzer-template/packages/github/dist/types/src/types/File.d.ts +45 -0
  1313. package/analyzer-template/packages/github/dist/types/src/types/File.d.ts.map +1 -0
  1314. package/analyzer-template/packages/github/dist/types/src/types/File.js +2 -0
  1315. package/analyzer-template/packages/github/dist/types/src/types/File.js.map +1 -0
  1316. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.d.ts +7 -0
  1317. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.d.ts.map +1 -0
  1318. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.js +2 -0
  1319. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.js.map +1 -0
  1320. package/analyzer-template/packages/github/dist/types/src/types/FileProp.d.ts +8 -0
  1321. package/analyzer-template/packages/github/dist/types/src/types/FileProp.d.ts.map +1 -0
  1322. package/analyzer-template/packages/github/dist/types/src/types/FileProp.js +2 -0
  1323. package/analyzer-template/packages/github/dist/types/src/types/FileProp.js.map +1 -0
  1324. package/analyzer-template/packages/github/dist/types/src/types/FileType.d.ts +2 -0
  1325. package/analyzer-template/packages/github/dist/types/src/types/FileType.d.ts.map +1 -0
  1326. package/analyzer-template/packages/github/dist/types/src/types/FileType.js +2 -0
  1327. package/analyzer-template/packages/github/dist/types/src/types/FileType.js.map +1 -0
  1328. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.d.ts +7 -0
  1329. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.d.ts.map +1 -0
  1330. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.js +2 -0
  1331. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.js.map +1 -0
  1332. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.d.ts +9 -0
  1333. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.d.ts.map +1 -0
  1334. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.js +2 -0
  1335. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.js.map +1 -0
  1336. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.d.ts +9 -0
  1337. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.d.ts.map +1 -0
  1338. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.js +2 -0
  1339. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.js.map +1 -0
  1340. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.d.ts +15 -0
  1341. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.d.ts.map +1 -0
  1342. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.js +2 -0
  1343. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.js.map +1 -0
  1344. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.d.ts +4 -0
  1345. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.d.ts.map +1 -0
  1346. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.js +2 -0
  1347. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.js.map +1 -0
  1348. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.d.ts +5 -0
  1349. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.d.ts.map +1 -0
  1350. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.js +2 -0
  1351. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.js.map +1 -0
  1352. package/analyzer-template/packages/github/dist/types/src/types/Mock.d.ts +35 -0
  1353. package/analyzer-template/packages/github/dist/types/src/types/Mock.d.ts.map +1 -0
  1354. package/analyzer-template/packages/github/dist/types/src/types/Mock.js +2 -0
  1355. package/analyzer-template/packages/github/dist/types/src/types/Mock.js.map +1 -0
  1356. package/analyzer-template/packages/github/dist/types/src/types/Project.d.ts +26 -0
  1357. package/analyzer-template/packages/github/dist/types/src/types/Project.d.ts.map +1 -0
  1358. package/analyzer-template/packages/github/dist/types/src/types/Project.js +2 -0
  1359. package/analyzer-template/packages/github/dist/types/src/types/Project.js.map +1 -0
  1360. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +53 -0
  1361. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -0
  1362. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.js +2 -0
  1363. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.js.map +1 -0
  1364. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.d.ts +8 -0
  1365. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.d.ts.map +1 -0
  1366. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.js +2 -0
  1367. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.js.map +1 -0
  1368. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +117 -0
  1369. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -0
  1370. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js +2 -0
  1371. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js.map +1 -0
  1372. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.d.ts +12 -0
  1373. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.d.ts.map +1 -0
  1374. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.js +2 -0
  1375. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.js.map +1 -0
  1376. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.d.ts +13 -0
  1377. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.d.ts.map +1 -0
  1378. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.js +2 -0
  1379. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.js.map +1 -0
  1380. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +270 -0
  1381. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -0
  1382. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.js +2 -0
  1383. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.js.map +1 -0
  1384. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +18 -0
  1385. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -0
  1386. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.js +2 -0
  1387. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.js.map +1 -0
  1388. package/analyzer-template/packages/github/dist/types/src/types/Statement.d.ts +11 -0
  1389. package/analyzer-template/packages/github/dist/types/src/types/Statement.d.ts.map +1 -0
  1390. package/analyzer-template/packages/github/dist/types/src/types/Statement.js +2 -0
  1391. package/analyzer-template/packages/github/dist/types/src/types/Statement.js.map +1 -0
  1392. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +14 -0
  1393. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -0
  1394. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.js +2 -0
  1395. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.js.map +1 -0
  1396. package/analyzer-template/packages/github/dist/types/src/types/Team.d.ts +5 -0
  1397. package/analyzer-template/packages/github/dist/types/src/types/Team.d.ts.map +1 -0
  1398. package/analyzer-template/packages/github/dist/types/src/types/Team.js +2 -0
  1399. package/analyzer-template/packages/github/dist/types/src/types/Team.js.map +1 -0
  1400. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.d.ts +17 -0
  1401. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.d.ts.map +1 -0
  1402. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.js +2 -0
  1403. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.js.map +1 -0
  1404. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.d.ts +2 -0
  1405. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.d.ts.map +1 -0
  1406. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.js +2 -0
  1407. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.js.map +1 -0
  1408. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.d.ts +5 -0
  1409. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.d.ts.map +1 -0
  1410. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.js +2 -0
  1411. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.js.map +1 -0
  1412. package/analyzer-template/packages/github/dist/types/src/types/User.d.ts +7 -0
  1413. package/analyzer-template/packages/github/dist/types/src/types/User.d.ts.map +1 -0
  1414. package/analyzer-template/packages/github/dist/types/src/types/User.js +2 -0
  1415. package/analyzer-template/packages/github/dist/types/src/types/User.js.map +1 -0
  1416. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.d.ts +10 -0
  1417. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.d.ts.map +1 -0
  1418. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.js +2 -0
  1419. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.js.map +1 -0
  1420. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.d.ts +14 -0
  1421. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.d.ts.map +1 -0
  1422. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.js +2 -0
  1423. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.js.map +1 -0
  1424. package/analyzer-template/packages/github/dist/utils/index.d.ts +24 -0
  1425. package/analyzer-template/packages/github/dist/utils/index.d.ts.map +1 -0
  1426. package/analyzer-template/packages/github/dist/utils/index.js +31 -0
  1427. package/analyzer-template/packages/github/dist/utils/index.js.map +1 -0
  1428. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.d.ts +25 -0
  1429. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.d.ts.map +1 -0
  1430. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.js +40 -0
  1431. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.js.map +1 -0
  1432. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.d.ts +12 -0
  1433. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.d.ts.map +1 -0
  1434. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.js +10 -0
  1435. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.js.map +1 -0
  1436. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.d.ts +61 -0
  1437. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -0
  1438. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js +288 -0
  1439. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js.map +1 -0
  1440. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.d.ts +8 -0
  1441. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.d.ts.map +1 -0
  1442. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.js +48 -0
  1443. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.js.map +1 -0
  1444. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts +15 -0
  1445. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts.map +1 -0
  1446. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +25 -0
  1447. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -0
  1448. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts +15 -0
  1449. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts.map +1 -0
  1450. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js +29 -0
  1451. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js.map +1 -0
  1452. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts +13 -0
  1453. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts.map +1 -0
  1454. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.js +22 -0
  1455. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.js.map +1 -0
  1456. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts +13 -0
  1457. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts.map +1 -0
  1458. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.js +20 -0
  1459. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.js.map +1 -0
  1460. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts +3 -0
  1461. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts.map +1 -0
  1462. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.js +7 -0
  1463. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.js.map +1 -0
  1464. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.d.ts +3 -0
  1465. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.d.ts.map +1 -0
  1466. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.js +12 -0
  1467. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.js.map +1 -0
  1468. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.d.ts +3 -0
  1469. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.d.ts.map +1 -0
  1470. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.js +8 -0
  1471. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.js.map +1 -0
  1472. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts +14 -0
  1473. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts.map +1 -0
  1474. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +26 -0
  1475. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -0
  1476. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts +3 -0
  1477. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts.map +1 -0
  1478. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js +22 -0
  1479. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js.map +1 -0
  1480. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts +21 -0
  1481. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts.map +1 -0
  1482. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +62 -0
  1483. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -0
  1484. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.d.ts +16 -0
  1485. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.d.ts.map +1 -0
  1486. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.js +64 -0
  1487. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.js.map +1 -0
  1488. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.d.ts +32 -0
  1489. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -0
  1490. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js +362 -0
  1491. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -0
  1492. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.d.ts +2 -0
  1493. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.d.ts.map +1 -0
  1494. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.js +4 -0
  1495. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.js.map +1 -0
  1496. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +10 -0
  1497. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -0
  1498. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +36 -0
  1499. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -0
  1500. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.d.ts +2 -0
  1501. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.d.ts.map +1 -0
  1502. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.js +64 -0
  1503. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.js.map +1 -0
  1504. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.d.ts +18 -0
  1505. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.d.ts.map +1 -0
  1506. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  1507. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  1508. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.d.ts +26 -0
  1509. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.d.ts.map +1 -0
  1510. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  1511. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  1512. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.d.ts +3 -0
  1513. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.d.ts.map +1 -0
  1514. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.js +3 -0
  1515. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.js.map +1 -0
  1516. package/analyzer-template/packages/github/index.ts +25 -0
  1517. package/analyzer-template/packages/github/package.json +21 -0
  1518. package/analyzer-template/packages/github/src/lib/__mocks__/createProjectOctokit.ts +10 -0
  1519. package/analyzer-template/packages/github/src/lib/constants.ts +3 -0
  1520. package/analyzer-template/packages/github/src/lib/createProjectOctokit.ts +58 -0
  1521. package/analyzer-template/packages/github/src/lib/getBranch.ts +29 -0
  1522. package/analyzer-template/packages/github/src/lib/getBranchCommits.ts +44 -0
  1523. package/analyzer-template/packages/github/src/lib/getBranches.ts +28 -0
  1524. package/analyzer-template/packages/github/src/lib/getCommit.ts +25 -0
  1525. package/analyzer-template/packages/github/src/lib/getCommitFromGithub.ts +67 -0
  1526. package/analyzer-template/packages/github/src/lib/getCommits.ts +57 -0
  1527. package/analyzer-template/packages/github/src/lib/getCommitsFromGithub.ts +239 -0
  1528. package/analyzer-template/packages/github/src/lib/getDiffBetweenCommits.ts +37 -0
  1529. package/analyzer-template/packages/github/src/lib/getFileContent.ts +42 -0
  1530. package/analyzer-template/packages/github/src/lib/getFirstCommitShaAfterTimestamp.ts +26 -0
  1531. package/analyzer-template/packages/github/src/lib/getLatestCommit.ts +41 -0
  1532. package/analyzer-template/packages/github/src/lib/getOpenPullRequests.ts +39 -0
  1533. package/analyzer-template/packages/github/src/lib/getPublicReposWithQuery.ts +21 -0
  1534. package/analyzer-template/packages/github/src/lib/getPullRequestsForCommit.ts +30 -0
  1535. package/analyzer-template/packages/github/src/lib/getRepoInfo.ts +56 -0
  1536. package/analyzer-template/packages/github/src/lib/getRepoWithBranches.ts +73 -0
  1537. package/analyzer-template/packages/github/src/lib/getRepos.ts +35 -0
  1538. package/analyzer-template/packages/github/src/lib/getTree.ts +29 -0
  1539. package/analyzer-template/packages/github/src/lib/githubToCommit.ts +25 -0
  1540. package/analyzer-template/packages/github/src/lib/listCommitsSince.ts +21 -0
  1541. package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +214 -0
  1542. package/analyzer-template/packages/github/src/lib/syncBranches.ts +105 -0
  1543. package/analyzer-template/packages/github/src/lib/syncHeadBranches.ts +54 -0
  1544. package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +95 -0
  1545. package/analyzer-template/packages/github/src/lib/syncPullRequest.ts +87 -0
  1546. package/analyzer-template/packages/github/src/lib/syncRepo.ts +35 -0
  1547. package/analyzer-template/packages/github/src/lib/updateCommitBranchesInDb.ts +66 -0
  1548. package/analyzer-template/packages/github/src/lib/updateFilesInDb.ts +111 -0
  1549. package/analyzer-template/packages/github/src/lib/urls.ts +29 -0
  1550. package/analyzer-template/packages/github/tsconfig.json +11 -0
  1551. package/analyzer-template/packages/process/index.ts +2 -0
  1552. package/analyzer-template/packages/process/package.json +12 -0
  1553. package/analyzer-template/packages/process/src/GlobalProcessManager.ts +93 -0
  1554. package/analyzer-template/packages/process/src/ProcessManager.ts +350 -0
  1555. package/analyzer-template/packages/process/src/index.ts +75 -0
  1556. package/analyzer-template/packages/process/src/managedExecAsync.ts +154 -0
  1557. package/analyzer-template/packages/process/tsconfig.json +8 -0
  1558. package/analyzer-template/packages/types/index.ts +90 -0
  1559. package/analyzer-template/packages/types/package.json +12 -0
  1560. package/analyzer-template/packages/types/src/constants.ts +1 -0
  1561. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +8 -0
  1562. package/analyzer-template/packages/types/src/types/Analysis.ts +229 -0
  1563. package/analyzer-template/packages/types/src/types/AnalysisBranch.ts +16 -0
  1564. package/analyzer-template/packages/types/src/types/AnalysisMap.ts +9 -0
  1565. package/analyzer-template/packages/types/src/types/BackgroundJob.ts +18 -0
  1566. package/analyzer-template/packages/types/src/types/Branch.ts +43 -0
  1567. package/analyzer-template/packages/types/src/types/CodeExplanation.ts +3 -0
  1568. package/analyzer-template/packages/types/src/types/Commit.ts +94 -0
  1569. package/analyzer-template/packages/types/src/types/CommitBranch.ts +11 -0
  1570. package/analyzer-template/packages/types/src/types/CommitChange.ts +9 -0
  1571. package/analyzer-template/packages/types/src/types/DeepPartial.ts +8 -0
  1572. package/analyzer-template/packages/types/src/types/DeepReadonly.ts +8 -0
  1573. package/analyzer-template/packages/types/src/types/DependencyTreeNode.ts +3 -0
  1574. package/analyzer-template/packages/types/src/types/Entity.ts +116 -0
  1575. package/analyzer-template/packages/types/src/types/EntityBranch.ts +8 -0
  1576. package/analyzer-template/packages/types/src/types/EntityMap.ts +5 -0
  1577. package/analyzer-template/packages/types/src/types/EntityType.ts +10 -0
  1578. package/analyzer-template/packages/types/src/types/File.ts +41 -0
  1579. package/analyzer-template/packages/types/src/types/FilePreMock.ts +7 -0
  1580. package/analyzer-template/packages/types/src/types/FileProp.ts +8 -0
  1581. package/analyzer-template/packages/types/src/types/FileType.ts +12 -0
  1582. package/analyzer-template/packages/types/src/types/GithubBranch.ts +7 -0
  1583. package/analyzer-template/packages/types/src/types/GithubFile.ts +8 -0
  1584. package/analyzer-template/packages/types/src/types/GithubRepoData.ts +9 -0
  1585. package/analyzer-template/packages/types/src/types/GithubRepoInfo.ts +16 -0
  1586. package/analyzer-template/packages/types/src/types/JsonTypeDefinition.ts +3 -0
  1587. package/analyzer-template/packages/types/src/types/LlmCall.ts +1 -0
  1588. package/analyzer-template/packages/types/src/types/Mock.ts +28 -0
  1589. package/analyzer-template/packages/types/src/types/Project.ts +26 -0
  1590. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +56 -0
  1591. package/analyzer-template/packages/types/src/types/PropsWithTypes.ts +8 -0
  1592. package/analyzer-template/packages/types/src/types/Scenario.ts +110 -0
  1593. package/analyzer-template/packages/types/src/types/ScenarioComment.ts +12 -0
  1594. package/analyzer-template/packages/types/src/types/ScenarioData.ts +8 -0
  1595. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +277 -0
  1596. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +14 -0
  1597. package/analyzer-template/packages/types/src/types/Statement.ts +11 -0
  1598. package/analyzer-template/packages/types/src/types/StatementInfo.ts +13 -0
  1599. package/analyzer-template/packages/types/src/types/Team.ts +4 -0
  1600. package/analyzer-template/packages/types/src/types/TimelineItem.ts +16 -0
  1601. package/analyzer-template/packages/types/src/types/TsConfigPaths.ts +1 -0
  1602. package/analyzer-template/packages/types/src/types/TypeStructures.ts +5 -0
  1603. package/analyzer-template/packages/types/src/types/User.ts +6 -0
  1604. package/analyzer-template/packages/types/src/types/UserScenario.ts +10 -0
  1605. package/analyzer-template/packages/types/src/types/WebContainerFileSystemTree.ts +15 -0
  1606. package/analyzer-template/packages/types/tsconfig.json +10 -0
  1607. package/analyzer-template/packages/ui-components/README.md +235 -0
  1608. package/analyzer-template/packages/ui-components/package.json +37 -0
  1609. package/analyzer-template/packages/ui-components/src/components/ResizeControlBar.tsx +313 -0
  1610. package/analyzer-template/packages/ui-components/src/components/ScenarioDetailInteractiveView.tsx +322 -0
  1611. package/analyzer-template/packages/ui-components/src/components/ScenarioPreview.tsx +232 -0
  1612. package/analyzer-template/packages/ui-components/src/components/ScenarioThumbnails.tsx +82 -0
  1613. package/analyzer-template/packages/ui-components/src/components/ScreenSizeSelector.tsx +45 -0
  1614. package/analyzer-template/packages/ui-components/src/index.tsx +61 -0
  1615. package/analyzer-template/packages/ui-components/src/providers/WebContainerProvider.tsx +105 -0
  1616. package/analyzer-template/packages/ui-components/src/scenario-editor/components/AIDataGeneratorForm.tsx +139 -0
  1617. package/analyzer-template/packages/ui-components/src/scenario-editor/components/BooleanSwitch.tsx +42 -0
  1618. package/analyzer-template/packages/ui-components/src/scenario-editor/components/DataItemEditor.tsx +132 -0
  1619. package/analyzer-template/packages/ui-components/src/scenario-editor/components/DataItemLink.tsx +80 -0
  1620. package/analyzer-template/packages/ui-components/src/scenario-editor/components/DataItemNavigation.tsx +107 -0
  1621. package/analyzer-template/packages/ui-components/src/scenario-editor/components/InputField.tsx +67 -0
  1622. package/analyzer-template/packages/ui-components/src/scenario-editor/components/ScenarioEditor.tsx +401 -0
  1623. package/analyzer-template/packages/ui-components/src/scenario-editor/components/ScenarioNameForm.tsx +52 -0
  1624. package/analyzer-template/packages/ui-components/src/scenario-editor/components/SectionExpand.tsx +55 -0
  1625. package/analyzer-template/packages/ui-components/src/scenario-editor/components/UnionTypeOptionDropdown.tsx +38 -0
  1626. package/analyzer-template/packages/ui-components/src/scenario-editor/index.ts +35 -0
  1627. package/analyzer-template/packages/ui-components/src/scenario-editor/types.ts +127 -0
  1628. package/analyzer-template/packages/ui-components/src/scenario-editor/utils.ts +72 -0
  1629. package/analyzer-template/packages/ui-components/tsconfig.json +23 -0
  1630. package/analyzer-template/packages/utils/dist/types/index.d.ts +47 -0
  1631. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -0
  1632. package/analyzer-template/packages/utils/dist/types/index.js +4 -0
  1633. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -0
  1634. package/analyzer-template/packages/utils/dist/types/src/constants.d.ts +2 -0
  1635. package/analyzer-template/packages/utils/dist/types/src/constants.d.ts.map +1 -0
  1636. package/analyzer-template/packages/utils/dist/types/src/constants.js +2 -0
  1637. package/analyzer-template/packages/utils/dist/types/src/constants.js.map +1 -0
  1638. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +9 -0
  1639. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -0
  1640. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +10 -0
  1641. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -0
  1642. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +207 -0
  1643. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -0
  1644. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.js +3 -0
  1645. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.js.map +1 -0
  1646. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.d.ts +15 -0
  1647. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.d.ts.map +1 -0
  1648. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.js +2 -0
  1649. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.js.map +1 -0
  1650. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.d.ts +12 -0
  1651. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.d.ts.map +1 -0
  1652. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.js +2 -0
  1653. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.js.map +1 -0
  1654. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.d.ts +19 -0
  1655. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.d.ts.map +1 -0
  1656. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.js +2 -0
  1657. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.js.map +1 -0
  1658. package/analyzer-template/packages/utils/dist/types/src/types/Branch.d.ts +43 -0
  1659. package/analyzer-template/packages/utils/dist/types/src/types/Branch.d.ts.map +1 -0
  1660. package/analyzer-template/packages/utils/dist/types/src/types/Branch.js +2 -0
  1661. package/analyzer-template/packages/utils/dist/types/src/types/Branch.js.map +1 -0
  1662. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.d.ts +4 -0
  1663. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.d.ts.map +1 -0
  1664. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.js +2 -0
  1665. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.js.map +1 -0
  1666. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +88 -0
  1667. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -0
  1668. package/analyzer-template/packages/utils/dist/types/src/types/Commit.js +2 -0
  1669. package/analyzer-template/packages/utils/dist/types/src/types/Commit.js.map +1 -0
  1670. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.d.ts +11 -0
  1671. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.d.ts.map +1 -0
  1672. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.js +2 -0
  1673. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.js.map +1 -0
  1674. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.d.ts +9 -0
  1675. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.d.ts.map +1 -0
  1676. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.js +2 -0
  1677. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.js.map +1 -0
  1678. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.d.ts +4 -0
  1679. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.d.ts.map +1 -0
  1680. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.js +2 -0
  1681. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.js.map +1 -0
  1682. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.d.ts +4 -0
  1683. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.d.ts.map +1 -0
  1684. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.js +2 -0
  1685. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.js.map +1 -0
  1686. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.d.ts +8 -0
  1687. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.d.ts.map +1 -0
  1688. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.js +2 -0
  1689. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.js.map +1 -0
  1690. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +100 -0
  1691. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -0
  1692. package/analyzer-template/packages/utils/dist/types/src/types/Entity.js +2 -0
  1693. package/analyzer-template/packages/utils/dist/types/src/types/Entity.js.map +1 -0
  1694. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.d.ts +8 -0
  1695. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.d.ts.map +1 -0
  1696. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.js +2 -0
  1697. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.js.map +1 -0
  1698. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.d.ts +7 -0
  1699. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.d.ts.map +1 -0
  1700. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.js +2 -0
  1701. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.js.map +1 -0
  1702. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.d.ts +2 -0
  1703. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.d.ts.map +1 -0
  1704. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.js +2 -0
  1705. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.js.map +1 -0
  1706. package/analyzer-template/packages/utils/dist/types/src/types/File.d.ts +45 -0
  1707. package/analyzer-template/packages/utils/dist/types/src/types/File.d.ts.map +1 -0
  1708. package/analyzer-template/packages/utils/dist/types/src/types/File.js +2 -0
  1709. package/analyzer-template/packages/utils/dist/types/src/types/File.js.map +1 -0
  1710. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.d.ts +7 -0
  1711. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.d.ts.map +1 -0
  1712. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.js +2 -0
  1713. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.js.map +1 -0
  1714. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.d.ts +8 -0
  1715. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.d.ts.map +1 -0
  1716. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.js +2 -0
  1717. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.js.map +1 -0
  1718. package/analyzer-template/packages/utils/dist/types/src/types/FileType.d.ts +2 -0
  1719. package/analyzer-template/packages/utils/dist/types/src/types/FileType.d.ts.map +1 -0
  1720. package/analyzer-template/packages/utils/dist/types/src/types/FileType.js +2 -0
  1721. package/analyzer-template/packages/utils/dist/types/src/types/FileType.js.map +1 -0
  1722. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.d.ts +7 -0
  1723. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.d.ts.map +1 -0
  1724. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.js +2 -0
  1725. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.js.map +1 -0
  1726. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.d.ts +9 -0
  1727. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.d.ts.map +1 -0
  1728. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.js +2 -0
  1729. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.js.map +1 -0
  1730. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.d.ts +9 -0
  1731. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.d.ts.map +1 -0
  1732. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.js +2 -0
  1733. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.js.map +1 -0
  1734. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.d.ts +15 -0
  1735. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.d.ts.map +1 -0
  1736. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.js +2 -0
  1737. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.js.map +1 -0
  1738. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.d.ts +4 -0
  1739. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.d.ts.map +1 -0
  1740. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.js +2 -0
  1741. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.js.map +1 -0
  1742. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.d.ts +5 -0
  1743. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.d.ts.map +1 -0
  1744. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.js +2 -0
  1745. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.js.map +1 -0
  1746. package/analyzer-template/packages/utils/dist/types/src/types/Mock.d.ts +35 -0
  1747. package/analyzer-template/packages/utils/dist/types/src/types/Mock.d.ts.map +1 -0
  1748. package/analyzer-template/packages/utils/dist/types/src/types/Mock.js +2 -0
  1749. package/analyzer-template/packages/utils/dist/types/src/types/Mock.js.map +1 -0
  1750. package/analyzer-template/packages/utils/dist/types/src/types/Project.d.ts +26 -0
  1751. package/analyzer-template/packages/utils/dist/types/src/types/Project.d.ts.map +1 -0
  1752. package/analyzer-template/packages/utils/dist/types/src/types/Project.js +2 -0
  1753. package/analyzer-template/packages/utils/dist/types/src/types/Project.js.map +1 -0
  1754. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +53 -0
  1755. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -0
  1756. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.js +2 -0
  1757. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.js.map +1 -0
  1758. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.d.ts +8 -0
  1759. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.d.ts.map +1 -0
  1760. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.js +2 -0
  1761. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.js.map +1 -0
  1762. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +117 -0
  1763. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -0
  1764. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js +2 -0
  1765. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js.map +1 -0
  1766. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.d.ts +12 -0
  1767. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.d.ts.map +1 -0
  1768. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.js +2 -0
  1769. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.js.map +1 -0
  1770. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.d.ts +13 -0
  1771. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.d.ts.map +1 -0
  1772. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.js +2 -0
  1773. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.js.map +1 -0
  1774. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +270 -0
  1775. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -0
  1776. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.js +2 -0
  1777. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.js.map +1 -0
  1778. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +18 -0
  1779. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -0
  1780. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.js +2 -0
  1781. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.js.map +1 -0
  1782. package/analyzer-template/packages/utils/dist/types/src/types/Statement.d.ts +11 -0
  1783. package/analyzer-template/packages/utils/dist/types/src/types/Statement.d.ts.map +1 -0
  1784. package/analyzer-template/packages/utils/dist/types/src/types/Statement.js +2 -0
  1785. package/analyzer-template/packages/utils/dist/types/src/types/Statement.js.map +1 -0
  1786. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +14 -0
  1787. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -0
  1788. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.js +2 -0
  1789. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.js.map +1 -0
  1790. package/analyzer-template/packages/utils/dist/types/src/types/Team.d.ts +5 -0
  1791. package/analyzer-template/packages/utils/dist/types/src/types/Team.d.ts.map +1 -0
  1792. package/analyzer-template/packages/utils/dist/types/src/types/Team.js +2 -0
  1793. package/analyzer-template/packages/utils/dist/types/src/types/Team.js.map +1 -0
  1794. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.d.ts +17 -0
  1795. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.d.ts.map +1 -0
  1796. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.js +2 -0
  1797. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.js.map +1 -0
  1798. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.d.ts +2 -0
  1799. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.d.ts.map +1 -0
  1800. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.js +2 -0
  1801. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.js.map +1 -0
  1802. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.d.ts +5 -0
  1803. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.d.ts.map +1 -0
  1804. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.js +2 -0
  1805. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.js.map +1 -0
  1806. package/analyzer-template/packages/utils/dist/types/src/types/User.d.ts +7 -0
  1807. package/analyzer-template/packages/utils/dist/types/src/types/User.d.ts.map +1 -0
  1808. package/analyzer-template/packages/utils/dist/types/src/types/User.js +2 -0
  1809. package/analyzer-template/packages/utils/dist/types/src/types/User.js.map +1 -0
  1810. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.d.ts +10 -0
  1811. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.d.ts.map +1 -0
  1812. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.js +2 -0
  1813. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.js.map +1 -0
  1814. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.d.ts +14 -0
  1815. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.d.ts.map +1 -0
  1816. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.js +2 -0
  1817. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.js.map +1 -0
  1818. package/analyzer-template/packages/utils/dist/utils/index.d.ts +24 -0
  1819. package/analyzer-template/packages/utils/dist/utils/index.d.ts.map +1 -0
  1820. package/analyzer-template/packages/utils/dist/utils/index.js +31 -0
  1821. package/analyzer-template/packages/utils/dist/utils/index.js.map +1 -0
  1822. package/analyzer-template/packages/utils/dist/utils/server.d.ts +12 -0
  1823. package/analyzer-template/packages/utils/dist/utils/server.d.ts.map +1 -0
  1824. package/analyzer-template/packages/utils/dist/utils/server.js +13 -0
  1825. package/analyzer-template/packages/utils/dist/utils/server.js.map +1 -0
  1826. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.d.ts +25 -0
  1827. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.d.ts.map +1 -0
  1828. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.js +40 -0
  1829. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.js.map +1 -0
  1830. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.d.ts +2 -0
  1831. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.d.ts.map +1 -0
  1832. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.js +5 -0
  1833. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.js.map +1 -0
  1834. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.d.ts +12 -0
  1835. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.d.ts.map +1 -0
  1836. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.js +10 -0
  1837. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.js.map +1 -0
  1838. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.d.ts +61 -0
  1839. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -0
  1840. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js +288 -0
  1841. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js.map +1 -0
  1842. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.d.ts +8 -0
  1843. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.d.ts.map +1 -0
  1844. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.js +48 -0
  1845. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.js.map +1 -0
  1846. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.d.ts +3 -0
  1847. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.d.ts.map +1 -0
  1848. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.js +14 -0
  1849. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.js.map +1 -0
  1850. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.d.ts +34 -0
  1851. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.d.ts.map +1 -0
  1852. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.js +217 -0
  1853. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.js.map +1 -0
  1854. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.d.ts +3 -0
  1855. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.d.ts.map +1 -0
  1856. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.js +3 -0
  1857. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.js.map +1 -0
  1858. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.d.ts +25 -0
  1859. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.d.ts.map +1 -0
  1860. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.js +145 -0
  1861. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.js.map +1 -0
  1862. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts +15 -0
  1863. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts.map +1 -0
  1864. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +25 -0
  1865. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -0
  1866. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts +15 -0
  1867. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts.map +1 -0
  1868. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js +29 -0
  1869. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js.map +1 -0
  1870. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts +13 -0
  1871. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts.map +1 -0
  1872. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.js +22 -0
  1873. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.js.map +1 -0
  1874. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts +13 -0
  1875. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts.map +1 -0
  1876. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.js +20 -0
  1877. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.js.map +1 -0
  1878. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts +3 -0
  1879. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts.map +1 -0
  1880. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.js +7 -0
  1881. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.js.map +1 -0
  1882. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.d.ts +3 -0
  1883. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.d.ts.map +1 -0
  1884. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.js +12 -0
  1885. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.js.map +1 -0
  1886. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.d.ts +3 -0
  1887. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.d.ts.map +1 -0
  1888. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.js +8 -0
  1889. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.js.map +1 -0
  1890. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts +14 -0
  1891. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts.map +1 -0
  1892. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +26 -0
  1893. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -0
  1894. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts +3 -0
  1895. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts.map +1 -0
  1896. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js +22 -0
  1897. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js.map +1 -0
  1898. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts +21 -0
  1899. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts.map +1 -0
  1900. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +62 -0
  1901. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -0
  1902. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.d.ts +9 -0
  1903. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.d.ts.map +1 -0
  1904. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.js +181 -0
  1905. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.js.map +1 -0
  1906. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +9 -0
  1907. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -0
  1908. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +41 -0
  1909. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -0
  1910. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.d.ts +16 -0
  1911. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.d.ts.map +1 -0
  1912. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.js +64 -0
  1913. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.js.map +1 -0
  1914. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.d.ts +6 -0
  1915. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.d.ts.map +1 -0
  1916. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.js +102 -0
  1917. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.js.map +1 -0
  1918. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.d.ts +12 -0
  1919. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.d.ts.map +1 -0
  1920. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.js +62 -0
  1921. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.js.map +1 -0
  1922. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.d.ts +32 -0
  1923. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -0
  1924. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js +362 -0
  1925. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -0
  1926. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.d.ts +2 -0
  1927. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.d.ts.map +1 -0
  1928. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.js +7 -0
  1929. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.js.map +1 -0
  1930. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.d.ts +2 -0
  1931. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.d.ts.map +1 -0
  1932. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.js +4 -0
  1933. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.js.map +1 -0
  1934. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +10 -0
  1935. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -0
  1936. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +36 -0
  1937. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -0
  1938. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.d.ts +2 -0
  1939. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.d.ts.map +1 -0
  1940. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.js +64 -0
  1941. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.js.map +1 -0
  1942. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.d.ts +18 -0
  1943. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.d.ts.map +1 -0
  1944. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  1945. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  1946. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.d.ts +26 -0
  1947. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.d.ts.map +1 -0
  1948. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  1949. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  1950. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.d.ts +3 -0
  1951. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.d.ts.map +1 -0
  1952. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.js +3 -0
  1953. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.js.map +1 -0
  1954. package/analyzer-template/packages/utils/index.ts +60 -0
  1955. package/analyzer-template/packages/utils/package.json +14 -0
  1956. package/analyzer-template/packages/utils/server.ts +26 -0
  1957. package/analyzer-template/packages/utils/src/lib/Semaphore.ts +42 -0
  1958. package/analyzer-template/packages/utils/src/lib/__mocks__/killProcess.server.ts +4 -0
  1959. package/analyzer-template/packages/utils/src/lib/analyses/pushAnalysisError.ts +21 -0
  1960. package/analyzer-template/packages/utils/src/lib/applyUniversalMocks.ts +449 -0
  1961. package/analyzer-template/packages/utils/src/lib/awsLog.ts +60 -0
  1962. package/analyzer-template/packages/utils/src/lib/commitRuns.ts +16 -0
  1963. package/analyzer-template/packages/utils/src/lib/env/detectEnvFiles.ts +287 -0
  1964. package/analyzer-template/packages/utils/src/lib/env/index.ts +15 -0
  1965. package/analyzer-template/packages/utils/src/lib/env/sanitizeEnvFiles.ts +203 -0
  1966. package/analyzer-template/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.ts +40 -0
  1967. package/analyzer-template/packages/utils/src/lib/frameworks/getFrameworkRoutePath.ts +58 -0
  1968. package/analyzer-template/packages/utils/src/lib/frameworks/getNextRoutePath.ts +54 -0
  1969. package/analyzer-template/packages/utils/src/lib/frameworks/getRemixRoutePath.ts +52 -0
  1970. package/analyzer-template/packages/utils/src/lib/frameworks/isFrameworkRoute.ts +15 -0
  1971. package/analyzer-template/packages/utils/src/lib/frameworks/isNextRoute.ts +20 -0
  1972. package/analyzer-template/packages/utils/src/lib/frameworks/isRemixRoute.ts +14 -0
  1973. package/analyzer-template/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.ts +36 -0
  1974. package/analyzer-template/packages/utils/src/lib/frameworks/remixRouteFileNameToRoute.ts +28 -0
  1975. package/analyzer-template/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.ts +67 -0
  1976. package/analyzer-template/packages/utils/src/lib/fs/copyNodeRepoQuickly.ts +241 -0
  1977. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +64 -0
  1978. package/analyzer-template/packages/utils/src/lib/getFrameworkForFile.ts +92 -0
  1979. package/analyzer-template/packages/utils/src/lib/killProcess.server.ts +134 -0
  1980. package/analyzer-template/packages/utils/src/lib/killProcessAndSubprocesses.server.ts +76 -0
  1981. package/analyzer-template/packages/utils/src/lib/lightweightEntityExtractor.ts +457 -0
  1982. package/analyzer-template/packages/utils/src/lib/loadEnv.ts +7 -0
  1983. package/analyzer-template/packages/utils/src/lib/normalizeKey.ts +3 -0
  1984. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +55 -0
  1985. package/analyzer-template/packages/utils/src/lib/safeStringify.ts +68 -0
  1986. package/analyzer-template/packages/utils/src/lib/startCommand/buildStartCommand.ts +63 -0
  1987. package/analyzer-template/packages/utils/src/lib/startCommand/getWebappInfo.ts +108 -0
  1988. package/analyzer-template/packages/utils/src/lib/startCommand/index.ts +10 -0
  1989. package/analyzer-template/packages/utils/tsconfig.json +11 -0
  1990. package/analyzer-template/playwright/capture.ts +1007 -0
  1991. package/analyzer-template/playwright/captureFromUrl.ts +252 -0
  1992. package/analyzer-template/playwright/capturePageWithPlaywright.ts +204 -0
  1993. package/analyzer-template/playwright/captureScreenshotLite.ts +201 -0
  1994. package/analyzer-template/playwright/captureStatic.ts +137 -0
  1995. package/analyzer-template/playwright/checkURL.ts +67 -0
  1996. package/analyzer-template/playwright/compareImages.ts +149 -0
  1997. package/analyzer-template/playwright/compareTwoImagesFromS3.ts +43 -0
  1998. package/analyzer-template/playwright/downloadImageFromS3.ts +58 -0
  1999. package/analyzer-template/playwright/downloadPage.ts +413 -0
  2000. package/analyzer-template/playwright/executeInstuctions.ts +119 -0
  2001. package/analyzer-template/playwright/findStep.ts +6 -0
  2002. package/analyzer-template/playwright/generateStaticBuild.ts +185 -0
  2003. package/analyzer-template/playwright/getCodeYamInfo.ts +103 -0
  2004. package/analyzer-template/playwright/invalidateCloudFrontPath.ts +46 -0
  2005. package/analyzer-template/playwright/takeElementScreenshot.ts +505 -0
  2006. package/analyzer-template/playwright/takeScreenshot.ts +271 -0
  2007. package/analyzer-template/playwright/taskComplete.ts +12 -0
  2008. package/analyzer-template/playwright/updateBackgroundJob.ts +43 -0
  2009. package/analyzer-template/playwright/uploadAssets.ts +118 -0
  2010. package/analyzer-template/playwright/waitForNoServer.ts +16 -0
  2011. package/analyzer-template/playwright/waitForServer.ts +98 -0
  2012. package/analyzer-template/project/LazyFileStore.ts +537 -0
  2013. package/analyzer-template/project/ScenarioIterator.ts +133 -0
  2014. package/analyzer-template/project/TESTING.md +83 -0
  2015. package/analyzer-template/project/analyzeAndGatherIndirectEntities.ts +131 -0
  2016. package/analyzer-template/project/analyzeBaselineCommit.ts +195 -0
  2017. package/analyzer-template/project/analyzeBranchCommit.ts +260 -0
  2018. package/analyzer-template/project/analyzeFileEntities.ts +286 -0
  2019. package/analyzer-template/project/analyzeReadyToBeCaptured.ts +51 -0
  2020. package/analyzer-template/project/analyzeRegularCommit.ts +285 -0
  2021. package/analyzer-template/project/backupFiles.ts +129 -0
  2022. package/analyzer-template/project/buildCliArgs.ts +15 -0
  2023. package/analyzer-template/project/buildProject.ts +46 -0
  2024. package/analyzer-template/project/captureLibraryFunctionDirect.ts +144 -0
  2025. package/analyzer-template/project/checkApprovedPath.ts +39 -0
  2026. package/analyzer-template/project/checkConsistentAnalyses.ts +58 -0
  2027. package/analyzer-template/project/checkConsistentEntities.ts +55 -0
  2028. package/analyzer-template/project/clearExtension.ts +9 -0
  2029. package/analyzer-template/project/cloneGitRepoAtCommit.ts +59 -0
  2030. package/analyzer-template/project/constructMockCode.ts +2511 -0
  2031. package/analyzer-template/project/controller/startController.ts +212 -0
  2032. package/analyzer-template/project/createEntitiesAndSortFiles.ts +330 -0
  2033. package/analyzer-template/project/emailErrorReport.ts +78 -0
  2034. package/analyzer-template/project/executeLibraryFunctionDirect.ts +182 -0
  2035. package/analyzer-template/project/generateCodeYamPage.ts +240 -0
  2036. package/analyzer-template/project/generateScenarioPage.ts +56 -0
  2037. package/analyzer-template/project/getAppPath.ts +84 -0
  2038. package/analyzer-template/project/getCodeYamPagePath.ts +101 -0
  2039. package/analyzer-template/project/getFilesWithEntitiesFromRepo.ts +213 -0
  2040. package/analyzer-template/project/getScenarioPagePath.ts +119 -0
  2041. package/analyzer-template/project/getScenarioUrl.ts +137 -0
  2042. package/analyzer-template/project/loadReadyToBeCaptured.ts +336 -0
  2043. package/analyzer-template/project/mocks/analyzeFileMock.ts +436 -0
  2044. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +302 -0
  2045. package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +154 -0
  2046. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +410 -0
  2047. package/analyzer-template/project/orchestrateCapture/SupabaseAnalysisLoader.ts +85 -0
  2048. package/analyzer-template/project/orchestrateCapture/spawnTaskProcess.ts +112 -0
  2049. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +123 -0
  2050. package/analyzer-template/project/orchestrateCapture.ts +480 -0
  2051. package/analyzer-template/project/prepareRepo.ts +106 -0
  2052. package/analyzer-template/project/reconcileMockDataKeys.ts +387 -0
  2053. package/analyzer-template/project/removeScenario.ts +9 -0
  2054. package/analyzer-template/project/removeStrictFlagFromTsConfig.ts +37 -0
  2055. package/analyzer-template/project/replaceImportLineContainingSubstring.ts +23 -0
  2056. package/analyzer-template/project/runAnalysis.ts +373 -0
  2057. package/analyzer-template/project/runMultiScenarioServer.ts +564 -0
  2058. package/analyzer-template/project/runScenarioServer.ts +379 -0
  2059. package/analyzer-template/project/serverOnlyModules.ts +413 -0
  2060. package/analyzer-template/project/start.ts +659 -0
  2061. package/analyzer-template/project/startScenarioCapture.ts +770 -0
  2062. package/analyzer-template/project/startServer.ts +168 -0
  2063. package/analyzer-template/project/trackGeneratedFiles.ts +41 -0
  2064. package/analyzer-template/project/updateCommitBackgroundJob.ts +16 -0
  2065. package/analyzer-template/project/utils/errorHandling.ts +48 -0
  2066. package/analyzer-template/project/utils/mergeEnvVarsIntoStartCommand.ts +50 -0
  2067. package/analyzer-template/project/utils/webappMapping.ts +95 -0
  2068. package/analyzer-template/project/writeCodeYamPage.ts +32 -0
  2069. package/analyzer-template/project/writeEnv.ts +54 -0
  2070. package/analyzer-template/project/writeLibComponent.ts +50 -0
  2071. package/analyzer-template/project/writeMockDataTsx.ts +1434 -0
  2072. package/analyzer-template/project/writeScenario.ts +112 -0
  2073. package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
  2074. package/analyzer-template/project/writeScenarioComponents.ts +3036 -0
  2075. package/analyzer-template/project/writeScenarioFiles.ts +139 -0
  2076. package/analyzer-template/project/writeScenarioPage.ts +59 -0
  2077. package/analyzer-template/project/writeSimpleRoot.ts +566 -0
  2078. package/analyzer-template/project/writeUniversalMocks.ts +250 -0
  2079. package/analyzer-template/scripts/comboWorkerLoop.cjs +523 -0
  2080. package/analyzer-template/scripts/defaultCmd.sh +9 -0
  2081. package/analyzer-template/scripts/mergePackageJsonFiles.cjs +81 -0
  2082. package/analyzer-template/scripts/postbuild.cjs +106 -0
  2083. package/analyzer-template/tsconfig.json +20 -0
  2084. package/background/src/lib/copyFolderToArchive.js +34 -0
  2085. package/background/src/lib/copyFolderToArchive.js.map +1 -0
  2086. package/background/src/lib/local/createLocalAnalyzer.js +132 -0
  2087. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -0
  2088. package/background/src/lib/local/execAsync.js +100 -0
  2089. package/background/src/lib/local/execAsync.js.map +1 -0
  2090. package/background/src/lib/virtualized/common/closePort.js +17 -0
  2091. package/background/src/lib/virtualized/common/closePort.js.map +1 -0
  2092. package/background/src/lib/virtualized/common/constants.js +3 -0
  2093. package/background/src/lib/virtualized/common/constants.js.map +1 -0
  2094. package/background/src/lib/virtualized/common/copy.js +16 -0
  2095. package/background/src/lib/virtualized/common/copy.js.map +1 -0
  2096. package/background/src/lib/virtualized/common/execAsync.js +116 -0
  2097. package/background/src/lib/virtualized/common/execAsync.js.map +1 -0
  2098. package/background/src/lib/virtualized/common/getPID.js +40 -0
  2099. package/background/src/lib/virtualized/common/getPID.js.map +1 -0
  2100. package/background/src/lib/virtualized/common/measureAndRepordExecutionTime.js +9 -0
  2101. package/background/src/lib/virtualized/common/measureAndRepordExecutionTime.js.map +1 -0
  2102. package/background/src/lib/virtualized/common/measureExecutionTime.js +11 -0
  2103. package/background/src/lib/virtualized/common/measureExecutionTime.js.map +1 -0
  2104. package/background/src/lib/virtualized/common/openPage.js +20 -0
  2105. package/background/src/lib/virtualized/common/openPage.js.map +1 -0
  2106. package/background/src/lib/virtualized/common/readFile.js +21 -0
  2107. package/background/src/lib/virtualized/common/readFile.js.map +1 -0
  2108. package/background/src/lib/virtualized/common/writeFile.js +24 -0
  2109. package/background/src/lib/virtualized/common/writeFile.js.map +1 -0
  2110. package/background/src/lib/virtualized/project/LazyFileStore.js +421 -0
  2111. package/background/src/lib/virtualized/project/LazyFileStore.js.map +1 -0
  2112. package/background/src/lib/virtualized/project/ScenarioIterator.js +102 -0
  2113. package/background/src/lib/virtualized/project/ScenarioIterator.js.map +1 -0
  2114. package/background/src/lib/virtualized/project/analyzeAndGatherIndirectEntities.js +88 -0
  2115. package/background/src/lib/virtualized/project/analyzeAndGatherIndirectEntities.js.map +1 -0
  2116. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +114 -0
  2117. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -0
  2118. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +181 -0
  2119. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -0
  2120. package/background/src/lib/virtualized/project/analyzeFileEntities.js +193 -0
  2121. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -0
  2122. package/background/src/lib/virtualized/project/analyzeReadyToBeCaptured.js +22 -0
  2123. package/background/src/lib/virtualized/project/analyzeReadyToBeCaptured.js.map +1 -0
  2124. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +178 -0
  2125. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -0
  2126. package/background/src/lib/virtualized/project/backupFiles.js +114 -0
  2127. package/background/src/lib/virtualized/project/backupFiles.js.map +1 -0
  2128. package/background/src/lib/virtualized/project/buildCliArgs.js +18 -0
  2129. package/background/src/lib/virtualized/project/buildCliArgs.js.map +1 -0
  2130. package/background/src/lib/virtualized/project/buildProject.js +37 -0
  2131. package/background/src/lib/virtualized/project/buildProject.js.map +1 -0
  2132. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +107 -0
  2133. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -0
  2134. package/background/src/lib/virtualized/project/checkApprovedPath.js +25 -0
  2135. package/background/src/lib/virtualized/project/checkApprovedPath.js.map +1 -0
  2136. package/background/src/lib/virtualized/project/checkConsistentAnalyses.js +34 -0
  2137. package/background/src/lib/virtualized/project/checkConsistentAnalyses.js.map +1 -0
  2138. package/background/src/lib/virtualized/project/checkConsistentEntities.js +37 -0
  2139. package/background/src/lib/virtualized/project/checkConsistentEntities.js.map +1 -0
  2140. package/background/src/lib/virtualized/project/cloneGitRepoAtCommit.js +38 -0
  2141. package/background/src/lib/virtualized/project/cloneGitRepoAtCommit.js.map +1 -0
  2142. package/background/src/lib/virtualized/project/constructMockCode.js +2120 -0
  2143. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -0
  2144. package/background/src/lib/virtualized/project/controller/startController.js +149 -0
  2145. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -0
  2146. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +221 -0
  2147. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -0
  2148. package/background/src/lib/virtualized/project/emailErrorReport.js +50 -0
  2149. package/background/src/lib/virtualized/project/emailErrorReport.js.map +1 -0
  2150. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +157 -0
  2151. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -0
  2152. package/background/src/lib/virtualized/project/generateCodeYamPage.js +213 -0
  2153. package/background/src/lib/virtualized/project/generateCodeYamPage.js.map +1 -0
  2154. package/background/src/lib/virtualized/project/generateScenarioPage.js +27 -0
  2155. package/background/src/lib/virtualized/project/generateScenarioPage.js.map +1 -0
  2156. package/background/src/lib/virtualized/project/getAppPath.js +79 -0
  2157. package/background/src/lib/virtualized/project/getAppPath.js.map +1 -0
  2158. package/background/src/lib/virtualized/project/getCodeYamPagePath.js +56 -0
  2159. package/background/src/lib/virtualized/project/getCodeYamPagePath.js.map +1 -0
  2160. package/background/src/lib/virtualized/project/getFilesWithEntitiesFromRepo.js +161 -0
  2161. package/background/src/lib/virtualized/project/getFilesWithEntitiesFromRepo.js.map +1 -0
  2162. package/background/src/lib/virtualized/project/getScenarioPagePath.js +62 -0
  2163. package/background/src/lib/virtualized/project/getScenarioPagePath.js.map +1 -0
  2164. package/background/src/lib/virtualized/project/getScenarioUrl.js +87 -0
  2165. package/background/src/lib/virtualized/project/getScenarioUrl.js.map +1 -0
  2166. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +217 -0
  2167. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -0
  2168. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +368 -0
  2169. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -0
  2170. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +196 -0
  2171. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -0
  2172. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +115 -0
  2173. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -0
  2174. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +293 -0
  2175. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -0
  2176. package/background/src/lib/virtualized/project/orchestrateCapture/spawnTaskProcess.js +71 -0
  2177. package/background/src/lib/virtualized/project/orchestrateCapture/spawnTaskProcess.js.map +1 -0
  2178. package/background/src/lib/virtualized/project/orchestrateCapture/taskRunner.js +2 -0
  2179. package/background/src/lib/virtualized/project/orchestrateCapture/taskRunner.js.map +1 -0
  2180. package/background/src/lib/virtualized/project/orchestrateCapture.js +344 -0
  2181. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -0
  2182. package/background/src/lib/virtualized/project/prepareRepo.js +61 -0
  2183. package/background/src/lib/virtualized/project/prepareRepo.js.map +1 -0
  2184. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +329 -0
  2185. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -0
  2186. package/background/src/lib/virtualized/project/removeScenario.js +11 -0
  2187. package/background/src/lib/virtualized/project/removeScenario.js.map +1 -0
  2188. package/background/src/lib/virtualized/project/removeStrictFlagFromTsConfig.js +32 -0
  2189. package/background/src/lib/virtualized/project/removeStrictFlagFromTsConfig.js.map +1 -0
  2190. package/background/src/lib/virtualized/project/runAnalysis.js +262 -0
  2191. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -0
  2192. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +426 -0
  2193. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -0
  2194. package/background/src/lib/virtualized/project/serverOnlyModules.js +338 -0
  2195. package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -0
  2196. package/background/src/lib/virtualized/project/start.js +513 -0
  2197. package/background/src/lib/virtualized/project/start.js.map +1 -0
  2198. package/background/src/lib/virtualized/project/startScenarioCapture.js +530 -0
  2199. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -0
  2200. package/background/src/lib/virtualized/project/startServer.js +128 -0
  2201. package/background/src/lib/virtualized/project/startServer.js.map +1 -0
  2202. package/background/src/lib/virtualized/project/trackGeneratedFiles.js +30 -0
  2203. package/background/src/lib/virtualized/project/trackGeneratedFiles.js.map +1 -0
  2204. package/background/src/lib/virtualized/project/updateCommitBackgroundJob.js +13 -0
  2205. package/background/src/lib/virtualized/project/updateCommitBackgroundJob.js.map +1 -0
  2206. package/background/src/lib/virtualized/project/utils/errorHandling.js +39 -0
  2207. package/background/src/lib/virtualized/project/utils/errorHandling.js.map +1 -0
  2208. package/background/src/lib/virtualized/project/utils/mergeEnvVarsIntoStartCommand.js +42 -0
  2209. package/background/src/lib/virtualized/project/utils/mergeEnvVarsIntoStartCommand.js.map +1 -0
  2210. package/background/src/lib/virtualized/project/utils/webappMapping.js +66 -0
  2211. package/background/src/lib/virtualized/project/utils/webappMapping.js.map +1 -0
  2212. package/background/src/lib/virtualized/project/writeCodeYamPage.js +23 -0
  2213. package/background/src/lib/virtualized/project/writeCodeYamPage.js.map +1 -0
  2214. package/background/src/lib/virtualized/project/writeEnv.js +43 -0
  2215. package/background/src/lib/virtualized/project/writeEnv.js.map +1 -0
  2216. package/background/src/lib/virtualized/project/writeLibComponent.js +19 -0
  2217. package/background/src/lib/virtualized/project/writeLibComponent.js.map +1 -0
  2218. package/background/src/lib/virtualized/project/writeMockDataTsx.js +1229 -0
  2219. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -0
  2220. package/background/src/lib/virtualized/project/writeScenario.js +58 -0
  2221. package/background/src/lib/virtualized/project/writeScenario.js.map +1 -0
  2222. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
  2223. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
  2224. package/background/src/lib/virtualized/project/writeScenarioComponents.js +2143 -0
  2225. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -0
  2226. package/background/src/lib/virtualized/project/writeScenarioFiles.js +81 -0
  2227. package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -0
  2228. package/background/src/lib/virtualized/project/writeScenarioPage.js +24 -0
  2229. package/background/src/lib/virtualized/project/writeScenarioPage.js.map +1 -0
  2230. package/background/src/lib/virtualized/project/writeSimpleRoot.js +409 -0
  2231. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -0
  2232. package/background/src/lib/virtualized/project/writeUniversalMocks.js +157 -0
  2233. package/background/src/lib/virtualized/project/writeUniversalMocks.js.map +1 -0
  2234. package/background/src/lib/writeFile.js +18 -0
  2235. package/background/src/lib/writeFile.js.map +1 -0
  2236. package/codeyam-cli/scripts/apply-setup.js +468 -0
  2237. package/codeyam-cli/scripts/apply-setup.js.map +1 -0
  2238. package/codeyam-cli/scripts/build-analyzer-template.js +174 -0
  2239. package/codeyam-cli/scripts/build-analyzer-template.js.map +1 -0
  2240. package/codeyam-cli/scripts/build-webserver-info.js +80 -0
  2241. package/codeyam-cli/scripts/build-webserver-info.js.map +1 -0
  2242. package/codeyam-cli/scripts/extract-setup.js +130 -0
  2243. package/codeyam-cli/scripts/extract-setup.js.map +1 -0
  2244. package/codeyam-cli/scripts/populateEntityTimestamps.js +72 -0
  2245. package/codeyam-cli/scripts/populateEntityTimestamps.js.map +1 -0
  2246. package/codeyam-cli/src/cli.js +78 -0
  2247. package/codeyam-cli/src/cli.js.map +1 -0
  2248. package/codeyam-cli/src/codeyam-cli.js +4 -0
  2249. package/codeyam-cli/src/codeyam-cli.js.map +1 -0
  2250. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +132 -0
  2251. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -0
  2252. package/codeyam-cli/src/commands/__tests__/init.unapprovedPaths.test.js +73 -0
  2253. package/codeyam-cli/src/commands/__tests__/init.unapprovedPaths.test.js.map +1 -0
  2254. package/codeyam-cli/src/commands/__tests__/suggest.test.js +161 -0
  2255. package/codeyam-cli/src/commands/__tests__/suggest.test.js.map +1 -0
  2256. package/codeyam-cli/src/commands/analyze.js +136 -0
  2257. package/codeyam-cli/src/commands/analyze.js.map +1 -0
  2258. package/codeyam-cli/src/commands/baseline.js +174 -0
  2259. package/codeyam-cli/src/commands/baseline.js.map +1 -0
  2260. package/codeyam-cli/src/commands/debug.js +251 -0
  2261. package/codeyam-cli/src/commands/debug.js.map +1 -0
  2262. package/codeyam-cli/src/commands/default.js +84 -0
  2263. package/codeyam-cli/src/commands/default.js.map +1 -0
  2264. package/codeyam-cli/src/commands/detect-universal-mocks.js +118 -0
  2265. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -0
  2266. package/codeyam-cli/src/commands/entities.js +102 -0
  2267. package/codeyam-cli/src/commands/entities.js.map +1 -0
  2268. package/codeyam-cli/src/commands/generate-data-structure.js +251 -0
  2269. package/codeyam-cli/src/commands/generate-data-structure.js.map +1 -0
  2270. package/codeyam-cli/src/commands/init.js +419 -0
  2271. package/codeyam-cli/src/commands/init.js.map +1 -0
  2272. package/codeyam-cli/src/commands/list.js +31 -0
  2273. package/codeyam-cli/src/commands/list.js.map +1 -0
  2274. package/codeyam-cli/src/commands/memory.js +264 -0
  2275. package/codeyam-cli/src/commands/memory.js.map +1 -0
  2276. package/codeyam-cli/src/commands/queue.js +83 -0
  2277. package/codeyam-cli/src/commands/queue.js.map +1 -0
  2278. package/codeyam-cli/src/commands/recapture.js +226 -0
  2279. package/codeyam-cli/src/commands/recapture.js.map +1 -0
  2280. package/codeyam-cli/src/commands/report.js +150 -0
  2281. package/codeyam-cli/src/commands/report.js.map +1 -0
  2282. package/codeyam-cli/src/commands/setup-sandbox.js +165 -0
  2283. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -0
  2284. package/codeyam-cli/src/commands/start.js +68 -0
  2285. package/codeyam-cli/src/commands/start.js.map +1 -0
  2286. package/codeyam-cli/src/commands/status.js +134 -0
  2287. package/codeyam-cli/src/commands/status.js.map +1 -0
  2288. package/codeyam-cli/src/commands/stop.js +28 -0
  2289. package/codeyam-cli/src/commands/stop.js.map +1 -0
  2290. package/codeyam-cli/src/commands/suggest.js +299 -0
  2291. package/codeyam-cli/src/commands/suggest.js.map +1 -0
  2292. package/codeyam-cli/src/commands/suggestUtils.js +110 -0
  2293. package/codeyam-cli/src/commands/suggestUtils.js.map +1 -0
  2294. package/codeyam-cli/src/commands/test-startup.js +667 -0
  2295. package/codeyam-cli/src/commands/test-startup.js.map +1 -0
  2296. package/codeyam-cli/src/commands/update-config.js +97 -0
  2297. package/codeyam-cli/src/commands/update-config.js.map +1 -0
  2298. package/codeyam-cli/src/commands/validate-mock.js +97 -0
  2299. package/codeyam-cli/src/commands/validate-mock.js.map +1 -0
  2300. package/codeyam-cli/src/commands/verify.js +140 -0
  2301. package/codeyam-cli/src/commands/verify.js.map +1 -0
  2302. package/codeyam-cli/src/commands/webapp-info.js +146 -0
  2303. package/codeyam-cli/src/commands/webapp-info.js.map +1 -0
  2304. package/codeyam-cli/src/commands/wipe.js +108 -0
  2305. package/codeyam-cli/src/commands/wipe.js.map +1 -0
  2306. package/codeyam-cli/src/state.js +9 -0
  2307. package/codeyam-cli/src/state.js.map +1 -0
  2308. package/codeyam-cli/src/utils/__tests__/cleanupAnalysisFiles.test.js +219 -0
  2309. package/codeyam-cli/src/utils/__tests__/cleanupAnalysisFiles.test.js.map +1 -0
  2310. package/codeyam-cli/src/utils/__tests__/entityVersioning.test.js +346 -0
  2311. package/codeyam-cli/src/utils/__tests__/entityVersioning.test.js.map +1 -0
  2312. package/codeyam-cli/src/utils/__tests__/fileMetadata.test.js +203 -0
  2313. package/codeyam-cli/src/utils/__tests__/fileMetadata.test.js.map +1 -0
  2314. package/codeyam-cli/src/utils/__tests__/fileWatcher.batch.test.js +614 -0
  2315. package/codeyam-cli/src/utils/__tests__/fileWatcher.batch.test.js.map +1 -0
  2316. package/codeyam-cli/src/utils/__tests__/fileWatcher.multiversion.test.js +587 -0
  2317. package/codeyam-cli/src/utils/__tests__/fileWatcher.multiversion.test.js.map +1 -0
  2318. package/codeyam-cli/src/utils/__tests__/fileWatcher.optimization.test.js +375 -0
  2319. package/codeyam-cli/src/utils/__tests__/fileWatcher.optimization.test.js.map +1 -0
  2320. package/codeyam-cli/src/utils/__tests__/fileWatcher.versioning.test.js +1293 -0
  2321. package/codeyam-cli/src/utils/__tests__/fileWatcher.versioning.test.js.map +1 -0
  2322. package/codeyam-cli/src/utils/__tests__/gitEntityLookup.test.js +119 -0
  2323. package/codeyam-cli/src/utils/__tests__/gitEntityLookup.test.js.map +1 -0
  2324. package/codeyam-cli/src/utils/__tests__/import-meta.test.js +37 -0
  2325. package/codeyam-cli/src/utils/__tests__/import-meta.test.js.map +1 -0
  2326. package/codeyam-cli/src/utils/__tests__/mockValidator.test.js +151 -0
  2327. package/codeyam-cli/src/utils/__tests__/mockValidator.test.js.map +1 -0
  2328. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +140 -0
  2329. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -0
  2330. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  2331. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  2332. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +227 -0
  2333. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -0
  2334. package/codeyam-cli/src/utils/__tests__/syncUniversalMocks.test.js +132 -0
  2335. package/codeyam-cli/src/utils/__tests__/syncUniversalMocks.test.js.map +1 -0
  2336. package/codeyam-cli/src/utils/analysisRunner.js +272 -0
  2337. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -0
  2338. package/codeyam-cli/src/utils/analyzer.js +252 -0
  2339. package/codeyam-cli/src/utils/analyzer.js.map +1 -0
  2340. package/codeyam-cli/src/utils/backgroundServer.js +88 -0
  2341. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -0
  2342. package/codeyam-cli/src/utils/changeDetection.js +102 -0
  2343. package/codeyam-cli/src/utils/changeDetection.js.map +1 -0
  2344. package/codeyam-cli/src/utils/claude-code.js +39 -0
  2345. package/codeyam-cli/src/utils/claude-code.js.map +1 -0
  2346. package/codeyam-cli/src/utils/cleanupAnalysisFiles.js +89 -0
  2347. package/codeyam-cli/src/utils/cleanupAnalysisFiles.js.map +1 -0
  2348. package/codeyam-cli/src/utils/database.js +280 -0
  2349. package/codeyam-cli/src/utils/database.js.map +1 -0
  2350. package/codeyam-cli/src/utils/defaultUnapprovedPaths.js +92 -0
  2351. package/codeyam-cli/src/utils/defaultUnapprovedPaths.js.map +1 -0
  2352. package/codeyam-cli/src/utils/detectEnvironmentVariables.js +137 -0
  2353. package/codeyam-cli/src/utils/detectEnvironmentVariables.js.map +1 -0
  2354. package/codeyam-cli/src/utils/entityCache.js +160 -0
  2355. package/codeyam-cli/src/utils/entityCache.js.map +1 -0
  2356. package/codeyam-cli/src/utils/entityMetadata.js +55 -0
  2357. package/codeyam-cli/src/utils/entityMetadata.js.map +1 -0
  2358. package/codeyam-cli/src/utils/entityVersioning.js +166 -0
  2359. package/codeyam-cli/src/utils/entityVersioning.js.map +1 -0
  2360. package/codeyam-cli/src/utils/fileMetadata.js +570 -0
  2361. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -0
  2362. package/codeyam-cli/src/utils/fileWatcher.js +1576 -0
  2363. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -0
  2364. package/codeyam-cli/src/utils/folderBurstDetector.js +174 -0
  2365. package/codeyam-cli/src/utils/folderBurstDetector.js.map +1 -0
  2366. package/codeyam-cli/src/utils/generateReport.js +366 -0
  2367. package/codeyam-cli/src/utils/generateReport.js.map +1 -0
  2368. package/codeyam-cli/src/utils/git.js +79 -0
  2369. package/codeyam-cli/src/utils/git.js.map +1 -0
  2370. package/codeyam-cli/src/utils/gitEntityLookup.js +28 -0
  2371. package/codeyam-cli/src/utils/gitEntityLookup.js.map +1 -0
  2372. package/codeyam-cli/src/utils/install-skills.js +120 -0
  2373. package/codeyam-cli/src/utils/install-skills.js.map +1 -0
  2374. package/codeyam-cli/src/utils/labsAutoCheck.js +48 -0
  2375. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  2376. package/codeyam-cli/src/utils/memoryLogger.js +151 -0
  2377. package/codeyam-cli/src/utils/memoryLogger.js.map +1 -0
  2378. package/codeyam-cli/src/utils/memoryProfiler.js +168 -0
  2379. package/codeyam-cli/src/utils/memoryProfiler.js.map +1 -0
  2380. package/codeyam-cli/src/utils/mockValidator.js +267 -0
  2381. package/codeyam-cli/src/utils/mockValidator.js.map +1 -0
  2382. package/codeyam-cli/src/utils/pathIgnoring.js +127 -0
  2383. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -0
  2384. package/codeyam-cli/src/utils/progress.js +132 -0
  2385. package/codeyam-cli/src/utils/progress.js.map +1 -0
  2386. package/codeyam-cli/src/utils/project.js +27 -0
  2387. package/codeyam-cli/src/utils/project.js.map +1 -0
  2388. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +637 -0
  2389. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -0
  2390. package/codeyam-cli/src/utils/queue/__tests__/job.pidTracking.test.js +295 -0
  2391. package/codeyam-cli/src/utils/queue/__tests__/job.pidTracking.test.js.map +1 -0
  2392. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +369 -0
  2393. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -0
  2394. package/codeyam-cli/src/utils/queue/__tests__/persistence.test.js +186 -0
  2395. package/codeyam-cli/src/utils/queue/__tests__/persistence.test.js.map +1 -0
  2396. package/codeyam-cli/src/utils/queue/heartbeat.js +141 -0
  2397. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -0
  2398. package/codeyam-cli/src/utils/queue/job.js +663 -0
  2399. package/codeyam-cli/src/utils/queue/job.js.map +1 -0
  2400. package/codeyam-cli/src/utils/queue/manager.js +236 -0
  2401. package/codeyam-cli/src/utils/queue/manager.js.map +1 -0
  2402. package/codeyam-cli/src/utils/queue/persistence.js +41 -0
  2403. package/codeyam-cli/src/utils/queue/persistence.js.map +1 -0
  2404. package/codeyam-cli/src/utils/queue/proxyQueue.js +163 -0
  2405. package/codeyam-cli/src/utils/queue/proxyQueue.js.map +1 -0
  2406. package/codeyam-cli/src/utils/queue/queueFileWatcher.js +77 -0
  2407. package/codeyam-cli/src/utils/queue/queueFileWatcher.js.map +1 -0
  2408. package/codeyam-cli/src/utils/queue/serverDetection.js +93 -0
  2409. package/codeyam-cli/src/utils/queue/serverDetection.js.map +1 -0
  2410. package/codeyam-cli/src/utils/routeIdentification.js +152 -0
  2411. package/codeyam-cli/src/utils/routeIdentification.js.map +1 -0
  2412. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  2413. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  2414. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
  2415. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  2416. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  2417. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  2418. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  2419. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  2420. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  2421. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  2422. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  2423. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  2424. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
  2425. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  2426. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +285 -0
  2427. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  2428. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
  2429. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  2430. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  2431. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  2432. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  2433. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  2434. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  2435. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  2436. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  2437. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  2438. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  2439. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  2440. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  2441. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  2442. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  2443. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  2444. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  2445. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  2446. package/codeyam-cli/src/utils/rules/index.js +6 -0
  2447. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  2448. package/codeyam-cli/src/utils/rules/parser.js +78 -0
  2449. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  2450. package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
  2451. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  2452. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  2453. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  2454. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  2455. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  2456. package/codeyam-cli/src/utils/sandbox.js +190 -0
  2457. package/codeyam-cli/src/utils/sandbox.js.map +1 -0
  2458. package/codeyam-cli/src/utils/secrets.js +152 -0
  2459. package/codeyam-cli/src/utils/secrets.js.map +1 -0
  2460. package/codeyam-cli/src/utils/secretsManager.js +189 -0
  2461. package/codeyam-cli/src/utils/secretsManager.js.map +1 -0
  2462. package/codeyam-cli/src/utils/serverState.js +129 -0
  2463. package/codeyam-cli/src/utils/serverState.js.map +1 -0
  2464. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +109 -0
  2465. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -0
  2466. package/codeyam-cli/src/utils/syncMocksMiddleware.js +51 -0
  2467. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -0
  2468. package/codeyam-cli/src/utils/syncUncommittedEntities.js +169 -0
  2469. package/codeyam-cli/src/utils/syncUncommittedEntities.js.map +1 -0
  2470. package/codeyam-cli/src/utils/syncUniversalMocks.js +284 -0
  2471. package/codeyam-cli/src/utils/syncUniversalMocks.js.map +1 -0
  2472. package/codeyam-cli/src/utils/universal-mocks.js +152 -0
  2473. package/codeyam-cli/src/utils/universal-mocks.js.map +1 -0
  2474. package/codeyam-cli/src/utils/versionInfo.js +123 -0
  2475. package/codeyam-cli/src/utils/versionInfo.js.map +1 -0
  2476. package/codeyam-cli/src/utils/webappDetection.js +259 -0
  2477. package/codeyam-cli/src/utils/webappDetection.js.map +1 -0
  2478. package/codeyam-cli/src/utils/webappMapping.js +52 -0
  2479. package/codeyam-cli/src/utils/webappMapping.js.map +1 -0
  2480. package/codeyam-cli/src/utils/wipe.js +128 -0
  2481. package/codeyam-cli/src/utils/wipe.js.map +1 -0
  2482. package/codeyam-cli/src/webserver/app/lib/database.js +524 -0
  2483. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -0
  2484. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js +88 -0
  2485. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -0
  2486. package/codeyam-cli/src/webserver/app/lib/lightweightEntityExtractor.js +3 -0
  2487. package/codeyam-cli/src/webserver/app/lib/lightweightEntityExtractor.js.map +1 -0
  2488. package/codeyam-cli/src/webserver/backgroundServer.js +167 -0
  2489. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -0
  2490. package/codeyam-cli/src/webserver/bootstrap.js +49 -0
  2491. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -0
  2492. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CA3JxPb7.js +1 -0
  2493. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-B86KKU7e.js +11 -0
  2494. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-B5ctlSYt.js +1 -0
  2495. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-BqY8gDAW.js +41 -0
  2496. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-ClaLpuOo.js +34 -0
  2497. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-BDhPilK7.js +25 -0
  2498. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-VeqEBv9v.js +3 -0
  2499. package/codeyam-cli/src/webserver/build/client/assets/LoadingDots-Bs7Nn1Jr.js +6 -0
  2500. package/codeyam-cli/src/webserver/build/client/assets/LogViewer-Bm3PmcCz.js +3 -0
  2501. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-C6PKeMYR.js +11 -0
  2502. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-Gq3Ocjo6.js +1 -0
  2503. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-BNLaXBHR.js +10 -0
  2504. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CiwXDxLh.js +1 -0
  2505. package/codeyam-cli/src/webserver/build/client/assets/_index-B3TDXxnk.js +11 -0
  2506. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BtBFH820.js +27 -0
  2507. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DfKzxuoe.js +11 -0
  2508. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  2509. package/codeyam-cli/src/webserver/build/client/assets/api.analyze-l0sNRNKZ.js +1 -0
  2510. package/codeyam-cli/src/webserver/build/client/assets/api.branch-entity-diff-l0sNRNKZ.js +1 -0
  2511. package/codeyam-cli/src/webserver/build/client/assets/api.capture-screenshot-l0sNRNKZ.js +1 -0
  2512. package/codeyam-cli/src/webserver/build/client/assets/api.debug-setup-l0sNRNKZ.js +1 -0
  2513. package/codeyam-cli/src/webserver/build/client/assets/api.delete-scenario-l0sNRNKZ.js +1 -0
  2514. package/codeyam-cli/src/webserver/build/client/assets/api.events-l0sNRNKZ.js +1 -0
  2515. package/codeyam-cli/src/webserver/build/client/assets/api.execute-function-l0sNRNKZ.js +1 -0
  2516. package/codeyam-cli/src/webserver/build/client/assets/api.generate-report-l0sNRNKZ.js +1 -0
  2517. package/codeyam-cli/src/webserver/build/client/assets/api.generate-scenario-data-l0sNRNKZ.js +1 -0
  2518. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  2519. package/codeyam-cli/src/webserver/build/client/assets/api.interactive-mode-l0sNRNKZ.js +1 -0
  2520. package/codeyam-cli/src/webserver/build/client/assets/api.kill-process-l0sNRNKZ.js +1 -0
  2521. package/codeyam-cli/src/webserver/build/client/assets/api.labs-survey-l0sNRNKZ.js +1 -0
  2522. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  2523. package/codeyam-cli/src/webserver/build/client/assets/api.llm-calls._entitySha-l0sNRNKZ.js +1 -0
  2524. package/codeyam-cli/src/webserver/build/client/assets/api.logs._projectSlug-l0sNRNKZ.js +1 -0
  2525. package/codeyam-cli/src/webserver/build/client/assets/api.memory-l0sNRNKZ.js +1 -0
  2526. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  2527. package/codeyam-cli/src/webserver/build/client/assets/api.process-status-l0sNRNKZ.js +1 -0
  2528. package/codeyam-cli/src/webserver/build/client/assets/api.queue-l0sNRNKZ.js +1 -0
  2529. package/codeyam-cli/src/webserver/build/client/assets/api.recapture-l0sNRNKZ.js +1 -0
  2530. package/codeyam-cli/src/webserver/build/client/assets/api.recapture-scenario-l0sNRNKZ.js +1 -0
  2531. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  2532. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  2533. package/codeyam-cli/src/webserver/build/client/assets/api.save-scenarios-l0sNRNKZ.js +1 -0
  2534. package/codeyam-cli/src/webserver/build/client/assets/api.screenshot._-l0sNRNKZ.js +1 -0
  2535. package/codeyam-cli/src/webserver/build/client/assets/book-open-PttOB2SF.js +6 -0
  2536. package/codeyam-cli/src/webserver/build/client/assets/chevron-down-TJp6ofnp.js +6 -0
  2537. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-JE9ZIoBl.js +51 -0
  2538. package/codeyam-cli/src/webserver/build/client/assets/circle-check-CXhHQYrI.js +6 -0
  2539. package/codeyam-cli/src/webserver/build/client/assets/codeyam-name-logo-CvKwUgHo.svg +9 -0
  2540. package/codeyam-cli/src/webserver/build/client/assets/copy-6y9ALfGT.js +11 -0
  2541. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-Ca9fAY46.js +21 -0
  2542. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CCKUIm0S.svg +4 -0
  2543. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  2544. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C5lqplTC.js +1 -0
  2545. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-n38keI1k.js +23 -0
  2546. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CBoafmVs.js +6 -0
  2547. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DGgZjdFg.js +6 -0
  2548. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-38yPijoD.js +5 -0
  2549. package/codeyam-cli/src/webserver/build/client/assets/entry.client-BSHEfydn.js +29 -0
  2550. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  2551. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-DCPhhSMo.js +1 -0
  2552. package/codeyam-cli/src/webserver/build/client/assets/files-0N0YJQv7.js +1 -0
  2553. package/codeyam-cli/src/webserver/build/client/assets/git-DXnyr8uP.js +15 -0
  2554. package/codeyam-cli/src/webserver/build/client/assets/globals-DoeDFXZN.css +1 -0
  2555. package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-fmIEn3Bc.js +9 -0
  2556. package/codeyam-cli/src/webserver/build/client/assets/index-CcsFv748.js +3 -0
  2557. package/codeyam-cli/src/webserver/build/client/assets/index-ChN9-fAY.js +9 -0
  2558. package/codeyam-cli/src/webserver/build/client/assets/labs-CmBYA0PH.js +1 -0
  2559. package/codeyam-cli/src/webserver/build/client/assets/loader-circle-CTqLEAGU.js +6 -0
  2560. package/codeyam-cli/src/webserver/build/client/assets/manifest-76786b8e.js +1 -0
  2561. package/codeyam-cli/src/webserver/build/client/assets/memory-CrNQfdMO.js +76 -0
  2562. package/codeyam-cli/src/webserver/build/client/assets/pause-D6vreykR.js +11 -0
  2563. package/codeyam-cli/src/webserver/build/client/assets/preload-helper-ckwbz45p.js +1 -0
  2564. package/codeyam-cli/src/webserver/build/client/assets/root-QAY34PIo.js +62 -0
  2565. package/codeyam-cli/src/webserver/build/client/assets/scenarioStatus-B_8jpV3e.js +1 -0
  2566. package/codeyam-cli/src/webserver/build/client/assets/search-B8VUL8nl.js +6 -0
  2567. package/codeyam-cli/src/webserver/build/client/assets/settings-eBI36Yv5.js +1 -0
  2568. package/codeyam-cli/src/webserver/build/client/assets/simulations-CPoAg7Zo.js +1 -0
  2569. package/codeyam-cli/src/webserver/build/client/assets/static._-l0sNRNKZ.js +1 -0
  2570. package/codeyam-cli/src/webserver/build/client/assets/styles-CMKNK2uU.css +1 -0
  2571. package/codeyam-cli/src/webserver/build/client/assets/terminal-BrCP7uQo.js +11 -0
  2572. package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-BZz2NjYa.js +6 -0
  2573. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DNwUduNu.js +1 -0
  2574. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-COky1GVF.js +2 -0
  2575. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-CpZgwliL.js +1 -0
  2576. package/codeyam-cli/src/webserver/build/client/assets/useToast-Bv9JFvUO.js +1 -0
  2577. package/codeyam-cli/src/webserver/build/client/favicon.ico +0 -0
  2578. package/codeyam-cli/src/webserver/build/client/favicon.png +0 -0
  2579. package/codeyam-cli/src/webserver/build/client/icons/file-icon.svg +14 -0
  2580. package/codeyam-cli/src/webserver/build/server/assets/index-DV1ykEI6.js +1 -0
  2581. package/codeyam-cli/src/webserver/build/server/assets/server-build-BrcVrUEv.js +260 -0
  2582. package/codeyam-cli/src/webserver/build/server/index.js +1 -0
  2583. package/codeyam-cli/src/webserver/build-info.json +7 -0
  2584. package/codeyam-cli/src/webserver/devServer.js +91 -0
  2585. package/codeyam-cli/src/webserver/devServer.js.map +1 -0
  2586. package/codeyam-cli/src/webserver/public/favicon.ico +0 -0
  2587. package/codeyam-cli/src/webserver/public/favicon.png +0 -0
  2588. package/codeyam-cli/src/webserver/public/icons/file-icon.svg +14 -0
  2589. package/codeyam-cli/src/webserver/server.js +153 -0
  2590. package/codeyam-cli/src/webserver/server.js.map +1 -0
  2591. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  2592. package/codeyam-cli/templates/codeyam-stop-hook.sh +284 -0
  2593. package/codeyam-cli/templates/codeyam:debug.md +601 -0
  2594. package/codeyam-cli/templates/codeyam:diagnose.md +805 -0
  2595. package/codeyam-cli/templates/codeyam:memory.md +404 -0
  2596. package/codeyam-cli/templates/codeyam:new-rule.md +13 -0
  2597. package/codeyam-cli/templates/codeyam:setup.md +588 -0
  2598. package/codeyam-cli/templates/codeyam:sim.md +222 -0
  2599. package/codeyam-cli/templates/codeyam:test.md +178 -0
  2600. package/codeyam-cli/templates/codeyam:verify.md +179 -0
  2601. package/codeyam-cli/templates/rule-notification-hook.py +56 -0
  2602. package/codeyam-cli/templates/rule-reflection-hook.py +590 -0
  2603. package/codeyam-cli/templates/rules-instructions.md +123 -0
  2604. package/package.json +81 -7
  2605. package/packages/ai/index.js +53 -0
  2606. package/packages/ai/index.js.map +1 -0
  2607. package/packages/ai/src/lib/aiConfig.js +16 -0
  2608. package/packages/ai/src/lib/aiConfig.js.map +1 -0
  2609. package/packages/ai/src/lib/analyzeScope.js +575 -0
  2610. package/packages/ai/src/lib/analyzeScope.js.map +1 -0
  2611. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  2612. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  2613. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +893 -0
  2614. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -0
  2615. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  2616. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  2617. package/packages/ai/src/lib/astScopes/methodSemantics.js +652 -0
  2618. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -0
  2619. package/packages/ai/src/lib/astScopes/nodeToSource.js +54 -0
  2620. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -0
  2621. package/packages/ai/src/lib/astScopes/paths.js +552 -0
  2622. package/packages/ai/src/lib/astScopes/paths.js.map +1 -0
  2623. package/packages/ai/src/lib/astScopes/patterns/blockHandler.js +24 -0
  2624. package/packages/ai/src/lib/astScopes/patterns/blockHandler.js.map +1 -0
  2625. package/packages/ai/src/lib/astScopes/patterns/breakStatementHandler.js +18 -0
  2626. package/packages/ai/src/lib/astScopes/patterns/breakStatementHandler.js.map +1 -0
  2627. package/packages/ai/src/lib/astScopes/patterns/doStatementHandler.js +22 -0
  2628. package/packages/ai/src/lib/astScopes/patterns/doStatementHandler.js.map +1 -0
  2629. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +53 -0
  2630. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -0
  2631. package/packages/ai/src/lib/astScopes/patterns/forOfStatementHandler.js +93 -0
  2632. package/packages/ai/src/lib/astScopes/patterns/forOfStatementHandler.js.map +1 -0
  2633. package/packages/ai/src/lib/astScopes/patterns/forStatementHandler.js +52 -0
  2634. package/packages/ai/src/lib/astScopes/patterns/forStatementHandler.js.map +1 -0
  2635. package/packages/ai/src/lib/astScopes/patterns/functionDeclarationHandler.js +179 -0
  2636. package/packages/ai/src/lib/astScopes/patterns/functionDeclarationHandler.js.map +1 -0
  2637. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +44 -0
  2638. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -0
  2639. package/packages/ai/src/lib/astScopes/patterns/patternHandler.js +2 -0
  2640. package/packages/ai/src/lib/astScopes/patterns/patternHandler.js.map +1 -0
  2641. package/packages/ai/src/lib/astScopes/patterns/returnStatementHandler.js +47 -0
  2642. package/packages/ai/src/lib/astScopes/patterns/returnStatementHandler.js.map +1 -0
  2643. package/packages/ai/src/lib/astScopes/patterns/standaloneExpressionHandler.js +51 -0
  2644. package/packages/ai/src/lib/astScopes/patterns/standaloneExpressionHandler.js.map +1 -0
  2645. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +110 -0
  2646. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -0
  2647. package/packages/ai/src/lib/astScopes/patterns/throwStatementHandler.js +16 -0
  2648. package/packages/ai/src/lib/astScopes/patterns/throwStatementHandler.js.map +1 -0
  2649. package/packages/ai/src/lib/astScopes/patterns/tryStatementHandler.js +53 -0
  2650. package/packages/ai/src/lib/astScopes/patterns/tryStatementHandler.js.map +1 -0
  2651. package/packages/ai/src/lib/astScopes/patterns/typeAndInterfaceHandler.js +18 -0
  2652. package/packages/ai/src/lib/astScopes/patterns/typeAndInterfaceHandler.js.map +1 -0
  2653. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +201 -0
  2654. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -0
  2655. package/packages/ai/src/lib/astScopes/patterns/whileStatementHandler.js +24 -0
  2656. package/packages/ai/src/lib/astScopes/patterns/whileStatementHandler.js.map +1 -0
  2657. package/packages/ai/src/lib/astScopes/processBindings.js +191 -0
  2658. package/packages/ai/src/lib/astScopes/processBindings.js.map +1 -0
  2659. package/packages/ai/src/lib/astScopes/processExpression.js +2707 -0
  2660. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -0
  2661. package/packages/ai/src/lib/astScopes/sharedPatterns.js +108 -0
  2662. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -0
  2663. package/packages/ai/src/lib/astScopes/types.js +31 -0
  2664. package/packages/ai/src/lib/astScopes/types.js.map +1 -0
  2665. package/packages/ai/src/lib/astScopes.js +12 -0
  2666. package/packages/ai/src/lib/astScopes.js.map +1 -0
  2667. package/packages/ai/src/lib/checkAllAttributes.js +41 -0
  2668. package/packages/ai/src/lib/checkAllAttributes.js.map +1 -0
  2669. package/packages/ai/src/lib/cleanOutBoundary.js +31 -0
  2670. package/packages/ai/src/lib/cleanOutBoundary.js.map +1 -0
  2671. package/packages/ai/src/lib/codeQualityEntityAnalysis.js +13 -0
  2672. package/packages/ai/src/lib/codeQualityEntityAnalysis.js.map +1 -0
  2673. package/packages/ai/src/lib/commitMessage.js +12 -0
  2674. package/packages/ai/src/lib/commitMessage.js.map +1 -0
  2675. package/packages/ai/src/lib/completionCall.js +514 -0
  2676. package/packages/ai/src/lib/completionCall.js.map +1 -0
  2677. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +4533 -0
  2678. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -0
  2679. package/packages/ai/src/lib/dataStructure/equivalencyManagers/EquivalencyManager.js +2 -0
  2680. package/packages/ai/src/lib/dataStructure/equivalencyManagers/EquivalencyManager.js.map +1 -0
  2681. package/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.js +401 -0
  2682. package/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.js.map +1 -0
  2683. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +88 -0
  2684. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -0
  2685. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +377 -0
  2686. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -0
  2687. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +661 -0
  2688. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -0
  2689. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +1004 -0
  2690. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -0
  2691. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +122 -0
  2692. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -0
  2693. package/packages/ai/src/lib/dataStructure/helpers/DebugTracer.js +176 -0
  2694. package/packages/ai/src/lib/dataStructure/helpers/DebugTracer.js.map +1 -0
  2695. package/packages/ai/src/lib/dataStructure/helpers/PathManager.js +178 -0
  2696. package/packages/ai/src/lib/dataStructure/helpers/PathManager.js.map +1 -0
  2697. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +140 -0
  2698. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -0
  2699. package/packages/ai/src/lib/dataStructure/helpers/VisitedTracker.js +199 -0
  2700. package/packages/ai/src/lib/dataStructure/helpers/VisitedTracker.js.map +1 -0
  2701. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +168 -0
  2702. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -0
  2703. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +877 -0
  2704. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -0
  2705. package/packages/ai/src/lib/dataStructure/helpers/cleanPath.js +21 -0
  2706. package/packages/ai/src/lib/dataStructure/helpers/cleanPath.js.map +1 -0
  2707. package/packages/ai/src/lib/dataStructure/helpers/cleanPathOfNonTransformingFunctions.js +42 -0
  2708. package/packages/ai/src/lib/dataStructure/helpers/cleanPathOfNonTransformingFunctions.js.map +1 -0
  2709. package/packages/ai/src/lib/dataStructure/helpers/cleanScopeNodeName.js +4 -0
  2710. package/packages/ai/src/lib/dataStructure/helpers/cleanScopeNodeName.js.map +1 -0
  2711. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  2712. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  2713. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +334 -0
  2714. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -0
  2715. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
  2716. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
  2717. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  2718. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  2719. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +128 -0
  2720. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -0
  2721. package/packages/ai/src/lib/dataStructure/helpers/determineIsFunctionCall.js +12 -0
  2722. package/packages/ai/src/lib/dataStructure/helpers/determineIsFunctionCall.js.map +1 -0
  2723. package/packages/ai/src/lib/dataStructure/helpers/ensureSchemaConsistency.js +73 -0
  2724. package/packages/ai/src/lib/dataStructure/helpers/ensureSchemaConsistency.js.map +1 -0
  2725. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +895 -0
  2726. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -0
  2727. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  2728. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  2729. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.js +33 -0
  2730. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.js.map +1 -0
  2731. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallScopeNodeName.js +8 -0
  2732. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallScopeNodeName.js.map +1 -0
  2733. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallSignature.js +13 -0
  2734. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallSignature.js.map +1 -0
  2735. package/packages/ai/src/lib/dataStructure/helpers/isGenericArray.js +65 -0
  2736. package/packages/ai/src/lib/dataStructure/helpers/isGenericArray.js.map +1 -0
  2737. package/packages/ai/src/lib/dataStructure/helpers/knownMethodCalls.js +128 -0
  2738. package/packages/ai/src/lib/dataStructure/helpers/knownMethodCalls.js.map +1 -0
  2739. package/packages/ai/src/lib/dataStructure/helpers/selectBestValue.js +62 -0
  2740. package/packages/ai/src/lib/dataStructure/helpers/selectBestValue.js.map +1 -0
  2741. package/packages/ai/src/lib/dataStructure/helpers/uniqueIdUtils.js +90 -0
  2742. package/packages/ai/src/lib/dataStructure/helpers/uniqueIdUtils.js.map +1 -0
  2743. package/packages/ai/src/lib/dataStructureChunking.js +111 -0
  2744. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  2745. package/packages/ai/src/lib/deepEqual.js +32 -0
  2746. package/packages/ai/src/lib/deepEqual.js.map +1 -0
  2747. package/packages/ai/src/lib/describeCodeChange.js +36 -0
  2748. package/packages/ai/src/lib/describeCodeChange.js.map +1 -0
  2749. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  2750. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  2751. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  2752. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  2753. package/packages/ai/src/lib/extractOverlappingMocks.js +41 -0
  2754. package/packages/ai/src/lib/extractOverlappingMocks.js.map +1 -0
  2755. package/packages/ai/src/lib/generateBranchSummary.js +40 -0
  2756. package/packages/ai/src/lib/generateBranchSummary.js.map +1 -0
  2757. package/packages/ai/src/lib/generateChangesEntityDocumentation.js +57 -0
  2758. package/packages/ai/src/lib/generateChangesEntityDocumentation.js.map +1 -0
  2759. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +334 -0
  2760. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -0
  2761. package/packages/ai/src/lib/generateChangesEntityScenarios.js +308 -0
  2762. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -0
  2763. package/packages/ai/src/lib/generateEntityDataStructure.js +113 -0
  2764. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -0
  2765. package/packages/ai/src/lib/generateEntityDocumentation.js +57 -0
  2766. package/packages/ai/src/lib/generateEntityDocumentation.js.map +1 -0
  2767. package/packages/ai/src/lib/generateEntityScenarioData.js +1295 -0
  2768. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -0
  2769. package/packages/ai/src/lib/generateEntityScenarios.js +362 -0
  2770. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -0
  2771. package/packages/ai/src/lib/generateExecutionFlows.js +400 -0
  2772. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  2773. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  2774. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  2775. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1646 -0
  2776. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  2777. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  2778. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  2779. package/packages/ai/src/lib/generateStatementAnalysis.js +1709 -0
  2780. package/packages/ai/src/lib/generateStatementAnalysis.js.map +1 -0
  2781. package/packages/ai/src/lib/getCodeExplanation.js +40 -0
  2782. package/packages/ai/src/lib/getCodeExplanation.js.map +1 -0
  2783. package/packages/ai/src/lib/getConditionalUsagesFromCode.js +309 -0
  2784. package/packages/ai/src/lib/getConditionalUsagesFromCode.js.map +1 -0
  2785. package/packages/ai/src/lib/getLLMCallCost.js +12 -0
  2786. package/packages/ai/src/lib/getLLMCallCost.js.map +1 -0
  2787. package/packages/ai/src/lib/getLLMCallStats.js +29 -0
  2788. package/packages/ai/src/lib/getLLMCallStats.js.map +1 -0
  2789. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +91 -0
  2790. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -0
  2791. package/packages/ai/src/lib/guessScenarioDataFromName.js +57 -0
  2792. package/packages/ai/src/lib/guessScenarioDataFromName.js.map +1 -0
  2793. package/packages/ai/src/lib/identifyReserved.js +619 -0
  2794. package/packages/ai/src/lib/identifyReserved.js.map +1 -0
  2795. package/packages/ai/src/lib/index.js +11 -0
  2796. package/packages/ai/src/lib/index.js.map +1 -0
  2797. package/packages/ai/src/lib/instantiatedInScope.js +186 -0
  2798. package/packages/ai/src/lib/instantiatedInScope.js.map +1 -0
  2799. package/packages/ai/src/lib/isolateScopes.js +990 -0
  2800. package/packages/ai/src/lib/isolateScopes.js.map +1 -0
  2801. package/packages/ai/src/lib/isolateStatements.js +882 -0
  2802. package/packages/ai/src/lib/isolateStatements.js.map +1 -0
  2803. package/packages/ai/src/lib/jsonTypeDefinitionToStandardTypeDefinition.js +34 -0
  2804. package/packages/ai/src/lib/jsonTypeDefinitionToStandardTypeDefinition.js.map +1 -0
  2805. package/packages/ai/src/lib/logOrderedMap.js +22 -0
  2806. package/packages/ai/src/lib/logOrderedMap.js.map +1 -0
  2807. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +50 -0
  2808. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -0
  2809. package/packages/ai/src/lib/mergeStatements.js +220 -0
  2810. package/packages/ai/src/lib/mergeStatements.js.map +1 -0
  2811. package/packages/ai/src/lib/modelInfo.js +215 -0
  2812. package/packages/ai/src/lib/modelInfo.js.map +1 -0
  2813. package/packages/ai/src/lib/openai/index.js +72 -0
  2814. package/packages/ai/src/lib/openai/index.js.map +1 -0
  2815. package/packages/ai/src/lib/parsers/fileContentToLines.js +8 -0
  2816. package/packages/ai/src/lib/parsers/fileContentToLines.js.map +1 -0
  2817. package/packages/ai/src/lib/parsers/parseJsonSafe.js +40 -0
  2818. package/packages/ai/src/lib/parsers/parseJsonSafe.js.map +1 -0
  2819. package/packages/ai/src/lib/promptGenerators/branchSummaryGenerator.js +6 -0
  2820. package/packages/ai/src/lib/promptGenerators/branchSummaryGenerator.js.map +1 -0
  2821. package/packages/ai/src/lib/promptGenerators/codeQualityEntityAnalysisGenerator.js +52 -0
  2822. package/packages/ai/src/lib/promptGenerators/codeQualityEntityAnalysisGenerator.js.map +1 -0
  2823. package/packages/ai/src/lib/promptGenerators/commitMessageGenerator.js +36 -0
  2824. package/packages/ai/src/lib/promptGenerators/commitMessageGenerator.js.map +1 -0
  2825. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +238 -0
  2826. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -0
  2827. package/packages/ai/src/lib/promptGenerators/generateChangesEntityDocumentationGenerator.js +18 -0
  2828. package/packages/ai/src/lib/promptGenerators/generateChangesEntityDocumentationGenerator.js.map +1 -0
  2829. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +96 -0
  2830. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -0
  2831. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +66 -0
  2832. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -0
  2833. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  2834. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  2835. package/packages/ai/src/lib/promptGenerators/generateEntityDataStructureGenerator.js +14 -0
  2836. package/packages/ai/src/lib/promptGenerators/generateEntityDataStructureGenerator.js.map +1 -0
  2837. package/packages/ai/src/lib/promptGenerators/generateEntityDocumentationGenerator.js +15 -0
  2838. package/packages/ai/src/lib/promptGenerators/generateEntityDocumentationGenerator.js.map +1 -0
  2839. package/packages/ai/src/lib/promptGenerators/generateEntityPropsStructureGenerator.js +17 -0
  2840. package/packages/ai/src/lib/promptGenerators/generateEntityPropsStructureGenerator.js.map +1 -0
  2841. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +102 -0
  2842. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -0
  2843. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +17 -0
  2844. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -0
  2845. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  2846. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  2847. package/packages/ai/src/lib/promptGenerators/getComponentExamplesGenerator.js +15 -0
  2848. package/packages/ai/src/lib/promptGenerators/getComponentExamplesGenerator.js.map +1 -0
  2849. package/packages/ai/src/lib/promptGenerators/guessEditScenarioDataFromDescriptionGenerator.js +29 -0
  2850. package/packages/ai/src/lib/promptGenerators/guessEditScenarioDataFromDescriptionGenerator.js.map +1 -0
  2851. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +26 -0
  2852. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -0
  2853. package/packages/ai/src/lib/promptGenerators/guessScenarioDataFromNameGenerator.js +21 -0
  2854. package/packages/ai/src/lib/promptGenerators/guessScenarioDataFromNameGenerator.js.map +1 -0
  2855. package/packages/ai/src/lib/promptGenerators/index.js +11 -0
  2856. package/packages/ai/src/lib/promptGenerators/index.js.map +1 -0
  2857. package/packages/ai/src/lib/promptGenerators/noErrorAttributes.js +17 -0
  2858. package/packages/ai/src/lib/promptGenerators/noErrorAttributes.js.map +1 -0
  2859. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  2860. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  2861. package/packages/ai/src/lib/promptGenerators/summarizeDiffGenerator.js +11 -0
  2862. package/packages/ai/src/lib/promptGenerators/summarizeDiffGenerator.js.map +1 -0
  2863. package/packages/ai/src/lib/providers.js +36 -0
  2864. package/packages/ai/src/lib/providers.js.map +1 -0
  2865. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  2866. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  2867. package/packages/ai/src/lib/services/aiServiceMode.js +132 -0
  2868. package/packages/ai/src/lib/services/aiServiceMode.js.map +1 -0
  2869. package/packages/ai/src/lib/services/claudeCliAIService.js +204 -0
  2870. package/packages/ai/src/lib/services/claudeCliAIService.js.map +1 -0
  2871. package/packages/ai/src/lib/splitOutsideParentheses.js +289 -0
  2872. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -0
  2873. package/packages/ai/src/lib/summarizeDiff.js +14 -0
  2874. package/packages/ai/src/lib/summarizeDiff.js.map +1 -0
  2875. package/packages/ai/src/lib/types/index.js +43 -0
  2876. package/packages/ai/src/lib/types/index.js.map +1 -0
  2877. package/packages/ai/src/lib/validateDataStructure.js +345 -0
  2878. package/packages/ai/src/lib/validateDataStructure.js.map +1 -0
  2879. package/packages/ai/src/lib/validateJson.js +64 -0
  2880. package/packages/ai/src/lib/validateJson.js.map +1 -0
  2881. package/packages/ai/src/lib/validatePlaywrightInstructions.js +162 -0
  2882. package/packages/ai/src/lib/validatePlaywrightInstructions.js.map +1 -0
  2883. package/packages/ai/src/lib/validateTypeStructure.js +72 -0
  2884. package/packages/ai/src/lib/validateTypeStructure.js.map +1 -0
  2885. package/packages/ai/src/lib/worker/SerializableDataStructure.js +128 -0
  2886. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -0
  2887. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +158 -0
  2888. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -0
  2889. package/packages/ai/src/lib/worker/analyzeScopeWorkerPaths.js +23 -0
  2890. package/packages/ai/src/lib/worker/analyzeScopeWorkerPaths.js.map +1 -0
  2891. package/packages/ai/src/lib/worker/fuzzyMatchFunctionName.js +64 -0
  2892. package/packages/ai/src/lib/worker/fuzzyMatchFunctionName.js.map +1 -0
  2893. package/packages/ai/src/lib/wrapperDetection/detectWrapperRequirements.js +103 -0
  2894. package/packages/ai/src/lib/wrapperDetection/detectWrapperRequirements.js.map +1 -0
  2895. package/packages/ai/src/lib/wrapperDetection/knownLibraryHooks.js +76 -0
  2896. package/packages/ai/src/lib/wrapperDetection/knownLibraryHooks.js.map +1 -0
  2897. package/packages/ai/src/lib/wrapperDetection/patterns/detectThrowOnMissingPatterns.js +155 -0
  2898. package/packages/ai/src/lib/wrapperDetection/patterns/detectThrowOnMissingPatterns.js.map +1 -0
  2899. package/packages/ai/src/lib/wrapperDetection/patterns/detectUseContextCalls.js +95 -0
  2900. package/packages/ai/src/lib/wrapperDetection/patterns/detectUseContextCalls.js.map +1 -0
  2901. package/packages/analyze/index.js +99 -0
  2902. package/packages/analyze/index.js.map +1 -0
  2903. package/packages/analyze/src/lib/FileAnalyzer.js +847 -0
  2904. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -0
  2905. package/packages/analyze/src/lib/ProjectAnalyzer.js +316 -0
  2906. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -0
  2907. package/packages/analyze/src/lib/analysisContext.js +238 -0
  2908. package/packages/analyze/src/lib/analysisContext.js.map +1 -0
  2909. package/packages/analyze/src/lib/asts/index.js +179 -0
  2910. package/packages/analyze/src/lib/asts/index.js.map +1 -0
  2911. package/packages/analyze/src/lib/asts/nodes/getCallExpressionNames.js +33 -0
  2912. package/packages/analyze/src/lib/asts/nodes/getCallExpressionNames.js.map +1 -0
  2913. package/packages/analyze/src/lib/asts/nodes/getFunctionNodeType.js +17 -0
  2914. package/packages/analyze/src/lib/asts/nodes/getFunctionNodeType.js.map +1 -0
  2915. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +108 -0
  2916. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -0
  2917. package/packages/analyze/src/lib/asts/nodes/getReactComponentType.js +36 -0
  2918. package/packages/analyze/src/lib/asts/nodes/getReactComponentType.js.map +1 -0
  2919. package/packages/analyze/src/lib/asts/nodes/index.js +139 -0
  2920. package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -0
  2921. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
  2922. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
  2923. package/packages/analyze/src/lib/asts/nodes/isDefaultExport.js +62 -0
  2924. package/packages/analyze/src/lib/asts/nodes/isDefaultExport.js.map +1 -0
  2925. package/packages/analyze/src/lib/asts/nodes/propsNodeToPropsData.js +342 -0
  2926. package/packages/analyze/src/lib/asts/nodes/propsNodeToPropsData.js.map +1 -0
  2927. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +205 -0
  2928. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -0
  2929. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntities.js +5 -0
  2930. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntities.js.map +1 -0
  2931. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +202 -0
  2932. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -0
  2933. package/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.js +104 -0
  2934. package/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.js.map +1 -0
  2935. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +197 -0
  2936. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -0
  2937. package/packages/analyze/src/lib/asts/sourceFiles/getComponentProps.js +24 -0
  2938. package/packages/analyze/src/lib/asts/sourceFiles/getComponentProps.js.map +1 -0
  2939. package/packages/analyze/src/lib/asts/sourceFiles/getComponentType.js +36 -0
  2940. package/packages/analyze/src/lib/asts/sourceFiles/getComponentType.js.map +1 -0
  2941. package/packages/analyze/src/lib/asts/sourceFiles/getDeclaredEntityNode.js +16 -0
  2942. package/packages/analyze/src/lib/asts/sourceFiles/getDeclaredEntityNode.js.map +1 -0
  2943. package/packages/analyze/src/lib/asts/sourceFiles/getDefaultExportedFunctionNode.js +38 -0
  2944. package/packages/analyze/src/lib/asts/sourceFiles/getDefaultExportedFunctionNode.js.map +1 -0
  2945. package/packages/analyze/src/lib/asts/sourceFiles/getEntityNode.js +17 -0
  2946. package/packages/analyze/src/lib/asts/sourceFiles/getEntityNode.js.map +1 -0
  2947. package/packages/analyze/src/lib/asts/sourceFiles/getImportMappings.js +33 -0
  2948. package/packages/analyze/src/lib/asts/sourceFiles/getImportMappings.js.map +1 -0
  2949. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +109 -0
  2950. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -0
  2951. package/packages/analyze/src/lib/asts/sourceFiles/getPropsFromFunctionalComponent.js +70 -0
  2952. package/packages/analyze/src/lib/asts/sourceFiles/getPropsFromFunctionalComponent.js.map +1 -0
  2953. package/packages/analyze/src/lib/asts/sourceFiles/getPseudoFile.js +10 -0
  2954. package/packages/analyze/src/lib/asts/sourceFiles/getPseudoFile.js.map +1 -0
  2955. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedImportedTypes.js +60 -0
  2956. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedImportedTypes.js.map +1 -0
  2957. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +126 -0
  2958. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -0
  2959. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFile.js +6 -0
  2960. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFile.js.map +1 -0
  2961. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +17 -0
  2962. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -0
  2963. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForImports.js +12 -0
  2964. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForImports.js.map +1 -0
  2965. package/packages/analyze/src/lib/asts/sourceFiles/index.js +44 -0
  2966. package/packages/analyze/src/lib/asts/sourceFiles/index.js.map +1 -0
  2967. package/packages/analyze/src/lib/files/analyze/analyzeEntities/extractClassMethods.js +95 -0
  2968. package/packages/analyze/src/lib/files/analyze/analyzeEntities/extractClassMethods.js.map +1 -0
  2969. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +758 -0
  2970. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -0
  2971. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncComplex.js +79 -0
  2972. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncComplex.js.map +1 -0
  2973. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncSimple.js +20 -0
  2974. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncSimple.js.map +1 -0
  2975. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/index.js +16 -0
  2976. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/index.js.map +1 -0
  2977. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/sequential.js +15 -0
  2978. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/sequential.js.map +1 -0
  2979. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/types.js +2 -0
  2980. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/types.js.map +1 -0
  2981. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +371 -0
  2982. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -0
  2983. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +88 -0
  2984. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -0
  2985. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +173 -0
  2986. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -0
  2987. package/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.js +15 -0
  2988. package/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.js.map +1 -0
  2989. package/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.js +13 -0
  2990. package/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.js.map +1 -0
  2991. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +84 -0
  2992. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -0
  2993. package/packages/analyze/src/lib/files/analyze/generateAnalysisTreeSha.js +118 -0
  2994. package/packages/analyze/src/lib/files/analyze/generateAnalysisTreeSha.js.map +1 -0
  2995. package/packages/analyze/src/lib/files/analyze/generateAnalyzedTreeSha.js +7 -0
  2996. package/packages/analyze/src/lib/files/analyze/generateAnalyzedTreeSha.js.map +1 -0
  2997. package/packages/analyze/src/lib/files/analyze/guessDefaultWidth.js +12 -0
  2998. package/packages/analyze/src/lib/files/analyze/guessDefaultWidth.js.map +1 -0
  2999. package/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.js +94 -0
  3000. package/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.js.map +1 -0
  3001. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +78 -0
  3002. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -0
  3003. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +106 -0
  3004. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -0
  3005. package/packages/analyze/src/lib/files/analyzeChange.js +148 -0
  3006. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -0
  3007. package/packages/analyze/src/lib/files/analyzeCodeChange.js +38 -0
  3008. package/packages/analyze/src/lib/files/analyzeCodeChange.js.map +1 -0
  3009. package/packages/analyze/src/lib/files/analyzeEntity.js +396 -0
  3010. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -0
  3011. package/packages/analyze/src/lib/files/analyzeFrameworkRoute.js +13 -0
  3012. package/packages/analyze/src/lib/files/analyzeFrameworkRoute.js.map +1 -0
  3013. package/packages/analyze/src/lib/files/analyzeInitial.js +119 -0
  3014. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -0
  3015. package/packages/analyze/src/lib/files/analyzeNextRoute.js +81 -0
  3016. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -0
  3017. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +103 -0
  3018. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -0
  3019. package/packages/analyze/src/lib/files/enums/steps.js +18 -0
  3020. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -0
  3021. package/packages/analyze/src/lib/files/extractDiffLines.js +22 -0
  3022. package/packages/analyze/src/lib/files/extractDiffLines.js.map +1 -0
  3023. package/packages/analyze/src/lib/files/fileAnalyzerFromCode.js +41 -0
  3024. package/packages/analyze/src/lib/files/fileAnalyzerFromCode.js.map +1 -0
  3025. package/packages/analyze/src/lib/files/findScenarioData.js +30 -0
  3026. package/packages/analyze/src/lib/files/findScenarioData.js.map +1 -0
  3027. package/packages/analyze/src/lib/files/getEntityCode.js +14 -0
  3028. package/packages/analyze/src/lib/files/getEntityCode.js.map +1 -0
  3029. package/packages/analyze/src/lib/files/getEntityType.js +13 -0
  3030. package/packages/analyze/src/lib/files/getEntityType.js.map +1 -0
  3031. package/packages/analyze/src/lib/files/getImportedExports.js +195 -0
  3032. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -0
  3033. package/packages/analyze/src/lib/files/getNodeModuleImports.js +24 -0
  3034. package/packages/analyze/src/lib/files/getNodeModuleImports.js.map +1 -0
  3035. package/packages/analyze/src/lib/files/newAnalysis.js +26 -0
  3036. package/packages/analyze/src/lib/files/newAnalysis.js.map +1 -0
  3037. package/packages/analyze/src/lib/files/recordStep.js +24 -0
  3038. package/packages/analyze/src/lib/files/recordStep.js.map +1 -0
  3039. package/packages/analyze/src/lib/files/relevantDiffPart.js +63 -0
  3040. package/packages/analyze/src/lib/files/relevantDiffPart.js.map +1 -0
  3041. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
  3042. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  3043. package/packages/analyze/src/lib/files/scenarios/detectChangedDataStructureFields.js +75 -0
  3044. package/packages/analyze/src/lib/files/scenarios/detectChangedDataStructureFields.js.map +1 -0
  3045. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +255 -0
  3046. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -0
  3047. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
  3048. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
  3049. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +684 -0
  3050. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -0
  3051. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js +110 -0
  3052. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js.map +1 -0
  3053. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +158 -0
  3054. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -0
  3055. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +600 -0
  3056. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -0
  3057. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +144 -0
  3058. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  3059. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +140 -0
  3060. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -0
  3061. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +93 -0
  3062. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -0
  3063. package/packages/analyze/src/lib/files/scenarios/isolateDataStructure.js +39 -0
  3064. package/packages/analyze/src/lib/files/scenarios/isolateDataStructure.js.map +1 -0
  3065. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1378 -0
  3066. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -0
  3067. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +188 -0
  3068. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -0
  3069. package/packages/analyze/src/lib/files/setImportedExports.js +208 -0
  3070. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -0
  3071. package/packages/analyze/src/lib/index.js +7 -0
  3072. package/packages/analyze/src/lib/index.js.map +1 -0
  3073. package/packages/analyze/src/lib/projects/index.js +42 -0
  3074. package/packages/analyze/src/lib/projects/index.js.map +1 -0
  3075. package/packages/analyze/src/lib/types/index.js +11 -0
  3076. package/packages/analyze/src/lib/types/index.js.map +1 -0
  3077. package/packages/analyze/src/lib/utils/deepEqual.js +32 -0
  3078. package/packages/analyze/src/lib/utils/deepEqual.js.map +1 -0
  3079. package/packages/analyze/src/lib/utils/getAnalysisError.js +4 -0
  3080. package/packages/analyze/src/lib/utils/getAnalysisError.js.map +1 -0
  3081. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  3082. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  3083. package/packages/analyze/src/lib/utils/measureAndReportExecutionTime.js +16 -0
  3084. package/packages/analyze/src/lib/utils/measureAndReportExecutionTime.js.map +1 -0
  3085. package/packages/analyze/src/lib/utils/measureExecutionTime.js +11 -0
  3086. package/packages/analyze/src/lib/utils/measureExecutionTime.js.map +1 -0
  3087. package/packages/aws/dynamodb/index.js +6 -0
  3088. package/packages/aws/dynamodb/index.js.map +1 -0
  3089. package/packages/aws/ecs/index.js +7 -0
  3090. package/packages/aws/ecs/index.js.map +1 -0
  3091. package/packages/aws/sqs/index.js +4 -0
  3092. package/packages/aws/sqs/index.js.map +1 -0
  3093. package/packages/aws/src/lib/dynamodb/loadLlmCall.js +26 -0
  3094. package/packages/aws/src/lib/dynamodb/loadLlmCall.js.map +1 -0
  3095. package/packages/aws/src/lib/dynamodb/loadLlmCalls.js +35 -0
  3096. package/packages/aws/src/lib/dynamodb/loadLlmCalls.js.map +1 -0
  3097. package/packages/aws/src/lib/dynamodb/provisionTable.js +66 -0
  3098. package/packages/aws/src/lib/dynamodb/provisionTable.js.map +1 -0
  3099. package/packages/aws/src/lib/dynamodb/saveLlmCall.js +67 -0
  3100. package/packages/aws/src/lib/dynamodb/saveLlmCall.js.map +1 -0
  3101. package/packages/aws/src/lib/dynamodb/tableNames.js +6 -0
  3102. package/packages/aws/src/lib/dynamodb/tableNames.js.map +1 -0
  3103. package/packages/aws/src/lib/dynamodb/types.js +2 -0
  3104. package/packages/aws/src/lib/dynamodb/types.js.map +1 -0
  3105. package/packages/aws/src/lib/ecs/ecsCheckTaskStatus.js +36 -0
  3106. package/packages/aws/src/lib/ecs/ecsCheckTaskStatus.js.map +1 -0
  3107. package/packages/aws/src/lib/ecs/ecsCreateTaskDefinition.js +138 -0
  3108. package/packages/aws/src/lib/ecs/ecsCreateTaskDefinition.js.map +1 -0
  3109. package/packages/aws/src/lib/ecs/ecsDefineContainer.js +30 -0
  3110. package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -0
  3111. package/packages/aws/src/lib/ecs/ecsStartTask.js +51 -0
  3112. package/packages/aws/src/lib/ecs/ecsStartTask.js.map +1 -0
  3113. package/packages/aws/src/lib/ecs/ecsTaskFactory.js +43 -0
  3114. package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -0
  3115. package/packages/aws/src/lib/sqs/getSqsQueueSizeStats.js +15 -0
  3116. package/packages/aws/src/lib/sqs/getSqsQueueSizeStats.js.map +1 -0
  3117. package/packages/aws/src/lib/sqs/sendSqsMessage.js +9 -0
  3118. package/packages/aws/src/lib/sqs/sendSqsMessage.js.map +1 -0
  3119. package/packages/database/index.js +84 -0
  3120. package/packages/database/index.js.map +1 -0
  3121. package/packages/database/src/lib/analysisBranchToDb.js +19 -0
  3122. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -0
  3123. package/packages/database/src/lib/analysisToDb.js +26 -0
  3124. package/packages/database/src/lib/analysisToDb.js.map +1 -0
  3125. package/packages/database/src/lib/backgroundJobToDb.js +13 -0
  3126. package/packages/database/src/lib/backgroundJobToDb.js.map +1 -0
  3127. package/packages/database/src/lib/branchToDb.js +18 -0
  3128. package/packages/database/src/lib/branchToDb.js.map +1 -0
  3129. package/packages/database/src/lib/commitBranchToDb.js +13 -0
  3130. package/packages/database/src/lib/commitBranchToDb.js.map +1 -0
  3131. package/packages/database/src/lib/commitToDb.js +26 -0
  3132. package/packages/database/src/lib/commitToDb.js.map +1 -0
  3133. package/packages/database/src/lib/createOrUpdateBranchCommitStats.js +108 -0
  3134. package/packages/database/src/lib/createOrUpdateBranchCommitStats.js.map +1 -0
  3135. package/packages/database/src/lib/createProject.js +22 -0
  3136. package/packages/database/src/lib/createProject.js.map +1 -0
  3137. package/packages/database/src/lib/createRetryFetch.js +42 -0
  3138. package/packages/database/src/lib/createRetryFetch.js.map +1 -0
  3139. package/packages/database/src/lib/dbToAnalysis.js +48 -0
  3140. package/packages/database/src/lib/dbToAnalysis.js.map +1 -0
  3141. package/packages/database/src/lib/dbToAnalysisBranch.js +24 -0
  3142. package/packages/database/src/lib/dbToAnalysisBranch.js.map +1 -0
  3143. package/packages/database/src/lib/dbToBackgroundJob.js +13 -0
  3144. package/packages/database/src/lib/dbToBackgroundJob.js.map +1 -0
  3145. package/packages/database/src/lib/dbToBranch.js +22 -0
  3146. package/packages/database/src/lib/dbToBranch.js.map +1 -0
  3147. package/packages/database/src/lib/dbToCommit.js +40 -0
  3148. package/packages/database/src/lib/dbToCommit.js.map +1 -0
  3149. package/packages/database/src/lib/dbToCommitBranch.js +18 -0
  3150. package/packages/database/src/lib/dbToCommitBranch.js.map +1 -0
  3151. package/packages/database/src/lib/dbToEntity.js +23 -0
  3152. package/packages/database/src/lib/dbToEntity.js.map +1 -0
  3153. package/packages/database/src/lib/dbToEntityBranch.js +13 -0
  3154. package/packages/database/src/lib/dbToEntityBranch.js.map +1 -0
  3155. package/packages/database/src/lib/dbToFile.js +14 -0
  3156. package/packages/database/src/lib/dbToFile.js.map +1 -0
  3157. package/packages/database/src/lib/dbToProject.js +16 -0
  3158. package/packages/database/src/lib/dbToProject.js.map +1 -0
  3159. package/packages/database/src/lib/dbToScenario.js +24 -0
  3160. package/packages/database/src/lib/dbToScenario.js.map +1 -0
  3161. package/packages/database/src/lib/dbToScenarioComment.js +21 -0
  3162. package/packages/database/src/lib/dbToScenarioComment.js.map +1 -0
  3163. package/packages/database/src/lib/dbToUserScenario.js +19 -0
  3164. package/packages/database/src/lib/dbToUserScenario.js.map +1 -0
  3165. package/packages/database/src/lib/deleteBranch.js +21 -0
  3166. package/packages/database/src/lib/deleteBranch.js.map +1 -0
  3167. package/packages/database/src/lib/deleteEntities.js +23 -0
  3168. package/packages/database/src/lib/deleteEntities.js.map +1 -0
  3169. package/packages/database/src/lib/deleteFile.js +18 -0
  3170. package/packages/database/src/lib/deleteFile.js.map +1 -0
  3171. package/packages/database/src/lib/deleteScenarios.js +34 -0
  3172. package/packages/database/src/lib/deleteScenarios.js.map +1 -0
  3173. package/packages/database/src/lib/entityToDb.js +54 -0
  3174. package/packages/database/src/lib/entityToDb.js.map +1 -0
  3175. package/packages/database/src/lib/fileToDb.js +14 -0
  3176. package/packages/database/src/lib/fileToDb.js.map +1 -0
  3177. package/packages/database/src/lib/generateSha.js +15 -0
  3178. package/packages/database/src/lib/generateSha.js.map +1 -0
  3179. package/packages/database/src/lib/jsonUpdateUtils.js +28 -0
  3180. package/packages/database/src/lib/jsonUpdateUtils.js.map +1 -0
  3181. package/packages/database/src/lib/kysely/aggregationHelpers.js +66 -0
  3182. package/packages/database/src/lib/kysely/aggregationHelpers.js.map +1 -0
  3183. package/packages/database/src/lib/kysely/db.js +373 -0
  3184. package/packages/database/src/lib/kysely/db.js.map +1 -0
  3185. package/packages/database/src/lib/kysely/schemaHelpers.js +17 -0
  3186. package/packages/database/src/lib/kysely/schemaHelpers.js.map +1 -0
  3187. package/packages/database/src/lib/kysely/sqliteBooleanPlugin.js +34 -0
  3188. package/packages/database/src/lib/kysely/sqliteBooleanPlugin.js.map +1 -0
  3189. package/packages/database/src/lib/kysely/tableRelations.js +2 -0
  3190. package/packages/database/src/lib/kysely/tableRelations.js.map +1 -0
  3191. package/packages/database/src/lib/kysely/tableRelationsTypes.js +7 -0
  3192. package/packages/database/src/lib/kysely/tableRelationsTypes.js.map +1 -0
  3193. package/packages/database/src/lib/kysely/tables/analysesTable.js +52 -0
  3194. package/packages/database/src/lib/kysely/tables/analysesTable.js.map +1 -0
  3195. package/packages/database/src/lib/kysely/tables/analysisBranchesTable.js +24 -0
  3196. package/packages/database/src/lib/kysely/tables/analysisBranchesTable.js.map +1 -0
  3197. package/packages/database/src/lib/kysely/tables/backgroundJobsTable.js +28 -0
  3198. package/packages/database/src/lib/kysely/tables/backgroundJobsTable.js.map +1 -0
  3199. package/packages/database/src/lib/kysely/tables/branchesTable.js +34 -0
  3200. package/packages/database/src/lib/kysely/tables/branchesTable.js.map +1 -0
  3201. package/packages/database/src/lib/kysely/tables/commitBranchesTable.js +22 -0
  3202. package/packages/database/src/lib/kysely/tables/commitBranchesTable.js.map +1 -0
  3203. package/packages/database/src/lib/kysely/tables/commitsTable.js +47 -0
  3204. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -0
  3205. package/packages/database/src/lib/kysely/tables/debugReportsTable.js +33 -0
  3206. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -0
  3207. package/packages/database/src/lib/kysely/tables/entitiesTable.js +38 -0
  3208. package/packages/database/src/lib/kysely/tables/entitiesTable.js.map +1 -0
  3209. package/packages/database/src/lib/kysely/tables/entityBranchesTable.js +22 -0
  3210. package/packages/database/src/lib/kysely/tables/entityBranchesTable.js.map +1 -0
  3211. package/packages/database/src/lib/kysely/tables/entityStatementsTable.js +22 -0
  3212. package/packages/database/src/lib/kysely/tables/entityStatementsTable.js.map +1 -0
  3213. package/packages/database/src/lib/kysely/tables/filesTable.js +28 -0
  3214. package/packages/database/src/lib/kysely/tables/filesTable.js.map +1 -0
  3215. package/packages/database/src/lib/kysely/tables/githubPayloadsTable.js +32 -0
  3216. package/packages/database/src/lib/kysely/tables/githubPayloadsTable.js.map +1 -0
  3217. package/packages/database/src/lib/kysely/tables/githubUsersTable.js +22 -0
  3218. package/packages/database/src/lib/kysely/tables/githubUsersTable.js.map +1 -0
  3219. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  3220. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  3221. package/packages/database/src/lib/kysely/tables/projectsTable.js +38 -0
  3222. package/packages/database/src/lib/kysely/tables/projectsTable.js.map +1 -0
  3223. package/packages/database/src/lib/kysely/tables/scenarioCommentsTable.js +28 -0
  3224. package/packages/database/src/lib/kysely/tables/scenarioCommentsTable.js.map +1 -0
  3225. package/packages/database/src/lib/kysely/tables/scenariosTable.js +30 -0
  3226. package/packages/database/src/lib/kysely/tables/scenariosTable.js.map +1 -0
  3227. package/packages/database/src/lib/kysely/tables/statementsTable.js +24 -0
  3228. package/packages/database/src/lib/kysely/tables/statementsTable.js.map +1 -0
  3229. package/packages/database/src/lib/kysely/tables/teamsTable.js +18 -0
  3230. package/packages/database/src/lib/kysely/tables/teamsTable.js.map +1 -0
  3231. package/packages/database/src/lib/kysely/tables/userScenariosTable.js +24 -0
  3232. package/packages/database/src/lib/kysely/tables/userScenariosTable.js.map +1 -0
  3233. package/packages/database/src/lib/kysely/tables/userTeamsTable.js +17 -0
  3234. package/packages/database/src/lib/kysely/tables/userTeamsTable.js.map +1 -0
  3235. package/packages/database/src/lib/kysely/tables/usersTable.js +26 -0
  3236. package/packages/database/src/lib/kysely/tables/usersTable.js.map +1 -0
  3237. package/packages/database/src/lib/kysely/upsertHelpers.js +9 -0
  3238. package/packages/database/src/lib/kysely/upsertHelpers.js.map +1 -0
  3239. package/packages/database/src/lib/loadAnalyses.js +174 -0
  3240. package/packages/database/src/lib/loadAnalyses.js.map +1 -0
  3241. package/packages/database/src/lib/loadAnalysis.js +138 -0
  3242. package/packages/database/src/lib/loadAnalysis.js.map +1 -0
  3243. package/packages/database/src/lib/loadAnalysisBranches.js +152 -0
  3244. package/packages/database/src/lib/loadAnalysisBranches.js.map +1 -0
  3245. package/packages/database/src/lib/loadBackgroundJob.js +19 -0
  3246. package/packages/database/src/lib/loadBackgroundJob.js.map +1 -0
  3247. package/packages/database/src/lib/loadBranch.js +100 -0
  3248. package/packages/database/src/lib/loadBranch.js.map +1 -0
  3249. package/packages/database/src/lib/loadBranches.js +37 -0
  3250. package/packages/database/src/lib/loadBranches.js.map +1 -0
  3251. package/packages/database/src/lib/loadCommit.js +118 -0
  3252. package/packages/database/src/lib/loadCommit.js.map +1 -0
  3253. package/packages/database/src/lib/loadCommitBranches.js +45 -0
  3254. package/packages/database/src/lib/loadCommitBranches.js.map +1 -0
  3255. package/packages/database/src/lib/loadCommitMetadata.js +26 -0
  3256. package/packages/database/src/lib/loadCommitMetadata.js.map +1 -0
  3257. package/packages/database/src/lib/loadCommits.js +209 -0
  3258. package/packages/database/src/lib/loadCommits.js.map +1 -0
  3259. package/packages/database/src/lib/loadEntities.js +82 -0
  3260. package/packages/database/src/lib/loadEntities.js.map +1 -0
  3261. package/packages/database/src/lib/loadEntity.js +72 -0
  3262. package/packages/database/src/lib/loadEntity.js.map +1 -0
  3263. package/packages/database/src/lib/loadEntityBranches.js +123 -0
  3264. package/packages/database/src/lib/loadEntityBranches.js.map +1 -0
  3265. package/packages/database/src/lib/loadFile.js +28 -0
  3266. package/packages/database/src/lib/loadFile.js.map +1 -0
  3267. package/packages/database/src/lib/loadFiles.js +101 -0
  3268. package/packages/database/src/lib/loadFiles.js.map +1 -0
  3269. package/packages/database/src/lib/loadMostRecentPreviousAnalysis.js +80 -0
  3270. package/packages/database/src/lib/loadMostRecentPreviousAnalysis.js.map +1 -0
  3271. package/packages/database/src/lib/loadProject.js +52 -0
  3272. package/packages/database/src/lib/loadProject.js.map +1 -0
  3273. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +68 -0
  3274. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -0
  3275. package/packages/database/src/lib/loadScenario.js +30 -0
  3276. package/packages/database/src/lib/loadScenario.js.map +1 -0
  3277. package/packages/database/src/lib/loadStatement.js +21 -0
  3278. package/packages/database/src/lib/loadStatement.js.map +1 -0
  3279. package/packages/database/src/lib/nullsToUndefines.js +7 -0
  3280. package/packages/database/src/lib/nullsToUndefines.js.map +1 -0
  3281. package/packages/database/src/lib/projectToDb.js +18 -0
  3282. package/packages/database/src/lib/projectToDb.js.map +1 -0
  3283. package/packages/database/src/lib/saveBackgroundEvent.js +10 -0
  3284. package/packages/database/src/lib/saveBackgroundEvent.js.map +1 -0
  3285. package/packages/database/src/lib/saveEntityStatements.js +20 -0
  3286. package/packages/database/src/lib/saveEntityStatements.js.map +1 -0
  3287. package/packages/database/src/lib/saveFiles.js +33 -0
  3288. package/packages/database/src/lib/saveFiles.js.map +1 -0
  3289. package/packages/database/src/lib/saveStatement.js +22 -0
  3290. package/packages/database/src/lib/saveStatement.js.map +1 -0
  3291. package/packages/database/src/lib/scenarioToDb.js +18 -0
  3292. package/packages/database/src/lib/scenarioToDb.js.map +1 -0
  3293. package/packages/database/src/lib/supabase.js +57 -0
  3294. package/packages/database/src/lib/supabase.js.map +1 -0
  3295. package/packages/database/src/lib/updateBackgroundJobProgress.js +61 -0
  3296. package/packages/database/src/lib/updateBackgroundJobProgress.js.map +1 -0
  3297. package/packages/database/src/lib/updateCommitMetadata.js +101 -0
  3298. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -0
  3299. package/packages/database/src/lib/updateEntityBranch.js +21 -0
  3300. package/packages/database/src/lib/updateEntityBranch.js.map +1 -0
  3301. package/packages/database/src/lib/updateFreshAnalysisMetadata.js +42 -0
  3302. package/packages/database/src/lib/updateFreshAnalysisMetadata.js.map +1 -0
  3303. package/packages/database/src/lib/updateFreshAnalysisStatus.js +42 -0
  3304. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -0
  3305. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +70 -0
  3306. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -0
  3307. package/packages/database/src/lib/updateProjectMetadata.js +60 -0
  3308. package/packages/database/src/lib/updateProjectMetadata.js.map +1 -0
  3309. package/packages/database/src/lib/upsertAnalyses.js +53 -0
  3310. package/packages/database/src/lib/upsertAnalyses.js.map +1 -0
  3311. package/packages/database/src/lib/upsertAnalysesWithScenarios.js +62 -0
  3312. package/packages/database/src/lib/upsertAnalysesWithScenarios.js.map +1 -0
  3313. package/packages/database/src/lib/upsertAnalysisBranches.js +72 -0
  3314. package/packages/database/src/lib/upsertAnalysisBranches.js.map +1 -0
  3315. package/packages/database/src/lib/upsertBackgroundJob.js +22 -0
  3316. package/packages/database/src/lib/upsertBackgroundJob.js.map +1 -0
  3317. package/packages/database/src/lib/upsertBranches.js +29 -0
  3318. package/packages/database/src/lib/upsertBranches.js.map +1 -0
  3319. package/packages/database/src/lib/upsertCommitBranches.js +29 -0
  3320. package/packages/database/src/lib/upsertCommitBranches.js.map +1 -0
  3321. package/packages/database/src/lib/upsertCommits.js +41 -0
  3322. package/packages/database/src/lib/upsertCommits.js.map +1 -0
  3323. package/packages/database/src/lib/upsertEntities.js +82 -0
  3324. package/packages/database/src/lib/upsertEntities.js.map +1 -0
  3325. package/packages/database/src/lib/upsertEntityBranches.js +27 -0
  3326. package/packages/database/src/lib/upsertEntityBranches.js.map +1 -0
  3327. package/packages/database/src/lib/upsertFiles.js +32 -0
  3328. package/packages/database/src/lib/upsertFiles.js.map +1 -0
  3329. package/packages/database/src/lib/upsertGithubUser.js +27 -0
  3330. package/packages/database/src/lib/upsertGithubUser.js.map +1 -0
  3331. package/packages/database/src/lib/upsertProjects.js +27 -0
  3332. package/packages/database/src/lib/upsertProjects.js.map +1 -0
  3333. package/packages/database/src/lib/upsertScenarios.js +28 -0
  3334. package/packages/database/src/lib/upsertScenarios.js.map +1 -0
  3335. package/packages/generate/index.js +16 -0
  3336. package/packages/generate/index.js.map +1 -0
  3337. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +136 -0
  3338. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -0
  3339. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js +108 -0
  3340. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js.map +1 -0
  3341. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
  3342. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  3343. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  3344. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  3345. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +82 -0
  3346. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -0
  3347. package/packages/generate/src/lib/componentScenarioPage/getImageReplacementCode.js +134 -0
  3348. package/packages/generate/src/lib/componentScenarioPage/getImageReplacementCode.js.map +1 -0
  3349. package/packages/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js +67 -0
  3350. package/packages/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js.map +1 -0
  3351. package/packages/generate/src/lib/constants.js +3 -0
  3352. package/packages/generate/src/lib/constants.js.map +1 -0
  3353. package/packages/generate/src/lib/deepMerge.js +72 -0
  3354. package/packages/generate/src/lib/deepMerge.js.map +1 -0
  3355. package/packages/generate/src/lib/directExecutionScript.js +165 -0
  3356. package/packages/generate/src/lib/directExecutionScript.js.map +1 -0
  3357. package/packages/generate/src/lib/escapeQuotes.js +4 -0
  3358. package/packages/generate/src/lib/escapeQuotes.js.map +1 -0
  3359. package/packages/generate/src/lib/getComponentImportStatement.js +23 -0
  3360. package/packages/generate/src/lib/getComponentImportStatement.js.map +1 -0
  3361. package/packages/generate/src/lib/getComponentImportStatements.js +24 -0
  3362. package/packages/generate/src/lib/getComponentImportStatements.js.map +1 -0
  3363. package/packages/generate/src/lib/getComponentScenarioPath.js +25 -0
  3364. package/packages/generate/src/lib/getComponentScenarioPath.js.map +1 -0
  3365. package/packages/generate/src/lib/getRelativePath.js +32 -0
  3366. package/packages/generate/src/lib/getRelativePath.js.map +1 -0
  3367. package/packages/generate/src/lib/handleCmdk.js +50 -0
  3368. package/packages/generate/src/lib/handleCmdk.js.map +1 -0
  3369. package/packages/generate/src/lib/handleRadix.js +224 -0
  3370. package/packages/generate/src/lib/handleRadix.js.map +1 -0
  3371. package/packages/generate/src/lib/handleWrappers.js +24 -0
  3372. package/packages/generate/src/lib/handleWrappers.js.map +1 -0
  3373. package/packages/generate/src/lib/libDemoComponent.js +160 -0
  3374. package/packages/generate/src/lib/libDemoComponent.js.map +1 -0
  3375. package/packages/generate/src/lib/mergeRootRemix.js +323 -0
  3376. package/packages/generate/src/lib/mergeRootRemix.js.map +1 -0
  3377. package/packages/generate/src/lib/requiredNodeModuleImports.js +45 -0
  3378. package/packages/generate/src/lib/requiredNodeModuleImports.js.map +1 -0
  3379. package/packages/generate/src/lib/safeFolder.js +11 -0
  3380. package/packages/generate/src/lib/safeFolder.js.map +1 -0
  3381. package/packages/generate/src/lib/scenarioComponent.js +94 -0
  3382. package/packages/generate/src/lib/scenarioComponent.js.map +1 -0
  3383. package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
  3384. package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  3385. package/packages/generate/src/lib/simpleRootRemix.js +73 -0
  3386. package/packages/generate/src/lib/simpleRootRemix.js.map +1 -0
  3387. package/packages/github/index.js +23 -0
  3388. package/packages/github/index.js.map +1 -0
  3389. package/packages/github/src/lib/constants.js +4 -0
  3390. package/packages/github/src/lib/constants.js.map +1 -0
  3391. package/packages/github/src/lib/createProjectOctokit.js +48 -0
  3392. package/packages/github/src/lib/createProjectOctokit.js.map +1 -0
  3393. package/packages/github/src/lib/getBranches.js +14 -0
  3394. package/packages/github/src/lib/getBranches.js.map +1 -0
  3395. package/packages/github/src/lib/getCommit.js +12 -0
  3396. package/packages/github/src/lib/getCommit.js.map +1 -0
  3397. package/packages/github/src/lib/getCommitFromGithub.js +57 -0
  3398. package/packages/github/src/lib/getCommitFromGithub.js.map +1 -0
  3399. package/packages/github/src/lib/getCommits.js +37 -0
  3400. package/packages/github/src/lib/getCommits.js.map +1 -0
  3401. package/packages/github/src/lib/getCommitsFromGithub.js +163 -0
  3402. package/packages/github/src/lib/getCommitsFromGithub.js.map +1 -0
  3403. package/packages/github/src/lib/getDiffBetweenCommits.js +26 -0
  3404. package/packages/github/src/lib/getDiffBetweenCommits.js.map +1 -0
  3405. package/packages/github/src/lib/getFirstCommitShaAfterTimestamp.js +22 -0
  3406. package/packages/github/src/lib/getFirstCommitShaAfterTimestamp.js.map +1 -0
  3407. package/packages/github/src/lib/getLatestCommit.js +28 -0
  3408. package/packages/github/src/lib/getLatestCommit.js.map +1 -0
  3409. package/packages/github/src/lib/getOpenPullRequests.js +28 -0
  3410. package/packages/github/src/lib/getOpenPullRequests.js.map +1 -0
  3411. package/packages/github/src/lib/getPublicReposWithQuery.js +12 -0
  3412. package/packages/github/src/lib/getPublicReposWithQuery.js.map +1 -0
  3413. package/packages/github/src/lib/getPullRequestsForCommit.js +21 -0
  3414. package/packages/github/src/lib/getPullRequestsForCommit.js.map +1 -0
  3415. package/packages/github/src/lib/getRepoInfo.js +35 -0
  3416. package/packages/github/src/lib/getRepoInfo.js.map +1 -0
  3417. package/packages/github/src/lib/getRepoWithBranches.js +53 -0
  3418. package/packages/github/src/lib/getRepoWithBranches.js.map +1 -0
  3419. package/packages/github/src/lib/getRepos.js +13 -0
  3420. package/packages/github/src/lib/getRepos.js.map +1 -0
  3421. package/packages/github/src/lib/getTree.js +14 -0
  3422. package/packages/github/src/lib/getTree.js.map +1 -0
  3423. package/packages/github/src/lib/githubToCommit.js +20 -0
  3424. package/packages/github/src/lib/githubToCommit.js.map +1 -0
  3425. package/packages/github/src/lib/loadOrCreateCommit.js +149 -0
  3426. package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -0
  3427. package/packages/github/src/lib/syncHeadBranches.js +38 -0
  3428. package/packages/github/src/lib/syncHeadBranches.js.map +1 -0
  3429. package/packages/github/src/lib/syncPrimaryBranch.js +75 -0
  3430. package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -0
  3431. package/packages/github/src/lib/syncPullRequest.js +48 -0
  3432. package/packages/github/src/lib/syncPullRequest.js.map +1 -0
  3433. package/packages/github/src/lib/updateCommitBranchesInDb.js +40 -0
  3434. package/packages/github/src/lib/updateCommitBranchesInDb.js.map +1 -0
  3435. package/packages/github/src/lib/updateFilesInDb.js +74 -0
  3436. package/packages/github/src/lib/updateFilesInDb.js.map +1 -0
  3437. package/packages/github/src/lib/urls.js +11 -0
  3438. package/packages/github/src/lib/urls.js.map +1 -0
  3439. package/packages/process/index.js +3 -0
  3440. package/packages/process/index.js.map +1 -0
  3441. package/packages/process/src/GlobalProcessManager.js +75 -0
  3442. package/packages/process/src/GlobalProcessManager.js.map +1 -0
  3443. package/packages/process/src/ProcessManager.js +244 -0
  3444. package/packages/process/src/ProcessManager.js.map +1 -0
  3445. package/packages/process/src/index.js +57 -0
  3446. package/packages/process/src/index.js.map +1 -0
  3447. package/packages/process/src/managedExecAsync.js +74 -0
  3448. package/packages/process/src/managedExecAsync.js.map +1 -0
  3449. package/packages/types/index.js +4 -0
  3450. package/packages/types/index.js.map +1 -0
  3451. package/packages/types/src/constants.js +2 -0
  3452. package/packages/types/src/constants.js.map +1 -0
  3453. package/packages/types/src/enums/ProjectFramework.js +10 -0
  3454. package/packages/types/src/enums/ProjectFramework.js.map +1 -0
  3455. package/packages/types/src/types/Analysis.js +3 -0
  3456. package/packages/types/src/types/Analysis.js.map +1 -0
  3457. package/packages/types/src/types/AnalysisBranch.js +2 -0
  3458. package/packages/types/src/types/AnalysisBranch.js.map +1 -0
  3459. package/packages/types/src/types/AnalysisMap.js +2 -0
  3460. package/packages/types/src/types/AnalysisMap.js.map +1 -0
  3461. package/packages/types/src/types/BackgroundJob.js +2 -0
  3462. package/packages/types/src/types/BackgroundJob.js.map +1 -0
  3463. package/packages/types/src/types/Branch.js +2 -0
  3464. package/packages/types/src/types/Branch.js.map +1 -0
  3465. package/packages/types/src/types/CodeExplanation.js +2 -0
  3466. package/packages/types/src/types/CodeExplanation.js.map +1 -0
  3467. package/packages/types/src/types/Commit.js +2 -0
  3468. package/packages/types/src/types/Commit.js.map +1 -0
  3469. package/packages/types/src/types/CommitBranch.js +2 -0
  3470. package/packages/types/src/types/CommitBranch.js.map +1 -0
  3471. package/packages/types/src/types/CommitChange.js +2 -0
  3472. package/packages/types/src/types/CommitChange.js.map +1 -0
  3473. package/packages/types/src/types/DeepPartial.js +2 -0
  3474. package/packages/types/src/types/DeepPartial.js.map +1 -0
  3475. package/packages/types/src/types/DeepReadonly.js +2 -0
  3476. package/packages/types/src/types/DeepReadonly.js.map +1 -0
  3477. package/packages/types/src/types/DependencyTreeNode.js +2 -0
  3478. package/packages/types/src/types/DependencyTreeNode.js.map +1 -0
  3479. package/packages/types/src/types/Entity.js +2 -0
  3480. package/packages/types/src/types/Entity.js.map +1 -0
  3481. package/packages/types/src/types/EntityBranch.js +2 -0
  3482. package/packages/types/src/types/EntityBranch.js.map +1 -0
  3483. package/packages/types/src/types/EntityMap.js +2 -0
  3484. package/packages/types/src/types/EntityMap.js.map +1 -0
  3485. package/packages/types/src/types/EntityType.js +2 -0
  3486. package/packages/types/src/types/EntityType.js.map +1 -0
  3487. package/packages/types/src/types/File.js +2 -0
  3488. package/packages/types/src/types/File.js.map +1 -0
  3489. package/packages/types/src/types/FilePreMock.js +2 -0
  3490. package/packages/types/src/types/FilePreMock.js.map +1 -0
  3491. package/packages/types/src/types/FileProp.js +2 -0
  3492. package/packages/types/src/types/FileProp.js.map +1 -0
  3493. package/packages/types/src/types/FileType.js +2 -0
  3494. package/packages/types/src/types/FileType.js.map +1 -0
  3495. package/packages/types/src/types/GithubBranch.js +2 -0
  3496. package/packages/types/src/types/GithubBranch.js.map +1 -0
  3497. package/packages/types/src/types/GithubFile.js +2 -0
  3498. package/packages/types/src/types/GithubFile.js.map +1 -0
  3499. package/packages/types/src/types/GithubRepoData.js +2 -0
  3500. package/packages/types/src/types/GithubRepoData.js.map +1 -0
  3501. package/packages/types/src/types/GithubRepoInfo.js +2 -0
  3502. package/packages/types/src/types/GithubRepoInfo.js.map +1 -0
  3503. package/packages/types/src/types/JsonTypeDefinition.js +2 -0
  3504. package/packages/types/src/types/JsonTypeDefinition.js.map +1 -0
  3505. package/packages/types/src/types/LlmCall.js +2 -0
  3506. package/packages/types/src/types/LlmCall.js.map +1 -0
  3507. package/packages/types/src/types/Mock.js +2 -0
  3508. package/packages/types/src/types/Mock.js.map +1 -0
  3509. package/packages/types/src/types/Project.js +2 -0
  3510. package/packages/types/src/types/Project.js.map +1 -0
  3511. package/packages/types/src/types/ProjectMetadata.js +2 -0
  3512. package/packages/types/src/types/ProjectMetadata.js.map +1 -0
  3513. package/packages/types/src/types/PropsWithTypes.js +2 -0
  3514. package/packages/types/src/types/PropsWithTypes.js.map +1 -0
  3515. package/packages/types/src/types/Scenario.js +2 -0
  3516. package/packages/types/src/types/Scenario.js.map +1 -0
  3517. package/packages/types/src/types/ScenarioComment.js +2 -0
  3518. package/packages/types/src/types/ScenarioComment.js.map +1 -0
  3519. package/packages/types/src/types/ScenarioData.js +2 -0
  3520. package/packages/types/src/types/ScenarioData.js.map +1 -0
  3521. package/packages/types/src/types/ScenariosDataStructure.js +2 -0
  3522. package/packages/types/src/types/ScenariosDataStructure.js.map +1 -0
  3523. package/packages/types/src/types/ScopeAnalysis.js +2 -0
  3524. package/packages/types/src/types/ScopeAnalysis.js.map +1 -0
  3525. package/packages/types/src/types/Statement.js +2 -0
  3526. package/packages/types/src/types/Statement.js.map +1 -0
  3527. package/packages/types/src/types/StatementInfo.js +2 -0
  3528. package/packages/types/src/types/StatementInfo.js.map +1 -0
  3529. package/packages/types/src/types/Team.js +2 -0
  3530. package/packages/types/src/types/Team.js.map +1 -0
  3531. package/packages/types/src/types/TimelineItem.js +2 -0
  3532. package/packages/types/src/types/TimelineItem.js.map +1 -0
  3533. package/packages/types/src/types/TsConfigPaths.js +2 -0
  3534. package/packages/types/src/types/TsConfigPaths.js.map +1 -0
  3535. package/packages/types/src/types/TypeStructures.js +2 -0
  3536. package/packages/types/src/types/TypeStructures.js.map +1 -0
  3537. package/packages/types/src/types/User.js +2 -0
  3538. package/packages/types/src/types/User.js.map +1 -0
  3539. package/packages/types/src/types/UserScenario.js +2 -0
  3540. package/packages/types/src/types/UserScenario.js.map +1 -0
  3541. package/packages/types/src/types/WebContainerFileSystemTree.js +2 -0
  3542. package/packages/types/src/types/WebContainerFileSystemTree.js.map +1 -0
  3543. package/packages/utils/index.js +31 -0
  3544. package/packages/utils/index.js.map +1 -0
  3545. package/packages/utils/server.js +13 -0
  3546. package/packages/utils/server.js.map +1 -0
  3547. package/packages/utils/src/lib/Semaphore.js +40 -0
  3548. package/packages/utils/src/lib/Semaphore.js.map +1 -0
  3549. package/packages/utils/src/lib/analyses/pushAnalysisError.js +10 -0
  3550. package/packages/utils/src/lib/analyses/pushAnalysisError.js.map +1 -0
  3551. package/packages/utils/src/lib/applyUniversalMocks.js +288 -0
  3552. package/packages/utils/src/lib/applyUniversalMocks.js.map +1 -0
  3553. package/packages/utils/src/lib/awsLog.js +48 -0
  3554. package/packages/utils/src/lib/awsLog.js.map +1 -0
  3555. package/packages/utils/src/lib/commitRuns.js +14 -0
  3556. package/packages/utils/src/lib/commitRuns.js.map +1 -0
  3557. package/packages/utils/src/lib/env/detectEnvFiles.js +217 -0
  3558. package/packages/utils/src/lib/env/detectEnvFiles.js.map +1 -0
  3559. package/packages/utils/src/lib/env/index.js +3 -0
  3560. package/packages/utils/src/lib/env/index.js.map +1 -0
  3561. package/packages/utils/src/lib/env/sanitizeEnvFiles.js +145 -0
  3562. package/packages/utils/src/lib/env/sanitizeEnvFiles.js.map +1 -0
  3563. package/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +25 -0
  3564. package/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -0
  3565. package/packages/utils/src/lib/frameworks/getFrameworkRoutePath.js +29 -0
  3566. package/packages/utils/src/lib/frameworks/getFrameworkRoutePath.js.map +1 -0
  3567. package/packages/utils/src/lib/frameworks/getNextRoutePath.js +22 -0
  3568. package/packages/utils/src/lib/frameworks/getNextRoutePath.js.map +1 -0
  3569. package/packages/utils/src/lib/frameworks/getRemixRoutePath.js +20 -0
  3570. package/packages/utils/src/lib/frameworks/getRemixRoutePath.js.map +1 -0
  3571. package/packages/utils/src/lib/frameworks/isFrameworkRoute.js +7 -0
  3572. package/packages/utils/src/lib/frameworks/isFrameworkRoute.js.map +1 -0
  3573. package/packages/utils/src/lib/frameworks/isNextRoute.js +12 -0
  3574. package/packages/utils/src/lib/frameworks/isNextRoute.js.map +1 -0
  3575. package/packages/utils/src/lib/frameworks/isRemixRoute.js +8 -0
  3576. package/packages/utils/src/lib/frameworks/isRemixRoute.js.map +1 -0
  3577. package/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +26 -0
  3578. package/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -0
  3579. package/packages/utils/src/lib/frameworks/remixRouteFileNameToRoute.js +22 -0
  3580. package/packages/utils/src/lib/frameworks/remixRouteFileNameToRoute.js.map +1 -0
  3581. package/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +62 -0
  3582. package/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -0
  3583. package/packages/utils/src/lib/fs/copyNodeRepoQuickly.js +181 -0
  3584. package/packages/utils/src/lib/fs/copyNodeRepoQuickly.js.map +1 -0
  3585. package/packages/utils/src/lib/fs/rsyncCopy.js +41 -0
  3586. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -0
  3587. package/packages/utils/src/lib/getFrameworkForFile.js +64 -0
  3588. package/packages/utils/src/lib/getFrameworkForFile.js.map +1 -0
  3589. package/packages/utils/src/lib/killProcess.server.js +102 -0
  3590. package/packages/utils/src/lib/killProcess.server.js.map +1 -0
  3591. package/packages/utils/src/lib/killProcessAndSubprocesses.server.js +62 -0
  3592. package/packages/utils/src/lib/killProcessAndSubprocesses.server.js.map +1 -0
  3593. package/packages/utils/src/lib/lightweightEntityExtractor.js +362 -0
  3594. package/packages/utils/src/lib/lightweightEntityExtractor.js.map +1 -0
  3595. package/packages/utils/src/lib/loadEnv.js +7 -0
  3596. package/packages/utils/src/lib/loadEnv.js.map +1 -0
  3597. package/packages/utils/src/lib/normalizeKey.js +4 -0
  3598. package/packages/utils/src/lib/normalizeKey.js.map +1 -0
  3599. package/packages/utils/src/lib/safeFileName.js +36 -0
  3600. package/packages/utils/src/lib/safeFileName.js.map +1 -0
  3601. package/packages/utils/src/lib/safeStringify.js +64 -0
  3602. package/packages/utils/src/lib/safeStringify.js.map +1 -0
  3603. package/packages/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  3604. package/packages/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  3605. package/packages/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  3606. package/packages/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  3607. package/packages/utils/src/lib/startCommand/index.js +3 -0
  3608. package/packages/utils/src/lib/startCommand/index.js.map +1 -0
  3609. package/scripts/finalize-analyzer.cjs +81 -0
  3610. package/bin.js +0 -13
@@ -0,0 +1,3668 @@
1
+ import ts from 'typescript';
2
+ import * as crypto from 'crypto';
3
+ import {
4
+ AnalysisContext,
5
+ CompoundConditional,
6
+ ConditionalUsage,
7
+ } from './types';
8
+ import { StructuredPath } from './paths';
9
+ import { nodeToSource } from './nodeToSource';
10
+ import { methodRegistry, ArrayPushSemantics } from './methodSemantics';
11
+ import {
12
+ isArithmeticOperator,
13
+ isAssignmentOperator,
14
+ isBitwiseCompoundOperator,
15
+ isComparisonOperator,
16
+ isDefinedType,
17
+ isNumericCompoundOperator,
18
+ leftOrRightType,
19
+ unwrapExpression,
20
+ } from './sharedPatterns';
21
+ import { processBindingPattern } from './processBindings';
22
+ import {
23
+ extractConditionalEffectsFromTernary,
24
+ findUseStateSetters,
25
+ } from './conditionalEffectsExtractor';
26
+ import { detectArrayDerivedPattern } from './arrayDerivationDetector';
27
+
28
+ /**
29
+ * Checks if a JSX element has props that reference variables from the parent scope.
30
+ * This is used to detect unconditionally-rendered children that should have their
31
+ * execution flows merged into the parent.
32
+ *
33
+ * We want to track children where the parent controls data that affects the child's
34
+ * conditional rendering. Static props (like title="Dashboard") don't need tracking
35
+ * because they don't create variable execution flows.
36
+ *
37
+ * Examples:
38
+ * - <WorkoutsView workouts={workouts} /> → true (workouts is a variable)
39
+ * - <ItemList items={items} count={count} /> → true (items, count are variables)
40
+ * - <Header title="Dashboard" /> → false (static string)
41
+ * - <Footer /> → false (no props)
42
+ * - <Button onClick={handleClick} /> → false (only callback, no data props)
43
+ *
44
+ * @returns true if the component has at least one prop that references a variable
45
+ * (excluding callbacks which typically start with 'on' or 'handle')
46
+ */
47
+ function hasDataPropsFromParent(
48
+ node: ts.JsxElement | ts.JsxSelfClosingElement,
49
+ componentName: string,
50
+ ): { hasDataProps: boolean; dataProps: string[] } {
51
+ const attributes = ts.isJsxElement(node)
52
+ ? node.openingElement.attributes.properties
53
+ : node.attributes.properties;
54
+
55
+ const dataProps: string[] = [];
56
+
57
+ for (const attr of attributes) {
58
+ // Spread attributes always reference parent data: {...props}
59
+ if (ts.isJsxSpreadAttribute(attr)) {
60
+ const spreadText = attr.expression?.getText() || '...spread';
61
+ dataProps.push(`{...${spreadText}}`);
62
+ console.log(
63
+ `[UnconditionalChild] ${componentName}: Found spread attribute {${spreadText}}`,
64
+ );
65
+ continue;
66
+ }
67
+
68
+ if (ts.isJsxAttribute(attr)) {
69
+ const propName = attr.name.getText();
70
+
71
+ // Skip callback props - they don't create data-driven execution flows
72
+ // Callbacks typically start with 'on' (onClick, onChange) or 'handle' (handleSubmit)
73
+ if (
74
+ propName.startsWith('on') ||
75
+ propName.startsWith('handle') ||
76
+ propName === 'ref'
77
+ ) {
78
+ console.log(
79
+ `[UnconditionalChild] ${componentName}: Skipping callback prop '${propName}'`,
80
+ );
81
+ continue;
82
+ }
83
+
84
+ // Check if the prop value is a JSX expression (references a variable)
85
+ // vs a string literal which is static
86
+ if (attr.initializer) {
87
+ if (ts.isJsxExpression(attr.initializer)) {
88
+ // JSX expression like prop={value} - this references a variable
89
+ // Could be a simple identifier, property access, or more complex expression
90
+ const expression = attr.initializer.expression;
91
+ if (expression) {
92
+ // Skip if it's just a function/arrow function (callback)
93
+ if (
94
+ ts.isArrowFunction(expression) ||
95
+ ts.isFunctionExpression(expression)
96
+ ) {
97
+ console.log(
98
+ `[UnconditionalChild] ${componentName}: Skipping inline callback prop '${propName}'`,
99
+ );
100
+ continue;
101
+ }
102
+ // This is a data prop that references parent state/props
103
+ const exprText = expression.getText();
104
+ dataProps.push(`${propName}={${exprText}}`);
105
+ console.log(
106
+ `[UnconditionalChild] ${componentName}: Found data prop '${propName}' = {${exprText}}`,
107
+ );
108
+ }
109
+ } else {
110
+ // String literals like prop="value" are static
111
+ console.log(
112
+ `[UnconditionalChild] ${componentName}: Skipping static prop '${propName}'`,
113
+ );
114
+ }
115
+ }
116
+ }
117
+ }
118
+
119
+ const hasDataProps = dataProps.length > 0;
120
+ if (hasDataProps) {
121
+ console.log(
122
+ `[UnconditionalChild] ${componentName}: Has ${dataProps.length} data props: [${dataProps.join(', ')}]`,
123
+ );
124
+ } else {
125
+ console.log(
126
+ `[UnconditionalChild] ${componentName}: No data props found, will NOT track`,
127
+ );
128
+ }
129
+
130
+ return { hasDataProps, dataProps };
131
+ }
132
+
133
+ /**
134
+ * Extracts the component name from a JSX element.
135
+ * Returns null for intrinsic elements (div, span, etc.) since we only care about
136
+ * custom components for gating condition tracking.
137
+ *
138
+ * Examples:
139
+ * - <ChildViewer /> → "ChildViewer"
140
+ * - <ScenarioViewer scenario={...} /> → "ScenarioViewer"
141
+ * - <div> → null (intrinsic element)
142
+ */
143
+ function getComponentNameFromJsx(
144
+ node: ts.JsxElement | ts.JsxSelfClosingElement,
145
+ ): string | null {
146
+ let tagName: ts.JsxTagNameExpression;
147
+
148
+ if (ts.isJsxElement(node)) {
149
+ tagName = node.openingElement.tagName;
150
+ } else {
151
+ tagName = node.tagName;
152
+ }
153
+
154
+ // Get the text of the tag name
155
+ const name = tagName.getText();
156
+
157
+ // Check if it's a custom component (starts with uppercase) vs intrinsic element
158
+ // Custom components start with uppercase: <MyComponent />
159
+ // Intrinsic elements start with lowercase: <div />
160
+ if (
161
+ name &&
162
+ name[0] === name[0].toUpperCase() &&
163
+ name[0] !== name[0].toLowerCase()
164
+ ) {
165
+ return name;
166
+ }
167
+
168
+ return null;
169
+ }
170
+
171
+ /**
172
+ * Extracts condition paths from a logical AND chain expression.
173
+ * Used for creating gating conditions for child components.
174
+ *
175
+ * Example: `hasData && isReady && <Component />` returns ['hasData', 'isReady']
176
+ */
177
+ function extractConditionPathsFromAndChain(
178
+ expr: ts.Expression,
179
+ sourceFile: ts.SourceFile,
180
+ ): string[] {
181
+ const paths: string[] = [];
182
+ const unwrapped = unwrapExpression(expr);
183
+
184
+ if (
185
+ ts.isBinaryExpression(unwrapped) &&
186
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
187
+ ) {
188
+ // Recursively get conditions from left side
189
+ paths.push(
190
+ ...extractConditionPathsFromAndChain(unwrapped.left, sourceFile),
191
+ );
192
+
193
+ // Process right side if it's not JSX (JSX is the consequence, not a condition)
194
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
195
+ if (
196
+ !ts.isJsxElement(rightUnwrapped) &&
197
+ !ts.isJsxSelfClosingElement(rightUnwrapped) &&
198
+ !ts.isJsxFragment(rightUnwrapped)
199
+ ) {
200
+ paths.push(
201
+ ...extractConditionPathsFromAndChain(unwrapped.right, sourceFile),
202
+ );
203
+ }
204
+ } else {
205
+ // Base case: extract path from this expression
206
+ const path = StructuredPath.fromNode(unwrapped, sourceFile);
207
+ if (path) {
208
+ paths.push(path.toString());
209
+ }
210
+ }
211
+
212
+ return paths;
213
+ }
214
+
215
+ /**
216
+ * Finds the rightmost JSX element in an && chain.
217
+ * Example: `a && b && <Component />` returns <Component />
218
+ */
219
+ function findJsxInAndChain(
220
+ expr: ts.Expression,
221
+ ): ts.JsxElement | ts.JsxSelfClosingElement | null {
222
+ const unwrapped = unwrapExpression(expr);
223
+
224
+ if (ts.isJsxElement(unwrapped) || ts.isJsxSelfClosingElement(unwrapped)) {
225
+ return unwrapped;
226
+ }
227
+
228
+ if (
229
+ ts.isBinaryExpression(unwrapped) &&
230
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
231
+ ) {
232
+ // Check right side first (most common case: condition && <Jsx />)
233
+ const rightResult = findJsxInAndChain(unwrapped.right);
234
+ if (rightResult) return rightResult;
235
+
236
+ // Also check left side for rare cases
237
+ return findJsxInAndChain(unwrapped.left);
238
+ }
239
+
240
+ return null;
241
+ }
242
+
243
+ /**
244
+ * Fix 32: Finds a JSX fragment in an && chain.
245
+ * Example: `activeTab && <><ChildA /><ChildB /></>` returns the fragment
246
+ * This is needed to propagate parent conditions through fragments.
247
+ */
248
+ function findJsxFragmentInAndChain(expr: ts.Expression): ts.JsxFragment | null {
249
+ const unwrapped = unwrapExpression(expr);
250
+
251
+ if (ts.isJsxFragment(unwrapped)) {
252
+ return unwrapped;
253
+ }
254
+
255
+ if (
256
+ ts.isBinaryExpression(unwrapped) &&
257
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
258
+ ) {
259
+ // Check right side first (most common case: condition && <></>)
260
+ const rightResult = findJsxFragmentInAndChain(unwrapped.right);
261
+ if (rightResult) return rightResult;
262
+
263
+ // Also check left side for rare cases
264
+ return findJsxFragmentInAndChain(unwrapped.left);
265
+ }
266
+
267
+ return null;
268
+ }
269
+
270
+ /**
271
+ * Detects if a property access looks like an environment variable store access.
272
+ * Matches patterns like `env.DATABASE_URL`, `env.IS_FORMBRICKS_CLOUD`, etc.
273
+ * where the object is named "env" and the property looks like an env var name.
274
+ */
275
+ function isEnvStoreAccess(fullText: string): boolean {
276
+ // Match: env.SOME_VAR or env.someVar (but object must be exactly "env")
277
+ // This catches patterns from @t3-oss/env-nextjs and similar packages
278
+ const envStorePattern = /^env\.[A-Z_][A-Z0-9_]*$/;
279
+ return envStorePattern.test(fullText);
280
+ }
281
+
282
+ /**
283
+ * Converts a call expression argument to a StructuredPath.
284
+ *
285
+ * IMPORTANT: We always use the original source text for callbacks, never cyScope names.
286
+ * cyScope names are internal identifiers for child scopes and should NEVER appear
287
+ * in schema paths or call signatures. Using cyScope names causes data merge conflicts
288
+ * because the same callback gets different identifiers in different contexts.
289
+ */
290
+ function getArgPathForCallSignature(
291
+ arg: ts.Expression,
292
+ context: AnalysisContext,
293
+ ): StructuredPath {
294
+ // Always use the standard path conversion - never replace with cyScope names
295
+ return (
296
+ StructuredPath.fromNode(arg, context.sourceFile) ||
297
+ nodeToSource(arg, context.sourceFile)
298
+ );
299
+ }
300
+
301
+ /**
302
+ * Builds a StructuredPath for a call expression using the original source text.
303
+ *
304
+ * IMPORTANT: This function ensures consistent call signatures by always using
305
+ * the original callback text, never cyScope names. This prevents schema path
306
+ * conflicts where the same call would have different paths.
307
+ */
308
+ function buildCallPathFromSource(
309
+ node: ts.CallExpression,
310
+ context: AnalysisContext,
311
+ ): StructuredPath | null {
312
+ const expression = node.expression;
313
+
314
+ // Convert arguments using original source text
315
+ const argPaths = node.arguments.map((arg) =>
316
+ getArgPathForCallSignature(arg, context),
317
+ );
318
+
319
+ // Handle type arguments if present
320
+ let typeArgs: string[] | undefined = undefined;
321
+ if (node.typeArguments && node.typeArguments.length > 0) {
322
+ typeArgs = node.typeArguments.map((typeArg) =>
323
+ typeArg.getText(context.sourceFile),
324
+ );
325
+ }
326
+
327
+ if (ts.isIdentifier(expression)) {
328
+ // Simple function call: func(arg1, arg2)
329
+ return StructuredPath.fromFunction(expression.text, argPaths, typeArgs);
330
+ } else if (ts.isPropertyAccessExpression(expression)) {
331
+ // Method call: obj.method(arg1, arg2)
332
+ const objPath = StructuredPath.fromNode(
333
+ expression.expression,
334
+ context.sourceFile,
335
+ );
336
+ if (!objPath) return null;
337
+ return objPath
338
+ .withProperty(expression.name.text)
339
+ .withFunctionCall(argPaths, typeArgs);
340
+ } else if (ts.isCallExpression(expression)) {
341
+ // Chained call: func(arg1)(arg2)
342
+ const funcPath = buildCallPathFromSource(expression, context);
343
+ if (!funcPath) return null;
344
+ return funcPath.withFunctionCall(argPaths, typeArgs);
345
+ } else if (ts.isElementAccessExpression(expression)) {
346
+ // Element access call: obj[key](args)
347
+ const basePath = StructuredPath.fromNode(expression, context.sourceFile);
348
+ if (!basePath) return null;
349
+ return basePath.withFunctionCall(argPaths, typeArgs);
350
+ } else {
351
+ // Complex call expression
352
+ const basePath = StructuredPath.fromNode(expression, context.sourceFile);
353
+ if (!basePath) return null;
354
+ return basePath.withFunctionCall(argPaths, typeArgs);
355
+ }
356
+ }
357
+
358
+ /**
359
+ * Checks if an expression is likely an array type.
360
+ * Uses TypeScript's type checker when available, falls back to heuristics.
361
+ */
362
+ function isLikelyArrayType(
363
+ expr: ts.Expression,
364
+ typeChecker: ts.TypeChecker | undefined,
365
+ ): boolean {
366
+ if (typeChecker) {
367
+ try {
368
+ const type = typeChecker.getTypeAtLocation(expr);
369
+ const typeString = typeChecker.typeToString(type);
370
+ // Check for common array type patterns:
371
+ // - T[] syntax (includes any[], string[], etc.)
372
+ // - Array<T> syntax
373
+ // - ReadonlyArray<T> syntax
374
+ // - readonly T[] syntax (starts with "readonly " and ends with "[]")
375
+ if (
376
+ typeString.includes('[]') ||
377
+ typeString.startsWith('Array<') ||
378
+ typeString.startsWith('ReadonlyArray<')
379
+ ) {
380
+ return true;
381
+ }
382
+ // Check if it's a tuple or array literal type via TypeScript's type flags
383
+ if (type.getFlags() & ts.TypeFlags.Object) {
384
+ const objectType = type as ts.ObjectType;
385
+ if (
386
+ objectType.objectFlags & ts.ObjectFlags.Tuple ||
387
+ objectType.objectFlags & ts.ObjectFlags.ArrayLiteral
388
+ ) {
389
+ return true;
390
+ }
391
+ }
392
+ } catch {
393
+ // Type checking can fail in some edge cases, fall through to false
394
+ }
395
+ }
396
+ return false;
397
+ }
398
+
399
+ /**
400
+ * Marks variables used in truthiness checks as potentially undefined.
401
+ * When code checks `if (x)` or `x && ...`, it indicates x might be falsy (null/undefined).
402
+ * This function walks through the condition and adds | undefined to such variables.
403
+ */
404
+ export function markConditionVariablesAsNullable(
405
+ condition: ts.Expression,
406
+ context: AnalysisContext,
407
+ ): void {
408
+ const unwrapped = unwrapExpression(condition);
409
+
410
+ // For binary expressions with &&, mark both sides as nullable if they're truthiness checks
411
+ // Example: `diffView && <Component />` means diffView might be undefined
412
+ // Example: `a && b && <Component />` means both a and b might be undefined
413
+ if (
414
+ ts.isBinaryExpression(unwrapped) &&
415
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
416
+ ) {
417
+ // Recursively mark left side
418
+ markConditionVariablesAsNullable(unwrapped.left, context);
419
+
420
+ // Mark right side if it's also a truthiness check (not JSX or other consequences)
421
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
422
+ // Check if right side is JSX or contains JSX
423
+ const isJsxConsequence =
424
+ ts.isJsxElement(rightUnwrapped) ||
425
+ ts.isJsxSelfClosingElement(rightUnwrapped) ||
426
+ ts.isJsxFragment(rightUnwrapped);
427
+
428
+ if (!isJsxConsequence) {
429
+ // This handles chains like `a && b && ...` where both a and b are checks
430
+ markConditionVariablesAsNullable(unwrapped.right, context);
431
+ }
432
+ return;
433
+ }
434
+
435
+ // Don't mark variables in comparison operators as nullable
436
+ // Example: `if (x === 5)` doesn't mean x might be undefined
437
+ if (
438
+ ts.isBinaryExpression(unwrapped) &&
439
+ isComparisonOperator(unwrapped.operatorToken.kind)
440
+ ) {
441
+ return;
442
+ }
443
+
444
+ // For simple identifiers or property accesses, mark as potentially undefined
445
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
446
+ if (path) {
447
+ const currentType = context.getTypeInfo(path) || 'unknown';
448
+
449
+ // Only add | undefined if it's not already there
450
+ if (!currentType.includes('undefined')) {
451
+ context.addType(path, `${currentType} | undefined`);
452
+ }
453
+ }
454
+ }
455
+
456
+ /**
457
+ * Helper to extract source location from an AST node
458
+ */
459
+ function getSourceLocation(
460
+ node: ts.Node,
461
+ sourceFile: ts.SourceFile,
462
+ ): ConditionalUsage['sourceLocation'] {
463
+ const start = node.getStart(sourceFile);
464
+ const { line, character } = sourceFile.getLineAndCharacterOfPosition(start);
465
+ const codeSnippet = node.getText(sourceFile);
466
+
467
+ return {
468
+ lineNumber: line + 1, // Convert to 1-based
469
+ column: character,
470
+ codeSnippet:
471
+ codeSnippet.length > 100
472
+ ? codeSnippet.slice(0, 100) + '...'
473
+ : codeSnippet,
474
+ };
475
+ }
476
+
477
+ /**
478
+ * Extracts the root array path from an expression that ends with .map().
479
+ * Handles chained methods like .filter().map(), .slice().map(), etc.
480
+ *
481
+ * Examples:
482
+ * - items.map(...) → "items"
483
+ * - data.users.map(...) → "data.users"
484
+ * - items.filter(...).map(...) → "items"
485
+ * - items.slice(0, 5).map(...) → "items"
486
+ */
487
+ function extractArrayPathFromMapCall(
488
+ expr: ts.CallExpression,
489
+ sourceFile: ts.SourceFile,
490
+ ): string | null {
491
+ // Walk up the chain to find the root array
492
+ let current: ts.Expression = expr.expression;
493
+
494
+ while (ts.isPropertyAccessExpression(current)) {
495
+ const methodName = current.name.getText(sourceFile);
496
+
497
+ // Common array methods that return arrays (so we keep going up)
498
+ const arrayReturningMethods = [
499
+ 'map',
500
+ 'filter',
501
+ 'slice',
502
+ 'concat',
503
+ 'flat',
504
+ 'flatMap',
505
+ 'reverse',
506
+ 'sort',
507
+ 'toReversed',
508
+ 'toSorted',
509
+ 'toSpliced',
510
+ ];
511
+
512
+ if (arrayReturningMethods.includes(methodName)) {
513
+ const objectExpr = current.expression;
514
+
515
+ // If the object is a call expression (chained method), keep going
516
+ if (ts.isCallExpression(objectExpr)) {
517
+ current = objectExpr.expression;
518
+ } else {
519
+ // Found the root - it's an identifier or property access
520
+ const path = StructuredPath.fromNode(objectExpr, sourceFile);
521
+ return path ? path.toString() : null;
522
+ }
523
+ } else {
524
+ // Not an array method we recognize
525
+ break;
526
+ }
527
+ }
528
+
529
+ return null;
530
+ }
531
+
532
+ /**
533
+ * Extracts JSX rendering usages from a JSX expression.
534
+ * Detects:
535
+ * - array.map() calls → 'array-map' type
536
+ * - string interpolations (identifiers/property access) → 'text-interpolation' type
537
+ *
538
+ * Recursively searches inside && chains and ternary expressions.
539
+ *
540
+ * @param expr The expression inside {expr}
541
+ * @param context The analysis context
542
+ */
543
+ function extractJsxRenderingUsage(
544
+ expr: ts.Expression,
545
+ context: AnalysisContext,
546
+ ): void {
547
+ const unwrapped = unwrapExpression(expr);
548
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
549
+
550
+ // Detect array.map() calls
551
+ if (ts.isCallExpression(unwrapped)) {
552
+ const calleeExpr = unwrapped.expression;
553
+
554
+ if (ts.isPropertyAccessExpression(calleeExpr)) {
555
+ const methodName = calleeExpr.name.getText(context.sourceFile);
556
+
557
+ if (methodName === 'map') {
558
+ const arrayPath = extractArrayPathFromMapCall(
559
+ unwrapped,
560
+ context.sourceFile,
561
+ );
562
+
563
+ if (arrayPath) {
564
+ context.addJsxRenderingUsage({
565
+ path: arrayPath,
566
+ renderingType: 'array-map',
567
+ valueType: 'array',
568
+ sourceLocation,
569
+ });
570
+ }
571
+ }
572
+ }
573
+ }
574
+ // Detect simple string interpolations: {title} or {user.name}
575
+ else if (
576
+ ts.isIdentifier(unwrapped) ||
577
+ ts.isPropertyAccessExpression(unwrapped)
578
+ ) {
579
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
580
+
581
+ if (path) {
582
+ const pathStr = path.toString();
583
+ const typeInfo = context.getTypeInfo(path);
584
+
585
+ // Only track as text interpolation if it's a string type
586
+ // Check for 'string' type, or types that contain 'string' (but not 'string[]')
587
+ if (
588
+ typeInfo === 'string' ||
589
+ (typeInfo &&
590
+ typeInfo.includes('string') &&
591
+ !typeInfo.includes('string[]'))
592
+ ) {
593
+ context.addJsxRenderingUsage({
594
+ path: pathStr,
595
+ renderingType: 'text-interpolation',
596
+ valueType: 'string',
597
+ sourceLocation,
598
+ });
599
+ }
600
+ }
601
+ }
602
+ // Recursively search inside && chains: {showList && items.map(...)}
603
+ else if (
604
+ ts.isBinaryExpression(unwrapped) &&
605
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
606
+ ) {
607
+ // Check the right side of the && chain (where .map() typically appears)
608
+ const rightSide = unwrapExpression(unwrapped.right);
609
+ extractJsxRenderingUsage(rightSide, context);
610
+ // Also check nested && chains on the left
611
+ extractJsxRenderingUsage(unwrapped.left, context);
612
+ }
613
+ // Recursively search inside ternaries: {isEmpty ? null : items.map(...)}
614
+ else if (ts.isConditionalExpression(unwrapped)) {
615
+ extractJsxRenderingUsage(unwrapped.whenTrue, context);
616
+ extractJsxRenderingUsage(unwrapped.whenFalse, context);
617
+ }
618
+ }
619
+
620
+ /**
621
+ * Counts the number of conditions in an && chain (excluding JSX consequence)
622
+ */
623
+ function countConditionsInAndChain(expr: ts.Expression): number {
624
+ const unwrapped = unwrapExpression(expr);
625
+
626
+ if (
627
+ ts.isBinaryExpression(unwrapped) &&
628
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
629
+ ) {
630
+ const leftCount = countConditionsInAndChain(unwrapped.left);
631
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
632
+ const isJsxConsequence =
633
+ ts.isJsxElement(rightUnwrapped) ||
634
+ ts.isJsxSelfClosingElement(rightUnwrapped) ||
635
+ ts.isJsxFragment(rightUnwrapped);
636
+
637
+ if (isJsxConsequence) {
638
+ return leftCount;
639
+ }
640
+ return leftCount + countConditionsInAndChain(unwrapped.right);
641
+ }
642
+
643
+ // Single condition (not an && chain)
644
+ return 1;
645
+ }
646
+
647
+ /**
648
+ * Chain tracking info for compound conditionals
649
+ */
650
+ interface ChainInfo {
651
+ chainId: string;
652
+ chainLength: number;
653
+ chainExpression: string;
654
+ currentPosition: number;
655
+ compound: CompoundConditional;
656
+ /**
657
+ * When processing OR expressions within an && chain, this tracks the
658
+ * current OR group ID. Conditions added while this is set will be marked
659
+ * as OR alternatives (only one needs to be true).
660
+ */
661
+ currentOrGroupId?: string;
662
+ }
663
+
664
+ /**
665
+ * Parent gating condition accumulated during JSX traversal.
666
+ * Used to track conditions from parent && chains that gate child components.
667
+ */
668
+ interface ParentGatingCondition {
669
+ path: string;
670
+ sourceLocation: { lineNumber: number; column: number; codeSnippet: string };
671
+ isNegated?: boolean;
672
+ }
673
+
674
+ /**
675
+ * Extracts conditionals from JSX elements by recursively traversing children.
676
+ *
677
+ * This is CRITICAL for extracting compound conditionals from JSX expressions
678
+ * like `{hasNewerVersion && !isActive && <Banner />}`.
679
+ *
680
+ * This function is called BEFORE the child boundary check in processExpression
681
+ * because JSX elements are NOT scopes - their expressions use variables from
682
+ * the parent scope and should have their conditionals extracted regardless of
683
+ * whether the JSX is within a child boundary.
684
+ *
685
+ * Fix 32: Added parentConditions parameter to track gating conditions from
686
+ * parent && chains. When we find a component nested inside multiple conditionals
687
+ * like `{activeTab && <>{ternary ? ... : <Component />}</>}`, ALL parent
688
+ * conditions should be added as gating conditions for the component.
689
+ *
690
+ * @param node The JSX element, self-closing element, or fragment to traverse
691
+ * @param context The analysis context
692
+ * @param parentConditions Accumulated gating conditions from parent && chains
693
+ */
694
+ function extractConditionalsFromJsx(
695
+ node: ts.JsxElement | ts.JsxSelfClosingElement | ts.JsxFragment,
696
+ context: AnalysisContext,
697
+ parentConditions: ParentGatingCondition[] = [],
698
+ ): void {
699
+ // Get children to process
700
+ let children: ts.NodeArray<ts.JsxChild> | undefined;
701
+
702
+ if (ts.isJsxElement(node)) {
703
+ children = node.children;
704
+ } else if (ts.isJsxFragment(node)) {
705
+ children = node.children;
706
+ }
707
+ // JsxSelfClosingElement has no children
708
+
709
+ if (!children) {
710
+ return;
711
+ }
712
+
713
+ for (const child of children) {
714
+ // Process JSX expressions: {expr}
715
+ if (ts.isJsxExpression(child) && child.expression) {
716
+ const expr = unwrapExpression(child.expression);
717
+
718
+ // Extract JSX rendering usages (array.map, text interpolation)
719
+ // This handles direct usages like {items.map(...)} or {user.name}
720
+ extractJsxRenderingUsage(expr, context);
721
+
722
+ // If the expression is an && chain, extract its conditional usages
723
+ if (
724
+ ts.isBinaryExpression(expr) &&
725
+ expr.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
726
+ ) {
727
+ // Mark nullable variables
728
+ markConditionVariablesAsNullable(expr, context);
729
+ // Extract conditional usage (this handles compound conditionals)
730
+ // Pass controlsJsxRendering: true since this conditional controls JSX rendering
731
+ extractConditionalUsage(expr, context, 'logical-and', {
732
+ controlsJsxRendering: true,
733
+ });
734
+
735
+ // Extract all condition paths from the && chain for gating tracking
736
+ const conditionPaths = extractConditionPathsFromAndChain(
737
+ expr,
738
+ context.sourceFile,
739
+ );
740
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
741
+
742
+ // Fix 32: Build accumulated conditions including parent conditions
743
+ const accumulatedConditions: ParentGatingCondition[] = [
744
+ ...parentConditions,
745
+ ...conditionPaths.map((path) => ({
746
+ path,
747
+ sourceLocation,
748
+ isNegated: false,
749
+ })),
750
+ ];
751
+
752
+ // Track gating conditions for child components
753
+ // Example: {hasAnalysis && <ScenarioViewer />}
754
+ const jsxElement = findJsxInAndChain(expr);
755
+ if (jsxElement) {
756
+ const componentName = getComponentNameFromJsx(jsxElement);
757
+ if (componentName) {
758
+ // Fix 32: Add ALL accumulated conditions (parent + current) as gating conditions
759
+ for (const condition of accumulatedConditions) {
760
+ context.addChildBoundaryGatingCondition(componentName, {
761
+ path: condition.path,
762
+ conditionType: 'truthiness',
763
+ location: 'logical-and',
764
+ sourceLocation: condition.sourceLocation,
765
+ controlsJsxRendering: true,
766
+ isNegated: condition.isNegated,
767
+ });
768
+ }
769
+ }
770
+
771
+ // Fix 32: Recursively process nested JSX with accumulated conditions
772
+ if (
773
+ ts.isJsxElement(jsxElement) ||
774
+ ts.isJsxSelfClosingElement(jsxElement)
775
+ ) {
776
+ extractConditionalsFromJsx(
777
+ jsxElement,
778
+ context,
779
+ accumulatedConditions,
780
+ );
781
+ }
782
+ }
783
+
784
+ // Fix 32: Also check for nested JSX fragments
785
+ const jsxFragment = findJsxFragmentInAndChain(expr);
786
+ if (jsxFragment) {
787
+ extractConditionalsFromJsx(
788
+ jsxFragment,
789
+ context,
790
+ accumulatedConditions,
791
+ );
792
+ }
793
+ }
794
+ // If the expression is a ternary, extract its conditional
795
+ else if (ts.isConditionalExpression(expr)) {
796
+ // Pass controlsJsxRendering: true since this conditional controls JSX rendering
797
+ extractConditionalUsage(expr.condition, context, 'ternary', {
798
+ controlsJsxRendering: true,
799
+ });
800
+
801
+ // Track gating conditions for components in both branches of the ternary
802
+ // Example: {isError ? <ErrorView /> : <SuccessView />}
803
+ const conditionPath = StructuredPath.fromNode(
804
+ unwrapExpression(expr.condition),
805
+ context.sourceFile,
806
+ );
807
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
808
+
809
+ // Recursively process the whenTrue and whenFalse branches for JSX
810
+ const whenTrue = unwrapExpression(expr.whenTrue);
811
+ const whenFalse = unwrapExpression(expr.whenFalse);
812
+
813
+ // Fix 32: Build conditions for whenTrue branch (parent conditions + ternary condition truthy)
814
+ const whenTrueConditions: ParentGatingCondition[] = [
815
+ ...parentConditions,
816
+ ...(conditionPath
817
+ ? [
818
+ {
819
+ path: conditionPath.toString(),
820
+ sourceLocation,
821
+ isNegated: false,
822
+ },
823
+ ]
824
+ : []),
825
+ ];
826
+
827
+ // Fix 32: Build conditions for whenFalse branch (parent conditions + ternary condition falsy)
828
+ const whenFalseConditions: ParentGatingCondition[] = [
829
+ ...parentConditions,
830
+ ...(conditionPath
831
+ ? [
832
+ {
833
+ path: conditionPath.toString(),
834
+ sourceLocation,
835
+ isNegated: true,
836
+ },
837
+ ]
838
+ : []),
839
+ ];
840
+
841
+ // Handle whenTrue branch (condition is truthy)
842
+ if (ts.isJsxElement(whenTrue) || ts.isJsxSelfClosingElement(whenTrue)) {
843
+ const componentName = getComponentNameFromJsx(whenTrue);
844
+ if (componentName) {
845
+ // Fix 32: Add ALL conditions (parent + ternary) as gating conditions
846
+ for (const condition of whenTrueConditions) {
847
+ context.addChildBoundaryGatingCondition(componentName, {
848
+ path: condition.path,
849
+ conditionType: 'truthiness',
850
+ location: 'ternary',
851
+ sourceLocation: condition.sourceLocation,
852
+ controlsJsxRendering: true,
853
+ isNegated: condition.isNegated,
854
+ });
855
+ }
856
+ }
857
+ }
858
+ if (
859
+ ts.isJsxElement(whenTrue) ||
860
+ ts.isJsxSelfClosingElement(whenTrue) ||
861
+ ts.isJsxFragment(whenTrue)
862
+ ) {
863
+ extractConditionalsFromJsx(whenTrue, context, whenTrueConditions);
864
+ }
865
+
866
+ // Handle whenFalse branch (condition is falsy/negated)
867
+ if (
868
+ ts.isJsxElement(whenFalse) ||
869
+ ts.isJsxSelfClosingElement(whenFalse)
870
+ ) {
871
+ const componentName = getComponentNameFromJsx(whenFalse);
872
+ if (componentName) {
873
+ // Fix 32: Add ALL conditions (parent + ternary) as gating conditions
874
+ for (const condition of whenFalseConditions) {
875
+ context.addChildBoundaryGatingCondition(componentName, {
876
+ path: condition.path,
877
+ conditionType: 'truthiness',
878
+ location: 'ternary',
879
+ sourceLocation: condition.sourceLocation,
880
+ controlsJsxRendering: true,
881
+ isNegated: condition.isNegated,
882
+ });
883
+ }
884
+ }
885
+ }
886
+ if (
887
+ ts.isJsxElement(whenFalse) ||
888
+ ts.isJsxSelfClosingElement(whenFalse) ||
889
+ ts.isJsxFragment(whenFalse)
890
+ ) {
891
+ extractConditionalsFromJsx(whenFalse, context, whenFalseConditions);
892
+ }
893
+ // Handle chained ternaries: a ? <A/> : b ? <B/> : <C/>
894
+ // When whenFalse is another ConditionalExpression, recursively process it
895
+ else if (ts.isConditionalExpression(whenFalse)) {
896
+ // Extract conditional usage for the nested ternary's condition
897
+ extractConditionalUsage(whenFalse.condition, context, 'ternary', {
898
+ controlsJsxRendering: true,
899
+ });
900
+
901
+ // Get the nested condition path
902
+ const nestedConditionPath = StructuredPath.fromNode(
903
+ unwrapExpression(whenFalse.condition),
904
+ context.sourceFile,
905
+ );
906
+ const nestedSourceLocation = getSourceLocation(
907
+ whenFalse,
908
+ context.sourceFile,
909
+ );
910
+
911
+ const nestedWhenTrue = unwrapExpression(whenFalse.whenTrue);
912
+ const nestedWhenFalse = unwrapExpression(whenFalse.whenFalse);
913
+
914
+ // Fix 32: Build conditions for nested whenTrue (parent falsy + nested truthy)
915
+ const nestedWhenTrueConditions: ParentGatingCondition[] = [
916
+ ...whenFalseConditions, // Parent ternary was falsy to get here
917
+ ...(nestedConditionPath
918
+ ? [
919
+ {
920
+ path: nestedConditionPath.toString(),
921
+ sourceLocation: nestedSourceLocation,
922
+ isNegated: false,
923
+ },
924
+ ]
925
+ : []),
926
+ ];
927
+
928
+ // Fix 32: Build conditions for nested whenFalse (parent falsy + nested falsy)
929
+ const nestedWhenFalseConditions: ParentGatingCondition[] = [
930
+ ...whenFalseConditions, // Parent ternary was falsy to get here
931
+ ...(nestedConditionPath
932
+ ? [
933
+ {
934
+ path: nestedConditionPath.toString(),
935
+ sourceLocation: nestedSourceLocation,
936
+ isNegated: true,
937
+ },
938
+ ]
939
+ : []),
940
+ ];
941
+
942
+ // Handle nested whenTrue branch
943
+ if (
944
+ ts.isJsxElement(nestedWhenTrue) ||
945
+ ts.isJsxSelfClosingElement(nestedWhenTrue)
946
+ ) {
947
+ const componentName = getComponentNameFromJsx(nestedWhenTrue);
948
+ if (componentName) {
949
+ // Fix 32: Add ALL accumulated conditions
950
+ for (const condition of nestedWhenTrueConditions) {
951
+ context.addChildBoundaryGatingCondition(componentName, {
952
+ path: condition.path,
953
+ conditionType: 'truthiness',
954
+ location: 'ternary',
955
+ sourceLocation: condition.sourceLocation,
956
+ controlsJsxRendering: true,
957
+ isNegated: condition.isNegated,
958
+ });
959
+ }
960
+ }
961
+ }
962
+ if (
963
+ ts.isJsxElement(nestedWhenTrue) ||
964
+ ts.isJsxSelfClosingElement(nestedWhenTrue) ||
965
+ ts.isJsxFragment(nestedWhenTrue)
966
+ ) {
967
+ extractConditionalsFromJsx(
968
+ nestedWhenTrue,
969
+ context,
970
+ nestedWhenTrueConditions,
971
+ );
972
+ }
973
+
974
+ // Handle nested whenFalse branch (this could be another chained ternary or JSX)
975
+ if (
976
+ ts.isJsxElement(nestedWhenFalse) ||
977
+ ts.isJsxSelfClosingElement(nestedWhenFalse)
978
+ ) {
979
+ const componentName = getComponentNameFromJsx(nestedWhenFalse);
980
+ if (componentName) {
981
+ // Fix 32: Add ALL accumulated conditions
982
+ for (const condition of nestedWhenFalseConditions) {
983
+ context.addChildBoundaryGatingCondition(componentName, {
984
+ path: condition.path,
985
+ conditionType: 'truthiness',
986
+ location: 'ternary',
987
+ sourceLocation: condition.sourceLocation,
988
+ controlsJsxRendering: true,
989
+ isNegated: condition.isNegated,
990
+ });
991
+ }
992
+ }
993
+ }
994
+ if (
995
+ ts.isJsxElement(nestedWhenFalse) ||
996
+ ts.isJsxSelfClosingElement(nestedWhenFalse) ||
997
+ ts.isJsxFragment(nestedWhenFalse)
998
+ ) {
999
+ extractConditionalsFromJsx(
1000
+ nestedWhenFalse,
1001
+ context,
1002
+ nestedWhenFalseConditions,
1003
+ );
1004
+ }
1005
+ // If nestedWhenFalse is yet another ConditionalExpression, the recursion
1006
+ // will handle it on the next iteration when this function processes it
1007
+ else if (ts.isConditionalExpression(nestedWhenFalse)) {
1008
+ // Recursively handle deeper nesting by wrapping in a synthetic process
1009
+ // We create a fake JsxExpression context to reuse the same logic
1010
+ const syntheticChild = {
1011
+ kind: ts.SyntaxKind.JsxExpression,
1012
+ expression: nestedWhenFalse,
1013
+ } as unknown as ts.JsxExpression;
1014
+ // Process via the main JSX expression handler by recursing
1015
+ // For now, just extract conditionals directly
1016
+ extractConditionalUsage(
1017
+ nestedWhenFalse.condition,
1018
+ context,
1019
+ 'ternary',
1020
+ { controlsJsxRendering: true },
1021
+ );
1022
+ }
1023
+ }
1024
+ }
1025
+ }
1026
+ // Recursively process nested JSX elements - Fix 32: pass parent conditions
1027
+ else if (ts.isJsxElement(child)) {
1028
+ // Check if this is a user-defined component (vs intrinsic element like div)
1029
+ const componentName = getComponentNameFromJsx(child);
1030
+ if (componentName) {
1031
+ if (parentConditions.length > 0) {
1032
+ // If there are parent conditions, record them as gating conditions
1033
+ console.log(
1034
+ `[ChildBoundary] ${componentName}: Conditionally rendered with ${parentConditions.length} gating conditions`,
1035
+ );
1036
+ for (const condition of parentConditions) {
1037
+ console.log(
1038
+ `[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`,
1039
+ );
1040
+ context.addChildBoundaryGatingCondition(componentName, {
1041
+ path: condition.path,
1042
+ conditionType: 'truthiness',
1043
+ location: 'ternary',
1044
+ sourceLocation: condition.sourceLocation,
1045
+ controlsJsxRendering: true,
1046
+ isNegated: condition.isNegated,
1047
+ });
1048
+ }
1049
+ } else {
1050
+ // No parent conditions - check if it has data props for unconditional tracking
1051
+ console.log(
1052
+ `[ChildBoundary] ${componentName}: Checking for unconditional rendering with data props...`,
1053
+ );
1054
+ const { hasDataProps, dataProps } = hasDataPropsFromParent(
1055
+ child,
1056
+ componentName,
1057
+ );
1058
+ if (hasDataProps) {
1059
+ // Fix: Track unconditionally-rendered children that receive data props
1060
+ // These need to be tracked for flow merging even without gating conditions
1061
+ // Example: <WorkoutsView workouts={workouts} /> - parent controls workouts data
1062
+ console.log(
1063
+ `[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered with data props: [${dataProps.join(', ')}]`,
1064
+ );
1065
+ context.addChildBoundaryGatingCondition(componentName, {
1066
+ path: '__unconditional__',
1067
+ conditionType: 'truthiness',
1068
+ location: 'unconditional',
1069
+ controlsJsxRendering: true,
1070
+ isNegated: false,
1071
+ });
1072
+ }
1073
+ }
1074
+ }
1075
+ extractConditionalsFromJsx(child, context, parentConditions);
1076
+ }
1077
+ // Handle self-closing JSX elements (e.g., <ScenarioViewer />)
1078
+ else if (ts.isJsxSelfClosingElement(child)) {
1079
+ // Check if this is a user-defined component (vs intrinsic element like div)
1080
+ const componentName = getComponentNameFromJsx(child);
1081
+ if (componentName) {
1082
+ if (parentConditions.length > 0) {
1083
+ // If there are parent conditions, record them as gating conditions
1084
+ console.log(
1085
+ `[ChildBoundary] ${componentName}: Conditionally rendered (self-closing) with ${parentConditions.length} gating conditions`,
1086
+ );
1087
+ for (const condition of parentConditions) {
1088
+ console.log(
1089
+ `[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`,
1090
+ );
1091
+ context.addChildBoundaryGatingCondition(componentName, {
1092
+ path: condition.path,
1093
+ conditionType: 'truthiness',
1094
+ location: 'ternary',
1095
+ sourceLocation: condition.sourceLocation,
1096
+ controlsJsxRendering: true,
1097
+ isNegated: condition.isNegated,
1098
+ });
1099
+ }
1100
+ } else {
1101
+ // No parent conditions - check if it has data props for unconditional tracking
1102
+ console.log(
1103
+ `[ChildBoundary] ${componentName}: Checking for unconditional rendering (self-closing) with data props...`,
1104
+ );
1105
+ const { hasDataProps, dataProps } = hasDataPropsFromParent(
1106
+ child,
1107
+ componentName,
1108
+ );
1109
+ if (hasDataProps) {
1110
+ // Fix: Track unconditionally-rendered children that receive data props
1111
+ console.log(
1112
+ `[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered (self-closing) with data props: [${dataProps.join(', ')}]`,
1113
+ );
1114
+ context.addChildBoundaryGatingCondition(componentName, {
1115
+ path: '__unconditional__',
1116
+ conditionType: 'truthiness',
1117
+ location: 'unconditional',
1118
+ controlsJsxRendering: true,
1119
+ isNegated: false,
1120
+ });
1121
+ }
1122
+ }
1123
+ }
1124
+ // Self-closing elements have no children, so no recursion needed
1125
+ }
1126
+ // Recursively process nested JSX fragments - Fix 32: pass parent conditions
1127
+ else if (ts.isJsxFragment(child)) {
1128
+ extractConditionalsFromJsx(child, context, parentConditions);
1129
+ }
1130
+ }
1131
+ }
1132
+
1133
+ /**
1134
+ * Options for extractConditionalUsage
1135
+ */
1136
+ interface ExtractConditionalOptions {
1137
+ /**
1138
+ * Whether this conditional controls JSX rendering.
1139
+ * Set to true when the conditional appears in a JSX expression like {cond && <Component />}
1140
+ */
1141
+ controlsJsxRendering?: boolean;
1142
+ }
1143
+
1144
+ /**
1145
+ * Extracts conditional usages from a condition expression for key attribute detection.
1146
+ * This function identifies which attributes are used in conditionals and how they're used.
1147
+ * It also tracks compound conditionals (&&-chains) where all conditions must be true together.
1148
+ *
1149
+ * @param condition The condition expression to analyze
1150
+ * @param context The analysis context
1151
+ * @param location Where this condition appears (if, ternary, logical-and, switch)
1152
+ * @param options Additional options including controlsJsxRendering flag
1153
+ */
1154
+ export function extractConditionalUsage(
1155
+ condition: ts.Expression,
1156
+ context: AnalysisContext,
1157
+ location: ConditionalUsage['location'],
1158
+ options: ExtractConditionalOptions = {},
1159
+ ): void {
1160
+ const { controlsJsxRendering } = options;
1161
+ // Internal recursive function with chain tracking
1162
+ function extractWithChainTracking(
1163
+ expr: ts.Expression,
1164
+ chainInfo: ChainInfo | null,
1165
+ isNegated: boolean,
1166
+ ): void {
1167
+ const unwrapped = unwrapExpression(expr);
1168
+
1169
+ // Handle binary expressions with && (logical AND chains)
1170
+ // Example: `a && b && <Component />` - both a and b are conditional checks
1171
+ if (
1172
+ ts.isBinaryExpression(unwrapped) &&
1173
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
1174
+ ) {
1175
+ // Track if we're creating the chain at this level (root of the chain)
1176
+ const isChainRoot = !chainInfo;
1177
+
1178
+ // If no chainInfo, this is the root of a new chain
1179
+ if (isChainRoot) {
1180
+ const chainLength = countConditionsInAndChain(unwrapped);
1181
+ // Only create chain tracking for chains with 2+ conditions
1182
+ if (chainLength >= 2) {
1183
+ const chainId = `chain_${crypto.randomUUID().slice(0, 8)}`;
1184
+ const chainExpression = unwrapped.getText(context.sourceFile);
1185
+ const compound: CompoundConditional = {
1186
+ chainId,
1187
+ expression:
1188
+ chainExpression.length > 200
1189
+ ? chainExpression.slice(0, 200) + '...'
1190
+ : chainExpression,
1191
+ conditions: [],
1192
+ location,
1193
+ sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
1194
+ controlsJsxRendering,
1195
+ };
1196
+ chainInfo = {
1197
+ chainId,
1198
+ chainLength,
1199
+ chainExpression: compound.expression,
1200
+ currentPosition: 0,
1201
+ compound,
1202
+ };
1203
+ }
1204
+ }
1205
+
1206
+ // Recursively process left side
1207
+ extractWithChainTracking(unwrapped.left, chainInfo, false);
1208
+
1209
+ // Process right side if it's not JSX (JSX is the consequence, not the condition)
1210
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
1211
+ const isJsxConsequence =
1212
+ ts.isJsxElement(rightUnwrapped) ||
1213
+ ts.isJsxSelfClosingElement(rightUnwrapped) ||
1214
+ ts.isJsxFragment(rightUnwrapped);
1215
+
1216
+ if (!isJsxConsequence) {
1217
+ extractWithChainTracking(unwrapped.right, chainInfo, false);
1218
+ }
1219
+
1220
+ // If this is the root of the chain, register the compound conditional
1221
+ if (isChainRoot && chainInfo) {
1222
+ context.addCompoundConditional(chainInfo.compound);
1223
+ }
1224
+ return;
1225
+ }
1226
+
1227
+ // Handle binary expressions with || (logical OR)
1228
+ // When OR is inside an && chain, we need to continue chain tracking
1229
+ // and mark conditions as OR alternatives
1230
+ if (
1231
+ ts.isBinaryExpression(unwrapped) &&
1232
+ unwrapped.operatorToken.kind === ts.SyntaxKind.BarBarToken
1233
+ ) {
1234
+ if (chainInfo) {
1235
+ // We're inside an && chain - continue tracking but mark as OR alternatives
1236
+ // Generate an orGroupId so conditions from both sides can be grouped
1237
+ const orGroupId =
1238
+ chainInfo.currentOrGroupId ?? `or_${crypto.randomUUID().slice(0, 8)}`;
1239
+
1240
+ // Process left side with OR group tracking
1241
+ const leftChainInfo = {
1242
+ ...chainInfo,
1243
+ currentOrGroupId: orGroupId,
1244
+ };
1245
+ extractWithChainTracking(unwrapped.left, leftChainInfo, false);
1246
+
1247
+ // Process right side with same OR group
1248
+ // Note: we use leftChainInfo's currentPosition which may have been updated
1249
+ const rightChainInfo = {
1250
+ ...leftChainInfo,
1251
+ currentPosition: chainInfo.currentPosition,
1252
+ };
1253
+ extractWithChainTracking(unwrapped.right, rightChainInfo, false);
1254
+ } else {
1255
+ // Not inside a chain - OR breaks into independent conditional checks
1256
+ extractWithChainTracking(unwrapped.left, null, false);
1257
+ extractWithChainTracking(unwrapped.right, null, false);
1258
+ }
1259
+ return;
1260
+ }
1261
+
1262
+ // Handle comparison operators (===, !==, <, >, <=, >=)
1263
+ // Example: `if (status === 'active')` - status is compared against 'active'
1264
+ if (
1265
+ ts.isBinaryExpression(unwrapped) &&
1266
+ isComparisonOperator(unwrapped.operatorToken.kind)
1267
+ ) {
1268
+ // Try to extract the variable and the compared value
1269
+ const leftPath = StructuredPath.fromNode(
1270
+ unwrapped.left,
1271
+ context.sourceFile,
1272
+ );
1273
+ const rightPath = StructuredPath.fromNode(
1274
+ unwrapped.right,
1275
+ context.sourceFile,
1276
+ );
1277
+
1278
+ // Determine the compared value for computing requiredValue
1279
+ const getRequiredValue = (
1280
+ literalValue: string | undefined,
1281
+ isNegatedComparison: boolean,
1282
+ ): string | boolean | undefined => {
1283
+ if (literalValue === undefined) return undefined;
1284
+ // For !== comparisons, the condition is true when NOT equal to the value
1285
+ // For === comparisons, the condition is true when equal to the value
1286
+ const isNotEqual =
1287
+ unwrapped.operatorToken.kind ===
1288
+ ts.SyntaxKind.ExclamationEqualsEqualsToken ||
1289
+ unwrapped.operatorToken.kind === ts.SyntaxKind.ExclamationEqualsToken;
1290
+ if (isNotEqual) {
1291
+ // !== 'value' means requiredValue is NOT 'value', but we express this as "not 'value'"
1292
+ return `not ${literalValue}`;
1293
+ }
1294
+ return literalValue;
1295
+ };
1296
+
1297
+ // Helper to add a condition
1298
+ const addCondition = (
1299
+ path: string,
1300
+ conditionType: 'comparison' | 'truthiness',
1301
+ comparedValues?: string[],
1302
+ requiredValue?: string | boolean,
1303
+ sourceExpr?: ts.Expression,
1304
+ ) => {
1305
+ const usage: ConditionalUsage = {
1306
+ path,
1307
+ conditionType,
1308
+ comparedValues,
1309
+ location,
1310
+ sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
1311
+ isNegated,
1312
+ controlsJsxRendering,
1313
+ };
1314
+
1315
+ // Check for inline array-derived patterns (.length) on the source expression
1316
+ if (sourceExpr) {
1317
+ const arrayDerived = detectArrayDerivedPattern(sourceExpr);
1318
+ if (arrayDerived) {
1319
+ usage.derivedFrom = {
1320
+ operation: arrayDerived.operation,
1321
+ sourcePath: arrayDerived.sourcePath,
1322
+ };
1323
+ }
1324
+ }
1325
+
1326
+ // Add chain info if part of a compound conditional
1327
+ if (chainInfo) {
1328
+ usage.chainId = chainInfo.chainId;
1329
+ usage.chainPosition = chainInfo.currentPosition;
1330
+ usage.chainLength = chainInfo.chainLength;
1331
+ usage.chainExpression = chainInfo.chainExpression;
1332
+ chainInfo.currentPosition++;
1333
+
1334
+ // Add to compound conditional conditions
1335
+ chainInfo.compound.conditions.push({
1336
+ path,
1337
+ conditionType,
1338
+ comparedValues,
1339
+ isNegated,
1340
+ requiredValue,
1341
+ ...(chainInfo.currentOrGroupId && {
1342
+ orGroupId: chainInfo.currentOrGroupId,
1343
+ }),
1344
+ });
1345
+ }
1346
+
1347
+ context.addConditionalUsage(usage);
1348
+ };
1349
+
1350
+ // Check if left is a variable and right is a literal
1351
+ if (leftPath && isLiteralExpression(unwrapped.right)) {
1352
+ const literalValue = getLiteralValue(unwrapped.right, context);
1353
+ addCondition(
1354
+ leftPath.toLeftHandSideString(),
1355
+ 'comparison',
1356
+ literalValue !== undefined ? [literalValue] : undefined,
1357
+ getRequiredValue(literalValue, isNegated),
1358
+ unwrapped.left, // Pass source expression for array derivation detection
1359
+ );
1360
+ return;
1361
+ }
1362
+
1363
+ // Check if right is a variable and left is a literal
1364
+ if (rightPath && isLiteralExpression(unwrapped.left)) {
1365
+ const literalValue = getLiteralValue(unwrapped.left, context);
1366
+ addCondition(
1367
+ rightPath.toLeftHandSideString(),
1368
+ 'comparison',
1369
+ literalValue !== undefined ? [literalValue] : undefined,
1370
+ getRequiredValue(literalValue, isNegated),
1371
+ unwrapped.right, // Pass source expression for array derivation detection
1372
+ );
1373
+ return;
1374
+ }
1375
+
1376
+ // Both sides are variables - record both as comparisons without specific values
1377
+ if (leftPath) {
1378
+ addCondition(
1379
+ leftPath.toLeftHandSideString(),
1380
+ 'comparison',
1381
+ undefined,
1382
+ undefined,
1383
+ unwrapped.left,
1384
+ );
1385
+ }
1386
+ if (rightPath) {
1387
+ addCondition(
1388
+ rightPath.toLeftHandSideString(),
1389
+ 'comparison',
1390
+ undefined,
1391
+ undefined,
1392
+ unwrapped.right,
1393
+ );
1394
+ }
1395
+ return;
1396
+ }
1397
+
1398
+ // Handle prefix unary NOT expression: !variable
1399
+ // Example: `if (!isVisible)` - isVisible is a truthiness check (negated)
1400
+ if (
1401
+ ts.isPrefixUnaryExpression(unwrapped) &&
1402
+ unwrapped.operator === ts.SyntaxKind.ExclamationToken
1403
+ ) {
1404
+ extractWithChainTracking(unwrapped.operand, chainInfo, !isNegated);
1405
+ return;
1406
+ }
1407
+
1408
+ // Handle simple identifiers or property accesses (truthiness checks)
1409
+ // Example: `if (x)` or `x && <JSX />` - x is checked for truthiness
1410
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
1411
+ if (path && !path.isLiteral()) {
1412
+ const pathStr = path.toLeftHandSideString();
1413
+ const usage: ConditionalUsage = {
1414
+ path: pathStr,
1415
+ conditionType: 'truthiness',
1416
+ location,
1417
+ sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
1418
+ isNegated,
1419
+ controlsJsxRendering,
1420
+ };
1421
+
1422
+ // Check for inline array-derived patterns (.some(), .every(), .includes(), .length)
1423
+ // This populates derivedFrom so downstream code can resolve to the base array path
1424
+ const arrayDerived = detectArrayDerivedPattern(unwrapped);
1425
+ if (arrayDerived) {
1426
+ usage.derivedFrom = {
1427
+ operation: arrayDerived.operation,
1428
+ sourcePath: arrayDerived.sourcePath,
1429
+ };
1430
+ }
1431
+
1432
+ // Add chain info if part of a compound conditional
1433
+ if (chainInfo) {
1434
+ usage.chainId = chainInfo.chainId;
1435
+ usage.chainPosition = chainInfo.currentPosition;
1436
+ usage.chainLength = chainInfo.chainLength;
1437
+ usage.chainExpression = chainInfo.chainExpression;
1438
+ chainInfo.currentPosition++;
1439
+
1440
+ // Add to compound conditional conditions
1441
+ // For truthiness, requiredValue is true if not negated, false if negated
1442
+ chainInfo.compound.conditions.push({
1443
+ path: pathStr,
1444
+ conditionType: 'truthiness',
1445
+ isNegated,
1446
+ requiredValue: !isNegated,
1447
+ ...(chainInfo.currentOrGroupId && {
1448
+ orGroupId: chainInfo.currentOrGroupId,
1449
+ }),
1450
+ });
1451
+ }
1452
+
1453
+ context.addConditionalUsage(usage);
1454
+ }
1455
+ }
1456
+
1457
+ // Start extraction with no chain info
1458
+ extractWithChainTracking(condition, null, false);
1459
+ }
1460
+
1461
+ /**
1462
+ * Helper to check if an expression is a literal value
1463
+ */
1464
+ function isLiteralExpression(expr: ts.Expression): boolean {
1465
+ const unwrapped = unwrapExpression(expr);
1466
+ return (
1467
+ ts.isStringLiteral(unwrapped) ||
1468
+ ts.isNumericLiteral(unwrapped) ||
1469
+ ts.isNoSubstitutionTemplateLiteral(unwrapped) ||
1470
+ unwrapped.kind === ts.SyntaxKind.TrueKeyword ||
1471
+ unwrapped.kind === ts.SyntaxKind.FalseKeyword ||
1472
+ unwrapped.kind === ts.SyntaxKind.NullKeyword ||
1473
+ unwrapped.kind === ts.SyntaxKind.UndefinedKeyword ||
1474
+ unwrapped.kind === ts.SyntaxKind.ThisKeyword
1475
+ );
1476
+ }
1477
+
1478
+ /**
1479
+ * Helper to get the string representation of a literal value
1480
+ */
1481
+ function getLiteralValue(
1482
+ expr: ts.Expression,
1483
+ context: AnalysisContext,
1484
+ ): string | undefined {
1485
+ const unwrapped = unwrapExpression(expr);
1486
+
1487
+ if (
1488
+ ts.isStringLiteral(unwrapped) ||
1489
+ ts.isNoSubstitutionTemplateLiteral(unwrapped)
1490
+ ) {
1491
+ return unwrapped.text;
1492
+ }
1493
+ if (ts.isNumericLiteral(unwrapped)) {
1494
+ return unwrapped.text;
1495
+ }
1496
+ if (unwrapped.kind === ts.SyntaxKind.TrueKeyword) {
1497
+ return 'true';
1498
+ }
1499
+ if (unwrapped.kind === ts.SyntaxKind.FalseKeyword) {
1500
+ return 'false';
1501
+ }
1502
+ if (unwrapped.kind === ts.SyntaxKind.NullKeyword) {
1503
+ return 'null';
1504
+ }
1505
+ if (unwrapped.kind === ts.SyntaxKind.UndefinedKeyword) {
1506
+ return 'undefined';
1507
+ }
1508
+ if (unwrapped.kind === ts.SyntaxKind.ThisKeyword) {
1509
+ return 'this';
1510
+ }
1511
+
1512
+ return undefined;
1513
+ }
1514
+
1515
+ /**
1516
+ * Processes an expression node recursively, establishing equivalences and types
1517
+ * in the analysis context as side effects.
1518
+ *
1519
+ * This is the core function for centralized expression analysis, which handles all
1520
+ * expression types and registers appropriate relationships and types in the context.
1521
+ *
1522
+ * @param node The expression node to process.
1523
+ * @param context The analysis context.
1524
+ * @param targetPath The base path to which this expression's value should be related.
1525
+ * For example, for a variable declaration `const x = y`, the targetPath would be
1526
+ * StructuredPath.fromBase('x'). For a return statement `return expr`, the targetPath
1527
+ * would be StructuredPath.fromBase('returnValue').
1528
+ *
1529
+ * When targetPath is provided, this function will establish all appropriate equivalences
1530
+ * and register types for targetPath. When omitted (typically for sub-expressions in
1531
+ * recursive calls), the function will operate without establishing external relationships.
1532
+ *
1533
+ * @returns true if the expression was processed successfully, false otherwise.
1534
+ */
1535
+ export function processExpression({
1536
+ node,
1537
+ context,
1538
+ targetPath,
1539
+ typeHint,
1540
+ }: {
1541
+ node: ts.Expression;
1542
+ context: AnalysisContext;
1543
+ targetPath?: StructuredPath; // Base path for relationship establishment
1544
+ typeHint?: string; // Optional type hint for the node
1545
+ }): boolean {
1546
+ let inferredNodeType = context.inferTypeFromNode(node);
1547
+ if (inferredNodeType === 'unknown' && typeHint) {
1548
+ inferredNodeType = typeHint;
1549
+ }
1550
+ const unwrappedNode = unwrapExpression(node);
1551
+
1552
+ // IMPORTANT: Mark nullable variables BEFORE checking child boundaries
1553
+ // JSX expressions like {showLogsForEntity && projectSlug && (<Component />)} are child boundaries,
1554
+ // but we still need to mark the variables as potentially undefined
1555
+ if (
1556
+ ts.isBinaryExpression(unwrappedNode) &&
1557
+ unwrappedNode.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
1558
+ ) {
1559
+ markConditionVariablesAsNullable(unwrappedNode, context);
1560
+ // Extract conditional usages for key attribute detection
1561
+ // Only call from the OUTERMOST && expression to avoid duplicates
1562
+ // Check if parent is also a && (meaning we're nested)
1563
+ const parent = unwrappedNode.parent;
1564
+ const parentIsAndChain =
1565
+ parent &&
1566
+ ts.isBinaryExpression(parent) &&
1567
+ parent.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken;
1568
+ if (!parentIsAndChain) {
1569
+ extractConditionalUsage(unwrappedNode, context, 'logical-and');
1570
+ }
1571
+ }
1572
+
1573
+ // CRITICAL: Extract conditionals from JSX BEFORE checking child boundaries
1574
+ // JSX elements are NOT scopes - their expressions use variables from the parent scope.
1575
+ // Even if the JSX element is within a child boundary (e.g., because it contains callbacks),
1576
+ // we must still extract conditionals from JSX expression children like {x && <div>...</div>}
1577
+ if (
1578
+ ts.isJsxElement(unwrappedNode) ||
1579
+ ts.isJsxSelfClosingElement(unwrappedNode) ||
1580
+ ts.isJsxFragment(unwrappedNode)
1581
+ ) {
1582
+ extractConditionalsFromJsx(unwrappedNode, context);
1583
+ }
1584
+
1585
+ // If the node falls within an excluded child scope, stop processing it.
1586
+ if (context.isChildBoundary(node)) {
1587
+ return true;
1588
+ }
1589
+
1590
+ // Create a path for this node
1591
+ let nodePath: StructuredPath | null = null;
1592
+
1593
+ // if (unwrappedNode.kind === ts.SyntaxKind.Identifier) {
1594
+ // console.warn(
1595
+ // `Got IDENTIFIER and ts.isIdentifier = ${ts.isIdentifier(unwrappedNode)}`,
1596
+ // unwrappedNode.getText(context.sourceFile),
1597
+ // );
1598
+ // }
1599
+
1600
+ // Handle simple cases directly
1601
+ if (ts.isIdentifier(unwrappedNode)) {
1602
+ nodePath = StructuredPath.fromBase(unwrappedNode.text);
1603
+
1604
+ // If targetPath is provided, establish equivalence and register type
1605
+ if (targetPath) {
1606
+ context.addEquivalence(targetPath, nodePath);
1607
+ context.addType(targetPath, inferredNodeType);
1608
+
1609
+ // Propagate sub-properties from the identifier to the targetPath
1610
+ // This handles cases like: dataItem={{ structure: completeDataStructure }}
1611
+ // where completeDataStructure was defined as { 'Function Arguments': dataStructure.arguments }
1612
+ // We need to propagate completeDataStructure['Function Arguments'] to
1613
+ // ChildComponent().signature[0].dataItem.structure['Function Arguments']
1614
+ const nodePathStr = nodePath.toString();
1615
+ const equivalentVariables = context.getEquivalentVariables();
1616
+ const structure = context.getStructure();
1617
+
1618
+ // Propagate existing equivalencies for sub-properties
1619
+ for (const [key, rawValue] of Object.entries(equivalentVariables)) {
1620
+ // Check if this equivalency is for a sub-property of the identifier
1621
+ // e.g., completeDataStructure['Function Arguments'] or completeDataStructure.foo
1622
+ if (
1623
+ key.startsWith(nodePathStr + '.') ||
1624
+ key.startsWith(nodePathStr + '[')
1625
+ ) {
1626
+ const subPath = key.substring(nodePathStr.length);
1627
+ const newTargetPath = StructuredPath.fromBase(
1628
+ targetPath.toString() + subPath,
1629
+ );
1630
+ // Handle both string and string[] values
1631
+ const values = Array.isArray(rawValue) ? rawValue : [rawValue];
1632
+ for (const value of values) {
1633
+ if (typeof value === 'string') {
1634
+ const valuePath = StructuredPath.fromBase(value);
1635
+ context.addEquivalence(newTargetPath, valuePath);
1636
+ }
1637
+ }
1638
+ }
1639
+ }
1640
+
1641
+ // Propagate existing structure entries for sub-properties
1642
+ for (const [key, value] of Object.entries(structure)) {
1643
+ if (
1644
+ key.startsWith(nodePathStr + '.') ||
1645
+ key.startsWith(nodePathStr + '[')
1646
+ ) {
1647
+ const subPath = key.substring(nodePathStr.length);
1648
+ const newTargetPath = StructuredPath.fromBase(
1649
+ targetPath.toString() + subPath,
1650
+ );
1651
+ context.addType(newTargetPath, value);
1652
+ }
1653
+ }
1654
+ }
1655
+ context.addType(nodePath, inferredNodeType);
1656
+ return true;
1657
+ }
1658
+
1659
+ if (
1660
+ ts.isStringLiteral(unwrappedNode) ||
1661
+ ts.isNoSubstitutionTemplateLiteral(unwrappedNode)
1662
+ ) {
1663
+ nodePath = StructuredPath.createLiteralPath(
1664
+ unwrappedNode.getText(context.sourceFile),
1665
+ 'string',
1666
+ );
1667
+
1668
+ if (targetPath) {
1669
+ context.addEquivalence(targetPath, nodePath);
1670
+ context.addType(targetPath, 'string');
1671
+ }
1672
+
1673
+ return true;
1674
+ }
1675
+
1676
+ if (ts.isNumericLiteral(unwrappedNode)) {
1677
+ nodePath = StructuredPath.createLiteralPath(unwrappedNode.text, 'number');
1678
+
1679
+ if (targetPath) {
1680
+ context.addEquivalence(targetPath, nodePath);
1681
+ context.addType(targetPath, 'number');
1682
+ }
1683
+
1684
+ return true;
1685
+ }
1686
+
1687
+ if (
1688
+ unwrappedNode.kind === ts.SyntaxKind.TrueKeyword ||
1689
+ unwrappedNode.kind === ts.SyntaxKind.FalseKeyword
1690
+ ) {
1691
+ const value =
1692
+ unwrappedNode.kind === ts.SyntaxKind.TrueKeyword ? 'true' : 'false';
1693
+ nodePath = StructuredPath.createLiteralPath(value, 'boolean');
1694
+
1695
+ if (targetPath) {
1696
+ context.addEquivalence(targetPath, nodePath);
1697
+ context.addType(targetPath, 'boolean');
1698
+ }
1699
+
1700
+ return true;
1701
+ }
1702
+
1703
+ if (unwrappedNode.kind === ts.SyntaxKind.NullKeyword) {
1704
+ nodePath = StructuredPath.createLiteralPath('null', 'null');
1705
+
1706
+ if (targetPath) {
1707
+ context.addEquivalence(targetPath, nodePath);
1708
+ context.addType(targetPath, 'null');
1709
+ }
1710
+
1711
+ return true;
1712
+ }
1713
+
1714
+ if (unwrappedNode.kind === ts.SyntaxKind.UndefinedKeyword) {
1715
+ nodePath = StructuredPath.createLiteralPath('undefined', 'undefined');
1716
+
1717
+ if (targetPath) {
1718
+ context.addEquivalence(targetPath, nodePath);
1719
+ context.addType(targetPath, 'undefined');
1720
+ }
1721
+
1722
+ return true;
1723
+ }
1724
+
1725
+ if (
1726
+ ts.isThisTypeNode(unwrappedNode) ||
1727
+ unwrappedNode.kind === ts.SyntaxKind.ThisKeyword
1728
+ ) {
1729
+ nodePath = StructuredPath.createLiteralPath('this', 'object');
1730
+
1731
+ if (targetPath) {
1732
+ context.addEquivalence(targetPath, nodePath);
1733
+ context.addType(targetPath, 'object');
1734
+ }
1735
+
1736
+ return true;
1737
+ }
1738
+
1739
+ // Handle Property Access: obj.prop
1740
+ if (ts.isPropertyAccessExpression(unwrappedNode)) {
1741
+ // Process the object part recursively (without targetPath)
1742
+ const objectProcessed = processExpression({
1743
+ node: unwrappedNode.expression,
1744
+ context,
1745
+ });
1746
+
1747
+ if (!objectProcessed) {
1748
+ // If we couldn't process the object part, we can't process the property access
1749
+ // console.warn(
1750
+ // `processExpression: Unsupported object part: ${unwrappedNode.expression.getText(context.sourceFile)}`,
1751
+ // ts.isIdentifier(unwrappedNode.expression),
1752
+ // );
1753
+ context.markUnsupported(
1754
+ unwrappedNode.expression,
1755
+ `processExpression: Unsupported base expression for property access: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
1756
+ false,
1757
+ );
1758
+ return false;
1759
+ }
1760
+
1761
+ // Get a proper path for the object
1762
+ const objectPath = StructuredPath.fromNode(
1763
+ unwrappedNode.expression,
1764
+ context.sourceFile,
1765
+ );
1766
+
1767
+ if (!objectPath) {
1768
+ context.markUnsupported(
1769
+ unwrappedNode.expression,
1770
+ `processExpression: Couldn't get path for property access base: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
1771
+ false,
1772
+ );
1773
+ return false;
1774
+ }
1775
+
1776
+ // Create the property access path
1777
+ const propertyPath = objectPath.withProperty(unwrappedNode.name.text);
1778
+
1779
+ // Check if this is an environment variable access
1780
+ const fullText = unwrappedNode.getText(context.sourceFile);
1781
+ if (
1782
+ fullText.includes('.env.') || // process.env.X, window.env.X
1783
+ isEnvStoreAccess(fullText) // env.X where env is likely an env config object
1784
+ ) {
1785
+ context.addEnvironmentVariable(fullText);
1786
+ }
1787
+
1788
+ // Infer and register type for the property
1789
+ context.addType(propertyPath, inferredNodeType);
1790
+
1791
+ // If targetPath is provided, establish equivalence and propagate type
1792
+ if (targetPath) {
1793
+ context.addEquivalence(targetPath, propertyPath);
1794
+ context.addType(targetPath, inferredNodeType);
1795
+ }
1796
+
1797
+ return true;
1798
+ }
1799
+
1800
+ // Handle Binary Expressions: a + b, x === y, etc.
1801
+ if (ts.isBinaryExpression(unwrappedNode)) {
1802
+ // Check if it's an assignment first, as BinaryExpression includes assignments
1803
+ if (isAssignmentOperator(unwrappedNode.operatorToken.kind)) {
1804
+ // Check for destructuring assignment first
1805
+ if (
1806
+ (ts.isObjectBindingPattern(unwrappedNode.left) ||
1807
+ ts.isArrayBindingPattern(unwrappedNode.left)) &&
1808
+ unwrappedNode.operatorToken.kind === ts.SyntaxKind.EqualsToken
1809
+ ) {
1810
+ // For destructuring assignment, we first need to process the right side
1811
+ const rightSideProcessed = processExpression({
1812
+ node: unwrappedNode.right,
1813
+ context,
1814
+ });
1815
+
1816
+ if (!rightSideProcessed) {
1817
+ context.markUnsupported(
1818
+ unwrappedNode.right,
1819
+ `processExpression: Unsupported right side of destructuring assignment: ${ts.SyntaxKind[unwrappedNode.right.kind]}`,
1820
+ false,
1821
+ );
1822
+ return false;
1823
+ }
1824
+
1825
+ // Get the right side path
1826
+ const rightSidePath = StructuredPath.fromNode(
1827
+ unwrappedNode.right,
1828
+ context.sourceFile,
1829
+ );
1830
+
1831
+ if (!rightSidePath) {
1832
+ context.markUnsupported(
1833
+ unwrappedNode.right,
1834
+ `processExpression: Couldn't get path for right side of destructuring assignment`,
1835
+ false,
1836
+ );
1837
+ return false;
1838
+ }
1839
+
1840
+ // Process the binding pattern with the right side as source
1841
+ const success = processBindingPattern(
1842
+ unwrappedNode.left as ts.BindingPattern,
1843
+ rightSidePath,
1844
+ context,
1845
+ );
1846
+
1847
+ // If targetPath was provided, establish equivalence to the right side
1848
+ // This is useful when the destructuring assignment is itself part of a larger expression
1849
+ if (targetPath) {
1850
+ context.addEquivalence(targetPath, rightSidePath);
1851
+ context.inferAndAddType(targetPath, unwrappedNode.right);
1852
+ }
1853
+
1854
+ return success;
1855
+ }
1856
+ // Regular non-destructuring assignment
1857
+ else {
1858
+ // Process the left side to ensure it's analyzed and to get its path
1859
+ const leftSideProcessed = processExpression({
1860
+ node: unwrappedNode.left,
1861
+ context,
1862
+ });
1863
+
1864
+ if (!leftSideProcessed) {
1865
+ context.markUnsupported(
1866
+ unwrappedNode.left,
1867
+ `processExpression: Unsupported left side of assignment: ${ts.SyntaxKind[unwrappedNode.left.kind]}`,
1868
+ false,
1869
+ );
1870
+ return false; // Cannot process assignment without successful LHS processing
1871
+ }
1872
+
1873
+ // Get the structured path for the left side
1874
+ const leftSidePath = StructuredPath.fromNode(
1875
+ unwrappedNode.left,
1876
+ context.sourceFile,
1877
+ );
1878
+
1879
+ if (!leftSidePath) {
1880
+ context.markUnsupported(
1881
+ unwrappedNode.left,
1882
+ `processExpression: Couldn't get path for left side of assignment: ${ts.SyntaxKind[unwrappedNode.left.kind]}`,
1883
+ false,
1884
+ );
1885
+ return false;
1886
+ }
1887
+
1888
+ // Handle simple assignment (=)
1889
+ if (unwrappedNode.operatorToken.kind === ts.SyntaxKind.EqualsToken) {
1890
+ // Process the right side
1891
+ const rightSideProcessed = processExpression({
1892
+ node: unwrappedNode.right,
1893
+ context,
1894
+ targetPath: leftSidePath, // Pass leftSidePath as targetPath
1895
+ });
1896
+
1897
+ if (!rightSideProcessed) {
1898
+ context.addType(leftSidePath, 'unknown');
1899
+ context.markUnsupported(
1900
+ unwrappedNode.right,
1901
+ `processExpression: Unsupported right side of assignment: ${ts.SyntaxKind[unwrappedNode.right.kind]}`,
1902
+ false,
1903
+ );
1904
+ return false;
1905
+ }
1906
+ if (ts.isObjectLiteralExpression(unwrappedNode.right)) {
1907
+ // Just add object type - property equivalences were set up during processing
1908
+ context.addType(leftSidePath, 'object');
1909
+ }
1910
+ // If targetPath was provided to us, establish equivalence
1911
+ if (targetPath) {
1912
+ context.addEquivalence(targetPath, leftSidePath);
1913
+ context.inferAndAddType(targetPath, unwrappedNode.right);
1914
+ }
1915
+
1916
+ return true;
1917
+ }
1918
+ // Handle compound assignments (+=, -=, etc.)
1919
+ else {
1920
+ // For compound assignments, we process the right side without targetPath
1921
+ const rightSideProcessed = processExpression({
1922
+ node: unwrappedNode.right,
1923
+ context,
1924
+ });
1925
+ if (!rightSideProcessed) {
1926
+ context.markUnsupported(
1927
+ unwrappedNode.right,
1928
+ `processExpression: Unsupported right side of compound assignment: ${ts.SyntaxKind[unwrappedNode.right.kind]}`,
1929
+ false,
1930
+ );
1931
+ return false;
1932
+ }
1933
+
1934
+ // Determine the result type based on operation
1935
+ const operatorKind = unwrappedNode.operatorToken.kind;
1936
+
1937
+ let leftType = context.getTypeInfo(leftSidePath);
1938
+ if (leftType === 'unknown') {
1939
+ leftType = context.inferTypeFromNode(unwrappedNode.left);
1940
+ }
1941
+
1942
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
1943
+
1944
+ let resultType = 'unknown';
1945
+ if (operatorKind === ts.SyntaxKind.PlusEqualsToken) {
1946
+ // plus operator is special - it can be string or number
1947
+ resultType =
1948
+ leftType === 'string' || rightType === 'string'
1949
+ ? 'string'
1950
+ : 'number';
1951
+ } else if (isNumericCompoundOperator(operatorKind)) {
1952
+ resultType = 'number';
1953
+ } else if (isBitwiseCompoundOperator(operatorKind)) {
1954
+ resultType = 'number';
1955
+ } else if (
1956
+ operatorKind === ts.SyntaxKind.AmpersandAmpersandEqualsToken
1957
+ ) {
1958
+ resultType = 'boolean';
1959
+ } else if (
1960
+ operatorKind === ts.SyntaxKind.BarBarEqualsToken ||
1961
+ operatorKind === ts.SyntaxKind.QuestionQuestionEqualsToken
1962
+ ) {
1963
+ resultType = leftOrRightType(leftType, rightType) ?? 'unknown';
1964
+ } else {
1965
+ context.markUnsupported(
1966
+ unwrappedNode,
1967
+ `processExpression: Unsupported compound assignment operator: ${ts.SyntaxKind[operatorKind]}`,
1968
+ false,
1969
+ );
1970
+ }
1971
+
1972
+ // Update the type of the left side
1973
+ context.addType(leftSidePath, resultType);
1974
+ context.addEquivalence(
1975
+ leftSidePath,
1976
+ StructuredPath.fromNode(unwrappedNode.right, context.sourceFile),
1977
+ );
1978
+
1979
+ // If targetPath was provided, establish equivalence
1980
+ if (targetPath) {
1981
+ context.addEquivalence(targetPath, leftSidePath);
1982
+ context.addType(targetPath, resultType);
1983
+ }
1984
+
1985
+ return true;
1986
+ }
1987
+ }
1988
+ }
1989
+ // Non-assignment binary expressions (logical, arithmetic, comparison, etc.)
1990
+ else {
1991
+ // Process both sides for their side effects (without targetPath)
1992
+ processExpression({ node: unwrappedNode.left, context });
1993
+ processExpression({ node: unwrappedNode.right, context });
1994
+
1995
+ // Determine the type of the result
1996
+ const operatorKind = unwrappedNode.operatorToken.kind;
1997
+ let resultPath = null;
1998
+ let resultType = 'unknown';
1999
+
2000
+ // Type Inference Logic
2001
+ if (isComparisonOperator(operatorKind)) {
2002
+ resultType = 'boolean';
2003
+
2004
+ // Type narrowing: if comparing a call expression with unknown return type
2005
+ // to a value of known type, narrow the return type
2006
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2007
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2008
+
2009
+ // Check if left side is a call expression with unknown return type
2010
+ if (
2011
+ ts.isCallExpression(unwrappedNode.left) &&
2012
+ leftType === 'unknown' &&
2013
+ rightType !== 'unknown'
2014
+ ) {
2015
+ const leftPath = StructuredPath.fromNode(
2016
+ unwrappedNode.left,
2017
+ context.sourceFile,
2018
+ );
2019
+ if (leftPath) {
2020
+ const returnValuePath = leftPath.withProperty(
2021
+ 'functionCallReturnValue',
2022
+ );
2023
+ context.addType(returnValuePath, `${rightType} | unknown`);
2024
+ }
2025
+ }
2026
+ // Check if right side is a call expression with unknown return type
2027
+ else if (
2028
+ ts.isCallExpression(unwrappedNode.right) &&
2029
+ rightType === 'unknown' &&
2030
+ leftType !== 'unknown'
2031
+ ) {
2032
+ const rightPath = StructuredPath.fromNode(
2033
+ unwrappedNode.right,
2034
+ context.sourceFile,
2035
+ );
2036
+ if (rightPath) {
2037
+ const returnValuePath = rightPath.withProperty(
2038
+ 'functionCallReturnValue',
2039
+ );
2040
+ context.addType(returnValuePath, `${leftType} | unknown`);
2041
+ }
2042
+ }
2043
+ } else if (isArithmeticOperator(operatorKind)) {
2044
+ // For plus operator, check if either operand is a string
2045
+ if (operatorKind === ts.SyntaxKind.PlusToken) {
2046
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2047
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2048
+
2049
+ if (leftType === 'string' || rightType === 'string') {
2050
+ resultType = 'string';
2051
+ } else {
2052
+ resultType = 'number';
2053
+ }
2054
+ } else {
2055
+ // All other arithmetic operators result in numbers
2056
+ resultType = 'number';
2057
+ }
2058
+ } else if (operatorKind === ts.SyntaxKind.AmpersandAmpersandToken) {
2059
+ // Logical AND typically results in a boolean
2060
+ resultType = 'boolean';
2061
+
2062
+ // Mark the left operand as potentially undefined since it's being checked for truthiness
2063
+ markConditionVariablesAsNullable(unwrappedNode.left, context);
2064
+ } else if (
2065
+ operatorKind === ts.SyntaxKind.BarBarToken || // Logical OR
2066
+ operatorKind === ts.SyntaxKind.QuestionQuestionToken // Nullish Coalescing
2067
+ ) {
2068
+ // For || and ??, the result type depends on the operands
2069
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2070
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2071
+
2072
+ // For ||, if either side is boolean, result is boolean
2073
+ if (
2074
+ operatorKind === ts.SyntaxKind.BarBarToken &&
2075
+ (leftType === 'boolean' || rightType === 'boolean')
2076
+ ) {
2077
+ resultType = 'boolean';
2078
+ }
2079
+ // Otherwise, for both || and ??, we use the first defined type
2080
+ else if (isDefinedType(leftType)) {
2081
+ resultType = leftType;
2082
+ } else {
2083
+ resultType = rightType || 'unknown';
2084
+ }
2085
+ // For || and ??, create an equivalence to the left side
2086
+ // This ensures the equivalency chain is preserved through fallback expressions
2087
+ // e.g., `const tab = segments[0] || 'default'` should trace tab back to segments[0]
2088
+ if (operatorKind === ts.SyntaxKind.QuestionQuestionToken) {
2089
+ // specifically for ?? we create an equivalence to the left side
2090
+ // IMPORTANT: Also process the left side recursively to apply method semantics
2091
+ // (e.g., for `const segments = splat?.split('/') ?? []`, we need split semantics)
2092
+ processExpression({
2093
+ node: unwrappedNode.left,
2094
+ context,
2095
+ // Don't pass targetPath here - we'll establish equivalence separately below
2096
+ });
2097
+
2098
+ if (targetPath) {
2099
+ resultPath = StructuredPath.fromNode(
2100
+ unwrappedNode.left,
2101
+ context.sourceFile,
2102
+ );
2103
+ } else {
2104
+ // if the expression is the target capture that the two sides are equivalent (e.g. (x ?? y).map())
2105
+ targetPath = StructuredPath.fromNode(
2106
+ unwrappedNode,
2107
+ context.sourceFile,
2108
+ );
2109
+ resultPath = StructuredPath.fromNode(
2110
+ unwrappedNode.left,
2111
+ context.sourceFile,
2112
+ );
2113
+ }
2114
+ } else if (operatorKind === ts.SyntaxKind.BarBarToken) {
2115
+ // For ||, create equivalences to BOTH sides
2116
+ // This enables data flow tracing through fallback expressions
2117
+ // e.g., `const item = items.find(...) || null` should trace to both:
2118
+ // - items[] (from the find result)
2119
+ // - null (from the fallback)
2120
+ if (targetPath) {
2121
+ // Get paths for both sides
2122
+ const leftPath = StructuredPath.fromNode(
2123
+ unwrappedNode.left,
2124
+ context.sourceFile,
2125
+ );
2126
+ const rightPath = StructuredPath.fromNode(
2127
+ unwrappedNode.right,
2128
+ context.sourceFile,
2129
+ );
2130
+
2131
+ // Collect all valid paths
2132
+ const allPaths: StructuredPath[] = [];
2133
+ if (leftPath) allPaths.push(leftPath);
2134
+ if (rightPath) allPaths.push(rightPath);
2135
+
2136
+ // Add multiple equivalencies to track both sources
2137
+ if (allPaths.length > 0) {
2138
+ context.addMultipleEquivalencies(targetPath, allPaths);
2139
+ }
2140
+
2141
+ // Process both sides to capture their internal structures
2142
+ processExpression({
2143
+ node: unwrappedNode.left,
2144
+ context,
2145
+ });
2146
+ processExpression({
2147
+ node: unwrappedNode.right,
2148
+ context,
2149
+ });
2150
+
2151
+ // Register the type for the target path
2152
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2153
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2154
+ const orResultType = isDefinedType(leftType)
2155
+ ? leftType
2156
+ : rightType || 'unknown';
2157
+ context.addType(targetPath, orResultType);
2158
+
2159
+ // Return early - we've already handled equivalencies with addMultipleEquivalencies
2160
+ // Don't fall through to the generic addEquivalence call below
2161
+ return true;
2162
+ }
2163
+ // Note: When there's no targetPath, we don't recursively process
2164
+ // because || is often used in boolean contexts where the full expression matters
2165
+ }
2166
+ } else if (operatorKind === ts.SyntaxKind.InstanceOfKeyword) {
2167
+ resultType = 'boolean';
2168
+ } else {
2169
+ // Fallback for other operators
2170
+ resultType = inferredNodeType;
2171
+ context.markUnsupported(
2172
+ unwrappedNode,
2173
+ `processExpression: Unsupported binary operator: ${ts.SyntaxKind[operatorKind]}`,
2174
+ false,
2175
+ );
2176
+ }
2177
+
2178
+ // Get a canonical representation for the entire binary expression
2179
+ resultPath ??= nodeToSource(unwrappedNode, context.sourceFile);
2180
+
2181
+ // Register the type for the expression
2182
+ context.addType(resultPath, resultType);
2183
+
2184
+ // If targetPath is provided, establish equivalence and register type
2185
+ if (targetPath) {
2186
+ context.addEquivalence(targetPath, resultPath);
2187
+ context.addType(targetPath, resultType);
2188
+ }
2189
+
2190
+ return true;
2191
+ }
2192
+ }
2193
+
2194
+ // Handle Call Expressions: func(), obj.method(), func()() etc.
2195
+ if (ts.isCallExpression(unwrappedNode)) {
2196
+ // 1. Process the expression being called (e.g., 'func', 'obj.method')
2197
+ const calledExprProcessed = processExpression({
2198
+ node: unwrappedNode.expression,
2199
+ context,
2200
+ });
2201
+
2202
+ if (!calledExprProcessed) {
2203
+ context.markUnsupported(
2204
+ unwrappedNode.expression,
2205
+ `processExpression: Unsupported expression being called: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2206
+ false,
2207
+ );
2208
+ return false;
2209
+ }
2210
+
2211
+ // Get a proper path for the called expression
2212
+ const calledExprPath = StructuredPath.fromNode(
2213
+ unwrappedNode.expression,
2214
+ context.sourceFile,
2215
+ );
2216
+
2217
+ if (!calledExprPath) {
2218
+ context.markUnsupported(
2219
+ unwrappedNode.expression,
2220
+ `processExpression: Couldn't get path for called expression: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2221
+ false,
2222
+ );
2223
+ return false;
2224
+ }
2225
+
2226
+ // Build call path using original source text for consistent schema paths.
2227
+ // IMPORTANT: Never use cyScope names in call paths - they are internal identifiers
2228
+ // that should not appear in schema paths or call signatures.
2229
+ const callPath = buildCallPathFromSource(unwrappedNode, context);
2230
+
2231
+ // 2. Process all arguments recursively WITH targetPath for proper equivalence
2232
+ for (let i = 0; i < unwrappedNode.arguments.length; i++) {
2233
+ const arg = unwrappedNode.arguments[i];
2234
+
2235
+ const childBoundary = context.isChildBoundary(arg);
2236
+ if (childBoundary) {
2237
+ context.addChildBoundaryEquivalence(callPath.withParameter(i), arg);
2238
+ }
2239
+
2240
+ // Process each argument with its parameter path as targetPath
2241
+ // This automatically establishes all equivalences and types
2242
+ processExpression({
2243
+ node: arg,
2244
+ context,
2245
+ targetPath: callPath.withParameter(i), // Use parameter path as targetPath
2246
+ });
2247
+
2248
+ // Special case for Object.keys, etc.
2249
+ if (calledExprPath.base === 'Object' && i === 0) {
2250
+ const argPath = StructuredPath.fromNode(arg, context.sourceFile);
2251
+ if (argPath) {
2252
+ context.addType(argPath, 'object');
2253
+ }
2254
+ }
2255
+ }
2256
+
2257
+ // 5. Handle Method Semantics and determine return type
2258
+ let returnType = 'unknown';
2259
+ let handledBySemantics = false;
2260
+
2261
+ // Check if it's a method call (PropertyAccess)
2262
+ if (ts.isPropertyAccessExpression(unwrappedNode.expression)) {
2263
+ const methodName = unwrappedNode.expression.name.text;
2264
+ const semanticsList = methodRegistry.getByMethodName(methodName);
2265
+
2266
+ if (semanticsList && semanticsList.length > 0) {
2267
+ const semantics = semanticsList[0];
2268
+
2269
+ // Get the source expression path (e.g., the object for obj.method())
2270
+ const sourceExpr = unwrappedNode.expression.expression;
2271
+ const unwrappedSourceExpr = unwrapExpression(sourceExpr);
2272
+
2273
+ // When the source is a ternary expression like (cond ? arr : arr.slice()),
2274
+ // apply method semantics to BOTH branches directly. The ternary itself isn't
2275
+ // a variable - it's just a choice between two paths that both flow to the result.
2276
+ if (ts.isConditionalExpression(unwrappedSourceExpr)) {
2277
+ const branches = [
2278
+ unwrappedSourceExpr.whenTrue,
2279
+ unwrappedSourceExpr.whenFalse,
2280
+ ];
2281
+
2282
+ for (const branch of branches) {
2283
+ const branchPath = StructuredPath.fromNode(
2284
+ branch,
2285
+ context.sourceFile,
2286
+ );
2287
+ if (branchPath) {
2288
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
2289
+ const shouldApply =
2290
+ !isArraySemantics ||
2291
+ isLikelyArrayType(branch, context.typeChecker);
2292
+
2293
+ if (shouldApply) {
2294
+ semantics.addEquivalences(callPath, branchPath, context);
2295
+ returnType = semantics.getReturnType();
2296
+ handledBySemantics = true;
2297
+ }
2298
+ }
2299
+ }
2300
+ } else {
2301
+ // Regular (non-ternary) source expression
2302
+ const sourcePath = StructuredPath.fromNode(
2303
+ sourceExpr,
2304
+ context.sourceFile,
2305
+ );
2306
+
2307
+ if (sourcePath) {
2308
+ // For array-specific semantics (like push), verify the source is actually an array
2309
+ // This prevents router.push() from being mistakenly treated as Array.push()
2310
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
2311
+ const shouldApply =
2312
+ !isArraySemantics ||
2313
+ isLikelyArrayType(sourceExpr, context.typeChecker);
2314
+
2315
+ if (shouldApply) {
2316
+ // Apply method semantics
2317
+ semantics.addEquivalences(callPath, sourcePath, context);
2318
+ returnType = semantics.getReturnType();
2319
+ handledBySemantics = true;
2320
+ }
2321
+ }
2322
+ }
2323
+ }
2324
+ }
2325
+ // Check if it's a method call via element access (obj['method']())
2326
+ else if (
2327
+ ts.isElementAccessExpression(unwrappedNode.expression) &&
2328
+ ts.isStringLiteral(unwrappedNode.expression.argumentExpression)
2329
+ ) {
2330
+ const methodName = unwrappedNode.expression.argumentExpression.text;
2331
+ const semanticsList = methodRegistry.getByMethodName(methodName);
2332
+
2333
+ if (semanticsList && semanticsList.length > 0) {
2334
+ const semantics = semanticsList[0];
2335
+
2336
+ // Get the source expression path
2337
+ const sourceExpr = unwrappedNode.expression.expression;
2338
+ const sourcePath = StructuredPath.fromNode(
2339
+ sourceExpr,
2340
+ context.sourceFile,
2341
+ );
2342
+
2343
+ if (sourcePath) {
2344
+ // For array-specific semantics (like push), verify the source is actually an array
2345
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
2346
+ const shouldApply =
2347
+ !isArraySemantics ||
2348
+ isLikelyArrayType(sourceExpr, context.typeChecker);
2349
+
2350
+ if (shouldApply) {
2351
+ // Apply method semantics
2352
+ semantics.addEquivalences(callPath, sourcePath, context);
2353
+ returnType = semantics.getReturnType();
2354
+ handledBySemantics = true;
2355
+ }
2356
+ }
2357
+ }
2358
+ }
2359
+ // 7. Determine and Add Return Type
2360
+ if (returnType === 'unknown') {
2361
+ // If semantics didn't provide a type, try inferring
2362
+ returnType = context.inferTypeFromNode(node);
2363
+ }
2364
+
2365
+ // Register types
2366
+ context.addType(callPath, 'function');
2367
+ context.addType(calledExprPath, 'function');
2368
+
2369
+ // Only register the function call return value if:
2370
+ // - It's not void, AND
2371
+ // - Either the result is being used (targetPath exists) OR the return type is known (not 'unknown')
2372
+ if (returnType !== 'void' && (targetPath || returnType !== 'unknown')) {
2373
+ const returnValuePath = callPath.withProperty('functionCallReturnValue');
2374
+ context.addType(returnValuePath, returnType);
2375
+ }
2376
+
2377
+ // 8. If targetPath is provided, establish equivalence and register type
2378
+ if (targetPath) {
2379
+ context.addEquivalence(targetPath, callPath);
2380
+ context.addType(targetPath, returnType);
2381
+ }
2382
+
2383
+ return true;
2384
+ }
2385
+
2386
+ // Handle Object Literals: { a: 1, b: x, ...spread }
2387
+ if (ts.isObjectLiteralExpression(unwrappedNode)) {
2388
+ // Create a path for the object literal itself
2389
+ const literalSourcePath = StructuredPath.createLiteralPath(
2390
+ unwrappedNode.getText(context.sourceFile),
2391
+ 'object',
2392
+ );
2393
+
2394
+ // If targetPath is provided, establish property relationships
2395
+ // This is the main use case we're optimizing for
2396
+ if (targetPath) {
2397
+ // Process each property and establish relationships to the targetPath
2398
+ for (const property of unwrappedNode.properties) {
2399
+ if (ts.isPropertyAssignment(property)) {
2400
+ // Get property name
2401
+ let propName: string;
2402
+ if (ts.isIdentifier(property.name)) {
2403
+ propName = property.name.text;
2404
+ } else if (ts.isStringLiteral(property.name)) {
2405
+ propName = property.name.text;
2406
+ } else if (ts.isNumericLiteral(property.name)) {
2407
+ propName = property.name.text;
2408
+ } else if (ts.isComputedPropertyName(property.name)) {
2409
+ // Handle computed property names: { [x]: y }
2410
+ processExpression({ node: property.name.expression, context });
2411
+ const path = StructuredPath.fromNode(
2412
+ property.name.expression,
2413
+ context.sourceFile,
2414
+ );
2415
+ propName = `*${path}*`;
2416
+ } else {
2417
+ // For other property name types, use text representation
2418
+ propName = property.name.getText(context.sourceFile);
2419
+ context.markSemanticLimitation(
2420
+ property.name,
2421
+ 'Complex property name might not be accurately represented.',
2422
+ );
2423
+ }
2424
+
2425
+ // Create a path for this property within the base
2426
+ const propPath = targetPath.withProperty(propName);
2427
+
2428
+ // Handle child boundaries (callback functions) in object properties
2429
+ // This establishes equivalency between the property path and the child scope
2430
+ // e.g., columns[0].renderCell → cyScope1()
2431
+ if (context.isChildBoundary(property.initializer)) {
2432
+ context.addChildBoundaryEquivalence(propPath, property.initializer);
2433
+ }
2434
+
2435
+ // Process the property value with propPath as targetPath
2436
+ // This allows nested object literals to work correctly
2437
+ processExpression({
2438
+ node: property.initializer,
2439
+ context,
2440
+ targetPath: propPath,
2441
+ });
2442
+ } else if (ts.isShorthandPropertyAssignment(property)) {
2443
+ // Handle shorthand form: { x } is equivalent to { x: x }
2444
+ const propName = property.name.text;
2445
+ const propPath = targetPath.withProperty(propName);
2446
+
2447
+ // Create a path for the identifier value
2448
+ const valuePath = StructuredPath.fromBase(propName);
2449
+
2450
+ // Establish the equivalence and type
2451
+ context.addEquivalence(propPath, valuePath);
2452
+ const valueType = context.inferTypeFromNode(property.name);
2453
+ context.addType(propPath, valueType);
2454
+ context.addType(valuePath, valueType);
2455
+ } else if (ts.isSpreadAssignment(property)) {
2456
+ // Handle spread: { ...obj }
2457
+ // Create a path for this spread source
2458
+ let spreadSourcePath: StructuredPath | null = null;
2459
+
2460
+ // Handle simple identifier spread: { ...obj }
2461
+ if (ts.isIdentifier(property.expression)) {
2462
+ // Process the spread expression first
2463
+ processExpression({ node: property.expression, context });
2464
+
2465
+ spreadSourcePath = StructuredPath.fromBase(
2466
+ property.expression.text,
2467
+ );
2468
+ // Establish equivalence between the target and the spread source
2469
+ context.addEquivalence(targetPath, spreadSourcePath);
2470
+ // and we know obj is an object
2471
+ context.addType(spreadSourcePath, 'object');
2472
+ }
2473
+ // Handle property access spread: { ...obj.prop }
2474
+ else if (ts.isPropertyAccessExpression(property.expression)) {
2475
+ // Process the spread expression first
2476
+ processExpression({ node: property.expression, context });
2477
+
2478
+ spreadSourcePath = StructuredPath.fromNode(
2479
+ property.expression,
2480
+ context.sourceFile,
2481
+ );
2482
+ if (spreadSourcePath) {
2483
+ context.addEquivalence(targetPath, spreadSourcePath);
2484
+ }
2485
+ }
2486
+ // Handle object literal spread: { ...{ key: value } }
2487
+ // This propagates sub-properties from the spread object to the target
2488
+ else if (ts.isObjectLiteralExpression(property.expression)) {
2489
+ // Recursively process the spread object literal WITH targetPath
2490
+ // This ensures sub-properties like { args: x } become targetPath.args = x
2491
+ processExpression({
2492
+ node: property.expression,
2493
+ context,
2494
+ targetPath,
2495
+ });
2496
+ }
2497
+ // Handle conditional spread: { ...(x ? {...} : {}) }
2498
+ else if (ts.isParenthesizedExpression(property.expression)) {
2499
+ // Unwrap parentheses and process
2500
+ const unwrapped = property.expression.expression;
2501
+
2502
+ // Handle conditional expression inside parens: (x ? {...} : {})
2503
+ if (ts.isConditionalExpression(unwrapped)) {
2504
+ // Process both branches - whenTrue and whenFalse
2505
+ // For tracing, we care about non-empty branches
2506
+ if (ts.isObjectLiteralExpression(unwrapped.whenTrue)) {
2507
+ processExpression({
2508
+ node: unwrapped.whenTrue,
2509
+ context,
2510
+ targetPath,
2511
+ });
2512
+ } else {
2513
+ processExpression({ node: unwrapped.whenTrue, context });
2514
+ }
2515
+
2516
+ if (ts.isObjectLiteralExpression(unwrapped.whenFalse)) {
2517
+ processExpression({
2518
+ node: unwrapped.whenFalse,
2519
+ context,
2520
+ targetPath,
2521
+ });
2522
+ } else {
2523
+ processExpression({ node: unwrapped.whenFalse, context });
2524
+ }
2525
+ } else {
2526
+ // Other parenthesized expression - just process normally
2527
+ processExpression({ node: property.expression, context });
2528
+ }
2529
+ }
2530
+ // Handle other expression types
2531
+ else {
2532
+ // Process the spread expression
2533
+ processExpression({ node: property.expression, context });
2534
+
2535
+ // For complex expressions, use their source representation
2536
+ spreadSourcePath = nodeToSource(
2537
+ property.expression,
2538
+ context.sourceFile,
2539
+ );
2540
+ if (spreadSourcePath) {
2541
+ context.addEquivalence(targetPath, spreadSourcePath);
2542
+ }
2543
+
2544
+ // Mark semantic limitation only for complex spread expressions
2545
+ context.markSemanticLimitation(
2546
+ property,
2547
+ 'Complex spread assignment - individual properties not fully mapped.',
2548
+ );
2549
+ }
2550
+ } else if (
2551
+ ts.isMethodDeclaration(property) ||
2552
+ ts.isGetAccessorDeclaration(property) ||
2553
+ ts.isSetAccessorDeclaration(property)
2554
+ ) {
2555
+ // For methods and accessors, just mark the property as a function
2556
+ if (ts.isIdentifier(property.name)) {
2557
+ const propName = property.name.text;
2558
+ const propPath = targetPath.withProperty(propName);
2559
+ context.addType(propPath, 'function');
2560
+ }
2561
+
2562
+ context.markUnsupported(
2563
+ property,
2564
+ `processExpression: Method/Accessor in object literal not fully processed: ${ts.SyntaxKind[property.kind]}`,
2565
+ false,
2566
+ );
2567
+ }
2568
+ }
2569
+
2570
+ // Mark the targetPath as an object type
2571
+ context.addType(targetPath, 'object');
2572
+ return true;
2573
+ } else {
2574
+ // No targetPath provided - just process each property for side effects
2575
+ for (const property of unwrappedNode.properties) {
2576
+ if (ts.isPropertyAssignment(property)) {
2577
+ processExpression({ node: property.initializer, context });
2578
+ } else if (ts.isShorthandPropertyAssignment(property)) {
2579
+ // For shorthand, establish type for the identifier
2580
+ const identPath = StructuredPath.fromBase(property.name.text);
2581
+ const idType = context.inferTypeFromNode(property.name);
2582
+ context.addType(identPath, idType);
2583
+ } else if (ts.isSpreadAssignment(property)) {
2584
+ // Still process the spread expression to ensure its contents are analyzed
2585
+ processExpression({ node: property.expression, context });
2586
+
2587
+ // Even without a targetPath, we can still determine the type for the spread source
2588
+ if (ts.isIdentifier(property.expression)) {
2589
+ const spreadSource = StructuredPath.fromBase(
2590
+ property.expression.text,
2591
+ );
2592
+ context.addType(spreadSource, 'object');
2593
+ } else if (ts.isPropertyAccessExpression(property.expression)) {
2594
+ const spreadSource = StructuredPath.fromNode(
2595
+ property.expression,
2596
+ context.sourceFile,
2597
+ );
2598
+ if (spreadSource) {
2599
+ context.addType(spreadSource, 'object');
2600
+ }
2601
+ }
2602
+ } else if (
2603
+ ts.isMethodDeclaration(property) ||
2604
+ ts.isGetAccessorDeclaration(property) ||
2605
+ ts.isSetAccessorDeclaration(property)
2606
+ ) {
2607
+ context.markUnsupported(
2608
+ property,
2609
+ `processExpression: Method/Accessor in object literal not fully processed: ${ts.SyntaxKind[property.kind]}`,
2610
+ false,
2611
+ );
2612
+ }
2613
+ }
2614
+
2615
+ // If we have no targetPath but we're still analyzing an object literal,
2616
+ // create a type registration for the literal itself
2617
+ context.addType(literalSourcePath, 'object');
2618
+ return true;
2619
+ }
2620
+ }
2621
+
2622
+ // Handle Array Literals: [1, x, func()]
2623
+ if (ts.isArrayLiteralExpression(unwrappedNode)) {
2624
+ // Create a path for the array literal
2625
+ const arrayLiteralPath = StructuredPath.createLiteralPath(
2626
+ unwrappedNode.getText(context.sourceFile),
2627
+ 'array',
2628
+ );
2629
+
2630
+ // Process each element recursively
2631
+ for (let i = 0; i < unwrappedNode.elements.length; i++) {
2632
+ const element = unwrappedNode.elements[i];
2633
+
2634
+ // If targetPath is provided, create element paths
2635
+ if (targetPath) {
2636
+ // Create path for this element (e.g., targetPath[0], targetPath[1])
2637
+ const elementPath = targetPath.withElement(i);
2638
+
2639
+ // Process the element with elementPath as targetPath
2640
+ processExpression({ node: element, context, targetPath: elementPath });
2641
+ } else {
2642
+ // No targetPath, just process for side effects
2643
+ processExpression({ node: element, context });
2644
+ }
2645
+ }
2646
+
2647
+ // Register type information
2648
+ if (targetPath) {
2649
+ context.addType(targetPath, 'array');
2650
+ } else {
2651
+ context.addType(arrayLiteralPath, 'array');
2652
+ }
2653
+
2654
+ return true;
2655
+ }
2656
+
2657
+ // Handle Element Access: arr[0], obj[key], obj['prop']
2658
+ if (ts.isElementAccessExpression(unwrappedNode)) {
2659
+ // Process the object expression
2660
+ const objectProcessed = processExpression({
2661
+ node: unwrappedNode.expression,
2662
+ context,
2663
+ });
2664
+
2665
+ if (!objectProcessed) {
2666
+ context.markUnsupported(
2667
+ unwrappedNode.expression,
2668
+ `processExpression: Unsupported base expression for element access: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2669
+ false,
2670
+ );
2671
+ return false;
2672
+ }
2673
+
2674
+ // Get a path for the object
2675
+ const objectPath = StructuredPath.fromNode(
2676
+ unwrappedNode.expression,
2677
+ context.sourceFile,
2678
+ );
2679
+
2680
+ if (!objectPath) {
2681
+ context.markUnsupported(
2682
+ unwrappedNode.expression,
2683
+ `processExpression: Couldn't get path for element access base: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2684
+ false,
2685
+ );
2686
+ return false;
2687
+ }
2688
+
2689
+ // Process the argument expression
2690
+ processExpression({ node: unwrappedNode.argumentExpression, context });
2691
+
2692
+ // Create the element access path based on argument type
2693
+ let elementPath: StructuredPath;
2694
+
2695
+ if (ts.isNumericLiteral(unwrappedNode.argumentExpression)) {
2696
+ // Array index: arr[0]
2697
+ elementPath = objectPath.withElement(
2698
+ parseInt(unwrappedNode.argumentExpression.text, 10),
2699
+ );
2700
+ } else if (ts.isStringLiteral(unwrappedNode.argumentExpression)) {
2701
+ // String key: obj['prop']
2702
+ elementPath = objectPath.withProperty(
2703
+ unwrappedNode.argumentExpression.text,
2704
+ );
2705
+ } else {
2706
+ // Dynamic access: obj[key]
2707
+ // Use a representation of the argument or fallback to wildcard
2708
+ const argText = unwrappedNode.argumentExpression.getText(
2709
+ context.sourceFile,
2710
+ );
2711
+ elementPath = objectPath.withElement(argText || '*');
2712
+ }
2713
+
2714
+ // Infer and register type
2715
+ context.addType(elementPath, inferredNodeType);
2716
+
2717
+ // If targetPath is provided, establish equivalence and register type
2718
+ if (targetPath) {
2719
+ context.addEquivalence(targetPath, elementPath);
2720
+ context.addType(targetPath, inferredNodeType);
2721
+ }
2722
+
2723
+ return true;
2724
+ }
2725
+
2726
+ // Handle Conditional Expression (Ternary): cond ? trueVal : falseVal
2727
+ if (ts.isConditionalExpression(unwrappedNode)) {
2728
+ // Mark variables in the condition as potentially undefined
2729
+ markConditionVariablesAsNullable(unwrappedNode.condition, context);
2730
+
2731
+ // Extract conditional usages for key attribute detection
2732
+ extractConditionalUsage(unwrappedNode.condition, context, 'ternary');
2733
+
2734
+ // Extract conditional effects (setter calls in ternary branches)
2735
+ const knownSetters = findUseStateSetters(context.sourceFile);
2736
+ const effects = extractConditionalEffectsFromTernary(
2737
+ unwrappedNode,
2738
+ context,
2739
+ knownSetters,
2740
+ );
2741
+ for (const effect of effects) {
2742
+ context.addConditionalEffect(effect);
2743
+ }
2744
+
2745
+ // Process all parts recursively
2746
+ processExpression({
2747
+ node: unwrappedNode.condition,
2748
+ context,
2749
+ typeHint: 'boolean | unknown',
2750
+ }); //TODO: could we capture that this is evidence of a boolean type?
2751
+
2752
+ // Process both branches WITH targetPath to establish equivalencies
2753
+ // This is critical for tracing nested properties through ternary assignments
2754
+ // e.g., const items = condition ? arr1 : arr2; items.map(i => i.prop)
2755
+ // We need items to be equivalent to both arr1 AND arr2 for proper tracing
2756
+ processExpression({ node: unwrappedNode.whenTrue, context, targetPath });
2757
+ processExpression({ node: unwrappedNode.whenFalse, context, targetPath });
2758
+
2759
+ // Create a path for the whole expression
2760
+ const expressionSourcePath = nodeToSource(
2761
+ unwrappedNode,
2762
+ context.sourceFile,
2763
+ );
2764
+
2765
+ // Infer type based on branches
2766
+ const trueType = context.inferTypeFromNode(unwrappedNode.whenTrue);
2767
+ const falseType = context.inferTypeFromNode(unwrappedNode.whenFalse);
2768
+
2769
+ // Determine the result type
2770
+ let resultType = leftOrRightType(falseType, trueType);
2771
+ if (!resultType) {
2772
+ // If we can't determine a specific type, use unknown without marking as semantic limitation
2773
+ // This prevents conditional expressions from marking the analysis as incomplete
2774
+ resultType = 'unknown';
2775
+ }
2776
+
2777
+ // Register type for the expression
2778
+ context.addType(expressionSourcePath, resultType);
2779
+
2780
+ // If targetPath is provided, only register type (don't overwrite branch equivalencies)
2781
+ // The equivalencies to individual branches (set above) are more useful for tracing
2782
+ // than an equivalency to the entire ternary expression text
2783
+ if (targetPath) {
2784
+ // NOTE: We intentionally do NOT add equivalence here.
2785
+ // The branch processing above already added equivalencies:
2786
+ // targetPath -> whenTrue branch
2787
+ // targetPath -> whenFalse branch
2788
+ // Adding an equivalence to expressionSourcePath would overwrite those
2789
+ // with a useless equivalence to the ternary text itself.
2790
+ //
2791
+ // Use updateSchemaType instead of addType because:
2792
+ // 1. Branch processing may have already set a type on targetPath
2793
+ // 2. addType has a guard that prevents overwriting specific types with 'unknown'
2794
+ // 3. updateSchemaType bypasses this guard, ensuring the ternary's computed type is used
2795
+ context.updateSchemaType(targetPath, resultType);
2796
+ }
2797
+
2798
+ return true;
2799
+ }
2800
+
2801
+ // Handle New Expression: new Date(), new MyClass()
2802
+ if (ts.isNewExpression(unwrappedNode)) {
2803
+ // Process the constructor expression
2804
+ const constructorProcessed = processExpression({
2805
+ node: unwrappedNode.expression,
2806
+ context,
2807
+ });
2808
+
2809
+ if (!constructorProcessed) {
2810
+ context.markUnsupported(
2811
+ unwrappedNode.expression,
2812
+ `processExpression: Unsupported constructor expression: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2813
+ false,
2814
+ );
2815
+ return false;
2816
+ }
2817
+
2818
+ // Get a path for the constructor
2819
+ const constructorPath = StructuredPath.fromNode(
2820
+ unwrappedNode.expression,
2821
+ context.sourceFile,
2822
+ );
2823
+
2824
+ if (!constructorPath) {
2825
+ return false;
2826
+ }
2827
+
2828
+ // Process any arguments
2829
+ if (unwrappedNode.arguments) {
2830
+ for (const arg of unwrappedNode.arguments) {
2831
+ processExpression({ node: arg, context });
2832
+ }
2833
+ }
2834
+
2835
+ // Create argument paths for the function call
2836
+ const validArgPaths: StructuredPath[] = unwrappedNode.arguments
2837
+ ? unwrappedNode.arguments.map(
2838
+ (arg) =>
2839
+ StructuredPath.fromNode(arg, context.sourceFile) ??
2840
+ nodeToSource(arg, context.sourceFile) ??
2841
+ StructuredPath.literal('unknown'),
2842
+ )
2843
+ : [];
2844
+
2845
+ // Construct a path for the new expression
2846
+ const newCallPath = constructorPath.withFunctionCall(validArgPaths);
2847
+
2848
+ // Infer result type
2849
+ let resultType = 'object';
2850
+ if (ts.isIdentifier(unwrappedNode.expression)) {
2851
+ const constructorName = unwrappedNode.expression.text;
2852
+ if (
2853
+ ['String', 'Number', 'Boolean', 'Array', 'Date'].includes(
2854
+ constructorName,
2855
+ )
2856
+ ) {
2857
+ resultType = constructorName.toLowerCase();
2858
+ }
2859
+ } else {
2860
+ resultType = inferredNodeType;
2861
+ }
2862
+
2863
+ // Register types
2864
+ context.addType(newCallPath, resultType);
2865
+ context.addType(constructorPath, 'function');
2866
+
2867
+ // If targetPath is provided, establish equivalence and register type
2868
+ if (targetPath) {
2869
+ context.addEquivalence(targetPath, newCallPath);
2870
+ context.addType(targetPath, resultType);
2871
+ }
2872
+
2873
+ return true;
2874
+ }
2875
+
2876
+ // Handle Arrow Functions: (p) => p.prop, (a, b) => { ... }
2877
+ if (ts.isArrowFunction(unwrappedNode)) {
2878
+ // If this arrow function is a child boundary (e.g., a .map() callback),
2879
+ // don't process its parameters here - they will be processed when the
2880
+ // child scope is analyzed separately. This prevents parameter variables
2881
+ // from leaking into the parent scope's equivalencies.
2882
+ // Check if this arrow function is a child boundary (i.e., should be processed
2883
+ // as a separate child scope, not here in the parent scope).
2884
+ //
2885
+ // We use two checks because childBoundary positions can be unreliable:
2886
+ // 1. Position-based check (standard isChildBoundary)
2887
+ // 2. Text-based check: if the arrow function text doesn't appear in the
2888
+ // statement text, it was replaced with a cyScope placeholder
2889
+ const isChildBoundary = context.isChildBoundary(unwrappedNode);
2890
+
2891
+ // Text-based child scope detection for when positions are unreliable
2892
+ const arrowFnText = unwrappedNode.getText(context.sourceFile);
2893
+ const firstLine = arrowFnText.split('\n')[0].trim();
2894
+ const searchText = firstLine.substring(0, Math.min(20, firstLine.length));
2895
+ const isInStatementText = context.statementInfo.text.includes(searchText);
2896
+ const isChildScope = !isInStatementText && arrowFnText.length > 10;
2897
+
2898
+ if (isChildBoundary || isChildScope) {
2899
+ // The method semantics (e.g., ArrayMapSemantics) have already established
2900
+ // the necessary equivalences between the child scope placeholder and array elements
2901
+ if (targetPath) {
2902
+ context.addType(targetPath, 'function');
2903
+ }
2904
+ return true;
2905
+ }
2906
+
2907
+ // Create a path for the function
2908
+ const functionPath = StructuredPath.empty();
2909
+
2910
+ // Process parameters
2911
+ unwrappedNode.parameters.forEach((param, index) => {
2912
+ const signaturePath = functionPath.withParameter(index);
2913
+ if (ts.isIdentifier(param.name)) {
2914
+ const paramNamePath = StructuredPath.fromBase(param.name.text);
2915
+
2916
+ // Establish equivalence between parameter name and signature path
2917
+ context.addEquivalence(paramNamePath, signaturePath);
2918
+
2919
+ // Register types
2920
+ const paramType = context.inferTypeFromNode(param) || 'unknown';
2921
+ context.addType(paramNamePath, paramType);
2922
+ context.addType(signaturePath, paramType);
2923
+ } else if (
2924
+ ts.isObjectBindingPattern(param.name) ||
2925
+ ts.isArrayBindingPattern(param.name)
2926
+ ) {
2927
+ const success = processBindingPattern(
2928
+ param.name,
2929
+ signaturePath,
2930
+ context,
2931
+ );
2932
+ if (!success) {
2933
+ context.markUnsupported(
2934
+ param,
2935
+ `processExpression: Failed to process binding pattern: ${ts.SyntaxKind[param.kind]}`,
2936
+ false,
2937
+ );
2938
+ }
2939
+ } else {
2940
+ context.markUnsupported(
2941
+ param,
2942
+ `processExpression: Unsupported parameter kind in ArrowFunction: ${ts.SyntaxKind[param.kind]}`,
2943
+ false,
2944
+ );
2945
+ }
2946
+ });
2947
+
2948
+ // Process function body
2949
+ const body = unwrappedNode.body;
2950
+ if (ts.isBlock(body)) {
2951
+ // For block bodies, process the statements inside
2952
+ context.processNode(body);
2953
+ } else {
2954
+ // For expression bodies, process as implicit return
2955
+ const returnPath = functionPath.withProperty('returnValue');
2956
+ processExpression({ node: body, context, targetPath: returnPath });
2957
+ }
2958
+
2959
+ // If targetPath is provided, establish equivalence
2960
+ if (targetPath) {
2961
+ context.addEquivalence(targetPath, functionPath);
2962
+ context.addType(targetPath, 'function');
2963
+ }
2964
+
2965
+ return true;
2966
+ }
2967
+
2968
+ // Handle Tagged Template Expressions: sql`SELECT * FROM ${table}`
2969
+ if (ts.isTaggedTemplateExpression(unwrappedNode)) {
2970
+ // Process the tag expression (e.g., 'sql', 'css', 'gql')
2971
+ const tagProcessed = processExpression({
2972
+ node: unwrappedNode.tag,
2973
+ context,
2974
+ });
2975
+
2976
+ if (!tagProcessed) {
2977
+ context.markUnsupported(
2978
+ unwrappedNode.tag,
2979
+ `processExpression: Unsupported tag expression in tagged template: ${ts.SyntaxKind[unwrappedNode.tag.kind]}`,
2980
+ false,
2981
+ );
2982
+ return false;
2983
+ }
2984
+
2985
+ // Get a path for the tag
2986
+ const tagPath = StructuredPath.fromNode(
2987
+ unwrappedNode.tag,
2988
+ context.sourceFile,
2989
+ );
2990
+
2991
+ if (tagPath) {
2992
+ // Mark the tag as a function
2993
+ context.addType(tagPath, 'function');
2994
+ }
2995
+
2996
+ // Process the template part (reusing existing template processing logic)
2997
+ const template = unwrappedNode.template;
2998
+ let allSpansProcessed = true;
2999
+
3000
+ if (ts.isTemplateExpression(template)) {
3001
+ // Process all template spans (interpolations)
3002
+ for (const span of template.templateSpans) {
3003
+ if (context.isChildBoundary(span.expression)) {
3004
+ continue;
3005
+ }
3006
+
3007
+ const spanProcessed = processExpression({
3008
+ node: span.expression,
3009
+ context,
3010
+ targetPath: StructuredPath.empty(),
3011
+ });
3012
+
3013
+ allSpansProcessed = allSpansProcessed && spanProcessed;
3014
+ }
3015
+ }
3016
+ // If it's NoSubstitutionTemplateLiteral, nothing more to process
3017
+
3018
+ // Create a path for the entire tagged template expression
3019
+ const taggedTemplatePath = StructuredPath.fromNode(
3020
+ unwrappedNode,
3021
+ context.sourceFile,
3022
+ );
3023
+
3024
+ // The return type of a tagged template is unknown (depends on the tag function)
3025
+ context.addType(taggedTemplatePath, 'unknown');
3026
+
3027
+ // If targetPath is provided, establish equivalence
3028
+ if (targetPath) {
3029
+ context.addEquivalence(targetPath, taggedTemplatePath);
3030
+ context.addType(targetPath, 'unknown');
3031
+ }
3032
+
3033
+ // If we didn't fully handle all spans, mark as semantic limitation
3034
+ if (!allSpansProcessed && ts.isTemplateExpression(template)) {
3035
+ context.markSemanticLimitation(
3036
+ unwrappedNode,
3037
+ 'Tagged template contains complex expressions that may not be fully analyzed',
3038
+ );
3039
+ }
3040
+
3041
+ return true;
3042
+ }
3043
+
3044
+ // Handle Template Literals: `Hello ${name}` or `Simple`
3045
+ if (
3046
+ ts.isTemplateExpression(unwrappedNode) ||
3047
+ ts.isNoSubstitutionTemplateLiteral(unwrappedNode)
3048
+ ) {
3049
+ // Create a path for the template literal
3050
+ const templatePath = StructuredPath.createLiteralPath(
3051
+ unwrappedNode.getText(context.sourceFile),
3052
+ 'string',
3053
+ );
3054
+
3055
+ // Track if we can fully handle all expressions in the template
3056
+ let allSpansProcessed = true;
3057
+
3058
+ // Process template spans if any by recursing back into processExpression
3059
+ if (ts.isTemplateExpression(unwrappedNode)) {
3060
+ for (const span of unwrappedNode.templateSpans) {
3061
+ if (context.isChildBoundary(span.expression)) {
3062
+ continue;
3063
+ }
3064
+
3065
+ // Process each span with StructuredPath.empty() as targetPath
3066
+ // This ensures types and equivalences are established without imposing
3067
+ // a prefix that wouldn't make sense in a template context
3068
+ const spanProcessed = processExpression({
3069
+ node: span.expression,
3070
+ context,
3071
+ targetPath: StructuredPath.empty(), // Use empty path to trigger equivalence and type registration
3072
+ });
3073
+
3074
+ allSpansProcessed = allSpansProcessed && spanProcessed;
3075
+ }
3076
+ }
3077
+
3078
+ // Template expressions are always strings
3079
+ context.addType(templatePath, 'string');
3080
+
3081
+ // Register the type with targetPath if provided
3082
+ if (targetPath) {
3083
+ context.addEquivalence(targetPath, templatePath);
3084
+ context.addType(targetPath, 'string');
3085
+ }
3086
+
3087
+ // If we didn't fully handle all spans, still return true but with limitations noted
3088
+ if (!allSpansProcessed && ts.isTemplateExpression(unwrappedNode)) {
3089
+ context.markSemanticLimitation(
3090
+ unwrappedNode,
3091
+ 'Template literal contains complex expressions that may not be fully analyzed',
3092
+ );
3093
+ }
3094
+
3095
+ return true;
3096
+ }
3097
+
3098
+ // Handle TypeOf Expression: typeof x
3099
+ if (ts.isTypeOfExpression(unwrappedNode)) {
3100
+ // Process the inner expression
3101
+ processExpression({ node: unwrappedNode.expression, context });
3102
+
3103
+ // Create a path for the typeof expression
3104
+ const typeofPath = StructuredPath.createLiteralPath(
3105
+ unwrappedNode.getText(context.sourceFile),
3106
+ 'string',
3107
+ );
3108
+
3109
+ // Register the type (always string)
3110
+ if (targetPath) {
3111
+ context.addEquivalence(targetPath, typeofPath);
3112
+ context.addType(targetPath, 'string');
3113
+ }
3114
+
3115
+ return true;
3116
+ }
3117
+
3118
+ // Handle Void Expression: void x, void 0, void func()
3119
+ if (ts.isVoidExpression(unwrappedNode)) {
3120
+ // Process the inner expression for side effects
3121
+ processExpression({ node: unwrappedNode.expression, context });
3122
+
3123
+ // void always returns undefined
3124
+ if (targetPath) {
3125
+ const voidPath = StructuredPath.createLiteralPath(
3126
+ 'undefined',
3127
+ 'undefined',
3128
+ );
3129
+ context.addEquivalence(targetPath, voidPath);
3130
+ context.addType(targetPath, 'undefined');
3131
+ }
3132
+
3133
+ return true;
3134
+ }
3135
+
3136
+ // Handle Prefix Unary Expressions: ++x, --y, !z, -a
3137
+ if (ts.isPrefixUnaryExpression(unwrappedNode)) {
3138
+ // Process the operand
3139
+ const operandProcessed = processExpression({
3140
+ node: unwrappedNode.operand,
3141
+ context,
3142
+ });
3143
+
3144
+ if (!operandProcessed) {
3145
+ context.markUnsupported(
3146
+ unwrappedNode.operand,
3147
+ `processExpression: Could not process operand of PrefixUnaryExpression: ${ts.SyntaxKind[unwrappedNode.operand.kind]}`,
3148
+ false,
3149
+ );
3150
+ return false;
3151
+ }
3152
+
3153
+ // Get a path for the operand
3154
+ const operandPath = StructuredPath.fromNode(
3155
+ unwrappedNode.operand,
3156
+ context.sourceFile,
3157
+ );
3158
+
3159
+ if (!operandPath) {
3160
+ return false;
3161
+ }
3162
+
3163
+ // Determine the result type based on operator
3164
+ const operatorKind = unwrappedNode.operator;
3165
+ let resultType = 'unknown';
3166
+
3167
+ if (
3168
+ operatorKind === ts.SyntaxKind.PlusPlusToken ||
3169
+ operatorKind === ts.SyntaxKind.MinusMinusToken
3170
+ ) {
3171
+ resultType = 'number';
3172
+ } else if (operatorKind === ts.SyntaxKind.ExclamationToken) {
3173
+ resultType = 'boolean | unknown';
3174
+ } else if (
3175
+ operatorKind === ts.SyntaxKind.MinusToken ||
3176
+ operatorKind === ts.SyntaxKind.PlusToken ||
3177
+ operatorKind === ts.SyntaxKind.TildeToken
3178
+ ) {
3179
+ resultType = 'number';
3180
+ } else {
3181
+ context.markUnsupported(
3182
+ unwrappedNode,
3183
+ `processExpression: Unsupported prefix unary operator: ${ts.SyntaxKind[operatorKind]}`,
3184
+ false,
3185
+ );
3186
+ }
3187
+
3188
+ // Register the operand's type (which is also the result)
3189
+ context.addType(operandPath, resultType);
3190
+
3191
+ // If targetPath is provided, establish equivalence and register type
3192
+ if (targetPath) {
3193
+ context.addEquivalence(targetPath, operandPath);
3194
+ context.addType(targetPath, resultType);
3195
+ }
3196
+
3197
+ return true;
3198
+ }
3199
+
3200
+ // Handle Postfix Unary Expressions: x++, y--, etc.
3201
+ if (ts.isPostfixUnaryExpression(unwrappedNode)) {
3202
+ // Process the operand
3203
+ const operandProcessed = processExpression({
3204
+ node: unwrappedNode.operand,
3205
+ context,
3206
+ });
3207
+
3208
+ if (!operandProcessed) {
3209
+ context.markUnsupported(
3210
+ unwrappedNode.operand,
3211
+ `processExpression: Could not process operand of PostfixUnaryExpression: ${ts.SyntaxKind[unwrappedNode.operand.kind]}`,
3212
+ false,
3213
+ );
3214
+ return false;
3215
+ }
3216
+
3217
+ // Get a path for the operand
3218
+ const operandPath = StructuredPath.fromNode(
3219
+ unwrappedNode.operand,
3220
+ context.sourceFile,
3221
+ );
3222
+
3223
+ if (!operandPath) {
3224
+ return false;
3225
+ }
3226
+
3227
+ // Determine the result type based on operator
3228
+ const operatorKind = unwrappedNode.operator;
3229
+ let resultType = 'unknown';
3230
+
3231
+ // Currently postfix expressions only support ++ and -- operators
3232
+ if (
3233
+ operatorKind === ts.SyntaxKind.PlusPlusToken ||
3234
+ operatorKind === ts.SyntaxKind.MinusMinusToken
3235
+ ) {
3236
+ resultType = 'number';
3237
+
3238
+ // Register the operand as a number
3239
+ context.addType(operandPath, resultType);
3240
+
3241
+ // If it's a property access like user.age, add type for parent object
3242
+ if (ts.isPropertyAccessExpression(unwrappedNode.operand)) {
3243
+ const objectPath = StructuredPath.fromNode(
3244
+ unwrappedNode.operand.expression,
3245
+ context.sourceFile,
3246
+ );
3247
+ if (objectPath) {
3248
+ context.addType(objectPath, 'object');
3249
+ }
3250
+ }
3251
+ } else {
3252
+ // Should never reach here (postfix only has ++ and --) but handle just in case
3253
+ context.markUnsupported(
3254
+ unwrappedNode,
3255
+ `processExpression: Unsupported postfix unary operator: ${ts.SyntaxKind[operatorKind]}`,
3256
+ false, // Non-blocking
3257
+ );
3258
+ return false;
3259
+ }
3260
+
3261
+ // If targetPath is provided, establish equivalence and register type
3262
+ if (targetPath) {
3263
+ context.addEquivalence(targetPath, operandPath);
3264
+ context.addType(targetPath, resultType);
3265
+ }
3266
+
3267
+ return true;
3268
+ }
3269
+
3270
+ // Handle JSX Elements (both normal and self-closing)
3271
+ if (
3272
+ ts.isJsxElement(unwrappedNode) ||
3273
+ ts.isJsxSelfClosingElement(unwrappedNode)
3274
+ ) {
3275
+ let openingElement: ts.JsxOpeningElement | ts.JsxSelfClosingElement;
3276
+
3277
+ if (ts.isJsxElement(unwrappedNode)) {
3278
+ openingElement = unwrappedNode.openingElement;
3279
+ } else {
3280
+ openingElement = unwrappedNode;
3281
+ }
3282
+
3283
+ // Extract the component/tag name
3284
+ const tagName = getJsxTagName(openingElement.tagName, context);
3285
+ if (!tagName) {
3286
+ context.markUnsupported(
3287
+ unwrappedNode,
3288
+ 'Unable to determine JSX element name',
3289
+ false,
3290
+ );
3291
+ return false;
3292
+ }
3293
+
3294
+ // Create a path for the component as a function call
3295
+ const componentPath = StructuredPath.fromFunction(tagName);
3296
+
3297
+ // Process each attribute
3298
+ let allAttributesHandled = true;
3299
+ for (const attr of openingElement.attributes.properties) {
3300
+ if (ts.isJsxAttribute(attr)) {
3301
+ // Process JSX attribute with component path as context
3302
+ const attrHandled = processJsxAttribute(
3303
+ attr,
3304
+ context,
3305
+ componentPath,
3306
+ targetPath,
3307
+ );
3308
+ allAttributesHandled = allAttributesHandled && attrHandled;
3309
+ } else if (ts.isJsxSpreadAttribute(attr)) {
3310
+ // Process JSX spread attribute (e.g., <Comp {...props} />)
3311
+ if (attr.expression) {
3312
+ // Process the spread expression
3313
+ const parameterPath = componentPath.withParameter(0);
3314
+ const spreadProcessed = processExpression({
3315
+ node: attr.expression,
3316
+ context,
3317
+ targetPath: parameterPath,
3318
+ });
3319
+ if (!spreadProcessed) {
3320
+ context.markUnsupported(
3321
+ attr.expression,
3322
+ `processExpression: Unsupported spread expression: ${ts.SyntaxKind[attr.expression.kind]}`,
3323
+ false,
3324
+ );
3325
+ }
3326
+
3327
+ allAttributesHandled = allAttributesHandled && spreadProcessed;
3328
+ }
3329
+ }
3330
+ }
3331
+
3332
+ // Process children for JSX elements (not self-closing)
3333
+ if (ts.isJsxElement(unwrappedNode)) {
3334
+ for (const child of unwrappedNode.children) {
3335
+ // Process expressions in JSX children: <div>{expr}</div>
3336
+ if (ts.isJsxExpression(child) && child.expression) {
3337
+ // Process the expression with StructuredPath.empty() as targetPath
3338
+ // to trigger type registration without imposing prefix
3339
+ processExpression({
3340
+ node: child.expression,
3341
+ context,
3342
+ targetPath: StructuredPath.empty(),
3343
+ });
3344
+ }
3345
+ // Process nested JSX elements recursively
3346
+ else if (ts.isJsxElement(child) || ts.isJsxSelfClosingElement(child)) {
3347
+ processExpression({ node: child, context });
3348
+ }
3349
+ }
3350
+ }
3351
+
3352
+ // Register component as 'jsx-component' type to distinguish from regular function calls
3353
+ // This allows downstream code to identify JSX components and not treat them as method chains
3354
+ context.addType(componentPath, 'jsx-component');
3355
+
3356
+ // If targetPath is provided (e.g., in variable assignment), establish equivalence to hardcoded "JSX"
3357
+ if (targetPath) {
3358
+ context.addEquivalence(targetPath, StructuredPath.literal('JSX'));
3359
+ // Don't register a type for targetPath
3360
+ }
3361
+
3362
+ return allAttributesHandled;
3363
+ }
3364
+
3365
+ // Handle JSX Fragments (<>...</>)
3366
+ if (ts.isJsxFragment(unwrappedNode)) {
3367
+ // Process children
3368
+ for (const child of unwrappedNode.children) {
3369
+ // Process expressions in JSX children: <>{expr}</>
3370
+ if (ts.isJsxExpression(child) && child.expression) {
3371
+ // Process the expression to extract structure
3372
+ processExpression({
3373
+ node: child.expression,
3374
+ context,
3375
+ targetPath: StructuredPath.empty(),
3376
+ });
3377
+ }
3378
+ // Process nested JSX elements recursively
3379
+ else if (ts.isJsxElement(child) || ts.isJsxSelfClosingElement(child)) {
3380
+ processExpression({ node: child, context });
3381
+ }
3382
+ // Process nested fragments recursively
3383
+ else if (ts.isJsxFragment(child)) {
3384
+ processExpression({ node: child, context });
3385
+ }
3386
+ // Process JsxText (for completeness)
3387
+ else if (ts.isJsxText(child)) {
3388
+ // JsxText nodes are just string literals, no additional processing needed
3389
+ // But we record them for completeness
3390
+ }
3391
+ }
3392
+
3393
+ // If targetPath is provided, establish equivalence to hardcoded "JSX"
3394
+ if (targetPath) {
3395
+ context.addEquivalence(targetPath, StructuredPath.literal('JSX'));
3396
+ // Don't register a type for targetPath
3397
+ }
3398
+
3399
+ return true;
3400
+ }
3401
+
3402
+ if (
3403
+ ts.isJsxOpeningElement(unwrappedNode) ||
3404
+ ts.isJsxOpeningFragment(unwrappedNode)
3405
+ ) {
3406
+ if (unwrappedNode.parent) {
3407
+ return processExpression({
3408
+ node: unwrappedNode.parent,
3409
+ context,
3410
+ targetPath,
3411
+ });
3412
+ }
3413
+ // Fallback: shouldn't normally happen, but handle gracefully
3414
+ return true;
3415
+ }
3416
+
3417
+ if (
3418
+ ts.isJsxClosingElement(unwrappedNode) ||
3419
+ ts.isJsxClosingFragment(unwrappedNode)
3420
+ ) {
3421
+ // Closing elements/fragments don't carry additional information
3422
+ return true;
3423
+ }
3424
+
3425
+ // Handle standalone JsxExpression (e.g., {expr} in JSX context)
3426
+ if (ts.isJsxExpression(unwrappedNode)) {
3427
+ if (unwrappedNode.expression) {
3428
+ // Process the inner expression
3429
+ return processExpression({
3430
+ node: unwrappedNode.expression,
3431
+ context,
3432
+ targetPath,
3433
+ });
3434
+ }
3435
+ // If there's no expression, we can just return true
3436
+ return true;
3437
+ }
3438
+
3439
+ // Handle JsxText (text content inside JSX elements)
3440
+ if (ts.isJsxText(unwrappedNode)) {
3441
+ // JsxText is just string content in JSX, typically doesn't need
3442
+ // complex analysis, but we mark it as handled
3443
+
3444
+ // If the text is non-whitespace and targetPath is provided,
3445
+ // we could establish a string literal equivalence
3446
+ const text = unwrappedNode.getText(context.sourceFile).trim();
3447
+ if (text && targetPath) {
3448
+ const literalPath = StructuredPath.createLiteralPath(
3449
+ `"${text}"`,
3450
+ 'string',
3451
+ );
3452
+ context.addEquivalence(targetPath, literalPath);
3453
+ context.addType(targetPath, 'string');
3454
+ }
3455
+
3456
+ return true;
3457
+ }
3458
+
3459
+ // Handle Spread Element: ...obj, ...arr
3460
+ if (ts.isSpreadElement(unwrappedNode)) {
3461
+ // Process the expression being spread
3462
+ const spreadExprProcessed = processExpression({
3463
+ node: unwrappedNode.expression,
3464
+ context,
3465
+ });
3466
+
3467
+ if (!spreadExprProcessed) {
3468
+ context.markUnsupported(
3469
+ unwrappedNode.expression,
3470
+ `processExpression: Unsupported expression in spread element: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
3471
+ false,
3472
+ );
3473
+ return false;
3474
+ }
3475
+
3476
+ // Get a path for the spread expression
3477
+ const spreadExprPath = StructuredPath.fromNode(
3478
+ unwrappedNode.expression,
3479
+ context.sourceFile,
3480
+ );
3481
+
3482
+ if (!spreadExprPath) {
3483
+ context.markUnsupported(
3484
+ unwrappedNode.expression,
3485
+ `processExpression: Couldn't get path for spread element expression`,
3486
+ false,
3487
+ );
3488
+ return false;
3489
+ }
3490
+
3491
+ // Create a path for the spread element itself
3492
+ const spreadPath = StructuredPath.fromBase(
3493
+ `...${unwrappedNode.expression.getText(context.sourceFile)}`,
3494
+ );
3495
+
3496
+ // If targetPath is provided, establish equivalence
3497
+ if (targetPath) {
3498
+ context.addEquivalence(targetPath, spreadPath);
3499
+
3500
+ // We don't know the exact type of the spread result as it depends on context
3501
+ // (object spread vs array spread), so we use the same type as the expression
3502
+ const spreadType = context.getTypeInfo(spreadExprPath) || 'unknown';
3503
+ context.addType(targetPath, spreadType);
3504
+ }
3505
+
3506
+ return true;
3507
+ }
3508
+ if (ts.isDeleteExpression(unwrappedNode)) {
3509
+ // first just process whatever is being deleted
3510
+ const result = processExpression({
3511
+ node: unwrappedNode.expression,
3512
+ context,
3513
+ });
3514
+ if (!result) {
3515
+ context.markUnsupported(
3516
+ unwrappedNode.expression,
3517
+ `processExpression: Unsupported expression in delete: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
3518
+ false,
3519
+ );
3520
+ return false;
3521
+ }
3522
+
3523
+ nodePath = StructuredPath.fromNode(unwrappedNode, context.sourceFile);
3524
+ // 'delete' is boolean typed
3525
+ context.addType(nodePath, 'boolean');
3526
+
3527
+ if (targetPath) {
3528
+ context.addEquivalence(targetPath, nodePath);
3529
+ context.addType(targetPath, 'boolean');
3530
+ }
3531
+ return result;
3532
+ }
3533
+
3534
+ // Handle yield expressions in generator functions
3535
+ if (ts.isYieldExpression(unwrappedNode)) {
3536
+ // yield returns whatever is yielded, or undefined if no expression
3537
+ if (unwrappedNode.expression) {
3538
+ // Process the yielded expression
3539
+ const result = processExpression({
3540
+ node: unwrappedNode.expression,
3541
+ context,
3542
+ targetPath,
3543
+ });
3544
+ return result;
3545
+ }
3546
+ // yield with no expression returns undefined
3547
+ if (targetPath) {
3548
+ context.addType(targetPath, 'undefined');
3549
+ }
3550
+ return true;
3551
+ }
3552
+
3553
+ if (ts.isRegularExpressionLiteral(unwrappedNode)) {
3554
+ // Regular expressions are treated as string literals
3555
+ const regexPath = StructuredPath.createLiteralPath(
3556
+ unwrappedNode.getText(context.sourceFile),
3557
+ 'string',
3558
+ );
3559
+ context.addType(regexPath, 'string');
3560
+
3561
+ // If targetPath is provided, establish equivalence
3562
+ if (targetPath) {
3563
+ context.addEquivalence(targetPath, regexPath);
3564
+ context.addType(targetPath, 'string');
3565
+ }
3566
+
3567
+ return true;
3568
+ }
3569
+
3570
+ console.warn(
3571
+ `processExpression: Unsupported expression kind: ${ts.SyntaxKind[unwrappedNode.kind]}`,
3572
+ {
3573
+ nodeText: node.getText(context.sourceFile),
3574
+ statementName: context.statementInfo.name,
3575
+ statementText: context.statementInfo.text,
3576
+ },
3577
+ );
3578
+
3579
+ // For now, mark other types as unsupported and return false
3580
+ context.markUnsupported(
3581
+ unwrappedNode,
3582
+ `processExpression: Unsupported expression kind: ${ts.SyntaxKind[unwrappedNode.kind]}`,
3583
+ false, // Non-blocking for now
3584
+ );
3585
+ return false;
3586
+ }
3587
+
3588
+ /**
3589
+ * Helper function to process a JSX attribute
3590
+ */
3591
+ function processJsxAttribute(
3592
+ attr: ts.JsxAttribute,
3593
+ context: AnalysisContext,
3594
+ componentPath: StructuredPath,
3595
+ targetPath?: StructuredPath,
3596
+ ): boolean {
3597
+ // JSX attribute names can be either simple identifiers or namespace names
3598
+ const attrName = ts.isIdentifier(attr.name)
3599
+ ? attr.name.text
3600
+ : attr.name.name.text;
3601
+
3602
+ // Skip attributes with no initializer (boolean props)
3603
+ if (!attr.initializer) {
3604
+ return true;
3605
+ }
3606
+
3607
+ // Create path for this attribute: Component.signature[0].attributeName
3608
+ const attributePath = componentPath.withParameter(0).withProperty(attrName);
3609
+
3610
+ // For string literals: <Component attr="value" />
3611
+ if (ts.isStringLiteral(attr.initializer)) {
3612
+ const literalPath = StructuredPath.createLiteralPath(
3613
+ `"${attr.initializer.text}"`,
3614
+ 'string',
3615
+ );
3616
+ context.addEquivalence(attributePath, literalPath);
3617
+ context.addType(attributePath, 'string');
3618
+ return true;
3619
+ }
3620
+
3621
+ // For expressions: <Component attr={value} />
3622
+ if (ts.isJsxExpression(attr.initializer) && attr.initializer.expression) {
3623
+ const expression = attr.initializer.expression;
3624
+ if (context.isChildBoundary(expression)) {
3625
+ // Create equivalency between attribute path and child scope
3626
+ // e.g., Grid().signature[0].renderRow → cyScope1()
3627
+ context.addChildBoundaryEquivalence(attributePath, expression);
3628
+ return true;
3629
+ }
3630
+
3631
+ // Process the expression with attributePath as targetPath
3632
+ // This will establish all equivalences and types automatically
3633
+ return processExpression({
3634
+ node: expression,
3635
+ context,
3636
+ targetPath: attributePath,
3637
+ });
3638
+ }
3639
+
3640
+ // Mark as unsupported if we couldn't handle the attribute
3641
+ context.markUnsupported(
3642
+ attr,
3643
+ `Unsupported JSX attribute initializer: ${attr.initializer?.kind ? ts.SyntaxKind[attr.initializer.kind] : 'undefined'}`,
3644
+ false,
3645
+ );
3646
+ return false;
3647
+ }
3648
+
3649
+ /**
3650
+ * Helper function to get a string representation of a JSX tag name
3651
+ */
3652
+ function getJsxTagName(
3653
+ tagNameNode: ts.JsxTagNameExpression,
3654
+ context: AnalysisContext,
3655
+ ): string {
3656
+ if (ts.isIdentifier(tagNameNode)) {
3657
+ return tagNameNode.text;
3658
+ } else if (ts.isPropertyAccessExpression(tagNameNode)) {
3659
+ const objName = getJsxTagName(tagNameNode.expression, context);
3660
+ return objName ? `${objName}.${tagNameNode.name.text}` : '';
3661
+ } else if ((tagNameNode as any).namespace) {
3662
+ // Handle namespaced names like <ns:elem />
3663
+ const jsxNamespacedName = tagNameNode as any;
3664
+ return `${jsxNamespacedName.namespace.text}:${jsxNamespacedName.name.text}`;
3665
+ }
3666
+
3667
+ return '';
3668
+ }