@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
|
@@ -181,6 +181,7 @@ const SILENTLY_IGNORED_EQUIVALENCY_REASONS = new Set([
|
|
|
181
181
|
'transformed non-object function equivalency - implicit parent equivalency - rerouted via useCallback',
|
|
182
182
|
'transformed non-object function equivalency - Array.from() equivalency',
|
|
183
183
|
'Spread operator equivalency key update: Explicit array deconstruction equivalency value',
|
|
184
|
+
// 'transformed non-object function equivalency - Explicit array deconstruction equivalency value',
|
|
184
185
|
]);
|
|
185
186
|
export class ScopeDataStructure {
|
|
186
187
|
// Getter for backward compatibility - returns the tree structure
|
|
@@ -475,6 +476,10 @@ export class ScopeDataStructure {
|
|
|
475
476
|
}
|
|
476
477
|
return;
|
|
477
478
|
}
|
|
479
|
+
// PERF: Early exit for paths with repeated function-call signature patterns
|
|
480
|
+
if (this.hasExcessivePatternRepetition(path)) {
|
|
481
|
+
return;
|
|
482
|
+
}
|
|
478
483
|
// Update chain metadata for database tracking
|
|
479
484
|
if (equivalencyValueChain.length > 0) {
|
|
480
485
|
equivalencyValueChain[equivalencyValueChain.length - 1].addToSchemaId =
|
|
@@ -693,6 +698,27 @@ export class ScopeDataStructure {
|
|
|
693
698
|
equivalentPath.startsWith(path + '(')) {
|
|
694
699
|
return;
|
|
695
700
|
}
|
|
701
|
+
// Case 3: Circular reference through scope-suffixed names (____cyScope pattern)
|
|
702
|
+
// When a named arrow function is defined inside a scope (e.g., useEffect callback):
|
|
703
|
+
// const identifyUser = async () => { ... };
|
|
704
|
+
// identifyUser();
|
|
705
|
+
// This creates a variable "identifyUser" and a scope "identifyUser____cyScope9F".
|
|
706
|
+
// Mutual equivalencies between these cause infinite loops in Phase 2 because
|
|
707
|
+
// processing one triggers addToSchema → followEquivalencies → addEquivalency
|
|
708
|
+
// on the reverse, which repeats indefinitely.
|
|
709
|
+
// Only block when the REVERSE direction already exists (creating a cycle).
|
|
710
|
+
// The initial one-directional equivalency is necessary for scope resolution.
|
|
711
|
+
if (path &&
|
|
712
|
+
equivalentPath &&
|
|
713
|
+
(equivalentPath.startsWith(path + '____') ||
|
|
714
|
+
path.startsWith(equivalentPath + '____'))) {
|
|
715
|
+
// Check if the reverse equivalency already exists
|
|
716
|
+
const reverseEquivalencies = scopeNode.equivalencies[equivalentPath] || [];
|
|
717
|
+
const reverseExists = reverseEquivalencies.some((v) => v.schemaPath === path);
|
|
718
|
+
if (reverseExists) {
|
|
719
|
+
return;
|
|
720
|
+
}
|
|
721
|
+
}
|
|
696
722
|
if (!equivalentScopeName) {
|
|
697
723
|
console.error('CodeYam Error: Missing equivalent scope name - FULL CONTEXT:', JSON.stringify({
|
|
698
724
|
path,
|
|
@@ -971,6 +997,12 @@ export class ScopeDataStructure {
|
|
|
971
997
|
const value1 = scopeNode.schema[schemaPath];
|
|
972
998
|
const value2 = equivalentScopeNode.schema[equivalentSchemaPath];
|
|
973
999
|
const bestValue = selectBestValue(value1, value2);
|
|
1000
|
+
// PERF: Skip paths with repeated function-call signature patterns
|
|
1001
|
+
// to prevent recursive type expansion (e.g., string.localeCompare returns string)
|
|
1002
|
+
if (this.hasExcessivePatternRepetition(schemaPath) ||
|
|
1003
|
+
this.hasExcessivePatternRepetition(equivalentSchemaPath)) {
|
|
1004
|
+
continue;
|
|
1005
|
+
}
|
|
974
1006
|
scopeNode.schema[schemaPath] = bestValue;
|
|
975
1007
|
equivalentScopeNode.schema[equivalentSchemaPath] = bestValue;
|
|
976
1008
|
}
|
|
@@ -982,6 +1014,10 @@ export class ScopeDataStructure {
|
|
|
982
1014
|
equivalentPath,
|
|
983
1015
|
...remainingSchemaPathParts,
|
|
984
1016
|
]);
|
|
1017
|
+
// PERF: Skip paths with repeated function-call signature patterns
|
|
1018
|
+
if (this.hasExcessivePatternRepetition(newEquivalentPath)) {
|
|
1019
|
+
continue;
|
|
1020
|
+
}
|
|
985
1021
|
equivalentScopeNode.schema[newEquivalentPath] =
|
|
986
1022
|
scopeNode.schema[schemaPath];
|
|
987
1023
|
}
|
|
@@ -1063,6 +1099,23 @@ export class ScopeDataStructure {
|
|
|
1063
1099
|
return true;
|
|
1064
1100
|
}
|
|
1065
1101
|
}
|
|
1102
|
+
// Check for repeated function calls that indicate recursive type expansion.
|
|
1103
|
+
// E.g., localeCompare(b[])...localeCompare(b[]) means string.localeCompare
|
|
1104
|
+
// returns a type that again has localeCompare, causing infinite expansion.
|
|
1105
|
+
// We extract all function call patterns like "funcName(args)" and check if
|
|
1106
|
+
// the same normalized call appears more than once.
|
|
1107
|
+
const funcCallPattern = /(?:^|\.)[^.([]+\([^)]*\)/g;
|
|
1108
|
+
const funcCallMatches = path.match(funcCallPattern);
|
|
1109
|
+
if (funcCallMatches && funcCallMatches.length > 1) {
|
|
1110
|
+
const seen = new Set();
|
|
1111
|
+
for (const match of funcCallMatches) {
|
|
1112
|
+
// Strip leading dot and normalize array indices
|
|
1113
|
+
const normalized = match.replace(/^\./, '').replace(/\[\d+\]/g, '[]');
|
|
1114
|
+
if (seen.has(normalized))
|
|
1115
|
+
return true;
|
|
1116
|
+
seen.add(normalized);
|
|
1117
|
+
}
|
|
1118
|
+
}
|
|
1066
1119
|
// For longer paths, detect any repeated multi-part segments we haven't explicitly listed
|
|
1067
1120
|
const pathParts = this.splitPath(path);
|
|
1068
1121
|
if (pathParts.length <= 6) {
|
|
@@ -1752,6 +1805,7 @@ export class ScopeDataStructure {
|
|
|
1752
1805
|
const remainingPath = this.joinPathParts(remainingPathParts);
|
|
1753
1806
|
if (relevantSubPathParts.every((part, i) => part === schemaPathParts[i]) &&
|
|
1754
1807
|
equivalentValue.scopeNodeName === scopeNode.name) {
|
|
1808
|
+
// DEBUG
|
|
1755
1809
|
continue;
|
|
1756
1810
|
}
|
|
1757
1811
|
const newEquivalentPath = this.joinPathParts([schemaPath, remainingPath]);
|
|
@@ -1893,6 +1947,8 @@ export class ScopeDataStructure {
|
|
|
1893
1947
|
return;
|
|
1894
1948
|
}
|
|
1895
1949
|
const usageScopeNode = this.getScopeOrFunctionCallInfo(usageEquivalency.scopeNodeName);
|
|
1950
|
+
if (!usageScopeNode)
|
|
1951
|
+
continue;
|
|
1896
1952
|
// Guard against infinite recursion by tracking which paths we've already
|
|
1897
1953
|
// added from addComplexSourcePathVariables
|
|
1898
1954
|
if (this.visitedTracker.checkAndMarkComplexSourceVisited(usageScopeNode.name, newUsageEquivalentPath)) {
|
|
@@ -1941,6 +1997,8 @@ export class ScopeDataStructure {
|
|
|
1941
1997
|
continue;
|
|
1942
1998
|
}
|
|
1943
1999
|
const usageScopeNode = this.getScopeOrFunctionCallInfo(usageEquivalency.scopeNodeName);
|
|
2000
|
+
if (!usageScopeNode)
|
|
2001
|
+
continue;
|
|
1944
2002
|
// This is put in place to avoid propagating array functions like 'filter' through complex equivalencies
|
|
1945
2003
|
// but may cause problems if the funtion call is not on a known object (e.g. string or array)
|
|
1946
2004
|
if (newUsageEquivalentPath.endsWith(')') ||
|
|
@@ -2246,6 +2304,13 @@ export class ScopeDataStructure {
|
|
|
2246
2304
|
delete scopeNode.schema[key];
|
|
2247
2305
|
}
|
|
2248
2306
|
}
|
|
2307
|
+
// Ensure parameter-to-signature equivalencies are fully propagated.
|
|
2308
|
+
// When a parameter variable (e.g., `node`) is equivalenced to `signature[N]`,
|
|
2309
|
+
// all sub-paths of that variable should also appear under `signature[N]`.
|
|
2310
|
+
// This handles cases where the sub-path was added to the schema via a propagation
|
|
2311
|
+
// chain that already included the variable↔signature equivalency, causing the
|
|
2312
|
+
// cycle detection to prevent the reverse mapping.
|
|
2313
|
+
this.propagateParameterToSignaturePaths(scopeNode);
|
|
2249
2314
|
fillInSchemaGapsAndUnknowns(scopeNode, fillInUnknowns);
|
|
2250
2315
|
if (final) {
|
|
2251
2316
|
for (const manager of this.equivalencyManagers) {
|
|
@@ -2257,6 +2322,85 @@ export class ScopeDataStructure {
|
|
|
2257
2322
|
ensureSchemaConsistency(scopeNode.schema);
|
|
2258
2323
|
}
|
|
2259
2324
|
}
|
|
2325
|
+
/**
|
|
2326
|
+
* For each equivalency where a simple variable maps to signature[N],
|
|
2327
|
+
* ensure all sub-paths of that variable are reflected under signature[N].
|
|
2328
|
+
*/
|
|
2329
|
+
propagateParameterToSignaturePaths(scopeNode) {
|
|
2330
|
+
// Helper: check if a type is a concrete scalar that cannot have sub-properties.
|
|
2331
|
+
const SCALAR_TYPES = new Set([
|
|
2332
|
+
'string',
|
|
2333
|
+
'number',
|
|
2334
|
+
'boolean',
|
|
2335
|
+
'bigint',
|
|
2336
|
+
'symbol',
|
|
2337
|
+
'void',
|
|
2338
|
+
'never',
|
|
2339
|
+
]);
|
|
2340
|
+
const isDefinitelyScalar = (type) => {
|
|
2341
|
+
const parts = type.split('|').map((s) => s.trim());
|
|
2342
|
+
const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
|
|
2343
|
+
return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
|
|
2344
|
+
};
|
|
2345
|
+
// Find variable → signature[N] equivalencies
|
|
2346
|
+
for (const [varName, equivalencies] of Object.entries(scopeNode.equivalencies)) {
|
|
2347
|
+
// Only process simple variable names (no dots, brackets, or parens)
|
|
2348
|
+
if (varName.includes('.') ||
|
|
2349
|
+
varName.includes('[') ||
|
|
2350
|
+
varName.includes('(')) {
|
|
2351
|
+
continue;
|
|
2352
|
+
}
|
|
2353
|
+
for (const equiv of equivalencies) {
|
|
2354
|
+
if (equiv.scopeNodeName === scopeNode.name &&
|
|
2355
|
+
equiv.schemaPath.startsWith('signature[')) {
|
|
2356
|
+
const signaturePath = equiv.schemaPath;
|
|
2357
|
+
const varPrefix = varName + '.';
|
|
2358
|
+
const varBracketPrefix = varName + '[';
|
|
2359
|
+
// Find all schema keys starting with the variable
|
|
2360
|
+
for (const key in scopeNode.schema) {
|
|
2361
|
+
if (key.startsWith(varPrefix) || key.startsWith(varBracketPrefix)) {
|
|
2362
|
+
const suffix = key.slice(varName.length);
|
|
2363
|
+
const sigKey = signaturePath + suffix;
|
|
2364
|
+
// Only add if the signature path doesn't already exist
|
|
2365
|
+
if (!scopeNode.schema[sigKey]) {
|
|
2366
|
+
// Check if this path represents variable conflation:
|
|
2367
|
+
// When a standalone variable (e.g., showWorkoutForm from useState)
|
|
2368
|
+
// appears as a sub-property of a scalar-typed ancestor (e.g.,
|
|
2369
|
+
// activity_type = "string"), it's from scope conflation, not real
|
|
2370
|
+
// property access. Block these while allowing legitimate built-in
|
|
2371
|
+
// accesses like string.length or string.slice.
|
|
2372
|
+
let isConflatedPath = false;
|
|
2373
|
+
let checkPos = signaturePath.length;
|
|
2374
|
+
while (true) {
|
|
2375
|
+
checkPos = sigKey.indexOf('.', checkPos + 1);
|
|
2376
|
+
if (checkPos === -1)
|
|
2377
|
+
break;
|
|
2378
|
+
const ancestorPath = sigKey.substring(0, checkPos);
|
|
2379
|
+
const ancestorType = scopeNode.schema[ancestorPath];
|
|
2380
|
+
if (ancestorType && isDefinitelyScalar(ancestorType)) {
|
|
2381
|
+
// Ancestor is scalar — check if the immediate sub-property
|
|
2382
|
+
// is also a standalone variable (indicating conflation)
|
|
2383
|
+
const afterDot = sigKey.substring(checkPos + 1);
|
|
2384
|
+
const nextSep = afterDot.search(/[.\[]/);
|
|
2385
|
+
const subPropName = nextSep === -1
|
|
2386
|
+
? afterDot
|
|
2387
|
+
: afterDot.substring(0, nextSep);
|
|
2388
|
+
if (scopeNode.schema[subPropName] !== undefined) {
|
|
2389
|
+
isConflatedPath = true;
|
|
2390
|
+
break;
|
|
2391
|
+
}
|
|
2392
|
+
}
|
|
2393
|
+
}
|
|
2394
|
+
if (!isConflatedPath) {
|
|
2395
|
+
scopeNode.schema[sigKey] = scopeNode.schema[key];
|
|
2396
|
+
}
|
|
2397
|
+
}
|
|
2398
|
+
}
|
|
2399
|
+
}
|
|
2400
|
+
}
|
|
2401
|
+
}
|
|
2402
|
+
}
|
|
2403
|
+
}
|
|
2260
2404
|
filterAndConvertSchema({ filterPath, newPath, schema, }) {
|
|
2261
2405
|
const filterPathParts = this.splitPath(filterPath);
|
|
2262
2406
|
return Object.keys(schema).reduce((acc, key) => {
|
|
@@ -2316,6 +2460,10 @@ export class ScopeDataStructure {
|
|
|
2316
2460
|
path,
|
|
2317
2461
|
...this.splitPath(key).slice(equivalentValueSchemaPathParts.length),
|
|
2318
2462
|
]);
|
|
2463
|
+
// PERF: Skip keys with repeated function-call signature patterns
|
|
2464
|
+
// to prevent recursive type expansion (e.g., string.localeCompare returns string)
|
|
2465
|
+
if (this.hasExcessivePatternRepetition(newKey))
|
|
2466
|
+
continue;
|
|
2319
2467
|
resolvedSchema[newKey] = value;
|
|
2320
2468
|
}
|
|
2321
2469
|
}
|
|
@@ -2337,6 +2485,9 @@ export class ScopeDataStructure {
|
|
|
2337
2485
|
if (!subSchema)
|
|
2338
2486
|
continue;
|
|
2339
2487
|
for (const resolvedKey in subSchema) {
|
|
2488
|
+
// PERF: Skip keys with repeated function-call signature patterns
|
|
2489
|
+
if (this.hasExcessivePatternRepetition(resolvedKey))
|
|
2490
|
+
continue;
|
|
2340
2491
|
if (!resolvedSchema[resolvedKey] ||
|
|
2341
2492
|
subSchema[resolvedKey] === 'unknown') {
|
|
2342
2493
|
resolvedSchema[resolvedKey] = subSchema[resolvedKey];
|
|
@@ -2623,21 +2774,91 @@ export class ScopeDataStructure {
|
|
|
2623
2774
|
}
|
|
2624
2775
|
return [source];
|
|
2625
2776
|
};
|
|
2626
|
-
|
|
2777
|
+
const acc = entries.reduce((result, entry) => {
|
|
2627
2778
|
var _a;
|
|
2628
2779
|
if (entry.sourceCandidates.length === 0)
|
|
2629
|
-
return
|
|
2780
|
+
return result;
|
|
2630
2781
|
const usages = entry.usages.filter(usageMatchesScope);
|
|
2631
2782
|
for (const usage of usages) {
|
|
2632
|
-
|
|
2783
|
+
result[_a = usage.schemaPath] || (result[_a] = []);
|
|
2633
2784
|
// Resolve each source candidate through the equivalency chain
|
|
2634
2785
|
for (const source of entry.sourceCandidates) {
|
|
2635
2786
|
const resolvedSources = resolveToSignature(source, new Set());
|
|
2636
|
-
|
|
2787
|
+
result[usage.schemaPath].push(...resolvedSources);
|
|
2637
2788
|
}
|
|
2638
2789
|
}
|
|
2639
|
-
return
|
|
2790
|
+
return result;
|
|
2640
2791
|
}, {});
|
|
2792
|
+
// Post-processing: enrich useState-backed sources with co-located external
|
|
2793
|
+
// function calls. When a useState value resolves to a setter variable that
|
|
2794
|
+
// lives in the same scope as a fetch/API call, that fetch is a data source.
|
|
2795
|
+
this.enrichUseStateSourcesWithCoLocatedCalls(acc);
|
|
2796
|
+
return acc;
|
|
2797
|
+
}
|
|
2798
|
+
/**
|
|
2799
|
+
* For each source that ends at a useState path, check if the setter was called
|
|
2800
|
+
* from a scope that also contains external function calls (like fetch).
|
|
2801
|
+
* If so, add those external calls as additional source candidates.
|
|
2802
|
+
*/
|
|
2803
|
+
enrichUseStateSourcesWithCoLocatedCalls(acc) {
|
|
2804
|
+
const rootScopeName = this.scopeTreeManager.getRootName();
|
|
2805
|
+
const rootScope = this.scopeNodes[rootScopeName];
|
|
2806
|
+
if (!rootScope)
|
|
2807
|
+
return;
|
|
2808
|
+
// Collect all descendants for each scope node
|
|
2809
|
+
const getAllDescendants = (node) => {
|
|
2810
|
+
const names = new Set([node.name]);
|
|
2811
|
+
for (const child of node.children) {
|
|
2812
|
+
for (const name of getAllDescendants(child)) {
|
|
2813
|
+
names.add(name);
|
|
2814
|
+
}
|
|
2815
|
+
}
|
|
2816
|
+
return names;
|
|
2817
|
+
};
|
|
2818
|
+
for (const [usagePath, sources] of Object.entries(acc)) {
|
|
2819
|
+
const additionalSources = [];
|
|
2820
|
+
for (const source of sources) {
|
|
2821
|
+
// Check if this source is a useState-related terminal path
|
|
2822
|
+
// (e.g., useState(X).functionCallReturnValue[1] or useState(X).signature[0])
|
|
2823
|
+
if (!source.schemaPath.match(/^useState\([^)]*\)\./))
|
|
2824
|
+
continue;
|
|
2825
|
+
// Find the useState call from the source path
|
|
2826
|
+
const useStateCallMatch = source.schemaPath.match(/^(useState\([^)]*\))\./);
|
|
2827
|
+
if (!useStateCallMatch)
|
|
2828
|
+
continue;
|
|
2829
|
+
const useStateCall = useStateCallMatch[1];
|
|
2830
|
+
// Look in the root scope for the useState value equivalency
|
|
2831
|
+
// which tells us where the setter was called from
|
|
2832
|
+
const valuePath = `${useStateCall}.functionCallReturnValue[0]`;
|
|
2833
|
+
const valueEquivs = rootScope.equivalencies[valuePath];
|
|
2834
|
+
if (!valueEquivs)
|
|
2835
|
+
continue;
|
|
2836
|
+
for (const equiv of valueEquivs) {
|
|
2837
|
+
// Find the scope where the setter was called
|
|
2838
|
+
const setterScopeName = equiv.scopeNodeName;
|
|
2839
|
+
const setterScopeTree = this.scopeTreeManager.findNode(setterScopeName);
|
|
2840
|
+
if (!setterScopeTree)
|
|
2841
|
+
continue;
|
|
2842
|
+
// Get all descendant scope names from the setter scope
|
|
2843
|
+
const relatedScopes = getAllDescendants(setterScopeTree);
|
|
2844
|
+
// Find external function calls in those scopes whose return values
|
|
2845
|
+
// are actually consumed (assigned to a variable). This excludes
|
|
2846
|
+
// fire-and-forget calls like analytics.track() or console.log().
|
|
2847
|
+
const coLocatedCalls = this.externalFunctionCalls.filter((efc) => relatedScopes.has(efc.callScope) &&
|
|
2848
|
+
efc.receivingVariableNames &&
|
|
2849
|
+
efc.receivingVariableNames.length > 0);
|
|
2850
|
+
for (const call of coLocatedCalls) {
|
|
2851
|
+
additionalSources.push({
|
|
2852
|
+
scopeNodeName: call.callScope,
|
|
2853
|
+
schemaPath: `${call.callSignature}.functionCallReturnValue`,
|
|
2854
|
+
});
|
|
2855
|
+
}
|
|
2856
|
+
}
|
|
2857
|
+
}
|
|
2858
|
+
if (additionalSources.length > 0) {
|
|
2859
|
+
acc[usagePath].push(...additionalSources);
|
|
2860
|
+
}
|
|
2861
|
+
}
|
|
2641
2862
|
}
|
|
2642
2863
|
getUsageEquivalencies(functionName) {
|
|
2643
2864
|
const scopeNode = this.getScopeOrFunctionCallInfo(functionName);
|
|
@@ -2702,6 +2923,66 @@ export class ScopeDataStructure {
|
|
|
2702
2923
|
}
|
|
2703
2924
|
}
|
|
2704
2925
|
}
|
|
2926
|
+
// Enrich schema with deeply nested paths from internal function call scopes.
|
|
2927
|
+
// When a function call like traverse(tree) exists, and traverse's scope has
|
|
2928
|
+
// signature[0].children[path][entityName] (from propagateParameterToSignaturePaths),
|
|
2929
|
+
// we need to map those paths back to the argument variable (tree) in this scope.
|
|
2930
|
+
// This handles cases where cycle detection prevented the equivalency chain from
|
|
2931
|
+
// propagating deep paths during Phase 2 batch queue processing.
|
|
2932
|
+
for (const equivalenceKey in equivalencies ?? {}) {
|
|
2933
|
+
// Look for keys matching function call pattern: funcName(...).signature[N]
|
|
2934
|
+
const funcCallMatch = equivalenceKey.match(/^([^(]+)\(.*?\)\.(signature\[\d+\])$/);
|
|
2935
|
+
if (!funcCallMatch)
|
|
2936
|
+
continue;
|
|
2937
|
+
const calledFunctionName = funcCallMatch[1];
|
|
2938
|
+
const signatureParam = funcCallMatch[2]; // e.g., "signature[0]"
|
|
2939
|
+
for (const equivalenceValue of equivalencies[equivalenceKey]) {
|
|
2940
|
+
if (equivalenceValue.scopeNodeName !== scopeName)
|
|
2941
|
+
continue;
|
|
2942
|
+
const targetVariable = equivalenceValue.schemaPath;
|
|
2943
|
+
// Get the called function's schema (includes propagated parameter paths)
|
|
2944
|
+
const childSchema = this.getSchema({
|
|
2945
|
+
scopeName: calledFunctionName,
|
|
2946
|
+
});
|
|
2947
|
+
if (!childSchema)
|
|
2948
|
+
continue;
|
|
2949
|
+
// Map child function's signature paths to parent variable paths
|
|
2950
|
+
const sigPrefix = signatureParam + '.';
|
|
2951
|
+
const sigBracketPrefix = signatureParam + '[';
|
|
2952
|
+
for (const childKey in childSchema) {
|
|
2953
|
+
let suffix = null;
|
|
2954
|
+
if (childKey.startsWith(sigPrefix)) {
|
|
2955
|
+
suffix = childKey.slice(signatureParam.length);
|
|
2956
|
+
}
|
|
2957
|
+
else if (childKey.startsWith(sigBracketPrefix)) {
|
|
2958
|
+
suffix = childKey.slice(signatureParam.length);
|
|
2959
|
+
}
|
|
2960
|
+
if (suffix !== null) {
|
|
2961
|
+
const parentKey = targetVariable + suffix;
|
|
2962
|
+
if (!schema[parentKey]) {
|
|
2963
|
+
schema[parentKey] = childSchema[childKey];
|
|
2964
|
+
}
|
|
2965
|
+
}
|
|
2966
|
+
}
|
|
2967
|
+
}
|
|
2968
|
+
}
|
|
2969
|
+
// Helper: check if a type is a concrete scalar that cannot have sub-properties.
|
|
2970
|
+
// e.g., "string", "number | undefined", "boolean | null" are scalar.
|
|
2971
|
+
// "object", "array", "function", "unknown", "Workout", etc. are NOT scalar.
|
|
2972
|
+
const SCALAR_TYPES = new Set([
|
|
2973
|
+
'string',
|
|
2974
|
+
'number',
|
|
2975
|
+
'boolean',
|
|
2976
|
+
'bigint',
|
|
2977
|
+
'symbol',
|
|
2978
|
+
'void',
|
|
2979
|
+
'never',
|
|
2980
|
+
]);
|
|
2981
|
+
const isDefinitelyScalarType = (type) => {
|
|
2982
|
+
const parts = type.split('|').map((s) => s.trim());
|
|
2983
|
+
const base = parts.filter((s) => s !== 'undefined' && s !== 'null');
|
|
2984
|
+
return base.length > 0 && base.every((b) => SCALAR_TYPES.has(b));
|
|
2985
|
+
};
|
|
2705
2986
|
// Propagate nested paths from variables to their signature equivalents
|
|
2706
2987
|
// e.g., if workouts = signature[0].workouts, then workouts[].title becomes
|
|
2707
2988
|
// signature[0].workouts[].title
|
|
@@ -2721,7 +3002,67 @@ export class ScopeDataStructure {
|
|
|
2721
3002
|
const signatureKey = signaturePath + suffix;
|
|
2722
3003
|
// Add to schema if not already present
|
|
2723
3004
|
if (!tempScopeNode.schema[signatureKey]) {
|
|
2724
|
-
|
|
3005
|
+
// Check if this path represents variable conflation:
|
|
3006
|
+
// When a standalone variable (e.g., showWorkoutForm from useState)
|
|
3007
|
+
// appears as a sub-property of a scalar-typed ancestor (e.g.,
|
|
3008
|
+
// activity_type = "string"), it's from scope conflation, not real
|
|
3009
|
+
// property access. Block these while allowing legitimate built-in
|
|
3010
|
+
// accesses like string.length or string.slice.
|
|
3011
|
+
let isConflatedPath = false;
|
|
3012
|
+
let checkPos = signaturePath.length;
|
|
3013
|
+
while (true) {
|
|
3014
|
+
checkPos = signatureKey.indexOf('.', checkPos + 1);
|
|
3015
|
+
if (checkPos === -1)
|
|
3016
|
+
break;
|
|
3017
|
+
const ancestorPath = signatureKey.substring(0, checkPos);
|
|
3018
|
+
const ancestorType = tempScopeNode.schema[ancestorPath];
|
|
3019
|
+
if (ancestorType && isDefinitelyScalarType(ancestorType)) {
|
|
3020
|
+
// Ancestor is scalar — check if the immediate sub-property
|
|
3021
|
+
// is also a standalone variable (indicating conflation)
|
|
3022
|
+
const afterDot = signatureKey.substring(checkPos + 1);
|
|
3023
|
+
const nextSep = afterDot.search(/[.\[]/);
|
|
3024
|
+
const subPropName = nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
|
|
3025
|
+
if (schema[subPropName] !== undefined) {
|
|
3026
|
+
isConflatedPath = true;
|
|
3027
|
+
break;
|
|
3028
|
+
}
|
|
3029
|
+
}
|
|
3030
|
+
}
|
|
3031
|
+
if (!isConflatedPath) {
|
|
3032
|
+
tempScopeNode.schema[signatureKey] = schema[schemaKey];
|
|
3033
|
+
}
|
|
3034
|
+
}
|
|
3035
|
+
}
|
|
3036
|
+
}
|
|
3037
|
+
}
|
|
3038
|
+
// Post-process: filter out conflated signature paths.
|
|
3039
|
+
// During phase 2 scope analysis, useState(false) conflation can create
|
|
3040
|
+
// bad paths like signature[0].mockWorkouts[].activity_type.showWorkoutForm
|
|
3041
|
+
// directly in scopeNode.schema. These flow through signatureInSchema into
|
|
3042
|
+
// tempScopeNode.schema without any guard. Filter them out here by checking:
|
|
3043
|
+
// 1. An ancestor in the path has a concrete scalar type (string, number, boolean, etc.)
|
|
3044
|
+
// 2. The immediate sub-property of that scalar ancestor is also a standalone
|
|
3045
|
+
// variable in the schema (indicating conflation, not a real property access)
|
|
3046
|
+
for (const key of Object.keys(tempScopeNode.schema)) {
|
|
3047
|
+
if (!key.startsWith('signature['))
|
|
3048
|
+
continue;
|
|
3049
|
+
// Walk through the path looking for scalar-typed ancestors
|
|
3050
|
+
let pos = 0;
|
|
3051
|
+
while (true) {
|
|
3052
|
+
pos = key.indexOf('.', pos + 1);
|
|
3053
|
+
if (pos === -1)
|
|
3054
|
+
break;
|
|
3055
|
+
const ancestorPath = key.substring(0, pos);
|
|
3056
|
+
const ancestorType = tempScopeNode.schema[ancestorPath];
|
|
3057
|
+
if (ancestorType && isDefinitelyScalarType(ancestorType)) {
|
|
3058
|
+
// Found a scalar ancestor — check if the sub-property name
|
|
3059
|
+
// is a standalone variable in the getSchema() result
|
|
3060
|
+
const afterDot = key.substring(pos + 1);
|
|
3061
|
+
const nextSep = afterDot.search(/[.\[]/);
|
|
3062
|
+
const subPropName = nextSep === -1 ? afterDot : afterDot.substring(0, nextSep);
|
|
3063
|
+
if (schema[subPropName] !== undefined) {
|
|
3064
|
+
delete tempScopeNode.schema[key];
|
|
3065
|
+
break;
|
|
2725
3066
|
}
|
|
2726
3067
|
}
|
|
2727
3068
|
}
|
|
@@ -2991,6 +3332,13 @@ export class ScopeDataStructure {
|
|
|
2991
3332
|
!equivalentValue.schemaPath.startsWith('signature[') && // not a signature path
|
|
2992
3333
|
!equivalentValue.schemaPath.endsWith('.functionCallReturnValue') // not already handled above
|
|
2993
3334
|
) {
|
|
3335
|
+
// Skip bare "returnValue" from child scopes — this is the child's return value,
|
|
3336
|
+
// not a meaningful data source path in the parent scope
|
|
3337
|
+
if (equivalentValue.schemaPath === 'returnValue' &&
|
|
3338
|
+
equivalentValue.scopeNodeName !==
|
|
3339
|
+
this.scopeTreeManager.getRootName()) {
|
|
3340
|
+
continue;
|
|
3341
|
+
}
|
|
2994
3342
|
// Add equivalency (will accumulate if multiple values for OR expressions)
|
|
2995
3343
|
addEquivalency(path, equivalentValue.schemaPath);
|
|
2996
3344
|
}
|
|
@@ -3329,7 +3677,95 @@ export class ScopeDataStructure {
|
|
|
3329
3677
|
// Replace cyScope placeholders in all external function call data
|
|
3330
3678
|
// This ensures call signatures and schema paths use actual callback text
|
|
3331
3679
|
// instead of internal cyScope names, preventing mock data merge conflicts.
|
|
3332
|
-
|
|
3680
|
+
const rootScopeName = this.scopeTreeManager.getRootName();
|
|
3681
|
+
const rootSchema = this.scopeNodes[rootScopeName]?.schema ?? {};
|
|
3682
|
+
return this.externalFunctionCalls.map((efc) => {
|
|
3683
|
+
const cleaned = this.cleanCyScopeFromFunctionCallInfo(efc);
|
|
3684
|
+
return this.filterConflatedExternalPaths(cleaned, rootSchema);
|
|
3685
|
+
});
|
|
3686
|
+
}
|
|
3687
|
+
/**
|
|
3688
|
+
* Filters out conflated paths from external function call schemas.
|
|
3689
|
+
*
|
|
3690
|
+
* When multiple useState(false) calls create equivalency conflation during
|
|
3691
|
+
* Phase 1 analysis, standalone boolean state variables (like showWorkoutForm,
|
|
3692
|
+
* showGoalForm) can bleed into external function call schemas as sub-properties
|
|
3693
|
+
* of unrelated data fields (like data[].activity_type.showWorkoutForm).
|
|
3694
|
+
*
|
|
3695
|
+
* Detection: group sub-properties by parent path. If 2+ sub-properties of
|
|
3696
|
+
* the same parent all match standalone root scope variable names, treat them
|
|
3697
|
+
* as conflation artifacts and remove them.
|
|
3698
|
+
*/
|
|
3699
|
+
filterConflatedExternalPaths(efc, rootSchema) {
|
|
3700
|
+
// Build a set of top-level root scope variable names (simple names, no dots/brackets)
|
|
3701
|
+
const topLevelRootVars = new Set();
|
|
3702
|
+
for (const key of Object.keys(rootSchema)) {
|
|
3703
|
+
if (!key.includes('.') && !key.includes('[')) {
|
|
3704
|
+
topLevelRootVars.add(key);
|
|
3705
|
+
}
|
|
3706
|
+
}
|
|
3707
|
+
if (topLevelRootVars.size === 0)
|
|
3708
|
+
return efc;
|
|
3709
|
+
// Group sub-property matches by their parent path.
|
|
3710
|
+
// For a path like "...data[].activity_type.showWorkoutForm",
|
|
3711
|
+
// parent = "...data[].activity_type", child = "showWorkoutForm"
|
|
3712
|
+
const parentToConflatedKeys = new Map();
|
|
3713
|
+
for (const key of Object.keys(efc.schema)) {
|
|
3714
|
+
const lastDot = key.lastIndexOf('.');
|
|
3715
|
+
if (lastDot === -1)
|
|
3716
|
+
continue;
|
|
3717
|
+
const parent = key.substring(0, lastDot);
|
|
3718
|
+
const child = key.substring(lastDot + 1);
|
|
3719
|
+
// Skip array access or function call patterns
|
|
3720
|
+
if (child.includes('[') || child.includes('('))
|
|
3721
|
+
continue;
|
|
3722
|
+
// Only consider paths inside array element chains (contains []).
|
|
3723
|
+
// Direct children of functionCallReturnValue are legitimate destructured
|
|
3724
|
+
// return values, not conflation. Conflation happens deeper in the chain
|
|
3725
|
+
// when array element fields get corrupted sub-properties.
|
|
3726
|
+
if (!parent.includes('['))
|
|
3727
|
+
continue;
|
|
3728
|
+
if (topLevelRootVars.has(child)) {
|
|
3729
|
+
if (!parentToConflatedKeys.has(parent)) {
|
|
3730
|
+
parentToConflatedKeys.set(parent, []);
|
|
3731
|
+
}
|
|
3732
|
+
parentToConflatedKeys.get(parent).push(key);
|
|
3733
|
+
}
|
|
3734
|
+
}
|
|
3735
|
+
// Only filter when 2+ sub-properties of the same parent match root scope vars.
|
|
3736
|
+
// This threshold avoids false positives from coincidental name matches.
|
|
3737
|
+
const keysToRemove = new Set();
|
|
3738
|
+
const parentsToRestore = new Set();
|
|
3739
|
+
for (const [parent, conflatedKeys] of parentToConflatedKeys) {
|
|
3740
|
+
if (conflatedKeys.length >= 2) {
|
|
3741
|
+
for (const key of conflatedKeys) {
|
|
3742
|
+
keysToRemove.add(key);
|
|
3743
|
+
}
|
|
3744
|
+
parentsToRestore.add(parent);
|
|
3745
|
+
}
|
|
3746
|
+
}
|
|
3747
|
+
if (keysToRemove.size === 0)
|
|
3748
|
+
return efc;
|
|
3749
|
+
// Create a new schema without the conflated paths
|
|
3750
|
+
const newSchema = {};
|
|
3751
|
+
for (const [key, value] of Object.entries(efc.schema)) {
|
|
3752
|
+
if (keysToRemove.has(key))
|
|
3753
|
+
continue;
|
|
3754
|
+
// Restore parent type: if it was changed to "object" because of conflated
|
|
3755
|
+
// sub-properties, and now all those sub-properties are removed, change it
|
|
3756
|
+
// back to "unknown" (we don't know the original type)
|
|
3757
|
+
if (parentsToRestore.has(key) && value === 'object') {
|
|
3758
|
+
// Check if there are any remaining sub-properties
|
|
3759
|
+
const hasRemainingSubProps = Object.keys(efc.schema).some((k) => !keysToRemove.has(k) &&
|
|
3760
|
+
k !== key &&
|
|
3761
|
+
(k.startsWith(key + '.') || k.startsWith(key + '[')));
|
|
3762
|
+
newSchema[key] = hasRemainingSubProps ? value : 'unknown';
|
|
3763
|
+
}
|
|
3764
|
+
else {
|
|
3765
|
+
newSchema[key] = value;
|
|
3766
|
+
}
|
|
3767
|
+
}
|
|
3768
|
+
return { ...efc, schema: newSchema };
|
|
3333
3769
|
}
|
|
3334
3770
|
/**
|
|
3335
3771
|
* Cleans cyScope placeholder references from a FunctionCallInfo.
|
|
@@ -3550,6 +3986,7 @@ export class ScopeDataStructure {
|
|
|
3550
3986
|
*/
|
|
3551
3987
|
getEnrichedConditionalUsages() {
|
|
3552
3988
|
const enriched = {};
|
|
3989
|
+
console.log(`[getEnrichedConditionalUsages] Processing ${Object.keys(this.rawConditionalUsages).length} conditional paths: [${Object.keys(this.rawConditionalUsages).join(', ')}]`);
|
|
3553
3990
|
for (const [path, usages] of Object.entries(this.rawConditionalUsages)) {
|
|
3554
3991
|
// Try to trace this path back to a data source
|
|
3555
3992
|
// First, try the root scope
|
|
@@ -3557,9 +3994,47 @@ export class ScopeDataStructure {
|
|
|
3557
3994
|
const explanation = this.explainPath(rootScopeName, path);
|
|
3558
3995
|
let sourceDataPath;
|
|
3559
3996
|
if (explanation.source) {
|
|
3560
|
-
|
|
3561
|
-
|
|
3997
|
+
const { scope, path: sourcePath } = explanation.source;
|
|
3998
|
+
// Build initial path — avoid redundant prefix when path already contains the scope call
|
|
3999
|
+
let fullPath;
|
|
4000
|
+
if (sourcePath.startsWith(`${scope}(`)) {
|
|
4001
|
+
fullPath = sourcePath;
|
|
4002
|
+
}
|
|
4003
|
+
else {
|
|
4004
|
+
fullPath = `${scope}.${sourcePath}`;
|
|
4005
|
+
}
|
|
4006
|
+
sourceDataPath = fullPath;
|
|
4007
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" explainPath → scope="${scope}", sourcePath="${sourcePath}" → sourceDataPath="${sourceDataPath}"`);
|
|
3562
4008
|
}
|
|
4009
|
+
else {
|
|
4010
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" explainPath → no source found`);
|
|
4011
|
+
}
|
|
4012
|
+
// If explainPath didn't find a useful external source (e.g., it traced to
|
|
4013
|
+
// useState or just to the component scope itself), check sourceEquivalencies
|
|
4014
|
+
// for an external function call source like a fetch call
|
|
4015
|
+
const hasExternalSource = sourceDataPath?.includes('.functionCallReturnValue');
|
|
4016
|
+
if (!hasExternalSource) {
|
|
4017
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" no external source (sourceDataPath="${sourceDataPath}"), checking sourceEquivalencies fallback...`);
|
|
4018
|
+
const sourceEquiv = this.getSourceEquivalencies();
|
|
4019
|
+
const returnValueKey = `returnValue.${path}`;
|
|
4020
|
+
const sources = sourceEquiv[returnValueKey];
|
|
4021
|
+
if (sources) {
|
|
4022
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies["${returnValueKey}"] has ${sources.length} sources: [${sources.map((s) => s.schemaPath).join(', ')}]`);
|
|
4023
|
+
const externalSource = sources.find((s) => s.schemaPath.includes('.functionCallReturnValue') &&
|
|
4024
|
+
!s.schemaPath.startsWith('useState('));
|
|
4025
|
+
if (externalSource) {
|
|
4026
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies fallback found external source: "${externalSource.schemaPath}"`);
|
|
4027
|
+
sourceDataPath = externalSource.schemaPath;
|
|
4028
|
+
}
|
|
4029
|
+
else {
|
|
4030
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies fallback found no external function call source`);
|
|
4031
|
+
}
|
|
4032
|
+
}
|
|
4033
|
+
else {
|
|
4034
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" sourceEquivalencies["${returnValueKey}"] not found`);
|
|
4035
|
+
}
|
|
4036
|
+
}
|
|
4037
|
+
console.log(`[getEnrichedConditionalUsages] "${path}" FINAL sourceDataPath="${sourceDataPath ?? '(none)'}" (${usages.length} usages)`);
|
|
3563
4038
|
enriched[path] = usages.map((usage) => ({
|
|
3564
4039
|
...usage,
|
|
3565
4040
|
sourceDataPath,
|
|
@@ -3818,11 +4293,21 @@ export class ScopeDataStructure {
|
|
|
3818
4293
|
perVariableSchemas = undefined;
|
|
3819
4294
|
}
|
|
3820
4295
|
}
|
|
4296
|
+
// Enrich the schema with inferred types by applying fillInSchemaGapsAndUnknowns.
|
|
4297
|
+
// This ensures the serialized schema has the same type inference as getReturnValue().
|
|
4298
|
+
// Without this, evidence like "entities[].analyses: array" becomes "unknown".
|
|
4299
|
+
const enrichedSchema = { ...efc.schema };
|
|
4300
|
+
const tempScopeNode = {
|
|
4301
|
+
name: efc.name,
|
|
4302
|
+
schema: enrichedSchema,
|
|
4303
|
+
equivalencies: efc.equivalencies ?? {},
|
|
4304
|
+
};
|
|
4305
|
+
fillInSchemaGapsAndUnknowns(tempScopeNode, true);
|
|
3821
4306
|
return {
|
|
3822
4307
|
name: efc.name,
|
|
3823
4308
|
callSignature: efc.callSignature,
|
|
3824
4309
|
callScope: efc.callScope,
|
|
3825
|
-
schema:
|
|
4310
|
+
schema: enrichedSchema,
|
|
3826
4311
|
equivalencies: efc.equivalencies
|
|
3827
4312
|
? Object.entries(efc.equivalencies).reduce((acc, [key, vars]) => {
|
|
3828
4313
|
// Clean cyScope from the key as well as variable properties
|