@codeyam/codeyam-cli 0.1.0-staging.b8a55ba → 0.1.0-staging.c1c8678
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.
- package/analyzer-template/.build-info.json +8 -8
- package/analyzer-template/common/execAsync.ts +1 -1
- package/analyzer-template/log.txt +3 -3
- package/analyzer-template/package.json +15 -12
- package/analyzer-template/packages/ai/index.ts +21 -5
- package/analyzer-template/packages/ai/package.json +3 -3
- package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
- package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +226 -24
- package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +183 -10
- package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +181 -23
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +15 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1229 -30
- package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +265 -6
- package/analyzer-template/packages/ai/src/lib/checkAllAttributes.ts +29 -10
- package/analyzer-template/packages/ai/src/lib/completionCall.ts +216 -36
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1867 -334
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +7 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +296 -35
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +120 -76
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +54 -3
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +140 -20
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +393 -90
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
- package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +174 -0
- package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
- package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
- package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
- package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +74 -7
- package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +86 -142
- package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +59 -3
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1421 -88
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +200 -196
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +614 -0
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
- package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +5 -5
- package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
- package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
- package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +111 -87
- package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +32 -142
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -89
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +11 -11
- package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
- package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
- package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
- package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
- package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +122 -3
- package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
- package/analyzer-template/packages/analyze/index.ts +2 -0
- package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +79 -59
- package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
- package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
- package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +1 -0
- package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
- package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
- package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
- package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
- package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
- package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
- package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +466 -270
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +34 -1
- package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +3 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
- package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
- package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +31 -15
- package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +11 -7
- package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
- package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
- package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
- package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +201 -46
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +593 -84
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -62
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +377 -84
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +264 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +35 -129
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +2 -3
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +970 -140
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
- package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
- package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
- package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
- package/analyzer-template/packages/aws/codebuild/index.ts +1 -0
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +11 -1
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +29 -18
- package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +2 -2
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +2 -2
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +8 -18
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +17 -61
- package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -1
- package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +8 -1
- package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -1
- package/analyzer-template/packages/aws/package.json +3 -3
- package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +43 -19
- package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +3 -3
- package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +17 -69
- package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +8 -1
- package/analyzer-template/packages/database/package.json +1 -1
- package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -1
- package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
- package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +17 -1
- package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
- package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
- package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
- package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
- package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
- package/analyzer-template/packages/database/src/lib/loadCommits.ts +28 -0
- package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
- package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
- package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +7 -3
- package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
- package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +7 -14
- package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
- package/analyzer-template/packages/generate/index.ts +3 -0
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +17 -1
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +193 -0
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
- package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
- package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +11 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -18
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +17 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +2 -6
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +22 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
- package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +5 -4
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/index.d.ts +3 -0
- package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/index.js +3 -0
- package/analyzer-template/packages/github/dist/generate/index.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
- package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
- package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +10 -0
- package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -1
- package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +3 -0
- package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/index.d.ts +3 -4
- package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/index.js +0 -1
- package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +71 -27
- package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
- package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +2 -0
- package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +7 -0
- package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +9 -54
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.js +1 -21
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
- package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
- package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
- package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
- package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
- package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
- package/analyzer-template/packages/github/package.json +1 -1
- package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +14 -0
- package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +2 -0
- package/analyzer-template/packages/process/index.ts +2 -0
- package/analyzer-template/packages/process/package.json +12 -0
- package/analyzer-template/packages/process/tsconfig.json +8 -0
- package/analyzer-template/packages/types/index.ts +3 -6
- package/analyzer-template/packages/types/src/types/Analysis.ts +87 -27
- package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
- package/analyzer-template/packages/types/src/types/Entity.ts +2 -0
- package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
- package/analyzer-template/packages/types/src/types/Scenario.ts +9 -77
- package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +181 -5
- package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
- package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/index.d.ts +3 -4
- package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/index.js +0 -1
- package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +71 -27
- package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +7 -0
- package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +9 -54
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js +1 -21
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
- package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
- package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +93 -2
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
- package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
- package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +108 -2
- package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
- package/analyzer-template/playwright/capture.ts +57 -26
- package/analyzer-template/playwright/captureStatic.ts +1 -1
- package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
- package/analyzer-template/playwright/waitForServer.ts +21 -6
- package/analyzer-template/project/analyzeBaselineCommit.ts +9 -0
- package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
- package/analyzer-template/project/analyzeFileEntities.ts +4 -0
- package/analyzer-template/project/analyzeRegularCommit.ts +9 -0
- package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
- package/analyzer-template/project/constructMockCode.ts +1201 -178
- package/analyzer-template/project/controller/startController.ts +16 -1
- package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
- package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
- package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
- package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
- package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
- package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +3 -6
- package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
- package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
- package/analyzer-template/project/orchestrateCapture.ts +81 -9
- package/analyzer-template/project/reconcileMockDataKeys.ts +220 -78
- package/analyzer-template/project/runAnalysis.ts +11 -0
- package/analyzer-template/project/serverOnlyModules.ts +127 -2
- package/analyzer-template/project/start.ts +51 -15
- package/analyzer-template/project/startScenarioCapture.ts +6 -0
- package/analyzer-template/project/writeMockDataTsx.ts +345 -32
- package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
- package/analyzer-template/project/writeScenarioComponents.ts +358 -118
- package/analyzer-template/project/writeScenarioFiles.ts +26 -0
- package/analyzer-template/project/writeSimpleRoot.ts +28 -42
- package/analyzer-template/scripts/comboWorkerLoop.cjs +99 -50
- package/analyzer-template/scripts/defaultCmd.sh +9 -0
- package/analyzer-template/tsconfig.json +2 -1
- package/background/src/lib/local/createLocalAnalyzer.js +2 -30
- package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
- package/background/src/lib/local/execAsync.js +1 -1
- package/background/src/lib/local/execAsync.js.map +1 -1
- package/background/src/lib/virtualized/common/execAsync.js +1 -1
- package/background/src/lib/virtualized/common/execAsync.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +7 -1
- package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
- package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
- package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeRegularCommit.js +7 -1
- package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
- package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
- package/background/src/lib/virtualized/project/constructMockCode.js +1062 -134
- package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
- package/background/src/lib/virtualized/project/controller/startController.js +11 -1
- package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
- package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
- package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
- package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
- package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
- package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
- package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
- package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
- package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
- package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +3 -2
- package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
- package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js +65 -10
- package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +188 -47
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
- package/background/src/lib/virtualized/project/runAnalysis.js +9 -0
- package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
- package/background/src/lib/virtualized/project/serverOnlyModules.js +106 -3
- package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -1
- package/background/src/lib/virtualized/project/start.js +47 -15
- package/background/src/lib/virtualized/project/start.js.map +1 -1
- package/background/src/lib/virtualized/project/startScenarioCapture.js +7 -0
- package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/writeMockDataTsx.js +301 -27
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
- package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +278 -100
- package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioFiles.js +19 -0
- package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -1
- package/background/src/lib/virtualized/project/writeSimpleRoot.js +28 -41
- package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
- package/codeyam-cli/scripts/apply-setup.js +180 -0
- package/codeyam-cli/scripts/apply-setup.js.map +1 -1
- package/codeyam-cli/src/cli.js +9 -1
- package/codeyam-cli/src/cli.js.map +1 -1
- package/codeyam-cli/src/codeyam-cli.js +18 -2
- package/codeyam-cli/src/codeyam-cli.js.map +1 -1
- package/codeyam-cli/src/commands/analyze.js +5 -3
- package/codeyam-cli/src/commands/analyze.js.map +1 -1
- package/codeyam-cli/src/commands/baseline.js +176 -0
- package/codeyam-cli/src/commands/baseline.js.map +1 -0
- package/codeyam-cli/src/commands/debug.js +37 -23
- package/codeyam-cli/src/commands/debug.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +30 -34
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/detect-universal-mocks.js +2 -0
- package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -1
- package/codeyam-cli/src/commands/init.js +49 -257
- package/codeyam-cli/src/commands/init.js.map +1 -1
- package/codeyam-cli/src/commands/memory.js +264 -0
- package/codeyam-cli/src/commands/memory.js.map +1 -0
- package/codeyam-cli/src/commands/recapture.js +31 -18
- package/codeyam-cli/src/commands/recapture.js.map +1 -1
- package/codeyam-cli/src/commands/report.js +46 -1
- package/codeyam-cli/src/commands/report.js.map +1 -1
- package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
- package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
- package/codeyam-cli/src/commands/setup-simulations.js +284 -0
- package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
- package/codeyam-cli/src/commands/start.js +8 -12
- package/codeyam-cli/src/commands/start.js.map +1 -1
- package/codeyam-cli/src/commands/status.js +23 -1
- package/codeyam-cli/src/commands/status.js.map +1 -1
- package/codeyam-cli/src/commands/test-startup.js +3 -1
- package/codeyam-cli/src/commands/test-startup.js.map +1 -1
- package/codeyam-cli/src/commands/verify.js +14 -2
- package/codeyam-cli/src/commands/verify.js.map +1 -1
- package/codeyam-cli/src/commands/wipe.js +108 -0
- package/codeyam-cli/src/commands/wipe.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
- package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +128 -82
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
- package/codeyam-cli/src/utils/analysisRunner.js +29 -15
- package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
- package/codeyam-cli/src/utils/analyzer.js +7 -0
- package/codeyam-cli/src/utils/analyzer.js.map +1 -1
- package/codeyam-cli/src/utils/backgroundServer.js +112 -21
- package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/utils/database.js +91 -5
- package/codeyam-cli/src/utils/database.js.map +1 -1
- package/codeyam-cli/src/utils/generateReport.js +4 -3
- package/codeyam-cli/src/utils/generateReport.js.map +1 -1
- package/codeyam-cli/src/utils/git.js +79 -0
- package/codeyam-cli/src/utils/git.js.map +1 -0
- package/codeyam-cli/src/utils/install-skills.js +76 -37
- package/codeyam-cli/src/utils/install-skills.js.map +1 -1
- package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
- package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
- package/codeyam-cli/src/utils/progress.js +7 -0
- package/codeyam-cli/src/utils/progress.js.map +1 -1
- package/codeyam-cli/src/utils/queue/job.js +109 -0
- package/codeyam-cli/src/utils/queue/job.js.map +1 -1
- package/codeyam-cli/src/utils/queue/manager.js +6 -0
- package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
- package/codeyam-cli/src/utils/queue/persistence.js.map +1 -1
- package/codeyam-cli/src/utils/requireSimulations.js +10 -0
- package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +378 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
- package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
- package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
- package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
- package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
- package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
- package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
- package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/index.js +6 -0
- package/codeyam-cli/src/utils/rules/index.js.map +1 -0
- package/codeyam-cli/src/utils/rules/parser.js +83 -0
- package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
- package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
- package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
- package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
- package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
- package/codeyam-cli/src/utils/rules/staleness.js +137 -0
- package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
- package/codeyam-cli/src/utils/serverState.js +37 -10
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +21 -42
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
- package/codeyam-cli/src/utils/versionInfo.js +25 -19
- package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
- package/codeyam-cli/src/utils/wipe.js +128 -0
- package/codeyam-cli/src/utils/wipe.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js +88 -23
- package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
- package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
- package/codeyam-cli/src/webserver/backgroundServer.js +50 -0
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/bootstrap.js +51 -0
- package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/CopyButton-D9i_zSlY.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BLlhOa3C.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-CzGX-miz.js → EntityTypeBadge-De5b5pC7.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CzdG5I7z.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bclf8Hka.js +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-Ce-byqKl.js +25 -0
- package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CBQPrpT0.js → LibraryFunctionPreview-DEMHrl7v.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-D1CdlbrV.js → LoadingDots-B1LNGboS.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-wDPcZNKx.js → LogViewer-B0Ll1DjK.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-CVOvmCKb.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-BfmDgXxG.js → SafeScreenshot-L0DWHa_L.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-D54Mmpwi.js +10 -0
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-6J7zDUD5.js → TruncatedFilePath-C7PFQfXy.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/_index-CKTtYlBU.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-CdziRIWU.js +27 -0
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-CPXtdaWm.js +17 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/book-open-Ch8b7GyQ.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-BYimnrHg.js → chevron-down-vJHJExlT.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BEyX4X6_.js +51 -0
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-CaVsIRxt.js → circle-check-rwynPZTW.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/copy-BBSpeBYf.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-CgUsG7ib.js → createLucideIcon-DHVDauuc.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-B9_ZqelV.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-BOPComvD.js +16 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Cfw__yQa.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-BIDUUrI3.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CfLCUi9S.js → entity._sha_.edit._scenarioId-BEqewwtZ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-DKJyZfAY.js → entry.client-Dxqz8ygt.js} +6 -6
- package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DAtOlaWE.js → fileTableUtils-CYnF5KWN.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/files-B_dAq2PQ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{git-D62Lxxmv.js → git-BHPqH3Ch.js} +8 -8
- package/codeyam-cli/src/webserver/build/client/assets/globals-BJGhRykz.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-BosqDOlH.js → index-DgAAopZk.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{index-CzNNiTkw.js → index-viijWaN6.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/labs-ChoAe3xq.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-CNp9QFCX.js → loader-circle-LGi2eKI5.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-87493a32.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-D9eA6kTo.js +78 -0
- package/codeyam-cli/src/webserver/build/client/assets/pause-DxJFmMsK.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/root-C3r0p_7H.js +62 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-DDGjYAMJ.js → search-Cu3QE9E5.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/settings-KH9TdArD.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/simulations-D9Fkx0-d.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/terminal-dAhIBEcd.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CBc5dE1s.js → triangle-alert-C4CYTEeP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CLPnITMB.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-BqPPNjAl.js → useLastLogLine-DmGI38Et.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/useReportContext-BK0S88PB.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-DWHcCcl1.js → useToast-CJ-JqR0l.js} +1 -1
- package/codeyam-cli/src/webserver/build/server/assets/index-CkkmL6r5.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-iBGjHYtO.js +259 -0
- package/codeyam-cli/src/webserver/build/server/index.js +1 -1
- package/codeyam-cli/src/webserver/build-info.json +5 -5
- package/codeyam-cli/src/webserver/server.js +35 -25
- package/codeyam-cli/src/webserver/server.js.map +1 -1
- package/codeyam-cli/templates/{codeyam-debug-skill.md → codeyam-debug.md} +48 -4
- package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
- package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
- package/codeyam-cli/templates/codeyam-memory.md +396 -0
- package/codeyam-cli/templates/codeyam-new-rule.md +13 -0
- package/codeyam-cli/templates/{codeyam-setup-skill.md → codeyam-setup.md} +151 -4
- package/codeyam-cli/templates/{codeyam-sim-skill.md → codeyam-sim.md} +1 -1
- package/codeyam-cli/templates/{codeyam-test-skill.md → codeyam-test.md} +1 -1
- package/codeyam-cli/templates/{codeyam-verify-skill.md → codeyam-verify.md} +1 -1
- package/codeyam-cli/templates/rule-notification-hook.py +56 -0
- package/codeyam-cli/templates/rule-reflection-hook.py +627 -0
- package/codeyam-cli/templates/rules-instructions.md +132 -0
- package/package.json +17 -14
- package/packages/ai/index.js +8 -6
- package/packages/ai/index.js.map +1 -1
- package/packages/ai/src/lib/analyzeScope.js +179 -13
- package/packages/ai/src/lib/analyzeScope.js.map +1 -1
- package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
- package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +138 -9
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
- package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
- package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
- package/packages/ai/src/lib/astScopes/methodSemantics.js +138 -23
- package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
- package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
- package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +7 -0
- package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
- package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/processExpression.js +944 -30
- package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
- package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
- package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
- package/packages/ai/src/lib/checkAllAttributes.js +24 -9
- package/packages/ai/src/lib/checkAllAttributes.js.map +1 -1
- package/packages/ai/src/lib/completionCall.js +178 -31
- package/packages/ai/src/lib/completionCall.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1461 -205
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +7 -2
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +230 -23
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +77 -55
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
- package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
- package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +52 -3
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +122 -14
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
- package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
- package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
- package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
- package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +333 -81
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
- package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
- package/packages/ai/src/lib/dataStructureChunking.js +126 -0
- package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
- package/packages/ai/src/lib/deepEqual.js +32 -0
- package/packages/ai/src/lib/deepEqual.js.map +1 -0
- package/packages/ai/src/lib/e2eDataTracking.js +241 -0
- package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
- package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
- package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
- package/packages/ai/src/lib/generateChangesEntityScenarioData.js +62 -5
- package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateChangesEntityScenarios.js +78 -120
- package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
- package/packages/ai/src/lib/generateEntityDataStructure.js +47 -2
- package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarioData.js +1130 -83
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarios.js +177 -163
- package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +414 -0
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
- package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -2
- package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
- package/packages/ai/src/lib/isolateScopes.js +270 -7
- package/packages/ai/src/lib/isolateScopes.js.map +1 -1
- package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
- package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
- package/packages/ai/src/lib/mergeStatements.js +88 -46
- package/packages/ai/src/lib/mergeStatements.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
- package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -100
- package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
- package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -70
- package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
- package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +9 -9
- package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
- package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
- package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
- package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
- package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
- package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
- package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
- package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
- package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
- package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
- package/packages/analyze/index.js +1 -0
- package/packages/analyze/index.js.map +1 -1
- package/packages/analyze/src/lib/FileAnalyzer.js +75 -36
- package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
- package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
- package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
- package/packages/analyze/src/lib/analysisContext.js +30 -5
- package/packages/analyze/src/lib/analysisContext.js.map +1 -1
- package/packages/analyze/src/lib/asts/nodes/index.js +1 -0
- package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -1
- package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
- package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
- package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
- package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
- package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
- package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
- package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
- package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +211 -54
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +24 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +5 -0
- package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +2 -0
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
- package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
- package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeChange.js +21 -11
- package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeEntity.js +9 -8
- package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
- package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
- package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
- package/packages/analyze/src/lib/files/enums/steps.js +1 -1
- package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
- package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
- package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +170 -40
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
- package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +480 -71
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -34
- package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +268 -66
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +144 -0
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +27 -98
- package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +2 -3
- package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +801 -118
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
- package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
- package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
- package/packages/analyze/src/lib/index.js +1 -0
- package/packages/analyze/src/lib/index.js.map +1 -1
- package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
- package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
- package/packages/aws/src/lib/ecs/ecsDefineContainer.js +2 -2
- package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -1
- package/packages/aws/src/lib/ecs/ecsTaskFactory.js +17 -61
- package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -1
- package/packages/database/src/lib/analysisBranchToDb.js +1 -1
- package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
- package/packages/database/src/lib/analysisToDb.js +1 -1
- package/packages/database/src/lib/analysisToDb.js.map +1 -1
- package/packages/database/src/lib/branchToDb.js +1 -1
- package/packages/database/src/lib/branchToDb.js.map +1 -1
- package/packages/database/src/lib/commitBranchToDb.js +1 -1
- package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
- package/packages/database/src/lib/commitToDb.js +1 -1
- package/packages/database/src/lib/commitToDb.js.map +1 -1
- package/packages/database/src/lib/fileToDb.js +1 -1
- package/packages/database/src/lib/fileToDb.js.map +1 -1
- package/packages/database/src/lib/kysely/db.js +11 -1
- package/packages/database/src/lib/kysely/db.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
- package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
- package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
- package/packages/database/src/lib/loadAnalyses.js +45 -2
- package/packages/database/src/lib/loadAnalyses.js.map +1 -1
- package/packages/database/src/lib/loadAnalysis.js +8 -0
- package/packages/database/src/lib/loadAnalysis.js.map +1 -1
- package/packages/database/src/lib/loadBranch.js +11 -1
- package/packages/database/src/lib/loadBranch.js.map +1 -1
- package/packages/database/src/lib/loadCommit.js +7 -0
- package/packages/database/src/lib/loadCommit.js.map +1 -1
- package/packages/database/src/lib/loadCommits.js +22 -1
- package/packages/database/src/lib/loadCommits.js.map +1 -1
- package/packages/database/src/lib/loadEntities.js +23 -4
- package/packages/database/src/lib/loadEntities.js.map +1 -1
- package/packages/database/src/lib/loadEntityBranches.js +9 -0
- package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
- package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +7 -4
- package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
- package/packages/database/src/lib/projectToDb.js +1 -1
- package/packages/database/src/lib/projectToDb.js.map +1 -1
- package/packages/database/src/lib/saveFiles.js +1 -1
- package/packages/database/src/lib/saveFiles.js.map +1 -1
- package/packages/database/src/lib/scenarioToDb.js +1 -1
- package/packages/database/src/lib/scenarioToDb.js.map +1 -1
- package/packages/database/src/lib/updateCommitMetadata.js +5 -4
- package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
- package/packages/generate/index.js +3 -0
- package/packages/generate/index.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
- package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
- package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
- package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
- package/packages/github/src/lib/loadOrCreateCommit.js +10 -0
- package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -1
- package/packages/github/src/lib/syncPrimaryBranch.js +3 -0
- package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -1
- package/packages/process/index.js +3 -0
- package/packages/process/index.js.map +1 -0
- package/packages/process/src/GlobalProcessManager.js.map +1 -0
- package/{background/src/lib/process → packages/process/src}/ProcessManager.js +1 -1
- package/packages/process/src/ProcessManager.js.map +1 -0
- package/packages/process/src/index.js.map +1 -0
- package/packages/process/src/managedExecAsync.js.map +1 -0
- package/packages/types/index.js +0 -1
- package/packages/types/index.js.map +1 -1
- package/packages/types/src/types/Scenario.js +1 -21
- package/packages/types/src/types/Scenario.js.map +1 -1
- package/packages/utils/src/lib/fs/rsyncCopy.js +93 -2
- package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/packages/utils/src/lib/safeFileName.js +29 -3
- package/packages/utils/src/lib/safeFileName.js.map +1 -1
- package/scripts/finalize-analyzer.cjs +8 -76
- package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -102
- package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -409
- package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -288
- package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -495
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -120
- package/analyzer-template/process/INTEGRATION_COMPLETE.md +0 -333
- package/analyzer-template/process/INTEGRATION_EXAMPLE.md +0 -525
- package/analyzer-template/process/README.md +0 -507
- package/background/src/lib/process/GlobalProcessManager.js.map +0 -1
- package/background/src/lib/process/ProcessManager.js.map +0 -1
- package/background/src/lib/process/index.js.map +0 -1
- package/background/src/lib/process/managedExecAsync.js.map +0 -1
- package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js +0 -238
- package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js.map +0 -1
- package/codeyam-cli/scripts/fixtures/formbricks/universal-mocks/apps/web/lib/instance/service.js +0 -7
- package/codeyam-cli/scripts/fixtures/formbricks/universal-mocks/apps/web/lib/instance/service.js.map +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityItem-wXL1Z2Aq.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CXFKsCOD.js +0 -41
- package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-D-9pXIaY.js +0 -25
- package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-4lcOlid-.js +0 -11
- package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-CUxUNEEC.js +0 -15
- package/codeyam-cli/src/webserver/build/client/assets/_index-DHImXdXq.js +0 -11
- package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-2mG6mjVb.js +0 -32
- package/codeyam-cli/src/webserver/build/client/assets/chunk-JMJ3UQ3L-BambyYE_.js +0 -51
- package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CKnwPCDr.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-DW_hdGUc.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha._-zUEpfPsu.js +0 -23
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DyB90fWk.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D_3ero5o.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/files-ClR0d32A.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/globals-C6vQASxy.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/keyAttributeCoverage-CTlFMihX.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-09d684be.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/root-BxJUvKau.js +0 -56
- package/codeyam-cli/src/webserver/build/client/assets/settings-DgTyB-Wg.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/simulations-CoNWGt0K.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BMIGFP-m.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useInteractiveMode-Dk_FQqWJ.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DsJbgMY9.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/index-CV6i1S1A.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BDlyhfrv.js +0 -175
- package/codeyam-cli/templates/debug-codeyam.md +0 -620
- package/packages/ai/src/lib/findMatchingAttribute.js +0 -77
- package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
- package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -298
- package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
- package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -226
- package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
- package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -408
- package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
- package/packages/ai/src/lib/isFrontend.js +0 -5
- package/packages/ai/src/lib/isFrontend.js.map +0 -1
- package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
- package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
- package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -77
- package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
- /package/analyzer-template/{process → packages/process/src}/GlobalProcessManager.ts +0 -0
- /package/analyzer-template/{process → packages/process/src}/ProcessManager.ts +0 -0
- /package/analyzer-template/{process → packages/process/src}/index.ts +0 -0
- /package/analyzer-template/{process → packages/process/src}/managedExecAsync.ts +0 -0
- /package/codeyam-cli/src/webserver/build/client/assets/{api.link-scenario-value-l0sNRNKZ.js → api.agent-transcripts-l0sNRNKZ.js} +0 -0
- /package/codeyam-cli/src/webserver/build/client/assets/{api.update-key-attributes-l0sNRNKZ.js → api.health-l0sNRNKZ.js} +0 -0
- /package/codeyam-cli/src/webserver/build/client/assets/{api.update-valid-values-l0sNRNKZ.js → api.labs-unlock-l0sNRNKZ.js} +0 -0
- /package/{background/src/lib/process → packages/process/src}/GlobalProcessManager.js +0 -0
- /package/{background/src/lib/process → packages/process/src}/index.js +0 -0
- /package/{background/src/lib/process → packages/process/src}/managedExecAsync.js +0 -0
|
@@ -4,19 +4,27 @@ import { awsLog, awsLogDebugLevel } from '~codeyam/utils';
|
|
|
4
4
|
import measureAndReportExecutionTime from '../../../utils/measureAndReportExecutionTime';
|
|
5
5
|
|
|
6
6
|
import {
|
|
7
|
+
deduplicateFunctionSchemas,
|
|
8
|
+
detectWrapperRequirements,
|
|
7
9
|
fillInDirectSchemaGapsAndUnknowns,
|
|
8
10
|
generateEntityDataStructure,
|
|
9
|
-
|
|
11
|
+
getConditionalUsages,
|
|
10
12
|
getEquivalentSignatureVariables,
|
|
11
13
|
getFunctionSignature,
|
|
12
14
|
getReturnValue,
|
|
13
15
|
getSourceEquivalencies,
|
|
14
16
|
getUsageEquivalencies,
|
|
15
|
-
|
|
16
|
-
|
|
17
|
+
getConditionalEffects,
|
|
18
|
+
getCompoundConditionals,
|
|
19
|
+
getChildBoundaryGatingConditions,
|
|
20
|
+
getJsxRenderingUsages,
|
|
21
|
+
skipWorkerPool,
|
|
17
22
|
} from '~codeyam/ai';
|
|
18
23
|
import type { AnalysisOptions } from '../analyzeEntities';
|
|
19
24
|
|
|
25
|
+
// Set to true to process entities one at a time for easier debugging.
|
|
26
|
+
const DEBUG_SEQUENTIAL_EXECUTION = false;
|
|
27
|
+
|
|
20
28
|
// VERSION MARKER: server-only-detection-v2 (2025-12-28)
|
|
21
29
|
// This version includes automatic detection of "use server" and "server-only" files
|
|
22
30
|
// and runs server-only detection even for cached entities
|
|
@@ -31,254 +39,268 @@ export default async function prepareEntityDataStructures(
|
|
|
31
39
|
projectAnalyzer: ProjectAnalyzer,
|
|
32
40
|
options: AnalysisOptions,
|
|
33
41
|
): Promise<void> {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
42
|
+
const processEntity = async (entity: Entity) => {
|
|
43
|
+
// Check if already has cached data structure (unless force is set)
|
|
44
|
+
const hasCache = !!entity.metadata?.isolatedDataStructure;
|
|
45
|
+
const shouldRegenerateDataStructure =
|
|
46
|
+
!hasCache || options.force || options.forceAll;
|
|
47
|
+
|
|
48
|
+
// PHASE 1: Generate data structure (only for non-cached entities or when forced)
|
|
49
|
+
// Wrapped in its own try-catch so PHASE 2 always runs even if this fails
|
|
50
|
+
if (shouldRegenerateDataStructure) {
|
|
51
|
+
try {
|
|
52
|
+
const fileAnalyzer = projectAnalyzer.getFileAnalyzerByPath(
|
|
53
|
+
entity.resolvedFilePath ?? entity.filePath,
|
|
54
|
+
);
|
|
55
|
+
if (!fileAnalyzer) {
|
|
56
|
+
awsLog(
|
|
57
|
+
`CodeYam: prepareEntityDataStructures: FileAnalyzer not found`,
|
|
58
|
+
{
|
|
59
|
+
entityFilePath: entity.filePath,
|
|
60
|
+
entityName: entity.name,
|
|
61
|
+
},
|
|
48
62
|
);
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
63
|
+
// Still continue to PHASE 2 for server-only detection
|
|
64
|
+
} else {
|
|
65
|
+
const dataStructureInfo =
|
|
66
|
+
await getEntityDataStructureAndFunctionCalls({
|
|
67
|
+
entity,
|
|
68
|
+
fileAnalyzer,
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
if (!dataStructureInfo?.isolatedDataStructure) {
|
|
72
|
+
// Data structure generation failed - entity will proceed with empty schemas
|
|
73
|
+
// This is okay - the entity can still be analyzed, just without detailed type info
|
|
74
|
+
if (['visual', 'library'].includes(entity.entityType)) {
|
|
75
|
+
// we'd really expect these to have data structures
|
|
76
|
+
awsLog(
|
|
77
|
+
`CodeYam: prepareEntityDataStructures: Failed to generate data structure for ${entity.filePath}:${entity.name}`,
|
|
78
|
+
);
|
|
79
|
+
}
|
|
57
80
|
// Still continue to PHASE 2 for server-only detection
|
|
58
81
|
} else {
|
|
59
|
-
const
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
82
|
+
const { isolatedDataStructure, functionCalls, callVariableNames } =
|
|
83
|
+
dataStructureInfo;
|
|
84
|
+
|
|
85
|
+
// Store data structure in entity metadata
|
|
86
|
+
entity.metadata ||= {};
|
|
87
|
+
|
|
88
|
+
// Deep clone dependencySchemas to avoid shared references
|
|
89
|
+
// We need to clone because getReturnValue() returns direct references to schema objects
|
|
90
|
+
// and multiple entities might reference the same dependency
|
|
91
|
+
const clonedDependencySchemas: typeof isolatedDataStructure.dependencySchemas =
|
|
92
|
+
{};
|
|
93
|
+
for (const filePath in isolatedDataStructure.dependencySchemas) {
|
|
94
|
+
clonedDependencySchemas[filePath] = {};
|
|
95
|
+
for (const entityName in isolatedDataStructure.dependencySchemas[
|
|
96
|
+
filePath
|
|
97
|
+
]) {
|
|
98
|
+
const depSchema =
|
|
99
|
+
isolatedDataStructure.dependencySchemas[filePath][entityName];
|
|
100
|
+
clonedDependencySchemas[filePath][entityName] = {
|
|
101
|
+
signatureSchema: { ...depSchema.signatureSchema },
|
|
102
|
+
returnValueSchema: { ...depSchema.returnValueSchema },
|
|
103
|
+
usageEquivalencies: depSchema.usageEquivalencies,
|
|
104
|
+
sourceEquivalencies: depSchema.sourceEquivalencies,
|
|
105
|
+
};
|
|
73
106
|
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
// Store data structure in entity metadata
|
|
83
|
-
entity.metadata ||= {};
|
|
84
|
-
|
|
85
|
-
// Deep clone dependencySchemas to avoid shared references
|
|
86
|
-
// We need to clone because getReturnValue() returns direct references to schema objects
|
|
87
|
-
// and multiple entities might reference the same dependency
|
|
88
|
-
const clonedDependencySchemas: typeof isolatedDataStructure.dependencySchemas =
|
|
89
|
-
{};
|
|
90
|
-
for (const filePath in isolatedDataStructure.dependencySchemas) {
|
|
91
|
-
clonedDependencySchemas[filePath] = {};
|
|
92
|
-
for (const entityName in isolatedDataStructure
|
|
93
|
-
.dependencySchemas[filePath]) {
|
|
94
|
-
const depSchema =
|
|
95
|
-
isolatedDataStructure.dependencySchemas[filePath][
|
|
96
|
-
entityName
|
|
97
|
-
];
|
|
98
|
-
clonedDependencySchemas[filePath][entityName] = {
|
|
99
|
-
signatureSchema: { ...depSchema.signatureSchema },
|
|
100
|
-
returnValueSchema: { ...depSchema.returnValueSchema },
|
|
101
|
-
usageEquivalencies: depSchema.usageEquivalencies,
|
|
102
|
-
sourceEquivalencies: depSchema.sourceEquivalencies,
|
|
103
|
-
};
|
|
104
|
-
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// LOGGING: Track dependencySchemas entity names for debugging :: format issues
|
|
110
|
+
const allEntityNames: string[] = [];
|
|
111
|
+
for (const filePath in clonedDependencySchemas) {
|
|
112
|
+
for (const entityName in clonedDependencySchemas[filePath]) {
|
|
113
|
+
allEntityNames.push(`${filePath}:${entityName}`);
|
|
105
114
|
}
|
|
115
|
+
}
|
|
116
|
+
entity.metadata.isolatedDataStructure = {
|
|
117
|
+
signatureSchema: deduplicateFunctionSchemas(
|
|
118
|
+
isolatedDataStructure.signatureSchema,
|
|
119
|
+
),
|
|
120
|
+
returnValueSchema: deduplicateFunctionSchemas(
|
|
121
|
+
isolatedDataStructure.returnValueSchema,
|
|
122
|
+
),
|
|
123
|
+
equivalentSignatureVariables:
|
|
124
|
+
isolatedDataStructure.equivalentSignatureVariables,
|
|
125
|
+
dependencySchemas: clonedDependencySchemas,
|
|
126
|
+
environmentVariables: isolatedDataStructure.environmentVariables,
|
|
127
|
+
// Use enriched conditional usages with source tracing from analysis
|
|
128
|
+
conditionalUsages: isolatedDataStructure.conditionalUsages,
|
|
129
|
+
// Include conditional effects for execution flow generation
|
|
130
|
+
conditionalEffects: isolatedDataStructure.conditionalEffects,
|
|
131
|
+
// Include compound conditionals for complete execution flow generation
|
|
132
|
+
compoundConditionals: isolatedDataStructure.compoundConditionals,
|
|
133
|
+
// Include root entity's equivalencies for merge step
|
|
134
|
+
usageEquivalencies: isolatedDataStructure.usageEquivalencies,
|
|
135
|
+
sourceEquivalencies: isolatedDataStructure.sourceEquivalencies,
|
|
136
|
+
// Include child boundary gating conditions for child component flow merging
|
|
137
|
+
childBoundaryGatingConditions:
|
|
138
|
+
isolatedDataStructure.childBoundaryGatingConditions,
|
|
139
|
+
// Include JSX rendering usages for array size and text length flow generation
|
|
140
|
+
jsxRenderingUsages: isolatedDataStructure.jsxRenderingUsages,
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
// Detect wrapper requirements (Context providers, etc.)
|
|
144
|
+
const wrapperRequirements = detectWrapperRequirements({
|
|
145
|
+
entity,
|
|
146
|
+
fileAnalyzer,
|
|
147
|
+
});
|
|
148
|
+
if (wrapperRequirements.length > 0) {
|
|
149
|
+
entity.metadata.wrapperRequirements = wrapperRequirements;
|
|
150
|
+
}
|
|
106
151
|
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
),
|
|
114
|
-
equivalentSignatureVariables:
|
|
115
|
-
isolatedDataStructure.equivalentSignatureVariables,
|
|
116
|
-
dependencySchemas: clonedDependencySchemas,
|
|
117
|
-
environmentVariables:
|
|
118
|
-
isolatedDataStructure.environmentVariables,
|
|
119
|
-
// Use enriched conditional usages with source tracing from analysis
|
|
120
|
-
conditionalUsages: isolatedDataStructure.conditionalUsages,
|
|
121
|
-
// Include root entity's equivalencies for merge step
|
|
122
|
-
usageEquivalencies: isolatedDataStructure.usageEquivalencies,
|
|
123
|
-
sourceEquivalencies: isolatedDataStructure.sourceEquivalencies,
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
// Detect wrapper requirements (Context providers, etc.)
|
|
127
|
-
const wrapperRequirements = detectWrapperRequirements({
|
|
128
|
-
entity,
|
|
129
|
-
fileAnalyzer,
|
|
130
|
-
});
|
|
131
|
-
if (wrapperRequirements.length > 0) {
|
|
132
|
-
entity.metadata.wrapperRequirements = wrapperRequirements;
|
|
152
|
+
// Annotate imported exports with function call information
|
|
153
|
+
const importedExports = entity.metadata.importedExports ?? [];
|
|
154
|
+
for (const importedExport of importedExports) {
|
|
155
|
+
const relevantCalls = functionCalls[importedExport.name];
|
|
156
|
+
if (relevantCalls) {
|
|
157
|
+
importedExport.calls = relevantCalls;
|
|
133
158
|
}
|
|
159
|
+
const relevantVariableNames =
|
|
160
|
+
callVariableNames[importedExport.name];
|
|
161
|
+
if (relevantVariableNames) {
|
|
162
|
+
importedExport.callVariableNames = relevantVariableNames;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
134
165
|
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
166
|
+
// Annotate node module imports with function call information
|
|
167
|
+
for (const [path, infos] of Object.entries(
|
|
168
|
+
entity.metadata.nodeModuleImports ?? {},
|
|
169
|
+
)) {
|
|
170
|
+
for (const info of infos) {
|
|
171
|
+
const relevantCalls = functionCalls[info.name];
|
|
139
172
|
if (relevantCalls) {
|
|
140
|
-
|
|
173
|
+
info.calls = relevantCalls;
|
|
141
174
|
}
|
|
142
|
-
const relevantVariableNames =
|
|
143
|
-
callVariableNames[importedExport.name];
|
|
175
|
+
const relevantVariableNames = callVariableNames[info.name];
|
|
144
176
|
if (relevantVariableNames) {
|
|
145
|
-
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
// Annotate node module imports with function call information
|
|
150
|
-
for (const [path, infos] of Object.entries(
|
|
151
|
-
entity.metadata.nodeModuleImports ?? {},
|
|
152
|
-
)) {
|
|
153
|
-
for (const info of infos) {
|
|
154
|
-
const relevantCalls = functionCalls[info.name];
|
|
155
|
-
if (relevantCalls) {
|
|
156
|
-
info.calls = relevantCalls;
|
|
157
|
-
}
|
|
158
|
-
const relevantVariableNames = callVariableNames[info.name];
|
|
159
|
-
if (relevantVariableNames) {
|
|
160
|
-
info.callVariableNames = relevantVariableNames;
|
|
161
|
-
}
|
|
177
|
+
info.callVariableNames = relevantVariableNames;
|
|
162
178
|
}
|
|
163
179
|
}
|
|
164
180
|
}
|
|
165
181
|
}
|
|
166
|
-
} catch (phase1Error) {
|
|
167
|
-
console.warn(
|
|
168
|
-
`CodeYam: prepareEntityDataStructures: PHASE 1 error for ${entity.filePath}:${entity.name}:`,
|
|
169
|
-
phase1Error,
|
|
170
|
-
);
|
|
171
|
-
// Continue to PHASE 2 - server-only detection should still run
|
|
172
182
|
}
|
|
183
|
+
} catch (phase1Error) {
|
|
184
|
+
console.warn(
|
|
185
|
+
`CodeYam: prepareEntityDataStructures: PHASE 1 error for ${entity.filePath}:${entity.name}:`,
|
|
186
|
+
phase1Error,
|
|
187
|
+
);
|
|
188
|
+
// Continue to PHASE 2 - server-only detection should still run
|
|
173
189
|
}
|
|
190
|
+
}
|
|
174
191
|
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
);
|
|
191
|
-
continue;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
// Never mock visual components - they render UI and should use real implementation
|
|
195
|
-
if (importedExport.entityType === 'visual') {
|
|
196
|
-
console.log(
|
|
197
|
-
`CodeYam: [${entity.name}] SKIP ${importedExport.name} - visual component, setting isMocked=false`,
|
|
198
|
-
);
|
|
199
|
-
importedExport.isMocked = false;
|
|
200
|
-
continue;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
// Always mock imports from server-only files ("use server" or import "server-only")
|
|
204
|
-
// These files contain Server Actions or server-only code that cannot run on the client
|
|
205
|
-
const importedFilePath =
|
|
206
|
-
importedExport.resolvedFilePath ?? importedExport.filePath;
|
|
207
|
-
const importedFileAnalyzer =
|
|
208
|
-
projectAnalyzer.getFileAnalyzerByPath(importedFilePath);
|
|
209
|
-
// Use sourceFile.getText() which is always available, unlike file.content which is lazy-loaded
|
|
210
|
-
const importedFileContent =
|
|
211
|
-
importedFileAnalyzer?.sourceFile?.getText();
|
|
212
|
-
|
|
213
|
-
const isServerOnly = importedFileContent
|
|
214
|
-
? isServerOnlyFile(importedFileContent)
|
|
215
|
-
: false;
|
|
216
|
-
console.log(
|
|
217
|
-
`CodeYam: [${entity.name}] CHECK ${importedExport.name} from ${importedFilePath}:`,
|
|
218
|
-
{
|
|
219
|
-
hasFileAnalyzer: !!importedFileAnalyzer,
|
|
220
|
-
hasSourceFile: !!importedFileAnalyzer?.sourceFile,
|
|
221
|
-
hasFileContent: !!importedFileContent,
|
|
222
|
-
contentFirst50Chars: importedFileContent
|
|
223
|
-
?.substring(0, 50)
|
|
224
|
-
?.replace(/\n/g, '\\n'),
|
|
225
|
-
isServerOnly,
|
|
226
|
-
},
|
|
227
|
-
);
|
|
192
|
+
try {
|
|
193
|
+
// PHASE 2: Server-only detection and isMocked determination
|
|
194
|
+
// This runs for ALL entities, even those with cached data structures
|
|
195
|
+
// because server-only detection may have been added after the entity was cached
|
|
196
|
+
const importedExports = entity.metadata?.importedExports ?? [];
|
|
197
|
+
const mockedDependencies = determineMockedDependencies(entity);
|
|
198
|
+
for (const importedExport of importedExports) {
|
|
199
|
+
// Skip if already has a definitive isMocked value (true or false, not null)
|
|
200
|
+
// But re-check if isMocked is null or undefined - this handles previously cached entities
|
|
201
|
+
if (
|
|
202
|
+
importedExport.isMocked === true ||
|
|
203
|
+
importedExport.isMocked === false
|
|
204
|
+
) {
|
|
205
|
+
continue;
|
|
206
|
+
}
|
|
228
207
|
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
continue;
|
|
235
|
-
}
|
|
208
|
+
// Never mock visual components - they render UI and should use real implementation
|
|
209
|
+
if (importedExport.entityType === 'visual') {
|
|
210
|
+
importedExport.isMocked = false;
|
|
211
|
+
continue;
|
|
212
|
+
}
|
|
236
213
|
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
214
|
+
// Always mock imports from server-only files ("use server" or import "server-only")
|
|
215
|
+
// These files contain Server Actions or server-only code that cannot run on the client
|
|
216
|
+
const importedFilePath =
|
|
217
|
+
importedExport.resolvedFilePath ?? importedExport.filePath;
|
|
218
|
+
const importedFileAnalyzer =
|
|
219
|
+
projectAnalyzer.getFileAnalyzerByPath(importedFilePath);
|
|
220
|
+
// Use sourceFile.getText() which is always available, unlike file.content which is lazy-loaded
|
|
221
|
+
const importedFileContent = importedFileAnalyzer?.sourceFile?.getText();
|
|
222
|
+
|
|
223
|
+
const isServerOnly = importedFileContent
|
|
224
|
+
? isServerOnlyFile(importedFileContent)
|
|
225
|
+
: false;
|
|
226
|
+
|
|
227
|
+
if (importedFileContent && isServerOnly) {
|
|
228
|
+
importedExport.isMocked = true;
|
|
229
|
+
continue;
|
|
246
230
|
}
|
|
247
231
|
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
232
|
+
const matchesMockedDep = mockedDependencies.some(
|
|
233
|
+
(dep) =>
|
|
234
|
+
dep.filePath === importedExport.filePath &&
|
|
235
|
+
dep.entityName === importedExport.name,
|
|
236
|
+
);
|
|
237
|
+
importedExport.isMocked = matchesMockedDep;
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
// Browser globals that should always be mocked (they make network calls)
|
|
241
|
+
const alwaysMockedBrowserGlobals = ['fetch', 'EventSource'];
|
|
242
|
+
|
|
243
|
+
for (const [path, infos] of Object.entries(
|
|
244
|
+
entity.metadata?.nodeModuleImports ?? {},
|
|
245
|
+
)) {
|
|
246
|
+
for (const info of infos) {
|
|
247
|
+
if (info.isMocked === undefined || info.isMocked === null) {
|
|
248
|
+
// Browser globals should always be mocked
|
|
249
|
+
if (alwaysMockedBrowserGlobals.includes(path)) {
|
|
250
|
+
info.isMocked = true;
|
|
251
|
+
} else {
|
|
252
|
+
// Check if this dependency should be mocked
|
|
253
|
+
// Match both exact entityName and variable-qualified entityNames
|
|
254
|
+
// e.g., "useFetcher" matches "useFetcher" OR "useFetcher::userFetcher"
|
|
255
|
+
info.isMocked = mockedDependencies.some(
|
|
256
|
+
(dep) =>
|
|
257
|
+
dep.filePath === path &&
|
|
258
|
+
(dep.entityName === info.name ||
|
|
259
|
+
dep.entityName.startsWith(info.name + '::')),
|
|
260
|
+
);
|
|
270
261
|
}
|
|
271
262
|
}
|
|
272
263
|
}
|
|
273
|
-
} catch (error) {
|
|
274
|
-
console.warn(
|
|
275
|
-
`CodeYam: prepareEntityDataStructures: Error preparing ${entity.filePath}:${entity.name}:`,
|
|
276
|
-
error,
|
|
277
|
-
);
|
|
278
|
-
// Continue with other entities - this one will have empty schemas
|
|
279
264
|
}
|
|
280
|
-
})
|
|
281
|
-
|
|
265
|
+
} catch (error) {
|
|
266
|
+
console.warn(
|
|
267
|
+
`CodeYam: prepareEntityDataStructures: Error preparing ${entity.filePath}:${entity.name}:`,
|
|
268
|
+
error,
|
|
269
|
+
);
|
|
270
|
+
// Continue with other entities - this one will have empty schemas
|
|
271
|
+
}
|
|
272
|
+
};
|
|
273
|
+
|
|
274
|
+
const entities = Array.from(allEntities);
|
|
275
|
+
|
|
276
|
+
// The worker thread creates its own ProjectAnalyzer (ts.Program) on first use,
|
|
277
|
+
// which takes 50-70s. For small entity counts the overhead far exceeds the actual
|
|
278
|
+
// processing time (<2s). Skip the worker and run on the main thread instead,
|
|
279
|
+
// reusing the existing ProjectAnalyzer.
|
|
280
|
+
const entitiesNeedingGeneration = entities.filter(
|
|
281
|
+
(e) =>
|
|
282
|
+
!e.metadata?.isolatedDataStructure || options.force || options.forceAll,
|
|
283
|
+
).length;
|
|
284
|
+
const WORKER_ENTITY_THRESHOLD = 500;
|
|
285
|
+
if (entitiesNeedingGeneration < WORKER_ENTITY_THRESHOLD) {
|
|
286
|
+
console.log(
|
|
287
|
+
`CodeYam: Skipping worker thread for DS prep (${entitiesNeedingGeneration} entities < ${WORKER_ENTITY_THRESHOLD} threshold)`,
|
|
288
|
+
);
|
|
289
|
+
skipWorkerPool();
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
const sequential =
|
|
293
|
+
DEBUG_SEQUENTIAL_EXECUTION || options.sequentialDataStructurePrep;
|
|
294
|
+
|
|
295
|
+
if (sequential) {
|
|
296
|
+
// Sequential execution for debugging - process one entity at a time
|
|
297
|
+
for (const entity of entities) {
|
|
298
|
+
await processEntity(entity);
|
|
299
|
+
}
|
|
300
|
+
} else {
|
|
301
|
+
// Parallel execution for speed
|
|
302
|
+
await Promise.all(entities.map(processEntity));
|
|
303
|
+
}
|
|
282
304
|
}
|
|
283
305
|
|
|
284
306
|
/**
|
|
@@ -328,19 +350,33 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
328
350
|
functionName: importedExport.name,
|
|
329
351
|
});
|
|
330
352
|
|
|
331
|
-
// If no signature found, this function doesn't exist in the analysis
|
|
332
|
-
if (!signatureSchema) {
|
|
333
|
-
return acc;
|
|
334
|
-
}
|
|
335
|
-
|
|
336
353
|
const returnValueSchema = getReturnValue(dataStructure, {
|
|
337
354
|
functionName: importedExport.name,
|
|
338
355
|
});
|
|
339
356
|
|
|
357
|
+
// If neither signature nor return value found, check if this function has matching
|
|
358
|
+
// external function calls. External functions (like useLoaderData from react-router)
|
|
359
|
+
// don't have entries in functionResults, so getReturnValue returns null for them.
|
|
360
|
+
// But their return values ARE traced in externalFunctionCalls via perVariableSchemas.
|
|
361
|
+
// We need to check for matching calls before skipping.
|
|
362
|
+
if (!signatureSchema && !returnValueSchema) {
|
|
363
|
+
const hasMatchingExternalCall =
|
|
364
|
+
dataStructure.externalFunctionCalls?.some(
|
|
365
|
+
(fc) =>
|
|
366
|
+
fc.name === importedExport.name ||
|
|
367
|
+
fc.name.startsWith(importedExport.name + '<'),
|
|
368
|
+
);
|
|
369
|
+
|
|
370
|
+
// Only skip if there are no matching external function calls
|
|
371
|
+
if (!hasMatchingExternalCall) {
|
|
372
|
+
return acc;
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
|
|
340
376
|
// Clone schemas before deduplication to avoid mutating shared references
|
|
341
377
|
// getReturnValue() and getFunctionSignature() return direct references, so we need
|
|
342
378
|
// to clone them before passing to deduplicateFunctionSchemas (which may mutate)
|
|
343
|
-
const clonedSignatureSchema = { ...signatureSchema };
|
|
379
|
+
const clonedSignatureSchema = { ...(signatureSchema ?? {}) };
|
|
344
380
|
const clonedReturnValueSchema = { ...(returnValueSchema ?? {}) };
|
|
345
381
|
|
|
346
382
|
acc[importedExport.filePath] ||= {};
|
|
@@ -365,32 +401,105 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
365
401
|
fc.name.startsWith(importedExport.name + '<'),
|
|
366
402
|
);
|
|
367
403
|
|
|
368
|
-
// Track how many times each variable name has been seen across ALL matching calls
|
|
369
|
-
// This handles the case where multiple parameterized calls (e.g., useFetcher<ConfigData>,
|
|
370
|
-
// useFetcher<SettingsData>) assign to the same variable name
|
|
371
|
-
const varNameCounts: Record<string, number> = {};
|
|
372
|
-
|
|
373
404
|
for (const efc of matchingCalls) {
|
|
374
|
-
// Check if this call has perVariableSchemas (multiple calls with
|
|
405
|
+
// Check if this call has perVariableSchemas (multiple calls with variable tracking)
|
|
375
406
|
if (efc?.perVariableSchemas) {
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
407
|
+
// Check if perVariableSchemas has indexed keys (e.g., "fetcher[1]") which indicates
|
|
408
|
+
// variable reuse with DIFFERENT call signatures (e.g., let fetcher = useFetcher<A>(); fetcher = useFetcher<B>();)
|
|
409
|
+
// In this case, we need to create SEPARATE entries for each call signature.
|
|
410
|
+
const perVarKeys = Object.keys(efc.perVariableSchemas);
|
|
411
|
+
const hasIndexedKeys = perVarKeys.some((key) => /\[\d+\]$/.test(key));
|
|
412
|
+
|
|
413
|
+
if (
|
|
414
|
+
hasIndexedKeys &&
|
|
415
|
+
efc.callSignatureToVariable &&
|
|
416
|
+
efc.allCallSignatures
|
|
417
|
+
) {
|
|
418
|
+
// Variable reuse case: create separate entries for each call signature
|
|
419
|
+
// Map from call signature to its variable key in perVariableSchemas
|
|
420
|
+
// e.g., useFetcher<ConfigData>() -> 'fetcher', useFetcher<SettingsData>() -> 'fetcher[1]'
|
|
421
|
+
const varNameCounts: Record<string, number> = {};
|
|
422
|
+
for (const callSig of efc.allCallSignatures) {
|
|
423
|
+
const varName = efc.callSignatureToVariable[callSig];
|
|
424
|
+
if (!varName) continue;
|
|
425
|
+
|
|
426
|
+
// Track occurrence count for this variable name
|
|
427
|
+
const occurrence = varNameCounts[varName] ?? 0;
|
|
428
|
+
varNameCounts[varName] = occurrence + 1;
|
|
429
|
+
|
|
430
|
+
// Get the key in perVariableSchemas (indexed if reused)
|
|
431
|
+
const perVarKey =
|
|
432
|
+
occurrence === 0 ? varName : `${varName}[${occurrence}]`;
|
|
433
|
+
const varSchema = efc.perVariableSchemas[perVarKey];
|
|
434
|
+
|
|
435
|
+
if (varSchema && Object.keys(varSchema).length > 0) {
|
|
436
|
+
// Create entry with this call signature as the key
|
|
437
|
+
const rewrittenSchema: Record<string, string> = {};
|
|
438
|
+
rewrittenSchema[`${callSig}.functionCallReturnValue`] =
|
|
439
|
+
'object';
|
|
440
|
+
|
|
441
|
+
for (const [path, type] of Object.entries(varSchema)) {
|
|
442
|
+
const rewrittenPath = path.startsWith(callSig)
|
|
443
|
+
? path
|
|
444
|
+
: `${callSig}.${path}`;
|
|
445
|
+
rewrittenSchema[rewrittenPath] = type;
|
|
446
|
+
}
|
|
447
|
+
|
|
448
|
+
acc[importedExport.filePath][callSig] = {
|
|
449
|
+
signatureSchema: deduplicateFunctionSchemas({
|
|
450
|
+
...signatureSchema,
|
|
451
|
+
}),
|
|
452
|
+
returnValueSchema:
|
|
453
|
+
deduplicateFunctionSchemas(rewrittenSchema),
|
|
454
|
+
usageEquivalencies:
|
|
455
|
+
getUsageEquivalencies(dataStructure, importedExport.name) ??
|
|
456
|
+
{},
|
|
457
|
+
sourceEquivalencies:
|
|
458
|
+
getSourceEquivalencies(
|
|
459
|
+
dataStructure,
|
|
460
|
+
importedExport.name,
|
|
461
|
+
) ?? {},
|
|
462
|
+
};
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
} else {
|
|
466
|
+
// Destructuring case: const { a, b, c } = useLoaderData()
|
|
467
|
+
// Merge all variable schemas into a single entry with the call signature as key
|
|
468
|
+
const callSignatureKey = efc.callSignature;
|
|
469
|
+
|
|
470
|
+
// Merge all variable schemas by prepending the call signature to each path.
|
|
471
|
+
// perVariableSchemas paths are like "functionCallReturnValue.entities.sha"
|
|
472
|
+
// We need to prefix them with the call signature to get:
|
|
473
|
+
// "useLoaderData<typeof loader>().functionCallReturnValue.entities.sha"
|
|
474
|
+
const mergedReturnValueSchema: Record<string, string> = {};
|
|
475
|
+
|
|
476
|
+
// Set the top-level return value as object since it contains named properties
|
|
477
|
+
mergedReturnValueSchema[
|
|
478
|
+
`${callSignatureKey}.functionCallReturnValue`
|
|
479
|
+
] = 'object';
|
|
480
|
+
|
|
481
|
+
for (const [varName, perVarSchema] of Object.entries(
|
|
482
|
+
efc.perVariableSchemas,
|
|
483
|
+
)) {
|
|
484
|
+
for (const [path, type] of Object.entries(perVarSchema)) {
|
|
485
|
+
// Only prepend the call signature if the path doesn't already have it.
|
|
486
|
+
// perVariableSchemas paths may already include the call signature prefix
|
|
487
|
+
// (e.g., "useCustomSizes(projectSlug).functionCallReturnValue.customSizes")
|
|
488
|
+
// depending on how they were built. If so, use the path as-is.
|
|
489
|
+
const rewrittenPath = path.startsWith(callSignatureKey)
|
|
490
|
+
? path
|
|
491
|
+
: `${callSignatureKey}.${path}`;
|
|
492
|
+
mergedReturnValueSchema[rewrittenPath] = type;
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
|
|
496
|
+
acc[importedExport.filePath][callSignatureKey] = {
|
|
388
497
|
signatureSchema: deduplicateFunctionSchemas({
|
|
389
498
|
...signatureSchema,
|
|
390
499
|
}),
|
|
391
|
-
returnValueSchema: deduplicateFunctionSchemas(
|
|
392
|
-
|
|
393
|
-
|
|
500
|
+
returnValueSchema: deduplicateFunctionSchemas(
|
|
501
|
+
mergedReturnValueSchema,
|
|
502
|
+
),
|
|
394
503
|
usageEquivalencies:
|
|
395
504
|
getUsageEquivalencies(dataStructure, importedExport.name) ?? {},
|
|
396
505
|
sourceEquivalencies:
|
|
@@ -400,18 +509,11 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
400
509
|
}
|
|
401
510
|
} else if (efc?.receivingVariableNames?.length === 1) {
|
|
402
511
|
// For parameterized calls like useFetcher<UserData>(), each is a separate entry
|
|
403
|
-
// with a single receivingVariableName.
|
|
404
|
-
// the specific return value for this parameterized call.
|
|
512
|
+
// with a single receivingVariableName. Use the call signature as the key.
|
|
405
513
|
const varName = efc.receivingVariableNames[0];
|
|
406
514
|
|
|
407
|
-
//
|
|
408
|
-
const
|
|
409
|
-
varNameCounts[varName] = occurrence + 1;
|
|
410
|
-
|
|
411
|
-
// Use indexed key if variable name is reused (e.g., fetcher, fetcher[1])
|
|
412
|
-
const indexedVarName =
|
|
413
|
-
occurrence === 0 ? varName : `${varName}[${occurrence}]`;
|
|
414
|
-
const qualifiedKey = `${importedExport.name}::${indexedVarName}`;
|
|
515
|
+
// Use the call signature as the key (e.g., "useFetcher<UserData>()")
|
|
516
|
+
const callSignatureKey = efc.callSignature;
|
|
415
517
|
|
|
416
518
|
// PREFER perVariableSchemas over getReturnValue() when available
|
|
417
519
|
// perVariableSchemas has the SPECIFIC schema for this parameterized call,
|
|
@@ -434,7 +536,7 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
434
536
|
parameterizedReturnValue &&
|
|
435
537
|
Object.keys(parameterizedReturnValue).length > 0
|
|
436
538
|
) {
|
|
437
|
-
acc[importedExport.filePath][
|
|
539
|
+
acc[importedExport.filePath][callSignatureKey] = {
|
|
438
540
|
signatureSchema: deduplicateFunctionSchemas({
|
|
439
541
|
...signatureSchema,
|
|
440
542
|
}),
|
|
@@ -471,6 +573,42 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
471
573
|
},
|
|
472
574
|
);
|
|
473
575
|
|
|
576
|
+
// Add same-file child components to dependencySchemas.
|
|
577
|
+
// Same-file components (e.g., AgentCard defined in the same file as AgentTranscriptsPage)
|
|
578
|
+
// appear in externalFunctionCalls and functionResults but NOT in importedExports or
|
|
579
|
+
// nodeModuleImports. Without this, their signatures are missing from dependencySchemas
|
|
580
|
+
// and enrichArrayTypesFromChildSignatures can't find child component field accesses.
|
|
581
|
+
const allDependencyNames = new Set(allDependencies.map((d) => d.name));
|
|
582
|
+
|
|
583
|
+
for (const efc of dataStructure.externalFunctionCalls) {
|
|
584
|
+
// Skip if already covered by importedExports or nodeModuleImports
|
|
585
|
+
if (allDependencyNames.has(efc.name)) continue;
|
|
586
|
+
|
|
587
|
+
const signatureSchema = getFunctionSignature(dataStructure, {
|
|
588
|
+
functionName: efc.name,
|
|
589
|
+
});
|
|
590
|
+
|
|
591
|
+
const returnValueSchema = getReturnValue(dataStructure, {
|
|
592
|
+
functionName: efc.name,
|
|
593
|
+
});
|
|
594
|
+
|
|
595
|
+
// Only add if we have signature or return value data
|
|
596
|
+
if (!signatureSchema && !returnValueSchema) continue;
|
|
597
|
+
|
|
598
|
+
const clonedSignatureSchema = { ...(signatureSchema ?? {}) };
|
|
599
|
+
const clonedReturnValueSchema = { ...(returnValueSchema ?? {}) };
|
|
600
|
+
|
|
601
|
+
const entityFilePath = entity.filePath;
|
|
602
|
+
dependencySchemas[entityFilePath] ||= {};
|
|
603
|
+
dependencySchemas[entityFilePath][efc.name] = {
|
|
604
|
+
signatureSchema: deduplicateFunctionSchemas(clonedSignatureSchema),
|
|
605
|
+
returnValueSchema: deduplicateFunctionSchemas(clonedReturnValueSchema),
|
|
606
|
+
usageEquivalencies: getUsageEquivalencies(dataStructure, efc.name) ?? {},
|
|
607
|
+
sourceEquivalencies:
|
|
608
|
+
getSourceEquivalencies(dataStructure, efc.name) ?? {},
|
|
609
|
+
};
|
|
610
|
+
}
|
|
611
|
+
|
|
474
612
|
const rawReturnValue =
|
|
475
613
|
getReturnValue(dataStructure, { fillInUnknowns: false }) ?? {};
|
|
476
614
|
|
|
@@ -483,23 +621,54 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
483
621
|
// Get enriched conditional usages with source tracing
|
|
484
622
|
const conditionalUsages = getConditionalUsages(dataStructure);
|
|
485
623
|
|
|
624
|
+
// Get conditional effects (setter calls inside conditionals)
|
|
625
|
+
const conditionalEffects = getConditionalEffects(dataStructure);
|
|
626
|
+
|
|
627
|
+
// Get compound conditionals (grouped conditions that must all be true)
|
|
628
|
+
const compoundConditionals = getCompoundConditionals(dataStructure);
|
|
486
629
|
const rawUsageEquivalencies = getUsageEquivalencies(dataStructure);
|
|
487
630
|
const rawSourceEquivalencies = getSourceEquivalencies(dataStructure);
|
|
488
631
|
|
|
632
|
+
// Get child boundary gating conditions for child component flow merging
|
|
633
|
+
const childBoundaryGatingConditions =
|
|
634
|
+
getChildBoundaryGatingConditions(dataStructure);
|
|
635
|
+
|
|
636
|
+
// Get JSX rendering usages for array size and text length flow generation
|
|
637
|
+
const jsxRenderingUsages = getJsxRenderingUsages(dataStructure);
|
|
638
|
+
|
|
639
|
+
const equivalentSignatureVariables =
|
|
640
|
+
getEquivalentSignatureVariables(dataStructure);
|
|
641
|
+
|
|
489
642
|
const isolatedDataStructure = {
|
|
490
643
|
signatureSchema: deduplicateFunctionSchemas(clonedRawSignature),
|
|
491
644
|
returnValueSchema: deduplicateFunctionSchemas(clonedRawReturnValue),
|
|
492
|
-
equivalentSignatureVariables
|
|
493
|
-
getEquivalentSignatureVariables(dataStructure),
|
|
645
|
+
equivalentSignatureVariables,
|
|
494
646
|
dependencySchemas,
|
|
495
647
|
environmentVariables: dataStructure.environmentVariables,
|
|
496
648
|
conditionalUsages:
|
|
497
649
|
Object.keys(conditionalUsages).length > 0 ? conditionalUsages : undefined,
|
|
650
|
+
// Include conditional effects for execution flow generation
|
|
651
|
+
conditionalEffects:
|
|
652
|
+
conditionalEffects.length > 0 ? conditionalEffects : undefined,
|
|
653
|
+
// Include compound conditionals for complete execution flow generation
|
|
654
|
+
// These capture grouped conditions like (a || b) && !c && !d
|
|
655
|
+
compoundConditionals:
|
|
656
|
+
compoundConditionals.length > 0 ? compoundConditionals : undefined,
|
|
498
657
|
// Include root entity's equivalencies so they can be used during merge.
|
|
499
658
|
// These show how the parent's data flows to/from child components.
|
|
500
659
|
// E.g., for SurveysList, usageEquivalencies shows surveys[] → SurveyCard().signature[0].survey
|
|
501
660
|
usageEquivalencies: rawUsageEquivalencies ?? {},
|
|
502
661
|
sourceEquivalencies: rawSourceEquivalencies ?? {},
|
|
662
|
+
// Include child boundary gating conditions for child component flow merging
|
|
663
|
+
// Maps child component names to the conditions that must be true for them to render
|
|
664
|
+
childBoundaryGatingConditions:
|
|
665
|
+
Object.keys(childBoundaryGatingConditions).length > 0
|
|
666
|
+
? childBoundaryGatingConditions
|
|
667
|
+
: undefined,
|
|
668
|
+
// Include JSX rendering usages for array size and text length flow generation
|
|
669
|
+
// These track arrays rendered via .map() and strings interpolated in JSX
|
|
670
|
+
jsxRenderingUsages:
|
|
671
|
+
jsxRenderingUsages.length > 0 ? jsxRenderingUsages : undefined,
|
|
503
672
|
};
|
|
504
673
|
|
|
505
674
|
const functionCalls: Record<string, string[]> = {};
|
|
@@ -557,6 +726,7 @@ async function getEntityDataStructureAndFunctionCalls({
|
|
|
557
726
|
) {
|
|
558
727
|
variableNames.push(...aggregatedReceivingVariableNames);
|
|
559
728
|
}
|
|
729
|
+
|
|
560
730
|
if (variableNames.length > 0) {
|
|
561
731
|
callVariableNames[entityName] = variableNames;
|
|
562
732
|
}
|
|
@@ -754,9 +924,21 @@ export function determineMockedDependencies(entity: Entity) {
|
|
|
754
924
|
// A schema with only "EntityName(): function" just indicates the entity is callable,
|
|
755
925
|
// it doesn't mean there's actual return data to mock
|
|
756
926
|
const hasReturnValue = hasActualReturnValueData(entityReturnValueSchema);
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
927
|
+
// Check for complex return types (object/array), accounting for nullable types
|
|
928
|
+
// e.g., 'object', 'object | null', 'array | undefined' should all count as complex.
|
|
929
|
+
// Also detect when functionCallReturnValue has nested child properties — this
|
|
930
|
+
// proves it's a structured type even if its declared type is still 'unknown'.
|
|
931
|
+
const returnValueKeys = Object.keys(entityReturnValueSchema ?? {});
|
|
932
|
+
const complexReturnValue =
|
|
933
|
+
Object.values(entityReturnValueSchema ?? {}).some((value) => {
|
|
934
|
+
const baseType = value?.split(' | ')[0];
|
|
935
|
+
return baseType === 'object' || baseType === 'array';
|
|
936
|
+
}) ||
|
|
937
|
+
returnValueKeys.some(
|
|
938
|
+
(key) =>
|
|
939
|
+
key.includes('functionCallReturnValue.') ||
|
|
940
|
+
key.includes('functionCallReturnValue['),
|
|
941
|
+
);
|
|
760
942
|
|
|
761
943
|
// Check if this is a validation function that should always be mocked
|
|
762
944
|
const isValidationFn = isValidationFunction(entityName);
|
|
@@ -776,14 +958,28 @@ export function determineMockedDependencies(entity: Entity) {
|
|
|
776
958
|
entityReturnValueSchema,
|
|
777
959
|
);
|
|
778
960
|
|
|
961
|
+
// Check if returnValueSchema is completely empty (no traced calls at all)
|
|
962
|
+
// This indicates a side-effect function that we couldn't trace
|
|
963
|
+
const returnValueSchemaEmpty =
|
|
964
|
+
Object.keys(entityReturnValueSchema ?? {}).length === 0;
|
|
965
|
+
|
|
779
966
|
const entityShouldBeMocked =
|
|
780
967
|
!onlyHasJsxComponents &&
|
|
781
968
|
(isValidationFn ||
|
|
782
969
|
hasChainedCallsWithNoReturn ||
|
|
970
|
+
// If entity takes no args AND has return value, it reads from external source
|
|
971
|
+
// Examples: useParams(), useAuth(), getConfig()
|
|
972
|
+
(emptySignature && hasReturnValue) ||
|
|
973
|
+
// If entity takes no args AND returnValueSchema is completely empty,
|
|
974
|
+
// it's a side-effect function calling external services
|
|
975
|
+
// Examples: logPageView(), initializeAnalytics(), trackEvent()
|
|
976
|
+
// NOTE: We don't mock entities that have function markers but no return value
|
|
977
|
+
// (like React components: FileProvider() has 'function' type but no return data)
|
|
978
|
+
(emptySignature && returnValueSchemaEmpty) ||
|
|
783
979
|
((signatureHasFunctions || returnValueHasFunctions) &&
|
|
784
980
|
hasReturnValue &&
|
|
785
|
-
|
|
786
|
-
|
|
981
|
+
!complexSignature &&
|
|
982
|
+
complexReturnValue));
|
|
787
983
|
|
|
788
984
|
if (entityShouldBeMocked) {
|
|
789
985
|
mockedEntities.push({
|