@codeyam/codeyam-cli 0.0.0 → 0.1.0-staging.032c089

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 (3914) 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 +118 -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 +804 -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 +1123 -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 +3769 -0
  50. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +155 -0
  51. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +643 -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 +682 -0
  59. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +6700 -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/coercePrimitivesToArraysBySchema.ts +62 -0
  80. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +415 -0
  81. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
  82. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  83. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +153 -0
  84. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/determineIsFunctionCall.ts +16 -0
  85. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ensureSchemaConsistency.ts +83 -0
  86. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +1065 -0
  87. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  88. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.ts +41 -0
  89. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallScopeNodeName.ts +15 -0
  90. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallSignature.ts +17 -0
  91. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/isGenericArray.ts +83 -0
  92. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/knownMethodCalls.ts +138 -0
  93. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/selectBestValue.ts +70 -0
  94. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  95. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/uniqueIdUtils.ts +113 -0
  96. package/analyzer-template/packages/ai/src/lib/dataStructure/typeUtils.ts +161 -0
  97. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -0
  98. package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
  99. package/analyzer-template/packages/ai/src/lib/describeCodeChange.ts +56 -0
  100. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  101. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  102. package/analyzer-template/packages/ai/src/lib/extractOverlappingMocks.ts +63 -0
  103. package/analyzer-template/packages/ai/src/lib/generateBranchSummary.ts +55 -0
  104. package/analyzer-template/packages/ai/src/lib/generateChangesEntityDocumentation.ts +82 -0
  105. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +488 -0
  106. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +386 -0
  107. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +153 -0
  108. package/analyzer-template/packages/ai/src/lib/generateEntityDocumentation.ts +84 -0
  109. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1783 -0
  110. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +447 -0
  111. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +677 -0
  112. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  113. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  114. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  115. package/analyzer-template/packages/ai/src/lib/generateStatementAnalysis.ts +1789 -0
  116. package/analyzer-template/packages/ai/src/lib/getCodeExplanation.ts +52 -0
  117. package/analyzer-template/packages/ai/src/lib/getConditionalUsagesFromCode.ts +442 -0
  118. package/analyzer-template/packages/ai/src/lib/getLLMCallCost.ts +26 -0
  119. package/analyzer-template/packages/ai/src/lib/getLLMCallStats.ts +40 -0
  120. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +125 -0
  121. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromName.ts +87 -0
  122. package/analyzer-template/packages/ai/src/lib/identifyReserved.ts +734 -0
  123. package/analyzer-template/packages/ai/src/lib/index.ts +26 -0
  124. package/analyzer-template/packages/ai/src/lib/instantiatedInScope.ts +212 -0
  125. package/analyzer-template/packages/ai/src/lib/isFrontend.ts +4 -0
  126. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +1219 -0
  127. package/analyzer-template/packages/ai/src/lib/isolateStatements.ts +1072 -0
  128. package/analyzer-template/packages/ai/src/lib/jsonTypeDefinitionToStandardTypeDefinition.ts +48 -0
  129. package/analyzer-template/packages/ai/src/lib/logOrderedMap.ts +49 -0
  130. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +58 -0
  131. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +289 -0
  132. package/analyzer-template/packages/ai/src/lib/modelInfo.ts +249 -0
  133. package/analyzer-template/packages/ai/src/lib/openai/index.ts +100 -0
  134. package/analyzer-template/packages/ai/src/lib/parsers/fileContentToLines.ts +12 -0
  135. package/analyzer-template/packages/ai/src/lib/parsers/parseJsonSafe.ts +45 -0
  136. package/analyzer-template/packages/ai/src/lib/promptGenerators/branchSummaryGenerator.ts +13 -0
  137. package/analyzer-template/packages/ai/src/lib/promptGenerators/codeQualityEntityAnalysisGenerator.ts +53 -0
  138. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  139. package/analyzer-template/packages/ai/src/lib/promptGenerators/commitMessageGenerator.ts +37 -0
  140. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +300 -0
  141. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityDocumentationGenerator.ts +22 -0
  142. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +120 -0
  143. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +106 -0
  144. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  145. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  146. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityDataMapGenerator.ts +20 -0
  147. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityDataStructureGenerator.ts +18 -0
  148. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityDocumentationGenerator.ts +16 -0
  149. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityPropsStructureGenerator.ts +24 -0
  150. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +159 -0
  151. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +30 -0
  152. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  153. package/analyzer-template/packages/ai/src/lib/promptGenerators/getComponentExamplesGenerator.ts +20 -0
  154. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessEditScenarioDataFromDescriptionGenerator.ts +56 -0
  155. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +50 -0
  156. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessScenarioDataFromNameGenerator.ts +41 -0
  157. package/analyzer-template/packages/ai/src/lib/promptGenerators/index.ts +10 -0
  158. package/analyzer-template/packages/ai/src/lib/promptGenerators/noErrorAttributes.ts +19 -0
  159. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  160. package/analyzer-template/packages/ai/src/lib/promptGenerators/summarizeDiffGenerator.ts +10 -0
  161. package/analyzer-template/packages/ai/src/lib/providers.ts +47 -0
  162. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  163. package/analyzer-template/packages/ai/src/lib/services/aiServiceMode.ts +166 -0
  164. package/analyzer-template/packages/ai/src/lib/services/claudeCliAIService.ts +283 -0
  165. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +337 -0
  166. package/analyzer-template/packages/ai/src/lib/summarizeDiff.ts +25 -0
  167. package/analyzer-template/packages/ai/src/lib/types/index.ts +96 -0
  168. package/analyzer-template/packages/ai/src/lib/validateDataStructure.ts +434 -0
  169. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  170. package/analyzer-template/packages/ai/src/lib/validateJson.ts +65 -0
  171. package/analyzer-template/packages/ai/src/lib/validatePlaywrightInstructions.ts +225 -0
  172. package/analyzer-template/packages/ai/src/lib/validateTypeStructure.ts +93 -0
  173. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +353 -0
  174. package/analyzer-template/packages/ai/src/lib/worker/__mocks__/analyzeScopeWorkerPaths.ts +5 -0
  175. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +218 -0
  176. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorkerPaths.ts +26 -0
  177. package/analyzer-template/packages/ai/src/lib/worker/fuzzyMatchFunctionName.ts +77 -0
  178. package/analyzer-template/packages/ai/src/lib/wrapperDetection/detectWrapperRequirements.ts +134 -0
  179. package/analyzer-template/packages/ai/src/lib/wrapperDetection/index.ts +9 -0
  180. package/analyzer-template/packages/ai/src/lib/wrapperDetection/knownLibraryHooks.ts +95 -0
  181. package/analyzer-template/packages/ai/src/lib/wrapperDetection/patterns/detectThrowOnMissingPatterns.ts +189 -0
  182. package/analyzer-template/packages/ai/src/lib/wrapperDetection/patterns/detectUseContextCalls.ts +127 -0
  183. package/analyzer-template/packages/ai/tsconfig.json +10 -0
  184. package/analyzer-template/packages/analyze/README.md +131 -0
  185. package/analyzer-template/packages/analyze/TODOS.md +46 -0
  186. package/analyzer-template/packages/analyze/index.ts +113 -0
  187. package/analyzer-template/packages/analyze/package.json +13 -0
  188. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +1135 -0
  189. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +423 -0
  190. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +348 -0
  191. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +246 -0
  192. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getCallExpressionNames.ts +37 -0
  193. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getFunctionNodeType.ts +25 -0
  194. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +131 -0
  195. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getReactComponentType.ts +39 -0
  196. package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +184 -0
  197. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
  198. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isDefaultExport.ts +76 -0
  199. package/analyzer-template/packages/analyze/src/lib/asts/nodes/propsNodeToPropsData.ts +540 -0
  200. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +257 -0
  201. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntities.ts +6 -0
  202. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +255 -0
  203. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.ts +133 -0
  204. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +254 -0
  205. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getComponentProps.ts +33 -0
  206. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getComponentType.ts +41 -0
  207. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getDeclaredEntityNode.ts +25 -0
  208. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getDefaultExportedFunctionNode.ts +53 -0
  209. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getEntityNode.ts +26 -0
  210. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportMappings.ts +40 -0
  211. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +135 -0
  212. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getPropsFromFunctionalComponent.ts +96 -0
  213. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getPseudoFile.ts +40 -0
  214. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedImportedTypes.ts +84 -0
  215. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +166 -0
  216. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFile.ts +13 -0
  217. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +26 -0
  218. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForImports.ts +21 -0
  219. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/index.ts +56 -0
  220. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/extractClassMethods.ts +139 -0
  221. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +1023 -0
  222. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncComplex.ts +165 -0
  223. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncSimple.ts +30 -0
  224. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/index.ts +23 -0
  225. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/sequential.ts +16 -0
  226. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/types.ts +20 -0
  227. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +603 -0
  228. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +120 -0
  229. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +279 -0
  230. package/analyzer-template/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.ts +31 -0
  231. package/analyzer-template/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.ts +25 -0
  232. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +141 -0
  233. package/analyzer-template/packages/analyze/src/lib/files/analyze/generateAnalysisTreeSha.ts +160 -0
  234. package/analyzer-template/packages/analyze/src/lib/files/analyze/generateAnalyzedTreeSha.ts +10 -0
  235. package/analyzer-template/packages/analyze/src/lib/files/analyze/guessDefaultWidth.ts +18 -0
  236. package/analyzer-template/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.ts +127 -0
  237. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +122 -0
  238. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +160 -0
  239. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +236 -0
  240. package/analyzer-template/packages/analyze/src/lib/files/analyzeCodeChange.ts +70 -0
  241. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +552 -0
  242. package/analyzer-template/packages/analyze/src/lib/files/analyzeFrameworkRoute.ts +19 -0
  243. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +195 -0
  244. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +112 -0
  245. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +140 -0
  246. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +16 -0
  247. package/analyzer-template/packages/analyze/src/lib/files/extractDiffLines.ts +21 -0
  248. package/analyzer-template/packages/analyze/src/lib/files/fileAnalyzerFromCode.ts +57 -0
  249. package/analyzer-template/packages/analyze/src/lib/files/findScenarioData.ts +43 -0
  250. package/analyzer-template/packages/analyze/src/lib/files/getEntityCode.ts +26 -0
  251. package/analyzer-template/packages/analyze/src/lib/files/getEntityType.ts +29 -0
  252. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +266 -0
  253. package/analyzer-template/packages/analyze/src/lib/files/getNodeModuleImports.ts +37 -0
  254. package/analyzer-template/packages/analyze/src/lib/files/newAnalysis.ts +43 -0
  255. package/analyzer-template/packages/analyze/src/lib/files/recordStep.ts +35 -0
  256. package/analyzer-template/packages/analyze/src/lib/files/relevantDiffPart.ts +74 -0
  257. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  258. package/analyzer-template/packages/analyze/src/lib/files/scenarios/detectChangedDataStructureFields.ts +102 -0
  259. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +313 -0
  260. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
  261. package/analyzer-template/packages/analyze/src/lib/files/scenarios/findImportedEntity.ts +36 -0
  262. package/analyzer-template/packages/analyze/src/lib/files/scenarios/findRelevantExportInfo.ts +52 -0
  263. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +936 -0
  264. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.ts +176 -0
  265. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +232 -0
  266. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +909 -0
  267. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +166 -0
  268. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +234 -0
  269. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +134 -0
  270. package/analyzer-template/packages/analyze/src/lib/files/scenarios/isolateDataStructure.ts +71 -0
  271. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1889 -0
  272. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +244 -0
  273. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  274. package/analyzer-template/packages/analyze/src/lib/files/scenarios/reproduceImports.ts +60 -0
  275. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +313 -0
  276. package/analyzer-template/packages/analyze/src/lib/index.ts +7 -0
  277. package/analyzer-template/packages/analyze/src/lib/projects/index.ts +48 -0
  278. package/analyzer-template/packages/analyze/src/lib/types/index.ts +17 -0
  279. package/analyzer-template/packages/analyze/src/lib/utils/deepEqual.ts +30 -0
  280. package/analyzer-template/packages/analyze/src/lib/utils/getAnalysisError.ts +13 -0
  281. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  282. package/analyzer-template/packages/analyze/src/lib/utils/measureAndReportExecutionTime.ts +22 -0
  283. package/analyzer-template/packages/analyze/src/lib/utils/measureExecutionTime.ts +16 -0
  284. package/analyzer-template/packages/analyze/tsconfig.json +10 -0
  285. package/analyzer-template/packages/aws/cloudwatch/index.ts +6 -0
  286. package/analyzer-template/packages/aws/codebuild/index.ts +7 -0
  287. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.d.ts +10 -0
  288. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.d.ts.map +1 -0
  289. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.js +31 -0
  290. package/analyzer-template/packages/aws/dist/src/lib/cloudwatch/getTaskLogs.js.map +1 -0
  291. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.d.ts +2 -0
  292. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.d.ts.map +1 -0
  293. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.js +32 -0
  294. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuild.js.map +1 -0
  295. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.d.ts +2 -0
  296. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.d.ts.map +1 -0
  297. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.js +28 -0
  298. package/analyzer-template/packages/aws/dist/src/lib/codebuild/checkForCodeBuildProject.js.map +1 -0
  299. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.d.ts +2 -0
  300. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.d.ts.map +1 -0
  301. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.js +40 -0
  302. package/analyzer-template/packages/aws/dist/src/lib/codebuild/createCodeBuildProject.js.map +1 -0
  303. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.d.ts +14 -0
  304. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.d.ts.map +1 -0
  305. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.js +29 -0
  306. package/analyzer-template/packages/aws/dist/src/lib/codebuild/triggerCodeBuild.js.map +1 -0
  307. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +12 -0
  308. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -0
  309. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +61 -0
  310. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -0
  311. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.d.ts +3 -0
  312. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.d.ts.map +1 -0
  313. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.js +26 -0
  314. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCall.js.map +1 -0
  315. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.d.ts +3 -0
  316. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.d.ts.map +1 -0
  317. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.js +35 -0
  318. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/loadLlmCalls.js.map +1 -0
  319. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.d.ts +2 -0
  320. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.d.ts.map +1 -0
  321. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.js +66 -0
  322. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/provisionTable.js.map +1 -0
  323. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.d.ts +25 -0
  324. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.d.ts.map +1 -0
  325. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.js +67 -0
  326. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/saveLlmCall.js.map +1 -0
  327. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.d.ts +2 -0
  328. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.d.ts.map +1 -0
  329. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.js +6 -0
  330. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/tableNames.js.map +1 -0
  331. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.d.ts +25 -0
  332. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.d.ts.map +1 -0
  333. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.js +2 -0
  334. package/analyzer-template/packages/aws/dist/src/lib/dynamodb/types.js.map +1 -0
  335. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.d.ts +9 -0
  336. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.d.ts.map +1 -0
  337. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.js +36 -0
  338. package/analyzer-template/packages/aws/dist/src/lib/ecr/checkForECRImage.js.map +1 -0
  339. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.d.ts +2 -0
  340. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.d.ts.map +1 -0
  341. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.js +49 -0
  342. package/analyzer-template/packages/aws/dist/src/lib/ecr/createECRRepository.js.map +1 -0
  343. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.d.ts +2 -0
  344. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.d.ts.map +1 -0
  345. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.js +36 -0
  346. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCheckTaskStatus.js.map +1 -0
  347. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.d.ts +11 -0
  348. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.d.ts.map +1 -0
  349. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.js +138 -0
  350. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsCreateTaskDefinition.js.map +1 -0
  351. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +11 -0
  352. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -0
  353. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +30 -0
  354. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -0
  355. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.d.ts +3 -0
  356. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.d.ts.map +1 -0
  357. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.js +51 -0
  358. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsStartTask.js.map +1 -0
  359. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +24 -0
  360. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -0
  361. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +43 -0
  362. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -0
  363. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts +15 -0
  364. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts.map +1 -0
  365. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js +31 -0
  366. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js.map +1 -0
  367. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.d.ts +23 -0
  368. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.d.ts.map +1 -0
  369. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.js +30 -0
  370. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.js.map +1 -0
  371. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts +9 -0
  372. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -0
  373. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +31 -0
  374. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -0
  375. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.d.ts +7 -0
  376. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.d.ts.map +1 -0
  377. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.js +15 -0
  378. package/analyzer-template/packages/aws/dist/src/lib/sqs/getSqsQueueSizeStats.js.map +1 -0
  379. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.d.ts +5 -0
  380. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.d.ts.map +1 -0
  381. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.js +9 -0
  382. package/analyzer-template/packages/aws/dist/src/lib/sqs/sendSqsMessage.js.map +1 -0
  383. package/analyzer-template/packages/aws/dist/types.d.ts +8 -0
  384. package/analyzer-template/packages/aws/dist/types.d.ts.map +1 -0
  385. package/analyzer-template/packages/aws/dist/types.js +2 -0
  386. package/analyzer-template/packages/aws/dist/types.js.map +1 -0
  387. package/analyzer-template/packages/aws/dynamodb/index.ts +10 -0
  388. package/analyzer-template/packages/aws/ecr/index.ts +4 -0
  389. package/analyzer-template/packages/aws/ecs/index.ts +6 -0
  390. package/analyzer-template/packages/aws/package.json +25 -0
  391. package/analyzer-template/packages/aws/s3/index.ts +7 -0
  392. package/analyzer-template/packages/aws/sqs/index.ts +3 -0
  393. package/analyzer-template/packages/aws/src/lib/cloudwatch/getTaskLogs.ts +50 -0
  394. package/analyzer-template/packages/aws/src/lib/codebuild/checkForCodeBuild.ts +43 -0
  395. package/analyzer-template/packages/aws/src/lib/codebuild/checkForCodeBuildProject.ts +30 -0
  396. package/analyzer-template/packages/aws/src/lib/codebuild/createCodeBuildProject.ts +51 -0
  397. package/analyzer-template/packages/aws/src/lib/codebuild/triggerCodeBuild.ts +52 -0
  398. package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +87 -0
  399. package/analyzer-template/packages/aws/src/lib/dynamodb/loadLlmCall.ts +31 -0
  400. package/analyzer-template/packages/aws/src/lib/dynamodb/loadLlmCalls.ts +44 -0
  401. package/analyzer-template/packages/aws/src/lib/dynamodb/provisionTable.ts +81 -0
  402. package/analyzer-template/packages/aws/src/lib/dynamodb/saveLlmCall.ts +118 -0
  403. package/analyzer-template/packages/aws/src/lib/dynamodb/tableNames.ts +5 -0
  404. package/analyzer-template/packages/aws/src/lib/dynamodb/types.ts +26 -0
  405. package/analyzer-template/packages/aws/src/lib/ecr/checkForECRImage.ts +55 -0
  406. package/analyzer-template/packages/aws/src/lib/ecr/createECRRepository.ts +63 -0
  407. package/analyzer-template/packages/aws/src/lib/ecs/ecsCheckTaskStatus.ts +43 -0
  408. package/analyzer-template/packages/aws/src/lib/ecs/ecsCreateTaskDefinition.ts +225 -0
  409. package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +43 -0
  410. package/analyzer-template/packages/aws/src/lib/ecs/ecsStartTask.ts +72 -0
  411. package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +57 -0
  412. package/analyzer-template/packages/aws/src/lib/s3/checkS3ObjectExists.ts +47 -0
  413. package/analyzer-template/packages/aws/src/lib/s3/getPresignedUrl.ts +62 -0
  414. package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +43 -0
  415. package/analyzer-template/packages/aws/src/lib/sqs/getSqsQueueSizeStats.ts +28 -0
  416. package/analyzer-template/packages/aws/src/lib/sqs/sendSqsMessage.ts +17 -0
  417. package/analyzer-template/packages/aws/tsconfig.json +11 -0
  418. package/analyzer-template/packages/aws/types.ts +11 -0
  419. package/analyzer-template/packages/database/__mocks__/index.ts +10 -0
  420. package/analyzer-template/packages/database/client.ts +35 -0
  421. package/analyzer-template/packages/database/index.ts +94 -0
  422. package/analyzer-template/packages/database/package.json +31 -0
  423. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +28 -0
  424. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +59 -0
  425. package/analyzer-template/packages/database/src/lib/backgroundJobToDb.ts +21 -0
  426. package/analyzer-template/packages/database/src/lib/branchToDb.ts +24 -0
  427. package/analyzer-template/packages/database/src/lib/client/listenForCommits_Client.ts +30 -0
  428. package/analyzer-template/packages/database/src/lib/client/loadAnalysesInClient.ts +146 -0
  429. package/analyzer-template/packages/database/src/lib/client/loadAnalysis_Client.ts +134 -0
  430. package/analyzer-template/packages/database/src/lib/client/loadBranches_Client.ts +45 -0
  431. package/analyzer-template/packages/database/src/lib/client/loadCommit_Client.ts +79 -0
  432. package/analyzer-template/packages/database/src/lib/client/upsertFiles_Client.ts +50 -0
  433. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +20 -0
  434. package/analyzer-template/packages/database/src/lib/commitToDb.ts +47 -0
  435. package/analyzer-template/packages/database/src/lib/createOrUpdateBranchCommitStats.ts +182 -0
  436. package/analyzer-template/packages/database/src/lib/createProject.ts +34 -0
  437. package/analyzer-template/packages/database/src/lib/createRetryFetch.ts +45 -0
  438. package/analyzer-template/packages/database/src/lib/dbToAnalysis.ts +76 -0
  439. package/analyzer-template/packages/database/src/lib/dbToAnalysisBranch.ts +28 -0
  440. package/analyzer-template/packages/database/src/lib/dbToBackgroundJob.ts +25 -0
  441. package/analyzer-template/packages/database/src/lib/dbToBranch.ts +39 -0
  442. package/analyzer-template/packages/database/src/lib/dbToCommit.ts +65 -0
  443. package/analyzer-template/packages/database/src/lib/dbToCommitBranch.ts +22 -0
  444. package/analyzer-template/packages/database/src/lib/dbToEntity.ts +42 -0
  445. package/analyzer-template/packages/database/src/lib/dbToEntityBranch.ts +17 -0
  446. package/analyzer-template/packages/database/src/lib/dbToFile.ts +16 -0
  447. package/analyzer-template/packages/database/src/lib/dbToProject.ts +30 -0
  448. package/analyzer-template/packages/database/src/lib/dbToScenario.ts +39 -0
  449. package/analyzer-template/packages/database/src/lib/dbToScenarioComment.ts +36 -0
  450. package/analyzer-template/packages/database/src/lib/dbToUserScenario.ts +32 -0
  451. package/analyzer-template/packages/database/src/lib/deleteBranch.ts +28 -0
  452. package/analyzer-template/packages/database/src/lib/deleteEntities.ts +32 -0
  453. package/analyzer-template/packages/database/src/lib/deleteFile.ts +19 -0
  454. package/analyzer-template/packages/database/src/lib/deleteScenarios.ts +41 -0
  455. package/analyzer-template/packages/database/src/lib/entityToDb.ts +83 -0
  456. package/analyzer-template/packages/database/src/lib/fileToDb.ts +17 -0
  457. package/analyzer-template/packages/database/src/lib/generateSha.ts +14 -0
  458. package/analyzer-template/packages/database/src/lib/jsonUpdateUtils.ts +43 -0
  459. package/analyzer-template/packages/database/src/lib/kysely/aggregationHelpers.ts +107 -0
  460. package/analyzer-template/packages/database/src/lib/kysely/db.ts +503 -0
  461. package/analyzer-template/packages/database/src/lib/kysely/schemaHelpers.ts +18 -0
  462. package/analyzer-template/packages/database/src/lib/kysely/sqliteBooleanPlugin.ts +46 -0
  463. package/analyzer-template/packages/database/src/lib/kysely/tableRelations.ts +108 -0
  464. package/analyzer-template/packages/database/src/lib/kysely/tableRelationsTypes.ts +26 -0
  465. package/analyzer-template/packages/database/src/lib/kysely/tables/analysesTable.ts +69 -0
  466. package/analyzer-template/packages/database/src/lib/kysely/tables/analysisBranchesTable.ts +46 -0
  467. package/analyzer-template/packages/database/src/lib/kysely/tables/backgroundJobsTable.ts +47 -0
  468. package/analyzer-template/packages/database/src/lib/kysely/tables/branchesTable.ts +49 -0
  469. package/analyzer-template/packages/database/src/lib/kysely/tables/commitBranchesTable.ts +36 -0
  470. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +67 -0
  471. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +88 -0
  472. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +93 -0
  473. package/analyzer-template/packages/database/src/lib/kysely/tables/entitiesTable.ts +55 -0
  474. package/analyzer-template/packages/database/src/lib/kysely/tables/entityBranchesTable.ts +42 -0
  475. package/analyzer-template/packages/database/src/lib/kysely/tables/entityStatementsTable.ts +44 -0
  476. package/analyzer-template/packages/database/src/lib/kysely/tables/filesTable.ts +47 -0
  477. package/analyzer-template/packages/database/src/lib/kysely/tables/githubPayloadsTable.ts +48 -0
  478. package/analyzer-template/packages/database/src/lib/kysely/tables/githubUsersTable.ts +36 -0
  479. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  480. package/analyzer-template/packages/database/src/lib/kysely/tables/projectsTable.ts +51 -0
  481. package/analyzer-template/packages/database/src/lib/kysely/tables/scenarioCommentsTable.ts +44 -0
  482. package/analyzer-template/packages/database/src/lib/kysely/tables/scenariosTable.ts +43 -0
  483. package/analyzer-template/packages/database/src/lib/kysely/tables/statementsTable.ts +38 -0
  484. package/analyzer-template/packages/database/src/lib/kysely/tables/teamsTable.ts +34 -0
  485. package/analyzer-template/packages/database/src/lib/kysely/tables/userScenariosTable.ts +44 -0
  486. package/analyzer-template/packages/database/src/lib/kysely/tables/userTeamsTable.ts +32 -0
  487. package/analyzer-template/packages/database/src/lib/kysely/tables/usersTable.ts +42 -0
  488. package/analyzer-template/packages/database/src/lib/kysely/upsertHelpers.ts +24 -0
  489. package/analyzer-template/packages/database/src/lib/kysely.ts +1 -0
  490. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +275 -0
  491. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +223 -0
  492. package/analyzer-template/packages/database/src/lib/loadAnalysisBranches.ts +238 -0
  493. package/analyzer-template/packages/database/src/lib/loadBackgroundJob.ts +23 -0
  494. package/analyzer-template/packages/database/src/lib/loadBranch.ts +137 -0
  495. package/analyzer-template/packages/database/src/lib/loadBranches.ts +52 -0
  496. package/analyzer-template/packages/database/src/lib/loadCommit.ts +173 -0
  497. package/analyzer-template/packages/database/src/lib/loadCommitBranches.ts +78 -0
  498. package/analyzer-template/packages/database/src/lib/loadCommitMetadata.ts +34 -0
  499. package/analyzer-template/packages/database/src/lib/loadCommits.ts +290 -0
  500. package/analyzer-template/packages/database/src/lib/loadEntities.ts +111 -0
  501. package/analyzer-template/packages/database/src/lib/loadEntity.ts +105 -0
  502. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +178 -0
  503. package/analyzer-template/packages/database/src/lib/loadFile.ts +42 -0
  504. package/analyzer-template/packages/database/src/lib/loadFiles.ts +134 -0
  505. package/analyzer-template/packages/database/src/lib/loadMostRecentPreviousAnalysis.ts +132 -0
  506. package/analyzer-template/packages/database/src/lib/loadProject.ts +70 -0
  507. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +96 -0
  508. package/analyzer-template/packages/database/src/lib/loadScenario.ts +38 -0
  509. package/analyzer-template/packages/database/src/lib/loadStatement.ts +23 -0
  510. package/analyzer-template/packages/database/src/lib/nullsToUndefines.ts +8 -0
  511. package/analyzer-template/packages/database/src/lib/projectToDb.ts +35 -0
  512. package/analyzer-template/packages/database/src/lib/saveBackgroundEvent.ts +19 -0
  513. package/analyzer-template/packages/database/src/lib/saveEntityStatements.ts +27 -0
  514. package/analyzer-template/packages/database/src/lib/saveFiles.ts +43 -0
  515. package/analyzer-template/packages/database/src/lib/saveStatement.ts +24 -0
  516. package/analyzer-template/packages/database/src/lib/scenarioCommentToDb.ts +35 -0
  517. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +35 -0
  518. package/analyzer-template/packages/database/src/lib/supabase.ts +85 -0
  519. package/analyzer-template/packages/database/src/lib/updateBackgroundJobProgress.ts +90 -0
  520. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +131 -0
  521. package/analyzer-template/packages/database/src/lib/updateEntityBranch.ts +29 -0
  522. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisMetadata.ts +63 -0
  523. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +80 -0
  524. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +110 -0
  525. package/analyzer-template/packages/database/src/lib/updateProjectMetadata.ts +95 -0
  526. package/analyzer-template/packages/database/src/lib/upsertAnalyses.ts +58 -0
  527. package/analyzer-template/packages/database/src/lib/upsertAnalysesWithScenarios.ts +94 -0
  528. package/analyzer-template/packages/database/src/lib/upsertAnalysisBranches.ts +96 -0
  529. package/analyzer-template/packages/database/src/lib/upsertBackgroundJob.ts +33 -0
  530. package/analyzer-template/packages/database/src/lib/upsertBranches.ts +32 -0
  531. package/analyzer-template/packages/database/src/lib/upsertCommitBranches.ts +36 -0
  532. package/analyzer-template/packages/database/src/lib/upsertCommits.ts +57 -0
  533. package/analyzer-template/packages/database/src/lib/upsertEntities.ts +105 -0
  534. package/analyzer-template/packages/database/src/lib/upsertEntityBranches.ts +40 -0
  535. package/analyzer-template/packages/database/src/lib/upsertFiles.ts +45 -0
  536. package/analyzer-template/packages/database/src/lib/upsertGithubUser.ts +32 -0
  537. package/analyzer-template/packages/database/src/lib/upsertProjects.ts +32 -0
  538. package/analyzer-template/packages/database/src/lib/upsertScenarios.ts +31 -0
  539. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +18 -0
  540. package/analyzer-template/packages/database/tsconfig.json +10 -0
  541. package/analyzer-template/packages/generate/index.ts +15 -0
  542. package/analyzer-template/packages/generate/jest.config.ts +11 -0
  543. package/analyzer-template/packages/generate/package.json +13 -0
  544. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +157 -0
  545. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.ts +119 -0
  546. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +221 -0
  547. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
  548. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +114 -0
  549. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getImageReplacementCode.ts +134 -0
  550. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.ts +66 -0
  551. package/analyzer-template/packages/generate/src/lib/constants.ts +3 -0
  552. package/analyzer-template/packages/generate/src/lib/deepMerge.ts +69 -0
  553. package/analyzer-template/packages/generate/src/lib/directExecutionScript.ts +185 -0
  554. package/analyzer-template/packages/generate/src/lib/escapeQuotes.ts +3 -0
  555. package/analyzer-template/packages/generate/src/lib/getComponentImportStatement.ts +60 -0
  556. package/analyzer-template/packages/generate/src/lib/getComponentImportStatements.ts +38 -0
  557. package/analyzer-template/packages/generate/src/lib/getComponentScenarioPath.ts +40 -0
  558. package/analyzer-template/packages/generate/src/lib/getRelativePath.ts +42 -0
  559. package/analyzer-template/packages/generate/src/lib/handleCmdk.ts +61 -0
  560. package/analyzer-template/packages/generate/src/lib/handleRadix.ts +362 -0
  561. package/analyzer-template/packages/generate/src/lib/handleWrappers.ts +30 -0
  562. package/analyzer-template/packages/generate/src/lib/libDemoComponent.ts +186 -0
  563. package/analyzer-template/packages/generate/src/lib/mergeRootRemix.ts +410 -0
  564. package/analyzer-template/packages/generate/src/lib/requiredNodeModuleImports.ts +55 -0
  565. package/analyzer-template/packages/generate/src/lib/safeFolder.ts +9 -0
  566. package/analyzer-template/packages/generate/src/lib/scenarioComponent.ts +122 -0
  567. package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
  568. package/analyzer-template/packages/generate/src/lib/simpleRootRemix.ts +74 -0
  569. package/analyzer-template/packages/generate/tsconfig.json +10 -0
  570. package/analyzer-template/packages/github/__mocks__/@octokit/auth-app.ts +4 -0
  571. package/analyzer-template/packages/github/__mocks__/@octokit/rest.ts +77 -0
  572. package/analyzer-template/packages/github/dist/database/index.d.ts +87 -0
  573. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -0
  574. package/analyzer-template/packages/github/dist/database/index.js +85 -0
  575. package/analyzer-template/packages/github/dist/database/index.js.map +1 -0
  576. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.d.ts +5 -0
  577. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.d.ts.map +1 -0
  578. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +19 -0
  579. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -0
  580. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.d.ts +5 -0
  581. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.d.ts.map +1 -0
  582. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +26 -0
  583. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -0
  584. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.d.ts +7 -0
  585. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.d.ts.map +1 -0
  586. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.js +13 -0
  587. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.js.map +1 -0
  588. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.d.ts +5 -0
  589. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.d.ts.map +1 -0
  590. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +18 -0
  591. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -0
  592. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.d.ts +5 -0
  593. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.d.ts.map +1 -0
  594. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +13 -0
  595. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -0
  596. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.d.ts +5 -0
  597. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.d.ts.map +1 -0
  598. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +26 -0
  599. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -0
  600. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.d.ts +18 -0
  601. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.d.ts.map +1 -0
  602. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.js +108 -0
  603. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.js.map +1 -0
  604. package/analyzer-template/packages/github/dist/database/src/lib/createProject.d.ts +2 -0
  605. package/analyzer-template/packages/github/dist/database/src/lib/createProject.d.ts.map +1 -0
  606. package/analyzer-template/packages/github/dist/database/src/lib/createProject.js +22 -0
  607. package/analyzer-template/packages/github/dist/database/src/lib/createProject.js.map +1 -0
  608. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.d.ts +5 -0
  609. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.d.ts.map +1 -0
  610. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.js +42 -0
  611. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.js.map +1 -0
  612. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.d.ts +4 -0
  613. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.d.ts.map +1 -0
  614. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.js +48 -0
  615. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.js.map +1 -0
  616. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.d.ts +4 -0
  617. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.d.ts.map +1 -0
  618. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.js +24 -0
  619. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.js.map +1 -0
  620. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.d.ts +4 -0
  621. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.d.ts.map +1 -0
  622. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.js +13 -0
  623. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.js.map +1 -0
  624. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.d.ts +4 -0
  625. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.d.ts.map +1 -0
  626. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.js +22 -0
  627. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.js.map +1 -0
  628. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.d.ts +4 -0
  629. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.d.ts.map +1 -0
  630. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.js +40 -0
  631. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.js.map +1 -0
  632. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.d.ts +4 -0
  633. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.d.ts.map +1 -0
  634. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.js +18 -0
  635. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.js.map +1 -0
  636. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.d.ts +4 -0
  637. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.d.ts.map +1 -0
  638. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.js +23 -0
  639. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.js.map +1 -0
  640. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.d.ts +4 -0
  641. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.d.ts.map +1 -0
  642. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.js +13 -0
  643. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.js.map +1 -0
  644. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.d.ts +4 -0
  645. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.d.ts.map +1 -0
  646. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.js +14 -0
  647. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.js.map +1 -0
  648. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.d.ts +4 -0
  649. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.d.ts.map +1 -0
  650. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.js +16 -0
  651. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.js.map +1 -0
  652. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.d.ts +4 -0
  653. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.d.ts.map +1 -0
  654. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.js +24 -0
  655. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.js.map +1 -0
  656. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.d.ts +4 -0
  657. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.d.ts.map +1 -0
  658. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.js +21 -0
  659. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.js.map +1 -0
  660. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.d.ts +4 -0
  661. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.d.ts.map +1 -0
  662. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.js +19 -0
  663. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.js.map +1 -0
  664. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.d.ts +5 -0
  665. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.d.ts.map +1 -0
  666. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.js +21 -0
  667. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.js.map +1 -0
  668. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.d.ts +7 -0
  669. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.d.ts.map +1 -0
  670. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.js +23 -0
  671. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.js.map +1 -0
  672. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.d.ts +32 -0
  673. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.d.ts.map +1 -0
  674. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.js +18 -0
  675. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.js.map +1 -0
  676. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.d.ts +7 -0
  677. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.d.ts.map +1 -0
  678. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.js +34 -0
  679. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.js.map +1 -0
  680. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.d.ts +5 -0
  681. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.d.ts.map +1 -0
  682. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.js +54 -0
  683. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.js.map +1 -0
  684. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.d.ts +5 -0
  685. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.d.ts.map +1 -0
  686. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +14 -0
  687. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -0
  688. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.d.ts +2 -0
  689. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.d.ts.map +1 -0
  690. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.js +15 -0
  691. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.js.map +1 -0
  692. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.d.ts +9 -0
  693. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.d.ts.map +1 -0
  694. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.js +28 -0
  695. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.js.map +1 -0
  696. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.d.ts +41 -0
  697. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.d.ts.map +1 -0
  698. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.js +66 -0
  699. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.js.map +1 -0
  700. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +73 -0
  701. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -0
  702. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +378 -0
  703. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -0
  704. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.d.ts +4 -0
  705. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.d.ts.map +1 -0
  706. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.js +17 -0
  707. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.js.map +1 -0
  708. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.d.ts +7 -0
  709. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.d.ts.map +1 -0
  710. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.js +34 -0
  711. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.js.map +1 -0
  712. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts +89 -0
  713. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts.map +1 -0
  714. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.js +2 -0
  715. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.js.map +1 -0
  716. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.d.ts +7 -0
  717. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.d.ts.map +1 -0
  718. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.js +7 -0
  719. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.js.map +1 -0
  720. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +97 -0
  721. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -0
  722. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.js +52 -0
  723. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.js.map +1 -0
  724. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.d.ts +17 -0
  725. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.d.ts.map +1 -0
  726. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.js +24 -0
  727. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.js.map +1 -0
  728. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.d.ts +27 -0
  729. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.d.ts.map +1 -0
  730. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.js +28 -0
  731. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.js.map +1 -0
  732. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.d.ts +42 -0
  733. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.d.ts.map +1 -0
  734. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.js +34 -0
  735. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.js.map +1 -0
  736. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.d.ts +16 -0
  737. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.d.ts.map +1 -0
  738. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.js +22 -0
  739. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.js.map +1 -0
  740. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +48 -0
  741. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -0
  742. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +47 -0
  743. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -0
  744. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +60 -0
  745. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -0
  746. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js +33 -0
  747. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -0
  748. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +25 -0
  749. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  750. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +76 -0
  751. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  752. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +68 -0
  753. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -0
  754. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.js +38 -0
  755. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.js.map +1 -0
  756. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.d.ts +14 -0
  757. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.d.ts.map +1 -0
  758. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.js +22 -0
  759. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.js.map +1 -0
  760. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.d.ts +16 -0
  761. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.d.ts.map +1 -0
  762. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.js +22 -0
  763. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.js.map +1 -0
  764. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.d.ts +40 -0
  765. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.d.ts.map +1 -0
  766. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.js +28 -0
  767. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.js.map +1 -0
  768. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.d.ts +21 -0
  769. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.d.ts.map +1 -0
  770. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.js +32 -0
  771. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.js.map +1 -0
  772. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.d.ts +16 -0
  773. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.d.ts.map +1 -0
  774. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.js +22 -0
  775. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.js.map +1 -0
  776. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  777. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  778. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  779. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  780. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.d.ts +25 -0
  781. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.d.ts.map +1 -0
  782. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.js +38 -0
  783. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.js.map +1 -0
  784. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.d.ts +19 -0
  785. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.d.ts.map +1 -0
  786. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.js +28 -0
  787. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.js.map +1 -0
  788. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +66 -0
  789. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -0
  790. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.js +30 -0
  791. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.js.map +1 -0
  792. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.d.ts +17 -0
  793. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.d.ts.map +1 -0
  794. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.js +24 -0
  795. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.js.map +1 -0
  796. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.d.ts +14 -0
  797. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.d.ts.map +1 -0
  798. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.js +18 -0
  799. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.js.map +1 -0
  800. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.d.ts +17 -0
  801. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.d.ts.map +1 -0
  802. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.js +24 -0
  803. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.js.map +1 -0
  804. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.d.ts +12 -0
  805. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.d.ts.map +1 -0
  806. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.js +17 -0
  807. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.js.map +1 -0
  808. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.d.ts +18 -0
  809. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.d.ts.map +1 -0
  810. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.js +26 -0
  811. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.js.map +1 -0
  812. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.d.ts +4 -0
  813. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.d.ts.map +1 -0
  814. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.js +9 -0
  815. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.js.map +1 -0
  816. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +16 -0
  817. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -0
  818. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +174 -0
  819. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -0
  820. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts +18 -0
  821. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -0
  822. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +138 -0
  823. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -0
  824. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.d.ts +26 -0
  825. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.d.ts.map +1 -0
  826. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.js +152 -0
  827. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.js.map +1 -0
  828. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.d.ts +4 -0
  829. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.d.ts.map +1 -0
  830. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.js +19 -0
  831. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.js.map +1 -0
  832. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.d.ts +12 -0
  833. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.d.ts.map +1 -0
  834. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +100 -0
  835. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -0
  836. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.d.ts +9 -0
  837. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.d.ts.map +1 -0
  838. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.js +37 -0
  839. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.js.map +1 -0
  840. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts +16 -0
  841. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -0
  842. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +118 -0
  843. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -0
  844. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.d.ts +11 -0
  845. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.d.ts.map +1 -0
  846. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.js +45 -0
  847. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.js.map +1 -0
  848. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.d.ts +23 -0
  849. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.d.ts.map +1 -0
  850. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.js +26 -0
  851. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.js.map +1 -0
  852. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +15 -0
  853. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -0
  854. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +219 -0
  855. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -0
  856. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +13 -0
  857. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -0
  858. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +76 -0
  859. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -0
  860. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +16 -0
  861. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -0
  862. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +72 -0
  863. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -0
  864. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts +17 -0
  865. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -0
  866. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +123 -0
  867. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -0
  868. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.d.ts +6 -0
  869. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.d.ts.map +1 -0
  870. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.js +28 -0
  871. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.js.map +1 -0
  872. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.d.ts +15 -0
  873. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.d.ts.map +1 -0
  874. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.js +101 -0
  875. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.js.map +1 -0
  876. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.d.ts +11 -0
  877. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.d.ts.map +1 -0
  878. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.js +80 -0
  879. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.js.map +1 -0
  880. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.d.ts +9 -0
  881. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.d.ts.map +1 -0
  882. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.js +52 -0
  883. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.js.map +1 -0
  884. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts +8 -0
  885. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -0
  886. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +65 -0
  887. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -0
  888. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.d.ts +5 -0
  889. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.d.ts.map +1 -0
  890. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.js +30 -0
  891. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.js.map +1 -0
  892. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.d.ts +3 -0
  893. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.d.ts.map +1 -0
  894. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.js +21 -0
  895. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.js.map +1 -0
  896. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.d.ts +2 -0
  897. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.d.ts.map +1 -0
  898. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.js +7 -0
  899. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.js.map +1 -0
  900. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.d.ts +5 -0
  901. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.d.ts.map +1 -0
  902. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +18 -0
  903. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -0
  904. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.d.ts +7 -0
  905. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.d.ts.map +1 -0
  906. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.js +10 -0
  907. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.js.map +1 -0
  908. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.d.ts +3 -0
  909. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.d.ts.map +1 -0
  910. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.js +20 -0
  911. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.js.map +1 -0
  912. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.d.ts +5 -0
  913. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.d.ts.map +1 -0
  914. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +33 -0
  915. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -0
  916. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.d.ts +3 -0
  917. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.d.ts.map +1 -0
  918. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.js +22 -0
  919. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.js.map +1 -0
  920. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.d.ts +5 -0
  921. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.d.ts.map +1 -0
  922. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +18 -0
  923. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -0
  924. package/analyzer-template/packages/github/dist/database/src/lib/supabase.d.ts +4 -0
  925. package/analyzer-template/packages/github/dist/database/src/lib/supabase.d.ts.map +1 -0
  926. package/analyzer-template/packages/github/dist/database/src/lib/supabase.js +57 -0
  927. package/analyzer-template/packages/github/dist/database/src/lib/supabase.js.map +1 -0
  928. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.d.ts +3 -0
  929. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.d.ts.map +1 -0
  930. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.js +61 -0
  931. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.js.map +1 -0
  932. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +13 -0
  933. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -0
  934. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +87 -0
  935. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -0
  936. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.d.ts +3 -0
  937. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.d.ts.map +1 -0
  938. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.js +21 -0
  939. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.js.map +1 -0
  940. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.d.ts +7 -0
  941. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.d.ts.map +1 -0
  942. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.js +42 -0
  943. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.js.map +1 -0
  944. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts +7 -0
  945. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -0
  946. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +53 -0
  947. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -0
  948. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts +10 -0
  949. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -0
  950. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +81 -0
  951. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -0
  952. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.d.ts +10 -0
  953. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.d.ts.map +1 -0
  954. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.js +60 -0
  955. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.js.map +1 -0
  956. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.d.ts +3 -0
  957. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.d.ts.map +1 -0
  958. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.js +53 -0
  959. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.js.map +1 -0
  960. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.d.ts +7 -0
  961. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.d.ts.map +1 -0
  962. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.js +62 -0
  963. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.js.map +1 -0
  964. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.d.ts +3 -0
  965. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.d.ts.map +1 -0
  966. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.js +72 -0
  967. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.js.map +1 -0
  968. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.d.ts +3 -0
  969. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.d.ts.map +1 -0
  970. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.js +22 -0
  971. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.js.map +1 -0
  972. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.d.ts +3 -0
  973. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.d.ts.map +1 -0
  974. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.js +29 -0
  975. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.js.map +1 -0
  976. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.d.ts +3 -0
  977. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.d.ts.map +1 -0
  978. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.js +29 -0
  979. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.js.map +1 -0
  980. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.d.ts +8 -0
  981. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.d.ts.map +1 -0
  982. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.js +41 -0
  983. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.js.map +1 -0
  984. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.d.ts +3 -0
  985. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.d.ts.map +1 -0
  986. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.js +82 -0
  987. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.js.map +1 -0
  988. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.d.ts +3 -0
  989. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.d.ts.map +1 -0
  990. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.js +27 -0
  991. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.js.map +1 -0
  992. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.d.ts +3 -0
  993. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.d.ts.map +1 -0
  994. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.js +32 -0
  995. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.js.map +1 -0
  996. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.d.ts +8 -0
  997. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.d.ts.map +1 -0
  998. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.js +27 -0
  999. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.js.map +1 -0
  1000. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.d.ts +3 -0
  1001. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.d.ts.map +1 -0
  1002. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.js +27 -0
  1003. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.js.map +1 -0
  1004. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.d.ts +3 -0
  1005. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.d.ts.map +1 -0
  1006. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.js +28 -0
  1007. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.js.map +1 -0
  1008. package/analyzer-template/packages/github/dist/generate/index.d.ts +16 -0
  1009. package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -0
  1010. package/analyzer-template/packages/github/dist/generate/index.js +16 -0
  1011. package/analyzer-template/packages/github/dist/generate/index.js.map +1 -0
  1012. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts +11 -0
  1013. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -0
  1014. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +136 -0
  1015. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -0
  1016. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.d.ts +3 -0
  1017. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.d.ts.map +1 -0
  1018. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js +108 -0
  1019. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js.map +1 -0
  1020. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
  1021. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
  1022. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +217 -0
  1023. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  1024. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
  1025. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
  1026. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  1027. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  1028. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts +4 -0
  1029. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -0
  1030. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +110 -0
  1031. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -0
  1032. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.d.ts +7 -0
  1033. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.d.ts.map +1 -0
  1034. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.js +134 -0
  1035. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getImageReplacementCode.js.map +1 -0
  1036. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.d.ts +2 -0
  1037. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.d.ts.map +1 -0
  1038. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js +67 -0
  1039. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js.map +1 -0
  1040. package/analyzer-template/packages/github/dist/generate/src/lib/constants.d.ts +2 -0
  1041. package/analyzer-template/packages/github/dist/generate/src/lib/constants.d.ts.map +1 -0
  1042. package/analyzer-template/packages/github/dist/generate/src/lib/constants.js +3 -0
  1043. package/analyzer-template/packages/github/dist/generate/src/lib/constants.js.map +1 -0
  1044. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts +2 -0
  1045. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts.map +1 -0
  1046. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js +72 -0
  1047. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js.map +1 -0
  1048. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.d.ts +14 -0
  1049. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.d.ts.map +1 -0
  1050. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js +165 -0
  1051. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js.map +1 -0
  1052. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.d.ts +2 -0
  1053. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.d.ts.map +1 -0
  1054. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.js +4 -0
  1055. package/analyzer-template/packages/github/dist/generate/src/lib/escapeQuotes.js.map +1 -0
  1056. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.d.ts +13 -0
  1057. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.d.ts.map +1 -0
  1058. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.js +23 -0
  1059. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatement.js.map +1 -0
  1060. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.d.ts +10 -0
  1061. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.d.ts.map +1 -0
  1062. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.js +24 -0
  1063. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentImportStatements.js.map +1 -0
  1064. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.d.ts +4 -0
  1065. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.d.ts.map +1 -0
  1066. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js +25 -0
  1067. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js.map +1 -0
  1068. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.d.ts +2 -0
  1069. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.d.ts.map +1 -0
  1070. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.js +32 -0
  1071. package/analyzer-template/packages/github/dist/generate/src/lib/getRelativePath.js.map +1 -0
  1072. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.d.ts +8 -0
  1073. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.d.ts.map +1 -0
  1074. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.js +50 -0
  1075. package/analyzer-template/packages/github/dist/generate/src/lib/handleCmdk.js.map +1 -0
  1076. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.d.ts +18 -0
  1077. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.d.ts.map +1 -0
  1078. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.js +224 -0
  1079. package/analyzer-template/packages/github/dist/generate/src/lib/handleRadix.js.map +1 -0
  1080. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.d.ts +3 -0
  1081. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.d.ts.map +1 -0
  1082. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.js +24 -0
  1083. package/analyzer-template/packages/github/dist/generate/src/lib/handleWrappers.js.map +1 -0
  1084. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.d.ts +3 -0
  1085. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.d.ts.map +1 -0
  1086. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.js +160 -0
  1087. package/analyzer-template/packages/github/dist/generate/src/lib/libDemoComponent.js.map +1 -0
  1088. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.d.ts +9 -0
  1089. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.d.ts.map +1 -0
  1090. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.js +323 -0
  1091. package/analyzer-template/packages/github/dist/generate/src/lib/mergeRootRemix.js.map +1 -0
  1092. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.d.ts +11 -0
  1093. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.d.ts.map +1 -0
  1094. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.js +45 -0
  1095. package/analyzer-template/packages/github/dist/generate/src/lib/requiredNodeModuleImports.js.map +1 -0
  1096. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.d.ts +2 -0
  1097. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.d.ts.map +1 -0
  1098. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.js +11 -0
  1099. package/analyzer-template/packages/github/dist/generate/src/lib/safeFolder.js.map +1 -0
  1100. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.d.ts +6 -0
  1101. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.d.ts.map +1 -0
  1102. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.js +94 -0
  1103. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponent.js.map +1 -0
  1104. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
  1105. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
  1106. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
  1107. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  1108. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.d.ts +3 -0
  1109. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.d.ts.map +1 -0
  1110. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.js +73 -0
  1111. package/analyzer-template/packages/github/dist/generate/src/lib/simpleRootRemix.js.map +1 -0
  1112. package/analyzer-template/packages/github/dist/github/index.d.ts +23 -0
  1113. package/analyzer-template/packages/github/dist/github/index.d.ts.map +1 -0
  1114. package/analyzer-template/packages/github/dist/github/index.js +23 -0
  1115. package/analyzer-template/packages/github/dist/github/index.js.map +1 -0
  1116. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.d.ts +3 -0
  1117. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.d.ts.map +1 -0
  1118. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.js +8 -0
  1119. package/analyzer-template/packages/github/dist/github/src/lib/__mocks__/createProjectOctokit.js.map +1 -0
  1120. package/analyzer-template/packages/github/dist/github/src/lib/constants.d.ts +4 -0
  1121. package/analyzer-template/packages/github/dist/github/src/lib/constants.d.ts.map +1 -0
  1122. package/analyzer-template/packages/github/dist/github/src/lib/constants.js +4 -0
  1123. package/analyzer-template/packages/github/dist/github/src/lib/constants.js.map +1 -0
  1124. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.d.ts +5 -0
  1125. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.d.ts.map +1 -0
  1126. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.js +48 -0
  1127. package/analyzer-template/packages/github/dist/github/src/lib/createProjectOctokit.js.map +1 -0
  1128. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.d.ts +8 -0
  1129. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.d.ts.map +1 -0
  1130. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.js +11 -0
  1131. package/analyzer-template/packages/github/dist/github/src/lib/getBranch.js.map +1 -0
  1132. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.d.ts +12 -0
  1133. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.d.ts.map +1 -0
  1134. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.js +24 -0
  1135. package/analyzer-template/packages/github/dist/github/src/lib/getBranchCommits.js.map +1 -0
  1136. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.d.ts +6 -0
  1137. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.d.ts.map +1 -0
  1138. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.js +14 -0
  1139. package/analyzer-template/packages/github/dist/github/src/lib/getBranches.js.map +1 -0
  1140. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.d.ts +9 -0
  1141. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.d.ts.map +1 -0
  1142. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.js +12 -0
  1143. package/analyzer-template/packages/github/dist/github/src/lib/getCommit.js.map +1 -0
  1144. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.d.ts +6 -0
  1145. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.d.ts.map +1 -0
  1146. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.js +57 -0
  1147. package/analyzer-template/packages/github/dist/github/src/lib/getCommitFromGithub.js.map +1 -0
  1148. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.d.ts +12 -0
  1149. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.d.ts.map +1 -0
  1150. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.js +37 -0
  1151. package/analyzer-template/packages/github/dist/github/src/lib/getCommits.js.map +1 -0
  1152. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.d.ts +13 -0
  1153. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.d.ts.map +1 -0
  1154. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.js +163 -0
  1155. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.js.map +1 -0
  1156. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.d.ts +3 -0
  1157. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.d.ts.map +1 -0
  1158. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.js +26 -0
  1159. package/analyzer-template/packages/github/dist/github/src/lib/getDiffBetweenCommits.js.map +1 -0
  1160. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.d.ts +12 -0
  1161. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.d.ts.map +1 -0
  1162. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.js +14 -0
  1163. package/analyzer-template/packages/github/dist/github/src/lib/getFileContent.js.map +1 -0
  1164. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.d.ts +2 -0
  1165. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.d.ts.map +1 -0
  1166. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.js +22 -0
  1167. package/analyzer-template/packages/github/dist/github/src/lib/getFirstCommitShaAfterTimestamp.js.map +1 -0
  1168. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.d.ts +8 -0
  1169. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.d.ts.map +1 -0
  1170. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.js +28 -0
  1171. package/analyzer-template/packages/github/dist/github/src/lib/getLatestCommit.js.map +1 -0
  1172. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.d.ts +9 -0
  1173. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.d.ts.map +1 -0
  1174. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.js +28 -0
  1175. package/analyzer-template/packages/github/dist/github/src/lib/getOpenPullRequests.js.map +1 -0
  1176. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.d.ts +6 -0
  1177. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.d.ts.map +1 -0
  1178. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.js +12 -0
  1179. package/analyzer-template/packages/github/dist/github/src/lib/getPublicReposWithQuery.js.map +1 -0
  1180. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.d.ts +607 -0
  1181. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.d.ts.map +1 -0
  1182. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.js +21 -0
  1183. package/analyzer-template/packages/github/dist/github/src/lib/getPullRequestsForCommit.js.map +1 -0
  1184. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.d.ts +20 -0
  1185. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.d.ts.map +1 -0
  1186. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.js +35 -0
  1187. package/analyzer-template/packages/github/dist/github/src/lib/getRepoInfo.js.map +1 -0
  1188. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.d.ts +7 -0
  1189. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.d.ts.map +1 -0
  1190. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.js +53 -0
  1191. package/analyzer-template/packages/github/dist/github/src/lib/getRepoWithBranches.js.map +1 -0
  1192. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.d.ts +17 -0
  1193. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.d.ts.map +1 -0
  1194. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.js +13 -0
  1195. package/analyzer-template/packages/github/dist/github/src/lib/getRepos.js.map +1 -0
  1196. package/analyzer-template/packages/github/dist/github/src/lib/getTree.d.ts +6 -0
  1197. package/analyzer-template/packages/github/dist/github/src/lib/getTree.d.ts.map +1 -0
  1198. package/analyzer-template/packages/github/dist/github/src/lib/getTree.js +14 -0
  1199. package/analyzer-template/packages/github/dist/github/src/lib/getTree.js.map +1 -0
  1200. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.d.ts +5 -0
  1201. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.d.ts.map +1 -0
  1202. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.js +20 -0
  1203. package/analyzer-template/packages/github/dist/github/src/lib/githubToCommit.js.map +1 -0
  1204. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.d.ts +11 -0
  1205. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.d.ts.map +1 -0
  1206. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.js +10 -0
  1207. package/analyzer-template/packages/github/dist/github/src/lib/listCommitsSince.js.map +1 -0
  1208. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts +14 -0
  1209. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -0
  1210. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +149 -0
  1211. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -0
  1212. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.d.ts +12 -0
  1213. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.d.ts.map +1 -0
  1214. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.js +74 -0
  1215. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.js.map +1 -0
  1216. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.d.ts +6 -0
  1217. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.d.ts.map +1 -0
  1218. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.js +38 -0
  1219. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.js.map +1 -0
  1220. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts +9 -0
  1221. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -0
  1222. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +75 -0
  1223. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -0
  1224. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.d.ts +27 -0
  1225. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.d.ts.map +1 -0
  1226. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.js +48 -0
  1227. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.js.map +1 -0
  1228. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.d.ts +9 -0
  1229. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.d.ts.map +1 -0
  1230. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.js +26 -0
  1231. package/analyzer-template/packages/github/dist/github/src/lib/syncRepo.js.map +1 -0
  1232. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.d.ts +7 -0
  1233. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.d.ts.map +1 -0
  1234. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.js +40 -0
  1235. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.js.map +1 -0
  1236. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.d.ts +13 -0
  1237. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.d.ts.map +1 -0
  1238. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.js +74 -0
  1239. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.js.map +1 -0
  1240. package/analyzer-template/packages/github/dist/github/src/lib/urls.d.ts +11 -0
  1241. package/analyzer-template/packages/github/dist/github/src/lib/urls.d.ts.map +1 -0
  1242. package/analyzer-template/packages/github/dist/github/src/lib/urls.js +11 -0
  1243. package/analyzer-template/packages/github/dist/github/src/lib/urls.js.map +1 -0
  1244. package/analyzer-template/packages/github/dist/types/index.d.ts +47 -0
  1245. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -0
  1246. package/analyzer-template/packages/github/dist/types/index.js +4 -0
  1247. package/analyzer-template/packages/github/dist/types/index.js.map +1 -0
  1248. package/analyzer-template/packages/github/dist/types/src/constants.d.ts +2 -0
  1249. package/analyzer-template/packages/github/dist/types/src/constants.d.ts.map +1 -0
  1250. package/analyzer-template/packages/github/dist/types/src/constants.js +2 -0
  1251. package/analyzer-template/packages/github/dist/types/src/constants.js.map +1 -0
  1252. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +11 -0
  1253. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -0
  1254. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +12 -0
  1255. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -0
  1256. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +207 -0
  1257. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -0
  1258. package/analyzer-template/packages/github/dist/types/src/types/Analysis.js +3 -0
  1259. package/analyzer-template/packages/github/dist/types/src/types/Analysis.js.map +1 -0
  1260. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.d.ts +15 -0
  1261. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.d.ts.map +1 -0
  1262. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.js +2 -0
  1263. package/analyzer-template/packages/github/dist/types/src/types/AnalysisBranch.js.map +1 -0
  1264. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.d.ts +12 -0
  1265. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.d.ts.map +1 -0
  1266. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.js +2 -0
  1267. package/analyzer-template/packages/github/dist/types/src/types/AnalysisMap.js.map +1 -0
  1268. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.d.ts +19 -0
  1269. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.d.ts.map +1 -0
  1270. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.js +2 -0
  1271. package/analyzer-template/packages/github/dist/types/src/types/BackgroundJob.js.map +1 -0
  1272. package/analyzer-template/packages/github/dist/types/src/types/Branch.d.ts +43 -0
  1273. package/analyzer-template/packages/github/dist/types/src/types/Branch.d.ts.map +1 -0
  1274. package/analyzer-template/packages/github/dist/types/src/types/Branch.js +2 -0
  1275. package/analyzer-template/packages/github/dist/types/src/types/Branch.js.map +1 -0
  1276. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.d.ts +4 -0
  1277. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.d.ts.map +1 -0
  1278. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.js +2 -0
  1279. package/analyzer-template/packages/github/dist/types/src/types/CodeExplanation.js.map +1 -0
  1280. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +88 -0
  1281. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -0
  1282. package/analyzer-template/packages/github/dist/types/src/types/Commit.js +2 -0
  1283. package/analyzer-template/packages/github/dist/types/src/types/Commit.js.map +1 -0
  1284. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.d.ts +11 -0
  1285. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.d.ts.map +1 -0
  1286. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.js +2 -0
  1287. package/analyzer-template/packages/github/dist/types/src/types/CommitBranch.js.map +1 -0
  1288. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.d.ts +9 -0
  1289. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.d.ts.map +1 -0
  1290. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.js +2 -0
  1291. package/analyzer-template/packages/github/dist/types/src/types/CommitChange.js.map +1 -0
  1292. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.d.ts +4 -0
  1293. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.d.ts.map +1 -0
  1294. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.js +2 -0
  1295. package/analyzer-template/packages/github/dist/types/src/types/DeepPartial.js.map +1 -0
  1296. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.d.ts +4 -0
  1297. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.d.ts.map +1 -0
  1298. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.js +2 -0
  1299. package/analyzer-template/packages/github/dist/types/src/types/DeepReadonly.js.map +1 -0
  1300. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.d.ts +8 -0
  1301. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.d.ts.map +1 -0
  1302. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.js +2 -0
  1303. package/analyzer-template/packages/github/dist/types/src/types/DependencyTreeNode.js.map +1 -0
  1304. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +100 -0
  1305. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -0
  1306. package/analyzer-template/packages/github/dist/types/src/types/Entity.js +2 -0
  1307. package/analyzer-template/packages/github/dist/types/src/types/Entity.js.map +1 -0
  1308. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.d.ts +8 -0
  1309. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.d.ts.map +1 -0
  1310. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.js +2 -0
  1311. package/analyzer-template/packages/github/dist/types/src/types/EntityBranch.js.map +1 -0
  1312. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.d.ts +7 -0
  1313. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.d.ts.map +1 -0
  1314. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.js +2 -0
  1315. package/analyzer-template/packages/github/dist/types/src/types/EntityMap.js.map +1 -0
  1316. package/analyzer-template/packages/github/dist/types/src/types/EntityType.d.ts +2 -0
  1317. package/analyzer-template/packages/github/dist/types/src/types/EntityType.d.ts.map +1 -0
  1318. package/analyzer-template/packages/github/dist/types/src/types/EntityType.js +2 -0
  1319. package/analyzer-template/packages/github/dist/types/src/types/EntityType.js.map +1 -0
  1320. package/analyzer-template/packages/github/dist/types/src/types/File.d.ts +45 -0
  1321. package/analyzer-template/packages/github/dist/types/src/types/File.d.ts.map +1 -0
  1322. package/analyzer-template/packages/github/dist/types/src/types/File.js +2 -0
  1323. package/analyzer-template/packages/github/dist/types/src/types/File.js.map +1 -0
  1324. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.d.ts +7 -0
  1325. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.d.ts.map +1 -0
  1326. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.js +2 -0
  1327. package/analyzer-template/packages/github/dist/types/src/types/FilePreMock.js.map +1 -0
  1328. package/analyzer-template/packages/github/dist/types/src/types/FileProp.d.ts +8 -0
  1329. package/analyzer-template/packages/github/dist/types/src/types/FileProp.d.ts.map +1 -0
  1330. package/analyzer-template/packages/github/dist/types/src/types/FileProp.js +2 -0
  1331. package/analyzer-template/packages/github/dist/types/src/types/FileProp.js.map +1 -0
  1332. package/analyzer-template/packages/github/dist/types/src/types/FileType.d.ts +2 -0
  1333. package/analyzer-template/packages/github/dist/types/src/types/FileType.d.ts.map +1 -0
  1334. package/analyzer-template/packages/github/dist/types/src/types/FileType.js +2 -0
  1335. package/analyzer-template/packages/github/dist/types/src/types/FileType.js.map +1 -0
  1336. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.d.ts +7 -0
  1337. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.d.ts.map +1 -0
  1338. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.js +2 -0
  1339. package/analyzer-template/packages/github/dist/types/src/types/GithubBranch.js.map +1 -0
  1340. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.d.ts +9 -0
  1341. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.d.ts.map +1 -0
  1342. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.js +2 -0
  1343. package/analyzer-template/packages/github/dist/types/src/types/GithubFile.js.map +1 -0
  1344. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.d.ts +9 -0
  1345. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.d.ts.map +1 -0
  1346. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.js +2 -0
  1347. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoData.js.map +1 -0
  1348. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.d.ts +15 -0
  1349. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.d.ts.map +1 -0
  1350. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.js +2 -0
  1351. package/analyzer-template/packages/github/dist/types/src/types/GithubRepoInfo.js.map +1 -0
  1352. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.d.ts +4 -0
  1353. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.d.ts.map +1 -0
  1354. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.js +2 -0
  1355. package/analyzer-template/packages/github/dist/types/src/types/JsonTypeDefinition.js.map +1 -0
  1356. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.d.ts +5 -0
  1357. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.d.ts.map +1 -0
  1358. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.js +2 -0
  1359. package/analyzer-template/packages/github/dist/types/src/types/LlmCall.js.map +1 -0
  1360. package/analyzer-template/packages/github/dist/types/src/types/Mock.d.ts +35 -0
  1361. package/analyzer-template/packages/github/dist/types/src/types/Mock.d.ts.map +1 -0
  1362. package/analyzer-template/packages/github/dist/types/src/types/Mock.js +2 -0
  1363. package/analyzer-template/packages/github/dist/types/src/types/Mock.js.map +1 -0
  1364. package/analyzer-template/packages/github/dist/types/src/types/Project.d.ts +26 -0
  1365. package/analyzer-template/packages/github/dist/types/src/types/Project.d.ts.map +1 -0
  1366. package/analyzer-template/packages/github/dist/types/src/types/Project.js +2 -0
  1367. package/analyzer-template/packages/github/dist/types/src/types/Project.js.map +1 -0
  1368. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +54 -0
  1369. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -0
  1370. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.js +2 -0
  1371. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.js.map +1 -0
  1372. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.d.ts +8 -0
  1373. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.d.ts.map +1 -0
  1374. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.js +2 -0
  1375. package/analyzer-template/packages/github/dist/types/src/types/PropsWithTypes.js.map +1 -0
  1376. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +127 -0
  1377. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -0
  1378. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js +2 -0
  1379. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js.map +1 -0
  1380. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.d.ts +12 -0
  1381. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.d.ts.map +1 -0
  1382. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.js +2 -0
  1383. package/analyzer-template/packages/github/dist/types/src/types/ScenarioComment.js.map +1 -0
  1384. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.d.ts +13 -0
  1385. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.d.ts.map +1 -0
  1386. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.js +2 -0
  1387. package/analyzer-template/packages/github/dist/types/src/types/ScenarioData.js.map +1 -0
  1388. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +270 -0
  1389. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -0
  1390. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.js +2 -0
  1391. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.js.map +1 -0
  1392. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +18 -0
  1393. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -0
  1394. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.js +2 -0
  1395. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.js.map +1 -0
  1396. package/analyzer-template/packages/github/dist/types/src/types/Statement.d.ts +11 -0
  1397. package/analyzer-template/packages/github/dist/types/src/types/Statement.d.ts.map +1 -0
  1398. package/analyzer-template/packages/github/dist/types/src/types/Statement.js +2 -0
  1399. package/analyzer-template/packages/github/dist/types/src/types/Statement.js.map +1 -0
  1400. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +14 -0
  1401. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -0
  1402. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.js +2 -0
  1403. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.js.map +1 -0
  1404. package/analyzer-template/packages/github/dist/types/src/types/Team.d.ts +5 -0
  1405. package/analyzer-template/packages/github/dist/types/src/types/Team.d.ts.map +1 -0
  1406. package/analyzer-template/packages/github/dist/types/src/types/Team.js +2 -0
  1407. package/analyzer-template/packages/github/dist/types/src/types/Team.js.map +1 -0
  1408. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.d.ts +17 -0
  1409. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.d.ts.map +1 -0
  1410. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.js +2 -0
  1411. package/analyzer-template/packages/github/dist/types/src/types/TimelineItem.js.map +1 -0
  1412. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.d.ts +2 -0
  1413. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.d.ts.map +1 -0
  1414. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.js +2 -0
  1415. package/analyzer-template/packages/github/dist/types/src/types/TsConfigPaths.js.map +1 -0
  1416. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.d.ts +5 -0
  1417. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.d.ts.map +1 -0
  1418. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.js +2 -0
  1419. package/analyzer-template/packages/github/dist/types/src/types/TypeStructures.js.map +1 -0
  1420. package/analyzer-template/packages/github/dist/types/src/types/User.d.ts +7 -0
  1421. package/analyzer-template/packages/github/dist/types/src/types/User.d.ts.map +1 -0
  1422. package/analyzer-template/packages/github/dist/types/src/types/User.js +2 -0
  1423. package/analyzer-template/packages/github/dist/types/src/types/User.js.map +1 -0
  1424. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.d.ts +10 -0
  1425. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.d.ts.map +1 -0
  1426. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.js +2 -0
  1427. package/analyzer-template/packages/github/dist/types/src/types/UserScenario.js.map +1 -0
  1428. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.d.ts +14 -0
  1429. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.d.ts.map +1 -0
  1430. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.js +2 -0
  1431. package/analyzer-template/packages/github/dist/types/src/types/WebContainerFileSystemTree.js.map +1 -0
  1432. package/analyzer-template/packages/github/dist/utils/index.d.ts +24 -0
  1433. package/analyzer-template/packages/github/dist/utils/index.d.ts.map +1 -0
  1434. package/analyzer-template/packages/github/dist/utils/index.js +31 -0
  1435. package/analyzer-template/packages/github/dist/utils/index.js.map +1 -0
  1436. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.d.ts +25 -0
  1437. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.d.ts.map +1 -0
  1438. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.js +40 -0
  1439. package/analyzer-template/packages/github/dist/utils/src/lib/Semaphore.js.map +1 -0
  1440. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.d.ts +12 -0
  1441. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.d.ts.map +1 -0
  1442. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.js +10 -0
  1443. package/analyzer-template/packages/github/dist/utils/src/lib/analyses/pushAnalysisError.js.map +1 -0
  1444. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.d.ts +61 -0
  1445. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -0
  1446. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js +288 -0
  1447. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js.map +1 -0
  1448. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.d.ts +8 -0
  1449. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.d.ts.map +1 -0
  1450. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.js +48 -0
  1451. package/analyzer-template/packages/github/dist/utils/src/lib/awsLog.js.map +1 -0
  1452. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts +15 -0
  1453. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts.map +1 -0
  1454. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +25 -0
  1455. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -0
  1456. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts +15 -0
  1457. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts.map +1 -0
  1458. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js +29 -0
  1459. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js.map +1 -0
  1460. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts +13 -0
  1461. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts.map +1 -0
  1462. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.js +22 -0
  1463. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getNextRoutePath.js.map +1 -0
  1464. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts +13 -0
  1465. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts.map +1 -0
  1466. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.js +20 -0
  1467. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/getRemixRoutePath.js.map +1 -0
  1468. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts +3 -0
  1469. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts.map +1 -0
  1470. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.js +7 -0
  1471. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isFrameworkRoute.js.map +1 -0
  1472. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.d.ts +3 -0
  1473. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.d.ts.map +1 -0
  1474. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.js +12 -0
  1475. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isNextRoute.js.map +1 -0
  1476. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.d.ts +3 -0
  1477. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.d.ts.map +1 -0
  1478. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.js +8 -0
  1479. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/isRemixRoute.js.map +1 -0
  1480. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts +14 -0
  1481. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts.map +1 -0
  1482. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +26 -0
  1483. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -0
  1484. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts +3 -0
  1485. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts.map +1 -0
  1486. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js +22 -0
  1487. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js.map +1 -0
  1488. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts +21 -0
  1489. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts.map +1 -0
  1490. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +62 -0
  1491. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -0
  1492. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.d.ts +16 -0
  1493. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.d.ts.map +1 -0
  1494. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.js +64 -0
  1495. package/analyzer-template/packages/github/dist/utils/src/lib/getFrameworkForFile.js.map +1 -0
  1496. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.d.ts +32 -0
  1497. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -0
  1498. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js +362 -0
  1499. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -0
  1500. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.d.ts +2 -0
  1501. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.d.ts.map +1 -0
  1502. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.js +4 -0
  1503. package/analyzer-template/packages/github/dist/utils/src/lib/normalizeKey.js.map +1 -0
  1504. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +10 -0
  1505. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -0
  1506. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +36 -0
  1507. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -0
  1508. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.d.ts +2 -0
  1509. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.d.ts.map +1 -0
  1510. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.js +64 -0
  1511. package/analyzer-template/packages/github/dist/utils/src/lib/safeStringify.js.map +1 -0
  1512. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.d.ts +18 -0
  1513. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.d.ts.map +1 -0
  1514. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  1515. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  1516. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.d.ts +26 -0
  1517. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.d.ts.map +1 -0
  1518. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  1519. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  1520. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.d.ts +3 -0
  1521. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.d.ts.map +1 -0
  1522. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.js +3 -0
  1523. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.js.map +1 -0
  1524. package/analyzer-template/packages/github/index.ts +25 -0
  1525. package/analyzer-template/packages/github/package.json +21 -0
  1526. package/analyzer-template/packages/github/src/lib/__mocks__/createProjectOctokit.ts +10 -0
  1527. package/analyzer-template/packages/github/src/lib/constants.ts +3 -0
  1528. package/analyzer-template/packages/github/src/lib/createProjectOctokit.ts +58 -0
  1529. package/analyzer-template/packages/github/src/lib/getBranch.ts +29 -0
  1530. package/analyzer-template/packages/github/src/lib/getBranchCommits.ts +44 -0
  1531. package/analyzer-template/packages/github/src/lib/getBranches.ts +28 -0
  1532. package/analyzer-template/packages/github/src/lib/getCommit.ts +25 -0
  1533. package/analyzer-template/packages/github/src/lib/getCommitFromGithub.ts +67 -0
  1534. package/analyzer-template/packages/github/src/lib/getCommits.ts +57 -0
  1535. package/analyzer-template/packages/github/src/lib/getCommitsFromGithub.ts +239 -0
  1536. package/analyzer-template/packages/github/src/lib/getDiffBetweenCommits.ts +37 -0
  1537. package/analyzer-template/packages/github/src/lib/getFileContent.ts +42 -0
  1538. package/analyzer-template/packages/github/src/lib/getFirstCommitShaAfterTimestamp.ts +26 -0
  1539. package/analyzer-template/packages/github/src/lib/getLatestCommit.ts +41 -0
  1540. package/analyzer-template/packages/github/src/lib/getOpenPullRequests.ts +39 -0
  1541. package/analyzer-template/packages/github/src/lib/getPublicReposWithQuery.ts +21 -0
  1542. package/analyzer-template/packages/github/src/lib/getPullRequestsForCommit.ts +30 -0
  1543. package/analyzer-template/packages/github/src/lib/getRepoInfo.ts +56 -0
  1544. package/analyzer-template/packages/github/src/lib/getRepoWithBranches.ts +73 -0
  1545. package/analyzer-template/packages/github/src/lib/getRepos.ts +35 -0
  1546. package/analyzer-template/packages/github/src/lib/getTree.ts +29 -0
  1547. package/analyzer-template/packages/github/src/lib/githubToCommit.ts +25 -0
  1548. package/analyzer-template/packages/github/src/lib/listCommitsSince.ts +21 -0
  1549. package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +214 -0
  1550. package/analyzer-template/packages/github/src/lib/syncBranches.ts +105 -0
  1551. package/analyzer-template/packages/github/src/lib/syncHeadBranches.ts +54 -0
  1552. package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +95 -0
  1553. package/analyzer-template/packages/github/src/lib/syncPullRequest.ts +87 -0
  1554. package/analyzer-template/packages/github/src/lib/syncRepo.ts +35 -0
  1555. package/analyzer-template/packages/github/src/lib/updateCommitBranchesInDb.ts +66 -0
  1556. package/analyzer-template/packages/github/src/lib/updateFilesInDb.ts +111 -0
  1557. package/analyzer-template/packages/github/src/lib/urls.ts +29 -0
  1558. package/analyzer-template/packages/github/tsconfig.json +11 -0
  1559. package/analyzer-template/packages/process/index.ts +2 -0
  1560. package/analyzer-template/packages/process/package.json +12 -0
  1561. package/analyzer-template/packages/process/src/GlobalProcessManager.ts +93 -0
  1562. package/analyzer-template/packages/process/src/ProcessManager.ts +350 -0
  1563. package/analyzer-template/packages/process/src/index.ts +75 -0
  1564. package/analyzer-template/packages/process/src/managedExecAsync.ts +154 -0
  1565. package/analyzer-template/packages/process/tsconfig.json +8 -0
  1566. package/analyzer-template/packages/types/index.ts +90 -0
  1567. package/analyzer-template/packages/types/package.json +12 -0
  1568. package/analyzer-template/packages/types/src/constants.ts +1 -0
  1569. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +10 -0
  1570. package/analyzer-template/packages/types/src/types/Analysis.ts +229 -0
  1571. package/analyzer-template/packages/types/src/types/AnalysisBranch.ts +16 -0
  1572. package/analyzer-template/packages/types/src/types/AnalysisMap.ts +9 -0
  1573. package/analyzer-template/packages/types/src/types/BackgroundJob.ts +18 -0
  1574. package/analyzer-template/packages/types/src/types/Branch.ts +43 -0
  1575. package/analyzer-template/packages/types/src/types/CodeExplanation.ts +3 -0
  1576. package/analyzer-template/packages/types/src/types/Commit.ts +94 -0
  1577. package/analyzer-template/packages/types/src/types/CommitBranch.ts +11 -0
  1578. package/analyzer-template/packages/types/src/types/CommitChange.ts +9 -0
  1579. package/analyzer-template/packages/types/src/types/DeepPartial.ts +8 -0
  1580. package/analyzer-template/packages/types/src/types/DeepReadonly.ts +8 -0
  1581. package/analyzer-template/packages/types/src/types/DependencyTreeNode.ts +3 -0
  1582. package/analyzer-template/packages/types/src/types/Entity.ts +116 -0
  1583. package/analyzer-template/packages/types/src/types/EntityBranch.ts +8 -0
  1584. package/analyzer-template/packages/types/src/types/EntityMap.ts +5 -0
  1585. package/analyzer-template/packages/types/src/types/EntityType.ts +10 -0
  1586. package/analyzer-template/packages/types/src/types/File.ts +41 -0
  1587. package/analyzer-template/packages/types/src/types/FilePreMock.ts +7 -0
  1588. package/analyzer-template/packages/types/src/types/FileProp.ts +8 -0
  1589. package/analyzer-template/packages/types/src/types/FileType.ts +12 -0
  1590. package/analyzer-template/packages/types/src/types/GithubBranch.ts +7 -0
  1591. package/analyzer-template/packages/types/src/types/GithubFile.ts +8 -0
  1592. package/analyzer-template/packages/types/src/types/GithubRepoData.ts +9 -0
  1593. package/analyzer-template/packages/types/src/types/GithubRepoInfo.ts +16 -0
  1594. package/analyzer-template/packages/types/src/types/JsonTypeDefinition.ts +3 -0
  1595. package/analyzer-template/packages/types/src/types/LlmCall.ts +1 -0
  1596. package/analyzer-template/packages/types/src/types/Mock.ts +28 -0
  1597. package/analyzer-template/packages/types/src/types/Project.ts +26 -0
  1598. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +57 -0
  1599. package/analyzer-template/packages/types/src/types/PropsWithTypes.ts +8 -0
  1600. package/analyzer-template/packages/types/src/types/Scenario.ts +120 -0
  1601. package/analyzer-template/packages/types/src/types/ScenarioComment.ts +12 -0
  1602. package/analyzer-template/packages/types/src/types/ScenarioData.ts +8 -0
  1603. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +277 -0
  1604. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +14 -0
  1605. package/analyzer-template/packages/types/src/types/Statement.ts +11 -0
  1606. package/analyzer-template/packages/types/src/types/StatementInfo.ts +13 -0
  1607. package/analyzer-template/packages/types/src/types/Team.ts +4 -0
  1608. package/analyzer-template/packages/types/src/types/TimelineItem.ts +16 -0
  1609. package/analyzer-template/packages/types/src/types/TsConfigPaths.ts +1 -0
  1610. package/analyzer-template/packages/types/src/types/TypeStructures.ts +5 -0
  1611. package/analyzer-template/packages/types/src/types/User.ts +6 -0
  1612. package/analyzer-template/packages/types/src/types/UserScenario.ts +10 -0
  1613. package/analyzer-template/packages/types/src/types/WebContainerFileSystemTree.ts +15 -0
  1614. package/analyzer-template/packages/types/tsconfig.json +10 -0
  1615. package/analyzer-template/packages/ui-components/README.md +235 -0
  1616. package/analyzer-template/packages/ui-components/package.json +37 -0
  1617. package/analyzer-template/packages/ui-components/src/components/ResizeControlBar.tsx +313 -0
  1618. package/analyzer-template/packages/ui-components/src/components/ScenarioDetailInteractiveView.tsx +322 -0
  1619. package/analyzer-template/packages/ui-components/src/components/ScenarioPreview.tsx +232 -0
  1620. package/analyzer-template/packages/ui-components/src/components/ScenarioThumbnails.tsx +82 -0
  1621. package/analyzer-template/packages/ui-components/src/components/ScreenSizeSelector.tsx +45 -0
  1622. package/analyzer-template/packages/ui-components/src/index.tsx +61 -0
  1623. package/analyzer-template/packages/ui-components/src/providers/WebContainerProvider.tsx +105 -0
  1624. package/analyzer-template/packages/ui-components/src/scenario-editor/components/AIDataGeneratorForm.tsx +139 -0
  1625. package/analyzer-template/packages/ui-components/src/scenario-editor/components/BooleanSwitch.tsx +42 -0
  1626. package/analyzer-template/packages/ui-components/src/scenario-editor/components/DataItemEditor.tsx +132 -0
  1627. package/analyzer-template/packages/ui-components/src/scenario-editor/components/DataItemLink.tsx +80 -0
  1628. package/analyzer-template/packages/ui-components/src/scenario-editor/components/DataItemNavigation.tsx +107 -0
  1629. package/analyzer-template/packages/ui-components/src/scenario-editor/components/InputField.tsx +67 -0
  1630. package/analyzer-template/packages/ui-components/src/scenario-editor/components/ScenarioEditor.tsx +401 -0
  1631. package/analyzer-template/packages/ui-components/src/scenario-editor/components/ScenarioNameForm.tsx +52 -0
  1632. package/analyzer-template/packages/ui-components/src/scenario-editor/components/SectionExpand.tsx +55 -0
  1633. package/analyzer-template/packages/ui-components/src/scenario-editor/components/UnionTypeOptionDropdown.tsx +38 -0
  1634. package/analyzer-template/packages/ui-components/src/scenario-editor/index.ts +35 -0
  1635. package/analyzer-template/packages/ui-components/src/scenario-editor/types.ts +127 -0
  1636. package/analyzer-template/packages/ui-components/src/scenario-editor/utils.ts +72 -0
  1637. package/analyzer-template/packages/ui-components/tsconfig.json +23 -0
  1638. package/analyzer-template/packages/utils/dist/types/index.d.ts +47 -0
  1639. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -0
  1640. package/analyzer-template/packages/utils/dist/types/index.js +4 -0
  1641. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -0
  1642. package/analyzer-template/packages/utils/dist/types/src/constants.d.ts +2 -0
  1643. package/analyzer-template/packages/utils/dist/types/src/constants.d.ts.map +1 -0
  1644. package/analyzer-template/packages/utils/dist/types/src/constants.js +2 -0
  1645. package/analyzer-template/packages/utils/dist/types/src/constants.js.map +1 -0
  1646. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +11 -0
  1647. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -0
  1648. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +12 -0
  1649. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -0
  1650. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +207 -0
  1651. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -0
  1652. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.js +3 -0
  1653. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.js.map +1 -0
  1654. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.d.ts +15 -0
  1655. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.d.ts.map +1 -0
  1656. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.js +2 -0
  1657. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisBranch.js.map +1 -0
  1658. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.d.ts +12 -0
  1659. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.d.ts.map +1 -0
  1660. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.js +2 -0
  1661. package/analyzer-template/packages/utils/dist/types/src/types/AnalysisMap.js.map +1 -0
  1662. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.d.ts +19 -0
  1663. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.d.ts.map +1 -0
  1664. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.js +2 -0
  1665. package/analyzer-template/packages/utils/dist/types/src/types/BackgroundJob.js.map +1 -0
  1666. package/analyzer-template/packages/utils/dist/types/src/types/Branch.d.ts +43 -0
  1667. package/analyzer-template/packages/utils/dist/types/src/types/Branch.d.ts.map +1 -0
  1668. package/analyzer-template/packages/utils/dist/types/src/types/Branch.js +2 -0
  1669. package/analyzer-template/packages/utils/dist/types/src/types/Branch.js.map +1 -0
  1670. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.d.ts +4 -0
  1671. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.d.ts.map +1 -0
  1672. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.js +2 -0
  1673. package/analyzer-template/packages/utils/dist/types/src/types/CodeExplanation.js.map +1 -0
  1674. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +88 -0
  1675. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -0
  1676. package/analyzer-template/packages/utils/dist/types/src/types/Commit.js +2 -0
  1677. package/analyzer-template/packages/utils/dist/types/src/types/Commit.js.map +1 -0
  1678. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.d.ts +11 -0
  1679. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.d.ts.map +1 -0
  1680. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.js +2 -0
  1681. package/analyzer-template/packages/utils/dist/types/src/types/CommitBranch.js.map +1 -0
  1682. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.d.ts +9 -0
  1683. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.d.ts.map +1 -0
  1684. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.js +2 -0
  1685. package/analyzer-template/packages/utils/dist/types/src/types/CommitChange.js.map +1 -0
  1686. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.d.ts +4 -0
  1687. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.d.ts.map +1 -0
  1688. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.js +2 -0
  1689. package/analyzer-template/packages/utils/dist/types/src/types/DeepPartial.js.map +1 -0
  1690. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.d.ts +4 -0
  1691. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.d.ts.map +1 -0
  1692. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.js +2 -0
  1693. package/analyzer-template/packages/utils/dist/types/src/types/DeepReadonly.js.map +1 -0
  1694. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.d.ts +8 -0
  1695. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.d.ts.map +1 -0
  1696. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.js +2 -0
  1697. package/analyzer-template/packages/utils/dist/types/src/types/DependencyTreeNode.js.map +1 -0
  1698. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +100 -0
  1699. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -0
  1700. package/analyzer-template/packages/utils/dist/types/src/types/Entity.js +2 -0
  1701. package/analyzer-template/packages/utils/dist/types/src/types/Entity.js.map +1 -0
  1702. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.d.ts +8 -0
  1703. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.d.ts.map +1 -0
  1704. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.js +2 -0
  1705. package/analyzer-template/packages/utils/dist/types/src/types/EntityBranch.js.map +1 -0
  1706. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.d.ts +7 -0
  1707. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.d.ts.map +1 -0
  1708. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.js +2 -0
  1709. package/analyzer-template/packages/utils/dist/types/src/types/EntityMap.js.map +1 -0
  1710. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.d.ts +2 -0
  1711. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.d.ts.map +1 -0
  1712. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.js +2 -0
  1713. package/analyzer-template/packages/utils/dist/types/src/types/EntityType.js.map +1 -0
  1714. package/analyzer-template/packages/utils/dist/types/src/types/File.d.ts +45 -0
  1715. package/analyzer-template/packages/utils/dist/types/src/types/File.d.ts.map +1 -0
  1716. package/analyzer-template/packages/utils/dist/types/src/types/File.js +2 -0
  1717. package/analyzer-template/packages/utils/dist/types/src/types/File.js.map +1 -0
  1718. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.d.ts +7 -0
  1719. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.d.ts.map +1 -0
  1720. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.js +2 -0
  1721. package/analyzer-template/packages/utils/dist/types/src/types/FilePreMock.js.map +1 -0
  1722. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.d.ts +8 -0
  1723. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.d.ts.map +1 -0
  1724. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.js +2 -0
  1725. package/analyzer-template/packages/utils/dist/types/src/types/FileProp.js.map +1 -0
  1726. package/analyzer-template/packages/utils/dist/types/src/types/FileType.d.ts +2 -0
  1727. package/analyzer-template/packages/utils/dist/types/src/types/FileType.d.ts.map +1 -0
  1728. package/analyzer-template/packages/utils/dist/types/src/types/FileType.js +2 -0
  1729. package/analyzer-template/packages/utils/dist/types/src/types/FileType.js.map +1 -0
  1730. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.d.ts +7 -0
  1731. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.d.ts.map +1 -0
  1732. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.js +2 -0
  1733. package/analyzer-template/packages/utils/dist/types/src/types/GithubBranch.js.map +1 -0
  1734. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.d.ts +9 -0
  1735. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.d.ts.map +1 -0
  1736. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.js +2 -0
  1737. package/analyzer-template/packages/utils/dist/types/src/types/GithubFile.js.map +1 -0
  1738. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.d.ts +9 -0
  1739. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.d.ts.map +1 -0
  1740. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.js +2 -0
  1741. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoData.js.map +1 -0
  1742. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.d.ts +15 -0
  1743. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.d.ts.map +1 -0
  1744. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.js +2 -0
  1745. package/analyzer-template/packages/utils/dist/types/src/types/GithubRepoInfo.js.map +1 -0
  1746. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.d.ts +4 -0
  1747. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.d.ts.map +1 -0
  1748. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.js +2 -0
  1749. package/analyzer-template/packages/utils/dist/types/src/types/JsonTypeDefinition.js.map +1 -0
  1750. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.d.ts +5 -0
  1751. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.d.ts.map +1 -0
  1752. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.js +2 -0
  1753. package/analyzer-template/packages/utils/dist/types/src/types/LlmCall.js.map +1 -0
  1754. package/analyzer-template/packages/utils/dist/types/src/types/Mock.d.ts +35 -0
  1755. package/analyzer-template/packages/utils/dist/types/src/types/Mock.d.ts.map +1 -0
  1756. package/analyzer-template/packages/utils/dist/types/src/types/Mock.js +2 -0
  1757. package/analyzer-template/packages/utils/dist/types/src/types/Mock.js.map +1 -0
  1758. package/analyzer-template/packages/utils/dist/types/src/types/Project.d.ts +26 -0
  1759. package/analyzer-template/packages/utils/dist/types/src/types/Project.d.ts.map +1 -0
  1760. package/analyzer-template/packages/utils/dist/types/src/types/Project.js +2 -0
  1761. package/analyzer-template/packages/utils/dist/types/src/types/Project.js.map +1 -0
  1762. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +54 -0
  1763. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -0
  1764. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.js +2 -0
  1765. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.js.map +1 -0
  1766. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.d.ts +8 -0
  1767. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.d.ts.map +1 -0
  1768. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.js +2 -0
  1769. package/analyzer-template/packages/utils/dist/types/src/types/PropsWithTypes.js.map +1 -0
  1770. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +127 -0
  1771. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -0
  1772. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js +2 -0
  1773. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js.map +1 -0
  1774. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.d.ts +12 -0
  1775. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.d.ts.map +1 -0
  1776. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.js +2 -0
  1777. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioComment.js.map +1 -0
  1778. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.d.ts +13 -0
  1779. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.d.ts.map +1 -0
  1780. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.js +2 -0
  1781. package/analyzer-template/packages/utils/dist/types/src/types/ScenarioData.js.map +1 -0
  1782. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +270 -0
  1783. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -0
  1784. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.js +2 -0
  1785. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.js.map +1 -0
  1786. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +18 -0
  1787. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -0
  1788. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.js +2 -0
  1789. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.js.map +1 -0
  1790. package/analyzer-template/packages/utils/dist/types/src/types/Statement.d.ts +11 -0
  1791. package/analyzer-template/packages/utils/dist/types/src/types/Statement.d.ts.map +1 -0
  1792. package/analyzer-template/packages/utils/dist/types/src/types/Statement.js +2 -0
  1793. package/analyzer-template/packages/utils/dist/types/src/types/Statement.js.map +1 -0
  1794. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +14 -0
  1795. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -0
  1796. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.js +2 -0
  1797. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.js.map +1 -0
  1798. package/analyzer-template/packages/utils/dist/types/src/types/Team.d.ts +5 -0
  1799. package/analyzer-template/packages/utils/dist/types/src/types/Team.d.ts.map +1 -0
  1800. package/analyzer-template/packages/utils/dist/types/src/types/Team.js +2 -0
  1801. package/analyzer-template/packages/utils/dist/types/src/types/Team.js.map +1 -0
  1802. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.d.ts +17 -0
  1803. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.d.ts.map +1 -0
  1804. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.js +2 -0
  1805. package/analyzer-template/packages/utils/dist/types/src/types/TimelineItem.js.map +1 -0
  1806. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.d.ts +2 -0
  1807. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.d.ts.map +1 -0
  1808. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.js +2 -0
  1809. package/analyzer-template/packages/utils/dist/types/src/types/TsConfigPaths.js.map +1 -0
  1810. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.d.ts +5 -0
  1811. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.d.ts.map +1 -0
  1812. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.js +2 -0
  1813. package/analyzer-template/packages/utils/dist/types/src/types/TypeStructures.js.map +1 -0
  1814. package/analyzer-template/packages/utils/dist/types/src/types/User.d.ts +7 -0
  1815. package/analyzer-template/packages/utils/dist/types/src/types/User.d.ts.map +1 -0
  1816. package/analyzer-template/packages/utils/dist/types/src/types/User.js +2 -0
  1817. package/analyzer-template/packages/utils/dist/types/src/types/User.js.map +1 -0
  1818. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.d.ts +10 -0
  1819. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.d.ts.map +1 -0
  1820. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.js +2 -0
  1821. package/analyzer-template/packages/utils/dist/types/src/types/UserScenario.js.map +1 -0
  1822. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.d.ts +14 -0
  1823. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.d.ts.map +1 -0
  1824. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.js +2 -0
  1825. package/analyzer-template/packages/utils/dist/types/src/types/WebContainerFileSystemTree.js.map +1 -0
  1826. package/analyzer-template/packages/utils/dist/utils/index.d.ts +24 -0
  1827. package/analyzer-template/packages/utils/dist/utils/index.d.ts.map +1 -0
  1828. package/analyzer-template/packages/utils/dist/utils/index.js +31 -0
  1829. package/analyzer-template/packages/utils/dist/utils/index.js.map +1 -0
  1830. package/analyzer-template/packages/utils/dist/utils/server.d.ts +12 -0
  1831. package/analyzer-template/packages/utils/dist/utils/server.d.ts.map +1 -0
  1832. package/analyzer-template/packages/utils/dist/utils/server.js +13 -0
  1833. package/analyzer-template/packages/utils/dist/utils/server.js.map +1 -0
  1834. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.d.ts +25 -0
  1835. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.d.ts.map +1 -0
  1836. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.js +40 -0
  1837. package/analyzer-template/packages/utils/dist/utils/src/lib/Semaphore.js.map +1 -0
  1838. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.d.ts +2 -0
  1839. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.d.ts.map +1 -0
  1840. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.js +5 -0
  1841. package/analyzer-template/packages/utils/dist/utils/src/lib/__mocks__/killProcess.server.js.map +1 -0
  1842. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.d.ts +12 -0
  1843. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.d.ts.map +1 -0
  1844. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.js +10 -0
  1845. package/analyzer-template/packages/utils/dist/utils/src/lib/analyses/pushAnalysisError.js.map +1 -0
  1846. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.d.ts +61 -0
  1847. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -0
  1848. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js +288 -0
  1849. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js.map +1 -0
  1850. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.d.ts +8 -0
  1851. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.d.ts.map +1 -0
  1852. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.js +48 -0
  1853. package/analyzer-template/packages/utils/dist/utils/src/lib/awsLog.js.map +1 -0
  1854. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.d.ts +3 -0
  1855. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.d.ts.map +1 -0
  1856. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.js +14 -0
  1857. package/analyzer-template/packages/utils/dist/utils/src/lib/commitRuns.js.map +1 -0
  1858. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.d.ts +34 -0
  1859. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.d.ts.map +1 -0
  1860. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.js +217 -0
  1861. package/analyzer-template/packages/utils/dist/utils/src/lib/env/detectEnvFiles.js.map +1 -0
  1862. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.d.ts +3 -0
  1863. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.d.ts.map +1 -0
  1864. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.js +3 -0
  1865. package/analyzer-template/packages/utils/dist/utils/src/lib/env/index.js.map +1 -0
  1866. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.d.ts +25 -0
  1867. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.d.ts.map +1 -0
  1868. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.js +145 -0
  1869. package/analyzer-template/packages/utils/dist/utils/src/lib/env/sanitizeEnvFiles.js.map +1 -0
  1870. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts +15 -0
  1871. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts.map +1 -0
  1872. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +25 -0
  1873. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -0
  1874. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts +15 -0
  1875. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.d.ts.map +1 -0
  1876. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js +29 -0
  1877. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getFrameworkRoutePath.js.map +1 -0
  1878. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts +13 -0
  1879. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.d.ts.map +1 -0
  1880. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.js +22 -0
  1881. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getNextRoutePath.js.map +1 -0
  1882. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts +13 -0
  1883. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.d.ts.map +1 -0
  1884. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.js +20 -0
  1885. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/getRemixRoutePath.js.map +1 -0
  1886. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts +3 -0
  1887. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.d.ts.map +1 -0
  1888. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.js +7 -0
  1889. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isFrameworkRoute.js.map +1 -0
  1890. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.d.ts +3 -0
  1891. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.d.ts.map +1 -0
  1892. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.js +12 -0
  1893. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isNextRoute.js.map +1 -0
  1894. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.d.ts +3 -0
  1895. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.d.ts.map +1 -0
  1896. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.js +8 -0
  1897. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/isRemixRoute.js.map +1 -0
  1898. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts +14 -0
  1899. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts.map +1 -0
  1900. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +26 -0
  1901. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -0
  1902. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts +3 -0
  1903. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.d.ts.map +1 -0
  1904. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js +22 -0
  1905. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/remixRouteFileNameToRoute.js.map +1 -0
  1906. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts +21 -0
  1907. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts.map +1 -0
  1908. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +62 -0
  1909. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -0
  1910. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.d.ts +9 -0
  1911. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.d.ts.map +1 -0
  1912. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.js +181 -0
  1913. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/copyNodeRepoQuickly.js.map +1 -0
  1914. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +9 -0
  1915. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -0
  1916. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +136 -0
  1917. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -0
  1918. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.d.ts +16 -0
  1919. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.d.ts.map +1 -0
  1920. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.js +64 -0
  1921. package/analyzer-template/packages/utils/dist/utils/src/lib/getFrameworkForFile.js.map +1 -0
  1922. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.d.ts +6 -0
  1923. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.d.ts.map +1 -0
  1924. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.js +102 -0
  1925. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcess.server.js.map +1 -0
  1926. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.d.ts +12 -0
  1927. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.d.ts.map +1 -0
  1928. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.js +62 -0
  1929. package/analyzer-template/packages/utils/dist/utils/src/lib/killProcessAndSubprocesses.server.js.map +1 -0
  1930. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.d.ts +32 -0
  1931. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -0
  1932. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js +362 -0
  1933. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -0
  1934. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.d.ts +2 -0
  1935. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.d.ts.map +1 -0
  1936. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.js +7 -0
  1937. package/analyzer-template/packages/utils/dist/utils/src/lib/loadEnv.js.map +1 -0
  1938. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.d.ts +2 -0
  1939. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.d.ts.map +1 -0
  1940. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.js +4 -0
  1941. package/analyzer-template/packages/utils/dist/utils/src/lib/normalizeKey.js.map +1 -0
  1942. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +10 -0
  1943. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -0
  1944. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +36 -0
  1945. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -0
  1946. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.d.ts +2 -0
  1947. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.d.ts.map +1 -0
  1948. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.js +64 -0
  1949. package/analyzer-template/packages/utils/dist/utils/src/lib/safeStringify.js.map +1 -0
  1950. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.d.ts +18 -0
  1951. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.d.ts.map +1 -0
  1952. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  1953. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  1954. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.d.ts +26 -0
  1955. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.d.ts.map +1 -0
  1956. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  1957. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  1958. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.d.ts +3 -0
  1959. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.d.ts.map +1 -0
  1960. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.js +3 -0
  1961. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.js.map +1 -0
  1962. package/analyzer-template/packages/utils/index.ts +60 -0
  1963. package/analyzer-template/packages/utils/package.json +14 -0
  1964. package/analyzer-template/packages/utils/server.ts +26 -0
  1965. package/analyzer-template/packages/utils/src/lib/Semaphore.ts +42 -0
  1966. package/analyzer-template/packages/utils/src/lib/__mocks__/killProcess.server.ts +4 -0
  1967. package/analyzer-template/packages/utils/src/lib/analyses/pushAnalysisError.ts +21 -0
  1968. package/analyzer-template/packages/utils/src/lib/applyUniversalMocks.ts +449 -0
  1969. package/analyzer-template/packages/utils/src/lib/awsLog.ts +60 -0
  1970. package/analyzer-template/packages/utils/src/lib/commitRuns.ts +16 -0
  1971. package/analyzer-template/packages/utils/src/lib/env/detectEnvFiles.ts +287 -0
  1972. package/analyzer-template/packages/utils/src/lib/env/index.ts +15 -0
  1973. package/analyzer-template/packages/utils/src/lib/env/sanitizeEnvFiles.ts +203 -0
  1974. package/analyzer-template/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.ts +40 -0
  1975. package/analyzer-template/packages/utils/src/lib/frameworks/getFrameworkRoutePath.ts +58 -0
  1976. package/analyzer-template/packages/utils/src/lib/frameworks/getNextRoutePath.ts +54 -0
  1977. package/analyzer-template/packages/utils/src/lib/frameworks/getRemixRoutePath.ts +52 -0
  1978. package/analyzer-template/packages/utils/src/lib/frameworks/isFrameworkRoute.ts +15 -0
  1979. package/analyzer-template/packages/utils/src/lib/frameworks/isNextRoute.ts +20 -0
  1980. package/analyzer-template/packages/utils/src/lib/frameworks/isRemixRoute.ts +14 -0
  1981. package/analyzer-template/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.ts +36 -0
  1982. package/analyzer-template/packages/utils/src/lib/frameworks/remixRouteFileNameToRoute.ts +28 -0
  1983. package/analyzer-template/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.ts +67 -0
  1984. package/analyzer-template/packages/utils/src/lib/fs/copyNodeRepoQuickly.ts +241 -0
  1985. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +182 -0
  1986. package/analyzer-template/packages/utils/src/lib/getFrameworkForFile.ts +92 -0
  1987. package/analyzer-template/packages/utils/src/lib/killProcess.server.ts +134 -0
  1988. package/analyzer-template/packages/utils/src/lib/killProcessAndSubprocesses.server.ts +76 -0
  1989. package/analyzer-template/packages/utils/src/lib/lightweightEntityExtractor.ts +457 -0
  1990. package/analyzer-template/packages/utils/src/lib/loadEnv.ts +7 -0
  1991. package/analyzer-template/packages/utils/src/lib/normalizeKey.ts +3 -0
  1992. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +55 -0
  1993. package/analyzer-template/packages/utils/src/lib/safeStringify.ts +68 -0
  1994. package/analyzer-template/packages/utils/src/lib/startCommand/buildStartCommand.ts +63 -0
  1995. package/analyzer-template/packages/utils/src/lib/startCommand/getWebappInfo.ts +108 -0
  1996. package/analyzer-template/packages/utils/src/lib/startCommand/index.ts +10 -0
  1997. package/analyzer-template/packages/utils/tsconfig.json +11 -0
  1998. package/analyzer-template/playwright/capture.ts +1007 -0
  1999. package/analyzer-template/playwright/captureFromUrl.ts +259 -0
  2000. package/analyzer-template/playwright/capturePageWithPlaywright.ts +204 -0
  2001. package/analyzer-template/playwright/captureScreenshotLite.ts +201 -0
  2002. package/analyzer-template/playwright/captureStatic.ts +137 -0
  2003. package/analyzer-template/playwright/checkURL.ts +67 -0
  2004. package/analyzer-template/playwright/compareImages.ts +149 -0
  2005. package/analyzer-template/playwright/compareTwoImagesFromS3.ts +43 -0
  2006. package/analyzer-template/playwright/downloadImageFromS3.ts +58 -0
  2007. package/analyzer-template/playwright/downloadPage.ts +413 -0
  2008. package/analyzer-template/playwright/executeInstuctions.ts +119 -0
  2009. package/analyzer-template/playwright/findStep.ts +6 -0
  2010. package/analyzer-template/playwright/generateStaticBuild.ts +185 -0
  2011. package/analyzer-template/playwright/getCodeYamInfo.ts +103 -0
  2012. package/analyzer-template/playwright/invalidateCloudFrontPath.ts +46 -0
  2013. package/analyzer-template/playwright/takeElementScreenshot.ts +505 -0
  2014. package/analyzer-template/playwright/takeScreenshot.ts +271 -0
  2015. package/analyzer-template/playwright/taskComplete.ts +12 -0
  2016. package/analyzer-template/playwright/updateBackgroundJob.ts +43 -0
  2017. package/analyzer-template/playwright/uploadAssets.ts +118 -0
  2018. package/analyzer-template/playwright/waitForNoServer.ts +16 -0
  2019. package/analyzer-template/playwright/waitForServer.ts +98 -0
  2020. package/analyzer-template/project/LazyFileStore.ts +537 -0
  2021. package/analyzer-template/project/ScenarioIterator.ts +133 -0
  2022. package/analyzer-template/project/TESTING.md +83 -0
  2023. package/analyzer-template/project/analyzeAndGatherIndirectEntities.ts +131 -0
  2024. package/analyzer-template/project/analyzeBaselineCommit.ts +195 -0
  2025. package/analyzer-template/project/analyzeBranchCommit.ts +260 -0
  2026. package/analyzer-template/project/analyzeFileEntities.ts +286 -0
  2027. package/analyzer-template/project/analyzeReadyToBeCaptured.ts +51 -0
  2028. package/analyzer-template/project/analyzeRegularCommit.ts +285 -0
  2029. package/analyzer-template/project/backupFiles.ts +129 -0
  2030. package/analyzer-template/project/buildCliArgs.ts +15 -0
  2031. package/analyzer-template/project/buildProject.ts +46 -0
  2032. package/analyzer-template/project/captureLibraryFunctionDirect.ts +144 -0
  2033. package/analyzer-template/project/checkApprovedPath.ts +39 -0
  2034. package/analyzer-template/project/checkConsistentAnalyses.ts +58 -0
  2035. package/analyzer-template/project/checkConsistentEntities.ts +55 -0
  2036. package/analyzer-template/project/clearExtension.ts +9 -0
  2037. package/analyzer-template/project/cloneGitRepoAtCommit.ts +59 -0
  2038. package/analyzer-template/project/constructMockCode.ts +2631 -0
  2039. package/analyzer-template/project/controller/startController.ts +212 -0
  2040. package/analyzer-template/project/createEntitiesAndSortFiles.ts +330 -0
  2041. package/analyzer-template/project/emailErrorReport.ts +78 -0
  2042. package/analyzer-template/project/executeLibraryFunctionDirect.ts +182 -0
  2043. package/analyzer-template/project/generateCodeYamPage.ts +240 -0
  2044. package/analyzer-template/project/generateScenarioPage.ts +56 -0
  2045. package/analyzer-template/project/getAppPath.ts +84 -0
  2046. package/analyzer-template/project/getCodeYamPagePath.ts +101 -0
  2047. package/analyzer-template/project/getFilesWithEntitiesFromRepo.ts +213 -0
  2048. package/analyzer-template/project/getScenarioPagePath.ts +119 -0
  2049. package/analyzer-template/project/getScenarioUrl.ts +137 -0
  2050. package/analyzer-template/project/loadReadyToBeCaptured.ts +336 -0
  2051. package/analyzer-template/project/mocks/analyzeFileMock.ts +436 -0
  2052. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +302 -0
  2053. package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +154 -0
  2054. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +410 -0
  2055. package/analyzer-template/project/orchestrateCapture/SupabaseAnalysisLoader.ts +85 -0
  2056. package/analyzer-template/project/orchestrateCapture/spawnTaskProcess.ts +112 -0
  2057. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +123 -0
  2058. package/analyzer-template/project/orchestrateCapture.ts +483 -0
  2059. package/analyzer-template/project/prepareRepo.ts +106 -0
  2060. package/analyzer-template/project/reconcileMockDataKeys.ts +392 -0
  2061. package/analyzer-template/project/removeScenario.ts +9 -0
  2062. package/analyzer-template/project/removeStrictFlagFromTsConfig.ts +37 -0
  2063. package/analyzer-template/project/replaceImportLineContainingSubstring.ts +23 -0
  2064. package/analyzer-template/project/runAnalysis.ts +373 -0
  2065. package/analyzer-template/project/runMultiScenarioServer.ts +564 -0
  2066. package/analyzer-template/project/runScenarioServer.ts +379 -0
  2067. package/analyzer-template/project/serverOnlyModules.ts +413 -0
  2068. package/analyzer-template/project/start.ts +662 -0
  2069. package/analyzer-template/project/startScenarioCapture.ts +779 -0
  2070. package/analyzer-template/project/startServer.ts +168 -0
  2071. package/analyzer-template/project/trackGeneratedFiles.ts +41 -0
  2072. package/analyzer-template/project/updateCommitBackgroundJob.ts +16 -0
  2073. package/analyzer-template/project/utils/errorHandling.ts +48 -0
  2074. package/analyzer-template/project/utils/mergeEnvVarsIntoStartCommand.ts +50 -0
  2075. package/analyzer-template/project/utils/webappMapping.ts +95 -0
  2076. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  2077. package/analyzer-template/project/writeCodeYamPage.ts +32 -0
  2078. package/analyzer-template/project/writeEnv.ts +54 -0
  2079. package/analyzer-template/project/writeLibComponent.ts +50 -0
  2080. package/analyzer-template/project/writeMockDataTsx.ts +1451 -0
  2081. package/analyzer-template/project/writeScenario.ts +112 -0
  2082. package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
  2083. package/analyzer-template/project/writeScenarioComponents.ts +3129 -0
  2084. package/analyzer-template/project/writeScenarioFiles.ts +139 -0
  2085. package/analyzer-template/project/writeScenarioPage.ts +59 -0
  2086. package/analyzer-template/project/writeSimpleRoot.ts +566 -0
  2087. package/analyzer-template/project/writeUniversalMocks.ts +250 -0
  2088. package/analyzer-template/scripts/comboWorkerLoop.cjs +523 -0
  2089. package/analyzer-template/scripts/defaultCmd.sh +9 -0
  2090. package/analyzer-template/scripts/mergePackageJsonFiles.cjs +81 -0
  2091. package/analyzer-template/scripts/postbuild.cjs +106 -0
  2092. package/analyzer-template/tsconfig.json +32 -0
  2093. package/background/src/lib/copyFolderToArchive.js +34 -0
  2094. package/background/src/lib/copyFolderToArchive.js.map +1 -0
  2095. package/background/src/lib/local/createLocalAnalyzer.js +132 -0
  2096. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -0
  2097. package/background/src/lib/local/execAsync.js +100 -0
  2098. package/background/src/lib/local/execAsync.js.map +1 -0
  2099. package/background/src/lib/virtualized/common/closePort.js +17 -0
  2100. package/background/src/lib/virtualized/common/closePort.js.map +1 -0
  2101. package/background/src/lib/virtualized/common/constants.js +3 -0
  2102. package/background/src/lib/virtualized/common/constants.js.map +1 -0
  2103. package/background/src/lib/virtualized/common/copy.js +16 -0
  2104. package/background/src/lib/virtualized/common/copy.js.map +1 -0
  2105. package/background/src/lib/virtualized/common/execAsync.js +116 -0
  2106. package/background/src/lib/virtualized/common/execAsync.js.map +1 -0
  2107. package/background/src/lib/virtualized/common/getPID.js +40 -0
  2108. package/background/src/lib/virtualized/common/getPID.js.map +1 -0
  2109. package/background/src/lib/virtualized/common/measureAndRepordExecutionTime.js +9 -0
  2110. package/background/src/lib/virtualized/common/measureAndRepordExecutionTime.js.map +1 -0
  2111. package/background/src/lib/virtualized/common/measureExecutionTime.js +11 -0
  2112. package/background/src/lib/virtualized/common/measureExecutionTime.js.map +1 -0
  2113. package/background/src/lib/virtualized/common/openPage.js +20 -0
  2114. package/background/src/lib/virtualized/common/openPage.js.map +1 -0
  2115. package/background/src/lib/virtualized/common/readFile.js +21 -0
  2116. package/background/src/lib/virtualized/common/readFile.js.map +1 -0
  2117. package/background/src/lib/virtualized/common/writeFile.js +24 -0
  2118. package/background/src/lib/virtualized/common/writeFile.js.map +1 -0
  2119. package/background/src/lib/virtualized/project/LazyFileStore.js +421 -0
  2120. package/background/src/lib/virtualized/project/LazyFileStore.js.map +1 -0
  2121. package/background/src/lib/virtualized/project/ScenarioIterator.js +102 -0
  2122. package/background/src/lib/virtualized/project/ScenarioIterator.js.map +1 -0
  2123. package/background/src/lib/virtualized/project/analyzeAndGatherIndirectEntities.js +88 -0
  2124. package/background/src/lib/virtualized/project/analyzeAndGatherIndirectEntities.js.map +1 -0
  2125. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +114 -0
  2126. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -0
  2127. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +181 -0
  2128. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -0
  2129. package/background/src/lib/virtualized/project/analyzeFileEntities.js +193 -0
  2130. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -0
  2131. package/background/src/lib/virtualized/project/analyzeReadyToBeCaptured.js +22 -0
  2132. package/background/src/lib/virtualized/project/analyzeReadyToBeCaptured.js.map +1 -0
  2133. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +178 -0
  2134. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -0
  2135. package/background/src/lib/virtualized/project/backupFiles.js +114 -0
  2136. package/background/src/lib/virtualized/project/backupFiles.js.map +1 -0
  2137. package/background/src/lib/virtualized/project/buildCliArgs.js +18 -0
  2138. package/background/src/lib/virtualized/project/buildCliArgs.js.map +1 -0
  2139. package/background/src/lib/virtualized/project/buildProject.js +37 -0
  2140. package/background/src/lib/virtualized/project/buildProject.js.map +1 -0
  2141. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +107 -0
  2142. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -0
  2143. package/background/src/lib/virtualized/project/checkApprovedPath.js +25 -0
  2144. package/background/src/lib/virtualized/project/checkApprovedPath.js.map +1 -0
  2145. package/background/src/lib/virtualized/project/checkConsistentAnalyses.js +34 -0
  2146. package/background/src/lib/virtualized/project/checkConsistentAnalyses.js.map +1 -0
  2147. package/background/src/lib/virtualized/project/checkConsistentEntities.js +37 -0
  2148. package/background/src/lib/virtualized/project/checkConsistentEntities.js.map +1 -0
  2149. package/background/src/lib/virtualized/project/cloneGitRepoAtCommit.js +38 -0
  2150. package/background/src/lib/virtualized/project/cloneGitRepoAtCommit.js.map +1 -0
  2151. package/background/src/lib/virtualized/project/constructMockCode.js +2224 -0
  2152. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -0
  2153. package/background/src/lib/virtualized/project/controller/startController.js +149 -0
  2154. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -0
  2155. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +221 -0
  2156. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -0
  2157. package/background/src/lib/virtualized/project/emailErrorReport.js +50 -0
  2158. package/background/src/lib/virtualized/project/emailErrorReport.js.map +1 -0
  2159. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +157 -0
  2160. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -0
  2161. package/background/src/lib/virtualized/project/generateCodeYamPage.js +213 -0
  2162. package/background/src/lib/virtualized/project/generateCodeYamPage.js.map +1 -0
  2163. package/background/src/lib/virtualized/project/generateScenarioPage.js +27 -0
  2164. package/background/src/lib/virtualized/project/generateScenarioPage.js.map +1 -0
  2165. package/background/src/lib/virtualized/project/getAppPath.js +79 -0
  2166. package/background/src/lib/virtualized/project/getAppPath.js.map +1 -0
  2167. package/background/src/lib/virtualized/project/getCodeYamPagePath.js +56 -0
  2168. package/background/src/lib/virtualized/project/getCodeYamPagePath.js.map +1 -0
  2169. package/background/src/lib/virtualized/project/getFilesWithEntitiesFromRepo.js +161 -0
  2170. package/background/src/lib/virtualized/project/getFilesWithEntitiesFromRepo.js.map +1 -0
  2171. package/background/src/lib/virtualized/project/getScenarioPagePath.js +62 -0
  2172. package/background/src/lib/virtualized/project/getScenarioPagePath.js.map +1 -0
  2173. package/background/src/lib/virtualized/project/getScenarioUrl.js +87 -0
  2174. package/background/src/lib/virtualized/project/getScenarioUrl.js.map +1 -0
  2175. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +217 -0
  2176. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -0
  2177. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +368 -0
  2178. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -0
  2179. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +196 -0
  2180. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -0
  2181. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +115 -0
  2182. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -0
  2183. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +293 -0
  2184. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -0
  2185. package/background/src/lib/virtualized/project/orchestrateCapture/spawnTaskProcess.js +71 -0
  2186. package/background/src/lib/virtualized/project/orchestrateCapture/spawnTaskProcess.js.map +1 -0
  2187. package/background/src/lib/virtualized/project/orchestrateCapture/taskRunner.js +2 -0
  2188. package/background/src/lib/virtualized/project/orchestrateCapture/taskRunner.js.map +1 -0
  2189. package/background/src/lib/virtualized/project/orchestrateCapture.js +347 -0
  2190. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -0
  2191. package/background/src/lib/virtualized/project/prepareRepo.js +61 -0
  2192. package/background/src/lib/virtualized/project/prepareRepo.js.map +1 -0
  2193. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +335 -0
  2194. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -0
  2195. package/background/src/lib/virtualized/project/removeScenario.js +11 -0
  2196. package/background/src/lib/virtualized/project/removeScenario.js.map +1 -0
  2197. package/background/src/lib/virtualized/project/removeStrictFlagFromTsConfig.js +32 -0
  2198. package/background/src/lib/virtualized/project/removeStrictFlagFromTsConfig.js.map +1 -0
  2199. package/background/src/lib/virtualized/project/runAnalysis.js +262 -0
  2200. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -0
  2201. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +426 -0
  2202. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -0
  2203. package/background/src/lib/virtualized/project/serverOnlyModules.js +338 -0
  2204. package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -0
  2205. package/background/src/lib/virtualized/project/start.js +515 -0
  2206. package/background/src/lib/virtualized/project/start.js.map +1 -0
  2207. package/background/src/lib/virtualized/project/startScenarioCapture.js +535 -0
  2208. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -0
  2209. package/background/src/lib/virtualized/project/startServer.js +128 -0
  2210. package/background/src/lib/virtualized/project/startServer.js.map +1 -0
  2211. package/background/src/lib/virtualized/project/trackGeneratedFiles.js +30 -0
  2212. package/background/src/lib/virtualized/project/trackGeneratedFiles.js.map +1 -0
  2213. package/background/src/lib/virtualized/project/updateCommitBackgroundJob.js +13 -0
  2214. package/background/src/lib/virtualized/project/updateCommitBackgroundJob.js.map +1 -0
  2215. package/background/src/lib/virtualized/project/utils/errorHandling.js +39 -0
  2216. package/background/src/lib/virtualized/project/utils/errorHandling.js.map +1 -0
  2217. package/background/src/lib/virtualized/project/utils/mergeEnvVarsIntoStartCommand.js +42 -0
  2218. package/background/src/lib/virtualized/project/utils/mergeEnvVarsIntoStartCommand.js.map +1 -0
  2219. package/background/src/lib/virtualized/project/utils/webappMapping.js +66 -0
  2220. package/background/src/lib/virtualized/project/utils/webappMapping.js.map +1 -0
  2221. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  2222. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  2223. package/background/src/lib/virtualized/project/writeCodeYamPage.js +23 -0
  2224. package/background/src/lib/virtualized/project/writeCodeYamPage.js.map +1 -0
  2225. package/background/src/lib/virtualized/project/writeEnv.js +43 -0
  2226. package/background/src/lib/virtualized/project/writeEnv.js.map +1 -0
  2227. package/background/src/lib/virtualized/project/writeLibComponent.js +19 -0
  2228. package/background/src/lib/virtualized/project/writeLibComponent.js.map +1 -0
  2229. package/background/src/lib/virtualized/project/writeMockDataTsx.js +1241 -0
  2230. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -0
  2231. package/background/src/lib/virtualized/project/writeScenario.js +58 -0
  2232. package/background/src/lib/virtualized/project/writeScenario.js.map +1 -0
  2233. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
  2234. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
  2235. package/background/src/lib/virtualized/project/writeScenarioComponents.js +2214 -0
  2236. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -0
  2237. package/background/src/lib/virtualized/project/writeScenarioFiles.js +81 -0
  2238. package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -0
  2239. package/background/src/lib/virtualized/project/writeScenarioPage.js +24 -0
  2240. package/background/src/lib/virtualized/project/writeScenarioPage.js.map +1 -0
  2241. package/background/src/lib/virtualized/project/writeSimpleRoot.js +409 -0
  2242. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -0
  2243. package/background/src/lib/virtualized/project/writeUniversalMocks.js +157 -0
  2244. package/background/src/lib/virtualized/project/writeUniversalMocks.js.map +1 -0
  2245. package/background/src/lib/writeFile.js +18 -0
  2246. package/background/src/lib/writeFile.js.map +1 -0
  2247. package/codeyam-cli/scripts/apply-setup.js +665 -0
  2248. package/codeyam-cli/scripts/apply-setup.js.map +1 -0
  2249. package/codeyam-cli/scripts/build-analyzer-template.js +174 -0
  2250. package/codeyam-cli/scripts/build-analyzer-template.js.map +1 -0
  2251. package/codeyam-cli/scripts/build-webserver-info.js +80 -0
  2252. package/codeyam-cli/scripts/build-webserver-info.js.map +1 -0
  2253. package/codeyam-cli/scripts/extract-setup.js +130 -0
  2254. package/codeyam-cli/scripts/extract-setup.js.map +1 -0
  2255. package/codeyam-cli/scripts/populateEntityTimestamps.js +72 -0
  2256. package/codeyam-cli/scripts/populateEntityTimestamps.js.map +1 -0
  2257. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  2258. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  2259. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  2260. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  2261. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  2262. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  2263. package/codeyam-cli/src/cli.js +87 -0
  2264. package/codeyam-cli/src/cli.js.map +1 -0
  2265. package/codeyam-cli/src/codeyam-cli.js +20 -0
  2266. package/codeyam-cli/src/codeyam-cli.js.map +1 -0
  2267. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +186 -0
  2268. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -0
  2269. package/codeyam-cli/src/commands/__tests__/init.unapprovedPaths.test.js +73 -0
  2270. package/codeyam-cli/src/commands/__tests__/init.unapprovedPaths.test.js.map +1 -0
  2271. package/codeyam-cli/src/commands/__tests__/suggest.test.js +161 -0
  2272. package/codeyam-cli/src/commands/__tests__/suggest.test.js.map +1 -0
  2273. package/codeyam-cli/src/commands/analyze.js +148 -0
  2274. package/codeyam-cli/src/commands/analyze.js.map +1 -0
  2275. package/codeyam-cli/src/commands/baseline.js +176 -0
  2276. package/codeyam-cli/src/commands/baseline.js.map +1 -0
  2277. package/codeyam-cli/src/commands/debug.js +253 -0
  2278. package/codeyam-cli/src/commands/debug.js.map +1 -0
  2279. package/codeyam-cli/src/commands/default.js +107 -0
  2280. package/codeyam-cli/src/commands/default.js.map +1 -0
  2281. package/codeyam-cli/src/commands/editor.js +3206 -0
  2282. package/codeyam-cli/src/commands/editor.js.map +1 -0
  2283. package/codeyam-cli/src/commands/entities.js +102 -0
  2284. package/codeyam-cli/src/commands/entities.js.map +1 -0
  2285. package/codeyam-cli/src/commands/generate-data-structure.js +251 -0
  2286. package/codeyam-cli/src/commands/generate-data-structure.js.map +1 -0
  2287. package/codeyam-cli/src/commands/init.js +273 -0
  2288. package/codeyam-cli/src/commands/init.js.map +1 -0
  2289. package/codeyam-cli/src/commands/memory.js +278 -0
  2290. package/codeyam-cli/src/commands/memory.js.map +1 -0
  2291. package/codeyam-cli/src/commands/queue.js +83 -0
  2292. package/codeyam-cli/src/commands/queue.js.map +1 -0
  2293. package/codeyam-cli/src/commands/recapture.js +228 -0
  2294. package/codeyam-cli/src/commands/recapture.js.map +1 -0
  2295. package/codeyam-cli/src/commands/report.js +150 -0
  2296. package/codeyam-cli/src/commands/report.js.map +1 -0
  2297. package/codeyam-cli/src/commands/setup-sandbox.js +167 -0
  2298. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -0
  2299. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  2300. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  2301. package/codeyam-cli/src/commands/start.js +68 -0
  2302. package/codeyam-cli/src/commands/start.js.map +1 -0
  2303. package/codeyam-cli/src/commands/status.js +134 -0
  2304. package/codeyam-cli/src/commands/status.js.map +1 -0
  2305. package/codeyam-cli/src/commands/stop.js +28 -0
  2306. package/codeyam-cli/src/commands/stop.js.map +1 -0
  2307. package/codeyam-cli/src/commands/suggest.js +299 -0
  2308. package/codeyam-cli/src/commands/suggest.js.map +1 -0
  2309. package/codeyam-cli/src/commands/suggestUtils.js +110 -0
  2310. package/codeyam-cli/src/commands/suggestUtils.js.map +1 -0
  2311. package/codeyam-cli/src/commands/test-startup.js +669 -0
  2312. package/codeyam-cli/src/commands/test-startup.js.map +1 -0
  2313. package/codeyam-cli/src/commands/update-config.js +97 -0
  2314. package/codeyam-cli/src/commands/update-config.js.map +1 -0
  2315. package/codeyam-cli/src/commands/validate-mock.js +97 -0
  2316. package/codeyam-cli/src/commands/validate-mock.js.map +1 -0
  2317. package/codeyam-cli/src/commands/verify.js +152 -0
  2318. package/codeyam-cli/src/commands/verify.js.map +1 -0
  2319. package/codeyam-cli/src/commands/wipe.js +108 -0
  2320. package/codeyam-cli/src/commands/wipe.js.map +1 -0
  2321. package/codeyam-cli/src/data/techStacks.js +77 -0
  2322. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  2323. package/codeyam-cli/src/state.js +9 -0
  2324. package/codeyam-cli/src/state.js.map +1 -0
  2325. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +144 -0
  2326. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  2327. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  2328. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  2329. package/codeyam-cli/src/utils/__tests__/cleanupAnalysisFiles.test.js +219 -0
  2330. package/codeyam-cli/src/utils/__tests__/cleanupAnalysisFiles.test.js.map +1 -0
  2331. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  2332. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  2333. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  2334. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  2335. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  2336. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  2337. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  2338. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  2339. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  2340. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  2341. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  2342. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  2343. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  2344. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  2345. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  2346. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  2347. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  2348. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  2349. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  2350. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  2351. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  2352. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  2353. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +289 -0
  2354. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  2355. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  2356. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  2357. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  2358. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  2359. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  2360. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  2361. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +841 -0
  2362. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  2363. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  2364. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  2365. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  2366. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  2367. package/codeyam-cli/src/utils/__tests__/entityVersioning.test.js +346 -0
  2368. package/codeyam-cli/src/utils/__tests__/entityVersioning.test.js.map +1 -0
  2369. package/codeyam-cli/src/utils/__tests__/fileMetadata.test.js +203 -0
  2370. package/codeyam-cli/src/utils/__tests__/fileMetadata.test.js.map +1 -0
  2371. package/codeyam-cli/src/utils/__tests__/fileWatcher.batch.test.js +614 -0
  2372. package/codeyam-cli/src/utils/__tests__/fileWatcher.batch.test.js.map +1 -0
  2373. package/codeyam-cli/src/utils/__tests__/fileWatcher.multiversion.test.js +587 -0
  2374. package/codeyam-cli/src/utils/__tests__/fileWatcher.multiversion.test.js.map +1 -0
  2375. package/codeyam-cli/src/utils/__tests__/fileWatcher.optimization.test.js +375 -0
  2376. package/codeyam-cli/src/utils/__tests__/fileWatcher.optimization.test.js.map +1 -0
  2377. package/codeyam-cli/src/utils/__tests__/fileWatcher.versioning.test.js +1293 -0
  2378. package/codeyam-cli/src/utils/__tests__/fileWatcher.versioning.test.js.map +1 -0
  2379. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  2380. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  2381. package/codeyam-cli/src/utils/__tests__/gitEntityLookup.test.js +119 -0
  2382. package/codeyam-cli/src/utils/__tests__/gitEntityLookup.test.js.map +1 -0
  2383. package/codeyam-cli/src/utils/__tests__/import-meta.test.js +37 -0
  2384. package/codeyam-cli/src/utils/__tests__/import-meta.test.js.map +1 -0
  2385. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  2386. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  2387. package/codeyam-cli/src/utils/__tests__/mockValidator.test.js +151 -0
  2388. package/codeyam-cli/src/utils/__tests__/mockValidator.test.js.map +1 -0
  2389. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  2390. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  2391. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  2392. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  2393. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +149 -0
  2394. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -0
  2395. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  2396. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  2397. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  2398. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  2399. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  2400. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  2401. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +300 -0
  2402. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  2403. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  2404. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  2405. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +315 -0
  2406. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -0
  2407. package/codeyam-cli/src/utils/__tests__/syncUniversalMocks.test.js +132 -0
  2408. package/codeyam-cli/src/utils/__tests__/syncUniversalMocks.test.js.map +1 -0
  2409. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  2410. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  2411. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  2412. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  2413. package/codeyam-cli/src/utils/analysisRunner.js +272 -0
  2414. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -0
  2415. package/codeyam-cli/src/utils/analyzer.js +268 -0
  2416. package/codeyam-cli/src/utils/analyzer.js.map +1 -0
  2417. package/codeyam-cli/src/utils/analyzerFinalization.js +96 -0
  2418. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  2419. package/codeyam-cli/src/utils/backgroundServer.js +247 -0
  2420. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -0
  2421. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  2422. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  2423. package/codeyam-cli/src/utils/changeDetection.js +102 -0
  2424. package/codeyam-cli/src/utils/changeDetection.js.map +1 -0
  2425. package/codeyam-cli/src/utils/claude-code.js +39 -0
  2426. package/codeyam-cli/src/utils/claude-code.js.map +1 -0
  2427. package/codeyam-cli/src/utils/cleanupAnalysisFiles.js +89 -0
  2428. package/codeyam-cli/src/utils/cleanupAnalysisFiles.js.map +1 -0
  2429. package/codeyam-cli/src/utils/database.js +315 -0
  2430. package/codeyam-cli/src/utils/database.js.map +1 -0
  2431. package/codeyam-cli/src/utils/defaultUnapprovedPaths.js +92 -0
  2432. package/codeyam-cli/src/utils/defaultUnapprovedPaths.js.map +1 -0
  2433. package/codeyam-cli/src/utils/detectEnvironmentVariables.js +137 -0
  2434. package/codeyam-cli/src/utils/detectEnvironmentVariables.js.map +1 -0
  2435. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  2436. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  2437. package/codeyam-cli/src/utils/devServerState.js +71 -0
  2438. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  2439. package/codeyam-cli/src/utils/editorApi.js +73 -0
  2440. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  2441. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  2442. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  2443. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  2444. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  2445. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  2446. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  2447. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  2448. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  2449. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  2450. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  2451. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  2452. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  2453. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  2454. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  2455. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  2456. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  2457. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  2458. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  2459. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  2460. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  2461. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  2462. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  2463. package/codeyam-cli/src/utils/editorScenarios.js +332 -0
  2464. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  2465. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  2466. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  2467. package/codeyam-cli/src/utils/entityCache.js +160 -0
  2468. package/codeyam-cli/src/utils/entityCache.js.map +1 -0
  2469. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  2470. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  2471. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  2472. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  2473. package/codeyam-cli/src/utils/entityMetadata.js +55 -0
  2474. package/codeyam-cli/src/utils/entityMetadata.js.map +1 -0
  2475. package/codeyam-cli/src/utils/entityVersioning.js +166 -0
  2476. package/codeyam-cli/src/utils/entityVersioning.js.map +1 -0
  2477. package/codeyam-cli/src/utils/fileMetadata.js +575 -0
  2478. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -0
  2479. package/codeyam-cli/src/utils/fileWatcher.js +1592 -0
  2480. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -0
  2481. package/codeyam-cli/src/utils/folderBurstDetector.js +174 -0
  2482. package/codeyam-cli/src/utils/folderBurstDetector.js.map +1 -0
  2483. package/codeyam-cli/src/utils/generateReport.js +366 -0
  2484. package/codeyam-cli/src/utils/generateReport.js.map +1 -0
  2485. package/codeyam-cli/src/utils/git.js +182 -0
  2486. package/codeyam-cli/src/utils/git.js.map +1 -0
  2487. package/codeyam-cli/src/utils/gitEntityLookup.js +28 -0
  2488. package/codeyam-cli/src/utils/gitEntityLookup.js.map +1 -0
  2489. package/codeyam-cli/src/utils/install-skills.js +142 -0
  2490. package/codeyam-cli/src/utils/install-skills.js.map +1 -0
  2491. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  2492. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  2493. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  2494. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  2495. package/codeyam-cli/src/utils/memoryLogger.js +151 -0
  2496. package/codeyam-cli/src/utils/memoryLogger.js.map +1 -0
  2497. package/codeyam-cli/src/utils/memoryProfiler.js +168 -0
  2498. package/codeyam-cli/src/utils/memoryProfiler.js.map +1 -0
  2499. package/codeyam-cli/src/utils/mockValidator.js +267 -0
  2500. package/codeyam-cli/src/utils/mockValidator.js.map +1 -0
  2501. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  2502. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  2503. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  2504. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  2505. package/codeyam-cli/src/utils/pathIgnoring.js +139 -0
  2506. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -0
  2507. package/codeyam-cli/src/utils/progress.js +139 -0
  2508. package/codeyam-cli/src/utils/progress.js.map +1 -0
  2509. package/codeyam-cli/src/utils/project.js +37 -0
  2510. package/codeyam-cli/src/utils/project.js.map +1 -0
  2511. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +637 -0
  2512. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -0
  2513. package/codeyam-cli/src/utils/queue/__tests__/job.pidTracking.test.js +295 -0
  2514. package/codeyam-cli/src/utils/queue/__tests__/job.pidTracking.test.js.map +1 -0
  2515. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +391 -0
  2516. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -0
  2517. package/codeyam-cli/src/utils/queue/__tests__/persistence.test.js +186 -0
  2518. package/codeyam-cli/src/utils/queue/__tests__/persistence.test.js.map +1 -0
  2519. package/codeyam-cli/src/utils/queue/heartbeat.js +149 -0
  2520. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -0
  2521. package/codeyam-cli/src/utils/queue/job.js +732 -0
  2522. package/codeyam-cli/src/utils/queue/job.js.map +1 -0
  2523. package/codeyam-cli/src/utils/queue/manager.js +237 -0
  2524. package/codeyam-cli/src/utils/queue/manager.js.map +1 -0
  2525. package/codeyam-cli/src/utils/queue/persistence.js +41 -0
  2526. package/codeyam-cli/src/utils/queue/persistence.js.map +1 -0
  2527. package/codeyam-cli/src/utils/queue/proxyQueue.js +163 -0
  2528. package/codeyam-cli/src/utils/queue/proxyQueue.js.map +1 -0
  2529. package/codeyam-cli/src/utils/queue/queueFileWatcher.js +77 -0
  2530. package/codeyam-cli/src/utils/queue/queueFileWatcher.js.map +1 -0
  2531. package/codeyam-cli/src/utils/queue/serverDetection.js +93 -0
  2532. package/codeyam-cli/src/utils/queue/serverDetection.js.map +1 -0
  2533. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  2534. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  2535. package/codeyam-cli/src/utils/routeIdentification.js +152 -0
  2536. package/codeyam-cli/src/utils/routeIdentification.js.map +1 -0
  2537. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  2538. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  2539. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  2540. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  2541. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  2542. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  2543. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  2544. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  2545. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  2546. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  2547. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  2548. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  2549. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  2550. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  2551. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  2552. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  2553. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  2554. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  2555. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  2556. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  2557. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  2558. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  2559. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  2560. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  2561. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  2562. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  2563. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  2564. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  2565. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  2566. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  2567. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  2568. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  2569. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  2570. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  2571. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  2572. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  2573. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  2574. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  2575. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  2576. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  2577. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  2578. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  2579. package/codeyam-cli/src/utils/rules/index.js +7 -0
  2580. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  2581. package/codeyam-cli/src/utils/rules/parser.js +93 -0
  2582. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  2583. package/codeyam-cli/src/utils/rules/pathMatcher.js +49 -0
  2584. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  2585. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  2586. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  2587. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  2588. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  2589. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  2590. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  2591. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  2592. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  2593. package/codeyam-cli/src/utils/sandbox.js +190 -0
  2594. package/codeyam-cli/src/utils/sandbox.js.map +1 -0
  2595. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  2596. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  2597. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  2598. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  2599. package/codeyam-cli/src/utils/scenariosManifest.js +159 -0
  2600. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  2601. package/codeyam-cli/src/utils/secrets.js +152 -0
  2602. package/codeyam-cli/src/utils/secrets.js.map +1 -0
  2603. package/codeyam-cli/src/utils/secretsManager.js +189 -0
  2604. package/codeyam-cli/src/utils/secretsManager.js.map +1 -0
  2605. package/codeyam-cli/src/utils/serverState.js +211 -0
  2606. package/codeyam-cli/src/utils/serverState.js.map +1 -0
  2607. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +157 -0
  2608. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -0
  2609. package/codeyam-cli/src/utils/simulationGateMiddleware.js +166 -0
  2610. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  2611. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  2612. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  2613. package/codeyam-cli/src/utils/syncMocksMiddleware.js +32 -0
  2614. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -0
  2615. package/codeyam-cli/src/utils/syncUncommittedEntities.js +169 -0
  2616. package/codeyam-cli/src/utils/syncUncommittedEntities.js.map +1 -0
  2617. package/codeyam-cli/src/utils/syncUniversalMocks.js +284 -0
  2618. package/codeyam-cli/src/utils/syncUniversalMocks.js.map +1 -0
  2619. package/codeyam-cli/src/utils/testRunner.js +158 -0
  2620. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  2621. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  2622. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  2623. package/codeyam-cli/src/utils/versionInfo.js +169 -0
  2624. package/codeyam-cli/src/utils/versionInfo.js.map +1 -0
  2625. package/codeyam-cli/src/utils/webappDetection.js +292 -0
  2626. package/codeyam-cli/src/utils/webappDetection.js.map +1 -0
  2627. package/codeyam-cli/src/utils/webappMapping.js +52 -0
  2628. package/codeyam-cli/src/utils/webappMapping.js.map +1 -0
  2629. package/codeyam-cli/src/utils/wipe.js +128 -0
  2630. package/codeyam-cli/src/utils/wipe.js.map +1 -0
  2631. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  2632. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  2633. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  2634. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  2635. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  2636. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  2637. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  2638. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  2639. package/codeyam-cli/src/webserver/app/lib/database.js +549 -0
  2640. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -0
  2641. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js +88 -0
  2642. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -0
  2643. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  2644. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  2645. package/codeyam-cli/src/webserver/app/lib/lightweightEntityExtractor.js +3 -0
  2646. package/codeyam-cli/src/webserver/app/lib/lightweightEntityExtractor.js.map +1 -0
  2647. package/codeyam-cli/src/webserver/backgroundServer.js +286 -0
  2648. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -0
  2649. package/codeyam-cli/src/webserver/bootstrap.js +60 -0
  2650. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -0
  2651. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  2652. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BcgbViKV.js +11 -0
  2653. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-g3saevPb.js +1 -0
  2654. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CQIG2qda.js +41 -0
  2655. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  2656. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DYFW3lDD.js +25 -0
  2657. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DLeucoVX.js +3 -0
  2658. package/codeyam-cli/src/webserver/build/client/assets/LoadingDots-BU_OAEMP.js +6 -0
  2659. package/codeyam-cli/src/webserver/build/client/assets/LogViewer-ceAyBX-H.js +3 -0
  2660. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BzHcG7SE.js +11 -0
  2661. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-BED4B6sP.js +1 -0
  2662. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-0DY_NKil.js +10 -0
  2663. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  2664. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-C8OKAR5x.js +1 -0
  2665. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  2666. package/codeyam-cli/src/webserver/build/client/assets/_index-DLxKhri3.js +11 -0
  2667. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BcY3q6nt.js +27 -0
  2668. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  2669. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  2670. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  2671. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  2672. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  2673. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  2674. package/codeyam-cli/src/webserver/build/client/assets/api.analyze-l0sNRNKZ.js +1 -0
  2675. package/codeyam-cli/src/webserver/build/client/assets/api.branch-entity-diff-l0sNRNKZ.js +1 -0
  2676. package/codeyam-cli/src/webserver/build/client/assets/api.capture-screenshot-l0sNRNKZ.js +1 -0
  2677. package/codeyam-cli/src/webserver/build/client/assets/api.debug-setup-l0sNRNKZ.js +1 -0
  2678. package/codeyam-cli/src/webserver/build/client/assets/api.delete-scenario-l0sNRNKZ.js +1 -0
  2679. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  2680. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  2681. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  2682. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  2683. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  2684. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  2685. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  2686. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  2687. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  2688. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  2689. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  2690. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  2691. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  2692. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  2693. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  2694. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  2695. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  2696. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  2697. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  2698. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  2699. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  2700. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  2701. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  2702. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  2703. package/codeyam-cli/src/webserver/build/client/assets/api.events-l0sNRNKZ.js +1 -0
  2704. package/codeyam-cli/src/webserver/build/client/assets/api.execute-function-l0sNRNKZ.js +1 -0
  2705. package/codeyam-cli/src/webserver/build/client/assets/api.generate-report-l0sNRNKZ.js +1 -0
  2706. package/codeyam-cli/src/webserver/build/client/assets/api.generate-scenario-data-l0sNRNKZ.js +1 -0
  2707. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  2708. package/codeyam-cli/src/webserver/build/client/assets/api.interactive-mode-l0sNRNKZ.js +1 -0
  2709. package/codeyam-cli/src/webserver/build/client/assets/api.kill-process-l0sNRNKZ.js +1 -0
  2710. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  2711. package/codeyam-cli/src/webserver/build/client/assets/api.llm-calls._entitySha-l0sNRNKZ.js +1 -0
  2712. package/codeyam-cli/src/webserver/build/client/assets/api.logs._projectSlug-l0sNRNKZ.js +1 -0
  2713. package/codeyam-cli/src/webserver/build/client/assets/api.memory-l0sNRNKZ.js +1 -0
  2714. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  2715. package/codeyam-cli/src/webserver/build/client/assets/api.process-status-l0sNRNKZ.js +1 -0
  2716. package/codeyam-cli/src/webserver/build/client/assets/api.queue-l0sNRNKZ.js +1 -0
  2717. package/codeyam-cli/src/webserver/build/client/assets/api.recapture-l0sNRNKZ.js +1 -0
  2718. package/codeyam-cli/src/webserver/build/client/assets/api.recapture-scenario-l0sNRNKZ.js +1 -0
  2719. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  2720. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  2721. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  2722. package/codeyam-cli/src/webserver/build/client/assets/api.save-scenarios-l0sNRNKZ.js +1 -0
  2723. package/codeyam-cli/src/webserver/build/client/assets/api.screenshot._-l0sNRNKZ.js +1 -0
  2724. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  2725. package/codeyam-cli/src/webserver/build/client/assets/chevron-down-C_Pmso5S.js +6 -0
  2726. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-C4pqxYJB.js +51 -0
  2727. package/codeyam-cli/src/webserver/build/client/assets/circle-check-BVMi9VA5.js +6 -0
  2728. package/codeyam-cli/src/webserver/build/client/assets/codeyam-name-logo-CvKwUgHo.svg +9 -0
  2729. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  2730. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  2731. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CCKUIm0S.svg +4 -0
  2732. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  2733. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
  2734. package/codeyam-cli/src/webserver/build/client/assets/editor-3VLXD_1q.js +10 -0
  2735. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
  2736. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-BF4oLwaE.js +23 -0
  2737. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
  2738. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-D2QMozBc.js +6 -0
  2739. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  2740. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-BMvVHNXU.js +5 -0
  2741. package/codeyam-cli/src/webserver/build/client/assets/entry.client-DTvKq3TY.js +29 -0
  2742. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  2743. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-cPo8LiG3.js +1 -0
  2744. package/codeyam-cli/src/webserver/build/client/assets/files-BZrlFE1F.js +1 -0
  2745. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  2746. package/codeyam-cli/src/webserver/build/client/assets/globals-COUSHTyZ.css +1 -0
  2747. package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-fmIEn3Bc.js +9 -0
  2748. package/codeyam-cli/src/webserver/build/client/assets/index-10oVnAAH.js +9 -0
  2749. package/codeyam-cli/src/webserver/build/client/assets/index-BcvgDzbZ.js +3 -0
  2750. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  2751. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  2752. package/codeyam-cli/src/webserver/build/client/assets/loader-circle-DaAZ_H2w.js +6 -0
  2753. package/codeyam-cli/src/webserver/build/client/assets/manifest-a6938576.js +1 -0
  2754. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  2755. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  2756. package/codeyam-cli/src/webserver/build/client/assets/preload-helper-ckwbz45p.js +1 -0
  2757. package/codeyam-cli/src/webserver/build/client/assets/root-CHOdrM6Y.js +67 -0
  2758. package/codeyam-cli/src/webserver/build/client/assets/scenarioStatus-B_8jpV3e.js +1 -0
  2759. package/codeyam-cli/src/webserver/build/client/assets/search-Di64LWVb.js +6 -0
  2760. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  2761. package/codeyam-cli/src/webserver/build/client/assets/simulations-DWT-CvLy.js +1 -0
  2762. package/codeyam-cli/src/webserver/build/client/assets/static._-l0sNRNKZ.js +1 -0
  2763. package/codeyam-cli/src/webserver/build/client/assets/styles-CMKNK2uU.css +1 -0
  2764. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  2765. package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-BLdiCuG-.js +6 -0
  2766. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  2767. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  2768. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-O-jkvSPx.js +1 -0
  2769. package/codeyam-cli/src/webserver/build/client/assets/useToast-9FIWuYfK.js +1 -0
  2770. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  2771. package/codeyam-cli/src/webserver/build/client/favicon.ico +0 -0
  2772. package/codeyam-cli/src/webserver/build/client/favicon.png +0 -0
  2773. package/codeyam-cli/src/webserver/build/client/icons/file-icon.svg +14 -0
  2774. package/codeyam-cli/src/webserver/build/server/assets/index-BAFoEtXs.js +1 -0
  2775. package/codeyam-cli/src/webserver/build/server/assets/init-_5muknwv.js +10 -0
  2776. package/codeyam-cli/src/webserver/build/server/assets/server-build-CPt5NLY9.js +439 -0
  2777. package/codeyam-cli/src/webserver/build/server/index.js +1 -0
  2778. package/codeyam-cli/src/webserver/build-info.json +7 -0
  2779. package/codeyam-cli/src/webserver/devServer.js +125 -0
  2780. package/codeyam-cli/src/webserver/devServer.js.map +1 -0
  2781. package/codeyam-cli/src/webserver/editorProxy.js +877 -0
  2782. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  2783. package/codeyam-cli/src/webserver/public/favicon.ico +0 -0
  2784. package/codeyam-cli/src/webserver/public/favicon.png +0 -0
  2785. package/codeyam-cli/src/webserver/public/icons/file-icon.svg +14 -0
  2786. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  2787. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  2788. package/codeyam-cli/src/webserver/server.js +410 -0
  2789. package/codeyam-cli/src/webserver/server.js.map +1 -0
  2790. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  2791. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  2792. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  2793. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  2794. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  2795. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  2796. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  2797. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  2798. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  2799. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  2800. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  2801. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  2802. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  2803. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  2804. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  2805. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  2806. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  2807. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  2808. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  2809. package/codeyam-cli/templates/editor-step-hook.py +236 -0
  2810. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  2811. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  2812. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  2813. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  2814. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  2815. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  2816. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  2817. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  2818. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  2819. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  2820. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  2821. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  2822. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  2823. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  2824. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  2825. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  2826. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  2827. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  2828. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  2829. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  2830. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  2831. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  2832. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  2833. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  2834. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  2835. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  2836. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  2837. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  2838. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  2839. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  2840. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  2841. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  2842. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  2843. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  2844. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  2845. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  2846. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  2847. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  2848. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  2849. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  2850. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  2851. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  2852. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  2853. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  2854. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  2855. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  2856. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  2857. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  2858. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  2859. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  2860. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  2861. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  2862. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  2863. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  2864. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  2865. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  2866. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  2867. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  2868. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  2869. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  2870. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  2871. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  2872. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  2873. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  2874. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  2875. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  2876. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  2877. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  2878. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  2879. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  2880. package/codeyam-cli/templates/rules-instructions.md +78 -0
  2881. package/codeyam-cli/templates/skills/codeyam-debug/SKILL.md +601 -0
  2882. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  2883. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  2884. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  2885. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  2886. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  2887. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  2888. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  2889. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  2890. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  2891. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  2892. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  2893. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  2894. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  2895. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  2896. package/codeyam-cli/templates/skills/codeyam-setup/SKILL.md +600 -0
  2897. package/codeyam-cli/templates/skills/codeyam-sim/SKILL.md +222 -0
  2898. package/codeyam-cli/templates/skills/codeyam-test/SKILL.md +178 -0
  2899. package/codeyam-cli/templates/skills/codeyam-verify/SKILL.md +179 -0
  2900. package/package.json +88 -7
  2901. package/packages/ai/index.js +53 -0
  2902. package/packages/ai/index.js.map +1 -0
  2903. package/packages/ai/src/lib/aiConfig.js +16 -0
  2904. package/packages/ai/src/lib/aiConfig.js.map +1 -0
  2905. package/packages/ai/src/lib/analyzeScope.js +589 -0
  2906. package/packages/ai/src/lib/analyzeScope.js.map +1 -0
  2907. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  2908. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  2909. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +911 -0
  2910. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -0
  2911. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  2912. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  2913. package/packages/ai/src/lib/astScopes/methodSemantics.js +652 -0
  2914. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -0
  2915. package/packages/ai/src/lib/astScopes/nodeToSource.js +54 -0
  2916. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -0
  2917. package/packages/ai/src/lib/astScopes/paths.js +552 -0
  2918. package/packages/ai/src/lib/astScopes/paths.js.map +1 -0
  2919. package/packages/ai/src/lib/astScopes/patterns/blockHandler.js +24 -0
  2920. package/packages/ai/src/lib/astScopes/patterns/blockHandler.js.map +1 -0
  2921. package/packages/ai/src/lib/astScopes/patterns/breakStatementHandler.js +18 -0
  2922. package/packages/ai/src/lib/astScopes/patterns/breakStatementHandler.js.map +1 -0
  2923. package/packages/ai/src/lib/astScopes/patterns/doStatementHandler.js +22 -0
  2924. package/packages/ai/src/lib/astScopes/patterns/doStatementHandler.js.map +1 -0
  2925. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +53 -0
  2926. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -0
  2927. package/packages/ai/src/lib/astScopes/patterns/forOfStatementHandler.js +93 -0
  2928. package/packages/ai/src/lib/astScopes/patterns/forOfStatementHandler.js.map +1 -0
  2929. package/packages/ai/src/lib/astScopes/patterns/forStatementHandler.js +52 -0
  2930. package/packages/ai/src/lib/astScopes/patterns/forStatementHandler.js.map +1 -0
  2931. package/packages/ai/src/lib/astScopes/patterns/functionDeclarationHandler.js +179 -0
  2932. package/packages/ai/src/lib/astScopes/patterns/functionDeclarationHandler.js.map +1 -0
  2933. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +44 -0
  2934. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -0
  2935. package/packages/ai/src/lib/astScopes/patterns/patternHandler.js +2 -0
  2936. package/packages/ai/src/lib/astScopes/patterns/patternHandler.js.map +1 -0
  2937. package/packages/ai/src/lib/astScopes/patterns/returnStatementHandler.js +47 -0
  2938. package/packages/ai/src/lib/astScopes/patterns/returnStatementHandler.js.map +1 -0
  2939. package/packages/ai/src/lib/astScopes/patterns/standaloneExpressionHandler.js +51 -0
  2940. package/packages/ai/src/lib/astScopes/patterns/standaloneExpressionHandler.js.map +1 -0
  2941. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +110 -0
  2942. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -0
  2943. package/packages/ai/src/lib/astScopes/patterns/throwStatementHandler.js +16 -0
  2944. package/packages/ai/src/lib/astScopes/patterns/throwStatementHandler.js.map +1 -0
  2945. package/packages/ai/src/lib/astScopes/patterns/tryStatementHandler.js +53 -0
  2946. package/packages/ai/src/lib/astScopes/patterns/tryStatementHandler.js.map +1 -0
  2947. package/packages/ai/src/lib/astScopes/patterns/typeAndInterfaceHandler.js +18 -0
  2948. package/packages/ai/src/lib/astScopes/patterns/typeAndInterfaceHandler.js.map +1 -0
  2949. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +201 -0
  2950. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -0
  2951. package/packages/ai/src/lib/astScopes/patterns/whileStatementHandler.js +24 -0
  2952. package/packages/ai/src/lib/astScopes/patterns/whileStatementHandler.js.map +1 -0
  2953. package/packages/ai/src/lib/astScopes/processBindings.js +191 -0
  2954. package/packages/ai/src/lib/astScopes/processBindings.js.map +1 -0
  2955. package/packages/ai/src/lib/astScopes/processExpression.js +2784 -0
  2956. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -0
  2957. package/packages/ai/src/lib/astScopes/sharedPatterns.js +133 -0
  2958. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -0
  2959. package/packages/ai/src/lib/astScopes/types.js +31 -0
  2960. package/packages/ai/src/lib/astScopes/types.js.map +1 -0
  2961. package/packages/ai/src/lib/astScopes.js +12 -0
  2962. package/packages/ai/src/lib/astScopes.js.map +1 -0
  2963. package/packages/ai/src/lib/checkAllAttributes.js +41 -0
  2964. package/packages/ai/src/lib/checkAllAttributes.js.map +1 -0
  2965. package/packages/ai/src/lib/cleanOutBoundary.js +31 -0
  2966. package/packages/ai/src/lib/cleanOutBoundary.js.map +1 -0
  2967. package/packages/ai/src/lib/codeQualityEntityAnalysis.js +13 -0
  2968. package/packages/ai/src/lib/codeQualityEntityAnalysis.js.map +1 -0
  2969. package/packages/ai/src/lib/commitMessage.js +12 -0
  2970. package/packages/ai/src/lib/commitMessage.js.map +1 -0
  2971. package/packages/ai/src/lib/completionCall.js +517 -0
  2972. package/packages/ai/src/lib/completionCall.js.map +1 -0
  2973. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +4885 -0
  2974. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -0
  2975. package/packages/ai/src/lib/dataStructure/equivalencyManagers/EquivalencyManager.js +2 -0
  2976. package/packages/ai/src/lib/dataStructure/equivalencyManagers/EquivalencyManager.js.map +1 -0
  2977. package/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.js +401 -0
  2978. package/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.js.map +1 -0
  2979. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +88 -0
  2980. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -0
  2981. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +377 -0
  2982. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -0
  2983. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +661 -0
  2984. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -0
  2985. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +1004 -0
  2986. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -0
  2987. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +122 -0
  2988. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -0
  2989. package/packages/ai/src/lib/dataStructure/helpers/DebugTracer.js +176 -0
  2990. package/packages/ai/src/lib/dataStructure/helpers/DebugTracer.js.map +1 -0
  2991. package/packages/ai/src/lib/dataStructure/helpers/PathManager.js +178 -0
  2992. package/packages/ai/src/lib/dataStructure/helpers/PathManager.js.map +1 -0
  2993. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +140 -0
  2994. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -0
  2995. package/packages/ai/src/lib/dataStructure/helpers/VisitedTracker.js +199 -0
  2996. package/packages/ai/src/lib/dataStructure/helpers/VisitedTracker.js.map +1 -0
  2997. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +168 -0
  2998. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -0
  2999. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +877 -0
  3000. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -0
  3001. package/packages/ai/src/lib/dataStructure/helpers/cleanPath.js +21 -0
  3002. package/packages/ai/src/lib/dataStructure/helpers/cleanPath.js.map +1 -0
  3003. package/packages/ai/src/lib/dataStructure/helpers/cleanPathOfNonTransformingFunctions.js +42 -0
  3004. package/packages/ai/src/lib/dataStructure/helpers/cleanPathOfNonTransformingFunctions.js.map +1 -0
  3005. package/packages/ai/src/lib/dataStructure/helpers/cleanScopeNodeName.js +4 -0
  3006. package/packages/ai/src/lib/dataStructure/helpers/cleanScopeNodeName.js.map +1 -0
  3007. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  3008. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  3009. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  3010. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  3011. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +376 -0
  3012. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -0
  3013. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
  3014. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
  3015. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  3016. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  3017. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +128 -0
  3018. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -0
  3019. package/packages/ai/src/lib/dataStructure/helpers/determineIsFunctionCall.js +12 -0
  3020. package/packages/ai/src/lib/dataStructure/helpers/determineIsFunctionCall.js.map +1 -0
  3021. package/packages/ai/src/lib/dataStructure/helpers/ensureSchemaConsistency.js +73 -0
  3022. package/packages/ai/src/lib/dataStructure/helpers/ensureSchemaConsistency.js.map +1 -0
  3023. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +895 -0
  3024. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -0
  3025. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  3026. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  3027. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.js +33 -0
  3028. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.js.map +1 -0
  3029. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallScopeNodeName.js +8 -0
  3030. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallScopeNodeName.js.map +1 -0
  3031. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallSignature.js +13 -0
  3032. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallSignature.js.map +1 -0
  3033. package/packages/ai/src/lib/dataStructure/helpers/isGenericArray.js +65 -0
  3034. package/packages/ai/src/lib/dataStructure/helpers/isGenericArray.js.map +1 -0
  3035. package/packages/ai/src/lib/dataStructure/helpers/knownMethodCalls.js +128 -0
  3036. package/packages/ai/src/lib/dataStructure/helpers/knownMethodCalls.js.map +1 -0
  3037. package/packages/ai/src/lib/dataStructure/helpers/selectBestValue.js +62 -0
  3038. package/packages/ai/src/lib/dataStructure/helpers/selectBestValue.js.map +1 -0
  3039. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  3040. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  3041. package/packages/ai/src/lib/dataStructure/helpers/uniqueIdUtils.js +90 -0
  3042. package/packages/ai/src/lib/dataStructure/helpers/uniqueIdUtils.js.map +1 -0
  3043. package/packages/ai/src/lib/dataStructureChunking.js +130 -0
  3044. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  3045. package/packages/ai/src/lib/deepEqual.js +32 -0
  3046. package/packages/ai/src/lib/deepEqual.js.map +1 -0
  3047. package/packages/ai/src/lib/describeCodeChange.js +36 -0
  3048. package/packages/ai/src/lib/describeCodeChange.js.map +1 -0
  3049. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  3050. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  3051. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  3052. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  3053. package/packages/ai/src/lib/extractOverlappingMocks.js +41 -0
  3054. package/packages/ai/src/lib/extractOverlappingMocks.js.map +1 -0
  3055. package/packages/ai/src/lib/generateBranchSummary.js +40 -0
  3056. package/packages/ai/src/lib/generateBranchSummary.js.map +1 -0
  3057. package/packages/ai/src/lib/generateChangesEntityDocumentation.js +57 -0
  3058. package/packages/ai/src/lib/generateChangesEntityDocumentation.js.map +1 -0
  3059. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +334 -0
  3060. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -0
  3061. package/packages/ai/src/lib/generateChangesEntityScenarios.js +308 -0
  3062. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -0
  3063. package/packages/ai/src/lib/generateEntityDataStructure.js +113 -0
  3064. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -0
  3065. package/packages/ai/src/lib/generateEntityDocumentation.js +57 -0
  3066. package/packages/ai/src/lib/generateEntityDocumentation.js.map +1 -0
  3067. package/packages/ai/src/lib/generateEntityScenarioData.js +1369 -0
  3068. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -0
  3069. package/packages/ai/src/lib/generateEntityScenarios.js +362 -0
  3070. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -0
  3071. package/packages/ai/src/lib/generateExecutionFlows.js +484 -0
  3072. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  3073. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  3074. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  3075. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  3076. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  3077. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  3078. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  3079. package/packages/ai/src/lib/generateStatementAnalysis.js +1709 -0
  3080. package/packages/ai/src/lib/generateStatementAnalysis.js.map +1 -0
  3081. package/packages/ai/src/lib/getCodeExplanation.js +40 -0
  3082. package/packages/ai/src/lib/getCodeExplanation.js.map +1 -0
  3083. package/packages/ai/src/lib/getConditionalUsagesFromCode.js +309 -0
  3084. package/packages/ai/src/lib/getConditionalUsagesFromCode.js.map +1 -0
  3085. package/packages/ai/src/lib/getLLMCallCost.js +12 -0
  3086. package/packages/ai/src/lib/getLLMCallCost.js.map +1 -0
  3087. package/packages/ai/src/lib/getLLMCallStats.js +29 -0
  3088. package/packages/ai/src/lib/getLLMCallStats.js.map +1 -0
  3089. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +91 -0
  3090. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -0
  3091. package/packages/ai/src/lib/guessScenarioDataFromName.js +57 -0
  3092. package/packages/ai/src/lib/guessScenarioDataFromName.js.map +1 -0
  3093. package/packages/ai/src/lib/identifyReserved.js +619 -0
  3094. package/packages/ai/src/lib/identifyReserved.js.map +1 -0
  3095. package/packages/ai/src/lib/index.js +11 -0
  3096. package/packages/ai/src/lib/index.js.map +1 -0
  3097. package/packages/ai/src/lib/instantiatedInScope.js +186 -0
  3098. package/packages/ai/src/lib/instantiatedInScope.js.map +1 -0
  3099. package/packages/ai/src/lib/isolateScopes.js +990 -0
  3100. package/packages/ai/src/lib/isolateScopes.js.map +1 -0
  3101. package/packages/ai/src/lib/isolateStatements.js +882 -0
  3102. package/packages/ai/src/lib/isolateStatements.js.map +1 -0
  3103. package/packages/ai/src/lib/jsonTypeDefinitionToStandardTypeDefinition.js +34 -0
  3104. package/packages/ai/src/lib/jsonTypeDefinitionToStandardTypeDefinition.js.map +1 -0
  3105. package/packages/ai/src/lib/logOrderedMap.js +22 -0
  3106. package/packages/ai/src/lib/logOrderedMap.js.map +1 -0
  3107. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +55 -0
  3108. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -0
  3109. package/packages/ai/src/lib/mergeStatements.js +220 -0
  3110. package/packages/ai/src/lib/mergeStatements.js.map +1 -0
  3111. package/packages/ai/src/lib/modelInfo.js +215 -0
  3112. package/packages/ai/src/lib/modelInfo.js.map +1 -0
  3113. package/packages/ai/src/lib/openai/index.js +72 -0
  3114. package/packages/ai/src/lib/openai/index.js.map +1 -0
  3115. package/packages/ai/src/lib/parsers/fileContentToLines.js +8 -0
  3116. package/packages/ai/src/lib/parsers/fileContentToLines.js.map +1 -0
  3117. package/packages/ai/src/lib/parsers/parseJsonSafe.js +40 -0
  3118. package/packages/ai/src/lib/parsers/parseJsonSafe.js.map +1 -0
  3119. package/packages/ai/src/lib/promptGenerators/branchSummaryGenerator.js +6 -0
  3120. package/packages/ai/src/lib/promptGenerators/branchSummaryGenerator.js.map +1 -0
  3121. package/packages/ai/src/lib/promptGenerators/codeQualityEntityAnalysisGenerator.js +52 -0
  3122. package/packages/ai/src/lib/promptGenerators/codeQualityEntityAnalysisGenerator.js.map +1 -0
  3123. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  3124. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  3125. package/packages/ai/src/lib/promptGenerators/commitMessageGenerator.js +36 -0
  3126. package/packages/ai/src/lib/promptGenerators/commitMessageGenerator.js.map +1 -0
  3127. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +238 -0
  3128. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -0
  3129. package/packages/ai/src/lib/promptGenerators/generateChangesEntityDocumentationGenerator.js +18 -0
  3130. package/packages/ai/src/lib/promptGenerators/generateChangesEntityDocumentationGenerator.js.map +1 -0
  3131. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +96 -0
  3132. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -0
  3133. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +66 -0
  3134. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -0
  3135. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  3136. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  3137. package/packages/ai/src/lib/promptGenerators/generateEntityDataStructureGenerator.js +14 -0
  3138. package/packages/ai/src/lib/promptGenerators/generateEntityDataStructureGenerator.js.map +1 -0
  3139. package/packages/ai/src/lib/promptGenerators/generateEntityDocumentationGenerator.js +15 -0
  3140. package/packages/ai/src/lib/promptGenerators/generateEntityDocumentationGenerator.js.map +1 -0
  3141. package/packages/ai/src/lib/promptGenerators/generateEntityPropsStructureGenerator.js +17 -0
  3142. package/packages/ai/src/lib/promptGenerators/generateEntityPropsStructureGenerator.js.map +1 -0
  3143. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +117 -0
  3144. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -0
  3145. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +17 -0
  3146. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -0
  3147. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  3148. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  3149. package/packages/ai/src/lib/promptGenerators/getComponentExamplesGenerator.js +15 -0
  3150. package/packages/ai/src/lib/promptGenerators/getComponentExamplesGenerator.js.map +1 -0
  3151. package/packages/ai/src/lib/promptGenerators/guessEditScenarioDataFromDescriptionGenerator.js +29 -0
  3152. package/packages/ai/src/lib/promptGenerators/guessEditScenarioDataFromDescriptionGenerator.js.map +1 -0
  3153. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +26 -0
  3154. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -0
  3155. package/packages/ai/src/lib/promptGenerators/guessScenarioDataFromNameGenerator.js +21 -0
  3156. package/packages/ai/src/lib/promptGenerators/guessScenarioDataFromNameGenerator.js.map +1 -0
  3157. package/packages/ai/src/lib/promptGenerators/index.js +11 -0
  3158. package/packages/ai/src/lib/promptGenerators/index.js.map +1 -0
  3159. package/packages/ai/src/lib/promptGenerators/noErrorAttributes.js +17 -0
  3160. package/packages/ai/src/lib/promptGenerators/noErrorAttributes.js.map +1 -0
  3161. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  3162. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  3163. package/packages/ai/src/lib/promptGenerators/summarizeDiffGenerator.js +11 -0
  3164. package/packages/ai/src/lib/promptGenerators/summarizeDiffGenerator.js.map +1 -0
  3165. package/packages/ai/src/lib/providers.js +36 -0
  3166. package/packages/ai/src/lib/providers.js.map +1 -0
  3167. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  3168. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  3169. package/packages/ai/src/lib/services/aiServiceMode.js +132 -0
  3170. package/packages/ai/src/lib/services/aiServiceMode.js.map +1 -0
  3171. package/packages/ai/src/lib/services/claudeCliAIService.js +204 -0
  3172. package/packages/ai/src/lib/services/claudeCliAIService.js.map +1 -0
  3173. package/packages/ai/src/lib/splitOutsideParentheses.js +289 -0
  3174. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -0
  3175. package/packages/ai/src/lib/summarizeDiff.js +14 -0
  3176. package/packages/ai/src/lib/summarizeDiff.js.map +1 -0
  3177. package/packages/ai/src/lib/types/index.js +43 -0
  3178. package/packages/ai/src/lib/types/index.js.map +1 -0
  3179. package/packages/ai/src/lib/validateDataStructure.js +345 -0
  3180. package/packages/ai/src/lib/validateDataStructure.js.map +1 -0
  3181. package/packages/ai/src/lib/validateJson.js +64 -0
  3182. package/packages/ai/src/lib/validateJson.js.map +1 -0
  3183. package/packages/ai/src/lib/validatePlaywrightInstructions.js +162 -0
  3184. package/packages/ai/src/lib/validatePlaywrightInstructions.js.map +1 -0
  3185. package/packages/ai/src/lib/validateTypeStructure.js +72 -0
  3186. package/packages/ai/src/lib/validateTypeStructure.js.map +1 -0
  3187. package/packages/ai/src/lib/worker/SerializableDataStructure.js +128 -0
  3188. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -0
  3189. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +158 -0
  3190. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -0
  3191. package/packages/ai/src/lib/worker/analyzeScopeWorkerPaths.js +23 -0
  3192. package/packages/ai/src/lib/worker/analyzeScopeWorkerPaths.js.map +1 -0
  3193. package/packages/ai/src/lib/worker/fuzzyMatchFunctionName.js +64 -0
  3194. package/packages/ai/src/lib/worker/fuzzyMatchFunctionName.js.map +1 -0
  3195. package/packages/ai/src/lib/wrapperDetection/detectWrapperRequirements.js +103 -0
  3196. package/packages/ai/src/lib/wrapperDetection/detectWrapperRequirements.js.map +1 -0
  3197. package/packages/ai/src/lib/wrapperDetection/knownLibraryHooks.js +76 -0
  3198. package/packages/ai/src/lib/wrapperDetection/knownLibraryHooks.js.map +1 -0
  3199. package/packages/ai/src/lib/wrapperDetection/patterns/detectThrowOnMissingPatterns.js +155 -0
  3200. package/packages/ai/src/lib/wrapperDetection/patterns/detectThrowOnMissingPatterns.js.map +1 -0
  3201. package/packages/ai/src/lib/wrapperDetection/patterns/detectUseContextCalls.js +95 -0
  3202. package/packages/ai/src/lib/wrapperDetection/patterns/detectUseContextCalls.js.map +1 -0
  3203. package/packages/analyze/index.js +99 -0
  3204. package/packages/analyze/index.js.map +1 -0
  3205. package/packages/analyze/src/lib/FileAnalyzer.js +847 -0
  3206. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -0
  3207. package/packages/analyze/src/lib/ProjectAnalyzer.js +325 -0
  3208. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -0
  3209. package/packages/analyze/src/lib/analysisContext.js +238 -0
  3210. package/packages/analyze/src/lib/analysisContext.js.map +1 -0
  3211. package/packages/analyze/src/lib/asts/index.js +181 -0
  3212. package/packages/analyze/src/lib/asts/index.js.map +1 -0
  3213. package/packages/analyze/src/lib/asts/nodes/getCallExpressionNames.js +33 -0
  3214. package/packages/analyze/src/lib/asts/nodes/getCallExpressionNames.js.map +1 -0
  3215. package/packages/analyze/src/lib/asts/nodes/getFunctionNodeType.js +17 -0
  3216. package/packages/analyze/src/lib/asts/nodes/getFunctionNodeType.js.map +1 -0
  3217. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +109 -0
  3218. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -0
  3219. package/packages/analyze/src/lib/asts/nodes/getReactComponentType.js +36 -0
  3220. package/packages/analyze/src/lib/asts/nodes/getReactComponentType.js.map +1 -0
  3221. package/packages/analyze/src/lib/asts/nodes/index.js +139 -0
  3222. package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -0
  3223. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
  3224. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
  3225. package/packages/analyze/src/lib/asts/nodes/isDefaultExport.js +62 -0
  3226. package/packages/analyze/src/lib/asts/nodes/isDefaultExport.js.map +1 -0
  3227. package/packages/analyze/src/lib/asts/nodes/propsNodeToPropsData.js +342 -0
  3228. package/packages/analyze/src/lib/asts/nodes/propsNodeToPropsData.js.map +1 -0
  3229. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +205 -0
  3230. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -0
  3231. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntities.js +5 -0
  3232. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntities.js.map +1 -0
  3233. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +202 -0
  3234. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -0
  3235. package/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.js +104 -0
  3236. package/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.js.map +1 -0
  3237. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +197 -0
  3238. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -0
  3239. package/packages/analyze/src/lib/asts/sourceFiles/getComponentProps.js +24 -0
  3240. package/packages/analyze/src/lib/asts/sourceFiles/getComponentProps.js.map +1 -0
  3241. package/packages/analyze/src/lib/asts/sourceFiles/getComponentType.js +36 -0
  3242. package/packages/analyze/src/lib/asts/sourceFiles/getComponentType.js.map +1 -0
  3243. package/packages/analyze/src/lib/asts/sourceFiles/getDeclaredEntityNode.js +16 -0
  3244. package/packages/analyze/src/lib/asts/sourceFiles/getDeclaredEntityNode.js.map +1 -0
  3245. package/packages/analyze/src/lib/asts/sourceFiles/getDefaultExportedFunctionNode.js +38 -0
  3246. package/packages/analyze/src/lib/asts/sourceFiles/getDefaultExportedFunctionNode.js.map +1 -0
  3247. package/packages/analyze/src/lib/asts/sourceFiles/getEntityNode.js +17 -0
  3248. package/packages/analyze/src/lib/asts/sourceFiles/getEntityNode.js.map +1 -0
  3249. package/packages/analyze/src/lib/asts/sourceFiles/getImportMappings.js +33 -0
  3250. package/packages/analyze/src/lib/asts/sourceFiles/getImportMappings.js.map +1 -0
  3251. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +109 -0
  3252. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -0
  3253. package/packages/analyze/src/lib/asts/sourceFiles/getPropsFromFunctionalComponent.js +70 -0
  3254. package/packages/analyze/src/lib/asts/sourceFiles/getPropsFromFunctionalComponent.js.map +1 -0
  3255. package/packages/analyze/src/lib/asts/sourceFiles/getPseudoFile.js +10 -0
  3256. package/packages/analyze/src/lib/asts/sourceFiles/getPseudoFile.js.map +1 -0
  3257. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedImportedTypes.js +60 -0
  3258. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedImportedTypes.js.map +1 -0
  3259. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +126 -0
  3260. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -0
  3261. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFile.js +6 -0
  3262. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFile.js.map +1 -0
  3263. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +17 -0
  3264. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -0
  3265. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForImports.js +12 -0
  3266. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForImports.js.map +1 -0
  3267. package/packages/analyze/src/lib/asts/sourceFiles/index.js +44 -0
  3268. package/packages/analyze/src/lib/asts/sourceFiles/index.js.map +1 -0
  3269. package/packages/analyze/src/lib/files/analyze/analyzeEntities/extractClassMethods.js +95 -0
  3270. package/packages/analyze/src/lib/files/analyze/analyzeEntities/extractClassMethods.js.map +1 -0
  3271. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +768 -0
  3272. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -0
  3273. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncComplex.js +79 -0
  3274. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncComplex.js.map +1 -0
  3275. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncSimple.js +20 -0
  3276. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/asyncSimple.js.map +1 -0
  3277. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/index.js +16 -0
  3278. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/index.js.map +1 -0
  3279. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/sequential.js +15 -0
  3280. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/sequential.js.map +1 -0
  3281. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/types.js +2 -0
  3282. package/packages/analyze/src/lib/files/analyze/analyzeEntities/strategies/types.js.map +1 -0
  3283. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +378 -0
  3284. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -0
  3285. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +83 -0
  3286. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -0
  3287. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +182 -0
  3288. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -0
  3289. package/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.js +15 -0
  3290. package/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.js.map +1 -0
  3291. package/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.js +13 -0
  3292. package/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.js.map +1 -0
  3293. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +84 -0
  3294. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -0
  3295. package/packages/analyze/src/lib/files/analyze/generateAnalysisTreeSha.js +118 -0
  3296. package/packages/analyze/src/lib/files/analyze/generateAnalysisTreeSha.js.map +1 -0
  3297. package/packages/analyze/src/lib/files/analyze/generateAnalyzedTreeSha.js +7 -0
  3298. package/packages/analyze/src/lib/files/analyze/generateAnalyzedTreeSha.js.map +1 -0
  3299. package/packages/analyze/src/lib/files/analyze/guessDefaultWidth.js +12 -0
  3300. package/packages/analyze/src/lib/files/analyze/guessDefaultWidth.js.map +1 -0
  3301. package/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.js +94 -0
  3302. package/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.js.map +1 -0
  3303. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +78 -0
  3304. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -0
  3305. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +106 -0
  3306. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -0
  3307. package/packages/analyze/src/lib/files/analyzeChange.js +148 -0
  3308. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -0
  3309. package/packages/analyze/src/lib/files/analyzeCodeChange.js +38 -0
  3310. package/packages/analyze/src/lib/files/analyzeCodeChange.js.map +1 -0
  3311. package/packages/analyze/src/lib/files/analyzeEntity.js +396 -0
  3312. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -0
  3313. package/packages/analyze/src/lib/files/analyzeFrameworkRoute.js +13 -0
  3314. package/packages/analyze/src/lib/files/analyzeFrameworkRoute.js.map +1 -0
  3315. package/packages/analyze/src/lib/files/analyzeInitial.js +119 -0
  3316. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -0
  3317. package/packages/analyze/src/lib/files/analyzeNextRoute.js +81 -0
  3318. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -0
  3319. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +103 -0
  3320. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -0
  3321. package/packages/analyze/src/lib/files/enums/steps.js +18 -0
  3322. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -0
  3323. package/packages/analyze/src/lib/files/extractDiffLines.js +22 -0
  3324. package/packages/analyze/src/lib/files/extractDiffLines.js.map +1 -0
  3325. package/packages/analyze/src/lib/files/fileAnalyzerFromCode.js +41 -0
  3326. package/packages/analyze/src/lib/files/fileAnalyzerFromCode.js.map +1 -0
  3327. package/packages/analyze/src/lib/files/findScenarioData.js +30 -0
  3328. package/packages/analyze/src/lib/files/findScenarioData.js.map +1 -0
  3329. package/packages/analyze/src/lib/files/getEntityCode.js +14 -0
  3330. package/packages/analyze/src/lib/files/getEntityCode.js.map +1 -0
  3331. package/packages/analyze/src/lib/files/getEntityType.js +13 -0
  3332. package/packages/analyze/src/lib/files/getEntityType.js.map +1 -0
  3333. package/packages/analyze/src/lib/files/getImportedExports.js +195 -0
  3334. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -0
  3335. package/packages/analyze/src/lib/files/getNodeModuleImports.js +24 -0
  3336. package/packages/analyze/src/lib/files/getNodeModuleImports.js.map +1 -0
  3337. package/packages/analyze/src/lib/files/newAnalysis.js +26 -0
  3338. package/packages/analyze/src/lib/files/newAnalysis.js.map +1 -0
  3339. package/packages/analyze/src/lib/files/recordStep.js +24 -0
  3340. package/packages/analyze/src/lib/files/recordStep.js.map +1 -0
  3341. package/packages/analyze/src/lib/files/relevantDiffPart.js +63 -0
  3342. package/packages/analyze/src/lib/files/relevantDiffPart.js.map +1 -0
  3343. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  3344. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  3345. package/packages/analyze/src/lib/files/scenarios/detectChangedDataStructureFields.js +75 -0
  3346. package/packages/analyze/src/lib/files/scenarios/detectChangedDataStructureFields.js.map +1 -0
  3347. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +255 -0
  3348. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -0
  3349. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
  3350. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
  3351. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +713 -0
  3352. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -0
  3353. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js +110 -0
  3354. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js.map +1 -0
  3355. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +158 -0
  3356. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -0
  3357. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +665 -0
  3358. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -0
  3359. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +104 -0
  3360. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  3361. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +140 -0
  3362. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -0
  3363. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +93 -0
  3364. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -0
  3365. package/packages/analyze/src/lib/files/scenarios/isolateDataStructure.js +39 -0
  3366. package/packages/analyze/src/lib/files/scenarios/isolateDataStructure.js.map +1 -0
  3367. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1448 -0
  3368. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -0
  3369. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +188 -0
  3370. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -0
  3371. package/packages/analyze/src/lib/files/setImportedExports.js +208 -0
  3372. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -0
  3373. package/packages/analyze/src/lib/index.js +7 -0
  3374. package/packages/analyze/src/lib/index.js.map +1 -0
  3375. package/packages/analyze/src/lib/projects/index.js +42 -0
  3376. package/packages/analyze/src/lib/projects/index.js.map +1 -0
  3377. package/packages/analyze/src/lib/types/index.js +11 -0
  3378. package/packages/analyze/src/lib/types/index.js.map +1 -0
  3379. package/packages/analyze/src/lib/utils/deepEqual.js +32 -0
  3380. package/packages/analyze/src/lib/utils/deepEqual.js.map +1 -0
  3381. package/packages/analyze/src/lib/utils/getAnalysisError.js +4 -0
  3382. package/packages/analyze/src/lib/utils/getAnalysisError.js.map +1 -0
  3383. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  3384. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  3385. package/packages/analyze/src/lib/utils/measureAndReportExecutionTime.js +16 -0
  3386. package/packages/analyze/src/lib/utils/measureAndReportExecutionTime.js.map +1 -0
  3387. package/packages/analyze/src/lib/utils/measureExecutionTime.js +11 -0
  3388. package/packages/analyze/src/lib/utils/measureExecutionTime.js.map +1 -0
  3389. package/packages/aws/dynamodb/index.js +6 -0
  3390. package/packages/aws/dynamodb/index.js.map +1 -0
  3391. package/packages/aws/ecs/index.js +7 -0
  3392. package/packages/aws/ecs/index.js.map +1 -0
  3393. package/packages/aws/sqs/index.js +4 -0
  3394. package/packages/aws/sqs/index.js.map +1 -0
  3395. package/packages/aws/src/lib/dynamodb/loadLlmCall.js +26 -0
  3396. package/packages/aws/src/lib/dynamodb/loadLlmCall.js.map +1 -0
  3397. package/packages/aws/src/lib/dynamodb/loadLlmCalls.js +35 -0
  3398. package/packages/aws/src/lib/dynamodb/loadLlmCalls.js.map +1 -0
  3399. package/packages/aws/src/lib/dynamodb/provisionTable.js +66 -0
  3400. package/packages/aws/src/lib/dynamodb/provisionTable.js.map +1 -0
  3401. package/packages/aws/src/lib/dynamodb/saveLlmCall.js +67 -0
  3402. package/packages/aws/src/lib/dynamodb/saveLlmCall.js.map +1 -0
  3403. package/packages/aws/src/lib/dynamodb/tableNames.js +6 -0
  3404. package/packages/aws/src/lib/dynamodb/tableNames.js.map +1 -0
  3405. package/packages/aws/src/lib/dynamodb/types.js +2 -0
  3406. package/packages/aws/src/lib/dynamodb/types.js.map +1 -0
  3407. package/packages/aws/src/lib/ecs/ecsCheckTaskStatus.js +36 -0
  3408. package/packages/aws/src/lib/ecs/ecsCheckTaskStatus.js.map +1 -0
  3409. package/packages/aws/src/lib/ecs/ecsCreateTaskDefinition.js +138 -0
  3410. package/packages/aws/src/lib/ecs/ecsCreateTaskDefinition.js.map +1 -0
  3411. package/packages/aws/src/lib/ecs/ecsDefineContainer.js +30 -0
  3412. package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -0
  3413. package/packages/aws/src/lib/ecs/ecsStartTask.js +51 -0
  3414. package/packages/aws/src/lib/ecs/ecsStartTask.js.map +1 -0
  3415. package/packages/aws/src/lib/ecs/ecsTaskFactory.js +43 -0
  3416. package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -0
  3417. package/packages/aws/src/lib/sqs/getSqsQueueSizeStats.js +15 -0
  3418. package/packages/aws/src/lib/sqs/getSqsQueueSizeStats.js.map +1 -0
  3419. package/packages/aws/src/lib/sqs/sendSqsMessage.js +9 -0
  3420. package/packages/aws/src/lib/sqs/sendSqsMessage.js.map +1 -0
  3421. package/packages/database/index.js +85 -0
  3422. package/packages/database/index.js.map +1 -0
  3423. package/packages/database/src/lib/analysisBranchToDb.js +19 -0
  3424. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -0
  3425. package/packages/database/src/lib/analysisToDb.js +26 -0
  3426. package/packages/database/src/lib/analysisToDb.js.map +1 -0
  3427. package/packages/database/src/lib/backgroundJobToDb.js +13 -0
  3428. package/packages/database/src/lib/backgroundJobToDb.js.map +1 -0
  3429. package/packages/database/src/lib/branchToDb.js +18 -0
  3430. package/packages/database/src/lib/branchToDb.js.map +1 -0
  3431. package/packages/database/src/lib/commitBranchToDb.js +13 -0
  3432. package/packages/database/src/lib/commitBranchToDb.js.map +1 -0
  3433. package/packages/database/src/lib/commitToDb.js +26 -0
  3434. package/packages/database/src/lib/commitToDb.js.map +1 -0
  3435. package/packages/database/src/lib/createOrUpdateBranchCommitStats.js +108 -0
  3436. package/packages/database/src/lib/createOrUpdateBranchCommitStats.js.map +1 -0
  3437. package/packages/database/src/lib/createProject.js +22 -0
  3438. package/packages/database/src/lib/createProject.js.map +1 -0
  3439. package/packages/database/src/lib/createRetryFetch.js +42 -0
  3440. package/packages/database/src/lib/createRetryFetch.js.map +1 -0
  3441. package/packages/database/src/lib/dbToAnalysis.js +48 -0
  3442. package/packages/database/src/lib/dbToAnalysis.js.map +1 -0
  3443. package/packages/database/src/lib/dbToAnalysisBranch.js +24 -0
  3444. package/packages/database/src/lib/dbToAnalysisBranch.js.map +1 -0
  3445. package/packages/database/src/lib/dbToBackgroundJob.js +13 -0
  3446. package/packages/database/src/lib/dbToBackgroundJob.js.map +1 -0
  3447. package/packages/database/src/lib/dbToBranch.js +22 -0
  3448. package/packages/database/src/lib/dbToBranch.js.map +1 -0
  3449. package/packages/database/src/lib/dbToCommit.js +40 -0
  3450. package/packages/database/src/lib/dbToCommit.js.map +1 -0
  3451. package/packages/database/src/lib/dbToCommitBranch.js +18 -0
  3452. package/packages/database/src/lib/dbToCommitBranch.js.map +1 -0
  3453. package/packages/database/src/lib/dbToEntity.js +23 -0
  3454. package/packages/database/src/lib/dbToEntity.js.map +1 -0
  3455. package/packages/database/src/lib/dbToEntityBranch.js +13 -0
  3456. package/packages/database/src/lib/dbToEntityBranch.js.map +1 -0
  3457. package/packages/database/src/lib/dbToFile.js +14 -0
  3458. package/packages/database/src/lib/dbToFile.js.map +1 -0
  3459. package/packages/database/src/lib/dbToProject.js +16 -0
  3460. package/packages/database/src/lib/dbToProject.js.map +1 -0
  3461. package/packages/database/src/lib/dbToScenario.js +24 -0
  3462. package/packages/database/src/lib/dbToScenario.js.map +1 -0
  3463. package/packages/database/src/lib/dbToScenarioComment.js +21 -0
  3464. package/packages/database/src/lib/dbToScenarioComment.js.map +1 -0
  3465. package/packages/database/src/lib/dbToUserScenario.js +19 -0
  3466. package/packages/database/src/lib/dbToUserScenario.js.map +1 -0
  3467. package/packages/database/src/lib/deleteBranch.js +21 -0
  3468. package/packages/database/src/lib/deleteBranch.js.map +1 -0
  3469. package/packages/database/src/lib/deleteEntities.js +23 -0
  3470. package/packages/database/src/lib/deleteEntities.js.map +1 -0
  3471. package/packages/database/src/lib/deleteFile.js +18 -0
  3472. package/packages/database/src/lib/deleteFile.js.map +1 -0
  3473. package/packages/database/src/lib/deleteScenarios.js +34 -0
  3474. package/packages/database/src/lib/deleteScenarios.js.map +1 -0
  3475. package/packages/database/src/lib/entityToDb.js +54 -0
  3476. package/packages/database/src/lib/entityToDb.js.map +1 -0
  3477. package/packages/database/src/lib/fileToDb.js +14 -0
  3478. package/packages/database/src/lib/fileToDb.js.map +1 -0
  3479. package/packages/database/src/lib/generateSha.js +15 -0
  3480. package/packages/database/src/lib/generateSha.js.map +1 -0
  3481. package/packages/database/src/lib/jsonUpdateUtils.js +28 -0
  3482. package/packages/database/src/lib/jsonUpdateUtils.js.map +1 -0
  3483. package/packages/database/src/lib/kysely/aggregationHelpers.js +66 -0
  3484. package/packages/database/src/lib/kysely/aggregationHelpers.js.map +1 -0
  3485. package/packages/database/src/lib/kysely/db.js +378 -0
  3486. package/packages/database/src/lib/kysely/db.js.map +1 -0
  3487. package/packages/database/src/lib/kysely/schemaHelpers.js +17 -0
  3488. package/packages/database/src/lib/kysely/schemaHelpers.js.map +1 -0
  3489. package/packages/database/src/lib/kysely/sqliteBooleanPlugin.js +34 -0
  3490. package/packages/database/src/lib/kysely/sqliteBooleanPlugin.js.map +1 -0
  3491. package/packages/database/src/lib/kysely/tableRelations.js +2 -0
  3492. package/packages/database/src/lib/kysely/tableRelations.js.map +1 -0
  3493. package/packages/database/src/lib/kysely/tableRelationsTypes.js +7 -0
  3494. package/packages/database/src/lib/kysely/tableRelationsTypes.js.map +1 -0
  3495. package/packages/database/src/lib/kysely/tables/analysesTable.js +52 -0
  3496. package/packages/database/src/lib/kysely/tables/analysesTable.js.map +1 -0
  3497. package/packages/database/src/lib/kysely/tables/analysisBranchesTable.js +24 -0
  3498. package/packages/database/src/lib/kysely/tables/analysisBranchesTable.js.map +1 -0
  3499. package/packages/database/src/lib/kysely/tables/backgroundJobsTable.js +28 -0
  3500. package/packages/database/src/lib/kysely/tables/backgroundJobsTable.js.map +1 -0
  3501. package/packages/database/src/lib/kysely/tables/branchesTable.js +34 -0
  3502. package/packages/database/src/lib/kysely/tables/branchesTable.js.map +1 -0
  3503. package/packages/database/src/lib/kysely/tables/commitBranchesTable.js +22 -0
  3504. package/packages/database/src/lib/kysely/tables/commitBranchesTable.js.map +1 -0
  3505. package/packages/database/src/lib/kysely/tables/commitsTable.js +47 -0
  3506. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -0
  3507. package/packages/database/src/lib/kysely/tables/debugReportsTable.js +33 -0
  3508. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -0
  3509. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +76 -0
  3510. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  3511. package/packages/database/src/lib/kysely/tables/entitiesTable.js +38 -0
  3512. package/packages/database/src/lib/kysely/tables/entitiesTable.js.map +1 -0
  3513. package/packages/database/src/lib/kysely/tables/entityBranchesTable.js +22 -0
  3514. package/packages/database/src/lib/kysely/tables/entityBranchesTable.js.map +1 -0
  3515. package/packages/database/src/lib/kysely/tables/entityStatementsTable.js +22 -0
  3516. package/packages/database/src/lib/kysely/tables/entityStatementsTable.js.map +1 -0
  3517. package/packages/database/src/lib/kysely/tables/filesTable.js +28 -0
  3518. package/packages/database/src/lib/kysely/tables/filesTable.js.map +1 -0
  3519. package/packages/database/src/lib/kysely/tables/githubPayloadsTable.js +32 -0
  3520. package/packages/database/src/lib/kysely/tables/githubPayloadsTable.js.map +1 -0
  3521. package/packages/database/src/lib/kysely/tables/githubUsersTable.js +22 -0
  3522. package/packages/database/src/lib/kysely/tables/githubUsersTable.js.map +1 -0
  3523. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  3524. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  3525. package/packages/database/src/lib/kysely/tables/projectsTable.js +38 -0
  3526. package/packages/database/src/lib/kysely/tables/projectsTable.js.map +1 -0
  3527. package/packages/database/src/lib/kysely/tables/scenarioCommentsTable.js +28 -0
  3528. package/packages/database/src/lib/kysely/tables/scenarioCommentsTable.js.map +1 -0
  3529. package/packages/database/src/lib/kysely/tables/scenariosTable.js +30 -0
  3530. package/packages/database/src/lib/kysely/tables/scenariosTable.js.map +1 -0
  3531. package/packages/database/src/lib/kysely/tables/statementsTable.js +24 -0
  3532. package/packages/database/src/lib/kysely/tables/statementsTable.js.map +1 -0
  3533. package/packages/database/src/lib/kysely/tables/teamsTable.js +18 -0
  3534. package/packages/database/src/lib/kysely/tables/teamsTable.js.map +1 -0
  3535. package/packages/database/src/lib/kysely/tables/userScenariosTable.js +24 -0
  3536. package/packages/database/src/lib/kysely/tables/userScenariosTable.js.map +1 -0
  3537. package/packages/database/src/lib/kysely/tables/userTeamsTable.js +17 -0
  3538. package/packages/database/src/lib/kysely/tables/userTeamsTable.js.map +1 -0
  3539. package/packages/database/src/lib/kysely/tables/usersTable.js +26 -0
  3540. package/packages/database/src/lib/kysely/tables/usersTable.js.map +1 -0
  3541. package/packages/database/src/lib/kysely/upsertHelpers.js +9 -0
  3542. package/packages/database/src/lib/kysely/upsertHelpers.js.map +1 -0
  3543. package/packages/database/src/lib/loadAnalyses.js +174 -0
  3544. package/packages/database/src/lib/loadAnalyses.js.map +1 -0
  3545. package/packages/database/src/lib/loadAnalysis.js +138 -0
  3546. package/packages/database/src/lib/loadAnalysis.js.map +1 -0
  3547. package/packages/database/src/lib/loadAnalysisBranches.js +152 -0
  3548. package/packages/database/src/lib/loadAnalysisBranches.js.map +1 -0
  3549. package/packages/database/src/lib/loadBackgroundJob.js +19 -0
  3550. package/packages/database/src/lib/loadBackgroundJob.js.map +1 -0
  3551. package/packages/database/src/lib/loadBranch.js +100 -0
  3552. package/packages/database/src/lib/loadBranch.js.map +1 -0
  3553. package/packages/database/src/lib/loadBranches.js +37 -0
  3554. package/packages/database/src/lib/loadBranches.js.map +1 -0
  3555. package/packages/database/src/lib/loadCommit.js +118 -0
  3556. package/packages/database/src/lib/loadCommit.js.map +1 -0
  3557. package/packages/database/src/lib/loadCommitBranches.js +45 -0
  3558. package/packages/database/src/lib/loadCommitBranches.js.map +1 -0
  3559. package/packages/database/src/lib/loadCommitMetadata.js +26 -0
  3560. package/packages/database/src/lib/loadCommitMetadata.js.map +1 -0
  3561. package/packages/database/src/lib/loadCommits.js +219 -0
  3562. package/packages/database/src/lib/loadCommits.js.map +1 -0
  3563. package/packages/database/src/lib/loadEntities.js +76 -0
  3564. package/packages/database/src/lib/loadEntities.js.map +1 -0
  3565. package/packages/database/src/lib/loadEntity.js +72 -0
  3566. package/packages/database/src/lib/loadEntity.js.map +1 -0
  3567. package/packages/database/src/lib/loadEntityBranches.js +123 -0
  3568. package/packages/database/src/lib/loadEntityBranches.js.map +1 -0
  3569. package/packages/database/src/lib/loadFile.js +28 -0
  3570. package/packages/database/src/lib/loadFile.js.map +1 -0
  3571. package/packages/database/src/lib/loadFiles.js +101 -0
  3572. package/packages/database/src/lib/loadFiles.js.map +1 -0
  3573. package/packages/database/src/lib/loadMostRecentPreviousAnalysis.js +80 -0
  3574. package/packages/database/src/lib/loadMostRecentPreviousAnalysis.js.map +1 -0
  3575. package/packages/database/src/lib/loadProject.js +52 -0
  3576. package/packages/database/src/lib/loadProject.js.map +1 -0
  3577. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +65 -0
  3578. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -0
  3579. package/packages/database/src/lib/loadScenario.js +30 -0
  3580. package/packages/database/src/lib/loadScenario.js.map +1 -0
  3581. package/packages/database/src/lib/loadStatement.js +21 -0
  3582. package/packages/database/src/lib/loadStatement.js.map +1 -0
  3583. package/packages/database/src/lib/nullsToUndefines.js +7 -0
  3584. package/packages/database/src/lib/nullsToUndefines.js.map +1 -0
  3585. package/packages/database/src/lib/projectToDb.js +18 -0
  3586. package/packages/database/src/lib/projectToDb.js.map +1 -0
  3587. package/packages/database/src/lib/saveBackgroundEvent.js +10 -0
  3588. package/packages/database/src/lib/saveBackgroundEvent.js.map +1 -0
  3589. package/packages/database/src/lib/saveEntityStatements.js +20 -0
  3590. package/packages/database/src/lib/saveEntityStatements.js.map +1 -0
  3591. package/packages/database/src/lib/saveFiles.js +33 -0
  3592. package/packages/database/src/lib/saveFiles.js.map +1 -0
  3593. package/packages/database/src/lib/saveStatement.js +22 -0
  3594. package/packages/database/src/lib/saveStatement.js.map +1 -0
  3595. package/packages/database/src/lib/scenarioToDb.js +18 -0
  3596. package/packages/database/src/lib/scenarioToDb.js.map +1 -0
  3597. package/packages/database/src/lib/supabase.js +57 -0
  3598. package/packages/database/src/lib/supabase.js.map +1 -0
  3599. package/packages/database/src/lib/updateBackgroundJobProgress.js +61 -0
  3600. package/packages/database/src/lib/updateBackgroundJobProgress.js.map +1 -0
  3601. package/packages/database/src/lib/updateCommitMetadata.js +87 -0
  3602. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -0
  3603. package/packages/database/src/lib/updateEntityBranch.js +21 -0
  3604. package/packages/database/src/lib/updateEntityBranch.js.map +1 -0
  3605. package/packages/database/src/lib/updateFreshAnalysisMetadata.js +42 -0
  3606. package/packages/database/src/lib/updateFreshAnalysisMetadata.js.map +1 -0
  3607. package/packages/database/src/lib/updateFreshAnalysisStatus.js +53 -0
  3608. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -0
  3609. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +81 -0
  3610. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -0
  3611. package/packages/database/src/lib/updateProjectMetadata.js +60 -0
  3612. package/packages/database/src/lib/updateProjectMetadata.js.map +1 -0
  3613. package/packages/database/src/lib/upsertAnalyses.js +53 -0
  3614. package/packages/database/src/lib/upsertAnalyses.js.map +1 -0
  3615. package/packages/database/src/lib/upsertAnalysesWithScenarios.js +62 -0
  3616. package/packages/database/src/lib/upsertAnalysesWithScenarios.js.map +1 -0
  3617. package/packages/database/src/lib/upsertAnalysisBranches.js +72 -0
  3618. package/packages/database/src/lib/upsertAnalysisBranches.js.map +1 -0
  3619. package/packages/database/src/lib/upsertBackgroundJob.js +22 -0
  3620. package/packages/database/src/lib/upsertBackgroundJob.js.map +1 -0
  3621. package/packages/database/src/lib/upsertBranches.js +29 -0
  3622. package/packages/database/src/lib/upsertBranches.js.map +1 -0
  3623. package/packages/database/src/lib/upsertCommitBranches.js +29 -0
  3624. package/packages/database/src/lib/upsertCommitBranches.js.map +1 -0
  3625. package/packages/database/src/lib/upsertCommits.js +41 -0
  3626. package/packages/database/src/lib/upsertCommits.js.map +1 -0
  3627. package/packages/database/src/lib/upsertEntities.js +82 -0
  3628. package/packages/database/src/lib/upsertEntities.js.map +1 -0
  3629. package/packages/database/src/lib/upsertEntityBranches.js +27 -0
  3630. package/packages/database/src/lib/upsertEntityBranches.js.map +1 -0
  3631. package/packages/database/src/lib/upsertFiles.js +32 -0
  3632. package/packages/database/src/lib/upsertFiles.js.map +1 -0
  3633. package/packages/database/src/lib/upsertGithubUser.js +27 -0
  3634. package/packages/database/src/lib/upsertGithubUser.js.map +1 -0
  3635. package/packages/database/src/lib/upsertProjects.js +27 -0
  3636. package/packages/database/src/lib/upsertProjects.js.map +1 -0
  3637. package/packages/database/src/lib/upsertScenarios.js +28 -0
  3638. package/packages/database/src/lib/upsertScenarios.js.map +1 -0
  3639. package/packages/generate/index.js +16 -0
  3640. package/packages/generate/index.js.map +1 -0
  3641. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +136 -0
  3642. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -0
  3643. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js +108 -0
  3644. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageRemix.js.map +1 -0
  3645. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +217 -0
  3646. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  3647. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  3648. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  3649. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +110 -0
  3650. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -0
  3651. package/packages/generate/src/lib/componentScenarioPage/getImageReplacementCode.js +134 -0
  3652. package/packages/generate/src/lib/componentScenarioPage/getImageReplacementCode.js.map +1 -0
  3653. package/packages/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js +67 -0
  3654. package/packages/generate/src/lib/componentScenarioPage/getNextJsErrorClosingCode.js.map +1 -0
  3655. package/packages/generate/src/lib/constants.js +3 -0
  3656. package/packages/generate/src/lib/constants.js.map +1 -0
  3657. package/packages/generate/src/lib/deepMerge.js +72 -0
  3658. package/packages/generate/src/lib/deepMerge.js.map +1 -0
  3659. package/packages/generate/src/lib/directExecutionScript.js +165 -0
  3660. package/packages/generate/src/lib/directExecutionScript.js.map +1 -0
  3661. package/packages/generate/src/lib/escapeQuotes.js +4 -0
  3662. package/packages/generate/src/lib/escapeQuotes.js.map +1 -0
  3663. package/packages/generate/src/lib/getComponentImportStatement.js +23 -0
  3664. package/packages/generate/src/lib/getComponentImportStatement.js.map +1 -0
  3665. package/packages/generate/src/lib/getComponentImportStatements.js +24 -0
  3666. package/packages/generate/src/lib/getComponentImportStatements.js.map +1 -0
  3667. package/packages/generate/src/lib/getComponentScenarioPath.js +25 -0
  3668. package/packages/generate/src/lib/getComponentScenarioPath.js.map +1 -0
  3669. package/packages/generate/src/lib/getRelativePath.js +32 -0
  3670. package/packages/generate/src/lib/getRelativePath.js.map +1 -0
  3671. package/packages/generate/src/lib/handleCmdk.js +50 -0
  3672. package/packages/generate/src/lib/handleCmdk.js.map +1 -0
  3673. package/packages/generate/src/lib/handleRadix.js +224 -0
  3674. package/packages/generate/src/lib/handleRadix.js.map +1 -0
  3675. package/packages/generate/src/lib/handleWrappers.js +24 -0
  3676. package/packages/generate/src/lib/handleWrappers.js.map +1 -0
  3677. package/packages/generate/src/lib/libDemoComponent.js +160 -0
  3678. package/packages/generate/src/lib/libDemoComponent.js.map +1 -0
  3679. package/packages/generate/src/lib/mergeRootRemix.js +323 -0
  3680. package/packages/generate/src/lib/mergeRootRemix.js.map +1 -0
  3681. package/packages/generate/src/lib/requiredNodeModuleImports.js +45 -0
  3682. package/packages/generate/src/lib/requiredNodeModuleImports.js.map +1 -0
  3683. package/packages/generate/src/lib/safeFolder.js +11 -0
  3684. package/packages/generate/src/lib/safeFolder.js.map +1 -0
  3685. package/packages/generate/src/lib/scenarioComponent.js +94 -0
  3686. package/packages/generate/src/lib/scenarioComponent.js.map +1 -0
  3687. package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
  3688. package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  3689. package/packages/generate/src/lib/simpleRootRemix.js +73 -0
  3690. package/packages/generate/src/lib/simpleRootRemix.js.map +1 -0
  3691. package/packages/github/index.js +23 -0
  3692. package/packages/github/index.js.map +1 -0
  3693. package/packages/github/src/lib/constants.js +4 -0
  3694. package/packages/github/src/lib/constants.js.map +1 -0
  3695. package/packages/github/src/lib/createProjectOctokit.js +48 -0
  3696. package/packages/github/src/lib/createProjectOctokit.js.map +1 -0
  3697. package/packages/github/src/lib/getBranches.js +14 -0
  3698. package/packages/github/src/lib/getBranches.js.map +1 -0
  3699. package/packages/github/src/lib/getCommit.js +12 -0
  3700. package/packages/github/src/lib/getCommit.js.map +1 -0
  3701. package/packages/github/src/lib/getCommitFromGithub.js +57 -0
  3702. package/packages/github/src/lib/getCommitFromGithub.js.map +1 -0
  3703. package/packages/github/src/lib/getCommits.js +37 -0
  3704. package/packages/github/src/lib/getCommits.js.map +1 -0
  3705. package/packages/github/src/lib/getCommitsFromGithub.js +163 -0
  3706. package/packages/github/src/lib/getCommitsFromGithub.js.map +1 -0
  3707. package/packages/github/src/lib/getDiffBetweenCommits.js +26 -0
  3708. package/packages/github/src/lib/getDiffBetweenCommits.js.map +1 -0
  3709. package/packages/github/src/lib/getFirstCommitShaAfterTimestamp.js +22 -0
  3710. package/packages/github/src/lib/getFirstCommitShaAfterTimestamp.js.map +1 -0
  3711. package/packages/github/src/lib/getLatestCommit.js +28 -0
  3712. package/packages/github/src/lib/getLatestCommit.js.map +1 -0
  3713. package/packages/github/src/lib/getOpenPullRequests.js +28 -0
  3714. package/packages/github/src/lib/getOpenPullRequests.js.map +1 -0
  3715. package/packages/github/src/lib/getPublicReposWithQuery.js +12 -0
  3716. package/packages/github/src/lib/getPublicReposWithQuery.js.map +1 -0
  3717. package/packages/github/src/lib/getPullRequestsForCommit.js +21 -0
  3718. package/packages/github/src/lib/getPullRequestsForCommit.js.map +1 -0
  3719. package/packages/github/src/lib/getRepoInfo.js +35 -0
  3720. package/packages/github/src/lib/getRepoInfo.js.map +1 -0
  3721. package/packages/github/src/lib/getRepoWithBranches.js +53 -0
  3722. package/packages/github/src/lib/getRepoWithBranches.js.map +1 -0
  3723. package/packages/github/src/lib/getRepos.js +13 -0
  3724. package/packages/github/src/lib/getRepos.js.map +1 -0
  3725. package/packages/github/src/lib/getTree.js +14 -0
  3726. package/packages/github/src/lib/getTree.js.map +1 -0
  3727. package/packages/github/src/lib/githubToCommit.js +20 -0
  3728. package/packages/github/src/lib/githubToCommit.js.map +1 -0
  3729. package/packages/github/src/lib/loadOrCreateCommit.js +149 -0
  3730. package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -0
  3731. package/packages/github/src/lib/syncHeadBranches.js +38 -0
  3732. package/packages/github/src/lib/syncHeadBranches.js.map +1 -0
  3733. package/packages/github/src/lib/syncPrimaryBranch.js +75 -0
  3734. package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -0
  3735. package/packages/github/src/lib/syncPullRequest.js +48 -0
  3736. package/packages/github/src/lib/syncPullRequest.js.map +1 -0
  3737. package/packages/github/src/lib/updateCommitBranchesInDb.js +40 -0
  3738. package/packages/github/src/lib/updateCommitBranchesInDb.js.map +1 -0
  3739. package/packages/github/src/lib/updateFilesInDb.js +74 -0
  3740. package/packages/github/src/lib/updateFilesInDb.js.map +1 -0
  3741. package/packages/github/src/lib/urls.js +11 -0
  3742. package/packages/github/src/lib/urls.js.map +1 -0
  3743. package/packages/process/index.js +3 -0
  3744. package/packages/process/index.js.map +1 -0
  3745. package/packages/process/src/GlobalProcessManager.js +75 -0
  3746. package/packages/process/src/GlobalProcessManager.js.map +1 -0
  3747. package/packages/process/src/ProcessManager.js +244 -0
  3748. package/packages/process/src/ProcessManager.js.map +1 -0
  3749. package/packages/process/src/index.js +57 -0
  3750. package/packages/process/src/index.js.map +1 -0
  3751. package/packages/process/src/managedExecAsync.js +74 -0
  3752. package/packages/process/src/managedExecAsync.js.map +1 -0
  3753. package/packages/types/index.js +4 -0
  3754. package/packages/types/index.js.map +1 -0
  3755. package/packages/types/src/constants.js +2 -0
  3756. package/packages/types/src/constants.js.map +1 -0
  3757. package/packages/types/src/enums/ProjectFramework.js +12 -0
  3758. package/packages/types/src/enums/ProjectFramework.js.map +1 -0
  3759. package/packages/types/src/types/Analysis.js +3 -0
  3760. package/packages/types/src/types/Analysis.js.map +1 -0
  3761. package/packages/types/src/types/AnalysisBranch.js +2 -0
  3762. package/packages/types/src/types/AnalysisBranch.js.map +1 -0
  3763. package/packages/types/src/types/AnalysisMap.js +2 -0
  3764. package/packages/types/src/types/AnalysisMap.js.map +1 -0
  3765. package/packages/types/src/types/BackgroundJob.js +2 -0
  3766. package/packages/types/src/types/BackgroundJob.js.map +1 -0
  3767. package/packages/types/src/types/Branch.js +2 -0
  3768. package/packages/types/src/types/Branch.js.map +1 -0
  3769. package/packages/types/src/types/CodeExplanation.js +2 -0
  3770. package/packages/types/src/types/CodeExplanation.js.map +1 -0
  3771. package/packages/types/src/types/Commit.js +2 -0
  3772. package/packages/types/src/types/Commit.js.map +1 -0
  3773. package/packages/types/src/types/CommitBranch.js +2 -0
  3774. package/packages/types/src/types/CommitBranch.js.map +1 -0
  3775. package/packages/types/src/types/CommitChange.js +2 -0
  3776. package/packages/types/src/types/CommitChange.js.map +1 -0
  3777. package/packages/types/src/types/DeepPartial.js +2 -0
  3778. package/packages/types/src/types/DeepPartial.js.map +1 -0
  3779. package/packages/types/src/types/DeepReadonly.js +2 -0
  3780. package/packages/types/src/types/DeepReadonly.js.map +1 -0
  3781. package/packages/types/src/types/DependencyTreeNode.js +2 -0
  3782. package/packages/types/src/types/DependencyTreeNode.js.map +1 -0
  3783. package/packages/types/src/types/Entity.js +2 -0
  3784. package/packages/types/src/types/Entity.js.map +1 -0
  3785. package/packages/types/src/types/EntityBranch.js +2 -0
  3786. package/packages/types/src/types/EntityBranch.js.map +1 -0
  3787. package/packages/types/src/types/EntityMap.js +2 -0
  3788. package/packages/types/src/types/EntityMap.js.map +1 -0
  3789. package/packages/types/src/types/EntityType.js +2 -0
  3790. package/packages/types/src/types/EntityType.js.map +1 -0
  3791. package/packages/types/src/types/File.js +2 -0
  3792. package/packages/types/src/types/File.js.map +1 -0
  3793. package/packages/types/src/types/FilePreMock.js +2 -0
  3794. package/packages/types/src/types/FilePreMock.js.map +1 -0
  3795. package/packages/types/src/types/FileProp.js +2 -0
  3796. package/packages/types/src/types/FileProp.js.map +1 -0
  3797. package/packages/types/src/types/FileType.js +2 -0
  3798. package/packages/types/src/types/FileType.js.map +1 -0
  3799. package/packages/types/src/types/GithubBranch.js +2 -0
  3800. package/packages/types/src/types/GithubBranch.js.map +1 -0
  3801. package/packages/types/src/types/GithubFile.js +2 -0
  3802. package/packages/types/src/types/GithubFile.js.map +1 -0
  3803. package/packages/types/src/types/GithubRepoData.js +2 -0
  3804. package/packages/types/src/types/GithubRepoData.js.map +1 -0
  3805. package/packages/types/src/types/GithubRepoInfo.js +2 -0
  3806. package/packages/types/src/types/GithubRepoInfo.js.map +1 -0
  3807. package/packages/types/src/types/JsonTypeDefinition.js +2 -0
  3808. package/packages/types/src/types/JsonTypeDefinition.js.map +1 -0
  3809. package/packages/types/src/types/LlmCall.js +2 -0
  3810. package/packages/types/src/types/LlmCall.js.map +1 -0
  3811. package/packages/types/src/types/Mock.js +2 -0
  3812. package/packages/types/src/types/Mock.js.map +1 -0
  3813. package/packages/types/src/types/Project.js +2 -0
  3814. package/packages/types/src/types/Project.js.map +1 -0
  3815. package/packages/types/src/types/ProjectMetadata.js +2 -0
  3816. package/packages/types/src/types/ProjectMetadata.js.map +1 -0
  3817. package/packages/types/src/types/PropsWithTypes.js +2 -0
  3818. package/packages/types/src/types/PropsWithTypes.js.map +1 -0
  3819. package/packages/types/src/types/Scenario.js +2 -0
  3820. package/packages/types/src/types/Scenario.js.map +1 -0
  3821. package/packages/types/src/types/ScenarioComment.js +2 -0
  3822. package/packages/types/src/types/ScenarioComment.js.map +1 -0
  3823. package/packages/types/src/types/ScenarioData.js +2 -0
  3824. package/packages/types/src/types/ScenarioData.js.map +1 -0
  3825. package/packages/types/src/types/ScenariosDataStructure.js +2 -0
  3826. package/packages/types/src/types/ScenariosDataStructure.js.map +1 -0
  3827. package/packages/types/src/types/ScopeAnalysis.js +2 -0
  3828. package/packages/types/src/types/ScopeAnalysis.js.map +1 -0
  3829. package/packages/types/src/types/Statement.js +2 -0
  3830. package/packages/types/src/types/Statement.js.map +1 -0
  3831. package/packages/types/src/types/StatementInfo.js +2 -0
  3832. package/packages/types/src/types/StatementInfo.js.map +1 -0
  3833. package/packages/types/src/types/Team.js +2 -0
  3834. package/packages/types/src/types/Team.js.map +1 -0
  3835. package/packages/types/src/types/TimelineItem.js +2 -0
  3836. package/packages/types/src/types/TimelineItem.js.map +1 -0
  3837. package/packages/types/src/types/TsConfigPaths.js +2 -0
  3838. package/packages/types/src/types/TsConfigPaths.js.map +1 -0
  3839. package/packages/types/src/types/TypeStructures.js +2 -0
  3840. package/packages/types/src/types/TypeStructures.js.map +1 -0
  3841. package/packages/types/src/types/User.js +2 -0
  3842. package/packages/types/src/types/User.js.map +1 -0
  3843. package/packages/types/src/types/UserScenario.js +2 -0
  3844. package/packages/types/src/types/UserScenario.js.map +1 -0
  3845. package/packages/types/src/types/WebContainerFileSystemTree.js +2 -0
  3846. package/packages/types/src/types/WebContainerFileSystemTree.js.map +1 -0
  3847. package/packages/utils/index.js +31 -0
  3848. package/packages/utils/index.js.map +1 -0
  3849. package/packages/utils/server.js +13 -0
  3850. package/packages/utils/server.js.map +1 -0
  3851. package/packages/utils/src/lib/Semaphore.js +40 -0
  3852. package/packages/utils/src/lib/Semaphore.js.map +1 -0
  3853. package/packages/utils/src/lib/analyses/pushAnalysisError.js +10 -0
  3854. package/packages/utils/src/lib/analyses/pushAnalysisError.js.map +1 -0
  3855. package/packages/utils/src/lib/applyUniversalMocks.js +288 -0
  3856. package/packages/utils/src/lib/applyUniversalMocks.js.map +1 -0
  3857. package/packages/utils/src/lib/awsLog.js +48 -0
  3858. package/packages/utils/src/lib/awsLog.js.map +1 -0
  3859. package/packages/utils/src/lib/commitRuns.js +14 -0
  3860. package/packages/utils/src/lib/commitRuns.js.map +1 -0
  3861. package/packages/utils/src/lib/env/detectEnvFiles.js +217 -0
  3862. package/packages/utils/src/lib/env/detectEnvFiles.js.map +1 -0
  3863. package/packages/utils/src/lib/env/index.js +3 -0
  3864. package/packages/utils/src/lib/env/index.js.map +1 -0
  3865. package/packages/utils/src/lib/env/sanitizeEnvFiles.js +145 -0
  3866. package/packages/utils/src/lib/env/sanitizeEnvFiles.js.map +1 -0
  3867. package/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +25 -0
  3868. package/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -0
  3869. package/packages/utils/src/lib/frameworks/getFrameworkRoutePath.js +29 -0
  3870. package/packages/utils/src/lib/frameworks/getFrameworkRoutePath.js.map +1 -0
  3871. package/packages/utils/src/lib/frameworks/getNextRoutePath.js +22 -0
  3872. package/packages/utils/src/lib/frameworks/getNextRoutePath.js.map +1 -0
  3873. package/packages/utils/src/lib/frameworks/getRemixRoutePath.js +20 -0
  3874. package/packages/utils/src/lib/frameworks/getRemixRoutePath.js.map +1 -0
  3875. package/packages/utils/src/lib/frameworks/isFrameworkRoute.js +7 -0
  3876. package/packages/utils/src/lib/frameworks/isFrameworkRoute.js.map +1 -0
  3877. package/packages/utils/src/lib/frameworks/isNextRoute.js +12 -0
  3878. package/packages/utils/src/lib/frameworks/isNextRoute.js.map +1 -0
  3879. package/packages/utils/src/lib/frameworks/isRemixRoute.js +8 -0
  3880. package/packages/utils/src/lib/frameworks/isRemixRoute.js.map +1 -0
  3881. package/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +26 -0
  3882. package/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -0
  3883. package/packages/utils/src/lib/frameworks/remixRouteFileNameToRoute.js +22 -0
  3884. package/packages/utils/src/lib/frameworks/remixRouteFileNameToRoute.js.map +1 -0
  3885. package/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +62 -0
  3886. package/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -0
  3887. package/packages/utils/src/lib/fs/copyNodeRepoQuickly.js +181 -0
  3888. package/packages/utils/src/lib/fs/copyNodeRepoQuickly.js.map +1 -0
  3889. package/packages/utils/src/lib/fs/rsyncCopy.js +136 -0
  3890. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -0
  3891. package/packages/utils/src/lib/getFrameworkForFile.js +64 -0
  3892. package/packages/utils/src/lib/getFrameworkForFile.js.map +1 -0
  3893. package/packages/utils/src/lib/killProcess.server.js +102 -0
  3894. package/packages/utils/src/lib/killProcess.server.js.map +1 -0
  3895. package/packages/utils/src/lib/killProcessAndSubprocesses.server.js +62 -0
  3896. package/packages/utils/src/lib/killProcessAndSubprocesses.server.js.map +1 -0
  3897. package/packages/utils/src/lib/lightweightEntityExtractor.js +362 -0
  3898. package/packages/utils/src/lib/lightweightEntityExtractor.js.map +1 -0
  3899. package/packages/utils/src/lib/loadEnv.js +7 -0
  3900. package/packages/utils/src/lib/loadEnv.js.map +1 -0
  3901. package/packages/utils/src/lib/normalizeKey.js +4 -0
  3902. package/packages/utils/src/lib/normalizeKey.js.map +1 -0
  3903. package/packages/utils/src/lib/safeFileName.js +36 -0
  3904. package/packages/utils/src/lib/safeFileName.js.map +1 -0
  3905. package/packages/utils/src/lib/safeStringify.js +64 -0
  3906. package/packages/utils/src/lib/safeStringify.js.map +1 -0
  3907. package/packages/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  3908. package/packages/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  3909. package/packages/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  3910. package/packages/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  3911. package/packages/utils/src/lib/startCommand/index.js +3 -0
  3912. package/packages/utils/src/lib/startCommand/index.js.map +1 -0
  3913. package/scripts/npm-post-install.cjs +34 -0
  3914. package/bin.js +0 -13
@@ -0,0 +1,3769 @@
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
+ getComparisonOperatorString,
13
+ isArithmeticOperator,
14
+ isAssignmentOperator,
15
+ isBitwiseCompoundOperator,
16
+ isComparisonOperator,
17
+ isDefinedType,
18
+ isNumericCompoundOperator,
19
+ leftOrRightType,
20
+ unwrapExpression,
21
+ } from './sharedPatterns';
22
+ import { processBindingPattern } from './processBindings';
23
+ import {
24
+ extractConditionalEffectsFromTernary,
25
+ findUseStateSetters,
26
+ } from './conditionalEffectsExtractor';
27
+ import { detectArrayDerivedPattern } from './arrayDerivationDetector';
28
+
29
+ /**
30
+ * Recursively extracts root variable names from an expression AST node.
31
+ * Used to identify which variables flow into JSX expression children,
32
+ * so we can link them to the return value schema.
33
+ *
34
+ * Examples:
35
+ * - `filteredTopPaths.map(...)` → ['filteredTopPaths']
36
+ * - `a && b` → ['a', 'b']
37
+ * - `condition ? x : y` → ['condition', 'x', 'y']
38
+ */
39
+ function extractRootVariableNames(node: ts.Expression): string[] {
40
+ const ignoredIdentifiers = new Set([
41
+ 'undefined',
42
+ 'null',
43
+ 'true',
44
+ 'false',
45
+ 'NaN',
46
+ 'Infinity',
47
+ ]);
48
+
49
+ if (ts.isIdentifier(node)) {
50
+ const name = node.text;
51
+ return ignoredIdentifiers.has(name) ? [] : [name];
52
+ }
53
+
54
+ if (ts.isPropertyAccessExpression(node)) {
55
+ return extractRootVariableNames(node.expression);
56
+ }
57
+
58
+ if (ts.isCallExpression(node)) {
59
+ return extractRootVariableNames(node.expression);
60
+ }
61
+
62
+ if (ts.isBinaryExpression(node)) {
63
+ return [
64
+ ...extractRootVariableNames(node.left),
65
+ ...extractRootVariableNames(node.right),
66
+ ];
67
+ }
68
+
69
+ if (ts.isPrefixUnaryExpression(node)) {
70
+ return extractRootVariableNames(node.operand);
71
+ }
72
+
73
+ if (ts.isConditionalExpression(node)) {
74
+ return [
75
+ ...extractRootVariableNames(node.condition),
76
+ ...extractRootVariableNames(node.whenTrue),
77
+ ...extractRootVariableNames(node.whenFalse),
78
+ ];
79
+ }
80
+
81
+ if (ts.isParenthesizedExpression(node)) {
82
+ return extractRootVariableNames(node.expression);
83
+ }
84
+
85
+ // Stop recursion at JSX elements and other terminal nodes
86
+ if (
87
+ ts.isJsxElement(node) ||
88
+ ts.isJsxFragment(node) ||
89
+ ts.isJsxSelfClosingElement(node)
90
+ ) {
91
+ return [];
92
+ }
93
+
94
+ return [];
95
+ }
96
+
97
+ /**
98
+ * Checks if a JSX element has props that reference variables from the parent scope.
99
+ * This is used to detect unconditionally-rendered children that should have their
100
+ * execution flows merged into the parent.
101
+ *
102
+ * We want to track children where the parent controls data that affects the child's
103
+ * conditional rendering. Static props (like title="Dashboard") don't need tracking
104
+ * because they don't create variable execution flows.
105
+ *
106
+ * Examples:
107
+ * - <WorkoutsView workouts={workouts} /> → true (workouts is a variable)
108
+ * - <ItemList items={items} count={count} /> → true (items, count are variables)
109
+ * - <Header title="Dashboard" /> → false (static string)
110
+ * - <Footer /> → false (no props)
111
+ * - <Button onClick={handleClick} /> → false (only callback, no data props)
112
+ *
113
+ * @returns true if the component has at least one prop that references a variable
114
+ * (excluding callbacks which typically start with 'on' or 'handle')
115
+ */
116
+ function hasDataPropsFromParent(
117
+ node: ts.JsxElement | ts.JsxSelfClosingElement,
118
+ componentName: string,
119
+ ): { hasDataProps: boolean; dataProps: string[] } {
120
+ const attributes = ts.isJsxElement(node)
121
+ ? node.openingElement.attributes.properties
122
+ : node.attributes.properties;
123
+
124
+ const dataProps: string[] = [];
125
+
126
+ for (const attr of attributes) {
127
+ // Spread attributes always reference parent data: {...props}
128
+ if (ts.isJsxSpreadAttribute(attr)) {
129
+ const spreadText = attr.expression?.getText() || '...spread';
130
+ dataProps.push(`{...${spreadText}}`);
131
+ console.log(
132
+ `[UnconditionalChild] ${componentName}: Found spread attribute {${spreadText}}`,
133
+ );
134
+ continue;
135
+ }
136
+
137
+ if (ts.isJsxAttribute(attr)) {
138
+ const propName = attr.name.getText();
139
+
140
+ // Skip callback props - they don't create data-driven execution flows
141
+ // Callbacks typically start with 'on' (onClick, onChange) or 'handle' (handleSubmit)
142
+ if (
143
+ propName.startsWith('on') ||
144
+ propName.startsWith('handle') ||
145
+ propName === 'ref'
146
+ ) {
147
+ console.log(
148
+ `[UnconditionalChild] ${componentName}: Skipping callback prop '${propName}'`,
149
+ );
150
+ continue;
151
+ }
152
+
153
+ // Check if the prop value is a JSX expression (references a variable)
154
+ // vs a string literal which is static
155
+ if (attr.initializer) {
156
+ if (ts.isJsxExpression(attr.initializer)) {
157
+ // JSX expression like prop={value} - this references a variable
158
+ // Could be a simple identifier, property access, or more complex expression
159
+ const expression = attr.initializer.expression;
160
+ if (expression) {
161
+ // Skip if it's just a function/arrow function (callback)
162
+ if (
163
+ ts.isArrowFunction(expression) ||
164
+ ts.isFunctionExpression(expression)
165
+ ) {
166
+ console.log(
167
+ `[UnconditionalChild] ${componentName}: Skipping inline callback prop '${propName}'`,
168
+ );
169
+ continue;
170
+ }
171
+ // This is a data prop that references parent state/props
172
+ const exprText = expression.getText();
173
+ dataProps.push(`${propName}={${exprText}}`);
174
+ console.log(
175
+ `[UnconditionalChild] ${componentName}: Found data prop '${propName}' = {${exprText}}`,
176
+ );
177
+ }
178
+ } else {
179
+ // String literals like prop="value" are static
180
+ console.log(
181
+ `[UnconditionalChild] ${componentName}: Skipping static prop '${propName}'`,
182
+ );
183
+ }
184
+ }
185
+ }
186
+ }
187
+
188
+ const hasDataProps = dataProps.length > 0;
189
+ if (hasDataProps) {
190
+ console.log(
191
+ `[UnconditionalChild] ${componentName}: Has ${dataProps.length} data props: [${dataProps.join(', ')}]`,
192
+ );
193
+ } else {
194
+ console.log(
195
+ `[UnconditionalChild] ${componentName}: No data props found, will NOT track`,
196
+ );
197
+ }
198
+
199
+ return { hasDataProps, dataProps };
200
+ }
201
+
202
+ /**
203
+ * Extracts the component name from a JSX element.
204
+ * Returns null for intrinsic elements (div, span, etc.) since we only care about
205
+ * custom components for gating condition tracking.
206
+ *
207
+ * Examples:
208
+ * - <ChildViewer /> → "ChildViewer"
209
+ * - <ScenarioViewer scenario={...} /> → "ScenarioViewer"
210
+ * - <div> → null (intrinsic element)
211
+ */
212
+ function getComponentNameFromJsx(
213
+ node: ts.JsxElement | ts.JsxSelfClosingElement,
214
+ ): string | null {
215
+ let tagName: ts.JsxTagNameExpression;
216
+
217
+ if (ts.isJsxElement(node)) {
218
+ tagName = node.openingElement.tagName;
219
+ } else {
220
+ tagName = node.tagName;
221
+ }
222
+
223
+ // Get the text of the tag name
224
+ const name = tagName.getText();
225
+
226
+ // Check if it's a custom component (starts with uppercase) vs intrinsic element
227
+ // Custom components start with uppercase: <MyComponent />
228
+ // Intrinsic elements start with lowercase: <div />
229
+ if (
230
+ name &&
231
+ name[0] === name[0].toUpperCase() &&
232
+ name[0] !== name[0].toLowerCase()
233
+ ) {
234
+ return name;
235
+ }
236
+
237
+ return null;
238
+ }
239
+
240
+ /**
241
+ * Extracts condition paths from a logical AND chain expression.
242
+ * Used for creating gating conditions for child components.
243
+ *
244
+ * Example: `hasData && isReady && <Component />` returns ['hasData', 'isReady']
245
+ */
246
+ function extractConditionPathsFromAndChain(
247
+ expr: ts.Expression,
248
+ sourceFile: ts.SourceFile,
249
+ ): string[] {
250
+ const paths: string[] = [];
251
+ const unwrapped = unwrapExpression(expr);
252
+
253
+ if (
254
+ ts.isBinaryExpression(unwrapped) &&
255
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
256
+ ) {
257
+ // Recursively get conditions from left side
258
+ paths.push(
259
+ ...extractConditionPathsFromAndChain(unwrapped.left, sourceFile),
260
+ );
261
+
262
+ // Process right side if it's not JSX (JSX is the consequence, not a condition)
263
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
264
+ if (
265
+ !ts.isJsxElement(rightUnwrapped) &&
266
+ !ts.isJsxSelfClosingElement(rightUnwrapped) &&
267
+ !ts.isJsxFragment(rightUnwrapped)
268
+ ) {
269
+ paths.push(
270
+ ...extractConditionPathsFromAndChain(unwrapped.right, sourceFile),
271
+ );
272
+ }
273
+ } else {
274
+ // Base case: extract path from this expression
275
+ const path = StructuredPath.fromNode(unwrapped, sourceFile);
276
+ if (path) {
277
+ paths.push(path.toString());
278
+ }
279
+ }
280
+
281
+ return paths;
282
+ }
283
+
284
+ /**
285
+ * Finds the rightmost JSX element in an && chain.
286
+ * Example: `a && b && <Component />` returns <Component />
287
+ */
288
+ function findJsxInAndChain(
289
+ expr: ts.Expression,
290
+ ): ts.JsxElement | ts.JsxSelfClosingElement | null {
291
+ const unwrapped = unwrapExpression(expr);
292
+
293
+ if (ts.isJsxElement(unwrapped) || ts.isJsxSelfClosingElement(unwrapped)) {
294
+ return unwrapped;
295
+ }
296
+
297
+ if (
298
+ ts.isBinaryExpression(unwrapped) &&
299
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
300
+ ) {
301
+ // Check right side first (most common case: condition && <Jsx />)
302
+ const rightResult = findJsxInAndChain(unwrapped.right);
303
+ if (rightResult) return rightResult;
304
+
305
+ // Also check left side for rare cases
306
+ return findJsxInAndChain(unwrapped.left);
307
+ }
308
+
309
+ return null;
310
+ }
311
+
312
+ /**
313
+ * Fix 32: Finds a JSX fragment in an && chain.
314
+ * Example: `activeTab && <><ChildA /><ChildB /></>` returns the fragment
315
+ * This is needed to propagate parent conditions through fragments.
316
+ */
317
+ function findJsxFragmentInAndChain(expr: ts.Expression): ts.JsxFragment | null {
318
+ const unwrapped = unwrapExpression(expr);
319
+
320
+ if (ts.isJsxFragment(unwrapped)) {
321
+ return unwrapped;
322
+ }
323
+
324
+ if (
325
+ ts.isBinaryExpression(unwrapped) &&
326
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
327
+ ) {
328
+ // Check right side first (most common case: condition && <></>)
329
+ const rightResult = findJsxFragmentInAndChain(unwrapped.right);
330
+ if (rightResult) return rightResult;
331
+
332
+ // Also check left side for rare cases
333
+ return findJsxFragmentInAndChain(unwrapped.left);
334
+ }
335
+
336
+ return null;
337
+ }
338
+
339
+ /**
340
+ * Detects if a property access looks like an environment variable store access.
341
+ * Matches patterns like `env.DATABASE_URL`, `env.IS_FORMBRICKS_CLOUD`, etc.
342
+ * where the object is named "env" and the property looks like an env var name.
343
+ */
344
+ function isEnvStoreAccess(fullText: string): boolean {
345
+ // Match: env.SOME_VAR or env.someVar (but object must be exactly "env")
346
+ // This catches patterns from @t3-oss/env-nextjs and similar packages
347
+ const envStorePattern = /^env\.[A-Z_][A-Z0-9_]*$/;
348
+ return envStorePattern.test(fullText);
349
+ }
350
+
351
+ /**
352
+ * Converts a call expression argument to a StructuredPath.
353
+ *
354
+ * IMPORTANT: We always use the original source text for callbacks, never cyScope names.
355
+ * cyScope names are internal identifiers for child scopes and should NEVER appear
356
+ * in schema paths or call signatures. Using cyScope names causes data merge conflicts
357
+ * because the same callback gets different identifiers in different contexts.
358
+ */
359
+ function getArgPathForCallSignature(
360
+ arg: ts.Expression,
361
+ context: AnalysisContext,
362
+ ): StructuredPath {
363
+ // Always use the standard path conversion - never replace with cyScope names
364
+ return (
365
+ StructuredPath.fromNode(arg, context.sourceFile) ||
366
+ nodeToSource(arg, context.sourceFile)
367
+ );
368
+ }
369
+
370
+ /**
371
+ * Builds a StructuredPath for a call expression using the original source text.
372
+ *
373
+ * IMPORTANT: This function ensures consistent call signatures by always using
374
+ * the original callback text, never cyScope names. This prevents schema path
375
+ * conflicts where the same call would have different paths.
376
+ */
377
+ function buildCallPathFromSource(
378
+ node: ts.CallExpression,
379
+ context: AnalysisContext,
380
+ ): StructuredPath | null {
381
+ const expression = node.expression;
382
+
383
+ // Convert arguments using original source text
384
+ const argPaths = node.arguments.map((arg) =>
385
+ getArgPathForCallSignature(arg, context),
386
+ );
387
+
388
+ // Handle type arguments if present
389
+ let typeArgs: string[] | undefined = undefined;
390
+ if (node.typeArguments && node.typeArguments.length > 0) {
391
+ typeArgs = node.typeArguments.map((typeArg) =>
392
+ typeArg.getText(context.sourceFile),
393
+ );
394
+ }
395
+
396
+ if (ts.isIdentifier(expression)) {
397
+ // Simple function call: func(arg1, arg2)
398
+ return StructuredPath.fromFunction(expression.text, argPaths, typeArgs);
399
+ } else if (ts.isPropertyAccessExpression(expression)) {
400
+ // Method call: obj.method(arg1, arg2)
401
+ const objPath = StructuredPath.fromNode(
402
+ expression.expression,
403
+ context.sourceFile,
404
+ );
405
+ if (!objPath) return null;
406
+ return objPath
407
+ .withProperty(expression.name.text)
408
+ .withFunctionCall(argPaths, typeArgs);
409
+ } else if (ts.isCallExpression(expression)) {
410
+ // Chained call: func(arg1)(arg2)
411
+ const funcPath = buildCallPathFromSource(expression, context);
412
+ if (!funcPath) return null;
413
+ return funcPath.withFunctionCall(argPaths, typeArgs);
414
+ } else if (ts.isElementAccessExpression(expression)) {
415
+ // Element access call: obj[key](args)
416
+ const basePath = StructuredPath.fromNode(expression, context.sourceFile);
417
+ if (!basePath) return null;
418
+ return basePath.withFunctionCall(argPaths, typeArgs);
419
+ } else {
420
+ // Complex call expression
421
+ const basePath = StructuredPath.fromNode(expression, context.sourceFile);
422
+ if (!basePath) return null;
423
+ return basePath.withFunctionCall(argPaths, typeArgs);
424
+ }
425
+ }
426
+
427
+ /**
428
+ * Checks if an expression is likely an array type.
429
+ * Uses TypeScript's type checker when available, falls back to heuristics.
430
+ */
431
+ function isLikelyArrayType(
432
+ expr: ts.Expression,
433
+ typeChecker: ts.TypeChecker | undefined,
434
+ ): boolean {
435
+ if (typeChecker) {
436
+ try {
437
+ const type = typeChecker.getTypeAtLocation(expr);
438
+ const typeString = typeChecker.typeToString(type);
439
+ // Check for common array type patterns:
440
+ // - T[] syntax (includes any[], string[], etc.)
441
+ // - Array<T> syntax
442
+ // - ReadonlyArray<T> syntax
443
+ // - readonly T[] syntax (starts with "readonly " and ends with "[]")
444
+ if (
445
+ typeString.includes('[]') ||
446
+ typeString.startsWith('Array<') ||
447
+ typeString.startsWith('ReadonlyArray<')
448
+ ) {
449
+ return true;
450
+ }
451
+ // Check if it's a tuple or array literal type via TypeScript's type flags
452
+ if (type.getFlags() & ts.TypeFlags.Object) {
453
+ const objectType = type as ts.ObjectType;
454
+ if (
455
+ objectType.objectFlags & ts.ObjectFlags.Tuple ||
456
+ objectType.objectFlags & ts.ObjectFlags.ArrayLiteral
457
+ ) {
458
+ return true;
459
+ }
460
+ }
461
+ } catch {
462
+ // Type checking can fail in some edge cases, fall through to false
463
+ }
464
+ }
465
+ return false;
466
+ }
467
+
468
+ /**
469
+ * Marks variables used in truthiness checks as potentially undefined.
470
+ * When code checks `if (x)` or `x && ...`, it indicates x might be falsy (null/undefined).
471
+ * This function walks through the condition and adds | undefined to such variables.
472
+ */
473
+ export function markConditionVariablesAsNullable(
474
+ condition: ts.Expression,
475
+ context: AnalysisContext,
476
+ ): void {
477
+ const unwrapped = unwrapExpression(condition);
478
+
479
+ // For binary expressions with &&, mark both sides as nullable if they're truthiness checks
480
+ // Example: `diffView && <Component />` means diffView might be undefined
481
+ // Example: `a && b && <Component />` means both a and b might be undefined
482
+ if (
483
+ ts.isBinaryExpression(unwrapped) &&
484
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
485
+ ) {
486
+ // Recursively mark left side
487
+ markConditionVariablesAsNullable(unwrapped.left, context);
488
+
489
+ // Mark right side if it's also a truthiness check (not JSX or other consequences)
490
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
491
+ // Check if right side is JSX or contains JSX
492
+ const isJsxConsequence =
493
+ ts.isJsxElement(rightUnwrapped) ||
494
+ ts.isJsxSelfClosingElement(rightUnwrapped) ||
495
+ ts.isJsxFragment(rightUnwrapped);
496
+
497
+ if (!isJsxConsequence) {
498
+ // This handles chains like `a && b && ...` where both a and b are checks
499
+ markConditionVariablesAsNullable(unwrapped.right, context);
500
+ }
501
+ return;
502
+ }
503
+
504
+ // Don't mark variables in comparison operators as nullable
505
+ // Example: `if (x === 5)` doesn't mean x might be undefined
506
+ if (
507
+ ts.isBinaryExpression(unwrapped) &&
508
+ isComparisonOperator(unwrapped.operatorToken.kind)
509
+ ) {
510
+ return;
511
+ }
512
+
513
+ // For simple identifiers or property accesses, mark as potentially undefined
514
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
515
+ if (path) {
516
+ const currentType = context.getTypeInfo(path) || 'unknown';
517
+
518
+ // Only add | undefined if it's not already there
519
+ if (!currentType.includes('undefined')) {
520
+ context.addType(path, `${currentType} | undefined`);
521
+ }
522
+ }
523
+ }
524
+
525
+ /**
526
+ * Helper to extract source location from an AST node
527
+ */
528
+ function getSourceLocation(
529
+ node: ts.Node,
530
+ sourceFile: ts.SourceFile,
531
+ ): ConditionalUsage['sourceLocation'] {
532
+ const start = node.getStart(sourceFile);
533
+ const { line, character } = sourceFile.getLineAndCharacterOfPosition(start);
534
+ const codeSnippet = node.getText(sourceFile);
535
+
536
+ return {
537
+ lineNumber: line + 1, // Convert to 1-based
538
+ column: character,
539
+ codeSnippet:
540
+ codeSnippet.length > 100
541
+ ? codeSnippet.slice(0, 100) + '...'
542
+ : codeSnippet,
543
+ };
544
+ }
545
+
546
+ /**
547
+ * Extracts the root array path from an expression that ends with .map().
548
+ * Handles chained methods like .filter().map(), .slice().map(), etc.
549
+ *
550
+ * Examples:
551
+ * - items.map(...) → "items"
552
+ * - data.users.map(...) → "data.users"
553
+ * - items.filter(...).map(...) → "items"
554
+ * - items.slice(0, 5).map(...) → "items"
555
+ */
556
+ function extractArrayPathFromMapCall(
557
+ expr: ts.CallExpression,
558
+ sourceFile: ts.SourceFile,
559
+ ): string | null {
560
+ // Walk up the chain to find the root array
561
+ let current: ts.Expression = expr.expression;
562
+
563
+ while (ts.isPropertyAccessExpression(current)) {
564
+ const methodName = current.name.getText(sourceFile);
565
+
566
+ // Common array methods that return arrays (so we keep going up)
567
+ const arrayReturningMethods = [
568
+ 'map',
569
+ 'filter',
570
+ 'slice',
571
+ 'concat',
572
+ 'flat',
573
+ 'flatMap',
574
+ 'reverse',
575
+ 'sort',
576
+ 'toReversed',
577
+ 'toSorted',
578
+ 'toSpliced',
579
+ ];
580
+
581
+ if (arrayReturningMethods.includes(methodName)) {
582
+ const objectExpr = current.expression;
583
+
584
+ // If the object is a call expression (chained method), keep going
585
+ if (ts.isCallExpression(objectExpr)) {
586
+ current = objectExpr.expression;
587
+ } else {
588
+ // Found the root - it's an identifier or property access
589
+ const path = StructuredPath.fromNode(objectExpr, sourceFile);
590
+ return path ? path.toString() : null;
591
+ }
592
+ } else {
593
+ // Not an array method we recognize
594
+ break;
595
+ }
596
+ }
597
+
598
+ return null;
599
+ }
600
+
601
+ /**
602
+ * Extracts JSX rendering usages from a JSX expression.
603
+ * Detects:
604
+ * - array.map() calls → 'array-map' type
605
+ * - string interpolations (identifiers/property access) → 'text-interpolation' type
606
+ *
607
+ * Recursively searches inside && chains and ternary expressions.
608
+ *
609
+ * @param expr The expression inside {expr}
610
+ * @param context The analysis context
611
+ */
612
+ function extractJsxRenderingUsage(
613
+ expr: ts.Expression,
614
+ context: AnalysisContext,
615
+ ): void {
616
+ const unwrapped = unwrapExpression(expr);
617
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
618
+
619
+ // Detect array.map() calls
620
+ if (ts.isCallExpression(unwrapped)) {
621
+ const calleeExpr = unwrapped.expression;
622
+
623
+ if (ts.isPropertyAccessExpression(calleeExpr)) {
624
+ const methodName = calleeExpr.name.getText(context.sourceFile);
625
+
626
+ if (methodName === 'map') {
627
+ const arrayPath = extractArrayPathFromMapCall(
628
+ unwrapped,
629
+ context.sourceFile,
630
+ );
631
+
632
+ if (arrayPath) {
633
+ context.addJsxRenderingUsage({
634
+ path: arrayPath,
635
+ renderingType: 'array-map',
636
+ valueType: 'array',
637
+ sourceLocation,
638
+ });
639
+ }
640
+ }
641
+ }
642
+ }
643
+ // Detect simple string interpolations: {title} or {user.name}
644
+ else if (
645
+ ts.isIdentifier(unwrapped) ||
646
+ ts.isPropertyAccessExpression(unwrapped)
647
+ ) {
648
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
649
+
650
+ if (path) {
651
+ const pathStr = path.toString();
652
+ const typeInfo = context.getTypeInfo(path);
653
+
654
+ // Only track as text interpolation if it's a string type
655
+ // Check for 'string' type, or types that contain 'string' (but not 'string[]')
656
+ if (
657
+ typeInfo === 'string' ||
658
+ (typeInfo &&
659
+ typeInfo.includes('string') &&
660
+ !typeInfo.includes('string[]'))
661
+ ) {
662
+ context.addJsxRenderingUsage({
663
+ path: pathStr,
664
+ renderingType: 'text-interpolation',
665
+ valueType: 'string',
666
+ sourceLocation,
667
+ });
668
+ }
669
+ }
670
+ }
671
+ // Recursively search inside && chains: {showList && items.map(...)}
672
+ else if (
673
+ ts.isBinaryExpression(unwrapped) &&
674
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
675
+ ) {
676
+ // Check the right side of the && chain (where .map() typically appears)
677
+ const rightSide = unwrapExpression(unwrapped.right);
678
+ extractJsxRenderingUsage(rightSide, context);
679
+ // Also check nested && chains on the left
680
+ extractJsxRenderingUsage(unwrapped.left, context);
681
+ }
682
+ // Recursively search inside ternaries: {isEmpty ? null : items.map(...)}
683
+ else if (ts.isConditionalExpression(unwrapped)) {
684
+ extractJsxRenderingUsage(unwrapped.whenTrue, context);
685
+ extractJsxRenderingUsage(unwrapped.whenFalse, context);
686
+ }
687
+ }
688
+
689
+ /**
690
+ * Counts the number of conditions in an && chain (excluding JSX consequence)
691
+ */
692
+ function countConditionsInAndChain(expr: ts.Expression): number {
693
+ const unwrapped = unwrapExpression(expr);
694
+
695
+ if (
696
+ ts.isBinaryExpression(unwrapped) &&
697
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
698
+ ) {
699
+ const leftCount = countConditionsInAndChain(unwrapped.left);
700
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
701
+ const isJsxConsequence =
702
+ ts.isJsxElement(rightUnwrapped) ||
703
+ ts.isJsxSelfClosingElement(rightUnwrapped) ||
704
+ ts.isJsxFragment(rightUnwrapped);
705
+
706
+ if (isJsxConsequence) {
707
+ return leftCount;
708
+ }
709
+ return leftCount + countConditionsInAndChain(unwrapped.right);
710
+ }
711
+
712
+ // Single condition (not an && chain)
713
+ return 1;
714
+ }
715
+
716
+ /**
717
+ * Chain tracking info for compound conditionals
718
+ */
719
+ interface ChainInfo {
720
+ chainId: string;
721
+ chainLength: number;
722
+ chainExpression: string;
723
+ currentPosition: number;
724
+ compound: CompoundConditional;
725
+ /**
726
+ * When processing OR expressions within an && chain, this tracks the
727
+ * current OR group ID. Conditions added while this is set will be marked
728
+ * as OR alternatives (only one needs to be true).
729
+ */
730
+ currentOrGroupId?: string;
731
+ }
732
+
733
+ /**
734
+ * Parent gating condition accumulated during JSX traversal.
735
+ * Used to track conditions from parent && chains that gate child components.
736
+ */
737
+ interface ParentGatingCondition {
738
+ path: string;
739
+ sourceLocation: { lineNumber: number; column: number; codeSnippet: string };
740
+ isNegated?: boolean;
741
+ }
742
+
743
+ /**
744
+ * Extracts conditionals from JSX elements by recursively traversing children.
745
+ *
746
+ * This is CRITICAL for extracting compound conditionals from JSX expressions
747
+ * like `{hasNewerVersion && !isActive && <Banner />}`.
748
+ *
749
+ * This function is called BEFORE the child boundary check in processExpression
750
+ * because JSX elements are NOT scopes - their expressions use variables from
751
+ * the parent scope and should have their conditionals extracted regardless of
752
+ * whether the JSX is within a child boundary.
753
+ *
754
+ * Fix 32: Added parentConditions parameter to track gating conditions from
755
+ * parent && chains. When we find a component nested inside multiple conditionals
756
+ * like `{activeTab && <>{ternary ? ... : <Component />}</>}`, ALL parent
757
+ * conditions should be added as gating conditions for the component.
758
+ *
759
+ * @param node The JSX element, self-closing element, or fragment to traverse
760
+ * @param context The analysis context
761
+ * @param parentConditions Accumulated gating conditions from parent && chains
762
+ */
763
+ function extractConditionalsFromJsx(
764
+ node: ts.JsxElement | ts.JsxSelfClosingElement | ts.JsxFragment,
765
+ context: AnalysisContext,
766
+ parentConditions: ParentGatingCondition[] = [],
767
+ ): void {
768
+ // Get children to process
769
+ let children: ts.NodeArray<ts.JsxChild> | undefined;
770
+
771
+ if (ts.isJsxElement(node)) {
772
+ children = node.children;
773
+ } else if (ts.isJsxFragment(node)) {
774
+ children = node.children;
775
+ }
776
+ // JsxSelfClosingElement has no children
777
+
778
+ if (!children) {
779
+ return;
780
+ }
781
+
782
+ for (const child of children) {
783
+ // Process JSX expressions: {expr}
784
+ if (ts.isJsxExpression(child) && child.expression) {
785
+ const expr = unwrapExpression(child.expression);
786
+
787
+ // Extract JSX rendering usages (array.map, text interpolation)
788
+ // This handles direct usages like {items.map(...)} or {user.name}
789
+ extractJsxRenderingUsage(expr, context);
790
+
791
+ // If the expression is an && chain, extract its conditional usages
792
+ if (
793
+ ts.isBinaryExpression(expr) &&
794
+ expr.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
795
+ ) {
796
+ // Mark nullable variables
797
+ markConditionVariablesAsNullable(expr, context);
798
+ // Extract conditional usage (this handles compound conditionals)
799
+ // Pass controlsJsxRendering: true since this conditional controls JSX rendering
800
+ extractConditionalUsage(expr, context, 'logical-and', {
801
+ controlsJsxRendering: true,
802
+ });
803
+
804
+ // Extract all condition paths from the && chain for gating tracking
805
+ const conditionPaths = extractConditionPathsFromAndChain(
806
+ expr,
807
+ context.sourceFile,
808
+ );
809
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
810
+
811
+ // Fix 32: Build accumulated conditions including parent conditions
812
+ const accumulatedConditions: ParentGatingCondition[] = [
813
+ ...parentConditions,
814
+ ...conditionPaths.map((path) => ({
815
+ path,
816
+ sourceLocation,
817
+ isNegated: false,
818
+ })),
819
+ ];
820
+
821
+ // Track gating conditions for child components
822
+ // Example: {hasAnalysis && <ScenarioViewer />}
823
+ const jsxElement = findJsxInAndChain(expr);
824
+ if (jsxElement) {
825
+ const componentName = getComponentNameFromJsx(jsxElement);
826
+ if (componentName) {
827
+ // Fix 32: Add ALL accumulated conditions (parent + current) as gating conditions
828
+ for (const condition of accumulatedConditions) {
829
+ context.addChildBoundaryGatingCondition(componentName, {
830
+ path: condition.path,
831
+ conditionType: 'truthiness',
832
+ location: 'logical-and',
833
+ sourceLocation: condition.sourceLocation,
834
+ controlsJsxRendering: true,
835
+ isNegated: condition.isNegated,
836
+ });
837
+ }
838
+ }
839
+
840
+ // Fix 32: Recursively process nested JSX with accumulated conditions
841
+ if (
842
+ ts.isJsxElement(jsxElement) ||
843
+ ts.isJsxSelfClosingElement(jsxElement)
844
+ ) {
845
+ extractConditionalsFromJsx(
846
+ jsxElement,
847
+ context,
848
+ accumulatedConditions,
849
+ );
850
+ }
851
+ }
852
+
853
+ // Fix 32: Also check for nested JSX fragments
854
+ const jsxFragment = findJsxFragmentInAndChain(expr);
855
+ if (jsxFragment) {
856
+ extractConditionalsFromJsx(
857
+ jsxFragment,
858
+ context,
859
+ accumulatedConditions,
860
+ );
861
+ }
862
+ }
863
+ // If the expression is a ternary, extract its conditional
864
+ else if (ts.isConditionalExpression(expr)) {
865
+ // Pass controlsJsxRendering: true since this conditional controls JSX rendering
866
+ extractConditionalUsage(expr.condition, context, 'ternary', {
867
+ controlsJsxRendering: true,
868
+ });
869
+
870
+ // Track gating conditions for components in both branches of the ternary
871
+ // Example: {isError ? <ErrorView /> : <SuccessView />}
872
+ const conditionPath = StructuredPath.fromNode(
873
+ unwrapExpression(expr.condition),
874
+ context.sourceFile,
875
+ );
876
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
877
+
878
+ // Recursively process the whenTrue and whenFalse branches for JSX
879
+ const whenTrue = unwrapExpression(expr.whenTrue);
880
+ const whenFalse = unwrapExpression(expr.whenFalse);
881
+
882
+ // Fix 32: Build conditions for whenTrue branch (parent conditions + ternary condition truthy)
883
+ const whenTrueConditions: ParentGatingCondition[] = [
884
+ ...parentConditions,
885
+ ...(conditionPath
886
+ ? [
887
+ {
888
+ path: conditionPath.toString(),
889
+ sourceLocation,
890
+ isNegated: false,
891
+ },
892
+ ]
893
+ : []),
894
+ ];
895
+
896
+ // Fix 32: Build conditions for whenFalse branch (parent conditions + ternary condition falsy)
897
+ const whenFalseConditions: ParentGatingCondition[] = [
898
+ ...parentConditions,
899
+ ...(conditionPath
900
+ ? [
901
+ {
902
+ path: conditionPath.toString(),
903
+ sourceLocation,
904
+ isNegated: true,
905
+ },
906
+ ]
907
+ : []),
908
+ ];
909
+
910
+ // Handle whenTrue branch (condition is truthy)
911
+ if (ts.isJsxElement(whenTrue) || ts.isJsxSelfClosingElement(whenTrue)) {
912
+ const componentName = getComponentNameFromJsx(whenTrue);
913
+ if (componentName) {
914
+ // Fix 32: Add ALL conditions (parent + ternary) as gating conditions
915
+ for (const condition of whenTrueConditions) {
916
+ context.addChildBoundaryGatingCondition(componentName, {
917
+ path: condition.path,
918
+ conditionType: 'truthiness',
919
+ location: 'ternary',
920
+ sourceLocation: condition.sourceLocation,
921
+ controlsJsxRendering: true,
922
+ isNegated: condition.isNegated,
923
+ });
924
+ }
925
+ }
926
+ }
927
+ if (
928
+ ts.isJsxElement(whenTrue) ||
929
+ ts.isJsxSelfClosingElement(whenTrue) ||
930
+ ts.isJsxFragment(whenTrue)
931
+ ) {
932
+ extractConditionalsFromJsx(whenTrue, context, whenTrueConditions);
933
+ }
934
+
935
+ // Handle whenFalse branch (condition is falsy/negated)
936
+ if (
937
+ ts.isJsxElement(whenFalse) ||
938
+ ts.isJsxSelfClosingElement(whenFalse)
939
+ ) {
940
+ const componentName = getComponentNameFromJsx(whenFalse);
941
+ if (componentName) {
942
+ // Fix 32: Add ALL conditions (parent + ternary) as gating conditions
943
+ for (const condition of whenFalseConditions) {
944
+ context.addChildBoundaryGatingCondition(componentName, {
945
+ path: condition.path,
946
+ conditionType: 'truthiness',
947
+ location: 'ternary',
948
+ sourceLocation: condition.sourceLocation,
949
+ controlsJsxRendering: true,
950
+ isNegated: condition.isNegated,
951
+ });
952
+ }
953
+ }
954
+ }
955
+ if (
956
+ ts.isJsxElement(whenFalse) ||
957
+ ts.isJsxSelfClosingElement(whenFalse) ||
958
+ ts.isJsxFragment(whenFalse)
959
+ ) {
960
+ extractConditionalsFromJsx(whenFalse, context, whenFalseConditions);
961
+ }
962
+ // Handle chained ternaries: a ? <A/> : b ? <B/> : <C/>
963
+ // When whenFalse is another ConditionalExpression, recursively process it
964
+ else if (ts.isConditionalExpression(whenFalse)) {
965
+ // Extract conditional usage for the nested ternary's condition
966
+ extractConditionalUsage(whenFalse.condition, context, 'ternary', {
967
+ controlsJsxRendering: true,
968
+ });
969
+
970
+ // Get the nested condition path
971
+ const nestedConditionPath = StructuredPath.fromNode(
972
+ unwrapExpression(whenFalse.condition),
973
+ context.sourceFile,
974
+ );
975
+ const nestedSourceLocation = getSourceLocation(
976
+ whenFalse,
977
+ context.sourceFile,
978
+ );
979
+
980
+ const nestedWhenTrue = unwrapExpression(whenFalse.whenTrue);
981
+ const nestedWhenFalse = unwrapExpression(whenFalse.whenFalse);
982
+
983
+ // Fix 32: Build conditions for nested whenTrue (parent falsy + nested truthy)
984
+ const nestedWhenTrueConditions: ParentGatingCondition[] = [
985
+ ...whenFalseConditions, // Parent ternary was falsy to get here
986
+ ...(nestedConditionPath
987
+ ? [
988
+ {
989
+ path: nestedConditionPath.toString(),
990
+ sourceLocation: nestedSourceLocation,
991
+ isNegated: false,
992
+ },
993
+ ]
994
+ : []),
995
+ ];
996
+
997
+ // Fix 32: Build conditions for nested whenFalse (parent falsy + nested falsy)
998
+ const nestedWhenFalseConditions: ParentGatingCondition[] = [
999
+ ...whenFalseConditions, // Parent ternary was falsy to get here
1000
+ ...(nestedConditionPath
1001
+ ? [
1002
+ {
1003
+ path: nestedConditionPath.toString(),
1004
+ sourceLocation: nestedSourceLocation,
1005
+ isNegated: true,
1006
+ },
1007
+ ]
1008
+ : []),
1009
+ ];
1010
+
1011
+ // Handle nested whenTrue branch
1012
+ if (
1013
+ ts.isJsxElement(nestedWhenTrue) ||
1014
+ ts.isJsxSelfClosingElement(nestedWhenTrue)
1015
+ ) {
1016
+ const componentName = getComponentNameFromJsx(nestedWhenTrue);
1017
+ if (componentName) {
1018
+ // Fix 32: Add ALL accumulated conditions
1019
+ for (const condition of nestedWhenTrueConditions) {
1020
+ context.addChildBoundaryGatingCondition(componentName, {
1021
+ path: condition.path,
1022
+ conditionType: 'truthiness',
1023
+ location: 'ternary',
1024
+ sourceLocation: condition.sourceLocation,
1025
+ controlsJsxRendering: true,
1026
+ isNegated: condition.isNegated,
1027
+ });
1028
+ }
1029
+ }
1030
+ }
1031
+ if (
1032
+ ts.isJsxElement(nestedWhenTrue) ||
1033
+ ts.isJsxSelfClosingElement(nestedWhenTrue) ||
1034
+ ts.isJsxFragment(nestedWhenTrue)
1035
+ ) {
1036
+ extractConditionalsFromJsx(
1037
+ nestedWhenTrue,
1038
+ context,
1039
+ nestedWhenTrueConditions,
1040
+ );
1041
+ }
1042
+
1043
+ // Handle nested whenFalse branch (this could be another chained ternary or JSX)
1044
+ if (
1045
+ ts.isJsxElement(nestedWhenFalse) ||
1046
+ ts.isJsxSelfClosingElement(nestedWhenFalse)
1047
+ ) {
1048
+ const componentName = getComponentNameFromJsx(nestedWhenFalse);
1049
+ if (componentName) {
1050
+ // Fix 32: Add ALL accumulated conditions
1051
+ for (const condition of nestedWhenFalseConditions) {
1052
+ context.addChildBoundaryGatingCondition(componentName, {
1053
+ path: condition.path,
1054
+ conditionType: 'truthiness',
1055
+ location: 'ternary',
1056
+ sourceLocation: condition.sourceLocation,
1057
+ controlsJsxRendering: true,
1058
+ isNegated: condition.isNegated,
1059
+ });
1060
+ }
1061
+ }
1062
+ }
1063
+ if (
1064
+ ts.isJsxElement(nestedWhenFalse) ||
1065
+ ts.isJsxSelfClosingElement(nestedWhenFalse) ||
1066
+ ts.isJsxFragment(nestedWhenFalse)
1067
+ ) {
1068
+ extractConditionalsFromJsx(
1069
+ nestedWhenFalse,
1070
+ context,
1071
+ nestedWhenFalseConditions,
1072
+ );
1073
+ }
1074
+ // If nestedWhenFalse is yet another ConditionalExpression, the recursion
1075
+ // will handle it on the next iteration when this function processes it
1076
+ else if (ts.isConditionalExpression(nestedWhenFalse)) {
1077
+ // Recursively handle deeper nesting by wrapping in a synthetic process
1078
+ // We create a fake JsxExpression context to reuse the same logic
1079
+ const syntheticChild = {
1080
+ kind: ts.SyntaxKind.JsxExpression,
1081
+ expression: nestedWhenFalse,
1082
+ } as unknown as ts.JsxExpression;
1083
+ // Process via the main JSX expression handler by recursing
1084
+ // For now, just extract conditionals directly
1085
+ extractConditionalUsage(
1086
+ nestedWhenFalse.condition,
1087
+ context,
1088
+ 'ternary',
1089
+ { controlsJsxRendering: true },
1090
+ );
1091
+ }
1092
+ }
1093
+ }
1094
+ }
1095
+ // Recursively process nested JSX elements - Fix 32: pass parent conditions
1096
+ else if (ts.isJsxElement(child)) {
1097
+ // Check if this is a user-defined component (vs intrinsic element like div)
1098
+ const componentName = getComponentNameFromJsx(child);
1099
+ if (componentName) {
1100
+ if (parentConditions.length > 0) {
1101
+ // If there are parent conditions, record them as gating conditions
1102
+ console.log(
1103
+ `[ChildBoundary] ${componentName}: Conditionally rendered with ${parentConditions.length} gating conditions`,
1104
+ );
1105
+ for (const condition of parentConditions) {
1106
+ console.log(
1107
+ `[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`,
1108
+ );
1109
+ context.addChildBoundaryGatingCondition(componentName, {
1110
+ path: condition.path,
1111
+ conditionType: 'truthiness',
1112
+ location: 'ternary',
1113
+ sourceLocation: condition.sourceLocation,
1114
+ controlsJsxRendering: true,
1115
+ isNegated: condition.isNegated,
1116
+ });
1117
+ }
1118
+ } else {
1119
+ // No parent conditions - check if it has data props for unconditional tracking
1120
+ console.log(
1121
+ `[ChildBoundary] ${componentName}: Checking for unconditional rendering with data props...`,
1122
+ );
1123
+ const { hasDataProps, dataProps } = hasDataPropsFromParent(
1124
+ child,
1125
+ componentName,
1126
+ );
1127
+ if (hasDataProps) {
1128
+ // Fix: Track unconditionally-rendered children that receive data props
1129
+ // These need to be tracked for flow merging even without gating conditions
1130
+ // Example: <WorkoutsView workouts={workouts} /> - parent controls workouts data
1131
+ console.log(
1132
+ `[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered with data props: [${dataProps.join(', ')}]`,
1133
+ );
1134
+ context.addChildBoundaryGatingCondition(componentName, {
1135
+ path: '__unconditional__',
1136
+ conditionType: 'truthiness',
1137
+ location: 'unconditional',
1138
+ controlsJsxRendering: true,
1139
+ isNegated: false,
1140
+ });
1141
+ }
1142
+ }
1143
+ }
1144
+ extractConditionalsFromJsx(child, context, parentConditions);
1145
+ }
1146
+ // Handle self-closing JSX elements (e.g., <ScenarioViewer />)
1147
+ else if (ts.isJsxSelfClosingElement(child)) {
1148
+ // Check if this is a user-defined component (vs intrinsic element like div)
1149
+ const componentName = getComponentNameFromJsx(child);
1150
+ if (componentName) {
1151
+ if (parentConditions.length > 0) {
1152
+ // If there are parent conditions, record them as gating conditions
1153
+ console.log(
1154
+ `[ChildBoundary] ${componentName}: Conditionally rendered (self-closing) with ${parentConditions.length} gating conditions`,
1155
+ );
1156
+ for (const condition of parentConditions) {
1157
+ console.log(
1158
+ `[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`,
1159
+ );
1160
+ context.addChildBoundaryGatingCondition(componentName, {
1161
+ path: condition.path,
1162
+ conditionType: 'truthiness',
1163
+ location: 'ternary',
1164
+ sourceLocation: condition.sourceLocation,
1165
+ controlsJsxRendering: true,
1166
+ isNegated: condition.isNegated,
1167
+ });
1168
+ }
1169
+ } else {
1170
+ // No parent conditions - check if it has data props for unconditional tracking
1171
+ console.log(
1172
+ `[ChildBoundary] ${componentName}: Checking for unconditional rendering (self-closing) with data props...`,
1173
+ );
1174
+ const { hasDataProps, dataProps } = hasDataPropsFromParent(
1175
+ child,
1176
+ componentName,
1177
+ );
1178
+ if (hasDataProps) {
1179
+ // Fix: Track unconditionally-rendered children that receive data props
1180
+ console.log(
1181
+ `[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered (self-closing) with data props: [${dataProps.join(', ')}]`,
1182
+ );
1183
+ context.addChildBoundaryGatingCondition(componentName, {
1184
+ path: '__unconditional__',
1185
+ conditionType: 'truthiness',
1186
+ location: 'unconditional',
1187
+ controlsJsxRendering: true,
1188
+ isNegated: false,
1189
+ });
1190
+ }
1191
+ }
1192
+ }
1193
+ // Self-closing elements have no children, so no recursion needed
1194
+ }
1195
+ // Recursively process nested JSX fragments - Fix 32: pass parent conditions
1196
+ else if (ts.isJsxFragment(child)) {
1197
+ extractConditionalsFromJsx(child, context, parentConditions);
1198
+ }
1199
+ }
1200
+ }
1201
+
1202
+ /**
1203
+ * Options for extractConditionalUsage
1204
+ */
1205
+ interface ExtractConditionalOptions {
1206
+ /**
1207
+ * Whether this conditional controls JSX rendering.
1208
+ * Set to true when the conditional appears in a JSX expression like {cond && <Component />}
1209
+ */
1210
+ controlsJsxRendering?: boolean;
1211
+ }
1212
+
1213
+ /**
1214
+ * Extracts conditional usages from a condition expression for key attribute detection.
1215
+ * This function identifies which attributes are used in conditionals and how they're used.
1216
+ * It also tracks compound conditionals (&&-chains) where all conditions must be true together.
1217
+ *
1218
+ * @param condition The condition expression to analyze
1219
+ * @param context The analysis context
1220
+ * @param location Where this condition appears (if, ternary, logical-and, switch)
1221
+ * @param options Additional options including controlsJsxRendering flag
1222
+ */
1223
+ export function extractConditionalUsage(
1224
+ condition: ts.Expression,
1225
+ context: AnalysisContext,
1226
+ location: ConditionalUsage['location'],
1227
+ options: ExtractConditionalOptions = {},
1228
+ ): void {
1229
+ const { controlsJsxRendering } = options;
1230
+ // Internal recursive function with chain tracking
1231
+ function extractWithChainTracking(
1232
+ expr: ts.Expression,
1233
+ chainInfo: ChainInfo | null,
1234
+ isNegated: boolean,
1235
+ ): void {
1236
+ const unwrapped = unwrapExpression(expr);
1237
+
1238
+ // Handle binary expressions with && (logical AND chains)
1239
+ // Example: `a && b && <Component />` - both a and b are conditional checks
1240
+ if (
1241
+ ts.isBinaryExpression(unwrapped) &&
1242
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
1243
+ ) {
1244
+ // Track if we're creating the chain at this level (root of the chain)
1245
+ const isChainRoot = !chainInfo;
1246
+
1247
+ // If no chainInfo, this is the root of a new chain
1248
+ if (isChainRoot) {
1249
+ const chainLength = countConditionsInAndChain(unwrapped);
1250
+ // Only create chain tracking for chains with 2+ conditions
1251
+ if (chainLength >= 2) {
1252
+ const chainId = `chain_${crypto.randomUUID().slice(0, 8)}`;
1253
+ const chainExpression = unwrapped.getText(context.sourceFile);
1254
+ const compound: CompoundConditional = {
1255
+ chainId,
1256
+ expression:
1257
+ chainExpression.length > 200
1258
+ ? chainExpression.slice(0, 200) + '...'
1259
+ : chainExpression,
1260
+ conditions: [],
1261
+ location,
1262
+ sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
1263
+ controlsJsxRendering,
1264
+ };
1265
+ chainInfo = {
1266
+ chainId,
1267
+ chainLength,
1268
+ chainExpression: compound.expression,
1269
+ currentPosition: 0,
1270
+ compound,
1271
+ };
1272
+ }
1273
+ }
1274
+
1275
+ // Recursively process left side
1276
+ extractWithChainTracking(unwrapped.left, chainInfo, false);
1277
+
1278
+ // Process right side if it's not JSX (JSX is the consequence, not the condition)
1279
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
1280
+ const isJsxConsequence =
1281
+ ts.isJsxElement(rightUnwrapped) ||
1282
+ ts.isJsxSelfClosingElement(rightUnwrapped) ||
1283
+ ts.isJsxFragment(rightUnwrapped);
1284
+
1285
+ if (!isJsxConsequence) {
1286
+ extractWithChainTracking(unwrapped.right, chainInfo, false);
1287
+ }
1288
+
1289
+ // If this is the root of the chain, register the compound conditional
1290
+ if (isChainRoot && chainInfo) {
1291
+ context.addCompoundConditional(chainInfo.compound);
1292
+ }
1293
+ return;
1294
+ }
1295
+
1296
+ // Handle binary expressions with || (logical OR)
1297
+ // When OR is inside an && chain, we need to continue chain tracking
1298
+ // and mark conditions as OR alternatives
1299
+ if (
1300
+ ts.isBinaryExpression(unwrapped) &&
1301
+ unwrapped.operatorToken.kind === ts.SyntaxKind.BarBarToken
1302
+ ) {
1303
+ if (chainInfo) {
1304
+ // We're inside an && chain - continue tracking but mark as OR alternatives
1305
+ // Generate an orGroupId so conditions from both sides can be grouped
1306
+ const orGroupId =
1307
+ chainInfo.currentOrGroupId ?? `or_${crypto.randomUUID().slice(0, 8)}`;
1308
+
1309
+ // Process left side with OR group tracking
1310
+ const leftChainInfo = {
1311
+ ...chainInfo,
1312
+ currentOrGroupId: orGroupId,
1313
+ };
1314
+ extractWithChainTracking(unwrapped.left, leftChainInfo, false);
1315
+
1316
+ // Process right side with same OR group
1317
+ // Note: we use leftChainInfo's currentPosition which may have been updated
1318
+ const rightChainInfo = {
1319
+ ...leftChainInfo,
1320
+ currentPosition: chainInfo.currentPosition,
1321
+ };
1322
+ extractWithChainTracking(unwrapped.right, rightChainInfo, false);
1323
+ } else {
1324
+ // Not inside a chain - OR breaks into independent conditional checks
1325
+ extractWithChainTracking(unwrapped.left, null, false);
1326
+ extractWithChainTracking(unwrapped.right, null, false);
1327
+ }
1328
+ return;
1329
+ }
1330
+
1331
+ // Handle comparison operators (===, !==, <, >, <=, >=)
1332
+ // Example: `if (status === 'active')` - status is compared against 'active'
1333
+ if (
1334
+ ts.isBinaryExpression(unwrapped) &&
1335
+ isComparisonOperator(unwrapped.operatorToken.kind)
1336
+ ) {
1337
+ // Try to extract the variable and the compared value
1338
+ const leftPath = StructuredPath.fromNode(
1339
+ unwrapped.left,
1340
+ context.sourceFile,
1341
+ );
1342
+ const rightPath = StructuredPath.fromNode(
1343
+ unwrapped.right,
1344
+ context.sourceFile,
1345
+ );
1346
+
1347
+ // Determine the compared value for computing requiredValue
1348
+ const getRequiredValue = (
1349
+ literalValue: string | undefined,
1350
+ isNegatedComparison: boolean,
1351
+ ): string | boolean | undefined => {
1352
+ if (literalValue === undefined) return undefined;
1353
+ // For !== comparisons, the condition is true when NOT equal to the value
1354
+ // For === comparisons, the condition is true when equal to the value
1355
+ const isNotEqual =
1356
+ unwrapped.operatorToken.kind ===
1357
+ ts.SyntaxKind.ExclamationEqualsEqualsToken ||
1358
+ unwrapped.operatorToken.kind === ts.SyntaxKind.ExclamationEqualsToken;
1359
+ if (isNotEqual) {
1360
+ // !== 'value' means requiredValue is NOT 'value', but we express this as "not 'value'"
1361
+ return `not ${literalValue}`;
1362
+ }
1363
+ return literalValue;
1364
+ };
1365
+
1366
+ // Get the comparison operator string for the compound condition
1367
+ const comparisonOperator = getComparisonOperatorString(
1368
+ unwrapped.operatorToken.kind,
1369
+ );
1370
+
1371
+ // Helper to add a condition
1372
+ const addCondition = (
1373
+ path: string,
1374
+ conditionType: 'comparison' | 'truthiness',
1375
+ comparedValues?: string[],
1376
+ requiredValue?: string | boolean,
1377
+ sourceExpr?: ts.Expression,
1378
+ ) => {
1379
+ const usage: ConditionalUsage = {
1380
+ path,
1381
+ conditionType,
1382
+ comparedValues,
1383
+ location,
1384
+ sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
1385
+ isNegated,
1386
+ controlsJsxRendering,
1387
+ };
1388
+
1389
+ // Check for inline array-derived patterns (.length) on the source expression
1390
+ if (sourceExpr) {
1391
+ const arrayDerived = detectArrayDerivedPattern(sourceExpr);
1392
+ if (arrayDerived) {
1393
+ usage.derivedFrom = {
1394
+ operation: arrayDerived.operation,
1395
+ sourcePath: arrayDerived.sourcePath,
1396
+ };
1397
+ }
1398
+ }
1399
+
1400
+ // Add chain info if part of a compound conditional
1401
+ if (chainInfo) {
1402
+ usage.chainId = chainInfo.chainId;
1403
+ usage.chainPosition = chainInfo.currentPosition;
1404
+ usage.chainLength = chainInfo.chainLength;
1405
+ usage.chainExpression = chainInfo.chainExpression;
1406
+ chainInfo.currentPosition++;
1407
+
1408
+ // Add to compound conditional conditions
1409
+ chainInfo.compound.conditions.push({
1410
+ path,
1411
+ conditionType,
1412
+ comparedValues,
1413
+ isNegated,
1414
+ requiredValue,
1415
+ ...(comparisonOperator && { comparisonOperator }),
1416
+ ...(chainInfo.currentOrGroupId && {
1417
+ orGroupId: chainInfo.currentOrGroupId,
1418
+ }),
1419
+ });
1420
+ }
1421
+
1422
+ context.addConditionalUsage(usage);
1423
+ };
1424
+
1425
+ // Check if left is a variable and right is a literal
1426
+ if (leftPath && isLiteralExpression(unwrapped.right)) {
1427
+ const literalValue = getLiteralValue(unwrapped.right, context);
1428
+ addCondition(
1429
+ leftPath.toLeftHandSideString(),
1430
+ 'comparison',
1431
+ literalValue !== undefined ? [literalValue] : undefined,
1432
+ getRequiredValue(literalValue, isNegated),
1433
+ unwrapped.left, // Pass source expression for array derivation detection
1434
+ );
1435
+ return;
1436
+ }
1437
+
1438
+ // Check if right is a variable and left is a literal
1439
+ if (rightPath && isLiteralExpression(unwrapped.left)) {
1440
+ const literalValue = getLiteralValue(unwrapped.left, context);
1441
+ addCondition(
1442
+ rightPath.toLeftHandSideString(),
1443
+ 'comparison',
1444
+ literalValue !== undefined ? [literalValue] : undefined,
1445
+ getRequiredValue(literalValue, isNegated),
1446
+ unwrapped.right, // Pass source expression for array derivation detection
1447
+ );
1448
+ return;
1449
+ }
1450
+
1451
+ // Both sides are variables - record both as comparisons without specific values
1452
+ if (leftPath) {
1453
+ addCondition(
1454
+ leftPath.toLeftHandSideString(),
1455
+ 'comparison',
1456
+ undefined,
1457
+ undefined,
1458
+ unwrapped.left,
1459
+ );
1460
+ }
1461
+ if (rightPath) {
1462
+ addCondition(
1463
+ rightPath.toLeftHandSideString(),
1464
+ 'comparison',
1465
+ undefined,
1466
+ undefined,
1467
+ unwrapped.right,
1468
+ );
1469
+ }
1470
+ return;
1471
+ }
1472
+
1473
+ // Handle prefix unary NOT expression: !variable
1474
+ // Example: `if (!isVisible)` - isVisible is a truthiness check (negated)
1475
+ if (
1476
+ ts.isPrefixUnaryExpression(unwrapped) &&
1477
+ unwrapped.operator === ts.SyntaxKind.ExclamationToken
1478
+ ) {
1479
+ extractWithChainTracking(unwrapped.operand, chainInfo, !isNegated);
1480
+ return;
1481
+ }
1482
+
1483
+ // Handle simple identifiers or property accesses (truthiness checks)
1484
+ // Example: `if (x)` or `x && <JSX />` - x is checked for truthiness
1485
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
1486
+ if (path && !path.isLiteral()) {
1487
+ const pathStr = path.toLeftHandSideString();
1488
+ const usage: ConditionalUsage = {
1489
+ path: pathStr,
1490
+ conditionType: 'truthiness',
1491
+ location,
1492
+ sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
1493
+ isNegated,
1494
+ controlsJsxRendering,
1495
+ };
1496
+
1497
+ // Check for inline array-derived patterns (.some(), .every(), .includes(), .length)
1498
+ // This populates derivedFrom so downstream code can resolve to the base array path
1499
+ const arrayDerived = detectArrayDerivedPattern(unwrapped);
1500
+ if (arrayDerived) {
1501
+ usage.derivedFrom = {
1502
+ operation: arrayDerived.operation,
1503
+ sourcePath: arrayDerived.sourcePath,
1504
+ };
1505
+ }
1506
+
1507
+ // Add chain info if part of a compound conditional
1508
+ if (chainInfo) {
1509
+ usage.chainId = chainInfo.chainId;
1510
+ usage.chainPosition = chainInfo.currentPosition;
1511
+ usage.chainLength = chainInfo.chainLength;
1512
+ usage.chainExpression = chainInfo.chainExpression;
1513
+ chainInfo.currentPosition++;
1514
+
1515
+ // Add to compound conditional conditions
1516
+ // For truthiness, requiredValue is true if not negated, false if negated
1517
+ chainInfo.compound.conditions.push({
1518
+ path: pathStr,
1519
+ conditionType: 'truthiness',
1520
+ isNegated,
1521
+ requiredValue: !isNegated,
1522
+ ...(chainInfo.currentOrGroupId && {
1523
+ orGroupId: chainInfo.currentOrGroupId,
1524
+ }),
1525
+ });
1526
+ }
1527
+
1528
+ context.addConditionalUsage(usage);
1529
+ }
1530
+ }
1531
+
1532
+ // Start extraction with no chain info
1533
+ extractWithChainTracking(condition, null, false);
1534
+ }
1535
+
1536
+ /**
1537
+ * Helper to check if an expression is a literal value
1538
+ */
1539
+ function isLiteralExpression(expr: ts.Expression): boolean {
1540
+ const unwrapped = unwrapExpression(expr);
1541
+ return (
1542
+ ts.isStringLiteral(unwrapped) ||
1543
+ ts.isNumericLiteral(unwrapped) ||
1544
+ ts.isNoSubstitutionTemplateLiteral(unwrapped) ||
1545
+ unwrapped.kind === ts.SyntaxKind.TrueKeyword ||
1546
+ unwrapped.kind === ts.SyntaxKind.FalseKeyword ||
1547
+ unwrapped.kind === ts.SyntaxKind.NullKeyword ||
1548
+ unwrapped.kind === ts.SyntaxKind.UndefinedKeyword ||
1549
+ unwrapped.kind === ts.SyntaxKind.ThisKeyword
1550
+ );
1551
+ }
1552
+
1553
+ /**
1554
+ * Helper to get the string representation of a literal value
1555
+ */
1556
+ function getLiteralValue(
1557
+ expr: ts.Expression,
1558
+ context: AnalysisContext,
1559
+ ): string | undefined {
1560
+ const unwrapped = unwrapExpression(expr);
1561
+
1562
+ if (
1563
+ ts.isStringLiteral(unwrapped) ||
1564
+ ts.isNoSubstitutionTemplateLiteral(unwrapped)
1565
+ ) {
1566
+ return unwrapped.text;
1567
+ }
1568
+ if (ts.isNumericLiteral(unwrapped)) {
1569
+ return unwrapped.text;
1570
+ }
1571
+ if (unwrapped.kind === ts.SyntaxKind.TrueKeyword) {
1572
+ return 'true';
1573
+ }
1574
+ if (unwrapped.kind === ts.SyntaxKind.FalseKeyword) {
1575
+ return 'false';
1576
+ }
1577
+ if (unwrapped.kind === ts.SyntaxKind.NullKeyword) {
1578
+ return 'null';
1579
+ }
1580
+ if (unwrapped.kind === ts.SyntaxKind.UndefinedKeyword) {
1581
+ return 'undefined';
1582
+ }
1583
+ if (unwrapped.kind === ts.SyntaxKind.ThisKeyword) {
1584
+ return 'this';
1585
+ }
1586
+
1587
+ return undefined;
1588
+ }
1589
+
1590
+ /**
1591
+ * Processes an expression node recursively, establishing equivalences and types
1592
+ * in the analysis context as side effects.
1593
+ *
1594
+ * This is the core function for centralized expression analysis, which handles all
1595
+ * expression types and registers appropriate relationships and types in the context.
1596
+ *
1597
+ * @param node The expression node to process.
1598
+ * @param context The analysis context.
1599
+ * @param targetPath The base path to which this expression's value should be related.
1600
+ * For example, for a variable declaration `const x = y`, the targetPath would be
1601
+ * StructuredPath.fromBase('x'). For a return statement `return expr`, the targetPath
1602
+ * would be StructuredPath.fromBase('returnValue').
1603
+ *
1604
+ * When targetPath is provided, this function will establish all appropriate equivalences
1605
+ * and register types for targetPath. When omitted (typically for sub-expressions in
1606
+ * recursive calls), the function will operate without establishing external relationships.
1607
+ *
1608
+ * @returns true if the expression was processed successfully, false otherwise.
1609
+ */
1610
+ export function processExpression({
1611
+ node,
1612
+ context,
1613
+ targetPath,
1614
+ typeHint,
1615
+ }: {
1616
+ node: ts.Expression;
1617
+ context: AnalysisContext;
1618
+ targetPath?: StructuredPath; // Base path for relationship establishment
1619
+ typeHint?: string; // Optional type hint for the node
1620
+ }): boolean {
1621
+ let inferredNodeType = context.inferTypeFromNode(node);
1622
+ if (inferredNodeType === 'unknown' && typeHint) {
1623
+ inferredNodeType = typeHint;
1624
+ }
1625
+ const unwrappedNode = unwrapExpression(node);
1626
+
1627
+ // IMPORTANT: Mark nullable variables BEFORE checking child boundaries
1628
+ // JSX expressions like {showLogsForEntity && projectSlug && (<Component />)} are child boundaries,
1629
+ // but we still need to mark the variables as potentially undefined
1630
+ if (
1631
+ ts.isBinaryExpression(unwrappedNode) &&
1632
+ unwrappedNode.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken
1633
+ ) {
1634
+ markConditionVariablesAsNullable(unwrappedNode, context);
1635
+ // Extract conditional usages for key attribute detection
1636
+ // Only call from the OUTERMOST && expression to avoid duplicates
1637
+ // Check if parent is also a && (meaning we're nested)
1638
+ const parent = unwrappedNode.parent;
1639
+ const parentIsAndChain =
1640
+ parent &&
1641
+ ts.isBinaryExpression(parent) &&
1642
+ parent.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken;
1643
+ if (!parentIsAndChain) {
1644
+ extractConditionalUsage(unwrappedNode, context, 'logical-and');
1645
+ }
1646
+ }
1647
+
1648
+ // CRITICAL: Extract conditionals from JSX BEFORE checking child boundaries
1649
+ // JSX elements are NOT scopes - their expressions use variables from the parent scope.
1650
+ // Even if the JSX element is within a child boundary (e.g., because it contains callbacks),
1651
+ // we must still extract conditionals from JSX expression children like {x && <div>...</div>}
1652
+ if (
1653
+ ts.isJsxElement(unwrappedNode) ||
1654
+ ts.isJsxSelfClosingElement(unwrappedNode) ||
1655
+ ts.isJsxFragment(unwrappedNode)
1656
+ ) {
1657
+ extractConditionalsFromJsx(unwrappedNode, context);
1658
+ }
1659
+
1660
+ // If the node falls within an excluded child scope, stop processing it.
1661
+ if (context.isChildBoundary(node)) {
1662
+ return true;
1663
+ }
1664
+
1665
+ // Create a path for this node
1666
+ let nodePath: StructuredPath | null = null;
1667
+
1668
+ // if (unwrappedNode.kind === ts.SyntaxKind.Identifier) {
1669
+ // console.warn(
1670
+ // `Got IDENTIFIER and ts.isIdentifier = ${ts.isIdentifier(unwrappedNode)}`,
1671
+ // unwrappedNode.getText(context.sourceFile),
1672
+ // );
1673
+ // }
1674
+
1675
+ // Handle simple cases directly
1676
+ if (ts.isIdentifier(unwrappedNode)) {
1677
+ nodePath = StructuredPath.fromBase(unwrappedNode.text);
1678
+
1679
+ // If targetPath is provided, establish equivalence and register type
1680
+ if (targetPath) {
1681
+ context.addEquivalence(targetPath, nodePath);
1682
+ context.addType(targetPath, inferredNodeType);
1683
+
1684
+ // Propagate sub-properties from the identifier to the targetPath
1685
+ // This handles cases like: dataItem={{ structure: completeDataStructure }}
1686
+ // where completeDataStructure was defined as { 'Function Arguments': dataStructure.arguments }
1687
+ // We need to propagate completeDataStructure['Function Arguments'] to
1688
+ // ChildComponent().signature[0].dataItem.structure['Function Arguments']
1689
+ const nodePathStr = nodePath.toString();
1690
+ const equivalentVariables = context.getEquivalentVariables();
1691
+ const structure = context.getStructure();
1692
+
1693
+ // Propagate existing equivalencies for sub-properties
1694
+ for (const [key, rawValue] of Object.entries(equivalentVariables)) {
1695
+ // Check if this equivalency is for a sub-property of the identifier
1696
+ // e.g., completeDataStructure['Function Arguments'] or completeDataStructure.foo
1697
+ if (
1698
+ key.startsWith(nodePathStr + '.') ||
1699
+ key.startsWith(nodePathStr + '[')
1700
+ ) {
1701
+ const subPath = key.substring(nodePathStr.length);
1702
+ const newTargetPath = StructuredPath.fromBase(
1703
+ targetPath.toString() + subPath,
1704
+ );
1705
+ // Handle both string and string[] values
1706
+ const values = Array.isArray(rawValue) ? rawValue : [rawValue];
1707
+ for (const value of values) {
1708
+ if (typeof value === 'string') {
1709
+ const valuePath = StructuredPath.fromBase(value);
1710
+ context.addEquivalence(newTargetPath, valuePath);
1711
+ }
1712
+ }
1713
+ }
1714
+ }
1715
+
1716
+ // Propagate existing structure entries for sub-properties
1717
+ for (const [key, value] of Object.entries(structure)) {
1718
+ if (
1719
+ key.startsWith(nodePathStr + '.') ||
1720
+ key.startsWith(nodePathStr + '[')
1721
+ ) {
1722
+ const subPath = key.substring(nodePathStr.length);
1723
+ const newTargetPath = StructuredPath.fromBase(
1724
+ targetPath.toString() + subPath,
1725
+ );
1726
+ context.addType(newTargetPath, value);
1727
+ }
1728
+ }
1729
+ }
1730
+ context.addType(nodePath, inferredNodeType);
1731
+ return true;
1732
+ }
1733
+
1734
+ if (
1735
+ ts.isStringLiteral(unwrappedNode) ||
1736
+ ts.isNoSubstitutionTemplateLiteral(unwrappedNode)
1737
+ ) {
1738
+ nodePath = StructuredPath.createLiteralPath(
1739
+ unwrappedNode.getText(context.sourceFile),
1740
+ 'string',
1741
+ );
1742
+
1743
+ if (targetPath) {
1744
+ context.addEquivalence(targetPath, nodePath);
1745
+ context.addType(targetPath, 'string');
1746
+ }
1747
+
1748
+ return true;
1749
+ }
1750
+
1751
+ if (ts.isNumericLiteral(unwrappedNode)) {
1752
+ nodePath = StructuredPath.createLiteralPath(unwrappedNode.text, 'number');
1753
+
1754
+ if (targetPath) {
1755
+ context.addEquivalence(targetPath, nodePath);
1756
+ context.addType(targetPath, 'number');
1757
+ }
1758
+
1759
+ return true;
1760
+ }
1761
+
1762
+ if (
1763
+ unwrappedNode.kind === ts.SyntaxKind.TrueKeyword ||
1764
+ unwrappedNode.kind === ts.SyntaxKind.FalseKeyword
1765
+ ) {
1766
+ const value =
1767
+ unwrappedNode.kind === ts.SyntaxKind.TrueKeyword ? 'true' : 'false';
1768
+ nodePath = StructuredPath.createLiteralPath(value, 'boolean');
1769
+
1770
+ if (targetPath) {
1771
+ context.addEquivalence(targetPath, nodePath);
1772
+ context.addType(targetPath, 'boolean');
1773
+ }
1774
+
1775
+ return true;
1776
+ }
1777
+
1778
+ if (unwrappedNode.kind === ts.SyntaxKind.NullKeyword) {
1779
+ nodePath = StructuredPath.createLiteralPath('null', 'null');
1780
+
1781
+ if (targetPath) {
1782
+ context.addEquivalence(targetPath, nodePath);
1783
+ context.addType(targetPath, 'null');
1784
+ }
1785
+
1786
+ return true;
1787
+ }
1788
+
1789
+ if (unwrappedNode.kind === ts.SyntaxKind.UndefinedKeyword) {
1790
+ nodePath = StructuredPath.createLiteralPath('undefined', 'undefined');
1791
+
1792
+ if (targetPath) {
1793
+ context.addEquivalence(targetPath, nodePath);
1794
+ context.addType(targetPath, 'undefined');
1795
+ }
1796
+
1797
+ return true;
1798
+ }
1799
+
1800
+ if (
1801
+ ts.isThisTypeNode(unwrappedNode) ||
1802
+ unwrappedNode.kind === ts.SyntaxKind.ThisKeyword
1803
+ ) {
1804
+ nodePath = StructuredPath.createLiteralPath('this', 'object');
1805
+
1806
+ if (targetPath) {
1807
+ context.addEquivalence(targetPath, nodePath);
1808
+ context.addType(targetPath, 'object');
1809
+ }
1810
+
1811
+ return true;
1812
+ }
1813
+
1814
+ // Handle Property Access: obj.prop
1815
+ if (ts.isPropertyAccessExpression(unwrappedNode)) {
1816
+ // Process the object part recursively (without targetPath)
1817
+ const objectProcessed = processExpression({
1818
+ node: unwrappedNode.expression,
1819
+ context,
1820
+ });
1821
+
1822
+ if (!objectProcessed) {
1823
+ // If we couldn't process the object part, we can't process the property access
1824
+ // console.warn(
1825
+ // `processExpression: Unsupported object part: ${unwrappedNode.expression.getText(context.sourceFile)}`,
1826
+ // ts.isIdentifier(unwrappedNode.expression),
1827
+ // );
1828
+ context.markUnsupported(
1829
+ unwrappedNode.expression,
1830
+ `processExpression: Unsupported base expression for property access: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
1831
+ false,
1832
+ );
1833
+ return false;
1834
+ }
1835
+
1836
+ // Get a proper path for the object
1837
+ const objectPath = StructuredPath.fromNode(
1838
+ unwrappedNode.expression,
1839
+ context.sourceFile,
1840
+ );
1841
+
1842
+ if (!objectPath) {
1843
+ context.markUnsupported(
1844
+ unwrappedNode.expression,
1845
+ `processExpression: Couldn't get path for property access base: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
1846
+ false,
1847
+ );
1848
+ return false;
1849
+ }
1850
+
1851
+ // Create the property access path
1852
+ const propertyPath = objectPath.withProperty(unwrappedNode.name.text);
1853
+
1854
+ // Check if this is an environment variable access
1855
+ const fullText = unwrappedNode.getText(context.sourceFile);
1856
+ if (
1857
+ fullText.includes('.env.') || // process.env.X, window.env.X
1858
+ isEnvStoreAccess(fullText) // env.X where env is likely an env config object
1859
+ ) {
1860
+ context.addEnvironmentVariable(fullText);
1861
+ }
1862
+
1863
+ // Infer and register type for the property
1864
+ context.addType(propertyPath, inferredNodeType);
1865
+
1866
+ // If targetPath is provided, establish equivalence and propagate type
1867
+ if (targetPath) {
1868
+ context.addEquivalence(targetPath, propertyPath);
1869
+ context.addType(targetPath, inferredNodeType);
1870
+ }
1871
+
1872
+ return true;
1873
+ }
1874
+
1875
+ // Handle Binary Expressions: a + b, x === y, etc.
1876
+ if (ts.isBinaryExpression(unwrappedNode)) {
1877
+ // Check if it's an assignment first, as BinaryExpression includes assignments
1878
+ if (isAssignmentOperator(unwrappedNode.operatorToken.kind)) {
1879
+ // Check for destructuring assignment first
1880
+ if (
1881
+ (ts.isObjectBindingPattern(unwrappedNode.left) ||
1882
+ ts.isArrayBindingPattern(unwrappedNode.left)) &&
1883
+ unwrappedNode.operatorToken.kind === ts.SyntaxKind.EqualsToken
1884
+ ) {
1885
+ // For destructuring assignment, we first need to process the right side
1886
+ const rightSideProcessed = processExpression({
1887
+ node: unwrappedNode.right,
1888
+ context,
1889
+ });
1890
+
1891
+ if (!rightSideProcessed) {
1892
+ context.markUnsupported(
1893
+ unwrappedNode.right,
1894
+ `processExpression: Unsupported right side of destructuring assignment: ${ts.SyntaxKind[unwrappedNode.right.kind]}`,
1895
+ false,
1896
+ );
1897
+ return false;
1898
+ }
1899
+
1900
+ // Get the right side path
1901
+ const rightSidePath = StructuredPath.fromNode(
1902
+ unwrappedNode.right,
1903
+ context.sourceFile,
1904
+ );
1905
+
1906
+ if (!rightSidePath) {
1907
+ context.markUnsupported(
1908
+ unwrappedNode.right,
1909
+ `processExpression: Couldn't get path for right side of destructuring assignment`,
1910
+ false,
1911
+ );
1912
+ return false;
1913
+ }
1914
+
1915
+ // Process the binding pattern with the right side as source
1916
+ const success = processBindingPattern(
1917
+ unwrappedNode.left as ts.BindingPattern,
1918
+ rightSidePath,
1919
+ context,
1920
+ );
1921
+
1922
+ // If targetPath was provided, establish equivalence to the right side
1923
+ // This is useful when the destructuring assignment is itself part of a larger expression
1924
+ if (targetPath) {
1925
+ context.addEquivalence(targetPath, rightSidePath);
1926
+ context.inferAndAddType(targetPath, unwrappedNode.right);
1927
+ }
1928
+
1929
+ return success;
1930
+ }
1931
+ // Regular non-destructuring assignment
1932
+ else {
1933
+ // Process the left side to ensure it's analyzed and to get its path
1934
+ const leftSideProcessed = processExpression({
1935
+ node: unwrappedNode.left,
1936
+ context,
1937
+ });
1938
+
1939
+ if (!leftSideProcessed) {
1940
+ context.markUnsupported(
1941
+ unwrappedNode.left,
1942
+ `processExpression: Unsupported left side of assignment: ${ts.SyntaxKind[unwrappedNode.left.kind]}`,
1943
+ false,
1944
+ );
1945
+ return false; // Cannot process assignment without successful LHS processing
1946
+ }
1947
+
1948
+ // Get the structured path for the left side
1949
+ const leftSidePath = StructuredPath.fromNode(
1950
+ unwrappedNode.left,
1951
+ context.sourceFile,
1952
+ );
1953
+
1954
+ if (!leftSidePath) {
1955
+ context.markUnsupported(
1956
+ unwrappedNode.left,
1957
+ `processExpression: Couldn't get path for left side of assignment: ${ts.SyntaxKind[unwrappedNode.left.kind]}`,
1958
+ false,
1959
+ );
1960
+ return false;
1961
+ }
1962
+
1963
+ // Handle simple assignment (=)
1964
+ if (unwrappedNode.operatorToken.kind === ts.SyntaxKind.EqualsToken) {
1965
+ // Process the right side
1966
+ const rightSideProcessed = processExpression({
1967
+ node: unwrappedNode.right,
1968
+ context,
1969
+ targetPath: leftSidePath, // Pass leftSidePath as targetPath
1970
+ });
1971
+
1972
+ if (!rightSideProcessed) {
1973
+ context.addType(leftSidePath, 'unknown');
1974
+ context.markUnsupported(
1975
+ unwrappedNode.right,
1976
+ `processExpression: Unsupported right side of assignment: ${ts.SyntaxKind[unwrappedNode.right.kind]}`,
1977
+ false,
1978
+ );
1979
+ return false;
1980
+ }
1981
+ if (ts.isObjectLiteralExpression(unwrappedNode.right)) {
1982
+ // Just add object type - property equivalences were set up during processing
1983
+ context.addType(leftSidePath, 'object');
1984
+ }
1985
+ // If targetPath was provided to us, establish equivalence
1986
+ if (targetPath) {
1987
+ context.addEquivalence(targetPath, leftSidePath);
1988
+ context.inferAndAddType(targetPath, unwrappedNode.right);
1989
+ }
1990
+
1991
+ return true;
1992
+ }
1993
+ // Handle compound assignments (+=, -=, etc.)
1994
+ else {
1995
+ // For compound assignments, we process the right side without targetPath
1996
+ const rightSideProcessed = processExpression({
1997
+ node: unwrappedNode.right,
1998
+ context,
1999
+ });
2000
+ if (!rightSideProcessed) {
2001
+ context.markUnsupported(
2002
+ unwrappedNode.right,
2003
+ `processExpression: Unsupported right side of compound assignment: ${ts.SyntaxKind[unwrappedNode.right.kind]}`,
2004
+ false,
2005
+ );
2006
+ return false;
2007
+ }
2008
+
2009
+ // Determine the result type based on operation
2010
+ const operatorKind = unwrappedNode.operatorToken.kind;
2011
+
2012
+ let leftType = context.getTypeInfo(leftSidePath);
2013
+ if (leftType === 'unknown') {
2014
+ leftType = context.inferTypeFromNode(unwrappedNode.left);
2015
+ }
2016
+
2017
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2018
+
2019
+ let resultType = 'unknown';
2020
+ if (operatorKind === ts.SyntaxKind.PlusEqualsToken) {
2021
+ // plus operator is special - it can be string or number
2022
+ resultType =
2023
+ leftType === 'string' || rightType === 'string'
2024
+ ? 'string'
2025
+ : 'number';
2026
+ } else if (isNumericCompoundOperator(operatorKind)) {
2027
+ resultType = 'number';
2028
+ } else if (isBitwiseCompoundOperator(operatorKind)) {
2029
+ resultType = 'number';
2030
+ } else if (
2031
+ operatorKind === ts.SyntaxKind.AmpersandAmpersandEqualsToken
2032
+ ) {
2033
+ resultType = 'boolean';
2034
+ } else if (
2035
+ operatorKind === ts.SyntaxKind.BarBarEqualsToken ||
2036
+ operatorKind === ts.SyntaxKind.QuestionQuestionEqualsToken
2037
+ ) {
2038
+ resultType = leftOrRightType(leftType, rightType) ?? 'unknown';
2039
+ } else {
2040
+ context.markUnsupported(
2041
+ unwrappedNode,
2042
+ `processExpression: Unsupported compound assignment operator: ${ts.SyntaxKind[operatorKind]}`,
2043
+ false,
2044
+ );
2045
+ }
2046
+
2047
+ // Update the type of the left side
2048
+ context.addType(leftSidePath, resultType);
2049
+ context.addEquivalence(
2050
+ leftSidePath,
2051
+ StructuredPath.fromNode(unwrappedNode.right, context.sourceFile),
2052
+ );
2053
+
2054
+ // If targetPath was provided, establish equivalence
2055
+ if (targetPath) {
2056
+ context.addEquivalence(targetPath, leftSidePath);
2057
+ context.addType(targetPath, resultType);
2058
+ }
2059
+
2060
+ return true;
2061
+ }
2062
+ }
2063
+ }
2064
+ // Non-assignment binary expressions (logical, arithmetic, comparison, etc.)
2065
+ else {
2066
+ // Process both sides for their side effects (without targetPath)
2067
+ processExpression({ node: unwrappedNode.left, context });
2068
+ processExpression({ node: unwrappedNode.right, context });
2069
+
2070
+ // Determine the type of the result
2071
+ const operatorKind = unwrappedNode.operatorToken.kind;
2072
+ let resultPath = null;
2073
+ let resultType = 'unknown';
2074
+
2075
+ // Type Inference Logic
2076
+ if (isComparisonOperator(operatorKind)) {
2077
+ resultType = 'boolean';
2078
+
2079
+ // Type narrowing: if comparing a call expression with unknown return type
2080
+ // to a value of known type, narrow the return type
2081
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2082
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2083
+
2084
+ // Check if left side is a call expression with unknown return type
2085
+ if (
2086
+ ts.isCallExpression(unwrappedNode.left) &&
2087
+ leftType === 'unknown' &&
2088
+ rightType !== 'unknown'
2089
+ ) {
2090
+ const leftPath = StructuredPath.fromNode(
2091
+ unwrappedNode.left,
2092
+ context.sourceFile,
2093
+ );
2094
+ if (leftPath) {
2095
+ const returnValuePath = leftPath.withProperty(
2096
+ 'functionCallReturnValue',
2097
+ );
2098
+ context.addType(returnValuePath, `${rightType} | unknown`);
2099
+ }
2100
+ }
2101
+ // Check if right side is a call expression with unknown return type
2102
+ else if (
2103
+ ts.isCallExpression(unwrappedNode.right) &&
2104
+ rightType === 'unknown' &&
2105
+ leftType !== 'unknown'
2106
+ ) {
2107
+ const rightPath = StructuredPath.fromNode(
2108
+ unwrappedNode.right,
2109
+ context.sourceFile,
2110
+ );
2111
+ if (rightPath) {
2112
+ const returnValuePath = rightPath.withProperty(
2113
+ 'functionCallReturnValue',
2114
+ );
2115
+ context.addType(returnValuePath, `${leftType} | unknown`);
2116
+ }
2117
+ }
2118
+ } else if (isArithmeticOperator(operatorKind)) {
2119
+ // For plus operator, check if either operand is a string
2120
+ if (operatorKind === ts.SyntaxKind.PlusToken) {
2121
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2122
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2123
+
2124
+ if (leftType === 'string' || rightType === 'string') {
2125
+ resultType = 'string';
2126
+ } else {
2127
+ resultType = 'number';
2128
+ }
2129
+ } else {
2130
+ // All other arithmetic operators result in numbers
2131
+ resultType = 'number';
2132
+ }
2133
+ } else if (operatorKind === ts.SyntaxKind.AmpersandAmpersandToken) {
2134
+ // Logical AND typically results in a boolean
2135
+ resultType = 'boolean';
2136
+
2137
+ // Mark the left operand as potentially undefined since it's being checked for truthiness
2138
+ markConditionVariablesAsNullable(unwrappedNode.left, context);
2139
+ } else if (
2140
+ operatorKind === ts.SyntaxKind.BarBarToken || // Logical OR
2141
+ operatorKind === ts.SyntaxKind.QuestionQuestionToken // Nullish Coalescing
2142
+ ) {
2143
+ // For || and ??, the result type depends on the operands
2144
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2145
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2146
+
2147
+ // For ||, if either side is boolean, result is boolean
2148
+ if (
2149
+ operatorKind === ts.SyntaxKind.BarBarToken &&
2150
+ (leftType === 'boolean' || rightType === 'boolean')
2151
+ ) {
2152
+ resultType = 'boolean';
2153
+ }
2154
+ // Otherwise, for both || and ??, we use the first defined type
2155
+ else if (isDefinedType(leftType)) {
2156
+ resultType = leftType;
2157
+ } else {
2158
+ resultType = rightType || 'unknown';
2159
+ }
2160
+ // For || and ??, create an equivalence to the left side
2161
+ // This ensures the equivalency chain is preserved through fallback expressions
2162
+ // e.g., `const tab = segments[0] || 'default'` should trace tab back to segments[0]
2163
+ if (operatorKind === ts.SyntaxKind.QuestionQuestionToken) {
2164
+ // specifically for ?? we create an equivalence to the left side
2165
+ // IMPORTANT: Also process the left side recursively to apply method semantics
2166
+ // (e.g., for `const segments = splat?.split('/') ?? []`, we need split semantics)
2167
+ processExpression({
2168
+ node: unwrappedNode.left,
2169
+ context,
2170
+ // Don't pass targetPath here - we'll establish equivalence separately below
2171
+ });
2172
+
2173
+ if (targetPath) {
2174
+ resultPath = StructuredPath.fromNode(
2175
+ unwrappedNode.left,
2176
+ context.sourceFile,
2177
+ );
2178
+ } else {
2179
+ // if the expression is the target capture that the two sides are equivalent (e.g. (x ?? y).map())
2180
+ targetPath = StructuredPath.fromNode(
2181
+ unwrappedNode,
2182
+ context.sourceFile,
2183
+ );
2184
+ resultPath = StructuredPath.fromNode(
2185
+ unwrappedNode.left,
2186
+ context.sourceFile,
2187
+ );
2188
+ }
2189
+ } else if (operatorKind === ts.SyntaxKind.BarBarToken) {
2190
+ // For ||, create equivalences to BOTH sides
2191
+ // This enables data flow tracing through fallback expressions
2192
+ // e.g., `const item = items.find(...) || null` should trace to both:
2193
+ // - items[] (from the find result)
2194
+ // - null (from the fallback)
2195
+ if (targetPath) {
2196
+ // Get paths for both sides
2197
+ const leftPath = StructuredPath.fromNode(
2198
+ unwrappedNode.left,
2199
+ context.sourceFile,
2200
+ );
2201
+ const rightPath = StructuredPath.fromNode(
2202
+ unwrappedNode.right,
2203
+ context.sourceFile,
2204
+ );
2205
+
2206
+ // Collect all valid paths
2207
+ const allPaths: StructuredPath[] = [];
2208
+ if (leftPath) allPaths.push(leftPath);
2209
+ if (rightPath) allPaths.push(rightPath);
2210
+
2211
+ // Add multiple equivalencies to track both sources
2212
+ if (allPaths.length > 0) {
2213
+ context.addMultipleEquivalencies(targetPath, allPaths);
2214
+ }
2215
+
2216
+ // Process both sides to capture their internal structures
2217
+ processExpression({
2218
+ node: unwrappedNode.left,
2219
+ context,
2220
+ });
2221
+ processExpression({
2222
+ node: unwrappedNode.right,
2223
+ context,
2224
+ });
2225
+
2226
+ // Register the type for the target path
2227
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
2228
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
2229
+ const orResultType = isDefinedType(leftType)
2230
+ ? leftType
2231
+ : rightType || 'unknown';
2232
+ context.addType(targetPath, orResultType);
2233
+
2234
+ // Return early - we've already handled equivalencies with addMultipleEquivalencies
2235
+ // Don't fall through to the generic addEquivalence call below
2236
+ return true;
2237
+ }
2238
+ // Note: When there's no targetPath, we don't recursively process
2239
+ // because || is often used in boolean contexts where the full expression matters
2240
+ }
2241
+ } else if (operatorKind === ts.SyntaxKind.InstanceOfKeyword) {
2242
+ resultType = 'boolean';
2243
+ } else {
2244
+ // Fallback for other operators
2245
+ resultType = inferredNodeType;
2246
+ context.markUnsupported(
2247
+ unwrappedNode,
2248
+ `processExpression: Unsupported binary operator: ${ts.SyntaxKind[operatorKind]}`,
2249
+ false,
2250
+ );
2251
+ }
2252
+
2253
+ // Get a canonical representation for the entire binary expression
2254
+ resultPath ??= nodeToSource(unwrappedNode, context.sourceFile);
2255
+
2256
+ // Register the type for the expression
2257
+ context.addType(resultPath, resultType);
2258
+
2259
+ // If targetPath is provided, establish equivalence and register type
2260
+ if (targetPath) {
2261
+ context.addEquivalence(targetPath, resultPath);
2262
+ context.addType(targetPath, resultType);
2263
+ }
2264
+
2265
+ return true;
2266
+ }
2267
+ }
2268
+
2269
+ // Handle Call Expressions: func(), obj.method(), func()() etc.
2270
+ if (ts.isCallExpression(unwrappedNode)) {
2271
+ // 1. Process the expression being called (e.g., 'func', 'obj.method')
2272
+ const calledExprProcessed = processExpression({
2273
+ node: unwrappedNode.expression,
2274
+ context,
2275
+ });
2276
+
2277
+ if (!calledExprProcessed) {
2278
+ context.markUnsupported(
2279
+ unwrappedNode.expression,
2280
+ `processExpression: Unsupported expression being called: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2281
+ false,
2282
+ );
2283
+ return false;
2284
+ }
2285
+
2286
+ // Get a proper path for the called expression
2287
+ const calledExprPath = StructuredPath.fromNode(
2288
+ unwrappedNode.expression,
2289
+ context.sourceFile,
2290
+ );
2291
+
2292
+ if (!calledExprPath) {
2293
+ context.markUnsupported(
2294
+ unwrappedNode.expression,
2295
+ `processExpression: Couldn't get path for called expression: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2296
+ false,
2297
+ );
2298
+ return false;
2299
+ }
2300
+
2301
+ // Build call path using original source text for consistent schema paths.
2302
+ // IMPORTANT: Never use cyScope names in call paths - they are internal identifiers
2303
+ // that should not appear in schema paths or call signatures.
2304
+ const callPath = buildCallPathFromSource(unwrappedNode, context);
2305
+
2306
+ // 2. Process all arguments recursively WITH targetPath for proper equivalence
2307
+ for (let i = 0; i < unwrappedNode.arguments.length; i++) {
2308
+ const arg = unwrappedNode.arguments[i];
2309
+
2310
+ const childBoundary = context.isChildBoundary(arg);
2311
+ if (childBoundary) {
2312
+ context.addChildBoundaryEquivalence(callPath.withParameter(i), arg);
2313
+ }
2314
+
2315
+ // Process each argument with its parameter path as targetPath
2316
+ // This automatically establishes all equivalences and types
2317
+ processExpression({
2318
+ node: arg,
2319
+ context,
2320
+ targetPath: callPath.withParameter(i), // Use parameter path as targetPath
2321
+ });
2322
+
2323
+ // Special case for Object.keys, etc.
2324
+ if (calledExprPath.base === 'Object' && i === 0) {
2325
+ const argPath = StructuredPath.fromNode(arg, context.sourceFile);
2326
+ if (argPath) {
2327
+ context.addType(argPath, 'object');
2328
+ }
2329
+ }
2330
+ }
2331
+
2332
+ // 5. Handle Method Semantics and determine return type
2333
+ let returnType = 'unknown';
2334
+ let handledBySemantics = false;
2335
+
2336
+ // Check if it's a method call (PropertyAccess)
2337
+ if (ts.isPropertyAccessExpression(unwrappedNode.expression)) {
2338
+ const methodName = unwrappedNode.expression.name.text;
2339
+ const semanticsList = methodRegistry.getByMethodName(methodName);
2340
+
2341
+ if (semanticsList && semanticsList.length > 0) {
2342
+ const semantics = semanticsList[0];
2343
+
2344
+ // Get the source expression path (e.g., the object for obj.method())
2345
+ const sourceExpr = unwrappedNode.expression.expression;
2346
+ const unwrappedSourceExpr = unwrapExpression(sourceExpr);
2347
+
2348
+ // When the source is a ternary expression like (cond ? arr : arr.slice()),
2349
+ // apply method semantics to BOTH branches directly. The ternary itself isn't
2350
+ // a variable - it's just a choice between two paths that both flow to the result.
2351
+ if (ts.isConditionalExpression(unwrappedSourceExpr)) {
2352
+ const branches = [
2353
+ unwrappedSourceExpr.whenTrue,
2354
+ unwrappedSourceExpr.whenFalse,
2355
+ ];
2356
+
2357
+ for (const branch of branches) {
2358
+ const branchPath = StructuredPath.fromNode(
2359
+ branch,
2360
+ context.sourceFile,
2361
+ );
2362
+ if (branchPath) {
2363
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
2364
+ const shouldApply =
2365
+ !isArraySemantics ||
2366
+ isLikelyArrayType(branch, context.typeChecker);
2367
+
2368
+ if (shouldApply) {
2369
+ semantics.addEquivalences(callPath, branchPath, context);
2370
+ returnType = semantics.getReturnType();
2371
+ handledBySemantics = true;
2372
+ }
2373
+ }
2374
+ }
2375
+ } else {
2376
+ // Regular (non-ternary) source expression
2377
+ const sourcePath = StructuredPath.fromNode(
2378
+ sourceExpr,
2379
+ context.sourceFile,
2380
+ );
2381
+
2382
+ if (sourcePath) {
2383
+ // For array-specific semantics (like push), verify the source is actually an array
2384
+ // This prevents router.push() from being mistakenly treated as Array.push()
2385
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
2386
+ const shouldApply =
2387
+ !isArraySemantics ||
2388
+ isLikelyArrayType(sourceExpr, context.typeChecker);
2389
+
2390
+ if (shouldApply) {
2391
+ // Apply method semantics
2392
+ semantics.addEquivalences(callPath, sourcePath, context);
2393
+ returnType = semantics.getReturnType();
2394
+ handledBySemantics = true;
2395
+ }
2396
+ }
2397
+ }
2398
+ }
2399
+ }
2400
+ // Check if it's a method call via element access (obj['method']())
2401
+ else if (
2402
+ ts.isElementAccessExpression(unwrappedNode.expression) &&
2403
+ ts.isStringLiteral(unwrappedNode.expression.argumentExpression)
2404
+ ) {
2405
+ const methodName = unwrappedNode.expression.argumentExpression.text;
2406
+ const semanticsList = methodRegistry.getByMethodName(methodName);
2407
+
2408
+ if (semanticsList && semanticsList.length > 0) {
2409
+ const semantics = semanticsList[0];
2410
+
2411
+ // Get the source expression path
2412
+ const sourceExpr = unwrappedNode.expression.expression;
2413
+ const sourcePath = StructuredPath.fromNode(
2414
+ sourceExpr,
2415
+ context.sourceFile,
2416
+ );
2417
+
2418
+ if (sourcePath) {
2419
+ // For array-specific semantics (like push), verify the source is actually an array
2420
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
2421
+ const shouldApply =
2422
+ !isArraySemantics ||
2423
+ isLikelyArrayType(sourceExpr, context.typeChecker);
2424
+
2425
+ if (shouldApply) {
2426
+ // Apply method semantics
2427
+ semantics.addEquivalences(callPath, sourcePath, context);
2428
+ returnType = semantics.getReturnType();
2429
+ handledBySemantics = true;
2430
+ }
2431
+ }
2432
+ }
2433
+ }
2434
+ // 7. Determine and Add Return Type
2435
+ if (returnType === 'unknown') {
2436
+ // If semantics didn't provide a type, try inferring
2437
+ returnType = context.inferTypeFromNode(node);
2438
+ }
2439
+
2440
+ // Register types
2441
+ context.addType(callPath, 'function');
2442
+ context.addType(calledExprPath, 'function');
2443
+
2444
+ // Only register the function call return value if:
2445
+ // - It's not void, AND
2446
+ // - Either the result is being used (targetPath exists) OR the return type is known (not 'unknown')
2447
+ if (returnType !== 'void' && (targetPath || returnType !== 'unknown')) {
2448
+ const returnValuePath = callPath.withProperty('functionCallReturnValue');
2449
+ context.addType(returnValuePath, returnType);
2450
+ }
2451
+
2452
+ // 8. If targetPath is provided, establish equivalence and register type
2453
+ if (targetPath) {
2454
+ context.addEquivalence(targetPath, callPath);
2455
+ context.addType(targetPath, returnType);
2456
+ }
2457
+
2458
+ return true;
2459
+ }
2460
+
2461
+ // Handle Object Literals: { a: 1, b: x, ...spread }
2462
+ if (ts.isObjectLiteralExpression(unwrappedNode)) {
2463
+ // Create a path for the object literal itself
2464
+ const literalSourcePath = StructuredPath.createLiteralPath(
2465
+ unwrappedNode.getText(context.sourceFile),
2466
+ 'object',
2467
+ );
2468
+
2469
+ // If targetPath is provided, establish property relationships
2470
+ // This is the main use case we're optimizing for
2471
+ if (targetPath) {
2472
+ // Process each property and establish relationships to the targetPath
2473
+ for (const property of unwrappedNode.properties) {
2474
+ if (ts.isPropertyAssignment(property)) {
2475
+ // Get property name
2476
+ let propName: string;
2477
+ if (ts.isIdentifier(property.name)) {
2478
+ propName = property.name.text;
2479
+ } else if (ts.isStringLiteral(property.name)) {
2480
+ propName = property.name.text;
2481
+ } else if (ts.isNumericLiteral(property.name)) {
2482
+ propName = property.name.text;
2483
+ } else if (ts.isComputedPropertyName(property.name)) {
2484
+ // Handle computed property names: { [x]: y }
2485
+ processExpression({ node: property.name.expression, context });
2486
+ const path = StructuredPath.fromNode(
2487
+ property.name.expression,
2488
+ context.sourceFile,
2489
+ );
2490
+ propName = `*${path}*`;
2491
+ } else {
2492
+ // For other property name types, use text representation
2493
+ propName = property.name.getText(context.sourceFile);
2494
+ context.markSemanticLimitation(
2495
+ property.name,
2496
+ 'Complex property name might not be accurately represented.',
2497
+ );
2498
+ }
2499
+
2500
+ // Create a path for this property within the base
2501
+ const propPath = targetPath.withProperty(propName);
2502
+
2503
+ // Handle child boundaries (callback functions) in object properties
2504
+ // This establishes equivalency between the property path and the child scope
2505
+ // e.g., columns[0].renderCell → cyScope1()
2506
+ if (context.isChildBoundary(property.initializer)) {
2507
+ context.addChildBoundaryEquivalence(propPath, property.initializer);
2508
+ }
2509
+
2510
+ // Process the property value with propPath as targetPath
2511
+ // This allows nested object literals to work correctly
2512
+ processExpression({
2513
+ node: property.initializer,
2514
+ context,
2515
+ targetPath: propPath,
2516
+ });
2517
+ } else if (ts.isShorthandPropertyAssignment(property)) {
2518
+ // Handle shorthand form: { x } is equivalent to { x: x }
2519
+ const propName = property.name.text;
2520
+ const propPath = targetPath.withProperty(propName);
2521
+
2522
+ // Create a path for the identifier value
2523
+ const valuePath = StructuredPath.fromBase(propName);
2524
+
2525
+ // Establish the equivalence and type
2526
+ context.addEquivalence(propPath, valuePath);
2527
+ const valueType = context.inferTypeFromNode(property.name);
2528
+ context.addType(propPath, valueType);
2529
+ context.addType(valuePath, valueType);
2530
+ } else if (ts.isSpreadAssignment(property)) {
2531
+ // Handle spread: { ...obj }
2532
+ // Create a path for this spread source
2533
+ let spreadSourcePath: StructuredPath | null = null;
2534
+
2535
+ // Handle simple identifier spread: { ...obj }
2536
+ if (ts.isIdentifier(property.expression)) {
2537
+ // Process the spread expression first
2538
+ processExpression({ node: property.expression, context });
2539
+
2540
+ spreadSourcePath = StructuredPath.fromBase(
2541
+ property.expression.text,
2542
+ );
2543
+ // Establish equivalence between the target and the spread source
2544
+ context.addEquivalence(targetPath, spreadSourcePath);
2545
+ // and we know obj is an object
2546
+ context.addType(spreadSourcePath, 'object');
2547
+ }
2548
+ // Handle property access spread: { ...obj.prop }
2549
+ else if (ts.isPropertyAccessExpression(property.expression)) {
2550
+ // Process the spread expression first
2551
+ processExpression({ node: property.expression, context });
2552
+
2553
+ spreadSourcePath = StructuredPath.fromNode(
2554
+ property.expression,
2555
+ context.sourceFile,
2556
+ );
2557
+ if (spreadSourcePath) {
2558
+ context.addEquivalence(targetPath, spreadSourcePath);
2559
+ }
2560
+ }
2561
+ // Handle object literal spread: { ...{ key: value } }
2562
+ // This propagates sub-properties from the spread object to the target
2563
+ else if (ts.isObjectLiteralExpression(property.expression)) {
2564
+ // Recursively process the spread object literal WITH targetPath
2565
+ // This ensures sub-properties like { args: x } become targetPath.args = x
2566
+ processExpression({
2567
+ node: property.expression,
2568
+ context,
2569
+ targetPath,
2570
+ });
2571
+ }
2572
+ // Handle conditional spread: { ...(x ? {...} : {}) }
2573
+ else if (ts.isParenthesizedExpression(property.expression)) {
2574
+ // Unwrap parentheses and process
2575
+ const unwrapped = property.expression.expression;
2576
+
2577
+ // Handle conditional expression inside parens: (x ? {...} : {})
2578
+ if (ts.isConditionalExpression(unwrapped)) {
2579
+ // Process both branches - whenTrue and whenFalse
2580
+ // For tracing, we care about non-empty branches
2581
+ if (ts.isObjectLiteralExpression(unwrapped.whenTrue)) {
2582
+ processExpression({
2583
+ node: unwrapped.whenTrue,
2584
+ context,
2585
+ targetPath,
2586
+ });
2587
+ } else {
2588
+ processExpression({ node: unwrapped.whenTrue, context });
2589
+ }
2590
+
2591
+ if (ts.isObjectLiteralExpression(unwrapped.whenFalse)) {
2592
+ processExpression({
2593
+ node: unwrapped.whenFalse,
2594
+ context,
2595
+ targetPath,
2596
+ });
2597
+ } else {
2598
+ processExpression({ node: unwrapped.whenFalse, context });
2599
+ }
2600
+ } else {
2601
+ // Other parenthesized expression - just process normally
2602
+ processExpression({ node: property.expression, context });
2603
+ }
2604
+ }
2605
+ // Handle other expression types
2606
+ else {
2607
+ // Process the spread expression
2608
+ processExpression({ node: property.expression, context });
2609
+
2610
+ // For complex expressions, use their source representation
2611
+ spreadSourcePath = nodeToSource(
2612
+ property.expression,
2613
+ context.sourceFile,
2614
+ );
2615
+ if (spreadSourcePath) {
2616
+ context.addEquivalence(targetPath, spreadSourcePath);
2617
+ }
2618
+
2619
+ // Mark semantic limitation only for complex spread expressions
2620
+ context.markSemanticLimitation(
2621
+ property,
2622
+ 'Complex spread assignment - individual properties not fully mapped.',
2623
+ );
2624
+ }
2625
+ } else if (
2626
+ ts.isMethodDeclaration(property) ||
2627
+ ts.isGetAccessorDeclaration(property) ||
2628
+ ts.isSetAccessorDeclaration(property)
2629
+ ) {
2630
+ // For methods and accessors, just mark the property as a function
2631
+ if (ts.isIdentifier(property.name)) {
2632
+ const propName = property.name.text;
2633
+ const propPath = targetPath.withProperty(propName);
2634
+ context.addType(propPath, 'function');
2635
+ }
2636
+
2637
+ context.markUnsupported(
2638
+ property,
2639
+ `processExpression: Method/Accessor in object literal not fully processed: ${ts.SyntaxKind[property.kind]}`,
2640
+ false,
2641
+ );
2642
+ }
2643
+ }
2644
+
2645
+ // Mark the targetPath as an object type
2646
+ context.addType(targetPath, 'object');
2647
+ return true;
2648
+ } else {
2649
+ // No targetPath provided - just process each property for side effects
2650
+ for (const property of unwrappedNode.properties) {
2651
+ if (ts.isPropertyAssignment(property)) {
2652
+ processExpression({ node: property.initializer, context });
2653
+ } else if (ts.isShorthandPropertyAssignment(property)) {
2654
+ // For shorthand, establish type for the identifier
2655
+ const identPath = StructuredPath.fromBase(property.name.text);
2656
+ const idType = context.inferTypeFromNode(property.name);
2657
+ context.addType(identPath, idType);
2658
+ } else if (ts.isSpreadAssignment(property)) {
2659
+ // Still process the spread expression to ensure its contents are analyzed
2660
+ processExpression({ node: property.expression, context });
2661
+
2662
+ // Even without a targetPath, we can still determine the type for the spread source
2663
+ if (ts.isIdentifier(property.expression)) {
2664
+ const spreadSource = StructuredPath.fromBase(
2665
+ property.expression.text,
2666
+ );
2667
+ context.addType(spreadSource, 'object');
2668
+ } else if (ts.isPropertyAccessExpression(property.expression)) {
2669
+ const spreadSource = StructuredPath.fromNode(
2670
+ property.expression,
2671
+ context.sourceFile,
2672
+ );
2673
+ if (spreadSource) {
2674
+ context.addType(spreadSource, 'object');
2675
+ }
2676
+ }
2677
+ } else if (
2678
+ ts.isMethodDeclaration(property) ||
2679
+ ts.isGetAccessorDeclaration(property) ||
2680
+ ts.isSetAccessorDeclaration(property)
2681
+ ) {
2682
+ context.markUnsupported(
2683
+ property,
2684
+ `processExpression: Method/Accessor in object literal not fully processed: ${ts.SyntaxKind[property.kind]}`,
2685
+ false,
2686
+ );
2687
+ }
2688
+ }
2689
+
2690
+ // If we have no targetPath but we're still analyzing an object literal,
2691
+ // create a type registration for the literal itself
2692
+ context.addType(literalSourcePath, 'object');
2693
+ return true;
2694
+ }
2695
+ }
2696
+
2697
+ // Handle Array Literals: [1, x, func()]
2698
+ if (ts.isArrayLiteralExpression(unwrappedNode)) {
2699
+ // Create a path for the array literal
2700
+ const arrayLiteralPath = StructuredPath.createLiteralPath(
2701
+ unwrappedNode.getText(context.sourceFile),
2702
+ 'array',
2703
+ );
2704
+
2705
+ // Process each element recursively
2706
+ for (let i = 0; i < unwrappedNode.elements.length; i++) {
2707
+ const element = unwrappedNode.elements[i];
2708
+
2709
+ // If targetPath is provided, create element paths
2710
+ if (targetPath) {
2711
+ // Create path for this element (e.g., targetPath[0], targetPath[1])
2712
+ const elementPath = targetPath.withElement(i);
2713
+
2714
+ // Process the element with elementPath as targetPath
2715
+ processExpression({ node: element, context, targetPath: elementPath });
2716
+ } else {
2717
+ // No targetPath, just process for side effects
2718
+ processExpression({ node: element, context });
2719
+ }
2720
+ }
2721
+
2722
+ // Register type information
2723
+ if (targetPath) {
2724
+ context.addType(targetPath, 'array');
2725
+ } else {
2726
+ context.addType(arrayLiteralPath, 'array');
2727
+ }
2728
+
2729
+ return true;
2730
+ }
2731
+
2732
+ // Handle Element Access: arr[0], obj[key], obj['prop']
2733
+ if (ts.isElementAccessExpression(unwrappedNode)) {
2734
+ // Process the object expression
2735
+ const objectProcessed = processExpression({
2736
+ node: unwrappedNode.expression,
2737
+ context,
2738
+ });
2739
+
2740
+ if (!objectProcessed) {
2741
+ context.markUnsupported(
2742
+ unwrappedNode.expression,
2743
+ `processExpression: Unsupported base expression for element access: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2744
+ false,
2745
+ );
2746
+ return false;
2747
+ }
2748
+
2749
+ // Get a path for the object
2750
+ const objectPath = StructuredPath.fromNode(
2751
+ unwrappedNode.expression,
2752
+ context.sourceFile,
2753
+ );
2754
+
2755
+ if (!objectPath) {
2756
+ context.markUnsupported(
2757
+ unwrappedNode.expression,
2758
+ `processExpression: Couldn't get path for element access base: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2759
+ false,
2760
+ );
2761
+ return false;
2762
+ }
2763
+
2764
+ // Process the argument expression
2765
+ processExpression({ node: unwrappedNode.argumentExpression, context });
2766
+
2767
+ // Create the element access path based on argument type
2768
+ let elementPath: StructuredPath;
2769
+
2770
+ if (ts.isNumericLiteral(unwrappedNode.argumentExpression)) {
2771
+ // Array index: arr[0]
2772
+ elementPath = objectPath.withElement(
2773
+ parseInt(unwrappedNode.argumentExpression.text, 10),
2774
+ );
2775
+ } else if (ts.isStringLiteral(unwrappedNode.argumentExpression)) {
2776
+ // String key: obj['prop']
2777
+ elementPath = objectPath.withProperty(
2778
+ unwrappedNode.argumentExpression.text,
2779
+ );
2780
+ } else {
2781
+ // Dynamic access: obj[key]
2782
+ // Use a representation of the argument or fallback to wildcard
2783
+ const argText = unwrappedNode.argumentExpression.getText(
2784
+ context.sourceFile,
2785
+ );
2786
+ elementPath = objectPath.withElement(argText || '*');
2787
+ }
2788
+
2789
+ // Infer and register type
2790
+ context.addType(elementPath, inferredNodeType);
2791
+
2792
+ // If targetPath is provided, establish equivalence and register type
2793
+ if (targetPath) {
2794
+ context.addEquivalence(targetPath, elementPath);
2795
+ context.addType(targetPath, inferredNodeType);
2796
+ }
2797
+
2798
+ return true;
2799
+ }
2800
+
2801
+ // Handle Conditional Expression (Ternary): cond ? trueVal : falseVal
2802
+ if (ts.isConditionalExpression(unwrappedNode)) {
2803
+ // Mark variables in the condition as potentially undefined
2804
+ markConditionVariablesAsNullable(unwrappedNode.condition, context);
2805
+
2806
+ // Extract conditional usages for key attribute detection
2807
+ extractConditionalUsage(unwrappedNode.condition, context, 'ternary');
2808
+
2809
+ // Extract conditional effects (setter calls in ternary branches)
2810
+ const knownSetters = findUseStateSetters(context.sourceFile);
2811
+ const effects = extractConditionalEffectsFromTernary(
2812
+ unwrappedNode,
2813
+ context,
2814
+ knownSetters,
2815
+ );
2816
+ for (const effect of effects) {
2817
+ context.addConditionalEffect(effect);
2818
+ }
2819
+
2820
+ // Process all parts recursively
2821
+ processExpression({
2822
+ node: unwrappedNode.condition,
2823
+ context,
2824
+ typeHint: 'boolean | unknown',
2825
+ }); //TODO: could we capture that this is evidence of a boolean type?
2826
+
2827
+ // Process both branches WITH targetPath to establish equivalencies
2828
+ // This is critical for tracing nested properties through ternary assignments
2829
+ // e.g., const items = condition ? arr1 : arr2; items.map(i => i.prop)
2830
+ // We need items to be equivalent to both arr1 AND arr2 for proper tracing
2831
+ processExpression({ node: unwrappedNode.whenTrue, context, targetPath });
2832
+ processExpression({ node: unwrappedNode.whenFalse, context, targetPath });
2833
+
2834
+ // Create a path for the whole expression
2835
+ const expressionSourcePath = nodeToSource(
2836
+ unwrappedNode,
2837
+ context.sourceFile,
2838
+ );
2839
+
2840
+ // Infer type based on branches
2841
+ const trueType = context.inferTypeFromNode(unwrappedNode.whenTrue);
2842
+ const falseType = context.inferTypeFromNode(unwrappedNode.whenFalse);
2843
+
2844
+ // Determine the result type
2845
+ let resultType = leftOrRightType(falseType, trueType);
2846
+ if (!resultType) {
2847
+ // If we can't determine a specific type, use unknown without marking as semantic limitation
2848
+ // This prevents conditional expressions from marking the analysis as incomplete
2849
+ resultType = 'unknown';
2850
+ }
2851
+
2852
+ // Register type for the expression
2853
+ context.addType(expressionSourcePath, resultType);
2854
+
2855
+ // If targetPath is provided, only register type (don't overwrite branch equivalencies)
2856
+ // The equivalencies to individual branches (set above) are more useful for tracing
2857
+ // than an equivalency to the entire ternary expression text
2858
+ if (targetPath) {
2859
+ // NOTE: We intentionally do NOT add equivalence here.
2860
+ // The branch processing above already added equivalencies:
2861
+ // targetPath -> whenTrue branch
2862
+ // targetPath -> whenFalse branch
2863
+ // Adding an equivalence to expressionSourcePath would overwrite those
2864
+ // with a useless equivalence to the ternary text itself.
2865
+ //
2866
+ // Use updateSchemaType instead of addType because:
2867
+ // 1. Branch processing may have already set a type on targetPath
2868
+ // 2. addType has a guard that prevents overwriting specific types with 'unknown'
2869
+ // 3. updateSchemaType bypasses this guard, ensuring the ternary's computed type is used
2870
+ context.updateSchemaType(targetPath, resultType);
2871
+ }
2872
+
2873
+ return true;
2874
+ }
2875
+
2876
+ // Handle New Expression: new Date(), new MyClass()
2877
+ if (ts.isNewExpression(unwrappedNode)) {
2878
+ // Process the constructor expression
2879
+ const constructorProcessed = processExpression({
2880
+ node: unwrappedNode.expression,
2881
+ context,
2882
+ });
2883
+
2884
+ if (!constructorProcessed) {
2885
+ context.markUnsupported(
2886
+ unwrappedNode.expression,
2887
+ `processExpression: Unsupported constructor expression: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
2888
+ false,
2889
+ );
2890
+ return false;
2891
+ }
2892
+
2893
+ // Get a path for the constructor
2894
+ const constructorPath = StructuredPath.fromNode(
2895
+ unwrappedNode.expression,
2896
+ context.sourceFile,
2897
+ );
2898
+
2899
+ if (!constructorPath) {
2900
+ return false;
2901
+ }
2902
+
2903
+ // Process any arguments
2904
+ if (unwrappedNode.arguments) {
2905
+ for (const arg of unwrappedNode.arguments) {
2906
+ processExpression({ node: arg, context });
2907
+ }
2908
+ }
2909
+
2910
+ // Create argument paths for the function call
2911
+ const validArgPaths: StructuredPath[] = unwrappedNode.arguments
2912
+ ? unwrappedNode.arguments.map(
2913
+ (arg) =>
2914
+ StructuredPath.fromNode(arg, context.sourceFile) ??
2915
+ nodeToSource(arg, context.sourceFile) ??
2916
+ StructuredPath.literal('unknown'),
2917
+ )
2918
+ : [];
2919
+
2920
+ // Construct a path for the new expression
2921
+ const newCallPath = constructorPath.withFunctionCall(validArgPaths);
2922
+
2923
+ // Infer result type
2924
+ let resultType = 'object';
2925
+ if (ts.isIdentifier(unwrappedNode.expression)) {
2926
+ const constructorName = unwrappedNode.expression.text;
2927
+ if (
2928
+ ['String', 'Number', 'Boolean', 'Array', 'Date'].includes(
2929
+ constructorName,
2930
+ )
2931
+ ) {
2932
+ resultType = constructorName.toLowerCase();
2933
+ }
2934
+ } else {
2935
+ resultType = inferredNodeType;
2936
+ }
2937
+
2938
+ // Register types
2939
+ context.addType(newCallPath, resultType);
2940
+ context.addType(constructorPath, 'function');
2941
+
2942
+ // If targetPath is provided, establish equivalence and register type
2943
+ if (targetPath) {
2944
+ context.addEquivalence(targetPath, newCallPath);
2945
+ context.addType(targetPath, resultType);
2946
+ }
2947
+
2948
+ return true;
2949
+ }
2950
+
2951
+ // Handle Arrow Functions: (p) => p.prop, (a, b) => { ... }
2952
+ if (ts.isArrowFunction(unwrappedNode)) {
2953
+ // If this arrow function is a child boundary (e.g., a .map() callback),
2954
+ // don't process its parameters here - they will be processed when the
2955
+ // child scope is analyzed separately. This prevents parameter variables
2956
+ // from leaking into the parent scope's equivalencies.
2957
+ // Check if this arrow function is a child boundary (i.e., should be processed
2958
+ // as a separate child scope, not here in the parent scope).
2959
+ //
2960
+ // We use two checks because childBoundary positions can be unreliable:
2961
+ // 1. Position-based check (standard isChildBoundary)
2962
+ // 2. Text-based check: if the arrow function text doesn't appear in the
2963
+ // statement text, it was replaced with a cyScope placeholder
2964
+ const isChildBoundary = context.isChildBoundary(unwrappedNode);
2965
+
2966
+ // Text-based child scope detection for when positions are unreliable
2967
+ const arrowFnText = unwrappedNode.getText(context.sourceFile);
2968
+ const firstLine = arrowFnText.split('\n')[0].trim();
2969
+ const searchText = firstLine.substring(0, Math.min(20, firstLine.length));
2970
+ const isInStatementText = context.statementInfo.text.includes(searchText);
2971
+ const isChildScope = !isInStatementText && arrowFnText.length > 10;
2972
+
2973
+ if (isChildBoundary || isChildScope) {
2974
+ // The method semantics (e.g., ArrayMapSemantics) have already established
2975
+ // the necessary equivalences between the child scope placeholder and array elements
2976
+ if (targetPath) {
2977
+ context.addType(targetPath, 'function');
2978
+ }
2979
+ return true;
2980
+ }
2981
+
2982
+ // Create a path for the function
2983
+ const functionPath = StructuredPath.empty();
2984
+
2985
+ // Process parameters
2986
+ unwrappedNode.parameters.forEach((param, index) => {
2987
+ const signaturePath = functionPath.withParameter(index);
2988
+ if (ts.isIdentifier(param.name)) {
2989
+ const paramNamePath = StructuredPath.fromBase(param.name.text);
2990
+
2991
+ // Establish equivalence between parameter name and signature path
2992
+ context.addEquivalence(paramNamePath, signaturePath);
2993
+
2994
+ // Register types
2995
+ const paramType = context.inferTypeFromNode(param) || 'unknown';
2996
+ context.addType(paramNamePath, paramType);
2997
+ context.addType(signaturePath, paramType);
2998
+ } else if (
2999
+ ts.isObjectBindingPattern(param.name) ||
3000
+ ts.isArrayBindingPattern(param.name)
3001
+ ) {
3002
+ const success = processBindingPattern(
3003
+ param.name,
3004
+ signaturePath,
3005
+ context,
3006
+ );
3007
+ if (!success) {
3008
+ context.markUnsupported(
3009
+ param,
3010
+ `processExpression: Failed to process binding pattern: ${ts.SyntaxKind[param.kind]}`,
3011
+ false,
3012
+ );
3013
+ }
3014
+ } else {
3015
+ context.markUnsupported(
3016
+ param,
3017
+ `processExpression: Unsupported parameter kind in ArrowFunction: ${ts.SyntaxKind[param.kind]}`,
3018
+ false,
3019
+ );
3020
+ }
3021
+ });
3022
+
3023
+ // Process function body
3024
+ const body = unwrappedNode.body;
3025
+ if (ts.isBlock(body)) {
3026
+ // For block bodies, process the statements inside
3027
+ context.processNode(body);
3028
+ } else {
3029
+ // For expression bodies, process as implicit return
3030
+ const returnPath = functionPath.withProperty('returnValue');
3031
+ processExpression({ node: body, context, targetPath: returnPath });
3032
+ }
3033
+
3034
+ // If targetPath is provided, establish equivalence
3035
+ if (targetPath) {
3036
+ context.addEquivalence(targetPath, functionPath);
3037
+ context.addType(targetPath, 'function');
3038
+ }
3039
+
3040
+ return true;
3041
+ }
3042
+
3043
+ // Handle Tagged Template Expressions: sql`SELECT * FROM ${table}`
3044
+ if (ts.isTaggedTemplateExpression(unwrappedNode)) {
3045
+ // Process the tag expression (e.g., 'sql', 'css', 'gql')
3046
+ const tagProcessed = processExpression({
3047
+ node: unwrappedNode.tag,
3048
+ context,
3049
+ });
3050
+
3051
+ if (!tagProcessed) {
3052
+ context.markUnsupported(
3053
+ unwrappedNode.tag,
3054
+ `processExpression: Unsupported tag expression in tagged template: ${ts.SyntaxKind[unwrappedNode.tag.kind]}`,
3055
+ false,
3056
+ );
3057
+ return false;
3058
+ }
3059
+
3060
+ // Get a path for the tag
3061
+ const tagPath = StructuredPath.fromNode(
3062
+ unwrappedNode.tag,
3063
+ context.sourceFile,
3064
+ );
3065
+
3066
+ if (tagPath) {
3067
+ // Mark the tag as a function
3068
+ context.addType(tagPath, 'function');
3069
+ }
3070
+
3071
+ // Process the template part (reusing existing template processing logic)
3072
+ const template = unwrappedNode.template;
3073
+ let allSpansProcessed = true;
3074
+
3075
+ if (ts.isTemplateExpression(template)) {
3076
+ // Process all template spans (interpolations)
3077
+ for (const span of template.templateSpans) {
3078
+ if (context.isChildBoundary(span.expression)) {
3079
+ continue;
3080
+ }
3081
+
3082
+ const spanProcessed = processExpression({
3083
+ node: span.expression,
3084
+ context,
3085
+ targetPath: StructuredPath.empty(),
3086
+ });
3087
+
3088
+ allSpansProcessed = allSpansProcessed && spanProcessed;
3089
+ }
3090
+ }
3091
+ // If it's NoSubstitutionTemplateLiteral, nothing more to process
3092
+
3093
+ // Create a path for the entire tagged template expression
3094
+ const taggedTemplatePath = StructuredPath.fromNode(
3095
+ unwrappedNode,
3096
+ context.sourceFile,
3097
+ );
3098
+
3099
+ // The return type of a tagged template is unknown (depends on the tag function)
3100
+ context.addType(taggedTemplatePath, 'unknown');
3101
+
3102
+ // If targetPath is provided, establish equivalence
3103
+ if (targetPath) {
3104
+ context.addEquivalence(targetPath, taggedTemplatePath);
3105
+ context.addType(targetPath, 'unknown');
3106
+ }
3107
+
3108
+ // If we didn't fully handle all spans, mark as semantic limitation
3109
+ if (!allSpansProcessed && ts.isTemplateExpression(template)) {
3110
+ context.markSemanticLimitation(
3111
+ unwrappedNode,
3112
+ 'Tagged template contains complex expressions that may not be fully analyzed',
3113
+ );
3114
+ }
3115
+
3116
+ return true;
3117
+ }
3118
+
3119
+ // Handle Template Literals: `Hello ${name}` or `Simple`
3120
+ if (
3121
+ ts.isTemplateExpression(unwrappedNode) ||
3122
+ ts.isNoSubstitutionTemplateLiteral(unwrappedNode)
3123
+ ) {
3124
+ // Create a path for the template literal
3125
+ const templatePath = StructuredPath.createLiteralPath(
3126
+ unwrappedNode.getText(context.sourceFile),
3127
+ 'string',
3128
+ );
3129
+
3130
+ // Track if we can fully handle all expressions in the template
3131
+ let allSpansProcessed = true;
3132
+
3133
+ // Process template spans if any by recursing back into processExpression
3134
+ if (ts.isTemplateExpression(unwrappedNode)) {
3135
+ for (const span of unwrappedNode.templateSpans) {
3136
+ if (context.isChildBoundary(span.expression)) {
3137
+ continue;
3138
+ }
3139
+
3140
+ // Process each span with StructuredPath.empty() as targetPath
3141
+ // This ensures types and equivalences are established without imposing
3142
+ // a prefix that wouldn't make sense in a template context
3143
+ const spanProcessed = processExpression({
3144
+ node: span.expression,
3145
+ context,
3146
+ targetPath: StructuredPath.empty(), // Use empty path to trigger equivalence and type registration
3147
+ });
3148
+
3149
+ allSpansProcessed = allSpansProcessed && spanProcessed;
3150
+ }
3151
+ }
3152
+
3153
+ // Template expressions are always strings
3154
+ context.addType(templatePath, 'string');
3155
+
3156
+ // Register the type with targetPath if provided
3157
+ if (targetPath) {
3158
+ context.addEquivalence(targetPath, templatePath);
3159
+ context.addType(targetPath, 'string');
3160
+ }
3161
+
3162
+ // If we didn't fully handle all spans, still return true but with limitations noted
3163
+ if (!allSpansProcessed && ts.isTemplateExpression(unwrappedNode)) {
3164
+ context.markSemanticLimitation(
3165
+ unwrappedNode,
3166
+ 'Template literal contains complex expressions that may not be fully analyzed',
3167
+ );
3168
+ }
3169
+
3170
+ return true;
3171
+ }
3172
+
3173
+ // Handle TypeOf Expression: typeof x
3174
+ if (ts.isTypeOfExpression(unwrappedNode)) {
3175
+ // Process the inner expression
3176
+ processExpression({ node: unwrappedNode.expression, context });
3177
+
3178
+ // Create a path for the typeof expression
3179
+ const typeofPath = StructuredPath.createLiteralPath(
3180
+ unwrappedNode.getText(context.sourceFile),
3181
+ 'string',
3182
+ );
3183
+
3184
+ // Register the type (always string)
3185
+ if (targetPath) {
3186
+ context.addEquivalence(targetPath, typeofPath);
3187
+ context.addType(targetPath, 'string');
3188
+ }
3189
+
3190
+ return true;
3191
+ }
3192
+
3193
+ // Handle Void Expression: void x, void 0, void func()
3194
+ if (ts.isVoidExpression(unwrappedNode)) {
3195
+ // Process the inner expression for side effects
3196
+ processExpression({ node: unwrappedNode.expression, context });
3197
+
3198
+ // void always returns undefined
3199
+ if (targetPath) {
3200
+ const voidPath = StructuredPath.createLiteralPath(
3201
+ 'undefined',
3202
+ 'undefined',
3203
+ );
3204
+ context.addEquivalence(targetPath, voidPath);
3205
+ context.addType(targetPath, 'undefined');
3206
+ }
3207
+
3208
+ return true;
3209
+ }
3210
+
3211
+ // Handle Prefix Unary Expressions: ++x, --y, !z, -a
3212
+ if (ts.isPrefixUnaryExpression(unwrappedNode)) {
3213
+ // Process the operand
3214
+ const operandProcessed = processExpression({
3215
+ node: unwrappedNode.operand,
3216
+ context,
3217
+ });
3218
+
3219
+ if (!operandProcessed) {
3220
+ context.markUnsupported(
3221
+ unwrappedNode.operand,
3222
+ `processExpression: Could not process operand of PrefixUnaryExpression: ${ts.SyntaxKind[unwrappedNode.operand.kind]}`,
3223
+ false,
3224
+ );
3225
+ return false;
3226
+ }
3227
+
3228
+ // Get a path for the operand
3229
+ const operandPath = StructuredPath.fromNode(
3230
+ unwrappedNode.operand,
3231
+ context.sourceFile,
3232
+ );
3233
+
3234
+ if (!operandPath) {
3235
+ return false;
3236
+ }
3237
+
3238
+ // Determine the result type based on operator
3239
+ const operatorKind = unwrappedNode.operator;
3240
+ let resultType = 'unknown';
3241
+
3242
+ if (
3243
+ operatorKind === ts.SyntaxKind.PlusPlusToken ||
3244
+ operatorKind === ts.SyntaxKind.MinusMinusToken
3245
+ ) {
3246
+ resultType = 'number';
3247
+ } else if (operatorKind === ts.SyntaxKind.ExclamationToken) {
3248
+ resultType = 'boolean | unknown';
3249
+ } else if (
3250
+ operatorKind === ts.SyntaxKind.MinusToken ||
3251
+ operatorKind === ts.SyntaxKind.PlusToken ||
3252
+ operatorKind === ts.SyntaxKind.TildeToken
3253
+ ) {
3254
+ resultType = 'number';
3255
+ } else {
3256
+ context.markUnsupported(
3257
+ unwrappedNode,
3258
+ `processExpression: Unsupported prefix unary operator: ${ts.SyntaxKind[operatorKind]}`,
3259
+ false,
3260
+ );
3261
+ }
3262
+
3263
+ // Register the operand's type (which is also the result)
3264
+ context.addType(operandPath, resultType);
3265
+
3266
+ // If targetPath is provided, establish equivalence and register type
3267
+ if (targetPath) {
3268
+ context.addEquivalence(targetPath, operandPath);
3269
+ context.addType(targetPath, resultType);
3270
+ }
3271
+
3272
+ return true;
3273
+ }
3274
+
3275
+ // Handle Postfix Unary Expressions: x++, y--, etc.
3276
+ if (ts.isPostfixUnaryExpression(unwrappedNode)) {
3277
+ // Process the operand
3278
+ const operandProcessed = processExpression({
3279
+ node: unwrappedNode.operand,
3280
+ context,
3281
+ });
3282
+
3283
+ if (!operandProcessed) {
3284
+ context.markUnsupported(
3285
+ unwrappedNode.operand,
3286
+ `processExpression: Could not process operand of PostfixUnaryExpression: ${ts.SyntaxKind[unwrappedNode.operand.kind]}`,
3287
+ false,
3288
+ );
3289
+ return false;
3290
+ }
3291
+
3292
+ // Get a path for the operand
3293
+ const operandPath = StructuredPath.fromNode(
3294
+ unwrappedNode.operand,
3295
+ context.sourceFile,
3296
+ );
3297
+
3298
+ if (!operandPath) {
3299
+ return false;
3300
+ }
3301
+
3302
+ // Determine the result type based on operator
3303
+ const operatorKind = unwrappedNode.operator;
3304
+ let resultType = 'unknown';
3305
+
3306
+ // Currently postfix expressions only support ++ and -- operators
3307
+ if (
3308
+ operatorKind === ts.SyntaxKind.PlusPlusToken ||
3309
+ operatorKind === ts.SyntaxKind.MinusMinusToken
3310
+ ) {
3311
+ resultType = 'number';
3312
+
3313
+ // Register the operand as a number
3314
+ context.addType(operandPath, resultType);
3315
+
3316
+ // If it's a property access like user.age, add type for parent object
3317
+ if (ts.isPropertyAccessExpression(unwrappedNode.operand)) {
3318
+ const objectPath = StructuredPath.fromNode(
3319
+ unwrappedNode.operand.expression,
3320
+ context.sourceFile,
3321
+ );
3322
+ if (objectPath) {
3323
+ context.addType(objectPath, 'object');
3324
+ }
3325
+ }
3326
+ } else {
3327
+ // Should never reach here (postfix only has ++ and --) but handle just in case
3328
+ context.markUnsupported(
3329
+ unwrappedNode,
3330
+ `processExpression: Unsupported postfix unary operator: ${ts.SyntaxKind[operatorKind]}`,
3331
+ false, // Non-blocking
3332
+ );
3333
+ return false;
3334
+ }
3335
+
3336
+ // If targetPath is provided, establish equivalence and register type
3337
+ if (targetPath) {
3338
+ context.addEquivalence(targetPath, operandPath);
3339
+ context.addType(targetPath, resultType);
3340
+ }
3341
+
3342
+ return true;
3343
+ }
3344
+
3345
+ // Handle JSX Elements (both normal and self-closing)
3346
+ if (
3347
+ ts.isJsxElement(unwrappedNode) ||
3348
+ ts.isJsxSelfClosingElement(unwrappedNode)
3349
+ ) {
3350
+ let openingElement: ts.JsxOpeningElement | ts.JsxSelfClosingElement;
3351
+
3352
+ if (ts.isJsxElement(unwrappedNode)) {
3353
+ openingElement = unwrappedNode.openingElement;
3354
+ } else {
3355
+ openingElement = unwrappedNode;
3356
+ }
3357
+
3358
+ // Extract the component/tag name
3359
+ const tagName = getJsxTagName(openingElement.tagName, context);
3360
+ if (!tagName) {
3361
+ context.markUnsupported(
3362
+ unwrappedNode,
3363
+ 'Unable to determine JSX element name',
3364
+ false,
3365
+ );
3366
+ return false;
3367
+ }
3368
+
3369
+ // Create a path for the component as a function call
3370
+ const componentPath = StructuredPath.fromFunction(tagName);
3371
+
3372
+ // Process each attribute
3373
+ let allAttributesHandled = true;
3374
+ for (const attr of openingElement.attributes.properties) {
3375
+ if (ts.isJsxAttribute(attr)) {
3376
+ // Process JSX attribute with component path as context
3377
+ const attrHandled = processJsxAttribute(
3378
+ attr,
3379
+ context,
3380
+ componentPath,
3381
+ targetPath,
3382
+ );
3383
+ allAttributesHandled = allAttributesHandled && attrHandled;
3384
+ } else if (ts.isJsxSpreadAttribute(attr)) {
3385
+ // Process JSX spread attribute (e.g., <Comp {...props} />)
3386
+ if (attr.expression) {
3387
+ // Process the spread expression
3388
+ const parameterPath = componentPath.withParameter(0);
3389
+ const spreadProcessed = processExpression({
3390
+ node: attr.expression,
3391
+ context,
3392
+ targetPath: parameterPath,
3393
+ });
3394
+ if (!spreadProcessed) {
3395
+ context.markUnsupported(
3396
+ attr.expression,
3397
+ `processExpression: Unsupported spread expression: ${ts.SyntaxKind[attr.expression.kind]}`,
3398
+ false,
3399
+ );
3400
+ }
3401
+
3402
+ allAttributesHandled = allAttributesHandled && spreadProcessed;
3403
+ }
3404
+ }
3405
+ }
3406
+
3407
+ // Process children for JSX elements (not self-closing)
3408
+ if (ts.isJsxElement(unwrappedNode)) {
3409
+ for (const child of unwrappedNode.children) {
3410
+ // Process expressions in JSX children: <div>{expr}</div>
3411
+ if (ts.isJsxExpression(child) && child.expression) {
3412
+ // When processing return value JSX, link root variables to return value schema
3413
+ if (targetPath && targetPath.base !== '') {
3414
+ const varNames = [
3415
+ ...new Set(extractRootVariableNames(child.expression)),
3416
+ ];
3417
+ for (const varName of varNames) {
3418
+ context.addEquivalence(
3419
+ targetPath.withProperty(varName),
3420
+ StructuredPath.fromBase(varName),
3421
+ );
3422
+ }
3423
+ }
3424
+
3425
+ // Process the expression with StructuredPath.empty() as targetPath
3426
+ // to trigger type registration without imposing prefix
3427
+ processExpression({
3428
+ node: child.expression,
3429
+ context,
3430
+ targetPath: StructuredPath.empty(),
3431
+ });
3432
+ }
3433
+ // Process nested JSX elements recursively
3434
+ else if (ts.isJsxElement(child) || ts.isJsxSelfClosingElement(child)) {
3435
+ processExpression({ node: child, context });
3436
+ }
3437
+ }
3438
+ }
3439
+
3440
+ // Register component as 'jsx-component' type to distinguish from regular function calls
3441
+ // This allows downstream code to identify JSX components and not treat them as method chains
3442
+ context.addType(componentPath, 'jsx-component');
3443
+
3444
+ // If targetPath is provided (e.g., in variable assignment), establish equivalence to hardcoded "JSX"
3445
+ if (targetPath) {
3446
+ context.addEquivalence(targetPath, StructuredPath.literal('JSX'));
3447
+ // Don't register a type for targetPath
3448
+ }
3449
+
3450
+ return allAttributesHandled;
3451
+ }
3452
+
3453
+ // Handle JSX Fragments (<>...</>)
3454
+ if (ts.isJsxFragment(unwrappedNode)) {
3455
+ // Process children
3456
+ for (const child of unwrappedNode.children) {
3457
+ // Process expressions in JSX children: <>{expr}</>
3458
+ if (ts.isJsxExpression(child) && child.expression) {
3459
+ // When processing return value JSX, link root variables to return value schema
3460
+ if (targetPath && targetPath.base !== '') {
3461
+ const varNames = [
3462
+ ...new Set(extractRootVariableNames(child.expression)),
3463
+ ];
3464
+ for (const varName of varNames) {
3465
+ context.addEquivalence(
3466
+ targetPath.withProperty(varName),
3467
+ StructuredPath.fromBase(varName),
3468
+ );
3469
+ }
3470
+ }
3471
+
3472
+ // Process the expression to extract structure
3473
+ processExpression({
3474
+ node: child.expression,
3475
+ context,
3476
+ targetPath: StructuredPath.empty(),
3477
+ });
3478
+ }
3479
+ // Process nested JSX elements recursively
3480
+ else if (ts.isJsxElement(child) || ts.isJsxSelfClosingElement(child)) {
3481
+ processExpression({ node: child, context });
3482
+ }
3483
+ // Process nested fragments recursively
3484
+ else if (ts.isJsxFragment(child)) {
3485
+ processExpression({ node: child, context });
3486
+ }
3487
+ // Process JsxText (for completeness)
3488
+ else if (ts.isJsxText(child)) {
3489
+ // JsxText nodes are just string literals, no additional processing needed
3490
+ // But we record them for completeness
3491
+ }
3492
+ }
3493
+
3494
+ // If targetPath is provided, establish equivalence to hardcoded "JSX"
3495
+ if (targetPath) {
3496
+ context.addEquivalence(targetPath, StructuredPath.literal('JSX'));
3497
+ // Don't register a type for targetPath
3498
+ }
3499
+
3500
+ return true;
3501
+ }
3502
+
3503
+ if (
3504
+ ts.isJsxOpeningElement(unwrappedNode) ||
3505
+ ts.isJsxOpeningFragment(unwrappedNode)
3506
+ ) {
3507
+ if (unwrappedNode.parent) {
3508
+ return processExpression({
3509
+ node: unwrappedNode.parent,
3510
+ context,
3511
+ targetPath,
3512
+ });
3513
+ }
3514
+ // Fallback: shouldn't normally happen, but handle gracefully
3515
+ return true;
3516
+ }
3517
+
3518
+ if (
3519
+ ts.isJsxClosingElement(unwrappedNode) ||
3520
+ ts.isJsxClosingFragment(unwrappedNode)
3521
+ ) {
3522
+ // Closing elements/fragments don't carry additional information
3523
+ return true;
3524
+ }
3525
+
3526
+ // Handle standalone JsxExpression (e.g., {expr} in JSX context)
3527
+ if (ts.isJsxExpression(unwrappedNode)) {
3528
+ if (unwrappedNode.expression) {
3529
+ // Process the inner expression
3530
+ return processExpression({
3531
+ node: unwrappedNode.expression,
3532
+ context,
3533
+ targetPath,
3534
+ });
3535
+ }
3536
+ // If there's no expression, we can just return true
3537
+ return true;
3538
+ }
3539
+
3540
+ // Handle JsxText (text content inside JSX elements)
3541
+ if (ts.isJsxText(unwrappedNode)) {
3542
+ // JsxText is just string content in JSX, typically doesn't need
3543
+ // complex analysis, but we mark it as handled
3544
+
3545
+ // If the text is non-whitespace and targetPath is provided,
3546
+ // we could establish a string literal equivalence
3547
+ const text = unwrappedNode.getText(context.sourceFile).trim();
3548
+ if (text && targetPath) {
3549
+ const literalPath = StructuredPath.createLiteralPath(
3550
+ `"${text}"`,
3551
+ 'string',
3552
+ );
3553
+ context.addEquivalence(targetPath, literalPath);
3554
+ context.addType(targetPath, 'string');
3555
+ }
3556
+
3557
+ return true;
3558
+ }
3559
+
3560
+ // Handle Spread Element: ...obj, ...arr
3561
+ if (ts.isSpreadElement(unwrappedNode)) {
3562
+ // Process the expression being spread
3563
+ const spreadExprProcessed = processExpression({
3564
+ node: unwrappedNode.expression,
3565
+ context,
3566
+ });
3567
+
3568
+ if (!spreadExprProcessed) {
3569
+ context.markUnsupported(
3570
+ unwrappedNode.expression,
3571
+ `processExpression: Unsupported expression in spread element: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
3572
+ false,
3573
+ );
3574
+ return false;
3575
+ }
3576
+
3577
+ // Get a path for the spread expression
3578
+ const spreadExprPath = StructuredPath.fromNode(
3579
+ unwrappedNode.expression,
3580
+ context.sourceFile,
3581
+ );
3582
+
3583
+ if (!spreadExprPath) {
3584
+ context.markUnsupported(
3585
+ unwrappedNode.expression,
3586
+ `processExpression: Couldn't get path for spread element expression`,
3587
+ false,
3588
+ );
3589
+ return false;
3590
+ }
3591
+
3592
+ // Create a path for the spread element itself
3593
+ const spreadPath = StructuredPath.fromBase(
3594
+ `...${unwrappedNode.expression.getText(context.sourceFile)}`,
3595
+ );
3596
+
3597
+ // If targetPath is provided, establish equivalence
3598
+ if (targetPath) {
3599
+ context.addEquivalence(targetPath, spreadPath);
3600
+
3601
+ // We don't know the exact type of the spread result as it depends on context
3602
+ // (object spread vs array spread), so we use the same type as the expression
3603
+ const spreadType = context.getTypeInfo(spreadExprPath) || 'unknown';
3604
+ context.addType(targetPath, spreadType);
3605
+ }
3606
+
3607
+ return true;
3608
+ }
3609
+ if (ts.isDeleteExpression(unwrappedNode)) {
3610
+ // first just process whatever is being deleted
3611
+ const result = processExpression({
3612
+ node: unwrappedNode.expression,
3613
+ context,
3614
+ });
3615
+ if (!result) {
3616
+ context.markUnsupported(
3617
+ unwrappedNode.expression,
3618
+ `processExpression: Unsupported expression in delete: ${ts.SyntaxKind[unwrappedNode.expression.kind]}`,
3619
+ false,
3620
+ );
3621
+ return false;
3622
+ }
3623
+
3624
+ nodePath = StructuredPath.fromNode(unwrappedNode, context.sourceFile);
3625
+ // 'delete' is boolean typed
3626
+ context.addType(nodePath, 'boolean');
3627
+
3628
+ if (targetPath) {
3629
+ context.addEquivalence(targetPath, nodePath);
3630
+ context.addType(targetPath, 'boolean');
3631
+ }
3632
+ return result;
3633
+ }
3634
+
3635
+ // Handle yield expressions in generator functions
3636
+ if (ts.isYieldExpression(unwrappedNode)) {
3637
+ // yield returns whatever is yielded, or undefined if no expression
3638
+ if (unwrappedNode.expression) {
3639
+ // Process the yielded expression
3640
+ const result = processExpression({
3641
+ node: unwrappedNode.expression,
3642
+ context,
3643
+ targetPath,
3644
+ });
3645
+ return result;
3646
+ }
3647
+ // yield with no expression returns undefined
3648
+ if (targetPath) {
3649
+ context.addType(targetPath, 'undefined');
3650
+ }
3651
+ return true;
3652
+ }
3653
+
3654
+ if (ts.isRegularExpressionLiteral(unwrappedNode)) {
3655
+ // Regular expressions are treated as string literals
3656
+ const regexPath = StructuredPath.createLiteralPath(
3657
+ unwrappedNode.getText(context.sourceFile),
3658
+ 'string',
3659
+ );
3660
+ context.addType(regexPath, 'string');
3661
+
3662
+ // If targetPath is provided, establish equivalence
3663
+ if (targetPath) {
3664
+ context.addEquivalence(targetPath, regexPath);
3665
+ context.addType(targetPath, 'string');
3666
+ }
3667
+
3668
+ return true;
3669
+ }
3670
+
3671
+ console.warn(
3672
+ `processExpression: Unsupported expression kind: ${ts.SyntaxKind[unwrappedNode.kind]}`,
3673
+ {
3674
+ nodeText: node.getText(context.sourceFile),
3675
+ statementName: context.statementInfo.name,
3676
+ statementText: context.statementInfo.text,
3677
+ },
3678
+ );
3679
+
3680
+ // For now, mark other types as unsupported and return false
3681
+ context.markUnsupported(
3682
+ unwrappedNode,
3683
+ `processExpression: Unsupported expression kind: ${ts.SyntaxKind[unwrappedNode.kind]}`,
3684
+ false, // Non-blocking for now
3685
+ );
3686
+ return false;
3687
+ }
3688
+
3689
+ /**
3690
+ * Helper function to process a JSX attribute
3691
+ */
3692
+ function processJsxAttribute(
3693
+ attr: ts.JsxAttribute,
3694
+ context: AnalysisContext,
3695
+ componentPath: StructuredPath,
3696
+ targetPath?: StructuredPath,
3697
+ ): boolean {
3698
+ // JSX attribute names can be either simple identifiers or namespace names
3699
+ const attrName = ts.isIdentifier(attr.name)
3700
+ ? attr.name.text
3701
+ : attr.name.name.text;
3702
+
3703
+ // Skip attributes with no initializer (boolean props)
3704
+ if (!attr.initializer) {
3705
+ return true;
3706
+ }
3707
+
3708
+ // Create path for this attribute: Component.signature[0].attributeName
3709
+ const attributePath = componentPath.withParameter(0).withProperty(attrName);
3710
+
3711
+ // For string literals: <Component attr="value" />
3712
+ if (ts.isStringLiteral(attr.initializer)) {
3713
+ const literalPath = StructuredPath.createLiteralPath(
3714
+ `"${attr.initializer.text}"`,
3715
+ 'string',
3716
+ );
3717
+ context.addEquivalence(attributePath, literalPath);
3718
+ context.addType(attributePath, 'string');
3719
+ return true;
3720
+ }
3721
+
3722
+ // For expressions: <Component attr={value} />
3723
+ if (ts.isJsxExpression(attr.initializer) && attr.initializer.expression) {
3724
+ const expression = attr.initializer.expression;
3725
+ if (context.isChildBoundary(expression)) {
3726
+ // Create equivalency between attribute path and child scope
3727
+ // e.g., Grid().signature[0].renderRow → cyScope1()
3728
+ context.addChildBoundaryEquivalence(attributePath, expression);
3729
+ return true;
3730
+ }
3731
+
3732
+ // Process the expression with attributePath as targetPath
3733
+ // This will establish all equivalences and types automatically
3734
+ return processExpression({
3735
+ node: expression,
3736
+ context,
3737
+ targetPath: attributePath,
3738
+ });
3739
+ }
3740
+
3741
+ // Mark as unsupported if we couldn't handle the attribute
3742
+ context.markUnsupported(
3743
+ attr,
3744
+ `Unsupported JSX attribute initializer: ${attr.initializer?.kind ? ts.SyntaxKind[attr.initializer.kind] : 'undefined'}`,
3745
+ false,
3746
+ );
3747
+ return false;
3748
+ }
3749
+
3750
+ /**
3751
+ * Helper function to get a string representation of a JSX tag name
3752
+ */
3753
+ function getJsxTagName(
3754
+ tagNameNode: ts.JsxTagNameExpression,
3755
+ context: AnalysisContext,
3756
+ ): string {
3757
+ if (ts.isIdentifier(tagNameNode)) {
3758
+ return tagNameNode.text;
3759
+ } else if (ts.isPropertyAccessExpression(tagNameNode)) {
3760
+ const objName = getJsxTagName(tagNameNode.expression, context);
3761
+ return objName ? `${objName}.${tagNameNode.name.text}` : '';
3762
+ } else if ((tagNameNode as any).namespace) {
3763
+ // Handle namespaced names like <ns:elem />
3764
+ const jsxNamespacedName = tagNameNode as any;
3765
+ return `${jsxNamespacedName.namespace.text}:${jsxNamespacedName.name.text}`;
3766
+ }
3767
+
3768
+ return '';
3769
+ }