@codeyam/codeyam-cli 0.1.0-staging.483fdc2 → 0.1.0-staging.57cd50f
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 +7 -7
- package/analyzer-template/log.txt +3 -3
- package/analyzer-template/package.json +24 -24
- package/analyzer-template/packages/ai/index.ts +1 -0
- package/analyzer-template/packages/ai/package.json +3 -3
- package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
- package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
- package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
- package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +588 -13
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -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 +20 -1
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
- package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
- package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +124 -7
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +101 -2
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
- 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/promptGenerators/collapseNullableObjects.ts +118 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
- package/analyzer-template/packages/analyze/index.ts +2 -0
- package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
- package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
- package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +13 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
- package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
- package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
- package/analyzer-template/packages/aws/package.json +10 -10
- package/analyzer-template/packages/database/index.ts +1 -0
- package/analyzer-template/packages/database/package.json +4 -4
- 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 -0
- package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
- package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +82 -0
- package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
- package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
- package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
- 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 +151 -135
- package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
- package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
- package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
- package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
- package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/index.js +1 -0
- package/analyzer-template/packages/github/dist/database/index.js.map +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 +4 -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 +8 -0
- 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/debugReportsTable.d.ts +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +24 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
- 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 +5 -0
- 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/loadCommits.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
- package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.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 +1 -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.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
- package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
- package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -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 +10 -0
- package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
- package/analyzer-template/packages/github/package.json +1 -1
- package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
- package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
- package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
- package/analyzer-template/packages/ui-components/package.json +1 -1
- package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
- package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
- package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
- package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -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 +10 -0
- package/analyzer-template/packages/utils/dist/types/src/types/Scenario.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 +98 -3
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
- package/analyzer-template/playwright/captureFromUrl.ts +89 -82
- package/analyzer-template/project/constructMockCode.ts +206 -51
- package/analyzer-template/project/orchestrateCapture.ts +4 -1
- package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
- package/analyzer-template/project/start.ts +3 -0
- package/analyzer-template/project/startScenarioCapture.ts +9 -0
- package/analyzer-template/project/writeClientLogRoute.ts +125 -0
- package/analyzer-template/project/writeMockDataTsx.ts +136 -17
- package/analyzer-template/project/writeScenarioComponents.ts +170 -29
- package/analyzer-template/project/writeSimpleRoot.ts +21 -11
- package/analyzer-template/tsconfig.json +13 -1
- 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/constructMockCode.js +175 -42
- package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
- package/background/src/lib/virtualized/project/start.js +2 -0
- package/background/src/lib/virtualized/project/start.js.map +1 -1
- package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
- package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
- package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
- package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
- 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 +252 -21
- package/codeyam-cli/scripts/apply-setup.js.map +1 -1
- package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
- package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
- package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
- package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
- package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
- package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
- package/codeyam-cli/src/cli.js +33 -24
- 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 +21 -9
- 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 +2 -0
- package/codeyam-cli/src/commands/debug.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +44 -21
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/editor.js +2868 -0
- package/codeyam-cli/src/commands/editor.js.map +1 -0
- package/codeyam-cli/src/commands/init.js +81 -260
- package/codeyam-cli/src/commands/init.js.map +1 -1
- package/codeyam-cli/src/commands/memory.js +97 -92
- package/codeyam-cli/src/commands/memory.js.map +1 -1
- 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/data/techStacks.js +77 -0
- package/codeyam-cli/src/data/techStacks.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
- package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
- package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
- package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
- package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
- package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
- package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
- package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
- package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
- package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
- package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
- package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
- package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
- package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
- package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +275 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
- package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
- package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
- package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
- package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
- package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
- package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
- package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
- package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
- package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
- package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
- package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
- package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
- 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 +198 -29
- package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/utils/buildFlags.js +4 -0
- package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
- package/codeyam-cli/src/utils/devModeEvents.js +40 -0
- package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
- package/codeyam-cli/src/utils/devServerState.js +71 -0
- package/codeyam-cli/src/utils/devServerState.js.map +1 -0
- package/codeyam-cli/src/utils/editorApi.js +73 -0
- package/codeyam-cli/src/utils/editorApi.js.map +1 -0
- package/codeyam-cli/src/utils/editorAudit.js +159 -0
- package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
- package/codeyam-cli/src/utils/editorCapture.js +102 -0
- package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
- package/codeyam-cli/src/utils/editorDevServer.js +197 -0
- package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
- package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
- package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
- package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
- package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
- package/codeyam-cli/src/utils/editorJournal.js +225 -0
- package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
- package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
- package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
- package/codeyam-cli/src/utils/editorMockState.js +248 -0
- package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
- package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
- package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
- package/codeyam-cli/src/utils/editorPreview.js +106 -0
- package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
- package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
- package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
- package/codeyam-cli/src/utils/editorScenarios.js +126 -0
- package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
- package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
- package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
- package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
- package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
- package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
- package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
- package/codeyam-cli/src/utils/fileMetadata.js +5 -0
- package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
- package/codeyam-cli/src/utils/fileWatcher.js +25 -9
- package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
- package/codeyam-cli/src/utils/generateReport.js +2 -2
- package/codeyam-cli/src/utils/git.js +103 -0
- package/codeyam-cli/src/utils/git.js.map +1 -1
- package/codeyam-cli/src/utils/install-skills.js +101 -56
- package/codeyam-cli/src/utils/install-skills.js.map +1 -1
- package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
- package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
- 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/parseRegisterArg.js +31 -0
- package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
- package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
- package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
- package/codeyam-cli/src/utils/progress.js +7 -0
- package/codeyam-cli/src/utils/progress.js.map +1 -1
- package/codeyam-cli/src/utils/project.js +15 -5
- package/codeyam-cli/src/utils/project.js.map +1 -1
- package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
- package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
- package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
- package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
- package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
- package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
- package/codeyam-cli/src/utils/queue/job.js +74 -1
- package/codeyam-cli/src/utils/queue/job.js.map +1 -1
- package/codeyam-cli/src/utils/queue/manager.js +7 -6
- 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 +229 -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 +113 -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__/parser.test.js +83 -0
- package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
- package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
- package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.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/__tests__/sourceFiles.test.js +76 -0
- package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/index.js +2 -0
- package/codeyam-cli/src/utils/rules/index.js.map +1 -1
- package/codeyam-cli/src/utils/rules/parser.js +16 -29
- package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
- package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
- package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
- package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
- package/codeyam-cli/src/utils/rules/rulePlacement.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/sourceFiles.js +43 -0
- package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
- package/codeyam-cli/src/utils/rules/staleness.js +16 -11
- package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
- package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
- package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
- package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
- package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
- package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
- package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
- package/codeyam-cli/src/utils/serverState.js +94 -12
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
- package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -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/testRunner.js +158 -0
- package/codeyam-cli/src/utils/testRunner.js.map +1 -0
- package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
- package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
- package/codeyam-cli/src/utils/versionInfo.js +46 -0
- package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
- package/codeyam-cli/src/utils/webappDetection.js +35 -2
- package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
- package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +31 -0
- package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
- 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/__tests__/editorProxy.test.js +487 -0
- package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
- package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
- 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/app/lib/git.js +396 -0
- package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
- package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/bootstrap.js +11 -0
- package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
- package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-0DY_NKil.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
- package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
- package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -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.dev-mode-events-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-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.rule-path-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-BYOypzCa.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/editor-vgc8jrQL.js +10 -0
- package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-BF4oLwaE.js} +12 -12
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
- package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/manifest-05e71e0b.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +96 -0
- package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/root-ClvYBUSA.js +67 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
- package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
- package/codeyam-cli/src/webserver/build/server/assets/index-B4lc-hKc.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BbkD6mNV.js +426 -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/devServer.js +39 -5
- package/codeyam-cli/src/webserver/devServer.js.map +1 -1
- package/codeyam-cli/src/webserver/editorProxy.js +846 -0
- package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
- package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
- package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
- package/codeyam-cli/src/webserver/server.js +258 -1
- package/codeyam-cli/src/webserver/server.js.map +1 -1
- package/codeyam-cli/src/webserver/terminalServer.js +726 -0
- package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
- package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
- package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
- package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
- package/codeyam-cli/templates/chrome-extension-react/package.json +26 -0
- package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
- package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
- package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
- package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
- package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
- package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
- package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
- package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
- package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
- package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
- package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
- package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
- package/codeyam-cli/templates/editor-step-hook.py +231 -0
- package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
- package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
- package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
- package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
- package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
- package/codeyam-cli/templates/expo-react-native/app.json +18 -0
- package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
- package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
- package/codeyam-cli/templates/expo-react-native/global.css +3 -0
- package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
- package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
- package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
- package/codeyam-cli/templates/expo-react-native/package.json +37 -0
- package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
- package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
- package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
- package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
- package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
- package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
- package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
- package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
- package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +36 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
- package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
- package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
- package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
- package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
- package/codeyam-cli/templates/rule-notification-hook.py +83 -0
- package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
- package/codeyam-cli/templates/rules-instructions.md +45 -93
- package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
- package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
- package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
- package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
- package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
- package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
- package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
- package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
- package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
- package/package.json +28 -21
- package/packages/ai/index.js +1 -1
- package/packages/ai/index.js.map +1 -1
- package/packages/ai/src/lib/analyzeScope.js +21 -1
- package/packages/ai/src/lib/analyzeScope.js.map +1 -1
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.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/processExpression.js +78 -1
- 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 +10 -7
- package/packages/ai/src/lib/completionCall.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
- 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/helpers/cleanKnownObjectFunctions.js +11 -2
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
- 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/coercePrimitivesToArraysBySchema.js +54 -0
- package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.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 +15 -1
- package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
- package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
- package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
- package/packages/ai/src/lib/dataStructureChunking.js +30 -11
- package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
- 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 +89 -5
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
- 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/promptGenerators/collapseNullableObjects.js +97 -0
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
- package/packages/analyze/index.js +1 -0
- package/packages/analyze/index.js.map +1 -1
- package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
- package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
- package/packages/analyze/src/lib/asts/index.js +4 -2
- package/packages/analyze/src/lib/asts/index.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/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
- package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
- package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
- package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.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/database/index.js +1 -0
- package/packages/database/index.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 +8 -0
- package/packages/database/src/lib/kysely/db.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
- package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
- 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/loadCommits.js +23 -13
- package/packages/database/src/lib/loadCommits.js.map +1 -1
- package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -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 +100 -89
- package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
- package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
- package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
- package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
- package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
- package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
- package/packages/types/src/enums/ProjectFramework.js +2 -0
- package/packages/types/src/enums/ProjectFramework.js.map +1 -1
- package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
- package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/scripts/npm-post-install.cjs +34 -0
- package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
- package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
- package/codeyam-cli/src/commands/list.js +0 -31
- package/codeyam-cli/src/commands/list.js.map +0 -1
- package/codeyam-cli/src/commands/webapp-info.js +0 -146
- package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
- package/codeyam-cli/src/utils/reviewedRules.js +0 -92
- package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
- package/codeyam-cli/src/utils/universal-mocks.js +0 -152
- package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
- package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
- package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
- package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
- package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
- package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
- package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
- package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
- package/codeyam-cli/templates/codeyam:memory.md +0 -403
- package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
- package/scripts/finalize-analyzer.cjs +0 -81
|
@@ -397,6 +397,7 @@ const SILENTLY_IGNORED_EQUIVALENCY_REASONS = new Set([
|
|
|
397
397
|
'transformed non-object function equivalency - implicit parent equivalency - rerouted via useCallback',
|
|
398
398
|
'transformed non-object function equivalency - Array.from() equivalency',
|
|
399
399
|
'Spread operator equivalency key update: Explicit array deconstruction equivalency value',
|
|
400
|
+
// 'transformed non-object function equivalency - Explicit array deconstruction equivalency value',
|
|
400
401
|
]);
|
|
401
402
|
|
|
402
403
|
export class ScopeDataStructure {
|
|
@@ -799,6 +800,11 @@ export class ScopeDataStructure {
|
|
|
799
800
|
return;
|
|
800
801
|
}
|
|
801
802
|
|
|
803
|
+
// PERF: Early exit for paths with repeated function-call signature patterns
|
|
804
|
+
if (this.hasExcessivePatternRepetition(path)) {
|
|
805
|
+
return;
|
|
806
|
+
}
|
|
807
|
+
|
|
802
808
|
// Update chain metadata for database tracking
|
|
803
809
|
if (equivalencyValueChain.length > 0) {
|
|
804
810
|
equivalencyValueChain[equivalencyValueChain.length - 1].addToSchemaId =
|
|
@@ -1102,6 +1108,33 @@ export class ScopeDataStructure {
|
|
|
1102
1108
|
return;
|
|
1103
1109
|
}
|
|
1104
1110
|
|
|
1111
|
+
// Case 3: Circular reference through scope-suffixed names (____cyScope pattern)
|
|
1112
|
+
// When a named arrow function is defined inside a scope (e.g., useEffect callback):
|
|
1113
|
+
// const identifyUser = async () => { ... };
|
|
1114
|
+
// identifyUser();
|
|
1115
|
+
// This creates a variable "identifyUser" and a scope "identifyUser____cyScope9F".
|
|
1116
|
+
// Mutual equivalencies between these cause infinite loops in Phase 2 because
|
|
1117
|
+
// processing one triggers addToSchema → followEquivalencies → addEquivalency
|
|
1118
|
+
// on the reverse, which repeats indefinitely.
|
|
1119
|
+
// Only block when the REVERSE direction already exists (creating a cycle).
|
|
1120
|
+
// The initial one-directional equivalency is necessary for scope resolution.
|
|
1121
|
+
if (
|
|
1122
|
+
path &&
|
|
1123
|
+
equivalentPath &&
|
|
1124
|
+
(equivalentPath.startsWith(path + '____') ||
|
|
1125
|
+
path.startsWith(equivalentPath + '____'))
|
|
1126
|
+
) {
|
|
1127
|
+
// Check if the reverse equivalency already exists
|
|
1128
|
+
const reverseEquivalencies =
|
|
1129
|
+
scopeNode.equivalencies[equivalentPath] || [];
|
|
1130
|
+
const reverseExists = reverseEquivalencies.some(
|
|
1131
|
+
(v) => v.schemaPath === path,
|
|
1132
|
+
);
|
|
1133
|
+
if (reverseExists) {
|
|
1134
|
+
return;
|
|
1135
|
+
}
|
|
1136
|
+
}
|
|
1137
|
+
|
|
1105
1138
|
if (!equivalentScopeName) {
|
|
1106
1139
|
console.error(
|
|
1107
1140
|
'CodeYam Error: Missing equivalent scope name - FULL CONTEXT:',
|
|
@@ -1486,6 +1519,15 @@ export class ScopeDataStructure {
|
|
|
1486
1519
|
|
|
1487
1520
|
const bestValue = selectBestValue(value1, value2);
|
|
1488
1521
|
|
|
1522
|
+
// PERF: Skip paths with repeated function-call signature patterns
|
|
1523
|
+
// to prevent recursive type expansion (e.g., string.localeCompare returns string)
|
|
1524
|
+
if (
|
|
1525
|
+
this.hasExcessivePatternRepetition(schemaPath) ||
|
|
1526
|
+
this.hasExcessivePatternRepetition(equivalentSchemaPath)
|
|
1527
|
+
) {
|
|
1528
|
+
continue;
|
|
1529
|
+
}
|
|
1530
|
+
|
|
1489
1531
|
scopeNode.schema[schemaPath] = bestValue;
|
|
1490
1532
|
equivalentScopeNode.schema[equivalentSchemaPath] = bestValue;
|
|
1491
1533
|
} else if (
|
|
@@ -1499,6 +1541,11 @@ export class ScopeDataStructure {
|
|
|
1499
1541
|
...remainingSchemaPathParts,
|
|
1500
1542
|
]);
|
|
1501
1543
|
|
|
1544
|
+
// PERF: Skip paths with repeated function-call signature patterns
|
|
1545
|
+
if (this.hasExcessivePatternRepetition(newEquivalentPath)) {
|
|
1546
|
+
continue;
|
|
1547
|
+
}
|
|
1548
|
+
|
|
1502
1549
|
equivalentScopeNode.schema[newEquivalentPath] =
|
|
1503
1550
|
scopeNode.schema[schemaPath];
|
|
1504
1551
|
}
|
|
@@ -1618,6 +1665,23 @@ export class ScopeDataStructure {
|
|
|
1618
1665
|
}
|
|
1619
1666
|
}
|
|
1620
1667
|
|
|
1668
|
+
// Check for repeated function calls that indicate recursive type expansion.
|
|
1669
|
+
// E.g., localeCompare(b[])...localeCompare(b[]) means string.localeCompare
|
|
1670
|
+
// returns a type that again has localeCompare, causing infinite expansion.
|
|
1671
|
+
// We extract all function call patterns like "funcName(args)" and check if
|
|
1672
|
+
// the same normalized call appears more than once.
|
|
1673
|
+
const funcCallPattern = /(?:^|\.)[^.([]+\([^)]*\)/g;
|
|
1674
|
+
const funcCallMatches = path.match(funcCallPattern);
|
|
1675
|
+
if (funcCallMatches && funcCallMatches.length > 1) {
|
|
1676
|
+
const seen = new Set<string>();
|
|
1677
|
+
for (const match of funcCallMatches) {
|
|
1678
|
+
// Strip leading dot and normalize array indices
|
|
1679
|
+
const normalized = match.replace(/^\./, '').replace(/\[\d+\]/g, '[]');
|
|
1680
|
+
if (seen.has(normalized)) return true;
|
|
1681
|
+
seen.add(normalized);
|
|
1682
|
+
}
|
|
1683
|
+
}
|
|
1684
|
+
|
|
1621
1685
|
// For longer paths, detect any repeated multi-part segments we haven't explicitly listed
|
|
1622
1686
|
const pathParts = this.splitPath(path);
|
|
1623
1687
|
if (pathParts.length <= 6) {
|
|
@@ -2574,6 +2638,7 @@ export class ScopeDataStructure {
|
|
|
2574
2638
|
relevantSubPathParts.every((part, i) => part === schemaPathParts[i]) &&
|
|
2575
2639
|
equivalentValue.scopeNodeName === scopeNode.name
|
|
2576
2640
|
) {
|
|
2641
|
+
// DEBUG
|
|
2577
2642
|
continue;
|
|
2578
2643
|
}
|
|
2579
2644
|
|
|
@@ -2760,6 +2825,8 @@ export class ScopeDataStructure {
|
|
|
2760
2825
|
usageEquivalency.scopeNodeName,
|
|
2761
2826
|
) as ScopeNode;
|
|
2762
2827
|
|
|
2828
|
+
if (!usageScopeNode) continue;
|
|
2829
|
+
|
|
2763
2830
|
// Guard against infinite recursion by tracking which paths we've already
|
|
2764
2831
|
// added from addComplexSourcePathVariables
|
|
2765
2832
|
if (
|
|
@@ -2839,6 +2906,8 @@ export class ScopeDataStructure {
|
|
|
2839
2906
|
usageEquivalency.scopeNodeName,
|
|
2840
2907
|
) as ScopeNode;
|
|
2841
2908
|
|
|
2909
|
+
if (!usageScopeNode) continue;
|
|
2910
|
+
|
|
2842
2911
|
// This is put in place to avoid propagating array functions like 'filter' through complex equivalencies
|
|
2843
2912
|
// but may cause problems if the funtion call is not on a known object (e.g. string or array)
|
|
2844
2913
|
if (
|
|
@@ -3291,6 +3360,14 @@ export class ScopeDataStructure {
|
|
|
3291
3360
|
}
|
|
3292
3361
|
}
|
|
3293
3362
|
|
|
3363
|
+
// Ensure parameter-to-signature equivalencies are fully propagated.
|
|
3364
|
+
// When a parameter variable (e.g., `node`) is equivalenced to `signature[N]`,
|
|
3365
|
+
// all sub-paths of that variable should also appear under `signature[N]`.
|
|
3366
|
+
// This handles cases where the sub-path was added to the schema via a propagation
|
|
3367
|
+
// chain that already included the variable↔signature equivalency, causing the
|
|
3368
|
+
// cycle detection to prevent the reverse mapping.
|
|
3369
|
+
this.propagateParameterToSignaturePaths(scopeNode);
|
|
3370
|
+
|
|
3294
3371
|
fillInSchemaGapsAndUnknowns(scopeNode, fillInUnknowns);
|
|
3295
3372
|
|
|
3296
3373
|
if (final) {
|
|
@@ -3305,6 +3382,97 @@ export class ScopeDataStructure {
|
|
|
3305
3382
|
}
|
|
3306
3383
|
}
|
|
3307
3384
|
|
|
3385
|
+
/**
|
|
3386
|
+
* For each equivalency where a simple variable maps to signature[N],
|
|
3387
|
+
* ensure all sub-paths of that variable are reflected under signature[N].
|
|
3388
|
+
*/
|
|
3389
|
+
private propagateParameterToSignaturePaths(scopeNode: ScopeNode) {
|
|
3390
|
+
// Helper: check if a type is a concrete scalar that cannot have sub-properties.
|
|
3391
|
+
const SCALAR_TYPES = new Set([
|
|
3392
|
+
'string',
|
|
3393
|
+
'number',
|
|
3394
|
+
'boolean',
|
|
3395
|
+
'bigint',
|
|
3396
|
+
'symbol',
|
|
3397
|
+
'void',
|
|
3398
|
+
'never',
|
|
3399
|
+
]);
|
|
3400
|
+
const isDefinitelyScalar = (type: string): boolean => {
|
|
3401
|
+
const parts = type.split('|').map((s) => s.trim());
|
|
3402
|
+
const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
|
|
3403
|
+
return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
|
|
3404
|
+
};
|
|
3405
|
+
|
|
3406
|
+
// Find variable → signature[N] equivalencies
|
|
3407
|
+
for (const [varName, equivalencies] of Object.entries(
|
|
3408
|
+
scopeNode.equivalencies,
|
|
3409
|
+
)) {
|
|
3410
|
+
// Only process simple variable names (no dots, brackets, or parens)
|
|
3411
|
+
if (
|
|
3412
|
+
varName.includes('.') ||
|
|
3413
|
+
varName.includes('[') ||
|
|
3414
|
+
varName.includes('(')
|
|
3415
|
+
) {
|
|
3416
|
+
continue;
|
|
3417
|
+
}
|
|
3418
|
+
|
|
3419
|
+
for (const equiv of equivalencies) {
|
|
3420
|
+
if (
|
|
3421
|
+
equiv.scopeNodeName === scopeNode.name &&
|
|
3422
|
+
equiv.schemaPath.startsWith('signature[')
|
|
3423
|
+
) {
|
|
3424
|
+
const signaturePath = equiv.schemaPath;
|
|
3425
|
+
const varPrefix = varName + '.';
|
|
3426
|
+
const varBracketPrefix = varName + '[';
|
|
3427
|
+
|
|
3428
|
+
// Find all schema keys starting with the variable
|
|
3429
|
+
for (const key in scopeNode.schema) {
|
|
3430
|
+
if (key.startsWith(varPrefix) || key.startsWith(varBracketPrefix)) {
|
|
3431
|
+
const suffix = key.slice(varName.length);
|
|
3432
|
+
const sigKey = signaturePath + suffix;
|
|
3433
|
+
|
|
3434
|
+
// Only add if the signature path doesn't already exist
|
|
3435
|
+
if (!scopeNode.schema[sigKey]) {
|
|
3436
|
+
// Check if this path represents variable conflation:
|
|
3437
|
+
// When a standalone variable (e.g., showWorkoutForm from useState)
|
|
3438
|
+
// appears as a sub-property of a scalar-typed ancestor (e.g.,
|
|
3439
|
+
// activity_type = "string"), it's from scope conflation, not real
|
|
3440
|
+
// property access. Block these while allowing legitimate built-in
|
|
3441
|
+
// accesses like string.length or string.slice.
|
|
3442
|
+
let isConflatedPath = false;
|
|
3443
|
+
let checkPos = signaturePath.length;
|
|
3444
|
+
while (true) {
|
|
3445
|
+
checkPos = sigKey.indexOf('.', checkPos + 1);
|
|
3446
|
+
if (checkPos === -1) break;
|
|
3447
|
+
const ancestorPath = sigKey.substring(0, checkPos);
|
|
3448
|
+
const ancestorType = scopeNode.schema[ancestorPath];
|
|
3449
|
+
if (ancestorType && isDefinitelyScalar(ancestorType)) {
|
|
3450
|
+
// Ancestor is scalar — check if the immediate sub-property
|
|
3451
|
+
// is also a standalone variable (indicating conflation)
|
|
3452
|
+
const afterDot = sigKey.substring(checkPos + 1);
|
|
3453
|
+
const nextSep = afterDot.search(/[.\[]/);
|
|
3454
|
+
const subPropName =
|
|
3455
|
+
nextSep === -1
|
|
3456
|
+
? afterDot
|
|
3457
|
+
: afterDot.substring(0, nextSep);
|
|
3458
|
+
if (scopeNode.schema[subPropName] !== undefined) {
|
|
3459
|
+
isConflatedPath = true;
|
|
3460
|
+
break;
|
|
3461
|
+
}
|
|
3462
|
+
}
|
|
3463
|
+
}
|
|
3464
|
+
|
|
3465
|
+
if (!isConflatedPath) {
|
|
3466
|
+
scopeNode.schema[sigKey] = scopeNode.schema[key];
|
|
3467
|
+
}
|
|
3468
|
+
}
|
|
3469
|
+
}
|
|
3470
|
+
}
|
|
3471
|
+
}
|
|
3472
|
+
}
|
|
3473
|
+
}
|
|
3474
|
+
}
|
|
3475
|
+
|
|
3308
3476
|
private filterAndConvertSchema({
|
|
3309
3477
|
filterPath,
|
|
3310
3478
|
newPath,
|
|
@@ -3391,6 +3559,9 @@ export class ScopeDataStructure {
|
|
|
3391
3559
|
equivalentValueSchemaPathParts.length,
|
|
3392
3560
|
),
|
|
3393
3561
|
]);
|
|
3562
|
+
// PERF: Skip keys with repeated function-call signature patterns
|
|
3563
|
+
// to prevent recursive type expansion (e.g., string.localeCompare returns string)
|
|
3564
|
+
if (this.hasExcessivePatternRepetition(newKey)) continue;
|
|
3394
3565
|
resolvedSchema[newKey] = value;
|
|
3395
3566
|
}
|
|
3396
3567
|
}
|
|
@@ -3413,6 +3584,8 @@ export class ScopeDataStructure {
|
|
|
3413
3584
|
if (!subSchema) continue;
|
|
3414
3585
|
|
|
3415
3586
|
for (const resolvedKey in subSchema) {
|
|
3587
|
+
// PERF: Skip keys with repeated function-call signature patterns
|
|
3588
|
+
if (this.hasExcessivePatternRepetition(resolvedKey)) continue;
|
|
3416
3589
|
if (
|
|
3417
3590
|
!resolvedSchema[resolvedKey] ||
|
|
3418
3591
|
subSchema[resolvedKey] === 'unknown'
|
|
@@ -3804,25 +3977,116 @@ export class ScopeDataStructure {
|
|
|
3804
3977
|
return [source];
|
|
3805
3978
|
};
|
|
3806
3979
|
|
|
3807
|
-
|
|
3808
|
-
(
|
|
3809
|
-
if (entry.sourceCandidates.length === 0) return
|
|
3980
|
+
const acc = entries.reduce(
|
|
3981
|
+
(result, entry) => {
|
|
3982
|
+
if (entry.sourceCandidates.length === 0) return result;
|
|
3810
3983
|
const usages = entry.usages.filter(usageMatchesScope);
|
|
3811
3984
|
for (const usage of usages) {
|
|
3812
|
-
|
|
3985
|
+
result[usage.schemaPath] ||= [];
|
|
3813
3986
|
// Resolve each source candidate through the equivalency chain
|
|
3814
3987
|
for (const source of entry.sourceCandidates) {
|
|
3815
3988
|
const resolvedSources = resolveToSignature(source, new Set());
|
|
3816
|
-
|
|
3989
|
+
result[usage.schemaPath].push(...resolvedSources);
|
|
3817
3990
|
}
|
|
3818
3991
|
}
|
|
3819
|
-
return
|
|
3992
|
+
return result;
|
|
3820
3993
|
},
|
|
3821
3994
|
{} as Record<
|
|
3822
3995
|
string,
|
|
3823
3996
|
Pick<ScopeVariable, 'scopeNodeName' | 'schemaPath'>[]
|
|
3824
3997
|
>,
|
|
3825
3998
|
);
|
|
3999
|
+
|
|
4000
|
+
// Post-processing: enrich useState-backed sources with co-located external
|
|
4001
|
+
// function calls. When a useState value resolves to a setter variable that
|
|
4002
|
+
// lives in the same scope as a fetch/API call, that fetch is a data source.
|
|
4003
|
+
this.enrichUseStateSourcesWithCoLocatedCalls(acc);
|
|
4004
|
+
|
|
4005
|
+
return acc;
|
|
4006
|
+
}
|
|
4007
|
+
|
|
4008
|
+
/**
|
|
4009
|
+
* For each source that ends at a useState path, check if the setter was called
|
|
4010
|
+
* from a scope that also contains external function calls (like fetch).
|
|
4011
|
+
* If so, add those external calls as additional source candidates.
|
|
4012
|
+
*/
|
|
4013
|
+
private enrichUseStateSourcesWithCoLocatedCalls(
|
|
4014
|
+
acc: Record<string, Pick<ScopeVariable, 'scopeNodeName' | 'schemaPath'>[]>,
|
|
4015
|
+
) {
|
|
4016
|
+
const rootScopeName = this.scopeTreeManager.getRootName();
|
|
4017
|
+
const rootScope = this.scopeNodes[rootScopeName];
|
|
4018
|
+
if (!rootScope) return;
|
|
4019
|
+
|
|
4020
|
+
// Collect all descendants for each scope node
|
|
4021
|
+
const getAllDescendants = (
|
|
4022
|
+
node: import('./helpers/ScopeTreeManager').ScopeTreeNode,
|
|
4023
|
+
): Set<string> => {
|
|
4024
|
+
const names = new Set<string>([node.name]);
|
|
4025
|
+
for (const child of node.children) {
|
|
4026
|
+
for (const name of getAllDescendants(child)) {
|
|
4027
|
+
names.add(name);
|
|
4028
|
+
}
|
|
4029
|
+
}
|
|
4030
|
+
return names;
|
|
4031
|
+
};
|
|
4032
|
+
|
|
4033
|
+
for (const [usagePath, sources] of Object.entries(acc)) {
|
|
4034
|
+
const additionalSources: Pick<
|
|
4035
|
+
ScopeVariable,
|
|
4036
|
+
'scopeNodeName' | 'schemaPath'
|
|
4037
|
+
>[] = [];
|
|
4038
|
+
|
|
4039
|
+
for (const source of sources) {
|
|
4040
|
+
// Check if this source is a useState-related terminal path
|
|
4041
|
+
// (e.g., useState(X).functionCallReturnValue[1] or useState(X).signature[0])
|
|
4042
|
+
if (!source.schemaPath.match(/^useState\([^)]*\)\./)) continue;
|
|
4043
|
+
|
|
4044
|
+
// Find the useState call from the source path
|
|
4045
|
+
const useStateCallMatch = source.schemaPath.match(
|
|
4046
|
+
/^(useState\([^)]*\))\./,
|
|
4047
|
+
);
|
|
4048
|
+
if (!useStateCallMatch) continue;
|
|
4049
|
+
const useStateCall = useStateCallMatch[1];
|
|
4050
|
+
|
|
4051
|
+
// Look in the root scope for the useState value equivalency
|
|
4052
|
+
// which tells us where the setter was called from
|
|
4053
|
+
const valuePath = `${useStateCall}.functionCallReturnValue[0]`;
|
|
4054
|
+
const valueEquivs = rootScope.equivalencies[valuePath];
|
|
4055
|
+
if (!valueEquivs) continue;
|
|
4056
|
+
|
|
4057
|
+
for (const equiv of valueEquivs) {
|
|
4058
|
+
// Find the scope where the setter was called
|
|
4059
|
+
const setterScopeName = equiv.scopeNodeName;
|
|
4060
|
+
const setterScopeTree =
|
|
4061
|
+
this.scopeTreeManager.findNode(setterScopeName);
|
|
4062
|
+
if (!setterScopeTree) continue;
|
|
4063
|
+
|
|
4064
|
+
// Get all descendant scope names from the setter scope
|
|
4065
|
+
const relatedScopes = getAllDescendants(setterScopeTree);
|
|
4066
|
+
|
|
4067
|
+
// Find external function calls in those scopes whose return values
|
|
4068
|
+
// are actually consumed (assigned to a variable). This excludes
|
|
4069
|
+
// fire-and-forget calls like analytics.track() or console.log().
|
|
4070
|
+
const coLocatedCalls = this.externalFunctionCalls.filter(
|
|
4071
|
+
(efc) =>
|
|
4072
|
+
relatedScopes.has(efc.callScope) &&
|
|
4073
|
+
efc.receivingVariableNames &&
|
|
4074
|
+
efc.receivingVariableNames.length > 0,
|
|
4075
|
+
);
|
|
4076
|
+
|
|
4077
|
+
for (const call of coLocatedCalls) {
|
|
4078
|
+
additionalSources.push({
|
|
4079
|
+
scopeNodeName: call.callScope,
|
|
4080
|
+
schemaPath: `${call.callSignature}.functionCallReturnValue`,
|
|
4081
|
+
});
|
|
4082
|
+
}
|
|
4083
|
+
}
|
|
4084
|
+
}
|
|
4085
|
+
|
|
4086
|
+
if (additionalSources.length > 0) {
|
|
4087
|
+
acc[usagePath].push(...additionalSources);
|
|
4088
|
+
}
|
|
4089
|
+
}
|
|
3826
4090
|
}
|
|
3827
4091
|
|
|
3828
4092
|
getUsageEquivalencies(functionName?: string) {
|
|
@@ -3927,6 +4191,72 @@ export class ScopeDataStructure {
|
|
|
3927
4191
|
}
|
|
3928
4192
|
}
|
|
3929
4193
|
|
|
4194
|
+
// Enrich schema with deeply nested paths from internal function call scopes.
|
|
4195
|
+
// When a function call like traverse(tree) exists, and traverse's scope has
|
|
4196
|
+
// signature[0].children[path][entityName] (from propagateParameterToSignaturePaths),
|
|
4197
|
+
// we need to map those paths back to the argument variable (tree) in this scope.
|
|
4198
|
+
// This handles cases where cycle detection prevented the equivalency chain from
|
|
4199
|
+
// propagating deep paths during Phase 2 batch queue processing.
|
|
4200
|
+
for (const equivalenceKey in equivalencies ?? {}) {
|
|
4201
|
+
// Look for keys matching function call pattern: funcName(...).signature[N]
|
|
4202
|
+
const funcCallMatch = equivalenceKey.match(
|
|
4203
|
+
/^([^(]+)\(.*?\)\.(signature\[\d+\])$/,
|
|
4204
|
+
);
|
|
4205
|
+
if (!funcCallMatch) continue;
|
|
4206
|
+
|
|
4207
|
+
const calledFunctionName = funcCallMatch[1];
|
|
4208
|
+
const signatureParam = funcCallMatch[2]; // e.g., "signature[0]"
|
|
4209
|
+
|
|
4210
|
+
for (const equivalenceValue of equivalencies[equivalenceKey]) {
|
|
4211
|
+
if (equivalenceValue.scopeNodeName !== scopeName) continue;
|
|
4212
|
+
|
|
4213
|
+
const targetVariable = equivalenceValue.schemaPath;
|
|
4214
|
+
|
|
4215
|
+
// Get the called function's schema (includes propagated parameter paths)
|
|
4216
|
+
const childSchema = this.getSchema({
|
|
4217
|
+
scopeName: calledFunctionName,
|
|
4218
|
+
});
|
|
4219
|
+
if (!childSchema) continue;
|
|
4220
|
+
|
|
4221
|
+
// Map child function's signature paths to parent variable paths
|
|
4222
|
+
const sigPrefix = signatureParam + '.';
|
|
4223
|
+
const sigBracketPrefix = signatureParam + '[';
|
|
4224
|
+
for (const childKey in childSchema) {
|
|
4225
|
+
let suffix: string | null = null;
|
|
4226
|
+
if (childKey.startsWith(sigPrefix)) {
|
|
4227
|
+
suffix = childKey.slice(signatureParam.length);
|
|
4228
|
+
} else if (childKey.startsWith(sigBracketPrefix)) {
|
|
4229
|
+
suffix = childKey.slice(signatureParam.length);
|
|
4230
|
+
}
|
|
4231
|
+
|
|
4232
|
+
if (suffix !== null) {
|
|
4233
|
+
const parentKey = targetVariable + suffix;
|
|
4234
|
+
if (!schema[parentKey]) {
|
|
4235
|
+
schema[parentKey] = childSchema[childKey];
|
|
4236
|
+
}
|
|
4237
|
+
}
|
|
4238
|
+
}
|
|
4239
|
+
}
|
|
4240
|
+
}
|
|
4241
|
+
|
|
4242
|
+
// Helper: check if a type is a concrete scalar that cannot have sub-properties.
|
|
4243
|
+
// e.g., "string", "number | undefined", "boolean | null" are scalar.
|
|
4244
|
+
// "object", "array", "function", "unknown", "Workout", etc. are NOT scalar.
|
|
4245
|
+
const SCALAR_TYPES = new Set([
|
|
4246
|
+
'string',
|
|
4247
|
+
'number',
|
|
4248
|
+
'boolean',
|
|
4249
|
+
'bigint',
|
|
4250
|
+
'symbol',
|
|
4251
|
+
'void',
|
|
4252
|
+
'never',
|
|
4253
|
+
]);
|
|
4254
|
+
const isDefinitelyScalarType = (type: string): boolean => {
|
|
4255
|
+
const parts = type.split('|').map((s) => s.trim());
|
|
4256
|
+
const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
|
|
4257
|
+
return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
|
|
4258
|
+
};
|
|
4259
|
+
|
|
3930
4260
|
// Propagate nested paths from variables to their signature equivalents
|
|
3931
4261
|
// e.g., if workouts = signature[0].workouts, then workouts[].title becomes
|
|
3932
4262
|
// signature[0].workouts[].title
|
|
@@ -3951,7 +4281,69 @@ export class ScopeDataStructure {
|
|
|
3951
4281
|
|
|
3952
4282
|
// Add to schema if not already present
|
|
3953
4283
|
if (!tempScopeNode.schema[signatureKey]) {
|
|
3954
|
-
|
|
4284
|
+
// Check if this path represents variable conflation:
|
|
4285
|
+
// When a standalone variable (e.g., showWorkoutForm from useState)
|
|
4286
|
+
// appears as a sub-property of a scalar-typed ancestor (e.g.,
|
|
4287
|
+
// activity_type = "string"), it's from scope conflation, not real
|
|
4288
|
+
// property access. Block these while allowing legitimate built-in
|
|
4289
|
+
// accesses like string.length or string.slice.
|
|
4290
|
+
let isConflatedPath = false;
|
|
4291
|
+
let checkPos = signaturePath.length;
|
|
4292
|
+
while (true) {
|
|
4293
|
+
checkPos = signatureKey.indexOf('.', checkPos + 1);
|
|
4294
|
+
if (checkPos === -1) break;
|
|
4295
|
+
const ancestorPath = signatureKey.substring(0, checkPos);
|
|
4296
|
+
const ancestorType = tempScopeNode.schema[ancestorPath];
|
|
4297
|
+
if (ancestorType && isDefinitelyScalarType(ancestorType)) {
|
|
4298
|
+
// Ancestor is scalar — check if the immediate sub-property
|
|
4299
|
+
// is also a standalone variable (indicating conflation)
|
|
4300
|
+
const afterDot = signatureKey.substring(checkPos + 1);
|
|
4301
|
+
const nextSep = afterDot.search(/[.\[]/);
|
|
4302
|
+
const subPropName =
|
|
4303
|
+
nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
|
|
4304
|
+
if (schema[subPropName] !== undefined) {
|
|
4305
|
+
isConflatedPath = true;
|
|
4306
|
+
break;
|
|
4307
|
+
}
|
|
4308
|
+
}
|
|
4309
|
+
}
|
|
4310
|
+
|
|
4311
|
+
if (!isConflatedPath) {
|
|
4312
|
+
tempScopeNode.schema[signatureKey] = schema[schemaKey];
|
|
4313
|
+
}
|
|
4314
|
+
}
|
|
4315
|
+
}
|
|
4316
|
+
}
|
|
4317
|
+
}
|
|
4318
|
+
|
|
4319
|
+
// Post-process: filter out conflated signature paths.
|
|
4320
|
+
// During phase 2 scope analysis, useState(false) conflation can create
|
|
4321
|
+
// bad paths like signature[0].mockWorkouts[].activity_type.showWorkoutForm
|
|
4322
|
+
// directly in scopeNode.schema. These flow through signatureInSchema into
|
|
4323
|
+
// tempScopeNode.schema without any guard. Filter them out here by checking:
|
|
4324
|
+
// 1. An ancestor in the path has a concrete scalar type (string, number, boolean, etc.)
|
|
4325
|
+
// 2. The immediate sub-property of that scalar ancestor is also a standalone
|
|
4326
|
+
// variable in the schema (indicating conflation, not a real property access)
|
|
4327
|
+
for (const key of Object.keys(tempScopeNode.schema)) {
|
|
4328
|
+
if (!key.startsWith('signature[')) continue;
|
|
4329
|
+
|
|
4330
|
+
// Walk through the path looking for scalar-typed ancestors
|
|
4331
|
+
let pos = 0;
|
|
4332
|
+
while (true) {
|
|
4333
|
+
pos = key.indexOf('.', pos + 1);
|
|
4334
|
+
if (pos === -1) break;
|
|
4335
|
+
const ancestorPath = key.substring(0, pos);
|
|
4336
|
+
const ancestorType = tempScopeNode.schema[ancestorPath];
|
|
4337
|
+
if (ancestorType && isDefinitelyScalarType(ancestorType)) {
|
|
4338
|
+
// Found a scalar ancestor — check if the sub-property name
|
|
4339
|
+
// is a standalone variable in the getSchema() result
|
|
4340
|
+
const afterDot = key.substring(pos + 1);
|
|
4341
|
+
const nextSep = afterDot.search(/[.\[]/);
|
|
4342
|
+
const subPropName =
|
|
4343
|
+
nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
|
|
4344
|
+
if (schema[subPropName] !== undefined) {
|
|
4345
|
+
delete tempScopeNode.schema[key];
|
|
4346
|
+
break;
|
|
3955
4347
|
}
|
|
3956
4348
|
}
|
|
3957
4349
|
}
|
|
@@ -4281,6 +4673,15 @@ export class ScopeDataStructure {
|
|
|
4281
4673
|
!equivalentValue.schemaPath.startsWith('signature[') && // not a signature path
|
|
4282
4674
|
!equivalentValue.schemaPath.endsWith('.functionCallReturnValue') // not already handled above
|
|
4283
4675
|
) {
|
|
4676
|
+
// Skip bare "returnValue" from child scopes — this is the child's return value,
|
|
4677
|
+
// not a meaningful data source path in the parent scope
|
|
4678
|
+
if (
|
|
4679
|
+
equivalentValue.schemaPath === 'returnValue' &&
|
|
4680
|
+
equivalentValue.scopeNodeName !==
|
|
4681
|
+
this.scopeTreeManager.getRootName()
|
|
4682
|
+
) {
|
|
4683
|
+
continue;
|
|
4684
|
+
}
|
|
4284
4685
|
// Add equivalency (will accumulate if multiple values for OR expressions)
|
|
4285
4686
|
addEquivalency(path, equivalentValue.schemaPath);
|
|
4286
4687
|
}
|
|
@@ -4682,9 +5083,109 @@ export class ScopeDataStructure {
|
|
|
4682
5083
|
// Replace cyScope placeholders in all external function call data
|
|
4683
5084
|
// This ensures call signatures and schema paths use actual callback text
|
|
4684
5085
|
// instead of internal cyScope names, preventing mock data merge conflicts.
|
|
4685
|
-
|
|
4686
|
-
|
|
4687
|
-
|
|
5086
|
+
const rootScopeName = this.scopeTreeManager.getRootName();
|
|
5087
|
+
const rootSchema = this.scopeNodes[rootScopeName]?.schema ?? {};
|
|
5088
|
+
|
|
5089
|
+
return this.externalFunctionCalls.map((efc) => {
|
|
5090
|
+
const cleaned = this.cleanCyScopeFromFunctionCallInfo(efc);
|
|
5091
|
+
return this.filterConflatedExternalPaths(cleaned, rootSchema);
|
|
5092
|
+
});
|
|
5093
|
+
}
|
|
5094
|
+
|
|
5095
|
+
/**
|
|
5096
|
+
* Filters out conflated paths from external function call schemas.
|
|
5097
|
+
*
|
|
5098
|
+
* When multiple useState(false) calls create equivalency conflation during
|
|
5099
|
+
* Phase 1 analysis, standalone boolean state variables (like showWorkoutForm,
|
|
5100
|
+
* showGoalForm) can bleed into external function call schemas as sub-properties
|
|
5101
|
+
* of unrelated data fields (like data[].activity_type.showWorkoutForm).
|
|
5102
|
+
*
|
|
5103
|
+
* Detection: group sub-properties by parent path. If 2+ sub-properties of
|
|
5104
|
+
* the same parent all match standalone root scope variable names, treat them
|
|
5105
|
+
* as conflation artifacts and remove them.
|
|
5106
|
+
*/
|
|
5107
|
+
private filterConflatedExternalPaths(
|
|
5108
|
+
efc: FunctionCallInfo,
|
|
5109
|
+
rootSchema: Record<string, string>,
|
|
5110
|
+
): FunctionCallInfo {
|
|
5111
|
+
// Build a set of top-level root scope variable names (simple names, no dots/brackets)
|
|
5112
|
+
const topLevelRootVars = new Set<string>();
|
|
5113
|
+
for (const key of Object.keys(rootSchema)) {
|
|
5114
|
+
if (!key.includes('.') && !key.includes('[')) {
|
|
5115
|
+
topLevelRootVars.add(key);
|
|
5116
|
+
}
|
|
5117
|
+
}
|
|
5118
|
+
|
|
5119
|
+
if (topLevelRootVars.size === 0) return efc;
|
|
5120
|
+
|
|
5121
|
+
// Group sub-property matches by their parent path.
|
|
5122
|
+
// For a path like "...data[].activity_type.showWorkoutForm",
|
|
5123
|
+
// parent = "...data[].activity_type", child = "showWorkoutForm"
|
|
5124
|
+
const parentToConflatedKeys = new Map<string, string[]>();
|
|
5125
|
+
|
|
5126
|
+
for (const key of Object.keys(efc.schema)) {
|
|
5127
|
+
const lastDot = key.lastIndexOf('.');
|
|
5128
|
+
if (lastDot === -1) continue;
|
|
5129
|
+
|
|
5130
|
+
const parent = key.substring(0, lastDot);
|
|
5131
|
+
const child = key.substring(lastDot + 1);
|
|
5132
|
+
|
|
5133
|
+
// Skip array access or function call patterns
|
|
5134
|
+
if (child.includes('[') || child.includes('(')) continue;
|
|
5135
|
+
|
|
5136
|
+
// Only consider paths inside array element chains (contains []).
|
|
5137
|
+
// Direct children of functionCallReturnValue are legitimate destructured
|
|
5138
|
+
// return values, not conflation. Conflation happens deeper in the chain
|
|
5139
|
+
// when array element fields get corrupted sub-properties.
|
|
5140
|
+
if (!parent.includes('[')) continue;
|
|
5141
|
+
|
|
5142
|
+
if (topLevelRootVars.has(child)) {
|
|
5143
|
+
if (!parentToConflatedKeys.has(parent)) {
|
|
5144
|
+
parentToConflatedKeys.set(parent, []);
|
|
5145
|
+
}
|
|
5146
|
+
parentToConflatedKeys.get(parent)!.push(key);
|
|
5147
|
+
}
|
|
5148
|
+
}
|
|
5149
|
+
|
|
5150
|
+
// Only filter when 2+ sub-properties of the same parent match root scope vars.
|
|
5151
|
+
// This threshold avoids false positives from coincidental name matches.
|
|
5152
|
+
const keysToRemove = new Set<string>();
|
|
5153
|
+
const parentsToRestore = new Set<string>();
|
|
5154
|
+
|
|
5155
|
+
for (const [parent, conflatedKeys] of parentToConflatedKeys) {
|
|
5156
|
+
if (conflatedKeys.length >= 2) {
|
|
5157
|
+
for (const key of conflatedKeys) {
|
|
5158
|
+
keysToRemove.add(key);
|
|
5159
|
+
}
|
|
5160
|
+
parentsToRestore.add(parent);
|
|
5161
|
+
}
|
|
5162
|
+
}
|
|
5163
|
+
|
|
5164
|
+
if (keysToRemove.size === 0) return efc;
|
|
5165
|
+
|
|
5166
|
+
// Create a new schema without the conflated paths
|
|
5167
|
+
const newSchema: Record<string, string> = {};
|
|
5168
|
+
for (const [key, value] of Object.entries(efc.schema)) {
|
|
5169
|
+
if (keysToRemove.has(key)) continue;
|
|
5170
|
+
|
|
5171
|
+
// Restore parent type: if it was changed to "object" because of conflated
|
|
5172
|
+
// sub-properties, and now all those sub-properties are removed, change it
|
|
5173
|
+
// back to "unknown" (we don't know the original type)
|
|
5174
|
+
if (parentsToRestore.has(key) && value === 'object') {
|
|
5175
|
+
// Check if there are any remaining sub-properties
|
|
5176
|
+
const hasRemainingSubProps = Object.keys(efc.schema).some(
|
|
5177
|
+
(k) =>
|
|
5178
|
+
!keysToRemove.has(k) &&
|
|
5179
|
+
k !== key &&
|
|
5180
|
+
(k.startsWith(key + '.') || k.startsWith(key + '[')),
|
|
5181
|
+
);
|
|
5182
|
+
newSchema[key] = hasRemainingSubProps ? value : 'unknown';
|
|
5183
|
+
} else {
|
|
5184
|
+
newSchema[key] = value;
|
|
5185
|
+
}
|
|
5186
|
+
}
|
|
5187
|
+
|
|
5188
|
+
return { ...efc, schema: newSchema };
|
|
4688
5189
|
}
|
|
4689
5190
|
|
|
4690
5191
|
/**
|
|
@@ -4977,6 +5478,10 @@ export class ScopeDataStructure {
|
|
|
4977
5478
|
getEnrichedConditionalUsages(): Record<string, EnrichedConditionalUsage[]> {
|
|
4978
5479
|
const enriched: Record<string, EnrichedConditionalUsage[]> = {};
|
|
4979
5480
|
|
|
5481
|
+
console.log(
|
|
5482
|
+
`[getEnrichedConditionalUsages] Processing ${Object.keys(this.rawConditionalUsages).length} conditional paths: [${Object.keys(this.rawConditionalUsages).join(', ')}]`,
|
|
5483
|
+
);
|
|
5484
|
+
|
|
4980
5485
|
for (const [path, usages] of Object.entries(this.rawConditionalUsages)) {
|
|
4981
5486
|
// Try to trace this path back to a data source
|
|
4982
5487
|
// First, try the root scope
|
|
@@ -4985,10 +5490,69 @@ export class ScopeDataStructure {
|
|
|
4985
5490
|
|
|
4986
5491
|
let sourceDataPath: string | undefined;
|
|
4987
5492
|
if (explanation.source) {
|
|
4988
|
-
|
|
4989
|
-
|
|
5493
|
+
const { scope, path: sourcePath } = explanation.source;
|
|
5494
|
+
|
|
5495
|
+
// Build initial path — avoid redundant prefix when path already contains the scope call
|
|
5496
|
+
let fullPath: string;
|
|
5497
|
+
if (sourcePath.startsWith(`${scope}(`)) {
|
|
5498
|
+
fullPath = sourcePath;
|
|
5499
|
+
} else {
|
|
5500
|
+
fullPath = `${scope}.${sourcePath}`;
|
|
5501
|
+
}
|
|
5502
|
+
|
|
5503
|
+
sourceDataPath = fullPath;
|
|
5504
|
+
console.log(
|
|
5505
|
+
`[getEnrichedConditionalUsages] "${path}" explainPath → scope="${scope}", sourcePath="${sourcePath}" → sourceDataPath="${sourceDataPath}"`,
|
|
5506
|
+
);
|
|
5507
|
+
} else {
|
|
5508
|
+
console.log(
|
|
5509
|
+
`[getEnrichedConditionalUsages] "${path}" explainPath → no source found`,
|
|
5510
|
+
);
|
|
5511
|
+
}
|
|
5512
|
+
|
|
5513
|
+
// If explainPath didn't find a useful external source (e.g., it traced to
|
|
5514
|
+
// useState or just to the component scope itself), check sourceEquivalencies
|
|
5515
|
+
// for an external function call source like a fetch call
|
|
5516
|
+
const hasExternalSource = sourceDataPath?.includes(
|
|
5517
|
+
'.functionCallReturnValue',
|
|
5518
|
+
);
|
|
5519
|
+
if (!hasExternalSource) {
|
|
5520
|
+
console.log(
|
|
5521
|
+
`[getEnrichedConditionalUsages] "${path}" no external source (sourceDataPath="${sourceDataPath}"), checking sourceEquivalencies fallback...`,
|
|
5522
|
+
);
|
|
5523
|
+
const sourceEquiv = this.getSourceEquivalencies();
|
|
5524
|
+
const returnValueKey = `returnValue.${path}`;
|
|
5525
|
+
const sources = sourceEquiv[returnValueKey];
|
|
5526
|
+
if (sources) {
|
|
5527
|
+
console.log(
|
|
5528
|
+
`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies["${returnValueKey}"] has ${sources.length} sources: [${sources.map((s: { schemaPath: string }) => s.schemaPath).join(', ')}]`,
|
|
5529
|
+
);
|
|
5530
|
+
const externalSource = sources.find(
|
|
5531
|
+
(s: { schemaPath: string }) =>
|
|
5532
|
+
s.schemaPath.includes('.functionCallReturnValue') &&
|
|
5533
|
+
!s.schemaPath.startsWith('useState('),
|
|
5534
|
+
);
|
|
5535
|
+
if (externalSource) {
|
|
5536
|
+
console.log(
|
|
5537
|
+
`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies fallback found external source: "${externalSource.schemaPath}"`,
|
|
5538
|
+
);
|
|
5539
|
+
sourceDataPath = externalSource.schemaPath;
|
|
5540
|
+
} else {
|
|
5541
|
+
console.log(
|
|
5542
|
+
`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies fallback found no external function call source`,
|
|
5543
|
+
);
|
|
5544
|
+
}
|
|
5545
|
+
} else {
|
|
5546
|
+
console.log(
|
|
5547
|
+
`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies["${returnValueKey}"] not found`,
|
|
5548
|
+
);
|
|
5549
|
+
}
|
|
4990
5550
|
}
|
|
4991
5551
|
|
|
5552
|
+
console.log(
|
|
5553
|
+
`[getEnrichedConditionalUsages] "${path}" FINAL sourceDataPath="${sourceDataPath ?? '(none)'}" (${usages.length} usages)`,
|
|
5554
|
+
);
|
|
5555
|
+
|
|
4992
5556
|
enriched[path] = usages.map((usage) => ({
|
|
4993
5557
|
...usage,
|
|
4994
5558
|
sourceDataPath,
|
|
@@ -5336,11 +5900,22 @@ export class ScopeDataStructure {
|
|
|
5336
5900
|
}
|
|
5337
5901
|
}
|
|
5338
5902
|
|
|
5903
|
+
// Enrich the schema with inferred types by applying fillInSchemaGapsAndUnknowns.
|
|
5904
|
+
// This ensures the serialized schema has the same type inference as getReturnValue().
|
|
5905
|
+
// Without this, evidence like "entities[].analyses: array" becomes "unknown".
|
|
5906
|
+
const enrichedSchema = { ...efc.schema };
|
|
5907
|
+
const tempScopeNode = {
|
|
5908
|
+
name: efc.name,
|
|
5909
|
+
schema: enrichedSchema,
|
|
5910
|
+
equivalencies: efc.equivalencies ?? {},
|
|
5911
|
+
};
|
|
5912
|
+
fillInSchemaGapsAndUnknowns(tempScopeNode, true);
|
|
5913
|
+
|
|
5339
5914
|
return {
|
|
5340
5915
|
name: efc.name,
|
|
5341
5916
|
callSignature: efc.callSignature,
|
|
5342
5917
|
callScope: efc.callScope,
|
|
5343
|
-
schema:
|
|
5918
|
+
schema: enrichedSchema,
|
|
5344
5919
|
equivalencies: efc.equivalencies
|
|
5345
5920
|
? Object.entries(efc.equivalencies).reduce(
|
|
5346
5921
|
(acc, [key, vars]) => {
|