@codeyam/codeyam-cli 0.1.0-staging.ad31e3e → 0.1.0-staging.ad44cd3

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 (2667) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/common/execAsync.ts +2 -2
  3. package/analyzer-template/log.txt +3 -3
  4. package/analyzer-template/package.json +39 -35
  5. package/analyzer-template/packages/ai/index.ts +25 -6
  6. package/analyzer-template/packages/ai/package.json +5 -5
  7. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
  8. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +256 -14
  9. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +273 -27
  11. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  12. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +232 -23
  13. package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +14 -1
  14. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  15. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
  16. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +48 -2
  17. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
  18. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1721 -150
  19. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  20. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +328 -5
  21. package/analyzer-template/packages/ai/src/lib/checkAllAttributes.ts +29 -10
  22. package/analyzer-template/packages/ai/src/lib/completionCall.ts +247 -66
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +2953 -268
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.ts +37 -7
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +21 -4
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +976 -0
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +249 -81
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +71 -2
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +229 -21
  32. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  33. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  34. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +166 -17
  35. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
  36. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  37. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  38. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +441 -82
  39. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  40. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.ts +33 -3
  41. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  42. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -0
  43. package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
  44. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  45. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  46. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +80 -10
  47. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +90 -111
  48. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +70 -7
  49. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1497 -78
  50. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +216 -109
  51. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +677 -0
  52. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  53. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  54. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  55. package/analyzer-template/packages/ai/src/lib/generateStatementAnalysis.ts +1 -1
  56. package/analyzer-template/packages/ai/src/lib/getConditionalUsagesFromCode.ts +143 -31
  57. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +8 -2
  58. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
  59. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  60. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +135 -7
  61. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  62. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +108 -27
  63. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
  64. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +33 -90
  65. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  66. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  67. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
  68. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -47
  69. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  70. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +28 -2
  71. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  72. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  73. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
  74. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  75. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +133 -3
  76. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +121 -2
  77. package/analyzer-template/packages/analyze/index.ts +2 -0
  78. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +212 -48
  79. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  80. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  81. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  82. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +2 -1
  83. package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +1 -0
  84. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
  85. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  86. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  87. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.ts +4 -2
  88. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +49 -9
  89. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  90. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  91. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  92. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +757 -146
  93. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +63 -2
  94. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +16 -1
  95. package/analyzer-template/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.ts +1 -1
  96. package/analyzer-template/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.ts +1 -1
  97. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +13 -5
  98. package/analyzer-template/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.ts +1 -1
  99. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  100. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +32 -16
  101. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +12 -8
  102. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +12 -13
  103. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +1 -1
  104. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +26 -39
  105. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
  106. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +135 -16
  107. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  108. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +313 -0
  109. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
  110. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +837 -99
  111. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.ts +1 -1
  112. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -62
  113. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +695 -30
  114. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +166 -0
  115. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +78 -79
  116. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +4 -8
  117. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1160 -134
  118. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +61 -6
  119. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  120. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +3 -2
  121. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  122. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  123. package/analyzer-template/packages/aws/codebuild/index.ts +1 -0
  124. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +11 -1
  125. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -1
  126. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +29 -18
  127. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -1
  128. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +2 -2
  129. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -1
  130. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +2 -2
  131. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -1
  132. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +8 -18
  133. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -1
  134. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +17 -61
  135. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -1
  136. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts +15 -0
  137. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts.map +1 -0
  138. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js +31 -0
  139. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js.map +1 -0
  140. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.d.ts.map +1 -1
  141. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.js +2 -2
  142. package/analyzer-template/packages/aws/dist/src/lib/s3/getPresignedUrl.js.map +1 -1
  143. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -1
  144. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +8 -1
  145. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -1
  146. package/analyzer-template/packages/aws/package.json +10 -10
  147. package/analyzer-template/packages/aws/s3/index.ts +1 -0
  148. package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +43 -19
  149. package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +3 -3
  150. package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +17 -69
  151. package/analyzer-template/packages/aws/src/lib/s3/checkS3ObjectExists.ts +47 -0
  152. package/analyzer-template/packages/aws/src/lib/s3/getPresignedUrl.ts +2 -2
  153. package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +8 -1
  154. package/analyzer-template/packages/database/client.ts +35 -0
  155. package/analyzer-template/packages/database/index.ts +94 -0
  156. package/analyzer-template/packages/database/package.json +31 -0
  157. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +28 -0
  158. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +59 -0
  159. package/analyzer-template/packages/database/src/lib/branchToDb.ts +24 -0
  160. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +20 -0
  161. package/analyzer-template/packages/database/src/lib/commitToDb.ts +47 -0
  162. package/analyzer-template/packages/database/src/lib/fileToDb.ts +17 -0
  163. package/analyzer-template/packages/database/src/lib/kysely/db.ts +503 -0
  164. package/analyzer-template/packages/database/src/lib/kysely/tableRelations.ts +108 -0
  165. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +67 -0
  166. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +88 -0
  167. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  168. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  169. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +275 -0
  170. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +223 -0
  171. package/analyzer-template/packages/database/src/lib/loadBranch.ts +137 -0
  172. package/analyzer-template/packages/database/src/lib/loadCommit.ts +173 -0
  173. package/analyzer-template/packages/database/src/lib/loadCommits.ts +290 -0
  174. package/analyzer-template/packages/database/src/lib/loadEntities.ts +111 -0
  175. package/analyzer-template/packages/database/src/lib/loadEntity.ts +105 -0
  176. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +178 -0
  177. package/analyzer-template/packages/database/src/lib/loadFile.ts +42 -0
  178. package/analyzer-template/packages/database/src/lib/loadFiles.ts +134 -0
  179. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +96 -0
  180. package/analyzer-template/packages/database/src/lib/loadStatement.ts +23 -0
  181. package/analyzer-template/packages/database/src/lib/projectToDb.ts +35 -0
  182. package/analyzer-template/packages/database/src/lib/saveEntityStatements.ts +27 -0
  183. package/analyzer-template/packages/database/src/lib/saveFiles.ts +43 -0
  184. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +35 -0
  185. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +131 -0
  186. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +80 -0
  187. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +110 -0
  188. package/analyzer-template/packages/database/src/lib/updateProjectMetadata.ts +95 -0
  189. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +18 -0
  190. package/analyzer-template/packages/generate/index.ts +3 -0
  191. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +17 -1
  192. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +221 -0
  193. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
  194. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +42 -9
  195. package/analyzer-template/packages/generate/src/lib/deepMerge.ts +29 -2
  196. package/analyzer-template/packages/generate/src/lib/directExecutionScript.ts +17 -2
  197. package/analyzer-template/packages/generate/src/lib/getComponentScenarioPath.ts +8 -3
  198. package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
  199. package/analyzer-template/packages/github/dist/database/index.d.ts +87 -0
  200. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -0
  201. package/analyzer-template/packages/github/dist/database/index.js +85 -0
  202. package/analyzer-template/packages/github/dist/database/index.js.map +1 -0
  203. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.d.ts.map +1 -0
  204. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +19 -0
  205. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -0
  206. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.d.ts.map +1 -0
  207. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +26 -0
  208. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -0
  209. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.d.ts.map +1 -0
  210. package/analyzer-template/packages/github/dist/database/src/lib/backgroundJobToDb.js.map +1 -0
  211. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.d.ts.map +1 -0
  212. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +18 -0
  213. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -0
  214. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.d.ts.map +1 -0
  215. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +13 -0
  216. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -0
  217. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.d.ts.map +1 -0
  218. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +26 -0
  219. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -0
  220. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.d.ts.map +1 -0
  221. package/analyzer-template/packages/github/dist/database/src/lib/createOrUpdateBranchCommitStats.js.map +1 -0
  222. package/analyzer-template/packages/github/dist/database/src/lib/createProject.d.ts.map +1 -0
  223. package/analyzer-template/packages/github/dist/database/src/lib/createProject.js.map +1 -0
  224. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.d.ts.map +1 -0
  225. package/analyzer-template/packages/github/dist/database/src/lib/createRetryFetch.js.map +1 -0
  226. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.d.ts.map +1 -0
  227. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysis.js.map +1 -0
  228. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.d.ts.map +1 -0
  229. package/analyzer-template/packages/github/dist/database/src/lib/dbToAnalysisBranch.js.map +1 -0
  230. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.d.ts.map +1 -0
  231. package/analyzer-template/packages/github/dist/database/src/lib/dbToBackgroundJob.js.map +1 -0
  232. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.d.ts.map +1 -0
  233. package/analyzer-template/packages/github/dist/database/src/lib/dbToBranch.js.map +1 -0
  234. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.d.ts.map +1 -0
  235. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommit.js.map +1 -0
  236. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.d.ts.map +1 -0
  237. package/analyzer-template/packages/github/dist/database/src/lib/dbToCommitBranch.js.map +1 -0
  238. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.d.ts.map +1 -0
  239. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntity.js.map +1 -0
  240. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.d.ts.map +1 -0
  241. package/analyzer-template/packages/github/dist/database/src/lib/dbToEntityBranch.js.map +1 -0
  242. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.d.ts.map +1 -0
  243. package/analyzer-template/packages/github/dist/database/src/lib/dbToFile.js.map +1 -0
  244. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.d.ts.map +1 -0
  245. package/analyzer-template/packages/github/dist/database/src/lib/dbToProject.js.map +1 -0
  246. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.d.ts.map +1 -0
  247. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenario.js.map +1 -0
  248. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.d.ts.map +1 -0
  249. package/analyzer-template/packages/github/dist/database/src/lib/dbToScenarioComment.js.map +1 -0
  250. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.d.ts.map +1 -0
  251. package/analyzer-template/packages/github/dist/database/src/lib/dbToUserScenario.js.map +1 -0
  252. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.d.ts.map +1 -0
  253. package/analyzer-template/packages/github/dist/database/src/lib/deleteBranch.js.map +1 -0
  254. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.d.ts.map +1 -0
  255. package/analyzer-template/packages/github/dist/database/src/lib/deleteEntities.js.map +1 -0
  256. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.d.ts.map +1 -0
  257. package/analyzer-template/packages/github/dist/database/src/lib/deleteFile.js.map +1 -0
  258. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.d.ts.map +1 -0
  259. package/analyzer-template/packages/github/dist/database/src/lib/deleteScenarios.js.map +1 -0
  260. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.d.ts.map +1 -0
  261. package/analyzer-template/packages/github/dist/database/src/lib/entityToDb.js.map +1 -0
  262. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.d.ts.map +1 -0
  263. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +14 -0
  264. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -0
  265. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.d.ts.map +1 -0
  266. package/analyzer-template/packages/github/dist/database/src/lib/generateSha.js.map +1 -0
  267. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.d.ts.map +1 -0
  268. package/analyzer-template/packages/github/dist/database/src/lib/jsonUpdateUtils.js.map +1 -0
  269. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.d.ts.map +1 -0
  270. package/analyzer-template/packages/github/dist/database/src/lib/kysely/aggregationHelpers.js.map +1 -0
  271. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +73 -0
  272. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -0
  273. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +378 -0
  274. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -0
  275. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.d.ts.map +1 -0
  276. package/analyzer-template/packages/github/dist/database/src/lib/kysely/schemaHelpers.js.map +1 -0
  277. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.d.ts.map +1 -0
  278. package/analyzer-template/packages/github/dist/database/src/lib/kysely/sqliteBooleanPlugin.js.map +1 -0
  279. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts +89 -0
  280. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts.map +1 -0
  281. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.js.map +1 -0
  282. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.d.ts.map +1 -0
  283. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelationsTypes.js.map +1 -0
  284. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +97 -0
  285. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -0
  286. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.js.map +1 -0
  287. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.d.ts.map +1 -0
  288. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysisBranchesTable.js.map +1 -0
  289. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.d.ts.map +1 -0
  290. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/backgroundJobsTable.js.map +1 -0
  291. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.d.ts.map +1 -0
  292. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/branchesTable.js.map +1 -0
  293. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.d.ts.map +1 -0
  294. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitBranchesTable.js.map +1 -0
  295. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +48 -0
  296. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -0
  297. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +47 -0
  298. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -0
  299. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +60 -0
  300. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -0
  301. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js +33 -0
  302. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -0
  303. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  304. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  305. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  306. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  307. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +68 -0
  308. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -0
  309. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.js.map +1 -0
  310. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.d.ts.map +1 -0
  311. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityBranchesTable.js.map +1 -0
  312. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.d.ts.map +1 -0
  313. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entityStatementsTable.js.map +1 -0
  314. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.d.ts.map +1 -0
  315. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/filesTable.js.map +1 -0
  316. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.d.ts.map +1 -0
  317. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubPayloadsTable.js.map +1 -0
  318. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.d.ts.map +1 -0
  319. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/githubUsersTable.js.map +1 -0
  320. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  321. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  322. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  323. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  324. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.d.ts.map +1 -0
  325. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/projectsTable.js.map +1 -0
  326. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.d.ts.map +1 -0
  327. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenarioCommentsTable.js.map +1 -0
  328. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +66 -0
  329. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -0
  330. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.js.map +1 -0
  331. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.d.ts.map +1 -0
  332. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/statementsTable.js.map +1 -0
  333. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.d.ts.map +1 -0
  334. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/teamsTable.js.map +1 -0
  335. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.d.ts.map +1 -0
  336. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userScenariosTable.js.map +1 -0
  337. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.d.ts.map +1 -0
  338. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/userTeamsTable.js.map +1 -0
  339. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.d.ts.map +1 -0
  340. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/usersTable.js.map +1 -0
  341. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.d.ts.map +1 -0
  342. package/analyzer-template/packages/github/dist/database/src/lib/kysely/upsertHelpers.js.map +1 -0
  343. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +16 -0
  344. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -0
  345. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +174 -0
  346. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -0
  347. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -0
  348. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +138 -0
  349. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -0
  350. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.d.ts.map +1 -0
  351. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysisBranches.js.map +1 -0
  352. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.d.ts.map +1 -0
  353. package/analyzer-template/packages/github/dist/database/src/lib/loadBackgroundJob.js.map +1 -0
  354. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.d.ts.map +1 -0
  355. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +100 -0
  356. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -0
  357. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.d.ts.map +1 -0
  358. package/analyzer-template/packages/github/dist/database/src/lib/loadBranches.js.map +1 -0
  359. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -0
  360. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +118 -0
  361. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -0
  362. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.d.ts.map +1 -0
  363. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitBranches.js.map +1 -0
  364. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.d.ts.map +1 -0
  365. package/analyzer-template/packages/github/dist/database/src/lib/loadCommitMetadata.js.map +1 -0
  366. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +15 -0
  367. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -0
  368. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +219 -0
  369. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -0
  370. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +13 -0
  371. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -0
  372. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +76 -0
  373. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -0
  374. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -0
  375. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -0
  376. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -0
  377. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +123 -0
  378. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -0
  379. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.d.ts.map +1 -0
  380. package/analyzer-template/packages/github/dist/database/src/lib/loadFile.js.map +1 -0
  381. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.d.ts.map +1 -0
  382. package/analyzer-template/packages/github/dist/database/src/lib/loadFiles.js.map +1 -0
  383. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.d.ts.map +1 -0
  384. package/analyzer-template/packages/github/dist/database/src/lib/loadMostRecentPreviousAnalysis.js.map +1 -0
  385. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.d.ts.map +1 -0
  386. package/analyzer-template/packages/github/dist/database/src/lib/loadProject.js.map +1 -0
  387. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -0
  388. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +65 -0
  389. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -0
  390. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.d.ts.map +1 -0
  391. package/analyzer-template/packages/github/dist/database/src/lib/loadScenario.js.map +1 -0
  392. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.d.ts +3 -0
  393. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.d.ts.map +1 -0
  394. package/analyzer-template/packages/github/dist/database/src/lib/loadStatement.js.map +1 -0
  395. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.d.ts.map +1 -0
  396. package/analyzer-template/packages/github/dist/database/src/lib/nullsToUndefines.js.map +1 -0
  397. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.d.ts.map +1 -0
  398. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +18 -0
  399. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -0
  400. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.d.ts.map +1 -0
  401. package/analyzer-template/packages/github/dist/database/src/lib/saveBackgroundEvent.js.map +1 -0
  402. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.d.ts.map +1 -0
  403. package/analyzer-template/packages/github/dist/database/src/lib/saveEntityStatements.js.map +1 -0
  404. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.d.ts.map +1 -0
  405. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +33 -0
  406. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -0
  407. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.d.ts.map +1 -0
  408. package/analyzer-template/packages/github/dist/database/src/lib/saveStatement.js.map +1 -0
  409. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.d.ts.map +1 -0
  410. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +18 -0
  411. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -0
  412. package/analyzer-template/packages/github/dist/database/src/lib/supabase.d.ts +4 -0
  413. package/analyzer-template/packages/github/dist/database/src/lib/supabase.d.ts.map +1 -0
  414. package/analyzer-template/packages/github/dist/database/src/lib/supabase.js.map +1 -0
  415. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.d.ts.map +1 -0
  416. package/analyzer-template/packages/github/dist/database/src/lib/updateBackgroundJobProgress.js.map +1 -0
  417. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +13 -0
  418. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -0
  419. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +87 -0
  420. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -0
  421. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.d.ts.map +1 -0
  422. package/analyzer-template/packages/github/dist/database/src/lib/updateEntityBranch.js.map +1 -0
  423. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.d.ts.map +1 -0
  424. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisMetadata.js.map +1 -0
  425. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -0
  426. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +53 -0
  427. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -0
  428. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -0
  429. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +81 -0
  430. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -0
  431. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.d.ts.map +1 -0
  432. package/analyzer-template/packages/github/dist/database/src/lib/updateProjectMetadata.js.map +1 -0
  433. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.d.ts.map +1 -0
  434. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalyses.js.map +1 -0
  435. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.d.ts.map +1 -0
  436. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysesWithScenarios.js.map +1 -0
  437. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.d.ts.map +1 -0
  438. package/analyzer-template/packages/github/dist/database/src/lib/upsertAnalysisBranches.js.map +1 -0
  439. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.d.ts.map +1 -0
  440. package/analyzer-template/packages/github/dist/database/src/lib/upsertBackgroundJob.js.map +1 -0
  441. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.d.ts.map +1 -0
  442. package/analyzer-template/packages/github/dist/database/src/lib/upsertBranches.js.map +1 -0
  443. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.d.ts.map +1 -0
  444. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommitBranches.js.map +1 -0
  445. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.d.ts.map +1 -0
  446. package/analyzer-template/packages/github/dist/database/src/lib/upsertCommits.js.map +1 -0
  447. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.d.ts.map +1 -0
  448. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntities.js.map +1 -0
  449. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.d.ts.map +1 -0
  450. package/analyzer-template/packages/github/dist/database/src/lib/upsertEntityBranches.js.map +1 -0
  451. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.d.ts.map +1 -0
  452. package/analyzer-template/packages/github/dist/database/src/lib/upsertFiles.js.map +1 -0
  453. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.d.ts.map +1 -0
  454. package/analyzer-template/packages/github/dist/database/src/lib/upsertGithubUser.js.map +1 -0
  455. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.d.ts.map +1 -0
  456. package/analyzer-template/packages/github/dist/database/src/lib/upsertProjects.js.map +1 -0
  457. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.d.ts.map +1 -0
  458. package/analyzer-template/packages/github/dist/database/src/lib/upsertScenarios.js.map +1 -0
  459. package/analyzer-template/packages/github/dist/generate/index.d.ts +3 -0
  460. package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -1
  461. package/analyzer-template/packages/github/dist/generate/index.js +3 -0
  462. package/analyzer-template/packages/github/dist/generate/index.js.map +1 -1
  463. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -1
  464. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
  465. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
  466. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
  467. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
  468. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +217 -0
  469. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  470. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
  471. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
  472. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  473. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  474. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  475. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +41 -9
  476. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  477. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts.map +1 -1
  478. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js +30 -2
  479. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js.map +1 -1
  480. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.d.ts.map +1 -1
  481. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js +10 -1
  482. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js.map +1 -1
  483. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.d.ts.map +1 -1
  484. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js +7 -3
  485. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js.map +1 -1
  486. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
  487. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
  488. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
  489. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  490. package/analyzer-template/packages/github/dist/github/src/lib/getCommitsFromGithub.js +1 -1
  491. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -1
  492. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +11 -1
  493. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -1
  494. package/analyzer-template/packages/github/dist/github/src/lib/syncBranches.js +1 -1
  495. package/analyzer-template/packages/github/dist/github/src/lib/syncHeadBranches.js +1 -1
  496. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -1
  497. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +4 -1
  498. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -1
  499. package/analyzer-template/packages/github/dist/github/src/lib/syncPullRequest.js +1 -1
  500. package/analyzer-template/packages/github/dist/github/src/lib/updateCommitBranchesInDb.js +1 -1
  501. package/analyzer-template/packages/github/dist/github/src/lib/updateFilesInDb.js +1 -1
  502. package/analyzer-template/packages/github/dist/types/index.d.ts +2 -2
  503. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  504. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  505. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  506. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  507. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  508. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  509. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +87 -9
  510. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  511. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  512. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  513. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +4 -0
  514. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -1
  515. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  516. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  517. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +21 -6
  518. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  519. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +199 -3
  520. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  521. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  522. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  523. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
  524. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  525. package/analyzer-template/packages/github/dist/utils/index.d.ts +1 -0
  526. package/analyzer-template/packages/github/dist/utils/index.d.ts.map +1 -1
  527. package/analyzer-template/packages/github/dist/utils/index.js +2 -0
  528. package/analyzer-template/packages/github/dist/utils/index.js.map +1 -1
  529. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -1
  530. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js +65 -7
  531. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js.map +1 -1
  532. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts +13 -1
  533. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts.map +1 -1
  534. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +14 -2
  535. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -1
  536. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts +12 -1
  537. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts.map +1 -1
  538. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +13 -2
  539. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -1
  540. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts +16 -7
  541. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts.map +1 -1
  542. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +43 -13
  543. package/analyzer-template/packages/github/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -1
  544. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -1
  545. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js +42 -0
  546. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -1
  547. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  548. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  549. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +32 -3
  550. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  551. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.d.ts +18 -0
  552. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.d.ts.map +1 -0
  553. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  554. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  555. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.d.ts +26 -0
  556. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.d.ts.map +1 -0
  557. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  558. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  559. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.d.ts +3 -0
  560. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.d.ts.map +1 -0
  561. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.js +3 -0
  562. package/analyzer-template/packages/github/dist/utils/src/lib/startCommand/index.js.map +1 -0
  563. package/analyzer-template/packages/github/package.json +2 -2
  564. package/analyzer-template/packages/github/src/lib/getCommitsFromGithub.ts +1 -1
  565. package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +15 -1
  566. package/analyzer-template/packages/github/src/lib/syncBranches.ts +1 -1
  567. package/analyzer-template/packages/github/src/lib/syncHeadBranches.ts +1 -1
  568. package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +3 -1
  569. package/analyzer-template/packages/github/src/lib/syncPullRequest.ts +1 -1
  570. package/analyzer-template/packages/github/src/lib/updateCommitBranchesInDb.ts +1 -1
  571. package/analyzer-template/packages/github/src/lib/updateFilesInDb.ts +1 -1
  572. package/analyzer-template/packages/process/index.ts +2 -0
  573. package/analyzer-template/packages/process/package.json +12 -0
  574. package/analyzer-template/packages/process/tsconfig.json +8 -0
  575. package/analyzer-template/packages/types/index.ts +5 -0
  576. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  577. package/analyzer-template/packages/types/src/types/Analysis.ts +104 -9
  578. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  579. package/analyzer-template/packages/types/src/types/Entity.ts +4 -0
  580. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  581. package/analyzer-template/packages/types/src/types/Scenario.ts +21 -10
  582. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +228 -3
  583. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  584. package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
  585. package/analyzer-template/packages/ui-components/package.json +5 -5
  586. package/analyzer-template/packages/ui-components/src/components/ScenarioDetailInteractiveView.tsx +23 -7
  587. package/analyzer-template/packages/utils/dist/types/index.d.ts +2 -2
  588. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  589. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  590. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  591. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  592. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  593. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  594. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +87 -9
  595. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  596. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  597. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  598. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +4 -0
  599. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -1
  600. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  601. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  602. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +21 -6
  603. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  604. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +199 -3
  605. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  606. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  607. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  608. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
  609. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  610. package/analyzer-template/packages/utils/dist/utils/index.d.ts +1 -0
  611. package/analyzer-template/packages/utils/dist/utils/index.d.ts.map +1 -1
  612. package/analyzer-template/packages/utils/dist/utils/index.js +2 -0
  613. package/analyzer-template/packages/utils/dist/utils/index.js.map +1 -1
  614. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -1
  615. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js +65 -7
  616. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js.map +1 -1
  617. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts +13 -1
  618. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.d.ts.map +1 -1
  619. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +14 -2
  620. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -1
  621. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts +12 -1
  622. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.d.ts.map +1 -1
  623. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +13 -2
  624. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -1
  625. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts +16 -7
  626. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.d.ts.map +1 -1
  627. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +43 -13
  628. package/analyzer-template/packages/utils/dist/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -1
  629. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  630. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  631. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  632. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -1
  633. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js +42 -0
  634. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -1
  635. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  636. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  637. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +32 -3
  638. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  639. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.d.ts +18 -0
  640. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.d.ts.map +1 -0
  641. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  642. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  643. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.d.ts +26 -0
  644. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.d.ts.map +1 -0
  645. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  646. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  647. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.d.ts +3 -0
  648. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.d.ts.map +1 -0
  649. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.js +3 -0
  650. package/analyzer-template/packages/utils/dist/utils/src/lib/startCommand/index.js.map +1 -0
  651. package/analyzer-template/packages/utils/index.ts +9 -0
  652. package/analyzer-template/packages/utils/src/lib/applyUniversalMocks.ts +74 -9
  653. package/analyzer-template/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.ts +20 -1
  654. package/analyzer-template/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.ts +16 -1
  655. package/analyzer-template/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.ts +43 -9
  656. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  657. package/analyzer-template/packages/utils/src/lib/lightweightEntityExtractor.ts +43 -0
  658. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +51 -3
  659. package/analyzer-template/packages/utils/src/lib/startCommand/buildStartCommand.ts +63 -0
  660. package/analyzer-template/packages/utils/src/lib/startCommand/getWebappInfo.ts +108 -0
  661. package/analyzer-template/packages/utils/src/lib/startCommand/index.ts +10 -0
  662. package/analyzer-template/playwright/capture.ts +103 -93
  663. package/analyzer-template/playwright/captureFromUrl.ts +121 -83
  664. package/analyzer-template/playwright/captureStatic.ts +2 -2
  665. package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
  666. package/analyzer-template/playwright/takeElementScreenshot.ts +48 -11
  667. package/analyzer-template/playwright/takeScreenshot.ts +38 -10
  668. package/analyzer-template/playwright/updateBackgroundJob.ts +1 -1
  669. package/analyzer-template/playwright/waitForServer.ts +21 -6
  670. package/analyzer-template/project/LazyFileStore.ts +1 -1
  671. package/analyzer-template/project/TESTING.md +83 -0
  672. package/analyzer-template/project/analyzeBaselineCommit.ts +10 -1
  673. package/analyzer-template/project/analyzeBranchCommit.ts +5 -1
  674. package/analyzer-template/project/analyzeFileEntities.ts +5 -1
  675. package/analyzer-template/project/analyzeRegularCommit.ts +10 -1
  676. package/analyzer-template/project/captureLibraryFunctionDirect.ts +30 -27
  677. package/analyzer-template/project/constructMockCode.ts +1705 -129
  678. package/analyzer-template/project/controller/startController.ts +16 -1
  679. package/analyzer-template/project/createEntitiesAndSortFiles.ts +98 -7
  680. package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
  681. package/analyzer-template/project/getFilesWithEntitiesFromRepo.ts +1 -1
  682. package/analyzer-template/project/getScenarioUrl.ts +73 -5
  683. package/analyzer-template/project/loadReadyToBeCaptured.ts +198 -38
  684. package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
  685. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  686. package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +15 -15
  687. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +97 -67
  688. package/analyzer-template/project/orchestrateCapture/SupabaseAnalysisLoader.ts +6 -6
  689. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  690. package/analyzer-template/project/orchestrateCapture.ts +93 -14
  691. package/analyzer-template/project/prepareRepo.ts +1 -1
  692. package/analyzer-template/project/reconcileMockDataKeys.ts +251 -3
  693. package/analyzer-template/project/runAnalysis.ts +12 -1
  694. package/analyzer-template/project/runMultiScenarioServer.ts +13 -16
  695. package/analyzer-template/project/runScenarioServer.ts +1 -5
  696. package/analyzer-template/project/serverOnlyModules.ts +413 -0
  697. package/analyzer-template/project/start.ts +97 -33
  698. package/analyzer-template/project/startScenarioCapture.ts +89 -42
  699. package/analyzer-template/project/startServer.ts +50 -70
  700. package/analyzer-template/project/updateCommitBackgroundJob.ts +1 -1
  701. package/analyzer-template/project/utils/errorHandling.ts +1 -1
  702. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  703. package/analyzer-template/project/writeMockDataTsx.ts +652 -77
  704. package/analyzer-template/project/writeScenario.ts +1 -1
  705. package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
  706. package/analyzer-template/project/writeScenarioComponents.ts +2228 -180
  707. package/analyzer-template/project/writeScenarioFiles.ts +26 -0
  708. package/analyzer-template/project/writeSimpleRoot.ts +125 -2
  709. package/analyzer-template/project/writeUniversalMocks.ts +32 -11
  710. package/analyzer-template/scripts/comboWorkerLoop.cjs +99 -50
  711. package/analyzer-template/scripts/defaultCmd.sh +9 -0
  712. package/analyzer-template/scripts/postbuild.cjs +12 -1
  713. package/analyzer-template/tsconfig.json +14 -1
  714. package/background/src/lib/local/createLocalAnalyzer.js +2 -30
  715. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  716. package/background/src/lib/local/execAsync.js +1 -1
  717. package/background/src/lib/local/execAsync.js.map +1 -1
  718. package/background/src/lib/virtualized/common/execAsync.js +2 -2
  719. package/background/src/lib/virtualized/common/execAsync.js.map +1 -1
  720. package/background/src/lib/virtualized/project/LazyFileStore.js +1 -1
  721. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +8 -2
  722. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  723. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +3 -2
  724. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
  725. package/background/src/lib/virtualized/project/analyzeFileEntities.js +3 -2
  726. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  727. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +8 -2
  728. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  729. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +4 -4
  730. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  731. package/background/src/lib/virtualized/project/constructMockCode.js +1476 -92
  732. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  733. package/background/src/lib/virtualized/project/controller/startController.js +11 -1
  734. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
  735. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +83 -4
  736. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  737. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
  738. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
  739. package/background/src/lib/virtualized/project/getFilesWithEntitiesFromRepo.js +1 -1
  740. package/background/src/lib/virtualized/project/getScenarioUrl.js +38 -3
  741. package/background/src/lib/virtualized/project/getScenarioUrl.js.map +1 -1
  742. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +108 -6
  743. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  744. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
  745. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
  746. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  747. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  748. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +13 -7
  749. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -1
  750. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +73 -49
  751. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  752. package/background/src/lib/virtualized/project/orchestrateCapture.js +77 -15
  753. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  754. package/background/src/lib/virtualized/project/prepareRepo.js +1 -1
  755. package/background/src/lib/virtualized/project/prepareRepo.js.map +1 -1
  756. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +211 -3
  757. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  758. package/background/src/lib/virtualized/project/runAnalysis.js +10 -1
  759. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  760. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +13 -14
  761. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -1
  762. package/background/src/lib/virtualized/project/serverOnlyModules.js +338 -0
  763. package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -0
  764. package/background/src/lib/virtualized/project/start.js +83 -30
  765. package/background/src/lib/virtualized/project/start.js.map +1 -1
  766. package/background/src/lib/virtualized/project/startScenarioCapture.js +67 -32
  767. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  768. package/background/src/lib/virtualized/project/startServer.js +40 -68
  769. package/background/src/lib/virtualized/project/startServer.js.map +1 -1
  770. package/background/src/lib/virtualized/project/updateCommitBackgroundJob.js +1 -1
  771. package/background/src/lib/virtualized/project/utils/errorHandling.js +1 -1
  772. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  773. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  774. package/background/src/lib/virtualized/project/writeMockDataTsx.js +565 -65
  775. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  776. package/background/src/lib/virtualized/project/writeScenario.js +1 -1
  777. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
  778. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
  779. package/background/src/lib/virtualized/project/writeScenarioComponents.js +1629 -119
  780. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  781. package/background/src/lib/virtualized/project/writeScenarioFiles.js +19 -0
  782. package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -1
  783. package/background/src/lib/virtualized/project/writeSimpleRoot.js +113 -2
  784. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  785. package/background/src/lib/virtualized/project/writeUniversalMocks.js +27 -12
  786. package/background/src/lib/virtualized/project/writeUniversalMocks.js.map +1 -1
  787. package/codeyam-cli/scripts/apply-setup.js +386 -9
  788. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  789. package/codeyam-cli/scripts/extract-setup.js +1 -1
  790. package/codeyam-cli/scripts/populateEntityTimestamps.js +1 -1
  791. package/codeyam-cli/scripts/populateEntityTimestamps.js.map +1 -1
  792. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  793. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  794. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  795. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  796. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  797. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  798. package/codeyam-cli/src/cli.js +48 -20
  799. package/codeyam-cli/src/cli.js.map +1 -1
  800. package/codeyam-cli/src/codeyam-cli.js +18 -2
  801. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  802. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  803. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  804. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  805. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  806. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  807. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  808. package/codeyam-cli/src/commands/analyze.js +22 -10
  809. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  810. package/codeyam-cli/src/commands/baseline.js +176 -0
  811. package/codeyam-cli/src/commands/baseline.js.map +1 -0
  812. package/codeyam-cli/src/commands/debug.js +58 -26
  813. package/codeyam-cli/src/commands/debug.js.map +1 -1
  814. package/codeyam-cli/src/commands/default.js +43 -35
  815. package/codeyam-cli/src/commands/default.js.map +1 -1
  816. package/codeyam-cli/src/commands/editor.js +4534 -0
  817. package/codeyam-cli/src/commands/editor.js.map +1 -0
  818. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  819. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  820. package/codeyam-cli/src/commands/entities.js +1 -1
  821. package/codeyam-cli/src/commands/generate-data-structure.js +17 -8
  822. package/codeyam-cli/src/commands/generate-data-structure.js.map +1 -1
  823. package/codeyam-cli/src/commands/init.js +149 -294
  824. package/codeyam-cli/src/commands/init.js.map +1 -1
  825. package/codeyam-cli/src/commands/memory.js +278 -0
  826. package/codeyam-cli/src/commands/memory.js.map +1 -0
  827. package/codeyam-cli/src/commands/recapture.js +228 -0
  828. package/codeyam-cli/src/commands/recapture.js.map +1 -0
  829. package/codeyam-cli/src/commands/report.js +72 -24
  830. package/codeyam-cli/src/commands/report.js.map +1 -1
  831. package/codeyam-cli/src/commands/setup-sandbox.js +4 -1
  832. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  833. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  834. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  835. package/codeyam-cli/src/commands/start.js +8 -12
  836. package/codeyam-cli/src/commands/start.js.map +1 -1
  837. package/codeyam-cli/src/commands/status.js +23 -1
  838. package/codeyam-cli/src/commands/status.js.map +1 -1
  839. package/codeyam-cli/src/commands/suggest.js +1 -1
  840. package/codeyam-cli/src/commands/telemetry.js +37 -0
  841. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  842. package/codeyam-cli/src/commands/test-startup.js +17 -6
  843. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  844. package/codeyam-cli/src/commands/verify.js +14 -2
  845. package/codeyam-cli/src/commands/verify.js.map +1 -1
  846. package/codeyam-cli/src/commands/wipe.js +108 -0
  847. package/codeyam-cli/src/commands/wipe.js.map +1 -0
  848. package/codeyam-cli/src/data/techStacks.js +77 -0
  849. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  850. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  851. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  852. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  853. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  854. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  855. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  856. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  857. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  858. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +1879 -0
  859. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  860. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  861. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  862. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  863. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  864. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  865. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  866. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  867. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  868. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  869. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  870. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +261 -0
  871. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  872. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  873. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  874. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  875. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  876. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  877. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  878. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  879. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  880. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  881. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  882. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  883. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  884. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  885. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  886. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  887. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  888. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  889. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  890. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  891. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  892. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1483 -0
  893. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  894. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +280 -0
  895. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  896. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  897. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  898. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  899. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  900. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  901. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  902. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1857 -0
  903. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  904. package/codeyam-cli/src/utils/__tests__/entityVersioning.test.js +2 -2
  905. package/codeyam-cli/src/utils/__tests__/fileWatcher.batch.test.js +2 -2
  906. package/codeyam-cli/src/utils/__tests__/fileWatcher.multiversion.test.js +58 -30
  907. package/codeyam-cli/src/utils/__tests__/fileWatcher.multiversion.test.js.map +1 -1
  908. package/codeyam-cli/src/utils/__tests__/fileWatcher.optimization.test.js +2 -2
  909. package/codeyam-cli/src/utils/__tests__/fileWatcher.versioning.test.js +2 -2
  910. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  911. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  912. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  913. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  914. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  915. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  916. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  917. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  918. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  919. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  920. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  921. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  922. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  923. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  924. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  925. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  926. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  927. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  928. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +493 -0
  929. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  930. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  931. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  932. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +175 -82
  933. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  934. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  935. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  936. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  937. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  938. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  939. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  940. package/codeyam-cli/src/utils/analysisRunner.js +35 -18
  941. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  942. package/codeyam-cli/src/utils/analyzer.js +24 -16
  943. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  944. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  945. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  946. package/codeyam-cli/src/utils/backgroundServer.js +204 -31
  947. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  948. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  949. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  950. package/codeyam-cli/src/utils/changeDetection.js +1 -1
  951. package/codeyam-cli/src/utils/database.js +129 -8
  952. package/codeyam-cli/src/utils/database.js.map +1 -1
  953. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  954. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  955. package/codeyam-cli/src/utils/devServerState.js +71 -0
  956. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  957. package/codeyam-cli/src/utils/editorApi.js +79 -0
  958. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  959. package/codeyam-cli/src/utils/editorAudit.js +355 -0
  960. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  961. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  962. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  963. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  964. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  965. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  966. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  967. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  968. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  969. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  970. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  971. package/codeyam-cli/src/utils/editorEntityHelpers.js +129 -0
  972. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  973. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  974. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  975. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  976. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  977. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  978. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  979. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  980. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  981. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  982. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  983. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  984. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  985. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  986. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  987. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  988. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  989. package/codeyam-cli/src/utils/editorScenarios.js +548 -0
  990. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  991. package/codeyam-cli/src/utils/editorSeedAdapter.js +422 -0
  992. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  993. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  994. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  995. package/codeyam-cli/src/utils/entityCache.js +1 -1
  996. package/codeyam-cli/src/utils/entityChangeStatus.js +366 -0
  997. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  998. package/codeyam-cli/src/utils/entityChangeStatus.server.js +196 -0
  999. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  1000. package/codeyam-cli/src/utils/entityMetadata.js +1 -1
  1001. package/codeyam-cli/src/utils/entityVersioning.js +1 -1
  1002. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  1003. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  1004. package/codeyam-cli/src/utils/fileWatcher.js +65 -11
  1005. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  1006. package/codeyam-cli/src/utils/generateReport.js +253 -100
  1007. package/codeyam-cli/src/utils/generateReport.js.map +1 -1
  1008. package/codeyam-cli/src/utils/git.js +182 -0
  1009. package/codeyam-cli/src/utils/git.js.map +1 -0
  1010. package/codeyam-cli/src/utils/install-skills.js +129 -44
  1011. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  1012. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  1013. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  1014. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  1015. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  1016. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  1017. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  1018. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  1019. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  1020. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  1021. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  1022. package/codeyam-cli/src/utils/progress.js +8 -1
  1023. package/codeyam-cli/src/utils/progress.js.map +1 -1
  1024. package/codeyam-cli/src/utils/project.js +15 -5
  1025. package/codeyam-cli/src/utils/project.js.map +1 -1
  1026. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +14 -14
  1027. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  1028. package/codeyam-cli/src/utils/queue/__tests__/job.pidTracking.test.js +2 -2
  1029. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +60 -0
  1030. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  1031. package/codeyam-cli/src/utils/queue/heartbeat.js +14 -6
  1032. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  1033. package/codeyam-cli/src/utils/queue/job.js +328 -25
  1034. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  1035. package/codeyam-cli/src/utils/queue/manager.js +104 -7
  1036. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  1037. package/codeyam-cli/src/utils/queue/persistence.js.map +1 -1
  1038. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  1039. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  1040. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  1041. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  1042. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  1043. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  1044. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  1045. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  1046. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  1047. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  1048. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  1049. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  1050. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  1051. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  1052. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  1053. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  1054. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  1055. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  1056. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  1057. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  1058. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  1059. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  1060. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  1061. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  1062. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  1063. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  1064. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  1065. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  1066. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  1067. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  1068. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  1069. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  1070. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  1071. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  1072. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  1073. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  1074. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  1075. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  1076. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  1077. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  1078. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  1079. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  1080. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  1081. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  1082. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  1083. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  1084. package/codeyam-cli/src/utils/rules/index.js +7 -0
  1085. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  1086. package/codeyam-cli/src/utils/rules/parser.js +93 -0
  1087. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  1088. package/codeyam-cli/src/utils/rules/pathMatcher.js +49 -0
  1089. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  1090. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  1091. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  1092. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  1093. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  1094. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  1095. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  1096. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  1097. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  1098. package/codeyam-cli/src/utils/sandbox.js +190 -0
  1099. package/codeyam-cli/src/utils/sandbox.js.map +1 -0
  1100. package/codeyam-cli/src/utils/scenarioCoverage.js +74 -0
  1101. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  1102. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  1103. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  1104. package/codeyam-cli/src/utils/scenariosManifest.js +249 -0
  1105. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  1106. package/codeyam-cli/src/utils/serverState.js +94 -12
  1107. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  1108. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +96 -45
  1109. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  1110. package/codeyam-cli/src/utils/simulationGateMiddleware.js +166 -0
  1111. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  1112. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  1113. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  1114. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  1115. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  1116. package/codeyam-cli/src/utils/syncUncommittedEntities.js +1 -1
  1117. package/codeyam-cli/src/utils/syncUniversalMocks.js +1 -1
  1118. package/codeyam-cli/src/utils/telemetry.js +106 -0
  1119. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  1120. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  1121. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  1122. package/codeyam-cli/src/utils/testRunner.js +158 -0
  1123. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  1124. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  1125. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  1126. package/codeyam-cli/src/utils/versionInfo.js +67 -15
  1127. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  1128. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  1129. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  1130. package/codeyam-cli/src/utils/wipe.js +128 -0
  1131. package/codeyam-cli/src/utils/wipe.js.map +1 -0
  1132. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  1133. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  1134. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  1135. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  1136. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  1137. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  1138. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +628 -0
  1139. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  1140. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +146 -0
  1141. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  1142. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  1143. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  1144. package/codeyam-cli/src/webserver/app/lib/database.js +160 -34
  1145. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  1146. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js +3 -1
  1147. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  1148. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  1149. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  1150. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  1151. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  1152. package/codeyam-cli/src/webserver/backgroundServer.js +187 -28
  1153. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  1154. package/codeyam-cli/src/webserver/bootstrap.js +60 -0
  1155. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -0
  1156. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CzTDWkF2.js +1 -0
  1157. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BFbq6iFk.js +11 -0
  1158. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  1159. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-B6OMi58N.js +41 -0
  1160. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-DuYodzo1.js +1 -0
  1161. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-CXo9EeCl.js +25 -0
  1162. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DYCNb2It.js +3 -0
  1163. package/codeyam-cli/src/webserver/build/client/assets/LoadingDots-By5zI316.js +6 -0
  1164. package/codeyam-cli/src/webserver/build/client/assets/LogViewer-CZgY3sxX.js +3 -0
  1165. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-CnYYwRDw.js +11 -0
  1166. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CDoF7ZpU.js +1 -0
  1167. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-DrnfvaLL.js +10 -0
  1168. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Df3UCi8k.js +34 -0
  1169. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  1170. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-DRKR9T0U.js +1 -0
  1171. package/codeyam-cli/src/webserver/build/client/assets/_index-ClR-g3tY.js +11 -0
  1172. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-DTH6ydEA.js +27 -0
  1173. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  1174. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  1175. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-74hnHF59.js +1 -0
  1176. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  1177. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-B8CYhCO9.js +22 -0
  1178. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  1179. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  1180. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  1181. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  1182. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  1183. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  1184. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  1185. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  1186. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  1187. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  1188. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  1189. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  1190. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  1191. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  1192. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  1193. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  1194. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  1195. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  1196. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  1197. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  1198. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  1199. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  1200. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  1201. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  1202. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  1203. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  1204. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  1205. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  1206. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  1207. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  1208. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  1209. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  1210. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  1211. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  1212. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  1213. package/codeyam-cli/src/webserver/build/client/assets/book-open-CLaoh4ac.js +6 -0
  1214. package/codeyam-cli/src/webserver/build/client/assets/chevron-down-BZ2DZxbW.js +6 -0
  1215. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BBXArFPl.js +43 -0
  1216. package/codeyam-cli/src/webserver/build/client/assets/circle-check-CT4unAk-.js +6 -0
  1217. package/codeyam-cli/src/webserver/build/client/assets/codeyam-name-logo-CvKwUgHo.svg +9 -0
  1218. package/codeyam-cli/src/webserver/build/client/assets/copy-zK0B6Nu-.js +11 -0
  1219. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-DJB0YQJL.js +41 -0
  1220. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CCKUIm0S.svg +4 -0
  1221. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  1222. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CkXFP_i-.js +1 -0
  1223. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-DPw7NZHc.js +1 -0
  1224. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-CjC3_6JI.js +58 -0
  1225. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-DBa7T2FK.js +41 -0
  1226. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-BqAN7hyG.js +23 -0
  1227. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-BOi8kpwd.js +6 -0
  1228. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Dg1NhIms.js +6 -0
  1229. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CJX6kkkV.js +6 -0
  1230. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-BhVjZhKg.js +5 -0
  1231. package/codeyam-cli/src/webserver/build/client/assets/entry.client-_gzKltPN.js +29 -0
  1232. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  1233. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  1234. package/codeyam-cli/src/webserver/build/client/assets/files-CV_17tZS.js +1 -0
  1235. package/codeyam-cli/src/webserver/build/client/assets/git-D-YXmMbR.js +1 -0
  1236. package/codeyam-cli/src/webserver/build/client/assets/globals-DRvOjyO3.css +1 -0
  1237. package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-fmIEn3Bc.js +9 -0
  1238. package/codeyam-cli/src/webserver/build/client/assets/index-Blo6EK8G.js +15 -0
  1239. package/codeyam-cli/src/webserver/build/client/assets/index-BsX0F-9C.js +9 -0
  1240. package/codeyam-cli/src/webserver/build/client/assets/index-CCrgCshv.js +3 -0
  1241. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  1242. package/codeyam-cli/src/webserver/build/client/assets/labs-Byazq8Pv.js +1 -0
  1243. package/codeyam-cli/src/webserver/build/client/assets/loader-circle-DVQ0oHR7.js +6 -0
  1244. package/codeyam-cli/src/webserver/build/client/assets/manifest-75b1b319.js +1 -0
  1245. package/codeyam-cli/src/webserver/build/client/assets/memory-b-VmA2Vj.js +101 -0
  1246. package/codeyam-cli/src/webserver/build/client/assets/pause-DGcndCAa.js +11 -0
  1247. package/codeyam-cli/src/webserver/build/client/assets/preload-helper-ckwbz45p.js +1 -0
  1248. package/codeyam-cli/src/webserver/build/client/assets/root-F-k2uYj5.js +67 -0
  1249. package/codeyam-cli/src/webserver/build/client/assets/scenarioStatus-B_8jpV3e.js +1 -0
  1250. package/codeyam-cli/src/webserver/build/client/assets/search-C0Uw0bcK.js +6 -0
  1251. package/codeyam-cli/src/webserver/build/client/assets/settings-OoNgHIfW.js +1 -0
  1252. package/codeyam-cli/src/webserver/build/client/assets/simulations-Bcemfu8a.js +1 -0
  1253. package/codeyam-cli/src/webserver/build/client/assets/terminal-BgMmG7R9.js +11 -0
  1254. package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-Cs87hJYK.js +6 -0
  1255. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BR3Rs7JY.js +1 -0
  1256. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-BxxP_XF9.js +2 -0
  1257. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-BermyNU5.js +1 -0
  1258. package/codeyam-cli/src/webserver/build/client/assets/useToast-a_QN_W9_.js +1 -0
  1259. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  1260. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  1261. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-lv2ooewK.js +13 -0
  1262. package/codeyam-cli/src/webserver/build/server/assets/index-Im3Smyei.js +1 -0
  1263. package/codeyam-cli/src/webserver/build/server/assets/init-BjuAFKGM.js +10 -0
  1264. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  1265. package/codeyam-cli/src/webserver/build/server/assets/server-build-CNjF0B9B.js +551 -0
  1266. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  1267. package/codeyam-cli/src/webserver/build-info.json +5 -5
  1268. package/codeyam-cli/src/webserver/devServer.js +40 -8
  1269. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  1270. package/codeyam-cli/src/webserver/editorProxy.js +976 -0
  1271. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  1272. package/codeyam-cli/src/webserver/idleDetector.js +73 -0
  1273. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  1274. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  1275. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  1276. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  1277. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  1278. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  1279. package/codeyam-cli/src/webserver/server.js +376 -26
  1280. package/codeyam-cli/src/webserver/server.js.map +1 -1
  1281. package/codeyam-cli/src/webserver/terminalServer.js +831 -0
  1282. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  1283. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  1284. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  1285. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  1286. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  1287. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  1288. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  1289. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  1290. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  1291. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  1292. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  1293. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  1294. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  1295. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  1296. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  1297. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  1298. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  1299. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  1300. package/codeyam-cli/templates/editor-step-hook.py +321 -0
  1301. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  1302. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  1303. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  1304. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  1305. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  1306. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  1307. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  1308. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  1309. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  1310. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  1311. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  1312. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  1313. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  1314. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  1315. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  1316. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  1317. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  1318. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  1319. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  1320. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  1321. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  1322. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  1323. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  1324. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  1325. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  1326. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  1327. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  1328. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  1329. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  1330. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  1331. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  1332. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  1333. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  1334. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  1335. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  1336. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  1337. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  1338. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  1339. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  1340. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  1341. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  1342. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  1343. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  1344. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +127 -0
  1345. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  1346. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  1347. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  1348. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  1349. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  1350. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  1351. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  1352. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  1353. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  1354. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  1355. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  1356. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  1357. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  1358. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  1359. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  1360. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  1361. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  1362. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  1363. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  1364. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  1365. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  1366. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  1367. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  1368. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  1369. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  1370. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  1371. package/codeyam-cli/templates/rules-instructions.md +78 -0
  1372. package/codeyam-cli/templates/seed-adapters/supabase.ts +282 -0
  1373. package/codeyam-cli/templates/skills/codeyam-debug/SKILL.md +601 -0
  1374. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  1375. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +211 -0
  1376. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  1377. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  1378. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  1379. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  1380. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  1381. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  1382. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  1383. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  1384. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  1385. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  1386. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  1387. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  1388. package/codeyam-cli/templates/skills/codeyam-setup/SKILL.md +600 -0
  1389. package/codeyam-cli/templates/skills/codeyam-sim/SKILL.md +222 -0
  1390. package/codeyam-cli/templates/skills/codeyam-test/SKILL.md +178 -0
  1391. package/codeyam-cli/templates/skills/codeyam-verify/SKILL.md +179 -0
  1392. package/package.json +40 -29
  1393. package/packages/ai/index.js +9 -7
  1394. package/packages/ai/index.js.map +1 -1
  1395. package/packages/ai/src/lib/analyzeScope.js +198 -6
  1396. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  1397. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  1398. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  1399. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +201 -25
  1400. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  1401. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  1402. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  1403. package/packages/ai/src/lib/astScopes/methodSemantics.js +177 -23
  1404. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  1405. package/packages/ai/src/lib/astScopes/paths.js +11 -1
  1406. package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
  1407. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  1408. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  1409. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
  1410. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
  1411. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +31 -1
  1412. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
  1413. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
  1414. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  1415. package/packages/ai/src/lib/astScopes/processExpression.js +1296 -105
  1416. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  1417. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  1418. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  1419. package/packages/ai/src/lib/checkAllAttributes.js +24 -9
  1420. package/packages/ai/src/lib/checkAllAttributes.js.map +1 -1
  1421. package/packages/ai/src/lib/completionCall.js +188 -38
  1422. package/packages/ai/src/lib/completionCall.js.map +1 -1
  1423. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +2322 -157
  1424. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  1425. package/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.js +27 -1
  1426. package/packages/ai/src/lib/dataStructure/equivalencyManagers/FunctionCallManager.js.map +1 -1
  1427. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +19 -4
  1428. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  1429. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +661 -0
  1430. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -0
  1431. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +184 -58
  1432. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  1433. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  1434. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  1435. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  1436. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  1437. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +66 -2
  1438. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  1439. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +198 -15
  1440. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  1441. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  1442. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  1443. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  1444. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  1445. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +145 -15
  1446. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  1447. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
  1448. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
  1449. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  1450. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  1451. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  1452. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  1453. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +371 -73
  1454. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  1455. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  1456. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  1457. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.js +28 -3
  1458. package/packages/ai/src/lib/dataStructure/helpers/getFunctionCallRoot.js.map +1 -1
  1459. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  1460. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  1461. package/packages/ai/src/lib/dataStructureChunking.js +130 -0
  1462. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  1463. package/packages/ai/src/lib/deepEqual.js +32 -0
  1464. package/packages/ai/src/lib/deepEqual.js.map +1 -0
  1465. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  1466. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  1467. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  1468. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  1469. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +68 -8
  1470. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
  1471. package/packages/ai/src/lib/generateChangesEntityScenarios.js +82 -90
  1472. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
  1473. package/packages/ai/src/lib/generateEntityDataStructure.js +56 -6
  1474. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  1475. package/packages/ai/src/lib/generateEntityScenarioData.js +1185 -73
  1476. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  1477. package/packages/ai/src/lib/generateEntityScenarios.js +193 -83
  1478. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  1479. package/packages/ai/src/lib/generateExecutionFlows.js +484 -0
  1480. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  1481. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  1482. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  1483. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  1484. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  1485. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  1486. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  1487. package/packages/ai/src/lib/generateStatementAnalysis.js +1 -1
  1488. package/packages/ai/src/lib/getConditionalUsagesFromCode.js +84 -14
  1489. package/packages/ai/src/lib/getConditionalUsagesFromCode.js.map +1 -1
  1490. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -1
  1491. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
  1492. package/packages/ai/src/lib/isolateScopes.js +270 -7
  1493. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  1494. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  1495. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  1496. package/packages/ai/src/lib/mergeStatements.js +104 -6
  1497. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  1498. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  1499. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  1500. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +82 -20
  1501. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  1502. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
  1503. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
  1504. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -58
  1505. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
  1506. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  1507. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  1508. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
  1509. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  1510. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -28
  1511. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
  1512. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  1513. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  1514. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +16 -3
  1515. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
  1516. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  1517. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  1518. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  1519. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  1520. package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
  1521. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
  1522. package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
  1523. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  1524. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +98 -1
  1525. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  1526. package/packages/analyze/index.js +1 -0
  1527. package/packages/analyze/index.js.map +1 -1
  1528. package/packages/analyze/src/lib/FileAnalyzer.js +179 -36
  1529. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  1530. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  1531. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  1532. package/packages/analyze/src/lib/analysisContext.js +30 -5
  1533. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  1534. package/packages/analyze/src/lib/asts/index.js +4 -2
  1535. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  1536. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +2 -1
  1537. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  1538. package/packages/analyze/src/lib/asts/nodes/index.js +1 -0
  1539. package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -1
  1540. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
  1541. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
  1542. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  1543. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  1544. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  1545. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  1546. package/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.js +3 -2
  1547. package/packages/analyze/src/lib/asts/sourceFiles/getAllExportedNodes.js.map +1 -1
  1548. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +41 -9
  1549. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  1550. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  1551. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  1552. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  1553. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  1554. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  1555. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  1556. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +591 -100
  1557. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  1558. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +50 -2
  1559. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  1560. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +12 -1
  1561. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  1562. package/packages/analyze/src/lib/files/analyze/findPreviousAnalysis.js +1 -1
  1563. package/packages/analyze/src/lib/files/analyze/findValidExistingAnalysis.js +1 -1
  1564. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +8 -2
  1565. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  1566. package/packages/analyze/src/lib/files/analyze/setActiveAnalysisBranches.js +1 -1
  1567. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  1568. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  1569. package/packages/analyze/src/lib/files/analyzeChange.js +22 -12
  1570. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  1571. package/packages/analyze/src/lib/files/analyzeEntity.js +10 -9
  1572. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
  1573. package/packages/analyze/src/lib/files/analyzeInitial.js +10 -11
  1574. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  1575. package/packages/analyze/src/lib/files/analyzeNextRoute.js +1 -1
  1576. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +22 -26
  1577. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  1578. package/packages/analyze/src/lib/files/enums/steps.js +1 -1
  1579. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
  1580. package/packages/analyze/src/lib/files/getImportedExports.js +103 -8
  1581. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  1582. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  1583. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  1584. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +255 -0
  1585. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -0
  1586. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
  1587. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
  1588. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +646 -72
  1589. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  1590. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js +1 -1
  1591. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js.map +1 -1
  1592. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -34
  1593. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
  1594. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +513 -29
  1595. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  1596. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +104 -0
  1597. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  1598. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +56 -66
  1599. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
  1600. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +4 -8
  1601. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
  1602. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +948 -112
  1603. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  1604. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +49 -6
  1605. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  1606. package/packages/analyze/src/lib/files/setImportedExports.js +3 -2
  1607. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  1608. package/packages/analyze/src/lib/index.js +1 -0
  1609. package/packages/analyze/src/lib/index.js.map +1 -1
  1610. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  1611. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  1612. package/packages/aws/src/lib/ecs/ecsDefineContainer.js +2 -2
  1613. package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -1
  1614. package/packages/aws/src/lib/ecs/ecsTaskFactory.js +17 -61
  1615. package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -1
  1616. package/packages/database/index.js +85 -0
  1617. package/packages/database/index.js.map +1 -0
  1618. package/packages/database/src/lib/analysisBranchToDb.js +19 -0
  1619. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -0
  1620. package/packages/database/src/lib/analysisToDb.js +26 -0
  1621. package/packages/database/src/lib/analysisToDb.js.map +1 -0
  1622. package/packages/database/src/lib/backgroundJobToDb.js.map +1 -0
  1623. package/packages/database/src/lib/branchToDb.js +18 -0
  1624. package/packages/database/src/lib/branchToDb.js.map +1 -0
  1625. package/packages/database/src/lib/commitBranchToDb.js +13 -0
  1626. package/packages/database/src/lib/commitBranchToDb.js.map +1 -0
  1627. package/packages/database/src/lib/commitToDb.js +26 -0
  1628. package/packages/database/src/lib/commitToDb.js.map +1 -0
  1629. package/packages/database/src/lib/createOrUpdateBranchCommitStats.js.map +1 -0
  1630. package/packages/database/src/lib/createProject.js.map +1 -0
  1631. package/packages/database/src/lib/createRetryFetch.js.map +1 -0
  1632. package/packages/database/src/lib/dbToAnalysis.js.map +1 -0
  1633. package/packages/database/src/lib/dbToAnalysisBranch.js.map +1 -0
  1634. package/packages/database/src/lib/dbToBackgroundJob.js.map +1 -0
  1635. package/packages/database/src/lib/dbToBranch.js.map +1 -0
  1636. package/packages/database/src/lib/dbToCommit.js.map +1 -0
  1637. package/packages/database/src/lib/dbToCommitBranch.js.map +1 -0
  1638. package/packages/database/src/lib/dbToEntity.js.map +1 -0
  1639. package/packages/database/src/lib/dbToEntityBranch.js.map +1 -0
  1640. package/packages/database/src/lib/dbToFile.js.map +1 -0
  1641. package/packages/database/src/lib/dbToProject.js.map +1 -0
  1642. package/packages/database/src/lib/dbToScenario.js.map +1 -0
  1643. package/packages/database/src/lib/dbToScenarioComment.js.map +1 -0
  1644. package/packages/database/src/lib/dbToUserScenario.js.map +1 -0
  1645. package/packages/database/src/lib/deleteBranch.js.map +1 -0
  1646. package/packages/database/src/lib/deleteEntities.js.map +1 -0
  1647. package/packages/database/src/lib/deleteFile.js.map +1 -0
  1648. package/packages/database/src/lib/deleteScenarios.js.map +1 -0
  1649. package/packages/database/src/lib/entityToDb.js.map +1 -0
  1650. package/packages/database/src/lib/fileToDb.js +14 -0
  1651. package/packages/database/src/lib/fileToDb.js.map +1 -0
  1652. package/packages/database/src/lib/generateSha.js.map +1 -0
  1653. package/packages/database/src/lib/jsonUpdateUtils.js.map +1 -0
  1654. package/packages/database/src/lib/kysely/aggregationHelpers.js.map +1 -0
  1655. package/packages/database/src/lib/kysely/db.js +378 -0
  1656. package/packages/database/src/lib/kysely/db.js.map +1 -0
  1657. package/packages/database/src/lib/kysely/schemaHelpers.js.map +1 -0
  1658. package/packages/database/src/lib/kysely/sqliteBooleanPlugin.js.map +1 -0
  1659. package/packages/database/src/lib/kysely/tableRelations.js.map +1 -0
  1660. package/packages/database/src/lib/kysely/tableRelationsTypes.js.map +1 -0
  1661. package/packages/database/src/lib/kysely/tables/analysesTable.js.map +1 -0
  1662. package/packages/database/src/lib/kysely/tables/analysisBranchesTable.js.map +1 -0
  1663. package/packages/database/src/lib/kysely/tables/backgroundJobsTable.js.map +1 -0
  1664. package/packages/database/src/lib/kysely/tables/branchesTable.js.map +1 -0
  1665. package/packages/database/src/lib/kysely/tables/commitBranchesTable.js.map +1 -0
  1666. package/packages/database/src/lib/kysely/tables/commitsTable.js +47 -0
  1667. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -0
  1668. package/packages/database/src/lib/kysely/tables/debugReportsTable.js +33 -0
  1669. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -0
  1670. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  1671. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  1672. package/packages/database/src/lib/kysely/tables/entitiesTable.js.map +1 -0
  1673. package/packages/database/src/lib/kysely/tables/entityBranchesTable.js.map +1 -0
  1674. package/packages/database/src/lib/kysely/tables/entityStatementsTable.js.map +1 -0
  1675. package/packages/database/src/lib/kysely/tables/filesTable.js.map +1 -0
  1676. package/packages/database/src/lib/kysely/tables/githubPayloadsTable.js.map +1 -0
  1677. package/packages/database/src/lib/kysely/tables/githubUsersTable.js.map +1 -0
  1678. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  1679. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  1680. package/packages/database/src/lib/kysely/tables/projectsTable.js.map +1 -0
  1681. package/packages/database/src/lib/kysely/tables/scenarioCommentsTable.js.map +1 -0
  1682. package/packages/database/src/lib/kysely/tables/scenariosTable.js.map +1 -0
  1683. package/packages/database/src/lib/kysely/tables/statementsTable.js.map +1 -0
  1684. package/packages/database/src/lib/kysely/tables/teamsTable.js.map +1 -0
  1685. package/packages/database/src/lib/kysely/tables/userScenariosTable.js.map +1 -0
  1686. package/packages/database/src/lib/kysely/tables/userTeamsTable.js.map +1 -0
  1687. package/packages/database/src/lib/kysely/tables/usersTable.js.map +1 -0
  1688. package/packages/database/src/lib/kysely/upsertHelpers.js.map +1 -0
  1689. package/packages/database/src/lib/loadAnalyses.js +174 -0
  1690. package/packages/database/src/lib/loadAnalyses.js.map +1 -0
  1691. package/packages/database/src/lib/loadAnalysis.js +138 -0
  1692. package/packages/database/src/lib/loadAnalysis.js.map +1 -0
  1693. package/packages/database/src/lib/loadAnalysisBranches.js.map +1 -0
  1694. package/packages/database/src/lib/loadBackgroundJob.js.map +1 -0
  1695. package/packages/database/src/lib/loadBranch.js +100 -0
  1696. package/packages/database/src/lib/loadBranch.js.map +1 -0
  1697. package/packages/database/src/lib/loadBranches.js.map +1 -0
  1698. package/packages/database/src/lib/loadCommit.js +118 -0
  1699. package/packages/database/src/lib/loadCommit.js.map +1 -0
  1700. package/packages/database/src/lib/loadCommitBranches.js.map +1 -0
  1701. package/packages/database/src/lib/loadCommitMetadata.js.map +1 -0
  1702. package/packages/database/src/lib/loadCommits.js +219 -0
  1703. package/packages/database/src/lib/loadCommits.js.map +1 -0
  1704. package/packages/database/src/lib/loadEntities.js +76 -0
  1705. package/packages/database/src/lib/loadEntities.js.map +1 -0
  1706. package/packages/database/src/lib/loadEntity.js.map +1 -0
  1707. package/packages/database/src/lib/loadEntityBranches.js +123 -0
  1708. package/packages/database/src/lib/loadEntityBranches.js.map +1 -0
  1709. package/packages/database/src/lib/loadFile.js.map +1 -0
  1710. package/packages/database/src/lib/loadFiles.js.map +1 -0
  1711. package/packages/database/src/lib/loadMostRecentPreviousAnalysis.js.map +1 -0
  1712. package/packages/database/src/lib/loadProject.js.map +1 -0
  1713. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +65 -0
  1714. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -0
  1715. package/packages/database/src/lib/loadScenario.js.map +1 -0
  1716. package/packages/database/src/lib/loadStatement.js.map +1 -0
  1717. package/packages/database/src/lib/nullsToUndefines.js.map +1 -0
  1718. package/packages/database/src/lib/projectToDb.js +18 -0
  1719. package/packages/database/src/lib/projectToDb.js.map +1 -0
  1720. package/packages/database/src/lib/saveBackgroundEvent.js.map +1 -0
  1721. package/packages/database/src/lib/saveEntityStatements.js.map +1 -0
  1722. package/packages/database/src/lib/saveFiles.js +33 -0
  1723. package/packages/database/src/lib/saveFiles.js.map +1 -0
  1724. package/packages/database/src/lib/saveStatement.js.map +1 -0
  1725. package/packages/database/src/lib/scenarioToDb.js +18 -0
  1726. package/packages/database/src/lib/scenarioToDb.js.map +1 -0
  1727. package/packages/database/src/lib/supabase.js.map +1 -0
  1728. package/packages/database/src/lib/updateBackgroundJobProgress.js.map +1 -0
  1729. package/packages/database/src/lib/updateCommitMetadata.js +87 -0
  1730. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -0
  1731. package/packages/database/src/lib/updateEntityBranch.js.map +1 -0
  1732. package/packages/database/src/lib/updateFreshAnalysisMetadata.js.map +1 -0
  1733. package/packages/database/src/lib/updateFreshAnalysisStatus.js +53 -0
  1734. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -0
  1735. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +81 -0
  1736. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -0
  1737. package/packages/database/src/lib/updateProjectMetadata.js.map +1 -0
  1738. package/packages/database/src/lib/upsertAnalyses.js.map +1 -0
  1739. package/packages/database/src/lib/upsertAnalysesWithScenarios.js.map +1 -0
  1740. package/packages/database/src/lib/upsertAnalysisBranches.js.map +1 -0
  1741. package/packages/database/src/lib/upsertBackgroundJob.js.map +1 -0
  1742. package/packages/database/src/lib/upsertBranches.js.map +1 -0
  1743. package/packages/database/src/lib/upsertCommitBranches.js.map +1 -0
  1744. package/packages/database/src/lib/upsertCommits.js.map +1 -0
  1745. package/packages/database/src/lib/upsertEntities.js.map +1 -0
  1746. package/packages/database/src/lib/upsertEntityBranches.js.map +1 -0
  1747. package/packages/database/src/lib/upsertFiles.js.map +1 -0
  1748. package/packages/database/src/lib/upsertGithubUser.js.map +1 -0
  1749. package/packages/database/src/lib/upsertProjects.js.map +1 -0
  1750. package/packages/database/src/lib/upsertScenarios.js.map +1 -0
  1751. package/packages/generate/index.js +3 -0
  1752. package/packages/generate/index.js.map +1 -1
  1753. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
  1754. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
  1755. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +217 -0
  1756. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  1757. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  1758. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  1759. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +41 -9
  1760. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  1761. package/packages/generate/src/lib/deepMerge.js +30 -2
  1762. package/packages/generate/src/lib/deepMerge.js.map +1 -1
  1763. package/packages/generate/src/lib/directExecutionScript.js +10 -1
  1764. package/packages/generate/src/lib/directExecutionScript.js.map +1 -1
  1765. package/packages/generate/src/lib/getComponentScenarioPath.js +7 -3
  1766. package/packages/generate/src/lib/getComponentScenarioPath.js.map +1 -1
  1767. package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
  1768. package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  1769. package/packages/github/src/lib/getCommitsFromGithub.js +1 -1
  1770. package/packages/github/src/lib/loadOrCreateCommit.js +11 -1
  1771. package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -1
  1772. package/packages/github/src/lib/syncHeadBranches.js +1 -1
  1773. package/packages/github/src/lib/syncPrimaryBranch.js +4 -1
  1774. package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -1
  1775. package/packages/github/src/lib/syncPullRequest.js +1 -1
  1776. package/packages/github/src/lib/updateCommitBranchesInDb.js +1 -1
  1777. package/packages/github/src/lib/updateFilesInDb.js +1 -1
  1778. package/packages/process/index.js +3 -0
  1779. package/packages/process/index.js.map +1 -0
  1780. package/packages/process/src/GlobalProcessManager.js.map +1 -0
  1781. package/packages/process/src/ProcessManager.js +244 -0
  1782. package/packages/process/src/ProcessManager.js.map +1 -0
  1783. package/packages/process/src/index.js.map +1 -0
  1784. package/packages/process/src/managedExecAsync.js.map +1 -0
  1785. package/packages/types/index.js.map +1 -1
  1786. package/packages/types/src/enums/ProjectFramework.js +2 -0
  1787. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  1788. package/packages/utils/index.js +2 -0
  1789. package/packages/utils/index.js.map +1 -1
  1790. package/packages/utils/src/lib/applyUniversalMocks.js +65 -7
  1791. package/packages/utils/src/lib/applyUniversalMocks.js.map +1 -1
  1792. package/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js +14 -2
  1793. package/packages/utils/src/lib/frameworks/frameworkRouteFileNameToRoute.js.map +1 -1
  1794. package/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.js +13 -2
  1795. package/packages/utils/src/lib/frameworks/nextRouteFileNameToRoute.js.map +1 -1
  1796. package/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.js +43 -13
  1797. package/packages/utils/src/lib/frameworks/sanitizeNextRouteSegments.js.map +1 -1
  1798. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  1799. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  1800. package/packages/utils/src/lib/lightweightEntityExtractor.js +42 -0
  1801. package/packages/utils/src/lib/lightweightEntityExtractor.js.map +1 -1
  1802. package/packages/utils/src/lib/safeFileName.js +32 -3
  1803. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  1804. package/packages/utils/src/lib/startCommand/buildStartCommand.js +45 -0
  1805. package/packages/utils/src/lib/startCommand/buildStartCommand.js.map +1 -0
  1806. package/packages/utils/src/lib/startCommand/getWebappInfo.js +67 -0
  1807. package/packages/utils/src/lib/startCommand/getWebappInfo.js.map +1 -0
  1808. package/packages/utils/src/lib/startCommand/index.js +3 -0
  1809. package/packages/utils/src/lib/startCommand/index.js.map +1 -0
  1810. package/scripts/npm-post-install.cjs +34 -0
  1811. package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -102
  1812. package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -185
  1813. package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -235
  1814. package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -251
  1815. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
  1816. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -109
  1817. package/analyzer-template/packages/github/dist/supabase/index.d.ts +0 -86
  1818. package/analyzer-template/packages/github/dist/supabase/index.d.ts.map +0 -1
  1819. package/analyzer-template/packages/github/dist/supabase/index.js +0 -84
  1820. package/analyzer-template/packages/github/dist/supabase/index.js.map +0 -1
  1821. package/analyzer-template/packages/github/dist/supabase/src/lib/analysisBranchToDb.d.ts.map +0 -1
  1822. package/analyzer-template/packages/github/dist/supabase/src/lib/analysisBranchToDb.js +0 -19
  1823. package/analyzer-template/packages/github/dist/supabase/src/lib/analysisBranchToDb.js.map +0 -1
  1824. package/analyzer-template/packages/github/dist/supabase/src/lib/analysisToDb.d.ts.map +0 -1
  1825. package/analyzer-template/packages/github/dist/supabase/src/lib/analysisToDb.js +0 -26
  1826. package/analyzer-template/packages/github/dist/supabase/src/lib/analysisToDb.js.map +0 -1
  1827. package/analyzer-template/packages/github/dist/supabase/src/lib/backgroundJobToDb.d.ts.map +0 -1
  1828. package/analyzer-template/packages/github/dist/supabase/src/lib/backgroundJobToDb.js.map +0 -1
  1829. package/analyzer-template/packages/github/dist/supabase/src/lib/branchToDb.d.ts.map +0 -1
  1830. package/analyzer-template/packages/github/dist/supabase/src/lib/branchToDb.js +0 -18
  1831. package/analyzer-template/packages/github/dist/supabase/src/lib/branchToDb.js.map +0 -1
  1832. package/analyzer-template/packages/github/dist/supabase/src/lib/commitBranchToDb.d.ts.map +0 -1
  1833. package/analyzer-template/packages/github/dist/supabase/src/lib/commitBranchToDb.js +0 -13
  1834. package/analyzer-template/packages/github/dist/supabase/src/lib/commitBranchToDb.js.map +0 -1
  1835. package/analyzer-template/packages/github/dist/supabase/src/lib/commitToDb.d.ts.map +0 -1
  1836. package/analyzer-template/packages/github/dist/supabase/src/lib/commitToDb.js +0 -26
  1837. package/analyzer-template/packages/github/dist/supabase/src/lib/commitToDb.js.map +0 -1
  1838. package/analyzer-template/packages/github/dist/supabase/src/lib/createOrUpdateBranchCommitStats.d.ts.map +0 -1
  1839. package/analyzer-template/packages/github/dist/supabase/src/lib/createOrUpdateBranchCommitStats.js.map +0 -1
  1840. package/analyzer-template/packages/github/dist/supabase/src/lib/createProject.d.ts.map +0 -1
  1841. package/analyzer-template/packages/github/dist/supabase/src/lib/createProject.js.map +0 -1
  1842. package/analyzer-template/packages/github/dist/supabase/src/lib/createRetryFetch.d.ts.map +0 -1
  1843. package/analyzer-template/packages/github/dist/supabase/src/lib/createRetryFetch.js.map +0 -1
  1844. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToAnalysis.d.ts.map +0 -1
  1845. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToAnalysis.js.map +0 -1
  1846. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToAnalysisBranch.d.ts.map +0 -1
  1847. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToAnalysisBranch.js.map +0 -1
  1848. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToBackgroundJob.d.ts.map +0 -1
  1849. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToBackgroundJob.js.map +0 -1
  1850. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToBranch.d.ts.map +0 -1
  1851. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToBranch.js.map +0 -1
  1852. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToCommit.d.ts.map +0 -1
  1853. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToCommit.js.map +0 -1
  1854. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToCommitBranch.d.ts.map +0 -1
  1855. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToCommitBranch.js.map +0 -1
  1856. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToEntity.d.ts.map +0 -1
  1857. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToEntity.js.map +0 -1
  1858. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToEntityBranch.d.ts.map +0 -1
  1859. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToEntityBranch.js.map +0 -1
  1860. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToFile.d.ts.map +0 -1
  1861. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToFile.js.map +0 -1
  1862. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToProject.d.ts.map +0 -1
  1863. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToProject.js.map +0 -1
  1864. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToScenario.d.ts.map +0 -1
  1865. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToScenario.js.map +0 -1
  1866. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToScenarioComment.d.ts.map +0 -1
  1867. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToScenarioComment.js.map +0 -1
  1868. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToUserScenario.d.ts.map +0 -1
  1869. package/analyzer-template/packages/github/dist/supabase/src/lib/dbToUserScenario.js.map +0 -1
  1870. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteBranch.d.ts.map +0 -1
  1871. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteBranch.js.map +0 -1
  1872. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteEntities.d.ts.map +0 -1
  1873. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteEntities.js.map +0 -1
  1874. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteFile.d.ts.map +0 -1
  1875. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteFile.js.map +0 -1
  1876. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteScenarios.d.ts.map +0 -1
  1877. package/analyzer-template/packages/github/dist/supabase/src/lib/deleteScenarios.js.map +0 -1
  1878. package/analyzer-template/packages/github/dist/supabase/src/lib/entityToDb.d.ts.map +0 -1
  1879. package/analyzer-template/packages/github/dist/supabase/src/lib/entityToDb.js.map +0 -1
  1880. package/analyzer-template/packages/github/dist/supabase/src/lib/fileToDb.d.ts.map +0 -1
  1881. package/analyzer-template/packages/github/dist/supabase/src/lib/fileToDb.js +0 -14
  1882. package/analyzer-template/packages/github/dist/supabase/src/lib/fileToDb.js.map +0 -1
  1883. package/analyzer-template/packages/github/dist/supabase/src/lib/generateSha.d.ts.map +0 -1
  1884. package/analyzer-template/packages/github/dist/supabase/src/lib/generateSha.js.map +0 -1
  1885. package/analyzer-template/packages/github/dist/supabase/src/lib/jsonUpdateUtils.d.ts.map +0 -1
  1886. package/analyzer-template/packages/github/dist/supabase/src/lib/jsonUpdateUtils.js.map +0 -1
  1887. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/aggregationHelpers.d.ts.map +0 -1
  1888. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/aggregationHelpers.js.map +0 -1
  1889. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/db.d.ts +0 -69
  1890. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/db.d.ts.map +0 -1
  1891. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/db.js +0 -363
  1892. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/db.js.map +0 -1
  1893. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/schemaHelpers.d.ts.map +0 -1
  1894. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/schemaHelpers.js.map +0 -1
  1895. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/sqliteBooleanPlugin.d.ts.map +0 -1
  1896. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/sqliteBooleanPlugin.js.map +0 -1
  1897. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tableRelations.d.ts +0 -89
  1898. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tableRelations.d.ts.map +0 -1
  1899. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tableRelations.js.map +0 -1
  1900. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tableRelationsTypes.d.ts.map +0 -1
  1901. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tableRelationsTypes.js.map +0 -1
  1902. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/analysesTable.d.ts +0 -105
  1903. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/analysesTable.d.ts.map +0 -1
  1904. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/analysesTable.js.map +0 -1
  1905. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/analysisBranchesTable.d.ts.map +0 -1
  1906. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/analysisBranchesTable.js.map +0 -1
  1907. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/backgroundJobsTable.d.ts.map +0 -1
  1908. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/backgroundJobsTable.js.map +0 -1
  1909. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/branchesTable.d.ts.map +0 -1
  1910. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/branchesTable.js.map +0 -1
  1911. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/commitBranchesTable.d.ts.map +0 -1
  1912. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/commitBranchesTable.js.map +0 -1
  1913. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/commitsTable.d.ts +0 -47
  1914. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/commitsTable.d.ts.map +0 -1
  1915. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/commitsTable.js +0 -44
  1916. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/commitsTable.js.map +0 -1
  1917. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/debugReportsTable.d.ts +0 -37
  1918. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/debugReportsTable.d.ts.map +0 -1
  1919. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/debugReportsTable.js +0 -27
  1920. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/debugReportsTable.js.map +0 -1
  1921. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entitiesTable.d.ts +0 -65
  1922. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entitiesTable.d.ts.map +0 -1
  1923. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entitiesTable.js.map +0 -1
  1924. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entityBranchesTable.d.ts.map +0 -1
  1925. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entityBranchesTable.js.map +0 -1
  1926. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entityStatementsTable.d.ts.map +0 -1
  1927. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/entityStatementsTable.js.map +0 -1
  1928. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/filesTable.d.ts.map +0 -1
  1929. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/filesTable.js.map +0 -1
  1930. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/githubPayloadsTable.d.ts.map +0 -1
  1931. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/githubPayloadsTable.js.map +0 -1
  1932. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/githubUsersTable.d.ts.map +0 -1
  1933. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/githubUsersTable.js.map +0 -1
  1934. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/projectsTable.d.ts.map +0 -1
  1935. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/projectsTable.js.map +0 -1
  1936. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/scenarioCommentsTable.d.ts.map +0 -1
  1937. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/scenarioCommentsTable.js.map +0 -1
  1938. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/scenariosTable.d.ts +0 -65
  1939. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/scenariosTable.d.ts.map +0 -1
  1940. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/scenariosTable.js.map +0 -1
  1941. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/statementsTable.d.ts.map +0 -1
  1942. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/statementsTable.js.map +0 -1
  1943. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/teamsTable.d.ts.map +0 -1
  1944. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/teamsTable.js.map +0 -1
  1945. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/userScenariosTable.d.ts.map +0 -1
  1946. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/userScenariosTable.js.map +0 -1
  1947. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/userTeamsTable.d.ts.map +0 -1
  1948. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/userTeamsTable.js.map +0 -1
  1949. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/usersTable.d.ts.map +0 -1
  1950. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/tables/usersTable.js.map +0 -1
  1951. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/upsertHelpers.d.ts.map +0 -1
  1952. package/analyzer-template/packages/github/dist/supabase/src/lib/kysely/upsertHelpers.js.map +0 -1
  1953. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalyses.d.ts +0 -14
  1954. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalyses.d.ts.map +0 -1
  1955. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalyses.js +0 -131
  1956. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalyses.js.map +0 -1
  1957. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalysis.d.ts.map +0 -1
  1958. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalysis.js +0 -130
  1959. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalysis.js.map +0 -1
  1960. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalysisBranches.d.ts.map +0 -1
  1961. package/analyzer-template/packages/github/dist/supabase/src/lib/loadAnalysisBranches.js.map +0 -1
  1962. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBackgroundJob.d.ts.map +0 -1
  1963. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBackgroundJob.js.map +0 -1
  1964. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBranch.d.ts.map +0 -1
  1965. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBranch.js +0 -90
  1966. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBranch.js.map +0 -1
  1967. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBranches.d.ts.map +0 -1
  1968. package/analyzer-template/packages/github/dist/supabase/src/lib/loadBranches.js.map +0 -1
  1969. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommit.d.ts.map +0 -1
  1970. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommit.js +0 -111
  1971. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommit.js.map +0 -1
  1972. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommitBranches.d.ts.map +0 -1
  1973. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommitBranches.js.map +0 -1
  1974. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommitMetadata.d.ts.map +0 -1
  1975. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommitMetadata.js.map +0 -1
  1976. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommits.d.ts +0 -13
  1977. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommits.d.ts.map +0 -1
  1978. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommits.js +0 -188
  1979. package/analyzer-template/packages/github/dist/supabase/src/lib/loadCommits.js.map +0 -1
  1980. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntities.d.ts +0 -11
  1981. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntities.d.ts.map +0 -1
  1982. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntities.js +0 -63
  1983. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntities.js.map +0 -1
  1984. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntity.d.ts.map +0 -1
  1985. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntity.js.map +0 -1
  1986. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntityBranches.d.ts.map +0 -1
  1987. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntityBranches.js +0 -114
  1988. package/analyzer-template/packages/github/dist/supabase/src/lib/loadEntityBranches.js.map +0 -1
  1989. package/analyzer-template/packages/github/dist/supabase/src/lib/loadFile.d.ts.map +0 -1
  1990. package/analyzer-template/packages/github/dist/supabase/src/lib/loadFile.js.map +0 -1
  1991. package/analyzer-template/packages/github/dist/supabase/src/lib/loadFiles.d.ts.map +0 -1
  1992. package/analyzer-template/packages/github/dist/supabase/src/lib/loadFiles.js.map +0 -1
  1993. package/analyzer-template/packages/github/dist/supabase/src/lib/loadMostRecentPreviousAnalysis.d.ts.map +0 -1
  1994. package/analyzer-template/packages/github/dist/supabase/src/lib/loadMostRecentPreviousAnalysis.js.map +0 -1
  1995. package/analyzer-template/packages/github/dist/supabase/src/lib/loadProject.d.ts.map +0 -1
  1996. package/analyzer-template/packages/github/dist/supabase/src/lib/loadProject.js.map +0 -1
  1997. package/analyzer-template/packages/github/dist/supabase/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +0 -1
  1998. package/analyzer-template/packages/github/dist/supabase/src/lib/loadReadyToBeCapturedAnalyses.js +0 -50
  1999. package/analyzer-template/packages/github/dist/supabase/src/lib/loadReadyToBeCapturedAnalyses.js.map +0 -1
  2000. package/analyzer-template/packages/github/dist/supabase/src/lib/loadScenario.d.ts.map +0 -1
  2001. package/analyzer-template/packages/github/dist/supabase/src/lib/loadScenario.js.map +0 -1
  2002. package/analyzer-template/packages/github/dist/supabase/src/lib/loadStatement.d.ts +0 -3
  2003. package/analyzer-template/packages/github/dist/supabase/src/lib/loadStatement.d.ts.map +0 -1
  2004. package/analyzer-template/packages/github/dist/supabase/src/lib/loadStatement.js.map +0 -1
  2005. package/analyzer-template/packages/github/dist/supabase/src/lib/nullsToUndefines.d.ts.map +0 -1
  2006. package/analyzer-template/packages/github/dist/supabase/src/lib/nullsToUndefines.js.map +0 -1
  2007. package/analyzer-template/packages/github/dist/supabase/src/lib/projectToDb.d.ts.map +0 -1
  2008. package/analyzer-template/packages/github/dist/supabase/src/lib/projectToDb.js +0 -18
  2009. package/analyzer-template/packages/github/dist/supabase/src/lib/projectToDb.js.map +0 -1
  2010. package/analyzer-template/packages/github/dist/supabase/src/lib/saveBackgroundEvent.d.ts.map +0 -1
  2011. package/analyzer-template/packages/github/dist/supabase/src/lib/saveBackgroundEvent.js.map +0 -1
  2012. package/analyzer-template/packages/github/dist/supabase/src/lib/saveEntityStatements.d.ts.map +0 -1
  2013. package/analyzer-template/packages/github/dist/supabase/src/lib/saveEntityStatements.js.map +0 -1
  2014. package/analyzer-template/packages/github/dist/supabase/src/lib/saveFiles.d.ts.map +0 -1
  2015. package/analyzer-template/packages/github/dist/supabase/src/lib/saveFiles.js +0 -33
  2016. package/analyzer-template/packages/github/dist/supabase/src/lib/saveFiles.js.map +0 -1
  2017. package/analyzer-template/packages/github/dist/supabase/src/lib/saveStatement.d.ts.map +0 -1
  2018. package/analyzer-template/packages/github/dist/supabase/src/lib/saveStatement.js.map +0 -1
  2019. package/analyzer-template/packages/github/dist/supabase/src/lib/scenarioToDb.d.ts.map +0 -1
  2020. package/analyzer-template/packages/github/dist/supabase/src/lib/scenarioToDb.js +0 -18
  2021. package/analyzer-template/packages/github/dist/supabase/src/lib/scenarioToDb.js.map +0 -1
  2022. package/analyzer-template/packages/github/dist/supabase/src/lib/supabase.d.ts +0 -4
  2023. package/analyzer-template/packages/github/dist/supabase/src/lib/supabase.d.ts.map +0 -1
  2024. package/analyzer-template/packages/github/dist/supabase/src/lib/supabase.js.map +0 -1
  2025. package/analyzer-template/packages/github/dist/supabase/src/lib/updateBackgroundJobProgress.d.ts.map +0 -1
  2026. package/analyzer-template/packages/github/dist/supabase/src/lib/updateBackgroundJobProgress.js.map +0 -1
  2027. package/analyzer-template/packages/github/dist/supabase/src/lib/updateCommitMetadata.d.ts +0 -13
  2028. package/analyzer-template/packages/github/dist/supabase/src/lib/updateCommitMetadata.d.ts.map +0 -1
  2029. package/analyzer-template/packages/github/dist/supabase/src/lib/updateCommitMetadata.js +0 -100
  2030. package/analyzer-template/packages/github/dist/supabase/src/lib/updateCommitMetadata.js.map +0 -1
  2031. package/analyzer-template/packages/github/dist/supabase/src/lib/updateEntityBranch.d.ts.map +0 -1
  2032. package/analyzer-template/packages/github/dist/supabase/src/lib/updateEntityBranch.js.map +0 -1
  2033. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisMetadata.d.ts.map +0 -1
  2034. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisMetadata.js.map +0 -1
  2035. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisStatus.d.ts.map +0 -1
  2036. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisStatus.js +0 -42
  2037. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisStatus.js.map +0 -1
  2038. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +0 -1
  2039. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisStatusWithScenarios.js +0 -70
  2040. package/analyzer-template/packages/github/dist/supabase/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +0 -1
  2041. package/analyzer-template/packages/github/dist/supabase/src/lib/updateProjectMetadata.d.ts.map +0 -1
  2042. package/analyzer-template/packages/github/dist/supabase/src/lib/updateProjectMetadata.js.map +0 -1
  2043. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertAnalyses.d.ts.map +0 -1
  2044. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertAnalyses.js.map +0 -1
  2045. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertAnalysesWithScenarios.d.ts.map +0 -1
  2046. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertAnalysesWithScenarios.js.map +0 -1
  2047. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertAnalysisBranches.d.ts.map +0 -1
  2048. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertAnalysisBranches.js.map +0 -1
  2049. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertBackgroundJob.d.ts.map +0 -1
  2050. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertBackgroundJob.js.map +0 -1
  2051. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertBranches.d.ts.map +0 -1
  2052. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertBranches.js.map +0 -1
  2053. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertCommitBranches.d.ts.map +0 -1
  2054. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertCommitBranches.js.map +0 -1
  2055. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertCommits.d.ts.map +0 -1
  2056. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertCommits.js.map +0 -1
  2057. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertEntities.d.ts.map +0 -1
  2058. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertEntities.js.map +0 -1
  2059. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertEntityBranches.d.ts.map +0 -1
  2060. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertEntityBranches.js.map +0 -1
  2061. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertFiles.d.ts.map +0 -1
  2062. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertFiles.js.map +0 -1
  2063. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertGithubUser.d.ts.map +0 -1
  2064. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertGithubUser.js.map +0 -1
  2065. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertProjects.d.ts.map +0 -1
  2066. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertProjects.js.map +0 -1
  2067. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertScenarios.d.ts.map +0 -1
  2068. package/analyzer-template/packages/github/dist/supabase/src/lib/upsertScenarios.js.map +0 -1
  2069. package/analyzer-template/packages/supabase/client.ts +0 -35
  2070. package/analyzer-template/packages/supabase/index.ts +0 -93
  2071. package/analyzer-template/packages/supabase/package.json +0 -31
  2072. package/analyzer-template/packages/supabase/src/lib/analysisBranchToDb.ts +0 -28
  2073. package/analyzer-template/packages/supabase/src/lib/analysisToDb.ts +0 -59
  2074. package/analyzer-template/packages/supabase/src/lib/branchToDb.ts +0 -24
  2075. package/analyzer-template/packages/supabase/src/lib/commitBranchToDb.ts +0 -20
  2076. package/analyzer-template/packages/supabase/src/lib/commitToDb.ts +0 -47
  2077. package/analyzer-template/packages/supabase/src/lib/fileToDb.ts +0 -17
  2078. package/analyzer-template/packages/supabase/src/lib/kysely/db.ts +0 -482
  2079. package/analyzer-template/packages/supabase/src/lib/kysely/tableRelations.ts +0 -108
  2080. package/analyzer-template/packages/supabase/src/lib/kysely/tables/commitsTable.ts +0 -61
  2081. package/analyzer-template/packages/supabase/src/lib/kysely/tables/debugReportsTable.ts +0 -61
  2082. package/analyzer-template/packages/supabase/src/lib/loadAnalyses.ts +0 -218
  2083. package/analyzer-template/packages/supabase/src/lib/loadAnalysis.ts +0 -210
  2084. package/analyzer-template/packages/supabase/src/lib/loadBranch.ts +0 -122
  2085. package/analyzer-template/packages/supabase/src/lib/loadCommit.ts +0 -163
  2086. package/analyzer-template/packages/supabase/src/lib/loadCommits.ts +0 -251
  2087. package/analyzer-template/packages/supabase/src/lib/loadEntities.ts +0 -94
  2088. package/analyzer-template/packages/supabase/src/lib/loadEntity.ts +0 -110
  2089. package/analyzer-template/packages/supabase/src/lib/loadEntityBranches.ts +0 -166
  2090. package/analyzer-template/packages/supabase/src/lib/loadFile.ts +0 -47
  2091. package/analyzer-template/packages/supabase/src/lib/loadFiles.ts +0 -137
  2092. package/analyzer-template/packages/supabase/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -76
  2093. package/analyzer-template/packages/supabase/src/lib/loadStatement.ts +0 -23
  2094. package/analyzer-template/packages/supabase/src/lib/projectToDb.ts +0 -35
  2095. package/analyzer-template/packages/supabase/src/lib/saveEntityStatements.ts +0 -28
  2096. package/analyzer-template/packages/supabase/src/lib/saveFiles.ts +0 -43
  2097. package/analyzer-template/packages/supabase/src/lib/scenarioToDb.ts +0 -34
  2098. package/analyzer-template/packages/supabase/src/lib/updateCommitMetadata.ts +0 -188
  2099. package/analyzer-template/packages/supabase/src/lib/updateFreshAnalysisStatus.ts +0 -64
  2100. package/analyzer-template/packages/supabase/src/lib/updateFreshAnalysisStatusWithScenarios.ts +0 -94
  2101. package/analyzer-template/packages/supabase/src/lib/updateProjectMetadata.ts +0 -96
  2102. package/analyzer-template/packages/supabase/src/lib/userScenarioToDb.ts +0 -18
  2103. package/analyzer-template/process/INTEGRATION_COMPLETE.md +0 -333
  2104. package/analyzer-template/process/INTEGRATION_EXAMPLE.md +0 -525
  2105. package/analyzer-template/process/README.md +0 -507
  2106. package/background/src/lib/process/GlobalProcessManager.js.map +0 -1
  2107. package/background/src/lib/process/ProcessManager.js +0 -244
  2108. package/background/src/lib/process/ProcessManager.js.map +0 -1
  2109. package/background/src/lib/process/index.js.map +0 -1
  2110. package/background/src/lib/process/managedExecAsync.js.map +0 -1
  2111. package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js +0 -238
  2112. package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js.map +0 -1
  2113. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  2114. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  2115. package/codeyam-cli/src/commands/list.js +0 -31
  2116. package/codeyam-cli/src/commands/list.js.map +0 -1
  2117. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  2118. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  2119. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-D5ZHFomX.js +0 -1
  2120. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-XDSzQLOY.js +0 -26
  2121. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-BYVx9KFp.js +0 -3
  2122. package/codeyam-cli/src/webserver/build/client/assets/LogViewer-CRcT5fOZ.js +0 -3
  2123. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BORLgi0X.js +0 -1
  2124. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-Bual6h18.js +0 -1
  2125. package/codeyam-cli/src/webserver/build/client/assets/ScenarioPreview-Bi-YUMa-.js +0 -6
  2126. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-4D2vLLJz.js +0 -5
  2127. package/codeyam-cli/src/webserver/build/client/assets/_index-BC200mfN.js +0 -1
  2128. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-CxvZPkCv.js +0 -10
  2129. package/codeyam-cli/src/webserver/build/client/assets/chart-column-B8fb6wnw.js +0 -1
  2130. package/codeyam-cli/src/webserver/build/client/assets/chunk-WWGJGFF6-De6i8FUT.js +0 -26
  2131. package/codeyam-cli/src/webserver/build/client/assets/circle-alert-IdsgAK39.js +0 -1
  2132. package/codeyam-cli/src/webserver/build/client/assets/circle-check-BACUUf75.js +0 -1
  2133. package/codeyam-cli/src/webserver/build/client/assets/clock-vWeoCemX.js +0 -1
  2134. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CS7XDrKv.js +0 -1
  2135. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-C1gnJVOL.svg +0 -4
  2136. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-DIOEw_3i.js +0 -1
  2137. package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-C6fctQ5v.js +0 -11
  2138. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-C3FZJx1w.js +0 -1
  2139. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-YJz_igar.js +0 -5
  2140. package/codeyam-cli/src/webserver/build/client/assets/entityStatus-BEqj2qBy.js +0 -1
  2141. package/codeyam-cli/src/webserver/build/client/assets/entityVersioning-Bk_YB1jM.js +0 -1
  2142. package/codeyam-cli/src/webserver/build/client/assets/entry.client-DiP0q291.js +0 -5
  2143. package/codeyam-cli/src/webserver/build/client/assets/file-text-LM0mgxXE.js +0 -1
  2144. package/codeyam-cli/src/webserver/build/client/assets/files-Dxh9CcaV.js +0 -1
  2145. package/codeyam-cli/src/webserver/build/client/assets/git-BXmqrWCH.js +0 -12
  2146. package/codeyam-cli/src/webserver/build/client/assets/globals-BGS74ED-.css +0 -1
  2147. package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-XQCGvadH.js +0 -5
  2148. package/codeyam-cli/src/webserver/build/client/assets/index-D-zYbzFZ.js +0 -8
  2149. package/codeyam-cli/src/webserver/build/client/assets/loader-circle-BXPKbHEb.js +0 -1
  2150. package/codeyam-cli/src/webserver/build/client/assets/manifest-e039ab42.js +0 -1
  2151. package/codeyam-cli/src/webserver/build/client/assets/root-D0s7DnXb.js +0 -16
  2152. package/codeyam-cli/src/webserver/build/client/assets/server-build-CMKNK2uU.css +0 -1
  2153. package/codeyam-cli/src/webserver/build/client/assets/settings-5zF_GOcS.js +0 -1
  2154. package/codeyam-cli/src/webserver/build/client/assets/settings-Dc4MlMpK.js +0 -1
  2155. package/codeyam-cli/src/webserver/build/client/assets/simulations-BQ-02-jB.js +0 -1
  2156. package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-D7k-ArFa.js +0 -1
  2157. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-AlhS7g5F.js +0 -2
  2158. package/codeyam-cli/src/webserver/build/client/assets/useToast-Ddo4UQv7.js +0 -1
  2159. package/codeyam-cli/src/webserver/build/client/assets/zap-_jw-9DCp.js +0 -1
  2160. package/codeyam-cli/src/webserver/build/server/assets/index-iaMjuNME.js +0 -1
  2161. package/codeyam-cli/src/webserver/build/server/assets/server-build-CpyX1FZX.js +0 -169
  2162. package/codeyam-cli/templates/codeyam-debug-skill.md +0 -557
  2163. package/codeyam-cli/templates/codeyam-setup-skill.md +0 -453
  2164. package/codeyam-cli/templates/codeyam-sim-skill.md +0 -222
  2165. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  2166. package/codeyam-cli/templates/codeyam-test-skill.md +0 -178
  2167. package/codeyam-cli/templates/codeyam-verify-skill.md +0 -179
  2168. package/codeyam-cli/templates/debug-command.md +0 -125
  2169. package/packages/ai/src/lib/findMatchingAttribute.js +0 -77
  2170. package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
  2171. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -134
  2172. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
  2173. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -190
  2174. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
  2175. package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -206
  2176. package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
  2177. package/packages/ai/src/lib/isFrontend.js +0 -5
  2178. package/packages/ai/src/lib/isFrontend.js.map +0 -1
  2179. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
  2180. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
  2181. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -67
  2182. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
  2183. package/packages/supabase/index.js +0 -84
  2184. package/packages/supabase/index.js.map +0 -1
  2185. package/packages/supabase/src/lib/analysisBranchToDb.js +0 -19
  2186. package/packages/supabase/src/lib/analysisBranchToDb.js.map +0 -1
  2187. package/packages/supabase/src/lib/analysisToDb.js +0 -26
  2188. package/packages/supabase/src/lib/analysisToDb.js.map +0 -1
  2189. package/packages/supabase/src/lib/backgroundJobToDb.js.map +0 -1
  2190. package/packages/supabase/src/lib/branchToDb.js +0 -18
  2191. package/packages/supabase/src/lib/branchToDb.js.map +0 -1
  2192. package/packages/supabase/src/lib/commitBranchToDb.js +0 -13
  2193. package/packages/supabase/src/lib/commitBranchToDb.js.map +0 -1
  2194. package/packages/supabase/src/lib/commitToDb.js +0 -26
  2195. package/packages/supabase/src/lib/commitToDb.js.map +0 -1
  2196. package/packages/supabase/src/lib/createOrUpdateBranchCommitStats.js.map +0 -1
  2197. package/packages/supabase/src/lib/createProject.js.map +0 -1
  2198. package/packages/supabase/src/lib/createRetryFetch.js.map +0 -1
  2199. package/packages/supabase/src/lib/dbToAnalysis.js.map +0 -1
  2200. package/packages/supabase/src/lib/dbToAnalysisBranch.js.map +0 -1
  2201. package/packages/supabase/src/lib/dbToBackgroundJob.js.map +0 -1
  2202. package/packages/supabase/src/lib/dbToBranch.js.map +0 -1
  2203. package/packages/supabase/src/lib/dbToCommit.js.map +0 -1
  2204. package/packages/supabase/src/lib/dbToCommitBranch.js.map +0 -1
  2205. package/packages/supabase/src/lib/dbToEntity.js.map +0 -1
  2206. package/packages/supabase/src/lib/dbToEntityBranch.js.map +0 -1
  2207. package/packages/supabase/src/lib/dbToFile.js.map +0 -1
  2208. package/packages/supabase/src/lib/dbToProject.js.map +0 -1
  2209. package/packages/supabase/src/lib/dbToScenario.js.map +0 -1
  2210. package/packages/supabase/src/lib/dbToScenarioComment.js.map +0 -1
  2211. package/packages/supabase/src/lib/dbToUserScenario.js.map +0 -1
  2212. package/packages/supabase/src/lib/deleteBranch.js.map +0 -1
  2213. package/packages/supabase/src/lib/deleteEntities.js.map +0 -1
  2214. package/packages/supabase/src/lib/deleteFile.js.map +0 -1
  2215. package/packages/supabase/src/lib/deleteScenarios.js.map +0 -1
  2216. package/packages/supabase/src/lib/entityToDb.js.map +0 -1
  2217. package/packages/supabase/src/lib/fileToDb.js +0 -14
  2218. package/packages/supabase/src/lib/fileToDb.js.map +0 -1
  2219. package/packages/supabase/src/lib/generateSha.js.map +0 -1
  2220. package/packages/supabase/src/lib/jsonUpdateUtils.js.map +0 -1
  2221. package/packages/supabase/src/lib/kysely/aggregationHelpers.js.map +0 -1
  2222. package/packages/supabase/src/lib/kysely/db.js +0 -363
  2223. package/packages/supabase/src/lib/kysely/db.js.map +0 -1
  2224. package/packages/supabase/src/lib/kysely/schemaHelpers.js.map +0 -1
  2225. package/packages/supabase/src/lib/kysely/sqliteBooleanPlugin.js.map +0 -1
  2226. package/packages/supabase/src/lib/kysely/tableRelations.js.map +0 -1
  2227. package/packages/supabase/src/lib/kysely/tableRelationsTypes.js.map +0 -1
  2228. package/packages/supabase/src/lib/kysely/tables/analysesTable.js.map +0 -1
  2229. package/packages/supabase/src/lib/kysely/tables/analysisBranchesTable.js.map +0 -1
  2230. package/packages/supabase/src/lib/kysely/tables/backgroundJobsTable.js.map +0 -1
  2231. package/packages/supabase/src/lib/kysely/tables/branchesTable.js.map +0 -1
  2232. package/packages/supabase/src/lib/kysely/tables/commitBranchesTable.js.map +0 -1
  2233. package/packages/supabase/src/lib/kysely/tables/commitsTable.js +0 -44
  2234. package/packages/supabase/src/lib/kysely/tables/commitsTable.js.map +0 -1
  2235. package/packages/supabase/src/lib/kysely/tables/debugReportsTable.js +0 -27
  2236. package/packages/supabase/src/lib/kysely/tables/debugReportsTable.js.map +0 -1
  2237. package/packages/supabase/src/lib/kysely/tables/entitiesTable.js.map +0 -1
  2238. package/packages/supabase/src/lib/kysely/tables/entityBranchesTable.js.map +0 -1
  2239. package/packages/supabase/src/lib/kysely/tables/entityStatementsTable.js.map +0 -1
  2240. package/packages/supabase/src/lib/kysely/tables/filesTable.js.map +0 -1
  2241. package/packages/supabase/src/lib/kysely/tables/githubPayloadsTable.js.map +0 -1
  2242. package/packages/supabase/src/lib/kysely/tables/githubUsersTable.js.map +0 -1
  2243. package/packages/supabase/src/lib/kysely/tables/projectsTable.js.map +0 -1
  2244. package/packages/supabase/src/lib/kysely/tables/scenarioCommentsTable.js.map +0 -1
  2245. package/packages/supabase/src/lib/kysely/tables/scenariosTable.js.map +0 -1
  2246. package/packages/supabase/src/lib/kysely/tables/statementsTable.js.map +0 -1
  2247. package/packages/supabase/src/lib/kysely/tables/teamsTable.js.map +0 -1
  2248. package/packages/supabase/src/lib/kysely/tables/userScenariosTable.js.map +0 -1
  2249. package/packages/supabase/src/lib/kysely/tables/userTeamsTable.js.map +0 -1
  2250. package/packages/supabase/src/lib/kysely/tables/usersTable.js.map +0 -1
  2251. package/packages/supabase/src/lib/kysely/upsertHelpers.js.map +0 -1
  2252. package/packages/supabase/src/lib/loadAnalyses.js +0 -131
  2253. package/packages/supabase/src/lib/loadAnalyses.js.map +0 -1
  2254. package/packages/supabase/src/lib/loadAnalysis.js +0 -130
  2255. package/packages/supabase/src/lib/loadAnalysis.js.map +0 -1
  2256. package/packages/supabase/src/lib/loadAnalysisBranches.js.map +0 -1
  2257. package/packages/supabase/src/lib/loadBackgroundJob.js.map +0 -1
  2258. package/packages/supabase/src/lib/loadBranch.js +0 -90
  2259. package/packages/supabase/src/lib/loadBranch.js.map +0 -1
  2260. package/packages/supabase/src/lib/loadBranches.js.map +0 -1
  2261. package/packages/supabase/src/lib/loadCommit.js +0 -111
  2262. package/packages/supabase/src/lib/loadCommit.js.map +0 -1
  2263. package/packages/supabase/src/lib/loadCommitBranches.js.map +0 -1
  2264. package/packages/supabase/src/lib/loadCommitMetadata.js.map +0 -1
  2265. package/packages/supabase/src/lib/loadCommits.js +0 -188
  2266. package/packages/supabase/src/lib/loadCommits.js.map +0 -1
  2267. package/packages/supabase/src/lib/loadEntities.js +0 -63
  2268. package/packages/supabase/src/lib/loadEntities.js.map +0 -1
  2269. package/packages/supabase/src/lib/loadEntity.js.map +0 -1
  2270. package/packages/supabase/src/lib/loadEntityBranches.js +0 -114
  2271. package/packages/supabase/src/lib/loadEntityBranches.js.map +0 -1
  2272. package/packages/supabase/src/lib/loadFile.js.map +0 -1
  2273. package/packages/supabase/src/lib/loadFiles.js.map +0 -1
  2274. package/packages/supabase/src/lib/loadMostRecentPreviousAnalysis.js.map +0 -1
  2275. package/packages/supabase/src/lib/loadProject.js.map +0 -1
  2276. package/packages/supabase/src/lib/loadReadyToBeCapturedAnalyses.js +0 -50
  2277. package/packages/supabase/src/lib/loadReadyToBeCapturedAnalyses.js.map +0 -1
  2278. package/packages/supabase/src/lib/loadScenario.js.map +0 -1
  2279. package/packages/supabase/src/lib/loadStatement.js.map +0 -1
  2280. package/packages/supabase/src/lib/nullsToUndefines.js.map +0 -1
  2281. package/packages/supabase/src/lib/projectToDb.js +0 -18
  2282. package/packages/supabase/src/lib/projectToDb.js.map +0 -1
  2283. package/packages/supabase/src/lib/saveBackgroundEvent.js.map +0 -1
  2284. package/packages/supabase/src/lib/saveEntityStatements.js.map +0 -1
  2285. package/packages/supabase/src/lib/saveFiles.js +0 -33
  2286. package/packages/supabase/src/lib/saveFiles.js.map +0 -1
  2287. package/packages/supabase/src/lib/saveStatement.js.map +0 -1
  2288. package/packages/supabase/src/lib/scenarioToDb.js +0 -18
  2289. package/packages/supabase/src/lib/scenarioToDb.js.map +0 -1
  2290. package/packages/supabase/src/lib/supabase.js.map +0 -1
  2291. package/packages/supabase/src/lib/updateBackgroundJobProgress.js.map +0 -1
  2292. package/packages/supabase/src/lib/updateCommitMetadata.js +0 -100
  2293. package/packages/supabase/src/lib/updateCommitMetadata.js.map +0 -1
  2294. package/packages/supabase/src/lib/updateEntityBranch.js.map +0 -1
  2295. package/packages/supabase/src/lib/updateFreshAnalysisMetadata.js.map +0 -1
  2296. package/packages/supabase/src/lib/updateFreshAnalysisStatus.js +0 -42
  2297. package/packages/supabase/src/lib/updateFreshAnalysisStatus.js.map +0 -1
  2298. package/packages/supabase/src/lib/updateFreshAnalysisStatusWithScenarios.js +0 -70
  2299. package/packages/supabase/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +0 -1
  2300. package/packages/supabase/src/lib/updateProjectMetadata.js.map +0 -1
  2301. package/packages/supabase/src/lib/upsertAnalyses.js.map +0 -1
  2302. package/packages/supabase/src/lib/upsertAnalysesWithScenarios.js.map +0 -1
  2303. package/packages/supabase/src/lib/upsertAnalysisBranches.js.map +0 -1
  2304. package/packages/supabase/src/lib/upsertBackgroundJob.js.map +0 -1
  2305. package/packages/supabase/src/lib/upsertBranches.js.map +0 -1
  2306. package/packages/supabase/src/lib/upsertCommitBranches.js.map +0 -1
  2307. package/packages/supabase/src/lib/upsertCommits.js.map +0 -1
  2308. package/packages/supabase/src/lib/upsertEntities.js.map +0 -1
  2309. package/packages/supabase/src/lib/upsertEntityBranches.js.map +0 -1
  2310. package/packages/supabase/src/lib/upsertFiles.js.map +0 -1
  2311. package/packages/supabase/src/lib/upsertGithubUser.js.map +0 -1
  2312. package/packages/supabase/src/lib/upsertProjects.js.map +0 -1
  2313. package/packages/supabase/src/lib/upsertScenarios.js.map +0 -1
  2314. package/scripts/finalize-analyzer.cjs +0 -79
  2315. /package/analyzer-template/packages/{supabase → database}/__mocks__/index.ts +0 -0
  2316. /package/analyzer-template/packages/{supabase → database}/src/lib/backgroundJobToDb.ts +0 -0
  2317. /package/analyzer-template/packages/{supabase → database}/src/lib/client/listenForCommits_Client.ts +0 -0
  2318. /package/analyzer-template/packages/{supabase → database}/src/lib/client/loadAnalysesInClient.ts +0 -0
  2319. /package/analyzer-template/packages/{supabase → database}/src/lib/client/loadAnalysis_Client.ts +0 -0
  2320. /package/analyzer-template/packages/{supabase → database}/src/lib/client/loadBranches_Client.ts +0 -0
  2321. /package/analyzer-template/packages/{supabase → database}/src/lib/client/loadCommit_Client.ts +0 -0
  2322. /package/analyzer-template/packages/{supabase → database}/src/lib/client/upsertFiles_Client.ts +0 -0
  2323. /package/analyzer-template/packages/{supabase → database}/src/lib/createOrUpdateBranchCommitStats.ts +0 -0
  2324. /package/analyzer-template/packages/{supabase → database}/src/lib/createProject.ts +0 -0
  2325. /package/analyzer-template/packages/{supabase → database}/src/lib/createRetryFetch.ts +0 -0
  2326. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToAnalysis.ts +0 -0
  2327. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToAnalysisBranch.ts +0 -0
  2328. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToBackgroundJob.ts +0 -0
  2329. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToBranch.ts +0 -0
  2330. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToCommit.ts +0 -0
  2331. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToCommitBranch.ts +0 -0
  2332. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToEntity.ts +0 -0
  2333. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToEntityBranch.ts +0 -0
  2334. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToFile.ts +0 -0
  2335. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToProject.ts +0 -0
  2336. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToScenario.ts +0 -0
  2337. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToScenarioComment.ts +0 -0
  2338. /package/analyzer-template/packages/{supabase → database}/src/lib/dbToUserScenario.ts +0 -0
  2339. /package/analyzer-template/packages/{supabase → database}/src/lib/deleteBranch.ts +0 -0
  2340. /package/analyzer-template/packages/{supabase → database}/src/lib/deleteEntities.ts +0 -0
  2341. /package/analyzer-template/packages/{supabase → database}/src/lib/deleteFile.ts +0 -0
  2342. /package/analyzer-template/packages/{supabase → database}/src/lib/deleteScenarios.ts +0 -0
  2343. /package/analyzer-template/packages/{supabase → database}/src/lib/entityToDb.ts +0 -0
  2344. /package/analyzer-template/packages/{supabase → database}/src/lib/generateSha.ts +0 -0
  2345. /package/analyzer-template/packages/{supabase → database}/src/lib/jsonUpdateUtils.ts +0 -0
  2346. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/aggregationHelpers.ts +0 -0
  2347. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/schemaHelpers.ts +0 -0
  2348. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/sqliteBooleanPlugin.ts +0 -0
  2349. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tableRelationsTypes.ts +0 -0
  2350. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/analysesTable.ts +0 -0
  2351. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/analysisBranchesTable.ts +0 -0
  2352. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/backgroundJobsTable.ts +0 -0
  2353. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/branchesTable.ts +0 -0
  2354. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/commitBranchesTable.ts +0 -0
  2355. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/entitiesTable.ts +0 -0
  2356. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/entityBranchesTable.ts +0 -0
  2357. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/entityStatementsTable.ts +0 -0
  2358. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/filesTable.ts +0 -0
  2359. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/githubPayloadsTable.ts +0 -0
  2360. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/githubUsersTable.ts +0 -0
  2361. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/projectsTable.ts +0 -0
  2362. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/scenarioCommentsTable.ts +0 -0
  2363. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/scenariosTable.ts +0 -0
  2364. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/statementsTable.ts +0 -0
  2365. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/teamsTable.ts +0 -0
  2366. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/userScenariosTable.ts +0 -0
  2367. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/userTeamsTable.ts +0 -0
  2368. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/tables/usersTable.ts +0 -0
  2369. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely/upsertHelpers.ts +0 -0
  2370. /package/analyzer-template/packages/{supabase → database}/src/lib/kysely.ts +0 -0
  2371. /package/analyzer-template/packages/{supabase → database}/src/lib/loadAnalysisBranches.ts +0 -0
  2372. /package/analyzer-template/packages/{supabase → database}/src/lib/loadBackgroundJob.ts +0 -0
  2373. /package/analyzer-template/packages/{supabase → database}/src/lib/loadBranches.ts +0 -0
  2374. /package/analyzer-template/packages/{supabase → database}/src/lib/loadCommitBranches.ts +0 -0
  2375. /package/analyzer-template/packages/{supabase → database}/src/lib/loadCommitMetadata.ts +0 -0
  2376. /package/analyzer-template/packages/{supabase → database}/src/lib/loadMostRecentPreviousAnalysis.ts +0 -0
  2377. /package/analyzer-template/packages/{supabase → database}/src/lib/loadProject.ts +0 -0
  2378. /package/analyzer-template/packages/{supabase → database}/src/lib/loadScenario.ts +0 -0
  2379. /package/analyzer-template/packages/{supabase → database}/src/lib/nullsToUndefines.ts +0 -0
  2380. /package/analyzer-template/packages/{supabase → database}/src/lib/saveBackgroundEvent.ts +0 -0
  2381. /package/analyzer-template/packages/{supabase → database}/src/lib/saveStatement.ts +0 -0
  2382. /package/analyzer-template/packages/{supabase → database}/src/lib/scenarioCommentToDb.ts +0 -0
  2383. /package/analyzer-template/packages/{supabase → database}/src/lib/supabase.ts +0 -0
  2384. /package/analyzer-template/packages/{supabase → database}/src/lib/updateBackgroundJobProgress.ts +0 -0
  2385. /package/analyzer-template/packages/{supabase → database}/src/lib/updateEntityBranch.ts +0 -0
  2386. /package/analyzer-template/packages/{supabase → database}/src/lib/updateFreshAnalysisMetadata.ts +0 -0
  2387. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertAnalyses.ts +0 -0
  2388. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertAnalysesWithScenarios.ts +0 -0
  2389. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertAnalysisBranches.ts +0 -0
  2390. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertBackgroundJob.ts +0 -0
  2391. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertBranches.ts +0 -0
  2392. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertCommitBranches.ts +0 -0
  2393. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertCommits.ts +0 -0
  2394. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertEntities.ts +0 -0
  2395. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertEntityBranches.ts +0 -0
  2396. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertFiles.ts +0 -0
  2397. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertGithubUser.ts +0 -0
  2398. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertProjects.ts +0 -0
  2399. /package/analyzer-template/packages/{supabase → database}/src/lib/upsertScenarios.ts +0 -0
  2400. /package/analyzer-template/packages/{supabase → database}/tsconfig.json +0 -0
  2401. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/analysisBranchToDb.d.ts +0 -0
  2402. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/analysisToDb.d.ts +0 -0
  2403. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/backgroundJobToDb.d.ts +0 -0
  2404. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/backgroundJobToDb.js +0 -0
  2405. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/branchToDb.d.ts +0 -0
  2406. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/commitBranchToDb.d.ts +0 -0
  2407. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/commitToDb.d.ts +0 -0
  2408. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/createOrUpdateBranchCommitStats.d.ts +0 -0
  2409. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/createOrUpdateBranchCommitStats.js +0 -0
  2410. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/createProject.d.ts +0 -0
  2411. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/createProject.js +0 -0
  2412. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/createRetryFetch.d.ts +0 -0
  2413. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/createRetryFetch.js +0 -0
  2414. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToAnalysis.d.ts +0 -0
  2415. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToAnalysis.js +0 -0
  2416. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToAnalysisBranch.d.ts +0 -0
  2417. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToAnalysisBranch.js +0 -0
  2418. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToBackgroundJob.d.ts +0 -0
  2419. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToBackgroundJob.js +0 -0
  2420. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToBranch.d.ts +0 -0
  2421. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToBranch.js +0 -0
  2422. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToCommit.d.ts +0 -0
  2423. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToCommit.js +0 -0
  2424. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToCommitBranch.d.ts +0 -0
  2425. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToCommitBranch.js +0 -0
  2426. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToEntity.d.ts +0 -0
  2427. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToEntity.js +0 -0
  2428. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToEntityBranch.d.ts +0 -0
  2429. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToEntityBranch.js +0 -0
  2430. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToFile.d.ts +0 -0
  2431. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToFile.js +0 -0
  2432. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToProject.d.ts +0 -0
  2433. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToProject.js +0 -0
  2434. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToScenario.d.ts +0 -0
  2435. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToScenario.js +0 -0
  2436. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToScenarioComment.d.ts +0 -0
  2437. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToScenarioComment.js +0 -0
  2438. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToUserScenario.d.ts +0 -0
  2439. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/dbToUserScenario.js +0 -0
  2440. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteBranch.d.ts +0 -0
  2441. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteBranch.js +0 -0
  2442. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteEntities.d.ts +0 -0
  2443. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteEntities.js +0 -0
  2444. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteFile.d.ts +0 -0
  2445. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteFile.js +0 -0
  2446. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteScenarios.d.ts +0 -0
  2447. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/deleteScenarios.js +0 -0
  2448. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/entityToDb.d.ts +0 -0
  2449. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/entityToDb.js +0 -0
  2450. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/fileToDb.d.ts +0 -0
  2451. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/generateSha.d.ts +0 -0
  2452. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/generateSha.js +0 -0
  2453. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/jsonUpdateUtils.d.ts +0 -0
  2454. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/jsonUpdateUtils.js +0 -0
  2455. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/aggregationHelpers.d.ts +0 -0
  2456. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/aggregationHelpers.js +0 -0
  2457. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/schemaHelpers.d.ts +0 -0
  2458. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/schemaHelpers.js +0 -0
  2459. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/sqliteBooleanPlugin.d.ts +0 -0
  2460. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/sqliteBooleanPlugin.js +0 -0
  2461. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tableRelations.js +0 -0
  2462. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tableRelationsTypes.d.ts +0 -0
  2463. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tableRelationsTypes.js +0 -0
  2464. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/analysesTable.js +0 -0
  2465. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/analysisBranchesTable.d.ts +0 -0
  2466. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/analysisBranchesTable.js +0 -0
  2467. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/backgroundJobsTable.d.ts +0 -0
  2468. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/backgroundJobsTable.js +0 -0
  2469. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/branchesTable.d.ts +0 -0
  2470. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/branchesTable.js +0 -0
  2471. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/commitBranchesTable.d.ts +0 -0
  2472. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/commitBranchesTable.js +0 -0
  2473. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/entitiesTable.js +0 -0
  2474. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/entityBranchesTable.d.ts +0 -0
  2475. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/entityBranchesTable.js +0 -0
  2476. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/entityStatementsTable.d.ts +0 -0
  2477. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/entityStatementsTable.js +0 -0
  2478. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/filesTable.d.ts +0 -0
  2479. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/filesTable.js +0 -0
  2480. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/githubPayloadsTable.d.ts +0 -0
  2481. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/githubPayloadsTable.js +0 -0
  2482. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/githubUsersTable.d.ts +0 -0
  2483. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/githubUsersTable.js +0 -0
  2484. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/projectsTable.d.ts +0 -0
  2485. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/projectsTable.js +0 -0
  2486. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/scenarioCommentsTable.d.ts +0 -0
  2487. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/scenarioCommentsTable.js +0 -0
  2488. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/scenariosTable.js +0 -0
  2489. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/statementsTable.d.ts +0 -0
  2490. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/statementsTable.js +0 -0
  2491. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/teamsTable.d.ts +0 -0
  2492. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/teamsTable.js +0 -0
  2493. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/userScenariosTable.d.ts +0 -0
  2494. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/userScenariosTable.js +0 -0
  2495. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/userTeamsTable.d.ts +0 -0
  2496. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/userTeamsTable.js +0 -0
  2497. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/usersTable.d.ts +0 -0
  2498. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/tables/usersTable.js +0 -0
  2499. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/upsertHelpers.d.ts +0 -0
  2500. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/kysely/upsertHelpers.js +0 -0
  2501. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadAnalysis.d.ts +0 -0
  2502. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadAnalysisBranches.d.ts +0 -0
  2503. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadAnalysisBranches.js +0 -0
  2504. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadBackgroundJob.d.ts +0 -0
  2505. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadBackgroundJob.js +0 -0
  2506. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadBranch.d.ts +0 -0
  2507. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadBranches.d.ts +0 -0
  2508. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadBranches.js +0 -0
  2509. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadCommit.d.ts +0 -0
  2510. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadCommitBranches.d.ts +0 -0
  2511. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadCommitBranches.js +0 -0
  2512. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadCommitMetadata.d.ts +0 -0
  2513. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadCommitMetadata.js +0 -0
  2514. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadEntity.d.ts +0 -0
  2515. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadEntity.js +0 -0
  2516. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadEntityBranches.d.ts +0 -0
  2517. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadFile.d.ts +0 -0
  2518. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadFile.js +0 -0
  2519. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadFiles.d.ts +0 -0
  2520. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadFiles.js +0 -0
  2521. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadMostRecentPreviousAnalysis.d.ts +0 -0
  2522. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadMostRecentPreviousAnalysis.js +0 -0
  2523. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadProject.d.ts +0 -0
  2524. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadProject.js +0 -0
  2525. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadReadyToBeCapturedAnalyses.d.ts +0 -0
  2526. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadScenario.d.ts +0 -0
  2527. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadScenario.js +0 -0
  2528. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/loadStatement.js +0 -0
  2529. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/nullsToUndefines.d.ts +0 -0
  2530. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/nullsToUndefines.js +0 -0
  2531. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/projectToDb.d.ts +0 -0
  2532. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveBackgroundEvent.d.ts +0 -0
  2533. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveBackgroundEvent.js +0 -0
  2534. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveEntityStatements.d.ts +0 -0
  2535. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveEntityStatements.js +0 -0
  2536. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveFiles.d.ts +0 -0
  2537. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveStatement.d.ts +0 -0
  2538. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/saveStatement.js +0 -0
  2539. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/scenarioToDb.d.ts +0 -0
  2540. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/supabase.js +0 -0
  2541. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateBackgroundJobProgress.d.ts +0 -0
  2542. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateBackgroundJobProgress.js +0 -0
  2543. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateEntityBranch.d.ts +0 -0
  2544. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateEntityBranch.js +0 -0
  2545. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateFreshAnalysisMetadata.d.ts +0 -0
  2546. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateFreshAnalysisMetadata.js +0 -0
  2547. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateFreshAnalysisStatus.d.ts +0 -0
  2548. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts +0 -0
  2549. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateProjectMetadata.d.ts +0 -0
  2550. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/updateProjectMetadata.js +0 -0
  2551. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertAnalyses.d.ts +0 -0
  2552. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertAnalyses.js +0 -0
  2553. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertAnalysesWithScenarios.d.ts +0 -0
  2554. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertAnalysesWithScenarios.js +0 -0
  2555. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertAnalysisBranches.d.ts +0 -0
  2556. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertAnalysisBranches.js +0 -0
  2557. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertBackgroundJob.d.ts +0 -0
  2558. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertBackgroundJob.js +0 -0
  2559. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertBranches.d.ts +0 -0
  2560. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertBranches.js +0 -0
  2561. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertCommitBranches.d.ts +0 -0
  2562. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertCommitBranches.js +0 -0
  2563. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertCommits.d.ts +0 -0
  2564. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertCommits.js +0 -0
  2565. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertEntities.d.ts +0 -0
  2566. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertEntities.js +0 -0
  2567. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertEntityBranches.d.ts +0 -0
  2568. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertEntityBranches.js +0 -0
  2569. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertFiles.d.ts +0 -0
  2570. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertFiles.js +0 -0
  2571. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertGithubUser.d.ts +0 -0
  2572. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertGithubUser.js +0 -0
  2573. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertProjects.d.ts +0 -0
  2574. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertProjects.js +0 -0
  2575. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertScenarios.d.ts +0 -0
  2576. /package/analyzer-template/packages/github/dist/{supabase → database}/src/lib/upsertScenarios.js +0 -0
  2577. /package/analyzer-template/{process → packages/process/src}/GlobalProcessManager.ts +0 -0
  2578. /package/analyzer-template/{process → packages/process/src}/ProcessManager.ts +0 -0
  2579. /package/analyzer-template/{process → packages/process/src}/index.ts +0 -0
  2580. /package/analyzer-template/{process → packages/process/src}/managedExecAsync.ts +0 -0
  2581. /package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-CMKNK2uU.css → styles-CMKNK2uU.css} +0 -0
  2582. /package/packages/{supabase → database}/src/lib/backgroundJobToDb.js +0 -0
  2583. /package/packages/{supabase → database}/src/lib/createOrUpdateBranchCommitStats.js +0 -0
  2584. /package/packages/{supabase → database}/src/lib/createProject.js +0 -0
  2585. /package/packages/{supabase → database}/src/lib/createRetryFetch.js +0 -0
  2586. /package/packages/{supabase → database}/src/lib/dbToAnalysis.js +0 -0
  2587. /package/packages/{supabase → database}/src/lib/dbToAnalysisBranch.js +0 -0
  2588. /package/packages/{supabase → database}/src/lib/dbToBackgroundJob.js +0 -0
  2589. /package/packages/{supabase → database}/src/lib/dbToBranch.js +0 -0
  2590. /package/packages/{supabase → database}/src/lib/dbToCommit.js +0 -0
  2591. /package/packages/{supabase → database}/src/lib/dbToCommitBranch.js +0 -0
  2592. /package/packages/{supabase → database}/src/lib/dbToEntity.js +0 -0
  2593. /package/packages/{supabase → database}/src/lib/dbToEntityBranch.js +0 -0
  2594. /package/packages/{supabase → database}/src/lib/dbToFile.js +0 -0
  2595. /package/packages/{supabase → database}/src/lib/dbToProject.js +0 -0
  2596. /package/packages/{supabase → database}/src/lib/dbToScenario.js +0 -0
  2597. /package/packages/{supabase → database}/src/lib/dbToScenarioComment.js +0 -0
  2598. /package/packages/{supabase → database}/src/lib/dbToUserScenario.js +0 -0
  2599. /package/packages/{supabase → database}/src/lib/deleteBranch.js +0 -0
  2600. /package/packages/{supabase → database}/src/lib/deleteEntities.js +0 -0
  2601. /package/packages/{supabase → database}/src/lib/deleteFile.js +0 -0
  2602. /package/packages/{supabase → database}/src/lib/deleteScenarios.js +0 -0
  2603. /package/packages/{supabase → database}/src/lib/entityToDb.js +0 -0
  2604. /package/packages/{supabase → database}/src/lib/generateSha.js +0 -0
  2605. /package/packages/{supabase → database}/src/lib/jsonUpdateUtils.js +0 -0
  2606. /package/packages/{supabase → database}/src/lib/kysely/aggregationHelpers.js +0 -0
  2607. /package/packages/{supabase → database}/src/lib/kysely/schemaHelpers.js +0 -0
  2608. /package/packages/{supabase → database}/src/lib/kysely/sqliteBooleanPlugin.js +0 -0
  2609. /package/packages/{supabase → database}/src/lib/kysely/tableRelations.js +0 -0
  2610. /package/packages/{supabase → database}/src/lib/kysely/tableRelationsTypes.js +0 -0
  2611. /package/packages/{supabase → database}/src/lib/kysely/tables/analysesTable.js +0 -0
  2612. /package/packages/{supabase → database}/src/lib/kysely/tables/analysisBranchesTable.js +0 -0
  2613. /package/packages/{supabase → database}/src/lib/kysely/tables/backgroundJobsTable.js +0 -0
  2614. /package/packages/{supabase → database}/src/lib/kysely/tables/branchesTable.js +0 -0
  2615. /package/packages/{supabase → database}/src/lib/kysely/tables/commitBranchesTable.js +0 -0
  2616. /package/packages/{supabase → database}/src/lib/kysely/tables/entitiesTable.js +0 -0
  2617. /package/packages/{supabase → database}/src/lib/kysely/tables/entityBranchesTable.js +0 -0
  2618. /package/packages/{supabase → database}/src/lib/kysely/tables/entityStatementsTable.js +0 -0
  2619. /package/packages/{supabase → database}/src/lib/kysely/tables/filesTable.js +0 -0
  2620. /package/packages/{supabase → database}/src/lib/kysely/tables/githubPayloadsTable.js +0 -0
  2621. /package/packages/{supabase → database}/src/lib/kysely/tables/githubUsersTable.js +0 -0
  2622. /package/packages/{supabase → database}/src/lib/kysely/tables/projectsTable.js +0 -0
  2623. /package/packages/{supabase → database}/src/lib/kysely/tables/scenarioCommentsTable.js +0 -0
  2624. /package/packages/{supabase → database}/src/lib/kysely/tables/scenariosTable.js +0 -0
  2625. /package/packages/{supabase → database}/src/lib/kysely/tables/statementsTable.js +0 -0
  2626. /package/packages/{supabase → database}/src/lib/kysely/tables/teamsTable.js +0 -0
  2627. /package/packages/{supabase → database}/src/lib/kysely/tables/userScenariosTable.js +0 -0
  2628. /package/packages/{supabase → database}/src/lib/kysely/tables/userTeamsTable.js +0 -0
  2629. /package/packages/{supabase → database}/src/lib/kysely/tables/usersTable.js +0 -0
  2630. /package/packages/{supabase → database}/src/lib/kysely/upsertHelpers.js +0 -0
  2631. /package/packages/{supabase → database}/src/lib/loadAnalysisBranches.js +0 -0
  2632. /package/packages/{supabase → database}/src/lib/loadBackgroundJob.js +0 -0
  2633. /package/packages/{supabase → database}/src/lib/loadBranches.js +0 -0
  2634. /package/packages/{supabase → database}/src/lib/loadCommitBranches.js +0 -0
  2635. /package/packages/{supabase → database}/src/lib/loadCommitMetadata.js +0 -0
  2636. /package/packages/{supabase → database}/src/lib/loadEntity.js +0 -0
  2637. /package/packages/{supabase → database}/src/lib/loadFile.js +0 -0
  2638. /package/packages/{supabase → database}/src/lib/loadFiles.js +0 -0
  2639. /package/packages/{supabase → database}/src/lib/loadMostRecentPreviousAnalysis.js +0 -0
  2640. /package/packages/{supabase → database}/src/lib/loadProject.js +0 -0
  2641. /package/packages/{supabase → database}/src/lib/loadScenario.js +0 -0
  2642. /package/packages/{supabase → database}/src/lib/loadStatement.js +0 -0
  2643. /package/packages/{supabase → database}/src/lib/nullsToUndefines.js +0 -0
  2644. /package/packages/{supabase → database}/src/lib/saveBackgroundEvent.js +0 -0
  2645. /package/packages/{supabase → database}/src/lib/saveEntityStatements.js +0 -0
  2646. /package/packages/{supabase → database}/src/lib/saveStatement.js +0 -0
  2647. /package/packages/{supabase → database}/src/lib/supabase.js +0 -0
  2648. /package/packages/{supabase → database}/src/lib/updateBackgroundJobProgress.js +0 -0
  2649. /package/packages/{supabase → database}/src/lib/updateEntityBranch.js +0 -0
  2650. /package/packages/{supabase → database}/src/lib/updateFreshAnalysisMetadata.js +0 -0
  2651. /package/packages/{supabase → database}/src/lib/updateProjectMetadata.js +0 -0
  2652. /package/packages/{supabase → database}/src/lib/upsertAnalyses.js +0 -0
  2653. /package/packages/{supabase → database}/src/lib/upsertAnalysesWithScenarios.js +0 -0
  2654. /package/packages/{supabase → database}/src/lib/upsertAnalysisBranches.js +0 -0
  2655. /package/packages/{supabase → database}/src/lib/upsertBackgroundJob.js +0 -0
  2656. /package/packages/{supabase → database}/src/lib/upsertBranches.js +0 -0
  2657. /package/packages/{supabase → database}/src/lib/upsertCommitBranches.js +0 -0
  2658. /package/packages/{supabase → database}/src/lib/upsertCommits.js +0 -0
  2659. /package/packages/{supabase → database}/src/lib/upsertEntities.js +0 -0
  2660. /package/packages/{supabase → database}/src/lib/upsertEntityBranches.js +0 -0
  2661. /package/packages/{supabase → database}/src/lib/upsertFiles.js +0 -0
  2662. /package/packages/{supabase → database}/src/lib/upsertGithubUser.js +0 -0
  2663. /package/packages/{supabase → database}/src/lib/upsertProjects.js +0 -0
  2664. /package/packages/{supabase → database}/src/lib/upsertScenarios.js +0 -0
  2665. /package/{background/src/lib/process → packages/process/src}/GlobalProcessManager.js +0 -0
  2666. /package/{background/src/lib/process → packages/process/src}/index.js +0 -0
  2667. /package/{background/src/lib/process → packages/process/src}/managedExecAsync.js +0 -0
