@codeyam/codeyam-cli 0.1.0-staging.1669d45 → 0.1.0-staging.1a2737b
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/log.txt +3 -3
- package/analyzer-template/package.json +19 -19
- package/analyzer-template/packages/ai/index.ts +16 -2
- package/analyzer-template/packages/ai/package.json +2 -2
- package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +110 -52
- package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +98 -9
- package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +139 -23
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +6 -126
- package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +656 -28
- package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +94 -7
- package/analyzer-template/packages/ai/src/lib/completionCall.ts +198 -34
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1331 -254
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
- 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 +124 -17
- 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/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 -97
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
- package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -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/generateEntityDataStructure.ts +58 -3
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +936 -7
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +35 -6
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +515 -6
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +1540 -75
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
- package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
- package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
- package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
- 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/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 +44 -7
- package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
- package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +179 -45
- package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +26 -4
- 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 +65 -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/getNodeType.ts +1 -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 +99 -22
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +19 -4
- package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -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/analyzeRemixRoute.ts +4 -5
- 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 +193 -76
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +269 -22
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +118 -10
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +647 -73
- 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/package.json +10 -10
- 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 +1 -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/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/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.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 +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/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/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/types/index.d.ts +1 -1
- package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -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 +25 -1
- 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/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/ScenariosDataStructure.d.ts +56 -6
- 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/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/types/index.ts +1 -0
- package/analyzer-template/packages/types/src/types/Analysis.ts +25 -0
- package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
- package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
- package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +70 -6
- package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
- package/analyzer-template/packages/utils/dist/types/index.d.ts +1 -1
- package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -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 +25 -1
- 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/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/ScenariosDataStructure.d.ts +56 -6
- 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/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 +20 -8
- package/analyzer-template/playwright/captureStatic.ts +1 -1
- package/analyzer-template/project/analyzeBaselineCommit.ts +5 -0
- package/analyzer-template/project/analyzeRegularCommit.ts +5 -0
- package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
- package/analyzer-template/project/constructMockCode.ts +436 -44
- package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
- package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
- package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
- package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
- package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
- package/analyzer-template/project/orchestrateCapture.ts +75 -7
- package/analyzer-template/project/reconcileMockDataKeys.ts +152 -9
- package/analyzer-template/project/runAnalysis.ts +4 -0
- package/analyzer-template/project/start.ts +35 -11
- package/analyzer-template/project/writeMockDataTsx.ts +295 -10
- package/analyzer-template/project/writeScenarioComponents.ts +237 -32
- package/analyzer-template/project/writeSimpleRoot.ts +21 -11
- package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
- package/background/src/lib/local/createLocalAnalyzer.js +1 -1
- package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +5 -0
- package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
- package/background/src/lib/virtualized/project/analyzeRegularCommit.js +5 -0
- 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 +359 -14
- package/background/src/lib/virtualized/project/constructMockCode.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/loadReadyToBeCaptured.js +19 -8
- package/background/src/lib/virtualized/project/loadReadyToBeCaptured.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/SequentialCaptureTaskRunner.js +7 -5
- package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js +62 -7
- package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +126 -9
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
- package/background/src/lib/virtualized/project/runAnalysis.js +3 -0
- package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
- package/background/src/lib/virtualized/project/start.js +32 -11
- package/background/src/lib/virtualized/project/start.js.map +1 -1
- package/background/src/lib/virtualized/project/writeMockDataTsx.js +251 -6
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +173 -30
- package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
- package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
- 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 +32 -18
- 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 +4 -2
- package/codeyam-cli/src/commands/analyze.js.map +1 -1
- package/codeyam-cli/src/commands/baseline.js +2 -0
- package/codeyam-cli/src/commands/baseline.js.map +1 -1
- package/codeyam-cli/src/commands/debug.js +9 -5
- package/codeyam-cli/src/commands/debug.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +31 -20
- 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 +307 -0
- package/codeyam-cli/src/commands/memory.js.map +1 -0
- package/codeyam-cli/src/commands/recapture.js +2 -0
- package/codeyam-cli/src/commands/recapture.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/test-startup.js +2 -0
- 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/utils/__tests__/npmVersionCheck.test.js +179 -0
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.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 +21 -2
- 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 +90 -19
- package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/utils/generateReport.js +2 -2
- package/codeyam-cli/src/utils/install-skills.js +77 -38
- 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/npmVersionCheck.js +76 -0
- package/codeyam-cli/src/utils/npmVersionCheck.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 +5 -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/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 +74 -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 +376 -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 +116 -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/simulationGateMiddleware.js +138 -0
- package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
- package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
- package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
- package/codeyam-cli/src/utils/versionInfo.js +25 -0
- package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
- package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
- package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js +22 -6
- 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-jNYXRRNI.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/EntityItem-bwuHPyTa.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-COi5OvsN.js → EntityTypeBadge-CvzqMxcu.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BwdQv49w.js → EntityTypeIcon-BH0XDim7.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{InlineSpinner-CEleMv_j.js → InlineSpinner-EhOseatT.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-D68KarMg.js → InteractivePreview-yjIHlOGa.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-L75Wvqgw.js → LibraryFunctionPreview-Cq5o8jL4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-C53WM8qn.js → LoadingDots-BvMu2i-g.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CrNkmy4i.js → LogViewer-kgBTLoJD.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BzPgx-xO.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CQifa1n-.js → SafeScreenshot-CwZrv-Ok.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-CyaBFX7l.js → ScenarioViewer-BX2Ny2Qj.js} +3 -13
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-D36O1rzU.js → TruncatedFilePath-CDpEprKa.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/_index-BRx8ZGZo.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-4S4yPfFw.js +27 -0
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +17 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -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-D4IPYH_y.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-DgTPh8H-.js → chevron-down-CG65viiV.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-DdQKK6on.js → chunk-JZWAC4HX-DB3aFuEO.js} +12 -12
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-Dmr2bb1R.js → circle-check-igfMr5DY.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/copy-Coc4o_8c.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-Do4ZLUYa.js → createLucideIcon-D1zB-pYc.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CbdFyxZh.js → entity._sha._-B0h9AqE6.js} +12 -12
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha.scenarios._scenarioId.fullscreen-B4iCfs5M.js → entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.create-scenario-wDWZZO1W.js → entity._sha_.create-scenario-CtYowLOt.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMbl7MeQ.js → entity._sha_.edit._scenarioId-PePWg17F.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-5wRKRIH9.js → entry.client-I-Wo99C_.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DD3SDH7t.js → fileTableUtils-9sMMAiWJ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/files-Co65J0s3.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{git-zXjT7J0G.js → git-BdHOxVfg.js} +8 -8
- package/codeyam-cli/src/webserver/build/client/assets/globals-BSZfYCkU.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-DLbXwndH.js → index-CUM5iXwc.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{index-gPZ-lad1.js → index-_417gcQW.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BsPXJ81F.js → loader-circle-TzRHMVog.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-040dab1c.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-UIDVz141.js +92 -0
- package/codeyam-cli/src/webserver/build/client/assets/pause-hjzB7t2z.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/root-D1WadSdf.js +62 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-P2FKIUql.js → search-DcAwD_Ln.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{simulations-L18M6-kN.js → simulations-DVNJVQgD.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/terminal-DbEAHMbA.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BDz7kbVA.js → triangle-alert-CAD5b1o_.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-29dDmbH8.js → useCustomSizes-BqgrAzs3.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-BUm0UVJm.js → useLastLogLine-DAFqfEDH.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-CkIOKTrZ.js → useReportContext-DZlYx2c4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-KKw5kTn-.js → useToast-ihdMtlf6.js} +1 -1
- package/codeyam-cli/src/webserver/build/server/assets/index-B3dE0r28.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-DYbfdxa3.js +273 -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/templates/{codeyam:debug.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.md → codeyam-setup.md} +13 -1
- package/codeyam-cli/templates/{codeyam:sim.md → codeyam-sim.md} +1 -1
- package/codeyam-cli/templates/{codeyam:test.md → codeyam-test.md} +1 -1
- package/codeyam-cli/templates/{codeyam:verify.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 +18 -15
- package/packages/ai/index.js +7 -3
- package/packages/ai/index.js.map +1 -1
- package/packages/ai/src/lib/analyzeScope.js +91 -30
- 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 +78 -8
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
- package/packages/ai/src/lib/astScopes/methodSemantics.js +109 -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/variableDeclarationHandler.js +1 -102
- package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
- package/packages/ai/src/lib/astScopes/processExpression.js +518 -28
- 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/completionCall.js +161 -30
- package/packages/ai/src/lib/completionCall.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1061 -174
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
- 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 +106 -13
- 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/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 -86
- 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 +130 -0
- package/packages/ai/src/lib/dataStructureChunking.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/generateEntityDataStructure.js +46 -2
- package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarioData.js +734 -8
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarios.js +26 -2
- package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +376 -4
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1124 -59
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
- package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
- package/packages/ai/src/lib/isolateScopes.js +39 -3
- 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 +70 -51
- 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/generateChunkPrompt.js +54 -0
- package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +30 -7
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.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 +155 -41
- package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
- package/packages/ai/src/lib/worker/SerializableDataStructure.js +7 -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 +60 -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/getNodeType.js +1 -0
- package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
- 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 +72 -10
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +17 -4
- 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/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/analyzeRemixRoute.js +3 -2
- package/packages/analyze/src/lib/files/analyzeRemixRoute.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 +164 -68
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +185 -20
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +57 -9
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +542 -53
- 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/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/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/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/types/index.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/codeyam-cli/src/webserver/build/client/assets/EntityItem-vauWK972.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DzJRkCkr.js +0 -11
- package/codeyam-cli/src/webserver/build/client/assets/_index-Be83mo_j.js +0 -11
- package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BN6wu6Y-.js +0 -37
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Bn6aCAy_.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/files-DKyMFI90.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/globals-DTTQ3gY7.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-22590fcf.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/root-BsAarjAM.js +0 -57
- package/codeyam-cli/src/webserver/build/client/assets/settings-B2eDuBj8.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/index-BND5I5fv.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-CFXnd7MG.js +0 -228
- package/codeyam-cli/templates/codeyam:diagnose.md +0 -625
|
@@ -3,9 +3,144 @@ import * as crypto from 'crypto';
|
|
|
3
3
|
import { StructuredPath } from "./paths.js";
|
|
4
4
|
import { nodeToSource } from "./nodeToSource.js";
|
|
5
5
|
import { methodRegistry, ArrayPushSemantics } from "./methodSemantics.js";
|
|
6
|
-
import { isArithmeticOperator, isAssignmentOperator, isBitwiseCompoundOperator, isComparisonOperator, isDefinedType, isNumericCompoundOperator, leftOrRightType, unwrapExpression, } from "./sharedPatterns.js";
|
|
6
|
+
import { getComparisonOperatorString, isArithmeticOperator, isAssignmentOperator, isBitwiseCompoundOperator, isComparisonOperator, isDefinedType, isNumericCompoundOperator, leftOrRightType, unwrapExpression, } from "./sharedPatterns.js";
|
|
7
7
|
import { processBindingPattern } from "./processBindings.js";
|
|
8
8
|
import { extractConditionalEffectsFromTernary, findUseStateSetters, } from "./conditionalEffectsExtractor.js";
|
|
9
|
+
import { detectArrayDerivedPattern } from "./arrayDerivationDetector.js";
|
|
10
|
+
/**
|
|
11
|
+
* Recursively extracts root variable names from an expression AST node.
|
|
12
|
+
* Used to identify which variables flow into JSX expression children,
|
|
13
|
+
* so we can link them to the return value schema.
|
|
14
|
+
*
|
|
15
|
+
* Examples:
|
|
16
|
+
* - `filteredTopPaths.map(...)` → ['filteredTopPaths']
|
|
17
|
+
* - `a && b` → ['a', 'b']
|
|
18
|
+
* - `condition ? x : y` → ['condition', 'x', 'y']
|
|
19
|
+
*/
|
|
20
|
+
function extractRootVariableNames(node) {
|
|
21
|
+
const ignoredIdentifiers = new Set([
|
|
22
|
+
'undefined',
|
|
23
|
+
'null',
|
|
24
|
+
'true',
|
|
25
|
+
'false',
|
|
26
|
+
'NaN',
|
|
27
|
+
'Infinity',
|
|
28
|
+
]);
|
|
29
|
+
if (ts.isIdentifier(node)) {
|
|
30
|
+
const name = node.text;
|
|
31
|
+
return ignoredIdentifiers.has(name) ? [] : [name];
|
|
32
|
+
}
|
|
33
|
+
if (ts.isPropertyAccessExpression(node)) {
|
|
34
|
+
return extractRootVariableNames(node.expression);
|
|
35
|
+
}
|
|
36
|
+
if (ts.isCallExpression(node)) {
|
|
37
|
+
return extractRootVariableNames(node.expression);
|
|
38
|
+
}
|
|
39
|
+
if (ts.isBinaryExpression(node)) {
|
|
40
|
+
return [
|
|
41
|
+
...extractRootVariableNames(node.left),
|
|
42
|
+
...extractRootVariableNames(node.right),
|
|
43
|
+
];
|
|
44
|
+
}
|
|
45
|
+
if (ts.isPrefixUnaryExpression(node)) {
|
|
46
|
+
return extractRootVariableNames(node.operand);
|
|
47
|
+
}
|
|
48
|
+
if (ts.isConditionalExpression(node)) {
|
|
49
|
+
return [
|
|
50
|
+
...extractRootVariableNames(node.condition),
|
|
51
|
+
...extractRootVariableNames(node.whenTrue),
|
|
52
|
+
...extractRootVariableNames(node.whenFalse),
|
|
53
|
+
];
|
|
54
|
+
}
|
|
55
|
+
if (ts.isParenthesizedExpression(node)) {
|
|
56
|
+
return extractRootVariableNames(node.expression);
|
|
57
|
+
}
|
|
58
|
+
// Stop recursion at JSX elements and other terminal nodes
|
|
59
|
+
if (ts.isJsxElement(node) ||
|
|
60
|
+
ts.isJsxFragment(node) ||
|
|
61
|
+
ts.isJsxSelfClosingElement(node)) {
|
|
62
|
+
return [];
|
|
63
|
+
}
|
|
64
|
+
return [];
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Checks if a JSX element has props that reference variables from the parent scope.
|
|
68
|
+
* This is used to detect unconditionally-rendered children that should have their
|
|
69
|
+
* execution flows merged into the parent.
|
|
70
|
+
*
|
|
71
|
+
* We want to track children where the parent controls data that affects the child's
|
|
72
|
+
* conditional rendering. Static props (like title="Dashboard") don't need tracking
|
|
73
|
+
* because they don't create variable execution flows.
|
|
74
|
+
*
|
|
75
|
+
* Examples:
|
|
76
|
+
* - <WorkoutsView workouts={workouts} /> → true (workouts is a variable)
|
|
77
|
+
* - <ItemList items={items} count={count} /> → true (items, count are variables)
|
|
78
|
+
* - <Header title="Dashboard" /> → false (static string)
|
|
79
|
+
* - <Footer /> → false (no props)
|
|
80
|
+
* - <Button onClick={handleClick} /> → false (only callback, no data props)
|
|
81
|
+
*
|
|
82
|
+
* @returns true if the component has at least one prop that references a variable
|
|
83
|
+
* (excluding callbacks which typically start with 'on' or 'handle')
|
|
84
|
+
*/
|
|
85
|
+
function hasDataPropsFromParent(node, componentName) {
|
|
86
|
+
const attributes = ts.isJsxElement(node)
|
|
87
|
+
? node.openingElement.attributes.properties
|
|
88
|
+
: node.attributes.properties;
|
|
89
|
+
const dataProps = [];
|
|
90
|
+
for (const attr of attributes) {
|
|
91
|
+
// Spread attributes always reference parent data: {...props}
|
|
92
|
+
if (ts.isJsxSpreadAttribute(attr)) {
|
|
93
|
+
const spreadText = attr.expression?.getText() || '...spread';
|
|
94
|
+
dataProps.push(`{...${spreadText}}`);
|
|
95
|
+
console.log(`[UnconditionalChild] ${componentName}: Found spread attribute {${spreadText}}`);
|
|
96
|
+
continue;
|
|
97
|
+
}
|
|
98
|
+
if (ts.isJsxAttribute(attr)) {
|
|
99
|
+
const propName = attr.name.getText();
|
|
100
|
+
// Skip callback props - they don't create data-driven execution flows
|
|
101
|
+
// Callbacks typically start with 'on' (onClick, onChange) or 'handle' (handleSubmit)
|
|
102
|
+
if (propName.startsWith('on') ||
|
|
103
|
+
propName.startsWith('handle') ||
|
|
104
|
+
propName === 'ref') {
|
|
105
|
+
console.log(`[UnconditionalChild] ${componentName}: Skipping callback prop '${propName}'`);
|
|
106
|
+
continue;
|
|
107
|
+
}
|
|
108
|
+
// Check if the prop value is a JSX expression (references a variable)
|
|
109
|
+
// vs a string literal which is static
|
|
110
|
+
if (attr.initializer) {
|
|
111
|
+
if (ts.isJsxExpression(attr.initializer)) {
|
|
112
|
+
// JSX expression like prop={value} - this references a variable
|
|
113
|
+
// Could be a simple identifier, property access, or more complex expression
|
|
114
|
+
const expression = attr.initializer.expression;
|
|
115
|
+
if (expression) {
|
|
116
|
+
// Skip if it's just a function/arrow function (callback)
|
|
117
|
+
if (ts.isArrowFunction(expression) ||
|
|
118
|
+
ts.isFunctionExpression(expression)) {
|
|
119
|
+
console.log(`[UnconditionalChild] ${componentName}: Skipping inline callback prop '${propName}'`);
|
|
120
|
+
continue;
|
|
121
|
+
}
|
|
122
|
+
// This is a data prop that references parent state/props
|
|
123
|
+
const exprText = expression.getText();
|
|
124
|
+
dataProps.push(`${propName}={${exprText}}`);
|
|
125
|
+
console.log(`[UnconditionalChild] ${componentName}: Found data prop '${propName}' = {${exprText}}`);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
// String literals like prop="value" are static
|
|
130
|
+
console.log(`[UnconditionalChild] ${componentName}: Skipping static prop '${propName}'`);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
const hasDataProps = dataProps.length > 0;
|
|
136
|
+
if (hasDataProps) {
|
|
137
|
+
console.log(`[UnconditionalChild] ${componentName}: Has ${dataProps.length} data props: [${dataProps.join(', ')}]`);
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
console.log(`[UnconditionalChild] ${componentName}: No data props found, will NOT track`);
|
|
141
|
+
}
|
|
142
|
+
return { hasDataProps, dataProps };
|
|
143
|
+
}
|
|
9
144
|
/**
|
|
10
145
|
* Extracts the component name from a JSX element.
|
|
11
146
|
* Returns null for intrinsic elements (div, span, etc.) since we only care about
|
|
@@ -273,6 +408,123 @@ function getSourceLocation(node, sourceFile) {
|
|
|
273
408
|
: codeSnippet,
|
|
274
409
|
};
|
|
275
410
|
}
|
|
411
|
+
/**
|
|
412
|
+
* Extracts the root array path from an expression that ends with .map().
|
|
413
|
+
* Handles chained methods like .filter().map(), .slice().map(), etc.
|
|
414
|
+
*
|
|
415
|
+
* Examples:
|
|
416
|
+
* - items.map(...) → "items"
|
|
417
|
+
* - data.users.map(...) → "data.users"
|
|
418
|
+
* - items.filter(...).map(...) → "items"
|
|
419
|
+
* - items.slice(0, 5).map(...) → "items"
|
|
420
|
+
*/
|
|
421
|
+
function extractArrayPathFromMapCall(expr, sourceFile) {
|
|
422
|
+
// Walk up the chain to find the root array
|
|
423
|
+
let current = expr.expression;
|
|
424
|
+
while (ts.isPropertyAccessExpression(current)) {
|
|
425
|
+
const methodName = current.name.getText(sourceFile);
|
|
426
|
+
// Common array methods that return arrays (so we keep going up)
|
|
427
|
+
const arrayReturningMethods = [
|
|
428
|
+
'map',
|
|
429
|
+
'filter',
|
|
430
|
+
'slice',
|
|
431
|
+
'concat',
|
|
432
|
+
'flat',
|
|
433
|
+
'flatMap',
|
|
434
|
+
'reverse',
|
|
435
|
+
'sort',
|
|
436
|
+
'toReversed',
|
|
437
|
+
'toSorted',
|
|
438
|
+
'toSpliced',
|
|
439
|
+
];
|
|
440
|
+
if (arrayReturningMethods.includes(methodName)) {
|
|
441
|
+
const objectExpr = current.expression;
|
|
442
|
+
// If the object is a call expression (chained method), keep going
|
|
443
|
+
if (ts.isCallExpression(objectExpr)) {
|
|
444
|
+
current = objectExpr.expression;
|
|
445
|
+
}
|
|
446
|
+
else {
|
|
447
|
+
// Found the root - it's an identifier or property access
|
|
448
|
+
const path = StructuredPath.fromNode(objectExpr, sourceFile);
|
|
449
|
+
return path ? path.toString() : null;
|
|
450
|
+
}
|
|
451
|
+
}
|
|
452
|
+
else {
|
|
453
|
+
// Not an array method we recognize
|
|
454
|
+
break;
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
return null;
|
|
458
|
+
}
|
|
459
|
+
/**
|
|
460
|
+
* Extracts JSX rendering usages from a JSX expression.
|
|
461
|
+
* Detects:
|
|
462
|
+
* - array.map() calls → 'array-map' type
|
|
463
|
+
* - string interpolations (identifiers/property access) → 'text-interpolation' type
|
|
464
|
+
*
|
|
465
|
+
* Recursively searches inside && chains and ternary expressions.
|
|
466
|
+
*
|
|
467
|
+
* @param expr The expression inside {expr}
|
|
468
|
+
* @param context The analysis context
|
|
469
|
+
*/
|
|
470
|
+
function extractJsxRenderingUsage(expr, context) {
|
|
471
|
+
const unwrapped = unwrapExpression(expr);
|
|
472
|
+
const sourceLocation = getSourceLocation(expr, context.sourceFile);
|
|
473
|
+
// Detect array.map() calls
|
|
474
|
+
if (ts.isCallExpression(unwrapped)) {
|
|
475
|
+
const calleeExpr = unwrapped.expression;
|
|
476
|
+
if (ts.isPropertyAccessExpression(calleeExpr)) {
|
|
477
|
+
const methodName = calleeExpr.name.getText(context.sourceFile);
|
|
478
|
+
if (methodName === 'map') {
|
|
479
|
+
const arrayPath = extractArrayPathFromMapCall(unwrapped, context.sourceFile);
|
|
480
|
+
if (arrayPath) {
|
|
481
|
+
context.addJsxRenderingUsage({
|
|
482
|
+
path: arrayPath,
|
|
483
|
+
renderingType: 'array-map',
|
|
484
|
+
valueType: 'array',
|
|
485
|
+
sourceLocation,
|
|
486
|
+
});
|
|
487
|
+
}
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
}
|
|
491
|
+
// Detect simple string interpolations: {title} or {user.name}
|
|
492
|
+
else if (ts.isIdentifier(unwrapped) ||
|
|
493
|
+
ts.isPropertyAccessExpression(unwrapped)) {
|
|
494
|
+
const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
|
|
495
|
+
if (path) {
|
|
496
|
+
const pathStr = path.toString();
|
|
497
|
+
const typeInfo = context.getTypeInfo(path);
|
|
498
|
+
// Only track as text interpolation if it's a string type
|
|
499
|
+
// Check for 'string' type, or types that contain 'string' (but not 'string[]')
|
|
500
|
+
if (typeInfo === 'string' ||
|
|
501
|
+
(typeInfo &&
|
|
502
|
+
typeInfo.includes('string') &&
|
|
503
|
+
!typeInfo.includes('string[]'))) {
|
|
504
|
+
context.addJsxRenderingUsage({
|
|
505
|
+
path: pathStr,
|
|
506
|
+
renderingType: 'text-interpolation',
|
|
507
|
+
valueType: 'string',
|
|
508
|
+
sourceLocation,
|
|
509
|
+
});
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
// Recursively search inside && chains: {showList && items.map(...)}
|
|
514
|
+
else if (ts.isBinaryExpression(unwrapped) &&
|
|
515
|
+
unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
|
|
516
|
+
// Check the right side of the && chain (where .map() typically appears)
|
|
517
|
+
const rightSide = unwrapExpression(unwrapped.right);
|
|
518
|
+
extractJsxRenderingUsage(rightSide, context);
|
|
519
|
+
// Also check nested && chains on the left
|
|
520
|
+
extractJsxRenderingUsage(unwrapped.left, context);
|
|
521
|
+
}
|
|
522
|
+
// Recursively search inside ternaries: {isEmpty ? null : items.map(...)}
|
|
523
|
+
else if (ts.isConditionalExpression(unwrapped)) {
|
|
524
|
+
extractJsxRenderingUsage(unwrapped.whenTrue, context);
|
|
525
|
+
extractJsxRenderingUsage(unwrapped.whenFalse, context);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
276
528
|
/**
|
|
277
529
|
* Counts the number of conditions in an && chain (excluding JSX consequence)
|
|
278
530
|
*/
|
|
@@ -330,6 +582,9 @@ function extractConditionalsFromJsx(node, context, parentConditions = []) {
|
|
|
330
582
|
// Process JSX expressions: {expr}
|
|
331
583
|
if (ts.isJsxExpression(child) && child.expression) {
|
|
332
584
|
const expr = unwrapExpression(child.expression);
|
|
585
|
+
// Extract JSX rendering usages (array.map, text interpolation)
|
|
586
|
+
// This handles direct usages like {items.map(...)} or {user.name}
|
|
587
|
+
extractJsxRenderingUsage(expr, context);
|
|
333
588
|
// If the expression is an && chain, extract its conditional usages
|
|
334
589
|
if (ts.isBinaryExpression(expr) &&
|
|
335
590
|
expr.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
|
|
@@ -568,8 +823,84 @@ function extractConditionalsFromJsx(node, context, parentConditions = []) {
|
|
|
568
823
|
}
|
|
569
824
|
// Recursively process nested JSX elements - Fix 32: pass parent conditions
|
|
570
825
|
else if (ts.isJsxElement(child)) {
|
|
826
|
+
// Check if this is a user-defined component (vs intrinsic element like div)
|
|
827
|
+
const componentName = getComponentNameFromJsx(child);
|
|
828
|
+
if (componentName) {
|
|
829
|
+
if (parentConditions.length > 0) {
|
|
830
|
+
// If there are parent conditions, record them as gating conditions
|
|
831
|
+
console.log(`[ChildBoundary] ${componentName}: Conditionally rendered with ${parentConditions.length} gating conditions`);
|
|
832
|
+
for (const condition of parentConditions) {
|
|
833
|
+
console.log(`[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`);
|
|
834
|
+
context.addChildBoundaryGatingCondition(componentName, {
|
|
835
|
+
path: condition.path,
|
|
836
|
+
conditionType: 'truthiness',
|
|
837
|
+
location: 'ternary',
|
|
838
|
+
sourceLocation: condition.sourceLocation,
|
|
839
|
+
controlsJsxRendering: true,
|
|
840
|
+
isNegated: condition.isNegated,
|
|
841
|
+
});
|
|
842
|
+
}
|
|
843
|
+
}
|
|
844
|
+
else {
|
|
845
|
+
// No parent conditions - check if it has data props for unconditional tracking
|
|
846
|
+
console.log(`[ChildBoundary] ${componentName}: Checking for unconditional rendering with data props...`);
|
|
847
|
+
const { hasDataProps, dataProps } = hasDataPropsFromParent(child, componentName);
|
|
848
|
+
if (hasDataProps) {
|
|
849
|
+
// Fix: Track unconditionally-rendered children that receive data props
|
|
850
|
+
// These need to be tracked for flow merging even without gating conditions
|
|
851
|
+
// Example: <WorkoutsView workouts={workouts} /> - parent controls workouts data
|
|
852
|
+
console.log(`[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered with data props: [${dataProps.join(', ')}]`);
|
|
853
|
+
context.addChildBoundaryGatingCondition(componentName, {
|
|
854
|
+
path: '__unconditional__',
|
|
855
|
+
conditionType: 'truthiness',
|
|
856
|
+
location: 'unconditional',
|
|
857
|
+
controlsJsxRendering: true,
|
|
858
|
+
isNegated: false,
|
|
859
|
+
});
|
|
860
|
+
}
|
|
861
|
+
}
|
|
862
|
+
}
|
|
571
863
|
extractConditionalsFromJsx(child, context, parentConditions);
|
|
572
864
|
}
|
|
865
|
+
// Handle self-closing JSX elements (e.g., <ScenarioViewer />)
|
|
866
|
+
else if (ts.isJsxSelfClosingElement(child)) {
|
|
867
|
+
// Check if this is a user-defined component (vs intrinsic element like div)
|
|
868
|
+
const componentName = getComponentNameFromJsx(child);
|
|
869
|
+
if (componentName) {
|
|
870
|
+
if (parentConditions.length > 0) {
|
|
871
|
+
// If there are parent conditions, record them as gating conditions
|
|
872
|
+
console.log(`[ChildBoundary] ${componentName}: Conditionally rendered (self-closing) with ${parentConditions.length} gating conditions`);
|
|
873
|
+
for (const condition of parentConditions) {
|
|
874
|
+
console.log(`[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`);
|
|
875
|
+
context.addChildBoundaryGatingCondition(componentName, {
|
|
876
|
+
path: condition.path,
|
|
877
|
+
conditionType: 'truthiness',
|
|
878
|
+
location: 'ternary',
|
|
879
|
+
sourceLocation: condition.sourceLocation,
|
|
880
|
+
controlsJsxRendering: true,
|
|
881
|
+
isNegated: condition.isNegated,
|
|
882
|
+
});
|
|
883
|
+
}
|
|
884
|
+
}
|
|
885
|
+
else {
|
|
886
|
+
// No parent conditions - check if it has data props for unconditional tracking
|
|
887
|
+
console.log(`[ChildBoundary] ${componentName}: Checking for unconditional rendering (self-closing) with data props...`);
|
|
888
|
+
const { hasDataProps, dataProps } = hasDataPropsFromParent(child, componentName);
|
|
889
|
+
if (hasDataProps) {
|
|
890
|
+
// Fix: Track unconditionally-rendered children that receive data props
|
|
891
|
+
console.log(`[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered (self-closing) with data props: [${dataProps.join(', ')}]`);
|
|
892
|
+
context.addChildBoundaryGatingCondition(componentName, {
|
|
893
|
+
path: '__unconditional__',
|
|
894
|
+
conditionType: 'truthiness',
|
|
895
|
+
location: 'unconditional',
|
|
896
|
+
controlsJsxRendering: true,
|
|
897
|
+
isNegated: false,
|
|
898
|
+
});
|
|
899
|
+
}
|
|
900
|
+
}
|
|
901
|
+
}
|
|
902
|
+
// Self-closing elements have no children, so no recursion needed
|
|
903
|
+
}
|
|
573
904
|
// Recursively process nested JSX fragments - Fix 32: pass parent conditions
|
|
574
905
|
else if (ts.isJsxFragment(child)) {
|
|
575
906
|
extractConditionalsFromJsx(child, context, parentConditions);
|
|
@@ -640,12 +971,33 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
640
971
|
return;
|
|
641
972
|
}
|
|
642
973
|
// Handle binary expressions with || (logical OR)
|
|
643
|
-
// OR
|
|
974
|
+
// When OR is inside an && chain, we need to continue chain tracking
|
|
975
|
+
// and mark conditions as OR alternatives
|
|
644
976
|
if (ts.isBinaryExpression(unwrapped) &&
|
|
645
977
|
unwrapped.operatorToken.kind === ts.SyntaxKind.BarBarToken) {
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
978
|
+
if (chainInfo) {
|
|
979
|
+
// We're inside an && chain - continue tracking but mark as OR alternatives
|
|
980
|
+
// Generate an orGroupId so conditions from both sides can be grouped
|
|
981
|
+
const orGroupId = chainInfo.currentOrGroupId ?? `or_${crypto.randomUUID().slice(0, 8)}`;
|
|
982
|
+
// Process left side with OR group tracking
|
|
983
|
+
const leftChainInfo = {
|
|
984
|
+
...chainInfo,
|
|
985
|
+
currentOrGroupId: orGroupId,
|
|
986
|
+
};
|
|
987
|
+
extractWithChainTracking(unwrapped.left, leftChainInfo, false);
|
|
988
|
+
// Process right side with same OR group
|
|
989
|
+
// Note: we use leftChainInfo's currentPosition which may have been updated
|
|
990
|
+
const rightChainInfo = {
|
|
991
|
+
...leftChainInfo,
|
|
992
|
+
currentPosition: chainInfo.currentPosition,
|
|
993
|
+
};
|
|
994
|
+
extractWithChainTracking(unwrapped.right, rightChainInfo, false);
|
|
995
|
+
}
|
|
996
|
+
else {
|
|
997
|
+
// Not inside a chain - OR breaks into independent conditional checks
|
|
998
|
+
extractWithChainTracking(unwrapped.left, null, false);
|
|
999
|
+
extractWithChainTracking(unwrapped.right, null, false);
|
|
1000
|
+
}
|
|
649
1001
|
return;
|
|
650
1002
|
}
|
|
651
1003
|
// Handle comparison operators (===, !==, <, >, <=, >=)
|
|
@@ -670,8 +1022,10 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
670
1022
|
}
|
|
671
1023
|
return literalValue;
|
|
672
1024
|
};
|
|
1025
|
+
// Get the comparison operator string for the compound condition
|
|
1026
|
+
const comparisonOperator = getComparisonOperatorString(unwrapped.operatorToken.kind);
|
|
673
1027
|
// Helper to add a condition
|
|
674
|
-
const addCondition = (path, conditionType, comparedValues, requiredValue) => {
|
|
1028
|
+
const addCondition = (path, conditionType, comparedValues, requiredValue, sourceExpr) => {
|
|
675
1029
|
const usage = {
|
|
676
1030
|
path,
|
|
677
1031
|
conditionType,
|
|
@@ -681,6 +1035,16 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
681
1035
|
isNegated,
|
|
682
1036
|
controlsJsxRendering,
|
|
683
1037
|
};
|
|
1038
|
+
// Check for inline array-derived patterns (.length) on the source expression
|
|
1039
|
+
if (sourceExpr) {
|
|
1040
|
+
const arrayDerived = detectArrayDerivedPattern(sourceExpr);
|
|
1041
|
+
if (arrayDerived) {
|
|
1042
|
+
usage.derivedFrom = {
|
|
1043
|
+
operation: arrayDerived.operation,
|
|
1044
|
+
sourcePath: arrayDerived.sourcePath,
|
|
1045
|
+
};
|
|
1046
|
+
}
|
|
1047
|
+
}
|
|
684
1048
|
// Add chain info if part of a compound conditional
|
|
685
1049
|
if (chainInfo) {
|
|
686
1050
|
usage.chainId = chainInfo.chainId;
|
|
@@ -695,6 +1059,10 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
695
1059
|
comparedValues,
|
|
696
1060
|
isNegated,
|
|
697
1061
|
requiredValue,
|
|
1062
|
+
...(comparisonOperator && { comparisonOperator }),
|
|
1063
|
+
...(chainInfo.currentOrGroupId && {
|
|
1064
|
+
orGroupId: chainInfo.currentOrGroupId,
|
|
1065
|
+
}),
|
|
698
1066
|
});
|
|
699
1067
|
}
|
|
700
1068
|
context.addConditionalUsage(usage);
|
|
@@ -702,21 +1070,21 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
702
1070
|
// Check if left is a variable and right is a literal
|
|
703
1071
|
if (leftPath && isLiteralExpression(unwrapped.right)) {
|
|
704
1072
|
const literalValue = getLiteralValue(unwrapped.right, context);
|
|
705
|
-
addCondition(leftPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated));
|
|
1073
|
+
addCondition(leftPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated), unwrapped.left);
|
|
706
1074
|
return;
|
|
707
1075
|
}
|
|
708
1076
|
// Check if right is a variable and left is a literal
|
|
709
1077
|
if (rightPath && isLiteralExpression(unwrapped.left)) {
|
|
710
1078
|
const literalValue = getLiteralValue(unwrapped.left, context);
|
|
711
|
-
addCondition(rightPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated));
|
|
1079
|
+
addCondition(rightPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated), unwrapped.right);
|
|
712
1080
|
return;
|
|
713
1081
|
}
|
|
714
1082
|
// Both sides are variables - record both as comparisons without specific values
|
|
715
1083
|
if (leftPath) {
|
|
716
|
-
addCondition(leftPath.toLeftHandSideString(), 'comparison');
|
|
1084
|
+
addCondition(leftPath.toLeftHandSideString(), 'comparison', undefined, undefined, unwrapped.left);
|
|
717
1085
|
}
|
|
718
1086
|
if (rightPath) {
|
|
719
|
-
addCondition(rightPath.toLeftHandSideString(), 'comparison');
|
|
1087
|
+
addCondition(rightPath.toLeftHandSideString(), 'comparison', undefined, undefined, unwrapped.right);
|
|
720
1088
|
}
|
|
721
1089
|
return;
|
|
722
1090
|
}
|
|
@@ -740,6 +1108,15 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
740
1108
|
isNegated,
|
|
741
1109
|
controlsJsxRendering,
|
|
742
1110
|
};
|
|
1111
|
+
// Check for inline array-derived patterns (.some(), .every(), .includes(), .length)
|
|
1112
|
+
// This populates derivedFrom so downstream code can resolve to the base array path
|
|
1113
|
+
const arrayDerived = detectArrayDerivedPattern(unwrapped);
|
|
1114
|
+
if (arrayDerived) {
|
|
1115
|
+
usage.derivedFrom = {
|
|
1116
|
+
operation: arrayDerived.operation,
|
|
1117
|
+
sourcePath: arrayDerived.sourcePath,
|
|
1118
|
+
};
|
|
1119
|
+
}
|
|
743
1120
|
// Add chain info if part of a compound conditional
|
|
744
1121
|
if (chainInfo) {
|
|
745
1122
|
usage.chainId = chainInfo.chainId;
|
|
@@ -754,6 +1131,9 @@ export function extractConditionalUsage(condition, context, location, options =
|
|
|
754
1131
|
conditionType: 'truthiness',
|
|
755
1132
|
isNegated,
|
|
756
1133
|
requiredValue: !isNegated,
|
|
1134
|
+
...(chainInfo.currentOrGroupId && {
|
|
1135
|
+
orGroupId: chainInfo.currentOrGroupId,
|
|
1136
|
+
}),
|
|
757
1137
|
});
|
|
758
1138
|
}
|
|
759
1139
|
context.addConditionalUsage(usage);
|
|
@@ -885,15 +1265,21 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
|
|
|
885
1265
|
const equivalentVariables = context.getEquivalentVariables();
|
|
886
1266
|
const structure = context.getStructure();
|
|
887
1267
|
// Propagate existing equivalencies for sub-properties
|
|
888
|
-
for (const [key,
|
|
1268
|
+
for (const [key, rawValue] of Object.entries(equivalentVariables)) {
|
|
889
1269
|
// Check if this equivalency is for a sub-property of the identifier
|
|
890
1270
|
// e.g., completeDataStructure['Function Arguments'] or completeDataStructure.foo
|
|
891
1271
|
if (key.startsWith(nodePathStr + '.') ||
|
|
892
1272
|
key.startsWith(nodePathStr + '[')) {
|
|
893
1273
|
const subPath = key.substring(nodePathStr.length);
|
|
894
1274
|
const newTargetPath = StructuredPath.fromBase(targetPath.toString() + subPath);
|
|
895
|
-
|
|
896
|
-
|
|
1275
|
+
// Handle both string and string[] values
|
|
1276
|
+
const values = Array.isArray(rawValue) ? rawValue : [rawValue];
|
|
1277
|
+
for (const value of values) {
|
|
1278
|
+
if (typeof value === 'string') {
|
|
1279
|
+
const valuePath = StructuredPath.fromBase(value);
|
|
1280
|
+
context.addEquivalence(newTargetPath, valuePath);
|
|
1281
|
+
}
|
|
1282
|
+
}
|
|
897
1283
|
}
|
|
898
1284
|
}
|
|
899
1285
|
// Propagate existing structure entries for sub-properties
|
|
@@ -1229,12 +1615,46 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
|
|
|
1229
1615
|
}
|
|
1230
1616
|
}
|
|
1231
1617
|
else if (operatorKind === ts.SyntaxKind.BarBarToken) {
|
|
1232
|
-
// For ||,
|
|
1618
|
+
// For ||, create equivalences to BOTH sides
|
|
1233
1619
|
// This enables data flow tracing through fallback expressions
|
|
1620
|
+
// e.g., `const item = items.find(...) || null` should trace to both:
|
|
1621
|
+
// - items[] (from the find result)
|
|
1622
|
+
// - null (from the fallback)
|
|
1234
1623
|
if (targetPath) {
|
|
1235
|
-
|
|
1624
|
+
// Get paths for both sides
|
|
1625
|
+
const leftPath = StructuredPath.fromNode(unwrappedNode.left, context.sourceFile);
|
|
1626
|
+
const rightPath = StructuredPath.fromNode(unwrappedNode.right, context.sourceFile);
|
|
1627
|
+
// Collect all valid paths
|
|
1628
|
+
const allPaths = [];
|
|
1629
|
+
if (leftPath)
|
|
1630
|
+
allPaths.push(leftPath);
|
|
1631
|
+
if (rightPath)
|
|
1632
|
+
allPaths.push(rightPath);
|
|
1633
|
+
// Add multiple equivalencies to track both sources
|
|
1634
|
+
if (allPaths.length > 0) {
|
|
1635
|
+
context.addMultipleEquivalencies(targetPath, allPaths);
|
|
1636
|
+
}
|
|
1637
|
+
// Process both sides to capture their internal structures
|
|
1638
|
+
processExpression({
|
|
1639
|
+
node: unwrappedNode.left,
|
|
1640
|
+
context,
|
|
1641
|
+
});
|
|
1642
|
+
processExpression({
|
|
1643
|
+
node: unwrappedNode.right,
|
|
1644
|
+
context,
|
|
1645
|
+
});
|
|
1646
|
+
// Register the type for the target path
|
|
1647
|
+
const leftType = context.inferTypeFromNode(unwrappedNode.left);
|
|
1648
|
+
const rightType = context.inferTypeFromNode(unwrappedNode.right);
|
|
1649
|
+
const orResultType = isDefinedType(leftType)
|
|
1650
|
+
? leftType
|
|
1651
|
+
: rightType || 'unknown';
|
|
1652
|
+
context.addType(targetPath, orResultType);
|
|
1653
|
+
// Return early - we've already handled equivalencies with addMultipleEquivalencies
|
|
1654
|
+
// Don't fall through to the generic addEquivalence call below
|
|
1655
|
+
return true;
|
|
1236
1656
|
}
|
|
1237
|
-
// Note:
|
|
1657
|
+
// Note: When there's no targetPath, we don't recursively process
|
|
1238
1658
|
// because || is often used in boolean contexts where the full expression matters
|
|
1239
1659
|
}
|
|
1240
1660
|
}
|
|
@@ -1312,18 +1732,44 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
|
|
|
1312
1732
|
const semantics = semanticsList[0];
|
|
1313
1733
|
// Get the source expression path (e.g., the object for obj.method())
|
|
1314
1734
|
const sourceExpr = unwrappedNode.expression.expression;
|
|
1315
|
-
const
|
|
1316
|
-
|
|
1317
|
-
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
const
|
|
1321
|
-
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1735
|
+
const unwrappedSourceExpr = unwrapExpression(sourceExpr);
|
|
1736
|
+
// When the source is a ternary expression like (cond ? arr : arr.slice()),
|
|
1737
|
+
// apply method semantics to BOTH branches directly. The ternary itself isn't
|
|
1738
|
+
// a variable - it's just a choice between two paths that both flow to the result.
|
|
1739
|
+
if (ts.isConditionalExpression(unwrappedSourceExpr)) {
|
|
1740
|
+
const branches = [
|
|
1741
|
+
unwrappedSourceExpr.whenTrue,
|
|
1742
|
+
unwrappedSourceExpr.whenFalse,
|
|
1743
|
+
];
|
|
1744
|
+
for (const branch of branches) {
|
|
1745
|
+
const branchPath = StructuredPath.fromNode(branch, context.sourceFile);
|
|
1746
|
+
if (branchPath) {
|
|
1747
|
+
const isArraySemantics = semantics instanceof ArrayPushSemantics;
|
|
1748
|
+
const shouldApply = !isArraySemantics ||
|
|
1749
|
+
isLikelyArrayType(branch, context.typeChecker);
|
|
1750
|
+
if (shouldApply) {
|
|
1751
|
+
semantics.addEquivalences(callPath, branchPath, context);
|
|
1752
|
+
returnType = semantics.getReturnType();
|
|
1753
|
+
handledBySemantics = true;
|
|
1754
|
+
}
|
|
1755
|
+
}
|
|
1756
|
+
}
|
|
1757
|
+
}
|
|
1758
|
+
else {
|
|
1759
|
+
// Regular (non-ternary) source expression
|
|
1760
|
+
const sourcePath = StructuredPath.fromNode(sourceExpr, context.sourceFile);
|
|
1761
|
+
if (sourcePath) {
|
|
1762
|
+
// For array-specific semantics (like push), verify the source is actually an array
|
|
1763
|
+
// This prevents router.push() from being mistakenly treated as Array.push()
|
|
1764
|
+
const isArraySemantics = semantics instanceof ArrayPushSemantics;
|
|
1765
|
+
const shouldApply = !isArraySemantics ||
|
|
1766
|
+
isLikelyArrayType(sourceExpr, context.typeChecker);
|
|
1767
|
+
if (shouldApply) {
|
|
1768
|
+
// Apply method semantics
|
|
1769
|
+
semantics.addEquivalences(callPath, sourcePath, context);
|
|
1770
|
+
returnType = semantics.getReturnType();
|
|
1771
|
+
handledBySemantics = true;
|
|
1772
|
+
}
|
|
1327
1773
|
}
|
|
1328
1774
|
}
|
|
1329
1775
|
}
|
|
@@ -1752,6 +2198,32 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
|
|
|
1752
2198
|
}
|
|
1753
2199
|
// Handle Arrow Functions: (p) => p.prop, (a, b) => { ... }
|
|
1754
2200
|
if (ts.isArrowFunction(unwrappedNode)) {
|
|
2201
|
+
// If this arrow function is a child boundary (e.g., a .map() callback),
|
|
2202
|
+
// don't process its parameters here - they will be processed when the
|
|
2203
|
+
// child scope is analyzed separately. This prevents parameter variables
|
|
2204
|
+
// from leaking into the parent scope's equivalencies.
|
|
2205
|
+
// Check if this arrow function is a child boundary (i.e., should be processed
|
|
2206
|
+
// as a separate child scope, not here in the parent scope).
|
|
2207
|
+
//
|
|
2208
|
+
// We use two checks because childBoundary positions can be unreliable:
|
|
2209
|
+
// 1. Position-based check (standard isChildBoundary)
|
|
2210
|
+
// 2. Text-based check: if the arrow function text doesn't appear in the
|
|
2211
|
+
// statement text, it was replaced with a cyScope placeholder
|
|
2212
|
+
const isChildBoundary = context.isChildBoundary(unwrappedNode);
|
|
2213
|
+
// Text-based child scope detection for when positions are unreliable
|
|
2214
|
+
const arrowFnText = unwrappedNode.getText(context.sourceFile);
|
|
2215
|
+
const firstLine = arrowFnText.split('\n')[0].trim();
|
|
2216
|
+
const searchText = firstLine.substring(0, Math.min(20, firstLine.length));
|
|
2217
|
+
const isInStatementText = context.statementInfo.text.includes(searchText);
|
|
2218
|
+
const isChildScope = !isInStatementText && arrowFnText.length > 10;
|
|
2219
|
+
if (isChildBoundary || isChildScope) {
|
|
2220
|
+
// The method semantics (e.g., ArrayMapSemantics) have already established
|
|
2221
|
+
// the necessary equivalences between the child scope placeholder and array elements
|
|
2222
|
+
if (targetPath) {
|
|
2223
|
+
context.addType(targetPath, 'function');
|
|
2224
|
+
}
|
|
2225
|
+
return true;
|
|
2226
|
+
}
|
|
1755
2227
|
// Create a path for the function
|
|
1756
2228
|
const functionPath = StructuredPath.empty();
|
|
1757
2229
|
// Process parameters
|
|
@@ -2043,6 +2515,15 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
|
|
|
2043
2515
|
for (const child of unwrappedNode.children) {
|
|
2044
2516
|
// Process expressions in JSX children: <div>{expr}</div>
|
|
2045
2517
|
if (ts.isJsxExpression(child) && child.expression) {
|
|
2518
|
+
// When processing return value JSX, link root variables to return value schema
|
|
2519
|
+
if (targetPath && targetPath.base !== '') {
|
|
2520
|
+
const varNames = [
|
|
2521
|
+
...new Set(extractRootVariableNames(child.expression)),
|
|
2522
|
+
];
|
|
2523
|
+
for (const varName of varNames) {
|
|
2524
|
+
context.addEquivalence(targetPath.withProperty(varName), StructuredPath.fromBase(varName));
|
|
2525
|
+
}
|
|
2526
|
+
}
|
|
2046
2527
|
// Process the expression with StructuredPath.empty() as targetPath
|
|
2047
2528
|
// to trigger type registration without imposing prefix
|
|
2048
2529
|
processExpression({
|
|
@@ -2073,6 +2554,15 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
|
|
|
2073
2554
|
for (const child of unwrappedNode.children) {
|
|
2074
2555
|
// Process expressions in JSX children: <>{expr}</>
|
|
2075
2556
|
if (ts.isJsxExpression(child) && child.expression) {
|
|
2557
|
+
// When processing return value JSX, link root variables to return value schema
|
|
2558
|
+
if (targetPath && targetPath.base !== '') {
|
|
2559
|
+
const varNames = [
|
|
2560
|
+
...new Set(extractRootVariableNames(child.expression)),
|
|
2561
|
+
];
|
|
2562
|
+
for (const varName of varNames) {
|
|
2563
|
+
context.addEquivalence(targetPath.withProperty(varName), StructuredPath.fromBase(varName));
|
|
2564
|
+
}
|
|
2565
|
+
}
|
|
2076
2566
|
// Process the expression to extract structure
|
|
2077
2567
|
processExpression({
|
|
2078
2568
|
node: child.expression,
|