@@ -0,0 +1,2484 @@
1
+ /**
2
+ * Generates execution flows from conditional usages using pure static analysis.
3
+ *
4
+ * This replaces LLM-driven flow generation with deterministic flow generation
5
+ * based on conditionalUsages extracted from the AST. Only paths that resolve
6
+ * to controllable data sources (exist in attributesMap) produce flows.
7
+ *
8
+ * Flow generation rules:
9
+ * - truthiness conditions → truthy flow + falsy flow
10
+ * - comparison conditions → one flow per compared value
11
+ * - switch conditions → one flow per case value
12
+ * - compound conditionals → one flow with all conditions (only if ALL paths controllable)
13
+ */
14
+
15
+ import type { ExecutionFlow } from '~codeyam/types';
16
+ import type {
17
+ ConditionalUsage,
18
+ CompoundConditional,
19
+ DerivedVariableOperation,
20
+ DerivedVariableInfo,
21
+ JsxRenderingUsage,
22
+ } from './astScopes/types';
23
+ import type { EnrichedConditionalUsage } from './worker/SerializableDataStructure';
24
+ import resolvePathToControllable from './resolvePathToControllable';
25
+ import cleanPathOfNonTransformingFunctions from './dataStructure/helpers/cleanPathOfNonTransformingFunctions';
26
+
27
+ /** Extended conditional usage type that may include sourceDataPath from enrichment */
28
+ type ExtendedConditionalUsage = ConditionalUsage &
29
+ Partial<EnrichedConditionalUsage>;
30
+
31
+ /** Child component conditional data for merging child flows into parent */
32
+ export interface ChildComponentConditionalData {
33
+ /** Child's conditional usages keyed by variable name (may include sourceDataPath from enrichment) */
34
+ conditionalUsages: Record<string, ExtendedConditionalUsage[]>;
35
+ /** Child's equivalent signature variables (maps internal paths to prop paths) */
36
+ equivalentSignatureVariables: Record<string, string | string[]>;
37
+ /** Child's compound conditionals */
38
+ compoundConditionals: CompoundConditional[];
39
+ /**
40
+ * Gating conditions - the parent's conditions required to render this child component.
41
+ * For example, if the parent has `{hasAnalysis && <ChildComponent />}`,
42
+ * then `hasAnalysis` is a gating condition for all of ChildComponent's flows.
43
+ */
44
+ gatingConditions?: ConditionalUsage[];
45
+ /**
46
+ * Child's JSX rendering usages (arrays rendered via .map(), text interpolation).
47
+ * These generate "variation flows" for different array lengths.
48
+ */
49
+ jsxRenderingUsages?: JsxRenderingUsage[];
50
+ }
51
+
52
+ export interface GenerateFlowsFromConditionalsArgs {
53
+ /** Record of attribute paths to their conditional usages (may include sourceDataPath) */
54
+ conditionalUsages: Record<string, ExtendedConditionalUsage[]>;
55
+ /** Compound conditionals (&&-chained conditions) */
56
+ compoundConditionals: CompoundConditional[];
57
+ /** Map of controllable paths to their types */
58
+ attributesMap: Record<string, string>;
59
+ /** Map from local variable names to data sources */
60
+ equivalentSignatureVariables: Record<string, string | string[]>;
61
+ /** Map from full paths to short paths */
62
+ fullToShortPathMap: Record<string, string>;
63
+ /**
64
+ * Optional child component conditional data.
65
+ * Maps child component name to its conditional data.
66
+ * Used to merge child execution flows into parent.
67
+ */
68
+ childComponentData?: Record<string, ChildComponentConditionalData>;
69
+ /**
70
+ * Optional map of derived variables to their derivation info.
71
+ * Used to trace intermediate derived variables that aren't directly
72
+ * used in conditionals but are sources for other derived variables.
73
+ *
74
+ * Example:
75
+ * - `isInCurrentRun = currentRun.entityShas.includes(sha)` → { sourcePath: 'currentRun.entityShas', operation: 'arrayIncludes' }
76
+ * - `isAnalyzing = isInCurrentRun || isInQueue` → { sourcePaths: ['isInCurrentRun', 'isInQueue'], operation: 'or' }
77
+ *
78
+ * Without this map, we can't trace from `isAnalyzing` through `isInCurrentRun`
79
+ * to `currentRun.entityShas` when `isInCurrentRun` isn't in conditionalUsages.
80
+ */
81
+ derivedVariables?: Record<string, DerivedVariableInfo>;
82
+ /**
83
+ * Optional map of child prop paths to their actual data sources.
84
+ * Used when child props flow through useState but ultimately come from
85
+ * mockable data sources (e.g., API calls, fetchers).
86
+ *
87
+ * Example:
88
+ * - "WorkoutsView().signature[0].workouts" → "createClient()...functionCallReturnValue.data"
89
+ *
90
+ * When a child path translates to a useState value, we check this map
91
+ * to find the real data source that can be mocked.
92
+ */
93
+ sourceEquivalencies?: Record<
94
+ string,
95
+ Array<{ scopeNodeName: string; schemaPath: string }>
96
+ >;
97
+ }
98
+
99
+ /**
100
+ * Resolved source info from expanding a derived variable.
101
+ * Contains the path and the operation that led to it.
102
+ */
103
+ interface ResolvedSourceInfo {
104
+ path: string;
105
+ operation?:
106
+ | 'notNull'
107
+ | 'isNull'
108
+ | 'equals'
109
+ | 'notEquals'
110
+ | 'or'
111
+ | 'and'
112
+ | 'arrayIncludes'
113
+ | 'arraySome'
114
+ | 'arrayEvery'
115
+ | 'arrayLength';
116
+ }
117
+
118
+ /**
119
+ * Recursively expands a derived variable to its leaf data sources.
120
+ *
121
+ * For OR expressions like `isAnalyzing = a || b || c`:
122
+ * - Returns all source paths [a, b, c] so they can all be set appropriately
123
+ *
124
+ * For nested derivations like `isAnalyzing = isInCurrentRun || isInQueue`:
125
+ * - Where `isInCurrentRun` is derived from `currentRun.entityShas.includes(x)`
126
+ * - Returns the final data sources: [currentRun.entityShas, queueState.jobs]
127
+ *
128
+ * @param path The variable path to expand
129
+ * @param conditionalUsages All conditional usages (to look up derivedFrom info)
130
+ * @param attributesMap Map of controllable paths
131
+ * @param equivalentSignatureVariables Variable-to-path mappings
132
+ * @param fullToShortPathMap Full-to-short path mappings
133
+ * @param visited Set of already-visited paths (prevents infinite recursion)
134
+ * @param derivedVariables Optional map of all derived variables (for intermediate tracing)
135
+ * @returns Array of resolved source paths that are controllable
136
+ */
137
+ function expandDerivedVariableToSources(
138
+ path: string,
139
+ conditionalUsages: Record<string, ConditionalUsage[]>,
140
+ attributesMap: Record<string, string>,
141
+ equivalentSignatureVariables: Record<string, string | string[]>,
142
+ fullToShortPathMap: Record<string, string>,
143
+ visited: Set<string> = new Set(),
144
+ derivedVariables?: Record<string, DerivedVariableInfo>,
145
+ ): ResolvedSourceInfo[] {
146
+ // Prevent infinite recursion
147
+ if (visited.has(path)) {
148
+ return [];
149
+ }
150
+ visited.add(path);
151
+
152
+ // First, check if this path is directly controllable
153
+ const directResolution = resolvePathToControllable(
154
+ path,
155
+ attributesMap,
156
+ equivalentSignatureVariables,
157
+ fullToShortPathMap,
158
+ );
159
+
160
+ if (directResolution.isControllable && directResolution.resolvedPath) {
161
+ return [{ path: directResolution.resolvedPath }];
162
+ }
163
+
164
+ // Look up derivedFrom info for this path
165
+ // First check conditionalUsages, then fall back to derivedVariables
166
+ const usage = conditionalUsages[path]?.[0];
167
+ let derivedFrom = usage?.derivedFrom;
168
+
169
+ // CRITICAL: If not found in conditionalUsages, check derivedVariables
170
+ // This handles intermediate derived variables like `isInCurrentRun` that aren't
171
+ // directly used in conditionals but ARE derived from data sources
172
+ if (!derivedFrom && derivedVariables?.[path]) {
173
+ derivedFrom = derivedVariables[path];
174
+ }
175
+
176
+ if (!derivedFrom) {
177
+ return [];
178
+ }
179
+
180
+ const { operation, sourcePath, sourcePaths } = derivedFrom;
181
+
182
+ // For OR/AND operations, recursively expand all source paths
183
+ if ((operation === 'or' || operation === 'and') && sourcePaths) {
184
+ const allSources: ResolvedSourceInfo[] = [];
185
+
186
+ for (const sp of sourcePaths) {
187
+ const expanded = expandDerivedVariableToSources(
188
+ sp,
189
+ conditionalUsages,
190
+ attributesMap,
191
+ equivalentSignatureVariables,
192
+ fullToShortPathMap,
193
+ visited,
194
+ derivedVariables,
195
+ );
196
+
197
+ // Add all expanded sources
198
+ for (const source of expanded) {
199
+ // Avoid duplicates
200
+ if (!allSources.some((s) => s.path === source.path)) {
201
+ allSources.push(source);
202
+ }
203
+ }
204
+ }
205
+
206
+ return allSources;
207
+ }
208
+
209
+ // For single-source operations (arrayIncludes, arraySome, notNull, etc.)
210
+ if (sourcePath) {
211
+ // Try to resolve the source path directly
212
+ const sourceResolution = resolvePathToControllable(
213
+ sourcePath,
214
+ attributesMap,
215
+ equivalentSignatureVariables,
216
+ fullToShortPathMap,
217
+ );
218
+
219
+ if (sourceResolution.isControllable && sourceResolution.resolvedPath) {
220
+ return [{ path: sourceResolution.resolvedPath, operation }];
221
+ }
222
+
223
+ // If not directly resolvable, recursively expand
224
+ return expandDerivedVariableToSources(
225
+ sourcePath,
226
+ conditionalUsages,
227
+ attributesMap,
228
+ equivalentSignatureVariables,
229
+ fullToShortPathMap,
230
+ visited,
231
+ derivedVariables,
232
+ );
233
+ }
234
+
235
+ return [];
236
+ }
237
+
238
+ /**
239
+ * Clean up sourceDataPath by removing redundant scope prefixes.
240
+ *
241
+ * This function ONLY handles the specific pattern where a scope name is
242
+ * duplicated before the hook call:
243
+ *
244
+ * Example:
245
+ * "useLoaderData<LoaderData>.useLoaderData<LoaderData>().functionCallReturnValue.entity.sha"
246
+ * → "useLoaderData<LoaderData>().functionCallReturnValue.entity.sha"
247
+ *
248
+ * For paths with multiple function calls (like fetch().json()), or paths
249
+ * that don't match the expected pattern, returns null to indicate the
250
+ * fallback resolution should be used.
251
+ */
252
+ function cleanSourceDataPath(sourceDataPath: string): string | null {
253
+ // Count function call patterns - both empty () and with content (...)
254
+ // We detect multiple function calls by counting:
255
+ // 1. Empty () patterns
256
+ // 2. Patterns like functionName(...) - closing paren followed by dot or end
257
+ const emptyFnCalls = (sourceDataPath.match(/\(\)/g) || []).length;
258
+ const fnCallReturnValues = (
259
+ sourceDataPath.match(/\.functionCallReturnValue/g) || []
260
+ ).length;
261
+
262
+ // For chained function calls (e.g., fetch().json()) or paths with non-standard
263
+ // fn call patterns, return the original path so findInAttributesMapForPath can
264
+ // try to look it up in fullToShortPathMap. If it doesn't match, the caller
265
+ // falls through to fallback resolution anyway.
266
+ if (fnCallReturnValues > 1 || emptyFnCalls !== 1) {
267
+ console.log(
268
+ `[cleanSourceDataPath] chained/non-standard path (fnCallRVs=${fnCallReturnValues}, emptyFnCalls=${emptyFnCalls}), returning original: "${sourceDataPath}"`,
269
+ );
270
+ return sourceDataPath;
271
+ }
272
+
273
+ // Find the "()" which marks the function call
274
+ const fnCallIndex = sourceDataPath.indexOf('()');
275
+
276
+ // Find where the function name starts (go back to find the start of this segment)
277
+ const beforeFnCall = sourceDataPath.slice(0, fnCallIndex);
278
+ const lastDotBeforeFn = beforeFnCall.lastIndexOf('.');
279
+
280
+ if (lastDotBeforeFn === -1) {
281
+ return sourceDataPath;
282
+ }
283
+
284
+ // Extract the scope prefix and the actual path
285
+ const scopePrefix = sourceDataPath.slice(0, lastDotBeforeFn);
286
+ const actualPath = sourceDataPath.slice(lastDotBeforeFn + 1);
287
+
288
+ // Verify this is actually a redundant scope prefix pattern
289
+ // The actualPath should start with something that matches the scopePrefix
290
+ // e.g., scopePrefix="useLoaderData<LoaderData>" and actualPath starts with "useLoaderData<LoaderData>()..."
291
+ if (!actualPath.startsWith(scopePrefix.split('.').pop() || '')) {
292
+ // Not a redundant prefix pattern - return the original path
293
+ return sourceDataPath;
294
+ }
295
+
296
+ return actualPath;
297
+ }
298
+
299
+ /**
300
+ * Strip .length suffix from a path if present.
301
+ *
302
+ * When we have a path like "items.length", the controllable attribute is "items"
303
+ * (the array), not "items.length". The length is derived from the array contents.
304
+ *
305
+ * This ensures that execution flows reference the actual controllable attribute
306
+ * rather than the derived .length property.
307
+ */
308
+ function stripLengthSuffix(path: string): string {
309
+ if (path.endsWith('.length')) {
310
+ return path.slice(0, -7); // Remove ".length" (7 characters)
311
+ }
312
+ return path;
313
+ }
314
+
315
+ /**
316
+ * Remove contradictory required values from a compound flow.
317
+ *
318
+ * When a lifecycle boolean (like isLoadingAuditData) is traced to a fetch call's
319
+ * return value, a negated condition (!isLoadingAuditData) produces "falsy" on
320
+ * the fetch path. But if another condition in the same compound requires data
321
+ * from a sub-path of that fetch (e.g., topPaths length > 0), the "falsy" on the
322
+ * parent path contradicts it — a null/falsy response has no .json() to call.
323
+ *
324
+ * This function removes "falsy" required values whose attributePath is a prefix
325
+ * of another required value's attributePath. The child data requirement already
326
+ * implies the parent (fetch) succeeded.
327
+ */
328
+ function removeContradictoryFalsyValues(
329
+ requiredValues: ExecutionFlow['requiredValues'],
330
+ ): ExecutionFlow['requiredValues'] {
331
+ return requiredValues.filter((rv) => {
332
+ if (rv.comparison === 'falsy') {
333
+ const hasChildRequirement = requiredValues.some(
334
+ (other) =>
335
+ other !== rv &&
336
+ other.attributePath.startsWith(rv.attributePath + '.'),
337
+ );
338
+ if (hasChildRequirement) {
339
+ return false;
340
+ }
341
+ }
342
+ return true;
343
+ });
344
+ }
345
+
346
+ /**
347
+ * Generate a human-readable description snippet for a required value,
348
+ * incorporating the comparison type so the LLM understands the intent.
349
+ */
350
+ function describeRequiredValue(rv: ExecutionFlow['requiredValues'][0]): string {
351
+ const name = generateNameFromPath(rv.attributePath).toLowerCase();
352
+ switch (rv.comparison) {
353
+ case 'truthy':
354
+ return `${name} is present`;
355
+ case 'falsy':
356
+ return `${name} is absent`;
357
+ case 'length>':
358
+ return rv.value === '0'
359
+ ? `${name} has items`
360
+ : `${name} has more than ${rv.value} items`;
361
+ case 'length<':
362
+ return `${name} has fewer than ${rv.value} items`;
363
+ case 'equals':
364
+ return `${name} is ${rv.value}`;
365
+ case 'exists':
366
+ return `${name} exists`;
367
+ case 'not-exists':
368
+ return `${name} does not exist`;
369
+ default:
370
+ return `${name} is ${rv.value}`;
371
+ }
372
+ }
373
+
374
+ /**
375
+ * Check whether a resolved path has child entries in the fullToShortPathMap.
376
+ *
377
+ * When a lifecycle boolean (e.g., isLoadingAuditData) resolves to a parent path
378
+ * like fetch(...).functionCallReturnValue, and that path has children (like
379
+ * .json().functionCallReturnValue.topPaths), individual truthy/falsy flows on
380
+ * the parent are misleading. Compound flows with specific child requirements
381
+ * provide better guidance for mock data generation.
382
+ */
383
+ function hasChildPathsInMap(
384
+ resolvedPath: string,
385
+ fullToShortPathMap: Record<string, string>,
386
+ ): boolean {
387
+ return Object.keys(fullToShortPathMap).some(
388
+ (fullPath) =>
389
+ fullPath.startsWith(resolvedPath + '.') ||
390
+ fullPath.startsWith(resolvedPath + '['),
391
+ );
392
+ }
393
+
394
+ /**
395
+ * Extract the controllable base path from a path that may contain method calls.
396
+ *
397
+ * This handles complex expressions like:
398
+ * - `scenarios.filter((s) => s.active).length` → `scenarios`
399
+ * - `users.some((u) => u.role === 'admin')` → `users`
400
+ * - `items.map(x => x.name).join(', ')` → `items`
401
+ *
402
+ * The controllable base is the path that can be mocked - we can control
403
+ * what `scenarios` contains, but we can't control what `.filter()` returns.
404
+ *
405
+ * @param path - The path that may contain method calls
406
+ * @returns The controllable base path with method calls stripped
407
+ */
408
+ function extractControllableBase(path: string): string {
409
+ // First strip .length suffix if present
410
+ const pathWithoutLength = stripLengthSuffix(path);
411
+
412
+ // Use cleanPathOfNonTransformingFunctions to strip method calls like .filter(), .some()
413
+ const cleanedPath = cleanPathOfNonTransformingFunctions(pathWithoutLength);
414
+
415
+ // If the cleaned path is different, return it
416
+ if (cleanedPath !== pathWithoutLength) {
417
+ return cleanedPath;
418
+ }
419
+
420
+ // Otherwise, return the path with just .length stripped
421
+ return pathWithoutLength;
422
+ }
423
+
424
+ /**
425
+ * Find a path in attributesMap, using fullToShortPathMap to verify the path is controllable.
426
+ *
427
+ * IMPORTANT: Returns the FULL path (preserving data source context) when possible.
428
+ * This ensures execution flows can be traced back to specific data sources,
429
+ * which is critical when multiple data sources have the same property names
430
+ * (e.g., multiple useFetcher hooks all having 'state' and 'data').
431
+ *
432
+ * The attributesMap contains short relative paths (e.g., "entity.sha")
433
+ * The sourceDataPath contains full paths (e.g., "useLoaderData<LoaderData>().functionCallReturnValue.entity.sha")
434
+ * The fullToShortPathMap maps full paths to short paths
435
+ */
436
+ export function findInAttributesMapForPath(
437
+ path: string,
438
+ attributesMap: Record<string, string>,
439
+ fullToShortPathMap: Record<string, string>,
440
+ ): string | null {
441
+ // Direct match in attributesMap (already a short path)
442
+ if (path in attributesMap) {
443
+ console.log(
444
+ `[findInAttributesMapForPath] "${path}" → DIRECT match in attributesMap`,
445
+ );
446
+ return path;
447
+ }
448
+
449
+ // Try looking up the path in fullToShortPathMap to verify it's controllable
450
+ // IMPORTANT: Return the FULL path, not the short path, to preserve data source context
451
+ if (path in fullToShortPathMap) {
452
+ const shortPath = fullToShortPathMap[path];
453
+ if (shortPath in attributesMap) {
454
+ console.log(
455
+ `[findInAttributesMapForPath] "${path}" → fullToShortPathMap match: shortPath="${shortPath}" found in attributesMap`,
456
+ );
457
+ return path; // Return FULL path to preserve data source context
458
+ }
459
+ console.log(
460
+ `[findInAttributesMapForPath] "${path}" → fullToShortPathMap match shortPath="${shortPath}" but NOT in attributesMap`,
461
+ );
462
+ }
463
+
464
+ // Normalized match (array indices [N] → [])
465
+ const normalizedPath = path.replace(/\[\d+\]/g, '[]');
466
+ if (normalizedPath !== path) {
467
+ if (normalizedPath in attributesMap) {
468
+ console.log(
469
+ `[findInAttributesMapForPath] "${path}" → normalized "${normalizedPath}" DIRECT match in attributesMap`,
470
+ );
471
+ return normalizedPath;
472
+ }
473
+ if (normalizedPath in fullToShortPathMap) {
474
+ const shortPath = fullToShortPathMap[normalizedPath];
475
+ if (shortPath in attributesMap) {
476
+ console.log(
477
+ `[findInAttributesMapForPath] "${path}" → normalized "${normalizedPath}" fullToShortPathMap match: shortPath="${shortPath}"`,
478
+ );
479
+ return normalizedPath; // Return normalized FULL path
480
+ }
481
+ }
482
+ }
483
+
484
+ // Try prefix matching for child paths
485
+ // e.g., path is "entity.sha.something" and attributesMap has "entity.sha"
486
+ // OR path is a full path like "useLoaderData<...>().functionCallReturnValue.entity.sha"
487
+ // and we need to find matching short path prefix
488
+ for (const attrPath of Object.keys(attributesMap)) {
489
+ if (path.startsWith(attrPath + '.') || path.startsWith(attrPath + '[')) {
490
+ console.log(
491
+ `[findInAttributesMapForPath] "${path}" → PREFIX match: starts with attributesMap key "${attrPath}"`,
492
+ );
493
+ return path;
494
+ }
495
+ }
496
+
497
+ // Try suffix matching: if the path ends with ".X.Y.Z" and attributesMap has "X.Y.Z"
498
+ // Return the FULL input path to preserve data source context
499
+ // Skip suffix matching for chained function calls (multiple .functionCallReturnValue segments)
500
+ // to avoid false matches: e.g., fetch(...).json().functionCallReturnValue.data falsely matching
501
+ // "data" from a completely different data source like useFetcher
502
+ const fnCallReturnValueCount = (
503
+ path.match(/\.functionCallReturnValue/g) || []
504
+ ).length;
505
+ if (fnCallReturnValueCount <= 1) {
506
+ for (const attrPath of Object.keys(attributesMap)) {
507
+ if (
508
+ path.endsWith('.' + attrPath) ||
509
+ path.endsWith('.' + attrPath.replace(/\[\d+\]/g, '[]'))
510
+ ) {
511
+ console.log(
512
+ `[findInAttributesMapForPath] "${path}" → SUFFIX match: ends with attributesMap key "${attrPath}"`,
513
+ );
514
+ return path; // Return FULL path, not short attrPath
515
+ }
516
+ }
517
+ }
518
+
519
+ // Try child path matching against fullToShortPathMap keys
520
+ // If the path starts with a known full path + '.' or '[', it's a child
521
+ // of a controllable path. Build the equivalent short child path.
522
+ // e.g., path = "fetch(...).fCRV.json().fCRV.topPaths.length"
523
+ // fullToShortPathMap has "fetch(...).fCRV.json().fCRV.topPaths" → "json().fCRV.topPaths"
524
+ // → check if "json().fCRV.topPaths.length" is in attributesMap
525
+ for (const [fullPath, shortPath] of Object.entries(fullToShortPathMap)) {
526
+ if (path.startsWith(fullPath + '.') || path.startsWith(fullPath + '[')) {
527
+ const suffix = path.slice(fullPath.length); // e.g., ".length"
528
+ const shortChildPath = shortPath + suffix;
529
+ if (shortChildPath in attributesMap) {
530
+ console.log(
531
+ `[findInAttributesMapForPath] "${path}" → CHILD of fullToShortPathMap key "${fullPath}": shortChildPath="${shortChildPath}" found in attributesMap`,
532
+ );
533
+ return path; // Return full path to preserve data source context
534
+ }
535
+ // Also check if the base short path is an array and suffix is .length
536
+ if (suffix === '.length' && shortPath in attributesMap) {
537
+ console.log(
538
+ `[findInAttributesMapForPath] "${path}" → CHILD .length of fullToShortPathMap key "${fullPath}": base shortPath="${shortPath}" is in attributesMap (array .length)`,
539
+ );
540
+ return path; // Array .length is controllable via the array
541
+ }
542
+ }
543
+ }
544
+
545
+ // Try parent matching: if the path is a prefix of any fullToShortPathMap key,
546
+ // it's a parent of controllable data and therefore controllable itself
547
+ for (const fullPath of Object.keys(fullToShortPathMap)) {
548
+ if (fullPath.startsWith(path + '.') || fullPath.startsWith(path + '[')) {
549
+ console.log(
550
+ `[findInAttributesMapForPath] "${path}" → PARENT match: fullToShortPathMap key "${fullPath}" starts with this path`,
551
+ );
552
+ return path;
553
+ }
554
+ }
555
+
556
+ console.log(
557
+ `[findInAttributesMapForPath] "${path}" → NO MATCH (checked ${Object.keys(attributesMap).length} attributesMap keys, ${Object.keys(fullToShortPathMap).length} fullToShortPathMap keys)`,
558
+ );
559
+ return null;
560
+ }
561
+
562
+ /**
563
+ * Generate a slug from a path for use in flow IDs and exclusive groups.
564
+ */
565
+ function pathToSlug(path: string): string {
566
+ return path
567
+ .replace(/\[\d+\]/g, '')
568
+ .replace(/\[\]/g, '')
569
+ .replace(/\(\)/g, '')
570
+ .replace(/\.functionCallReturnValue/g, '')
571
+ .replace(/[<>]/g, '')
572
+ .replace(/\./g, '-')
573
+ .toLowerCase();
574
+ }
575
+
576
+ /**
577
+ * Generate a human-readable name from a path.
578
+ * Extracts the last meaningful part of the path.
579
+ *
580
+ * Examples:
581
+ * - "useFetcher<...>().functionCallReturnValue.state" → "state"
582
+ * - "useLoaderData<...>().functionCallReturnValue.user.isActive" → "isActive"
583
+ */
584
+ function generateNameFromPath(path: string): string {
585
+ // Remove function call markers and get the last meaningful segment
586
+ const cleanPath = path
587
+ .replace(/\(\)/g, '')
588
+ .replace(/\.functionCallReturnValue/g, '');
589
+ const parts = cleanPath.split('.');
590
+ const lastPart = parts[parts.length - 1];
591
+
592
+ // Convert camelCase to Title Case with spaces
593
+ return lastPart
594
+ .replace(/([A-Z])/g, ' $1')
595
+ .replace(/^./, (str) => str.toUpperCase())
596
+ .trim();
597
+ }
598
+
599
+ /**
600
+ * Generate a flow ID from path and value.
601
+ * Creates a unique, URL-safe identifier.
602
+ */
603
+ function generateFlowId(path: string, value: string): string {
604
+ // Clean the path for use in ID
605
+ const cleanPath = path
606
+ .replace(/\(\)/g, '')
607
+ .replace(/\.functionCallReturnValue/g, '')
608
+ .replace(/[<>]/g, '')
609
+ .replace(/\./g, '-');
610
+
611
+ // Clean the value
612
+ const cleanValue = value
613
+ .toString()
614
+ .toLowerCase()
615
+ .replace(/[^a-z0-9]/g, '-')
616
+ .replace(/-+/g, '-')
617
+ .replace(/^-|-$/g, '');
618
+
619
+ return `${cleanPath}-${cleanValue}`.toLowerCase();
620
+ }
621
+
622
+ /**
623
+ * Infer value type from a string value.
624
+ */
625
+ function inferValueType(
626
+ value: string,
627
+ ): 'string' | 'number' | 'boolean' | 'null' {
628
+ if (value === 'true' || value === 'false') return 'boolean';
629
+ if (value === 'null' || value === 'undefined') return 'null';
630
+ if (!isNaN(Number(value)) && value !== '') return 'number';
631
+ return 'string';
632
+ }
633
+
634
+ /**
635
+ * Generate flows from a single conditional usage.
636
+ * Sets impact to 'high' if the conditional controls JSX rendering.
637
+ *
638
+ * When the usage has a `constraintExpression`, it represents a complex expression
639
+ * that can't be simply resolved (e.g., `scenarios.filter(x => x.active).length > 1`).
640
+ * In this case:
641
+ * - `attributePath` is set to the controllable base (e.g., `scenarios`)
642
+ * - `constraint` is set to the full expression for LLM reasoning
643
+ */
644
+ function generateFlowsFromUsage(
645
+ usage: ConditionalUsage,
646
+ resolvedPath: string,
647
+ ): ExecutionFlow[] {
648
+ const flows: ExecutionFlow[] = [];
649
+ const baseName = generateNameFromPath(resolvedPath);
650
+
651
+ // Determine impact based on whether this conditional controls JSX rendering
652
+ // Conditionals that control visual output are high-impact
653
+ const impact: ExecutionFlow['impact'] = usage.controlsJsxRendering
654
+ ? 'high'
655
+ : 'medium';
656
+
657
+ // When there's a constraintExpression, use the controllable base for attributePath
658
+ // and pass through the constraint for LLM reasoning
659
+ const hasConstraint = !!usage.constraintExpression;
660
+ const attributePath = hasConstraint
661
+ ? extractControllableBase(resolvedPath)
662
+ : stripLengthSuffix(resolvedPath);
663
+ const constraint = usage.constraintExpression;
664
+
665
+ if (usage.conditionType === 'truthiness') {
666
+ // Generate both truthy and falsy flows
667
+ const isNegated = usage.isNegated ?? false;
668
+
669
+ // Truthy flow (or falsy if negated)
670
+ flows.push({
671
+ id: generateFlowId(resolvedPath, isNegated ? 'falsy' : 'truthy'),
672
+ name: `${baseName} ${isNegated ? 'False' : 'True'}`,
673
+ description: `When ${baseName.toLowerCase()} is ${isNegated ? 'falsy' : 'truthy'}`,
674
+ requiredValues: [
675
+ {
676
+ attributePath,
677
+ value: isNegated ? 'falsy' : 'truthy',
678
+ comparison: isNegated ? 'falsy' : 'truthy',
679
+ valueType: 'boolean',
680
+ constraint,
681
+ },
682
+ ],
683
+ impact,
684
+ sourceLocation: usage.sourceLocation
685
+ ? {
686
+ lineNumber: usage.sourceLocation.lineNumber,
687
+ column: usage.sourceLocation.column,
688
+ }
689
+ : undefined,
690
+ codeSnippet: usage.sourceLocation?.codeSnippet,
691
+ });
692
+
693
+ // Falsy flow (or truthy if negated)
694
+ flows.push({
695
+ id: generateFlowId(resolvedPath, isNegated ? 'truthy' : 'falsy'),
696
+ name: `${baseName} ${isNegated ? 'True' : 'False'}`,
697
+ description: `When ${baseName.toLowerCase()} is ${isNegated ? 'truthy' : 'falsy'}`,
698
+ requiredValues: [
699
+ {
700
+ attributePath,
701
+ value: isNegated ? 'truthy' : 'falsy',
702
+ comparison: isNegated ? 'truthy' : 'falsy',
703
+ valueType: 'boolean',
704
+ constraint,
705
+ },
706
+ ],
707
+ impact,
708
+ sourceLocation: usage.sourceLocation
709
+ ? {
710
+ lineNumber: usage.sourceLocation.lineNumber,
711
+ column: usage.sourceLocation.column,
712
+ }
713
+ : undefined,
714
+ codeSnippet: usage.sourceLocation?.codeSnippet,
715
+ });
716
+ } else if (
717
+ usage.conditionType === 'comparison' ||
718
+ usage.conditionType === 'switch'
719
+ ) {
720
+ // Generate one flow per compared value
721
+ const values = usage.comparedValues ?? [];
722
+
723
+ for (const value of values) {
724
+ flows.push({
725
+ id: generateFlowId(resolvedPath, value),
726
+ name: `${baseName}: ${value}`,
727
+ description: `When ${baseName.toLowerCase()} equals "${value}"`,
728
+ requiredValues: [
729
+ {
730
+ attributePath,
731
+ value: value,
732
+ comparison: 'equals',
733
+ valueType: inferValueType(value),
734
+ constraint,
735
+ },
736
+ ],
737
+ impact,
738
+ sourceLocation: usage.sourceLocation
739
+ ? {
740
+ lineNumber: usage.sourceLocation.lineNumber,
741
+ column: usage.sourceLocation.column,
742
+ }
743
+ : undefined,
744
+ codeSnippet: usage.sourceLocation?.codeSnippet,
745
+ });
746
+ }
747
+ }
748
+
749
+ return flows;
750
+ }
751
+
752
+ /**
753
+ * Generate a flow from a compound conditional (all conditions must be satisfied).
754
+ * Sets impact to 'high' if the compound conditional controls JSX rendering.
755
+ */
756
+ function generateFlowFromCompound(
757
+ compound: CompoundConditional,
758
+ resolvedPaths: Map<string, string>,
759
+ ): ExecutionFlow | null {
760
+ // Determine impact based on whether this compound conditional controls JSX rendering
761
+ const impact: ExecutionFlow['impact'] = compound.controlsJsxRendering
762
+ ? 'high'
763
+ : 'medium';
764
+ const requiredValues: ExecutionFlow['requiredValues'] = [];
765
+
766
+ for (const condition of compound.conditions) {
767
+ const resolvedPath = resolvedPaths.get(condition.path);
768
+ if (!resolvedPath) {
769
+ // This shouldn't happen if we pre-filtered, but safety check
770
+ return null;
771
+ }
772
+
773
+ // Determine the required value based on condition type
774
+ let value: string;
775
+ let comparison: ExecutionFlow['requiredValues'][0]['comparison'];
776
+
777
+ if (condition.conditionType === 'truthiness') {
778
+ // If negated (!foo), we need falsy; otherwise truthy
779
+ value = condition.isNegated ? 'falsy' : 'truthy';
780
+ comparison = condition.isNegated ? 'falsy' : 'truthy';
781
+ } else {
782
+ // For comparison/switch, use the first compared value or required value
783
+ value =
784
+ condition.requiredValue?.toString() ??
785
+ condition.comparedValues?.[0] ??
786
+ 'truthy';
787
+ // Map comparison operator to flow comparison type
788
+ const op = condition.comparisonOperator;
789
+ if (op === '>' || op === '>=') {
790
+ comparison = 'length>';
791
+ } else if (op === '<' || op === '<=') {
792
+ comparison = 'length<';
793
+ } else {
794
+ comparison = 'equals';
795
+ }
796
+ }
797
+
798
+ requiredValues.push({
799
+ attributePath: stripLengthSuffix(resolvedPath),
800
+ value,
801
+ comparison,
802
+ valueType: inferValueType(value),
803
+ });
804
+ }
805
+
806
+ // Remove contradictory "falsy" values where a child path requires data
807
+ const cleanedValues = removeContradictoryFalsyValues(requiredValues);
808
+
809
+ if (cleanedValues.length === 0) {
810
+ return null;
811
+ }
812
+
813
+ // Generate a combined ID from all paths + values to distinguish different comparisons
814
+ const pathParts = cleanedValues
815
+ .map((rv) => {
816
+ const name = generateNameFromPath(rv.attributePath);
817
+ const suffix =
818
+ rv.comparison === 'truthy' || rv.comparison === 'falsy'
819
+ ? `-${rv.comparison}`
820
+ : `-${rv.comparison}-${rv.value}`;
821
+ return name.toLowerCase().replace(/\s+/g, '-') + suffix;
822
+ })
823
+ .join('-and-');
824
+
825
+ return {
826
+ id: `compound-${pathParts}`,
827
+ name: cleanedValues
828
+ .map((rv) => generateNameFromPath(rv.attributePath))
829
+ .join(' + '),
830
+ description: `When ${cleanedValues.map((rv) => describeRequiredValue(rv)).join(' and ')}`,
831
+ requiredValues: cleanedValues,
832
+ impact,
833
+ sourceLocation: {
834
+ lineNumber: compound.sourceLocation.lineNumber,
835
+ column: compound.sourceLocation.column,
836
+ },
837
+ codeSnippet: compound.sourceLocation.codeSnippet,
838
+ };
839
+ }
840
+
841
+ /**
842
+ * Expand a compound conditional with OR groups into multiple condition sets.
843
+ *
844
+ * For a compound like `A && (B || C)`:
845
+ * - Conditions: [{ path: 'A' }, { path: 'B', orGroupId: 'or_xxx' }, { path: 'C', orGroupId: 'or_xxx' }]
846
+ * - Returns: [[A, B], [A, C]] - two sets of conditions
847
+ *
848
+ * For multiple OR groups like `A && (B || C) && (D || E)`:
849
+ * - Returns: [[A, B, D], [A, B, E], [A, C, D], [A, C, E]]
850
+ */
851
+ function expandOrGroups(
852
+ conditions: CompoundConditional['conditions'],
853
+ ): CompoundConditional['conditions'][] {
854
+ // Separate conditions into mandatory (no orGroupId) and OR groups
855
+ const mandatory = conditions.filter((c) => !c.orGroupId);
856
+ const orGroups = new Map<string, typeof conditions>();
857
+
858
+ for (const condition of conditions) {
859
+ if (condition.orGroupId) {
860
+ const group = orGroups.get(condition.orGroupId) ?? [];
861
+ group.push(condition);
862
+ orGroups.set(condition.orGroupId, group);
863
+ }
864
+ }
865
+
866
+ // If no OR groups, return the original conditions
867
+ if (orGroups.size === 0) {
868
+ return [conditions];
869
+ }
870
+
871
+ // Generate all combinations by picking one condition from each OR group
872
+ const groupArrays = Array.from(orGroups.values());
873
+ const combinations: CompoundConditional['conditions'][] = [];
874
+
875
+ function generateCombinations(
876
+ index: number,
877
+ current: typeof conditions,
878
+ ): void {
879
+ if (index === groupArrays.length) {
880
+ // We've picked one from each OR group - combine with mandatory conditions
881
+ combinations.push([...mandatory, ...current]);
882
+ return;
883
+ }
884
+
885
+ // Pick each option from the current OR group
886
+ for (const option of groupArrays[index]) {
887
+ generateCombinations(index + 1, [...current, option]);
888
+ }
889
+ }
890
+
891
+ generateCombinations(0, []);
892
+ return combinations;
893
+ }
894
+
895
+ /**
896
+ * Generate execution flows from conditional usages using pure static analysis.
897
+ *
898
+ * Only generates flows where all paths resolve to controllable data sources.
899
+ * This ensures we never produce flows with invalid paths like useState variables.
900
+ */
901
+ /**
902
+ * Normalize a resolved path to a canonical form for deduplication.
903
+ * Uses fullToShortPathMap to convert full paths to short paths.
904
+ * This ensures that both "hasNewerVersion" and
905
+ * "useLoaderData<LoaderData>().functionCallReturnValue.hasNewerVersion"
906
+ * normalize to the same canonical path.
907
+ */
908
+ function normalizePathForDeduplication(
909
+ resolvedPath: string,
910
+ fullToShortPathMap: Record<string, string>,
911
+ ): string {
912
+ // If the path is in fullToShortPathMap, use the short path as canonical
913
+ if (resolvedPath in fullToShortPathMap) {
914
+ return fullToShortPathMap[resolvedPath];
915
+ }
916
+ // Otherwise, the path itself is canonical
917
+ return resolvedPath;
918
+ }
919
+
920
+ /**
921
+ * Translate a child component path to a parent path using prop mappings.
922
+ *
923
+ * Given:
924
+ * - childPath: "selectedScenario.metadata.screenshotPaths[0]" (path in child's context)
925
+ * - childEquiv: { selectedScenario: "signature[0].selectedScenario" } (child's internal-to-prop mapping)
926
+ * - parentEquiv: { "ChildName().signature[0].selectedScenario": "selectedScenario" } (parent's prop assignments)
927
+ * - childName: "ChildName"
928
+ *
929
+ * Returns: "selectedScenario.metadata.screenshotPaths[0]" (path in parent's context)
930
+ *
931
+ * The translation works by:
932
+ * 1. Finding the root variable in the child path (e.g., "selectedScenario")
933
+ * 2. Looking up the child's equivalence to find the prop path (e.g., "signature[0].selectedScenario")
934
+ * 3. Building the full child prop path (e.g., "ChildName().signature[0].selectedScenario")
935
+ * 4. Looking up the parent's equivalence to find the parent path (e.g., "selectedScenario")
936
+ * 5. Replacing the root with the parent path and preserving the suffix
937
+ */
938
+ function translateChildPathToParent(
939
+ childPath: string,
940
+ childEquivalentSignatureVariables: Record<string, string | string[]>,
941
+ parentEquivalentSignatureVariables: Record<string, string | string[]>,
942
+ childName: string,
943
+ ): string | null {
944
+ // Extract the root variable from the child path
945
+ // e.g., "selectedScenario.metadata.screenshotPaths[0]" → "selectedScenario"
946
+ const dotIndex = childPath.indexOf('.');
947
+ const bracketIndex = childPath.indexOf('[');
948
+ let rootVar: string;
949
+ let suffix: string;
950
+
951
+ if (dotIndex === -1 && bracketIndex === -1) {
952
+ rootVar = childPath;
953
+ suffix = '';
954
+ } else if (dotIndex === -1) {
955
+ rootVar = childPath.slice(0, bracketIndex);
956
+ suffix = childPath.slice(bracketIndex);
957
+ } else if (bracketIndex === -1) {
958
+ rootVar = childPath.slice(0, dotIndex);
959
+ suffix = childPath.slice(dotIndex);
960
+ } else {
961
+ const firstIndex = Math.min(dotIndex, bracketIndex);
962
+ rootVar = childPath.slice(0, firstIndex);
963
+ suffix = childPath.slice(firstIndex);
964
+ }
965
+
966
+ // Look up the child's equivalence for this root variable
967
+ // e.g., childEquiv[selectedScenario] = "signature[0].selectedScenario"
968
+ // Handle array case (OR expressions) - use first element if array
969
+ const rawChildPropPath = childEquivalentSignatureVariables[rootVar];
970
+ const childPropPath = Array.isArray(rawChildPropPath)
971
+ ? rawChildPropPath[0]
972
+ : rawChildPropPath;
973
+
974
+ if (!childPropPath) {
975
+ // No mapping found - this might be internal state, not a prop
976
+ return null;
977
+ }
978
+
979
+ // Build the full child prop path as seen from parent
980
+ // e.g., "ChildName().signature[0].selectedScenario"
981
+ const fullChildPropPath = `${childName}().${childPropPath}`;
982
+
983
+ // Look up parent's equivalence to find what value was passed to this prop
984
+ // e.g., parentEquiv["ChildName().signature[0].selectedScenario"] = "selectedScenario"
985
+ // Handle array case (OR expressions) - use first element if array
986
+ const rawParentValue = parentEquivalentSignatureVariables[fullChildPropPath];
987
+ const parentValue = Array.isArray(rawParentValue)
988
+ ? rawParentValue[0]
989
+ : rawParentValue;
990
+
991
+ if (!parentValue) {
992
+ // No parent mapping found - log ALL parent keys that contain the childName
993
+ const relevantParentKeys = Object.keys(
994
+ parentEquivalentSignatureVariables,
995
+ ).filter((k) => k.includes(childName));
996
+ return null;
997
+ }
998
+
999
+ // Build the translated path: parentValue + suffix
1000
+ // e.g., "selectedScenario" + ".metadata.screenshotPaths[0]"
1001
+ const result = parentValue + suffix;
1002
+ return result;
1003
+ }
1004
+
1005
+ export default function generateExecutionFlowsFromConditionals(
1006
+ args: GenerateFlowsFromConditionalsArgs,
1007
+ ): ExecutionFlow[] {
1008
+ const {
1009
+ conditionalUsages,
1010
+ compoundConditionals,
1011
+ attributesMap,
1012
+ equivalentSignatureVariables,
1013
+ fullToShortPathMap,
1014
+ childComponentData,
1015
+ derivedVariables,
1016
+ sourceEquivalencies,
1017
+ } = args;
1018
+
1019
+ const flows: ExecutionFlow[] = [];
1020
+ const seenFlowIds = new Set<string>();
1021
+
1022
+ console.log(
1023
+ `[genFlowsFromConditionals] INPUT: ${Object.keys(conditionalUsages).length} conditional paths, ${Object.keys(attributesMap).length} attributesMap entries, ${Object.keys(fullToShortPathMap).length} fullToShortPathMap entries, ${Object.keys(equivalentSignatureVariables).length} equivSigVars, ${compoundConditionals.length} compound conditionals`,
1024
+ );
1025
+ console.log(
1026
+ `[genFlowsFromConditionals] conditionalUsages keys: [${Object.keys(conditionalUsages).join(', ')}]`,
1027
+ );
1028
+ console.log(
1029
+ `[genFlowsFromConditionals] attributesMap keys: [${Object.keys(attributesMap).join(', ')}]`,
1030
+ );
1031
+ console.log(
1032
+ `[genFlowsFromConditionals] fullToShortPathMap: ${JSON.stringify(fullToShortPathMap)}`,
1033
+ );
1034
+ console.log(
1035
+ `[genFlowsFromConditionals] equivalentSignatureVariables: ${JSON.stringify(equivalentSignatureVariables)}`,
1036
+ );
1037
+
1038
+ // Track normalized resolved paths to prevent duplicate flows
1039
+ // This handles the case where we have usages for both:
1040
+ // - "hasNewerVersion" (short path from destructured variable)
1041
+ // - "useLoaderData<LoaderData>().functionCallReturnValue.hasNewerVersion" (full path)
1042
+ // Both resolve to the same logical data source, so we only want ONE set of flows.
1043
+ const seenNormalizedPaths = new Set<string>();
1044
+
1045
+ // Track which usages are part of compound conditionals (to avoid duplicates)
1046
+ const compoundChainIds = new Set(
1047
+ compoundConditionals.map((c) => c.chainId).filter(Boolean),
1048
+ );
1049
+
1050
+ // Process individual conditional usages
1051
+ for (const [_path, usages] of Object.entries(conditionalUsages)) {
1052
+ for (const usage of usages) {
1053
+ // Skip usages that are part of compound conditionals (handled separately)
1054
+ if (usage.chainId && compoundChainIds.has(usage.chainId)) {
1055
+ console.log(
1056
+ `[genFlowsFromConditionals] "${usage.path}" SKIP: part of compound conditional chain=${usage.chainId}`,
1057
+ );
1058
+ continue;
1059
+ }
1060
+
1061
+ console.log(
1062
+ `[genFlowsFromConditionals] --- Processing "${usage.path}" (type=${usage.conditionType}, negated=${usage.isNegated}, sourceDataPath="${usage.sourceDataPath ?? '(none)'}", derivedFrom=${usage.derivedFrom ? JSON.stringify(usage.derivedFrom) : 'none'})`,
1063
+ );
1064
+
1065
+ // First, try to use pre-computed sourceDataPath if available
1066
+ let resolvedPath: string | null = null;
1067
+
1068
+ if (usage.sourceDataPath) {
1069
+ // Clean up the sourceDataPath - it may have redundant scope prefixes
1070
+ // e.g., "useLoaderData<LoaderData>.useLoaderData<LoaderData>().functionCallReturnValue.entity.sha"
1071
+ // should become "useLoaderData<LoaderData>().functionCallReturnValue.entity.sha"
1072
+ // Returns null for malformed paths (e.g., chained function calls like fetch().json())
1073
+ const cleanedPath = cleanSourceDataPath(usage.sourceDataPath);
1074
+ console.log(
1075
+ `[genFlowsFromConditionals] "${usage.path}" cleanSourceDataPath("${usage.sourceDataPath}") → "${cleanedPath}"`,
1076
+ );
1077
+ if (cleanedPath) {
1078
+ // Verify the cleaned path exists in attributesMap
1079
+ const pathMatch = findInAttributesMapForPath(
1080
+ cleanedPath,
1081
+ attributesMap,
1082
+ fullToShortPathMap,
1083
+ );
1084
+ console.log(
1085
+ `[genFlowsFromConditionals] "${usage.path}" findInAttributesMapForPath("${cleanedPath}") → ${pathMatch ? `"${pathMatch}"` : 'null (not found)'}`,
1086
+ );
1087
+ if (pathMatch) {
1088
+ resolvedPath = pathMatch;
1089
+ }
1090
+ }
1091
+ // If cleanedPath is null, fall through to use fallback resolution
1092
+ }
1093
+
1094
+ // Fall back to resolution via equivalentSignatureVariables
1095
+ if (!resolvedPath) {
1096
+ console.log(
1097
+ `[genFlowsFromConditionals] "${usage.path}" sourceDataPath resolution failed, trying resolvePathToControllable("${usage.path}")...`,
1098
+ );
1099
+ const resolution = resolvePathToControllable(
1100
+ usage.path,
1101
+ attributesMap,
1102
+ equivalentSignatureVariables,
1103
+ fullToShortPathMap,
1104
+ );
1105
+ console.log(
1106
+ `[genFlowsFromConditionals] "${usage.path}" resolvePathToControllable → isControllable=${resolution.isControllable}, resolvedPath="${resolution.resolvedPath ?? '(none)'}"`,
1107
+ );
1108
+ if (resolution.isControllable && resolution.resolvedPath) {
1109
+ resolvedPath = resolution.resolvedPath;
1110
+ }
1111
+ }
1112
+
1113
+ // If still not resolved, try using derivedFrom info to find the source path
1114
+ // This handles cases like: const hasAnalysis = analysis !== null
1115
+ // where hasAnalysis is not in attributesMap but analysis is
1116
+ if (!resolvedPath && usage.derivedFrom) {
1117
+ const { operation, sourcePath, sourcePaths, comparedValue } =
1118
+ usage.derivedFrom;
1119
+ console.log(
1120
+ `[genFlowsFromConditionals] "${usage.path}" trying derivedFrom: operation=${operation}, sourcePath="${sourcePath ?? '(none)'}", sourcePaths=${sourcePaths ? JSON.stringify(sourcePaths) : '(none)'}, comparedValue="${comparedValue ?? '(none)'}"`,
1121
+ );
1122
+ // For single-source derivations (notNull, equals, etc.)
1123
+ if (sourcePath) {
1124
+ const resolution = resolvePathToControllable(
1125
+ sourcePath,
1126
+ attributesMap,
1127
+ equivalentSignatureVariables,
1128
+ fullToShortPathMap,
1129
+ );
1130
+ if (resolution.isControllable && resolution.resolvedPath) {
1131
+ resolvedPath = resolution.resolvedPath;
1132
+ }
1133
+ }
1134
+
1135
+ // For equals/notEquals derivations with comparedValue, generate comparison flows
1136
+ // e.g., canEdit derived from user.role === 'admin'
1137
+ // When canEdit is used in truthiness check, we need:
1138
+ // - Truthy flow: user.role = 'admin' (comparison: 'equals')
1139
+ // - Falsy flow: user.role != 'admin' (comparison: 'notEquals')
1140
+ if (
1141
+ (operation === 'equals' || operation === 'notEquals') &&
1142
+ comparedValue !== undefined &&
1143
+ resolvedPath &&
1144
+ usage.conditionType === 'truthiness'
1145
+ ) {
1146
+ const baseName = generateNameFromPath(usage.path);
1147
+ const impact: ExecutionFlow['impact'] = usage.controlsJsxRendering
1148
+ ? 'high'
1149
+ : 'medium';
1150
+
1151
+ const isNegated = usage.isNegated ?? false;
1152
+
1153
+ // For equals derivation:
1154
+ // - Truthy check (!negated): needs value = comparedValue (equals)
1155
+ // - Falsy check (negated): needs value != comparedValue (notEquals)
1156
+ // For notEquals derivation: inverse of above
1157
+ const isEqualsDerivation = operation === 'equals';
1158
+ const truthyNeedsEquals = isEqualsDerivation !== isNegated;
1159
+
1160
+ // Generate truthy flow
1161
+ const truthyFlow: ExecutionFlow = {
1162
+ id: generateFlowId(usage.path, 'truthy'),
1163
+ name: `${baseName} True`,
1164
+ description: `When ${baseName.toLowerCase()} is truthy (${resolvedPath} ${truthyNeedsEquals ? '=' : '!='} ${comparedValue})`,
1165
+ requiredValues: [
1166
+ {
1167
+ attributePath: stripLengthSuffix(resolvedPath),
1168
+ value: comparedValue,
1169
+ comparison: truthyNeedsEquals ? 'equals' : 'notEquals',
1170
+ valueType: inferValueType(comparedValue),
1171
+ },
1172
+ ],
1173
+ impact,
1174
+ sourceLocation: usage.sourceLocation
1175
+ ? {
1176
+ lineNumber: usage.sourceLocation.lineNumber,
1177
+ column: usage.sourceLocation.column,
1178
+ }
1179
+ : undefined,
1180
+ codeSnippet: usage.sourceLocation?.codeSnippet,
1181
+ };
1182
+
1183
+ // Generate falsy flow
1184
+ const falsyFlow: ExecutionFlow = {
1185
+ id: generateFlowId(usage.path, 'falsy'),
1186
+ name: `${baseName} False`,
1187
+ description: `When ${baseName.toLowerCase()} is falsy (${resolvedPath} ${truthyNeedsEquals ? '!=' : '='} ${comparedValue})`,
1188
+ requiredValues: [
1189
+ {
1190
+ attributePath: stripLengthSuffix(resolvedPath),
1191
+ value: comparedValue,
1192
+ comparison: truthyNeedsEquals ? 'notEquals' : 'equals',
1193
+ valueType: inferValueType(comparedValue),
1194
+ },
1195
+ ],
1196
+ impact,
1197
+ sourceLocation: usage.sourceLocation
1198
+ ? {
1199
+ lineNumber: usage.sourceLocation.lineNumber,
1200
+ column: usage.sourceLocation.column,
1201
+ }
1202
+ : undefined,
1203
+ codeSnippet: usage.sourceLocation?.codeSnippet,
1204
+ };
1205
+
1206
+ // Add flows and skip normal flow generation
1207
+ if (!seenFlowIds.has(truthyFlow.id)) {
1208
+ seenFlowIds.add(truthyFlow.id);
1209
+ flows.push(truthyFlow);
1210
+ }
1211
+ if (!seenFlowIds.has(falsyFlow.id)) {
1212
+ seenFlowIds.add(falsyFlow.id);
1213
+ flows.push(falsyFlow);
1214
+ }
1215
+
1216
+ continue;
1217
+ }
1218
+
1219
+ // For OR derivations with negation, we need ALL sources to be falsy
1220
+ // e.g., !isBusy where isBusy = isRunning || isQueued || isPending
1221
+ // For the falsy flow, ALL sources must be falsy
1222
+ if (
1223
+ operation === 'or' &&
1224
+ usage.conditionType === 'truthiness' &&
1225
+ usage.isNegated === true &&
1226
+ sourcePaths &&
1227
+ sourcePaths.length > 0
1228
+ ) {
1229
+ // Use expandDerivedVariableToSources to recursively resolve all sources
1230
+ const allSources = expandDerivedVariableToSources(
1231
+ usage.path,
1232
+ conditionalUsages,
1233
+ attributesMap,
1234
+ equivalentSignatureVariables,
1235
+ fullToShortPathMap,
1236
+ new Set(),
1237
+ derivedVariables,
1238
+ );
1239
+
1240
+ if (allSources.length > 0) {
1241
+ // Generate a compound-style flow with all sources set to falsy
1242
+ const baseName = generateNameFromPath(usage.path);
1243
+ const impact: ExecutionFlow['impact'] = usage.controlsJsxRendering
1244
+ ? 'high'
1245
+ : 'medium';
1246
+
1247
+ const requiredValues: ExecutionFlow['requiredValues'] =
1248
+ allSources.map((source) => ({
1249
+ attributePath: source.path,
1250
+ value: 'falsy',
1251
+ comparison: 'falsy' as const,
1252
+ valueType: 'boolean' as const,
1253
+ }));
1254
+
1255
+ // Create a single falsy flow with all sources
1256
+ const falsyFlow: ExecutionFlow = {
1257
+ id: generateFlowId(usage.path, 'falsy'),
1258
+ name: `${baseName} False`,
1259
+ description: `When ${baseName.toLowerCase()} is falsy (all sources are falsy)`,
1260
+ requiredValues,
1261
+ impact,
1262
+ sourceLocation: usage.sourceLocation
1263
+ ? {
1264
+ lineNumber: usage.sourceLocation.lineNumber,
1265
+ column: usage.sourceLocation.column,
1266
+ }
1267
+ : undefined,
1268
+ codeSnippet: usage.sourceLocation?.codeSnippet,
1269
+ };
1270
+
1271
+ // Create a truthy flow - for OR, ANY source being truthy is sufficient
1272
+ // We use the first resolvable source for the truthy flow
1273
+ const firstSource = allSources[0];
1274
+ const truthyFlow: ExecutionFlow = {
1275
+ id: generateFlowId(usage.path, 'truthy'),
1276
+ name: `${baseName} True`,
1277
+ description: `When ${baseName.toLowerCase()} is truthy`,
1278
+ requiredValues: [
1279
+ {
1280
+ attributePath: firstSource.path,
1281
+ value: 'truthy',
1282
+ comparison: 'truthy',
1283
+ valueType: 'boolean',
1284
+ },
1285
+ ],
1286
+ impact,
1287
+ sourceLocation: usage.sourceLocation
1288
+ ? {
1289
+ lineNumber: usage.sourceLocation.lineNumber,
1290
+ column: usage.sourceLocation.column,
1291
+ }
1292
+ : undefined,
1293
+ codeSnippet: usage.sourceLocation?.codeSnippet,
1294
+ };
1295
+
1296
+ // Add both flows (falsy needs all sources, truthy needs one)
1297
+ if (!seenFlowIds.has(falsyFlow.id)) {
1298
+ seenFlowIds.add(falsyFlow.id);
1299
+ flows.push(falsyFlow);
1300
+ }
1301
+ if (!seenFlowIds.has(truthyFlow.id)) {
1302
+ seenFlowIds.add(truthyFlow.id);
1303
+ flows.push(truthyFlow);
1304
+ }
1305
+
1306
+ // Skip the normal flow generation for this usage
1307
+ continue;
1308
+ }
1309
+ }
1310
+
1311
+ // For AND derivations without negation, we need ALL sources to be truthy
1312
+ // e.g., isReady where isReady = hasData && isLoaded && isValid
1313
+ // For the truthy flow, ALL sources must be truthy
1314
+ // For negated AND (!isReady), ANY source being falsy is sufficient (fallback behavior)
1315
+ if (
1316
+ operation === 'and' &&
1317
+ usage.conditionType === 'truthiness' &&
1318
+ usage.isNegated !== true &&
1319
+ sourcePaths &&
1320
+ sourcePaths.length > 0
1321
+ ) {
1322
+ // Use expandDerivedVariableToSources to recursively resolve all sources
1323
+ const allSources = expandDerivedVariableToSources(
1324
+ usage.path,
1325
+ conditionalUsages,
1326
+ attributesMap,
1327
+ equivalentSignatureVariables,
1328
+ fullToShortPathMap,
1329
+ new Set(),
1330
+ derivedVariables,
1331
+ );
1332
+
1333
+ if (allSources.length > 0) {
1334
+ // Generate a compound-style flow with all sources set to truthy
1335
+ const baseName = generateNameFromPath(usage.path);
1336
+ const impact: ExecutionFlow['impact'] = usage.controlsJsxRendering
1337
+ ? 'high'
1338
+ : 'medium';
1339
+
1340
+ const requiredValues: ExecutionFlow['requiredValues'] =
1341
+ allSources.map((source) => ({
1342
+ attributePath: source.path,
1343
+ value: 'truthy',
1344
+ comparison: 'truthy' as const,
1345
+ valueType: 'boolean' as const,
1346
+ }));
1347
+
1348
+ // Create a truthy flow with all sources
1349
+ const truthyFlow: ExecutionFlow = {
1350
+ id: generateFlowId(usage.path, 'truthy'),
1351
+ name: `${baseName} True`,
1352
+ description: `When ${baseName.toLowerCase()} is truthy (all sources are truthy)`,
1353
+ requiredValues,
1354
+ impact,
1355
+ sourceLocation: usage.sourceLocation
1356
+ ? {
1357
+ lineNumber: usage.sourceLocation.lineNumber,
1358
+ column: usage.sourceLocation.column,
1359
+ }
1360
+ : undefined,
1361
+ codeSnippet: usage.sourceLocation?.codeSnippet,
1362
+ };
1363
+
1364
+ // Create a falsy flow - for AND, ANY source being falsy is sufficient
1365
+ // We use the first resolvable source for the falsy flow
1366
+ const firstSource = allSources[0];
1367
+ const falsyFlow: ExecutionFlow = {
1368
+ id: generateFlowId(usage.path, 'falsy'),
1369
+ name: `${baseName} False`,
1370
+ description: `When ${baseName.toLowerCase()} is falsy`,
1371
+ requiredValues: [
1372
+ {
1373
+ attributePath: firstSource.path,
1374
+ value: 'falsy',
1375
+ comparison: 'falsy',
1376
+ valueType: 'boolean',
1377
+ },
1378
+ ],
1379
+ impact,
1380
+ sourceLocation: usage.sourceLocation
1381
+ ? {
1382
+ lineNumber: usage.sourceLocation.lineNumber,
1383
+ column: usage.sourceLocation.column,
1384
+ }
1385
+ : undefined,
1386
+ codeSnippet: usage.sourceLocation?.codeSnippet,
1387
+ };
1388
+
1389
+ // Add both flows (truthy needs all sources, falsy needs one)
1390
+ if (!seenFlowIds.has(truthyFlow.id)) {
1391
+ seenFlowIds.add(truthyFlow.id);
1392
+ flows.push(truthyFlow);
1393
+ }
1394
+ if (!seenFlowIds.has(falsyFlow.id)) {
1395
+ seenFlowIds.add(falsyFlow.id);
1396
+ flows.push(falsyFlow);
1397
+ }
1398
+
1399
+ // Skip the normal flow generation for this usage
1400
+ continue;
1401
+ }
1402
+ }
1403
+
1404
+ // For multi-source derivations (or, and) without special handling,
1405
+ // try the first resolvable path as a fallback
1406
+ if (!resolvedPath && sourcePaths && sourcePaths.length > 0) {
1407
+ for (const sp of sourcePaths) {
1408
+ const resolution = resolvePathToControllable(
1409
+ sp,
1410
+ attributesMap,
1411
+ equivalentSignatureVariables,
1412
+ fullToShortPathMap,
1413
+ );
1414
+
1415
+ if (resolution.isControllable && resolution.resolvedPath) {
1416
+ resolvedPath = resolution.resolvedPath;
1417
+ break;
1418
+ }
1419
+ }
1420
+ }
1421
+ }
1422
+
1423
+ if (!resolvedPath) {
1424
+ // Path is not controllable - skip (no invalid flows possible)
1425
+ console.log(
1426
+ `[genFlowsFromConditionals] "${usage.path}" SKIP: not controllable (no resolvedPath after all attempts)`,
1427
+ );
1428
+ continue;
1429
+ }
1430
+
1431
+ // Normalize the resolved path to detect duplicates
1432
+ // E.g., both "hasNewerVersion" and "useLoaderData<...>().hasNewerVersion"
1433
+ // should normalize to the same canonical path
1434
+ const normalizedPath = normalizePathForDeduplication(
1435
+ resolvedPath,
1436
+ fullToShortPathMap,
1437
+ );
1438
+
1439
+ // Skip if we've already generated flows for this normalized path
1440
+ // This prevents duplicate flows when we have usages for both short and full paths
1441
+ if (seenNormalizedPaths.has(normalizedPath)) {
1442
+ console.log(
1443
+ `[genFlowsFromConditionals] "${usage.path}" SKIP: duplicate normalizedPath="${normalizedPath}" (resolvedPath="${resolvedPath}")`,
1444
+ );
1445
+ continue;
1446
+ }
1447
+ seenNormalizedPaths.add(normalizedPath);
1448
+
1449
+ // Skip individual truthy/falsy flows on parent paths that have child data entries.
1450
+ // Lifecycle booleans (like isLoadingAuditData) traced to fetch(...).functionCallReturnValue
1451
+ // produce misleading truthy/falsy flows: "truthy" can't show loading (mock resolves instantly),
1452
+ // "falsy" tells the LLM to return null (breaking .json()). Compound flows with specific child
1453
+ // data requirements provide the correct mock guidance.
1454
+ if (
1455
+ usage.conditionType === 'truthiness' &&
1456
+ resolvedPath &&
1457
+ hasChildPathsInMap(resolvedPath, fullToShortPathMap)
1458
+ ) {
1459
+ console.log(
1460
+ `[genFlowsFromConditionals] "${usage.path}" SKIP: parent path "${resolvedPath}" has child data paths — compound flows will handle this`,
1461
+ );
1462
+ continue;
1463
+ }
1464
+
1465
+ console.log(
1466
+ `[genFlowsFromConditionals] "${usage.path}" RESOLVED → resolvedPath="${resolvedPath}", normalizedPath="${normalizedPath}" — generating flows`,
1467
+ );
1468
+
1469
+ // Generate flows for this controllable usage
1470
+ const usageFlows = generateFlowsFromUsage(usage, resolvedPath);
1471
+
1472
+ for (const flow of usageFlows) {
1473
+ // Deduplicate by flow ID
1474
+ if (!seenFlowIds.has(flow.id)) {
1475
+ seenFlowIds.add(flow.id);
1476
+ flows.push(flow);
1477
+ console.log(
1478
+ `[genFlowsFromConditionals] "${usage.path}" FLOW ADDED: id="${flow.id}", requiredValues=${JSON.stringify(flow.requiredValues.map((rv) => ({ attr: rv.attributePath, val: rv.value })))}`,
1479
+ );
1480
+ }
1481
+ }
1482
+ }
1483
+ }
1484
+
1485
+ // Process compound conditionals
1486
+ for (const compound of compoundConditionals) {
1487
+ // Expand OR groups into separate condition sets
1488
+ // For example, `A && (B || C)` becomes [[A, B], [A, C]]
1489
+ const expandedConditionSets = expandOrGroups(compound.conditions);
1490
+
1491
+ // Process each expanded condition set as a separate potential flow
1492
+ for (const conditionSet of expandedConditionSets) {
1493
+ // First, check if ALL paths in this condition set are controllable (or can be expanded to controllable sources)
1494
+ const resolvedPaths = new Map<string, string>();
1495
+ // Track expanded sources for derived variables (path -> array of expanded sources)
1496
+ const expandedSources = new Map<
1497
+ string,
1498
+ Array<{ path: string; operation?: DerivedVariableOperation }>
1499
+ >();
1500
+ let allControllable = true;
1501
+
1502
+ for (const condition of conditionSet) {
1503
+ // Check if this condition path has derivation info
1504
+ // First check conditionalUsages, then fall back to derivedVariables
1505
+ const usagesForPath = conditionalUsages[condition.path];
1506
+ let derivedFromInfo = usagesForPath?.find(
1507
+ (u) => u.derivedFrom?.operation,
1508
+ )?.derivedFrom;
1509
+
1510
+ // CRITICAL: Also check derivedVariables for intermediate derived variables
1511
+ if (!derivedFromInfo && derivedVariables?.[condition.path]) {
1512
+ derivedFromInfo = derivedVariables[condition.path];
1513
+ }
1514
+
1515
+ if (derivedFromInfo) {
1516
+ // This is a derived variable - expand to its sources
1517
+ const sources = expandDerivedVariableToSources(
1518
+ condition.path,
1519
+ conditionalUsages,
1520
+ attributesMap,
1521
+ equivalentSignatureVariables,
1522
+ fullToShortPathMap,
1523
+ new Set(),
1524
+ derivedVariables,
1525
+ );
1526
+
1527
+ if (sources.length > 0) {
1528
+ // Store the expanded sources for this condition
1529
+ expandedSources.set(condition.path, sources);
1530
+ // Use the first source's path for the resolvedPaths map (for ID generation)
1531
+ resolvedPaths.set(condition.path, sources[0].path);
1532
+ } else {
1533
+ // Derived variable expansion failed — try sourceDataPath fallback
1534
+ // This handles cases where the derivation chain goes through useMemo/useState
1535
+ // but the enriched sourceDataPath already traced to the actual data source
1536
+ const usageWithSource = usagesForPath?.find(
1537
+ (u) => u.sourceDataPath,
1538
+ );
1539
+ let derivedFallbackPath: string | null = null;
1540
+
1541
+ if (usageWithSource?.sourceDataPath) {
1542
+ const cleanedPath = cleanSourceDataPath(
1543
+ usageWithSource.sourceDataPath,
1544
+ );
1545
+ if (cleanedPath) {
1546
+ const pathMatch = findInAttributesMapForPath(
1547
+ cleanedPath,
1548
+ attributesMap,
1549
+ fullToShortPathMap,
1550
+ );
1551
+ if (pathMatch) {
1552
+ derivedFallbackPath = pathMatch;
1553
+ }
1554
+ }
1555
+ }
1556
+
1557
+ if (derivedFallbackPath) {
1558
+ resolvedPaths.set(condition.path, derivedFallbackPath);
1559
+ console.log(
1560
+ `[genFlowsFromConditionals] COMPOUND "${condition.path}" derived expansion failed but sourceDataPath fallback resolved → "${derivedFallbackPath}"`,
1561
+ );
1562
+ } else {
1563
+ // Truly not controllable
1564
+ console.log(
1565
+ `[genFlowsFromConditionals] COMPOUND "${condition.path}" derived but no controllable sources and no sourceDataPath fallback → NOT controllable`,
1566
+ );
1567
+ allControllable = false;
1568
+ break;
1569
+ }
1570
+ }
1571
+ } else {
1572
+ // Not a derived variable - resolve directly
1573
+ // First try sourceDataPath from the usage (same as individual processing)
1574
+ let compoundResolvedPath: string | null = null;
1575
+
1576
+ const usageWithSource = usagesForPath?.find((u) => u.sourceDataPath);
1577
+ if (usageWithSource?.sourceDataPath) {
1578
+ const cleanedPath = cleanSourceDataPath(
1579
+ usageWithSource.sourceDataPath,
1580
+ );
1581
+ if (cleanedPath) {
1582
+ const pathMatch = findInAttributesMapForPath(
1583
+ cleanedPath,
1584
+ attributesMap,
1585
+ fullToShortPathMap,
1586
+ );
1587
+ if (pathMatch) {
1588
+ compoundResolvedPath = pathMatch;
1589
+ }
1590
+ }
1591
+ }
1592
+
1593
+ if (!compoundResolvedPath) {
1594
+ const resolution = resolvePathToControllable(
1595
+ condition.path,
1596
+ attributesMap,
1597
+ equivalentSignatureVariables,
1598
+ fullToShortPathMap,
1599
+ );
1600
+
1601
+ if (resolution.isControllable && resolution.resolvedPath) {
1602
+ compoundResolvedPath = resolution.resolvedPath;
1603
+ }
1604
+ }
1605
+
1606
+ if (!compoundResolvedPath) {
1607
+ allControllable = false;
1608
+ break;
1609
+ }
1610
+
1611
+ resolvedPaths.set(condition.path, compoundResolvedPath);
1612
+ }
1613
+ }
1614
+
1615
+ // Only create a flow if ALL paths are controllable
1616
+ if (allControllable && resolvedPaths.size > 0) {
1617
+ // If any conditions were expanded from derived variables, we need to build a custom flow
1618
+ if (expandedSources.size > 0) {
1619
+ const requiredValues: ExecutionFlow['requiredValues'] = [];
1620
+
1621
+ for (const condition of conditionSet) {
1622
+ const sources = expandedSources.get(condition.path);
1623
+
1624
+ if (sources) {
1625
+ // This condition was expanded - add all its sources
1626
+ // Determine the required value based on condition type and derivation operation
1627
+ const usagesForPath = conditionalUsages[condition.path];
1628
+ let expandedDerivedFrom = usagesForPath?.find(
1629
+ (u) => u.derivedFrom?.operation,
1630
+ )?.derivedFrom;
1631
+
1632
+ // Also check derivedVariables for intermediate derived variables
1633
+ if (!expandedDerivedFrom && derivedVariables?.[condition.path]) {
1634
+ expandedDerivedFrom = derivedVariables[condition.path];
1635
+ }
1636
+ const operation = expandedDerivedFrom?.operation;
1637
+
1638
+ for (const source of sources) {
1639
+ // For OR-derived truthy: ANY source truthy
1640
+ // For AND-derived truthy: ALL sources truthy
1641
+ // For negated: inverse
1642
+ let value: string;
1643
+ let comparison: ExecutionFlow['requiredValues'][0]['comparison'];
1644
+
1645
+ if (condition.conditionType === 'truthiness') {
1646
+ const isNegated = condition.isNegated === true;
1647
+ // For OR: truthy needs ANY source truthy, falsy needs ALL sources falsy
1648
+ // For AND: truthy needs ALL sources truthy, falsy needs ANY source falsy
1649
+ // In compound conditionals, we generate the truthy path by default
1650
+ // (the compound expression must be truthy)
1651
+ if (operation === 'or') {
1652
+ // For OR-derived, truthy means we need at least one source truthy
1653
+ // We'll use the first source as truthy (simplification)
1654
+ value = isNegated ? 'falsy' : 'truthy';
1655
+ } else if (operation === 'and') {
1656
+ // For AND-derived, truthy means ALL sources truthy
1657
+ value = isNegated ? 'falsy' : 'truthy';
1658
+ } else {
1659
+ value = isNegated ? 'falsy' : 'truthy';
1660
+ }
1661
+ comparison = isNegated ? 'falsy' : 'truthy';
1662
+ } else {
1663
+ value = 'truthy';
1664
+ comparison = 'truthy';
1665
+ }
1666
+
1667
+ requiredValues.push({
1668
+ attributePath: source.path,
1669
+ value,
1670
+ comparison,
1671
+ valueType: 'boolean' as const,
1672
+ });
1673
+ }
1674
+ } else {
1675
+ // This condition was resolved directly
1676
+ const resolvedPath = resolvedPaths.get(condition.path);
1677
+ if (resolvedPath) {
1678
+ let value: string;
1679
+ let comparison: ExecutionFlow['requiredValues'][0]['comparison'];
1680
+
1681
+ if (condition.conditionType === 'truthiness') {
1682
+ value = condition.isNegated ? 'falsy' : 'truthy';
1683
+ comparison = condition.isNegated ? 'falsy' : 'truthy';
1684
+ } else {
1685
+ value =
1686
+ condition.requiredValue?.toString() ??
1687
+ condition.comparedValues?.[0] ??
1688
+ 'truthy';
1689
+ const op = condition.comparisonOperator;
1690
+ if (op === '>' || op === '>=') {
1691
+ comparison = 'length>';
1692
+ } else if (op === '<' || op === '<=') {
1693
+ comparison = 'length<';
1694
+ } else {
1695
+ comparison = 'equals';
1696
+ }
1697
+ }
1698
+
1699
+ requiredValues.push({
1700
+ attributePath: stripLengthSuffix(resolvedPath),
1701
+ value,
1702
+ comparison,
1703
+ valueType: inferValueType(value),
1704
+ });
1705
+ }
1706
+ }
1707
+ }
1708
+
1709
+ // Remove contradictory "falsy" values where a child path requires data
1710
+ const cleanedValues = removeContradictoryFalsyValues(requiredValues);
1711
+
1712
+ if (cleanedValues.length > 0) {
1713
+ const impact: ExecutionFlow['impact'] =
1714
+ compound.controlsJsxRendering ? 'high' : 'medium';
1715
+
1716
+ // Generate a combined ID from all paths + values
1717
+ const pathParts = cleanedValues
1718
+ .map((rv) => {
1719
+ const name = generateNameFromPath(rv.attributePath);
1720
+ const suffix =
1721
+ rv.comparison === 'truthy' || rv.comparison === 'falsy'
1722
+ ? `-${rv.comparison}`
1723
+ : `-${rv.comparison}-${rv.value}`;
1724
+ return name.toLowerCase().replace(/\s+/g, '-') + suffix;
1725
+ })
1726
+ .join('-and-');
1727
+
1728
+ const compoundFlow: ExecutionFlow = {
1729
+ id: `${pathParts}`,
1730
+ name: generateNameFromPath(cleanedValues[0].attributePath),
1731
+ description: `When ${cleanedValues.map((rv) => describeRequiredValue(rv)).join(' and ')}`,
1732
+ impact,
1733
+ requiredValues: cleanedValues,
1734
+ sourceLocation: compound.sourceLocation,
1735
+ };
1736
+
1737
+ if (!seenFlowIds.has(compoundFlow.id)) {
1738
+ seenFlowIds.add(compoundFlow.id);
1739
+ flows.push(compoundFlow);
1740
+ }
1741
+ }
1742
+ } else {
1743
+ // No derived variables - use the original generateFlowFromCompound
1744
+ // Create a modified compound with just this condition set
1745
+ const modifiedCompound = {
1746
+ ...compound,
1747
+ conditions: conditionSet,
1748
+ };
1749
+ const compoundFlow = generateFlowFromCompound(
1750
+ modifiedCompound,
1751
+ resolvedPaths,
1752
+ );
1753
+ if (compoundFlow && !seenFlowIds.has(compoundFlow.id)) {
1754
+ seenFlowIds.add(compoundFlow.id);
1755
+ flows.push(compoundFlow);
1756
+ }
1757
+ }
1758
+ }
1759
+ }
1760
+ }
1761
+
1762
+ // Process child component conditional usages
1763
+ // Translate child paths to parent paths and merge flows
1764
+ if (childComponentData) {
1765
+ for (const [childName, childData] of Object.entries(childComponentData)) {
1766
+ // First, resolve gating conditions to get required values that must be added to all child flows
1767
+ const gatingRequiredValues: Array<{
1768
+ attributePath: string;
1769
+ value: string;
1770
+ comparison:
1771
+ | 'truthy'
1772
+ | 'falsy'
1773
+ | 'equals'
1774
+ | 'length>'
1775
+ | 'length<'
1776
+ | 'exists'
1777
+ | 'not-exists';
1778
+ }> = [];
1779
+
1780
+ if (childData.gatingConditions) {
1781
+ for (const gatingCondition of childData.gatingConditions) {
1782
+ // Try to resolve via derivedFrom first
1783
+ let gatingPath = gatingCondition.path;
1784
+ if (gatingCondition.derivedFrom?.sourcePath) {
1785
+ gatingPath = gatingCondition.derivedFrom.sourcePath;
1786
+ }
1787
+
1788
+ // Fix 32: Handle comparison expressions like "activeTab === 'scenarios'"
1789
+ // Extract the variable name and the compared value
1790
+ const comparisonMatch = gatingPath.match(
1791
+ /^([a-zA-Z_][a-zA-Z0-9_]*)\s*(===?|!==?)\s*['"]?([^'"]+)['"]?$/,
1792
+ );
1793
+ if (comparisonMatch) {
1794
+ const [, varName, operator, comparedValue] = comparisonMatch;
1795
+
1796
+ // Try to resolve the variable name
1797
+ const varResolution = resolvePathToControllable(
1798
+ varName,
1799
+ attributesMap,
1800
+ equivalentSignatureVariables,
1801
+ fullToShortPathMap,
1802
+ );
1803
+
1804
+ // Only use controllable paths for gating conditions (whitelist approach).
1805
+ // Do NOT fall back to equivalentSignatureVariables because those may contain
1806
+ // uncontrollable paths like useState that cannot be mocked.
1807
+ let resolvedVarPath: string | null = null;
1808
+ if (varResolution.isControllable && varResolution.resolvedPath) {
1809
+ resolvedVarPath = varResolution.resolvedPath;
1810
+ }
1811
+ // Note: We intentionally do NOT fall back to equivalentSignatureVariables here
1812
+ // because that would allow uncontrollable paths (like useState) to be added
1813
+ // as gating conditions.
1814
+
1815
+ if (resolvedVarPath) {
1816
+ const isNegated = (gatingCondition as any).isNegated === true;
1817
+ const isNotEquals = operator === '!=' || operator === '!==';
1818
+ // Determine the effective value for this gating condition
1819
+ // If condition is "activeTab === 'scenarios'" and NOT negated, flow needs activeTab = 'scenarios'
1820
+ // If condition is "activeTab === 'scenarios'" and IS negated, flow needs activeTab != 'scenarios' (falsy/other value)
1821
+ // If condition is "activeTab !== 'scenarios'" and NOT negated, flow needs activeTab != 'scenarios'
1822
+ // XOR logic: isNegated XOR isNotEquals
1823
+ const needsExactValue = isNegated !== isNotEquals;
1824
+
1825
+ gatingRequiredValues.push({
1826
+ attributePath: resolvedVarPath,
1827
+ value: needsExactValue ? 'falsy' : comparedValue,
1828
+ comparison: needsExactValue ? 'falsy' : 'equals',
1829
+ });
1830
+ continue; // Skip to next gating condition
1831
+ }
1832
+ }
1833
+
1834
+ // Fix 31: Handle compound gating conditions (containing && or ||)
1835
+ // e.g., "isEditMode && selectedScenario" should be parsed into individual paths
1836
+ const isAndExpression = gatingPath.includes(' && ');
1837
+ const isOrExpression = gatingPath.includes(' || ');
1838
+ const isCompoundExpression = isAndExpression || isOrExpression;
1839
+
1840
+ if (isCompoundExpression) {
1841
+ // Parse the compound expression into individual variable names
1842
+ // Split on && and || (with optional spaces)
1843
+ const parts = gatingPath.split(/\s*(?:&&|\|\|)\s*/);
1844
+ const isNegated = (gatingCondition as any).isNegated === true;
1845
+
1846
+ // Fix 37: Apply DeMorgan's law correctly for compound conditions
1847
+ // - !(A && B) = !A || !B: EITHER A is false OR B is false (can't know which)
1848
+ // - !(A || B) = !A && !B: BOTH must be false
1849
+ // - (A && B): BOTH must be true
1850
+ // - (A || B): EITHER is true (can't know which)
1851
+ //
1852
+ // We should only add gating requirements when we can definitively say
1853
+ // all parts must have the same value. This is true for:
1854
+ // - Non-negated &&: all parts must be truthy
1855
+ // - Negated ||: all parts must be falsy (DeMorgan: !(A || B) = !A && !B)
1856
+ //
1857
+ // We should NOT add gating requirements when either part could be true/false:
1858
+ // - Negated && (DeMorgan: !(A && B) = !A || !B): can't constrain both to falsy
1859
+ // - Non-negated ||: can't constrain both to truthy
1860
+ const shouldSkipGating =
1861
+ (isAndExpression && isNegated) || // !(A && B) - either could be falsy
1862
+ (isOrExpression && !isNegated); // (A || B) - either could be truthy
1863
+
1864
+ if (shouldSkipGating) {
1865
+ // Don't add gating requirements for this compound condition
1866
+ // The child flow's own requirements will determine what values are needed
1867
+ } else {
1868
+ for (const part of parts) {
1869
+ // Clean up the part (remove parentheses, negation, etc.)
1870
+ const cleanPart = part
1871
+ .replace(/^\(+|\)+$/g, '') // Remove leading/trailing parens
1872
+ .replace(/^!+/, '') // Remove leading negation
1873
+ .trim();
1874
+
1875
+ if (!cleanPart) continue;
1876
+
1877
+ // Try to resolve this individual path
1878
+ const partResolution = resolvePathToControllable(
1879
+ cleanPart,
1880
+ attributesMap,
1881
+ equivalentSignatureVariables,
1882
+ fullToShortPathMap,
1883
+ );
1884
+
1885
+ if (
1886
+ partResolution.isControllable &&
1887
+ partResolution.resolvedPath
1888
+ ) {
1889
+ // For non-negated &&: all parts must be truthy
1890
+ // For negated ||: all parts must be falsy (DeMorgan: !(A || B) = !A && !B)
1891
+ gatingRequiredValues.push({
1892
+ attributePath: stripLengthSuffix(
1893
+ partResolution.resolvedPath,
1894
+ ),
1895
+ value: isNegated ? 'falsy' : 'truthy',
1896
+ comparison: isNegated ? 'falsy' : 'truthy',
1897
+ });
1898
+ }
1899
+ }
1900
+ }
1901
+ } else {
1902
+ // Simple gating condition (single path)
1903
+ // Resolve the gating path in parent context
1904
+ const gatingResolution = resolvePathToControllable(
1905
+ gatingPath,
1906
+ attributesMap,
1907
+ equivalentSignatureVariables,
1908
+ fullToShortPathMap,
1909
+ );
1910
+
1911
+ // Only use controllable paths for gating conditions (whitelist approach).
1912
+ // Do NOT fall back to equivalentSignatureVariables because those may contain
1913
+ // uncontrollable paths like useState that cannot be mocked.
1914
+ let resolvedGatingPath: string | null = null;
1915
+ if (
1916
+ gatingResolution.isControllable &&
1917
+ gatingResolution.resolvedPath
1918
+ ) {
1919
+ resolvedGatingPath = gatingResolution.resolvedPath;
1920
+ }
1921
+ // Note: We intentionally do NOT fall back to equivalentSignatureVariables here
1922
+ // because that would allow uncontrollable paths (like useState) to be added
1923
+ // as gating conditions.
1924
+
1925
+ if (resolvedGatingPath) {
1926
+ // For truthiness conditions on gating, check if the condition is negated
1927
+ // e.g., ternary else branch: isError ? <ErrorView /> : <SuccessView />
1928
+ // SuccessView has isNegated: true, meaning it renders when isError is falsy
1929
+ const isNegated = (gatingCondition as any).isNegated === true;
1930
+ gatingRequiredValues.push({
1931
+ attributePath: resolvedGatingPath,
1932
+ value: isNegated ? 'falsy' : 'truthy',
1933
+ comparison: isNegated ? 'falsy' : 'truthy',
1934
+ });
1935
+ }
1936
+ }
1937
+ }
1938
+ }
1939
+
1940
+ // Track which child usages are part of compound conditionals (to avoid duplicates)
1941
+ // Fix 33: Only skip usages that are part of compound conditionals, not all usages with chainIds
1942
+ const childCompoundChainIds = new Set(
1943
+ childData.compoundConditionals.map((c) => c.chainId).filter(Boolean),
1944
+ );
1945
+
1946
+ for (const [_path, usages] of Object.entries(
1947
+ childData.conditionalUsages,
1948
+ )) {
1949
+ for (const usage of usages) {
1950
+ // Skip usages that are part of compound conditionals (handled separately)
1951
+ // Fix 33: Only skip if the chainId is in the child's compound conditionals
1952
+ if (usage.chainId && childCompoundChainIds.has(usage.chainId)) {
1953
+ continue;
1954
+ }
1955
+
1956
+ // Determine the child path to translate
1957
+ let childPath = usage.path;
1958
+
1959
+ // If the usage has derivedFrom, use the source path instead
1960
+ if (usage.derivedFrom?.sourcePath) {
1961
+ childPath = usage.derivedFrom.sourcePath;
1962
+ }
1963
+
1964
+ // Translate the child path to a parent path
1965
+ let translatedPath = translateChildPathToParent(
1966
+ childPath,
1967
+ childData.equivalentSignatureVariables,
1968
+ equivalentSignatureVariables,
1969
+ childName,
1970
+ );
1971
+
1972
+ // If translation failed but we have sourceDataPath, try to extract the prop path from it
1973
+ // sourceDataPath format: "ChildName.signature[n].propPath.rest" → extract "propPath.rest"
1974
+ if (!translatedPath && usage.sourceDataPath) {
1975
+ const signatureMatch = usage.sourceDataPath.match(
1976
+ /\.signature\[\d+\]\.(.+)$/,
1977
+ );
1978
+ if (signatureMatch) {
1979
+ translatedPath = signatureMatch[1];
1980
+ }
1981
+ }
1982
+
1983
+ if (!translatedPath) {
1984
+ // Could not translate - skip this usage
1985
+ continue;
1986
+ }
1987
+
1988
+ // Now resolve the translated path in the parent context
1989
+ // First, try standard resolution
1990
+ const resolution = resolvePathToControllable(
1991
+ translatedPath,
1992
+ attributesMap,
1993
+ equivalentSignatureVariables,
1994
+ fullToShortPathMap,
1995
+ );
1996
+
1997
+ // Only create flows for controllable paths (whitelist approach).
1998
+ // If the path doesn't resolve to something in attributesMap, skip it.
1999
+ // This prevents creating flows for useState values which are not
2000
+ // controllable via mock data injection.
2001
+ let resolvedPath = resolution.resolvedPath;
2002
+
2003
+ if (!resolution.isControllable || !resolvedPath) {
2004
+ // Path is not controllable via standard resolution.
2005
+ // Try fallback: For useState values (cyScope*().functionCallReturnValue),
2006
+ // look for a related URL parameter like "varNameFromUrl" that might
2007
+ // control the initial state.
2008
+ //
2009
+ // Example: viewMode → cyScope20().functionCallReturnValue (useState value)
2010
+ // Fallback: viewModeFromUrl → segments[2] (URL param that initializes the useState)
2011
+ const useStateMatch = translatedPath.match(
2012
+ /^cyScope\d+\(\)\.functionCallReturnValue$/,
2013
+ );
2014
+
2015
+ if (useStateMatch) {
2016
+ // Find what variable this useState value corresponds to by looking
2017
+ // for entries like "varName": "cyScope20()" in equivalentSignatureVariables
2018
+ const useStatePattern = translatedPath.replace(
2019
+ /\.functionCallReturnValue$/,
2020
+ '',
2021
+ ); // e.g., "cyScope20()"
2022
+
2023
+ // Find the variable name that maps to this useState
2024
+ let useStateVarName: string | null = null;
2025
+ for (const [varName, varPath] of Object.entries(
2026
+ equivalentSignatureVariables,
2027
+ )) {
2028
+ if (varPath === useStatePattern) {
2029
+ useStateVarName = varName;
2030
+ break;
2031
+ }
2032
+ }
2033
+
2034
+ if (useStateVarName) {
2035
+ // Look for a related URL param like "varNameFromUrl"
2036
+ const urlParamName = `${useStateVarName}FromUrl`;
2037
+ const urlParamPath = equivalentSignatureVariables[urlParamName];
2038
+
2039
+ if (urlParamPath) {
2040
+ // For useState values initialized from URL params, use the
2041
+ // URL param variable name directly (e.g., "viewModeFromUrl")
2042
+ // rather than fully resolving it. This keeps the path meaningful
2043
+ // for scenario generation and avoids overly generic paths like
2044
+ // "useParams().functionCallReturnValue.*".
2045
+ //
2046
+ // The flow will use the URL param name as the attributePath,
2047
+ // which gets properly resolved when generating mock data.
2048
+ resolvedPath = urlParamName;
2049
+ }
2050
+ }
2051
+ }
2052
+
2053
+ // Fallback 2: Try sourceEquivalencies to find the actual data source
2054
+ // This handles the case where props flow through useState but originate
2055
+ // from a mockable data source (e.g., API call, fetcher).
2056
+ //
2057
+ // Example: WorkoutsView receives `workouts` prop which in parent is stored
2058
+ // in useState, but ultimately comes from a Supabase query.
2059
+ // sourceEquivalencies tells us: "WorkoutsView().signature[0].workouts" → "createClient()...data"
2060
+ if (!resolvedPath && sourceEquivalencies) {
2061
+ // Build the child prop path to look up in sourceEquivalencies
2062
+ // Format: "ChildName().signature[0].propName"
2063
+ // First, find what prop this child path maps to
2064
+ let childPropName: string | null = null;
2065
+ for (const [varName, varPath] of Object.entries(
2066
+ childData.equivalentSignatureVariables,
2067
+ )) {
2068
+ // Check if childPath starts with this variable name
2069
+ // e.g., childPath = "workouts.length", varName = "workouts", varPath = "signature[0].workouts"
2070
+ if (
2071
+ childPath === varName ||
2072
+ childPath.startsWith(`${varName}.`)
2073
+ ) {
2074
+ childPropName = varName;
2075
+ break;
2076
+ }
2077
+ }
2078
+
2079
+ if (childPropName) {
2080
+ // Build the full sourceEquivalencies key
2081
+ const sourceEquivKey = `${childName}().signature[0].${childPropName}`;
2082
+
2083
+ const sourceEquivEntry = sourceEquivalencies[sourceEquivKey];
2084
+ if (sourceEquivEntry && sourceEquivEntry.length > 0) {
2085
+ const dataSourcePath = sourceEquivEntry[0].schemaPath;
2086
+
2087
+ // Check if this data source path is controllable
2088
+ const dataSourceResolution = resolvePathToControllable(
2089
+ dataSourcePath,
2090
+ attributesMap,
2091
+ equivalentSignatureVariables,
2092
+ fullToShortPathMap,
2093
+ );
2094
+
2095
+ if (
2096
+ dataSourceResolution.isControllable &&
2097
+ dataSourceResolution.resolvedPath
2098
+ ) {
2099
+ // Preserve any suffix from the child path
2100
+ // e.g., childPath = "workouts.length" → suffix = ".length"
2101
+ const suffix = childPath.startsWith(`${childPropName}.`)
2102
+ ? childPath.slice(childPropName.length)
2103
+ : '';
2104
+ resolvedPath = dataSourceResolution.resolvedPath + suffix;
2105
+ }
2106
+ }
2107
+ }
2108
+ }
2109
+
2110
+ // If still not resolved after fallback, skip
2111
+ if (!resolvedPath) {
2112
+ continue;
2113
+ }
2114
+ }
2115
+
2116
+ // Check for duplicates
2117
+ const normalizedPath = normalizePathForDeduplication(
2118
+ resolvedPath,
2119
+ fullToShortPathMap,
2120
+ );
2121
+
2122
+ if (seenNormalizedPaths.has(normalizedPath)) {
2123
+ continue;
2124
+ }
2125
+ seenNormalizedPaths.add(normalizedPath);
2126
+
2127
+ // Generate flows for this translated usage
2128
+ // Create a modified usage with the translated path for flow generation
2129
+ const translatedUsage: ConditionalUsage = {
2130
+ ...usage,
2131
+ path: resolvedPath,
2132
+ };
2133
+
2134
+ const usageFlows = generateFlowsFromUsage(
2135
+ translatedUsage,
2136
+ resolvedPath,
2137
+ );
2138
+
2139
+ // Add gating conditions to each flow
2140
+ for (const flow of usageFlows) {
2141
+ // Add gating required values to the flow
2142
+ if (gatingRequiredValues.length > 0) {
2143
+ // Filter out any gating values that are already in the flow
2144
+ const existingPaths = new Set(
2145
+ flow.requiredValues.map((rv) => rv.attributePath),
2146
+ );
2147
+ const newGatingValues = gatingRequiredValues.filter(
2148
+ (gv) => !existingPaths.has(gv.attributePath),
2149
+ );
2150
+ flow.requiredValues = [
2151
+ ...flow.requiredValues,
2152
+ ...newGatingValues,
2153
+ ];
2154
+
2155
+ // Update the flow ID to include gating conditions
2156
+ if (newGatingValues.length > 0) {
2157
+ const gatingIdPart = newGatingValues
2158
+ .map((gv) => `${gv.attributePath}-${gv.value}`)
2159
+ .join('-');
2160
+ flow.id = `${flow.id}-gated-${gatingIdPart}`;
2161
+ }
2162
+ }
2163
+
2164
+ if (!seenFlowIds.has(flow.id)) {
2165
+ seenFlowIds.add(flow.id);
2166
+ flows.push(flow);
2167
+ }
2168
+ }
2169
+ }
2170
+ }
2171
+
2172
+ // Process child's compound conditionals
2173
+ for (const compound of childData.compoundConditionals) {
2174
+ const resolvedPaths = new Map<string, string>();
2175
+ let allResolvable = true;
2176
+
2177
+ for (const condition of compound.conditions) {
2178
+ // Determine the child path to translate
2179
+ const childPath = condition.path;
2180
+
2181
+ // Translate the child path to a parent path
2182
+ const translatedPath = translateChildPathToParent(
2183
+ childPath,
2184
+ childData.equivalentSignatureVariables,
2185
+ equivalentSignatureVariables,
2186
+ childName,
2187
+ );
2188
+
2189
+ if (!translatedPath) {
2190
+ allResolvable = false;
2191
+ break;
2192
+ }
2193
+
2194
+ const resolution = resolvePathToControllable(
2195
+ translatedPath,
2196
+ attributesMap,
2197
+ equivalentSignatureVariables,
2198
+ fullToShortPathMap,
2199
+ );
2200
+
2201
+ // Only create flows for controllable paths (whitelist approach).
2202
+ // If the path doesn't resolve to something in attributesMap, skip it.
2203
+ // This prevents creating flows for useState values which are not
2204
+ // controllable via mock data injection.
2205
+ let resolvedPath = resolution.resolvedPath;
2206
+
2207
+ if (!resolution.isControllable || !resolvedPath) {
2208
+ // Path is not controllable via standard resolution.
2209
+ // Try fallback: For useState values (cyScope*().functionCallReturnValue),
2210
+ // look for a related URL parameter like "varNameFromUrl" that might
2211
+ // control the initial state.
2212
+ const useStateMatch = translatedPath.match(
2213
+ /^cyScope\d+\(\)\.functionCallReturnValue$/,
2214
+ );
2215
+
2216
+ if (useStateMatch) {
2217
+ const useStatePattern = translatedPath.replace(
2218
+ /\.functionCallReturnValue$/,
2219
+ '',
2220
+ );
2221
+
2222
+ // Find the variable name that maps to this useState
2223
+ let useStateVarName: string | null = null;
2224
+ for (const [varName, varPath] of Object.entries(
2225
+ equivalentSignatureVariables,
2226
+ )) {
2227
+ if (varPath === useStatePattern) {
2228
+ useStateVarName = varName;
2229
+ break;
2230
+ }
2231
+ }
2232
+
2233
+ if (useStateVarName) {
2234
+ const urlParamName = `${useStateVarName}FromUrl`;
2235
+ const urlParamPath = equivalentSignatureVariables[urlParamName];
2236
+
2237
+ if (urlParamPath) {
2238
+ resolvedPath = urlParamName;
2239
+ }
2240
+ }
2241
+ }
2242
+ }
2243
+
2244
+ if (!resolvedPath) {
2245
+ allResolvable = false;
2246
+ break;
2247
+ }
2248
+
2249
+ resolvedPaths.set(condition.path, resolvedPath);
2250
+ }
2251
+
2252
+ if (allResolvable && resolvedPaths.size > 0) {
2253
+ const compoundFlow = generateFlowFromCompound(
2254
+ compound,
2255
+ resolvedPaths,
2256
+ );
2257
+ if (compoundFlow) {
2258
+ // Add gating conditions to compound flow (same as regular usage flows)
2259
+ if (gatingRequiredValues.length > 0) {
2260
+ // Filter out any gating values that are already in the flow
2261
+ const existingPaths = new Set(
2262
+ compoundFlow.requiredValues.map((rv) => rv.attributePath),
2263
+ );
2264
+ const newGatingValues = gatingRequiredValues.filter(
2265
+ (gv) => !existingPaths.has(gv.attributePath),
2266
+ );
2267
+ compoundFlow.requiredValues = [
2268
+ ...compoundFlow.requiredValues,
2269
+ ...newGatingValues,
2270
+ ];
2271
+
2272
+ // Update the flow ID to include gating conditions
2273
+ if (newGatingValues.length > 0) {
2274
+ const gatingIdPart = newGatingValues
2275
+ .map((gv) => `${gv.attributePath}-${gv.value}`)
2276
+ .join('-');
2277
+ compoundFlow.id = `${compoundFlow.id}-gated-${gatingIdPart}`;
2278
+ }
2279
+ }
2280
+
2281
+ if (!seenFlowIds.has(compoundFlow.id)) {
2282
+ seenFlowIds.add(compoundFlow.id);
2283
+ flows.push(compoundFlow);
2284
+ }
2285
+ }
2286
+ }
2287
+ }
2288
+
2289
+ // Process child's jsxRenderingUsages (array.map flows)
2290
+ // This generates array variation flows (empty, few, many) for arrays rendered in child
2291
+ if (childData.jsxRenderingUsages) {
2292
+ for (const jsxUsage of childData.jsxRenderingUsages) {
2293
+ // Translate the child path to a parent path
2294
+ const translatedPath = translateChildPathToParent(
2295
+ jsxUsage.path,
2296
+ childData.equivalentSignatureVariables,
2297
+ equivalentSignatureVariables,
2298
+ childName,
2299
+ );
2300
+
2301
+ if (!translatedPath) {
2302
+ continue;
2303
+ }
2304
+
2305
+ // Resolve to controllable path in parent context
2306
+ const resolution = resolvePathToControllable(
2307
+ translatedPath,
2308
+ attributesMap,
2309
+ equivalentSignatureVariables,
2310
+ fullToShortPathMap,
2311
+ );
2312
+
2313
+ let resolvedPath = resolution.resolvedPath;
2314
+
2315
+ // Try sourceEquivalencies fallback if not controllable
2316
+ if (!resolution.isControllable || !resolvedPath) {
2317
+ if (sourceEquivalencies) {
2318
+ // Build the sourceEquivalencies key
2319
+ // The child path (e.g., "workouts") maps to a prop path (e.g., "signature[0].workouts")
2320
+ let childPropName: string | null = null;
2321
+ for (const [varName, varPath] of Object.entries(
2322
+ childData.equivalentSignatureVariables,
2323
+ )) {
2324
+ if (
2325
+ jsxUsage.path === varName ||
2326
+ jsxUsage.path.startsWith(`${varName}.`)
2327
+ ) {
2328
+ childPropName = varName;
2329
+ break;
2330
+ }
2331
+ }
2332
+
2333
+ if (childPropName) {
2334
+ const sourceEquivKey = `${childName}().signature[0].${childPropName}`;
2335
+ const sourceEquivEntry = sourceEquivalencies[sourceEquivKey];
2336
+
2337
+ if (sourceEquivEntry && sourceEquivEntry.length > 0) {
2338
+ const dataSourcePath = sourceEquivEntry[0].schemaPath;
2339
+
2340
+ const dataSourceResolution = resolvePathToControllable(
2341
+ dataSourcePath,
2342
+ attributesMap,
2343
+ equivalentSignatureVariables,
2344
+ fullToShortPathMap,
2345
+ );
2346
+
2347
+ if (
2348
+ dataSourceResolution.isControllable &&
2349
+ dataSourceResolution.resolvedPath
2350
+ ) {
2351
+ resolvedPath = dataSourceResolution.resolvedPath;
2352
+ }
2353
+ }
2354
+ }
2355
+ }
2356
+ }
2357
+
2358
+ if (!resolvedPath) {
2359
+ continue;
2360
+ }
2361
+
2362
+ // Check for duplicates
2363
+ const normalizedPath = normalizePathForDeduplication(
2364
+ resolvedPath,
2365
+ fullToShortPathMap,
2366
+ );
2367
+ const dedupeKey = `${normalizedPath}:${jsxUsage.renderingType}`;
2368
+ if (seenNormalizedPaths.has(dedupeKey)) {
2369
+ continue;
2370
+ }
2371
+ seenNormalizedPaths.add(dedupeKey);
2372
+
2373
+ // Generate array variation flows for array-map rendering
2374
+ if (jsxUsage.renderingType === 'array-map') {
2375
+ const baseName = generateNameFromPath(resolvedPath);
2376
+ const pathSlug = pathToSlug(resolvedPath);
2377
+ const exclusiveGroup = `array-length-${pathSlug}`;
2378
+
2379
+ // Empty array flow
2380
+ const emptyFlow: ExecutionFlow = {
2381
+ id: `${pathSlug}-empty-array`,
2382
+ name: `${baseName} Empty`,
2383
+ description: `When ${baseName.toLowerCase()} array is empty`,
2384
+ requiredValues: [
2385
+ {
2386
+ attributePath: resolvedPath,
2387
+ value: '0',
2388
+ comparison: 'length<',
2389
+ valueType: 'array',
2390
+ },
2391
+ ...gatingRequiredValues,
2392
+ ],
2393
+ impact: 'medium',
2394
+ exclusiveGroup,
2395
+ sourceLocation: jsxUsage.sourceLocation
2396
+ ? {
2397
+ lineNumber: jsxUsage.sourceLocation.lineNumber,
2398
+ column: jsxUsage.sourceLocation.column,
2399
+ }
2400
+ : undefined,
2401
+ codeSnippet: jsxUsage.sourceLocation?.codeSnippet,
2402
+ };
2403
+
2404
+ if (!seenFlowIds.has(emptyFlow.id)) {
2405
+ seenFlowIds.add(emptyFlow.id);
2406
+ flows.push(emptyFlow);
2407
+ }
2408
+
2409
+ // Few items flow (1-3)
2410
+ const fewFlow: ExecutionFlow = {
2411
+ id: `${pathSlug}-few-items`,
2412
+ name: `${baseName} Few Items`,
2413
+ description: `When ${baseName.toLowerCase()} array has 1-3 items`,
2414
+ requiredValues: [
2415
+ {
2416
+ attributePath: resolvedPath,
2417
+ value: '3',
2418
+ comparison: 'length<',
2419
+ valueType: 'array',
2420
+ },
2421
+ ...gatingRequiredValues,
2422
+ ],
2423
+ impact: 'low',
2424
+ exclusiveGroup,
2425
+ sourceLocation: jsxUsage.sourceLocation
2426
+ ? {
2427
+ lineNumber: jsxUsage.sourceLocation.lineNumber,
2428
+ column: jsxUsage.sourceLocation.column,
2429
+ }
2430
+ : undefined,
2431
+ codeSnippet: jsxUsage.sourceLocation?.codeSnippet,
2432
+ };
2433
+
2434
+ if (!seenFlowIds.has(fewFlow.id)) {
2435
+ seenFlowIds.add(fewFlow.id);
2436
+ flows.push(fewFlow);
2437
+ }
2438
+
2439
+ // Many items flow (10+)
2440
+ const manyFlow: ExecutionFlow = {
2441
+ id: `${pathSlug}-many-items`,
2442
+ name: `${baseName} Many Items`,
2443
+ description: `When ${baseName.toLowerCase()} array has many items`,
2444
+ requiredValues: [
2445
+ {
2446
+ attributePath: resolvedPath,
2447
+ value: '10',
2448
+ comparison: 'length>',
2449
+ valueType: 'array',
2450
+ },
2451
+ ...gatingRequiredValues,
2452
+ ],
2453
+ impact: 'low',
2454
+ exclusiveGroup,
2455
+ sourceLocation: jsxUsage.sourceLocation
2456
+ ? {
2457
+ lineNumber: jsxUsage.sourceLocation.lineNumber,
2458
+ column: jsxUsage.sourceLocation.column,
2459
+ }
2460
+ : undefined,
2461
+ codeSnippet: jsxUsage.sourceLocation?.codeSnippet,
2462
+ };
2463
+
2464
+ if (!seenFlowIds.has(manyFlow.id)) {
2465
+ seenFlowIds.add(manyFlow.id);
2466
+ flows.push(manyFlow);
2467
+ }
2468
+ }
2469
+ }
2470
+ }
2471
+ }
2472
+ }
2473
+
2474
+ console.log(
2475
+ `[genFlowsFromConditionals] RESULT: ${flows.length} total flows generated`,
2476
+ );
2477
+ for (const flow of flows) {
2478
+ console.log(
2479
+ `[genFlowsFromConditionals] FLOW: id="${flow.id}" requiredValues=[${flow.requiredValues.map((rv) => `${rv.attributePath}=${rv.value}`).join(', ')}]`,
2480
+ );
2481
+ }
2482
+
2483
+ return flows;
2484
+ }