@codeyam/codeyam-cli 0.1.0-staging.a890816 → 0.1.0-staging.aa28063
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/analyzer-template/.build-info.json +8 -8
- package/analyzer-template/log.txt +3 -3
- package/analyzer-template/package.json +12 -12
- package/analyzer-template/packages/ai/package.json +2 -2
- package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +135 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/nodeToSource.ts +19 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +11 -4
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +36 -9
- package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +10 -3
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +16 -6
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +0 -33
- package/analyzer-template/packages/analyze/index.ts +4 -1
- package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +13 -7
- package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +28 -2
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +5 -36
- package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +10 -6
- package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +9 -12
- package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +21 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +82 -10
- package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +4 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +4 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +8 -3
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +239 -58
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1684 -1462
- package/analyzer-template/packages/aws/package.json +7 -7
- package/analyzer-template/packages/database/package.json +4 -4
- package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +102 -0
- package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +25 -15
- package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
- package/analyzer-template/packages/database/src/lib/loadEntity.ts +19 -8
- package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +0 -65
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +9 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +104 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +7 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +4 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +5 -5
- package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.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 +0 -25
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.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/package.json +1 -1
- package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -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/utils/src/lib/fs/rsyncCopy.d.ts +3 -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 +22 -1
- 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 +27 -0
- package/analyzer-template/project/analyzeFileEntities.ts +26 -0
- package/analyzer-template/project/runMultiScenarioServer.ts +26 -3
- package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
- package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
- package/background/src/lib/virtualized/project/runMultiScenarioServer.js +23 -3
- package/background/src/lib/virtualized/project/runMultiScenarioServer.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 +24 -0
- package/codeyam-cli/src/cli.js.map +1 -1
- package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js +47 -0
- package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js.map +1 -0
- package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js +71 -0
- package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js.map +1 -0
- package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js +30 -0
- package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js.map +1 -0
- package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
- package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
- package/codeyam-cli/src/commands/__tests__/editor.statePersistence.test.js +55 -0
- package/codeyam-cli/src/commands/__tests__/editor.statePersistence.test.js.map +1 -0
- package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
- package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
- package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +137 -47
- package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +3 -46
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/editor.js +5802 -526
- package/codeyam-cli/src/commands/editor.js.map +1 -1
- package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js +23 -0
- package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js.map +1 -0
- package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
- package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
- package/codeyam-cli/src/commands/init.js +95 -35
- package/codeyam-cli/src/commands/init.js.map +1 -1
- package/codeyam-cli/src/commands/telemetry.js +37 -0
- package/codeyam-cli/src/commands/telemetry.js.map +1 -0
- package/codeyam-cli/src/data/designSystems.js +27 -0
- package/codeyam-cli/src/data/designSystems.js.map +1 -0
- 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__/analyzerFinalization.test.js +173 -0
- package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.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 +181 -0
- package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +4160 -0
- package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
- package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.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__/editorCaptureScenarioSeeding.test.js +137 -0
- package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
- package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.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 +194 -0
- package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
- package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
- package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.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 +594 -0
- package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
- package/codeyam-cli/src/utils/__tests__/editorMigration.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 +361 -0
- package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +250 -0
- package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorRoadmap.test.js +1108 -0
- package/codeyam-cli/src/utils/__tests__/editorRoadmap.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 +411 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1768 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +413 -0
- package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
- package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
- package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
- package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2121 -0
- package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/envFile.test.js +125 -0
- package/codeyam-cli/src/utils/__tests__/envFile.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__/glossaryAdd.test.js +177 -0
- package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/handoffContext.test.js +500 -0
- package/codeyam-cli/src/utils/__tests__/handoffContext.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
- package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js +302 -0
- package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
- package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
- 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__/registerScenarioResult.test.js +127 -0
- package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
- package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -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 +672 -0
- package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
- package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +26 -5
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
- package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
- 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__/testRunner.test.js +216 -0
- package/codeyam-cli/src/utils/__tests__/testRunner.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +148 -0
- package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
- package/codeyam-cli/src/utils/analysisRunner.js +39 -8
- package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
- package/codeyam-cli/src/utils/analyzer.js +19 -0
- package/codeyam-cli/src/utils/analyzer.js.map +1 -1
- package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
- package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
- package/codeyam-cli/src/utils/backgroundServer.js +95 -19
- 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/database.js +37 -2
- package/codeyam-cli/src/utils/database.js.map +1 -1
- package/codeyam-cli/src/utils/designSystemShowcase.js +810 -0
- package/codeyam-cli/src/utils/designSystemShowcase.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 +95 -0
- package/codeyam-cli/src/utils/editorApi.js.map +1 -0
- package/codeyam-cli/src/utils/editorAudit.js +849 -0
- package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
- package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
- package/codeyam-cli/src/utils/editorBroadcastViewport.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/editorDeleteScenario.js +67 -0
- package/codeyam-cli/src/utils/editorDeleteScenario.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 +50 -0
- package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
- package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
- package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
- package/codeyam-cli/src/utils/editorGuard.js +36 -0
- package/codeyam-cli/src/utils/editorGuard.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 +152 -0
- package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
- package/codeyam-cli/src/utils/editorMigration.js +224 -0
- package/codeyam-cli/src/utils/editorMigration.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 +139 -0
- package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
- package/codeyam-cli/src/utils/editorRecapture.js +109 -0
- package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
- package/codeyam-cli/src/utils/editorRoadmap.js +574 -0
- package/codeyam-cli/src/utils/editorRoadmap.js.map +1 -0
- package/codeyam-cli/src/utils/editorScenarioSwitch.js +149 -0
- package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
- package/codeyam-cli/src/utils/editorScenarios.js +687 -0
- package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
- package/codeyam-cli/src/utils/editorSeedAdapter.js +475 -0
- package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
- package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
- package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
- package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
- package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
- package/codeyam-cli/src/utils/entityChangeStatus.server.js +227 -0
- package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
- package/codeyam-cli/src/utils/envFile.js +90 -0
- package/codeyam-cli/src/utils/envFile.js.map +1 -0
- package/codeyam-cli/src/utils/fileWatcher.js +38 -0
- package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
- package/codeyam-cli/src/utils/git.js +51 -0
- package/codeyam-cli/src/utils/git.js.map +1 -1
- package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
- package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
- package/codeyam-cli/src/utils/handoffContext.js +257 -0
- package/codeyam-cli/src/utils/handoffContext.js.map +1 -0
- package/codeyam-cli/src/utils/install-skills.js +78 -23
- package/codeyam-cli/src/utils/install-skills.js.map +1 -1
- package/codeyam-cli/src/utils/manualEntityAnalysis.js +196 -0
- package/codeyam-cli/src/utils/manualEntityAnalysis.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/progress.js +2 -2
- 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__/job.interactiveStart.test.js +159 -0
- package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js.map +1 -0
- package/codeyam-cli/src/utils/queue/job.js +35 -6
- package/codeyam-cli/src/utils/queue/job.js.map +1 -1
- package/codeyam-cli/src/utils/registerScenarioResult.js +52 -0
- package/codeyam-cli/src/utils/registerScenarioResult.js.map +1 -0
- package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
- package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
- package/codeyam-cli/src/utils/scenarioCoverage.js +77 -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 +313 -0
- package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
- package/codeyam-cli/src/utils/screenshotHash.js +26 -0
- package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
- package/codeyam-cli/src/utils/serverState.js +30 -0
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +47 -16
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
- package/codeyam-cli/src/utils/simulationGateMiddleware.js +17 -1
- package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -1
- package/codeyam-cli/src/utils/slugUtils.js +25 -0
- package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
- package/codeyam-cli/src/utils/syncMocksMiddleware.js +2 -2
- package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
- package/codeyam-cli/src/utils/techStackConfig.js +38 -0
- package/codeyam-cli/src/utils/techStackConfig.js.map +1 -0
- package/codeyam-cli/src/utils/techStackConfig.test.js +85 -0
- package/codeyam-cli/src/utils/techStackConfig.test.js.map +1 -0
- package/codeyam-cli/src/utils/telemetry.js +106 -0
- package/codeyam-cli/src/utils/telemetry.js.map +1 -0
- package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
- package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
- package/codeyam-cli/src/utils/testResultCache.js +53 -0
- package/codeyam-cli/src/utils/testResultCache.js.map +1 -0
- package/codeyam-cli/src/utils/testResultCache.server.js +81 -0
- package/codeyam-cli/src/utils/testResultCache.server.js.map +1 -0
- package/codeyam-cli/src/utils/testResultCache.server.test.js +187 -0
- package/codeyam-cli/src/utils/testResultCache.server.test.js.map +1 -0
- package/codeyam-cli/src/utils/testResultCache.test.js +230 -0
- package/codeyam-cli/src/utils/testResultCache.test.js.map +1 -0
- package/codeyam-cli/src/utils/testRunner.js +194 -2
- package/codeyam-cli/src/utils/testRunner.js.map +1 -1
- package/codeyam-cli/src/utils/webappDetection.js +25 -2
- package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
- package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js +99 -0
- package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js.map +1 -0
- package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +129 -0
- package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
- package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
- package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
- package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +762 -0
- package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
- package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +315 -0
- package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
- package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
- package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
- package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
- package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
- package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
- package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js +34 -0
- package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js.map +1 -0
- package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
- package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
- package/codeyam-cli/src/webserver/backgroundServer.js +60 -61
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/CopyButton-DTBZZfSk.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-C76mRRiF.js → EntityItem-BxclONWq.js} +5 -5
- package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-CobE682z.js → EntityTypeIcon-BsnEOJZ_.js} +9 -9
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-ByaELMbv.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-6WjVfhxX.js +25 -0
- package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-ChX-Hp7W.js +3 -0
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BU_OAEMP.js → LoadingDots-By5zI316.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-ceAyBX-H.js → LogViewer-C-9zQdXg.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-Bs2_Oua4.js +36 -0
- package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-djPLI-WV.js → ReportIssueModal-DQsceHVv.js} +4 -4
- package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DThcm_9M.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-B76aig_2.js → ScenarioViewer-Cl4oOA3A.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/Spinner-CIil5-gb.js +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BqkA9zyZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{_index-C96V0n15.js → _index-DnOgyseQ.js} +4 -4
- package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BpKzcsJz.js → activity.(_tab)-DqM9hbNE.js} +8 -8
- 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 → addon-web-links-C58dYPwR.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
- package/codeyam-cli/src/webserver/build/client/assets/{agent-transcripts-D9hemwl6.js → agent-transcripts-B8NCeOrm.js} +7 -7
- 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-database-verify-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-github-verify-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-handoff-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-hosting-verify-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-recapture-stale-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-roadmap-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-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-prompt-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-verify-routes-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.interactive-switch-scenario-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{book-open-D_nMCFmP.js → book-open-BFSIqZgO.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-BH2h1Ea2.js → chevron-down-B9fDzFVh.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/chunk-UVKPFVEO-Bmq2apuh.js +43 -0
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-DyIKORY6.js → circle-check-DLPObLUx.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{copy-NDbZjXao.js → copy-DXEmO0TD.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BwyFiRot.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-iRhRIFlp.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/editor._tab-BZPBzV73.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DOXe0Qx7.js +161 -0
- package/codeyam-cli/src/webserver/build/client/assets/editorPreview-C6fEYHrh.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CrjR3zZW.js → entity._sha._-pc-vc6wO.js} +14 -13
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C8AyYgYT.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DziaVQX1.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-BTcpgIpC.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMvVHNXU.js → entity._sha_.edit._scenarioId-D_O_ajfZ.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-DTvKq3TY.js → entry.client-j1Vi0bco.js} +6 -6
- package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/files-kuny2Q_s.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/git-DgCZPMie.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/globals-L-aUIeux.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-BcvgDzbZ.js → index-BliGSSpl.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/index-SqjQKTdH.js +15 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-10oVnAAH.js → index-vyrZD2g4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
- package/codeyam-cli/src/webserver/build/client/assets/labs-c3yLxSEp.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BAXYRVEO.js → loader-circle-D-q28GLF.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/manifest-30c44d84.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-CEWIUC4t.js +101 -0
- package/codeyam-cli/src/webserver/build/client/assets/{pause-DTAcYxBt.js → pause-BP6fitdh.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/root-CLedrjXQ.js +80 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-fKo7v0Zo.js → search-BooqacKS.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/settings-BM0nbryO.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/simulations-ovy6FjRY.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{terminal-BG4heKCG.js → terminal-DHemCJIs.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-DtSmdtM4.js → triangle-alert-D87ekDl8.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-Dk0Tciqg.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C8QvIe05.js +2 -0
- package/codeyam-cli/src/webserver/build/client/assets/useReportContext-jkCytuYz.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/useToast-BgqkixU9.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
- package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
- package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-CuR5TvUx.js +16 -0
- package/codeyam-cli/src/webserver/build/server/assets/index-D4MWAsqb.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/init-JObA4lXD.js +14 -0
- package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-i8OXK4oL.js +765 -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/editorProxy.js +881 -52
- package/codeyam-cli/src/webserver/editorProxy.js.map +1 -1
- package/codeyam-cli/src/webserver/idleDetector.js +130 -0
- package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
- package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
- package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
- package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
- package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
- package/codeyam-cli/src/webserver/scripts/journalCapture.ts +147 -4
- package/codeyam-cli/src/webserver/server.js +281 -12
- package/codeyam-cli/src/webserver/server.js.map +1 -1
- package/codeyam-cli/src/webserver/terminalServer.js +433 -157
- package/codeyam-cli/src/webserver/terminalServer.js.map +1 -1
- package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
- package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
- package/codeyam-cli/templates/chrome-extension-react/README.md +46 -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 +27 -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 +86 -5
- package/codeyam-cli/templates/codeyam-editor-codex.md +61 -0
- package/codeyam-cli/templates/codeyam-editor-gemini.md +59 -0
- package/codeyam-cli/templates/codeyam-editor-reference.md +216 -0
- package/codeyam-cli/templates/design-systems/clean-dashboard-design-system.md +255 -0
- package/codeyam-cli/templates/design-systems/editorial-design-system.md +267 -0
- package/codeyam-cli/templates/design-systems/mono-brutalist-design-system.md +256 -0
- package/codeyam-cli/templates/design-systems/neo-brutalist-design-system.md +294 -0
- package/codeyam-cli/templates/editor-step-hook.py +262 -39
- package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +288 -0
- package/codeyam-cli/templates/expo-react-native/README.md +41 -0
- package/codeyam-cli/templates/expo-react-native/__tests__/.gitkeep +0 -0
- package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +15 -0
- package/codeyam-cli/templates/expo-react-native/app/index.tsx +36 -0
- package/codeyam-cli/templates/expo-react-native/app.json +29 -0
- package/codeyam-cli/templates/expo-react-native/babel.config.js +10 -0
- package/codeyam-cli/templates/expo-react-native/gitignore +14 -0
- package/codeyam-cli/templates/expo-react-native/global.css +10 -0
- package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
- package/codeyam-cli/templates/expo-react-native/lib/theme.ts +73 -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 +54 -0
- package/codeyam-cli/templates/expo-react-native/patches/expo-modules-autolinking+3.0.24.patch +29 -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/isolation-route/expo-router.tsx.template +54 -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/README.md +53 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +9 -4
- package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +22 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +6 -2
- package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +4 -1
- package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +140 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
- package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
- package/codeyam-cli/templates/{nextjs-prisma-sqlite/PRISMA_SETUP.md → nextjs-prisma-supabase/SUPABASE_SETUP.md} +37 -17
- 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 +37 -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/seed-adapters/supabase.ts +475 -0
- package/codeyam-cli/templates/{codeyam-dev-mode.md → skills/codeyam-dev-mode/SKILL.md} +3 -3
- package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +244 -0
- package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -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/package.json +16 -10
- package/packages/ai/src/lib/astScopes/methodSemantics.js +99 -0
- package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
- package/packages/ai/src/lib/astScopes/nodeToSource.js +16 -0
- package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -1
- package/packages/ai/src/lib/astScopes/paths.js +12 -3
- package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +27 -10
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
- package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +14 -4
- package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
- package/packages/analyze/index.js +1 -1
- package/packages/analyze/index.js.map +1 -1
- package/packages/analyze/src/lib/ProjectAnalyzer.js +10 -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/files/analyze/analyzeEntities/prepareDataStructures.js +16 -2
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +6 -26
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +3 -2
- package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +9 -7
- package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
- package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -11
- package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
- package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
- package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
- package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
- package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +120 -28
- 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 +1368 -1193
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +104 -0
- package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
- package/packages/database/src/lib/loadAnalysis.js +7 -1
- package/packages/database/src/lib/loadAnalysis.js.map +1 -1
- package/packages/database/src/lib/loadEntities.js +0 -6
- package/packages/database/src/lib/loadEntities.js.map +1 -1
- package/packages/database/src/lib/loadEntity.js +5 -5
- package/packages/database/src/lib/loadEntity.js.map +1 -1
- package/packages/database/src/lib/updateCommitMetadata.js +0 -25
- package/packages/database/src/lib/updateCommitMetadata.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 +22 -1
- package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/scripts/npm-post-install.cjs +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/CopyButton-DmJveP3T.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-g3saevPb.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DYFW3lDD.js +0 -25
- package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DLeucoVX.js +0 -3
- package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-BED4B6sP.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +0 -34
- package/codeyam-cli/src/webserver/build/client/assets/Terminal-CcG8YTLx.js +0 -41
- package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-C8OKAR5x.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-C4pqxYJB.js +0 -51
- package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CMT1jU2q.js +0 -21
- package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/editor-W_IGJ2Kd.js +0 -7
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-D6SEzMCu.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-cPo8LiG3.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/files-DO4CZ16O.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/git-CFCTYk9I.js +0 -15
- package/codeyam-cli/src/webserver/build/client/assets/globals-BZB_H1w2.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-8daa4147.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/memory-FweZHj5U.js +0 -93
- package/codeyam-cli/src/webserver/build/client/assets/root-DiRdBreB.js +0 -67
- package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/simulations-B3aOzpCZ.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-ByhSyh0W.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +0 -2
- package/codeyam-cli/src/webserver/build/client/assets/useReportContext-O-jkvSPx.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useToast-9FIWuYfK.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/xterm-DMSzMhqy.js +0 -9
- package/codeyam-cli/src/webserver/build/server/assets/index-BzAbACSx.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-OdUocH6P.js +0 -362
- package/codeyam-cli/templates/codeyam-editor.md +0 -68
- package/scripts/finalize-analyzer.cjs +0 -13
- /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
- /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
- /package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -0
- /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
- /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
- /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
- /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
|
@@ -2,13 +2,109 @@ var _a, _b;
|
|
|
2
2
|
import { WebSocketServer, WebSocket } from 'ws';
|
|
3
3
|
import crypto from 'crypto';
|
|
4
4
|
import fs from 'fs';
|
|
5
|
+
import os from 'os';
|
|
5
6
|
import path from 'path';
|
|
6
7
|
import * as pty from 'node-pty';
|
|
8
|
+
import { createMarkerTransformer } from "../utils/scenarioMarkers.js";
|
|
9
|
+
import { IdleDetector } from "./idleDetector.js";
|
|
10
|
+
import { mockStateEventEmitter } from "./mockStateEvents.js";
|
|
11
|
+
/**
|
|
12
|
+
* Strip the raw `claude ...` shell command from suppressed PTY output
|
|
13
|
+
* so it doesn't leak to the user in the fallback timeout path.
|
|
14
|
+
*/
|
|
15
|
+
export function stripClaudeCommand(output) {
|
|
16
|
+
// Find the line containing the claude command and strip everything before
|
|
17
|
+
// and including it (shell prompt, ANSI codes, command echo). Preserve any
|
|
18
|
+
// real output that follows.
|
|
19
|
+
const idx = output.indexOf('claude ');
|
|
20
|
+
if (idx === -1)
|
|
21
|
+
return output;
|
|
22
|
+
// Find the end of the command line (\r or \n after "claude")
|
|
23
|
+
let end = idx;
|
|
24
|
+
while (end < output.length && output[end] !== '\r' && output[end] !== '\n') {
|
|
25
|
+
end++;
|
|
26
|
+
}
|
|
27
|
+
// Skip past trailing \r\n
|
|
28
|
+
while (end < output.length &&
|
|
29
|
+
(output[end] === '\r' || output[end] === '\n')) {
|
|
30
|
+
end++;
|
|
31
|
+
}
|
|
32
|
+
// Strip leading ANSI escape sequences from the remainder
|
|
33
|
+
// (e.g. bracketed paste mode toggles like \x1b[?2004l)
|
|
34
|
+
let rest = output.slice(end);
|
|
35
|
+
rest = rest.replace(/^(\x1b\[[\x20-\x3f]*[\x40-\x7e]|\x1b[()][A-Z0-9])*/, '');
|
|
36
|
+
return rest;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Detect whether a PTY output chunk contains Claude Code's welcome banner.
|
|
40
|
+
* Supports both the old box-drawing format (`╭─── Claude Code ───╮`)
|
|
41
|
+
* and the new block-art format (`▐▛███▜▌ Claude Code`).
|
|
42
|
+
*/
|
|
43
|
+
export function isBannerChunk(data) {
|
|
44
|
+
// Strip ANSI escape sequences before checking — Claude Code's Ink renderer
|
|
45
|
+
// inserts SGR color codes between the banner characters (e.g. ▐\x1b[48;5;16m▛).
|
|
46
|
+
const plain = data.replace(/\x1b\[[0-9;?]*[A-Za-z]|\x1b\][^\x07]*\x07|\x1b[()][A-Z0-9]/g, '');
|
|
47
|
+
return plain.includes('╭') || plain.includes('▐▛');
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Determine whether the startup output filter should be active.
|
|
51
|
+
* The filter strips the raw `claude --session-id ...` command from the
|
|
52
|
+
* terminal so the user never sees it.
|
|
53
|
+
*/
|
|
54
|
+
export function shouldFilterStartup(opts) {
|
|
55
|
+
return opts.hasContext || opts.editorMode;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Manages PTY output suppression during Claude startup.
|
|
59
|
+
*
|
|
60
|
+
* Suppresses all output until the welcome banner arrives, then clears
|
|
61
|
+
* the screen. The claude command is stripped from any chunk that is forwarded
|
|
62
|
+
* (both the banner chunk on the normal path and the buffered output on the
|
|
63
|
+
* fallback timeout path).
|
|
64
|
+
*/
|
|
65
|
+
export class StartupOutputFilter {
|
|
66
|
+
constructor() {
|
|
67
|
+
this.hasClearedScreen = false;
|
|
68
|
+
this.suppressedOutput = '';
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Process a PTY data chunk. Returns an object describing what action to take:
|
|
72
|
+
* - `type: 'suppress'` — buffer the chunk, send nothing
|
|
73
|
+
* - `type: 'clear-and-send'` — clear screen, then send `data`
|
|
74
|
+
* - `type: 'send'` — send `data` as-is (post-startup)
|
|
75
|
+
*/
|
|
76
|
+
processChunk(data) {
|
|
77
|
+
if (!this.hasClearedScreen && isBannerChunk(data)) {
|
|
78
|
+
this.hasClearedScreen = true;
|
|
79
|
+
const cleaned = stripClaudeCommand(data);
|
|
80
|
+
return { type: 'clear-and-send', data: cleaned };
|
|
81
|
+
}
|
|
82
|
+
if (!this.hasClearedScreen) {
|
|
83
|
+
this.suppressedOutput += data;
|
|
84
|
+
return { type: 'suppress' };
|
|
85
|
+
}
|
|
86
|
+
return { type: 'send', data };
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Called when the fallback timeout fires (╭ never arrived).
|
|
90
|
+
* Returns the buffered output with the command stripped, or null if
|
|
91
|
+
* the screen was already cleared.
|
|
92
|
+
*/
|
|
93
|
+
getTimeoutOutput() {
|
|
94
|
+
if (this.hasClearedScreen)
|
|
95
|
+
return null;
|
|
96
|
+
this.hasClearedScreen = true;
|
|
97
|
+
if (this.suppressedOutput.length === 0)
|
|
98
|
+
return null;
|
|
99
|
+
const cleaned = stripClaudeCommand(this.suppressedOutput);
|
|
100
|
+
return cleaned.length > 0 ? cleaned : null;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
7
103
|
// Use globalThis so the sessions Set is shared across module instances.
|
|
8
104
|
// In Vite dev mode, this file is loaded twice: once by the Vite plugin (Node.js native)
|
|
9
105
|
// and once by the SSR context (ssrLoadModule). Without globalThis, each instance
|
|
10
106
|
// gets its own empty Set — so broadcastPreviewRefresh() called from the SSR instance
|
|
11
|
-
// (via the /api/dev-mode-
|
|
107
|
+
// (via the /api/dev-mode-preview endpoint) would broadcast to 0 sessions.
|
|
12
108
|
const sessions = ((_a = globalThis).__codeyamTerminalSessions ?? (_a.__codeyamTerminalSessions = new Set()));
|
|
13
109
|
// Detached PTYs waiting for reconnection (keyed by sessionId).
|
|
14
110
|
// When a WebSocket drops, the PTY is moved here with a grace timer
|
|
@@ -17,104 +113,6 @@ const detachedPtys = ((_b = globalThis).__codeyamDetachedPtys ?? (_b.__codeyamDe
|
|
|
17
113
|
const PING_INTERVAL_MS = 30000;
|
|
18
114
|
const DETACH_GRACE_MS = 60000;
|
|
19
115
|
const OUTPUT_BUFFER_MAX = 8 * 1024; // 8KB
|
|
20
|
-
const ANSI_ESCAPE_RE = /\x1b\[[0-9;]*[a-zA-Z]/g;
|
|
21
|
-
/**
|
|
22
|
-
* Build a position map from ANSI-stripped indices to original indices.
|
|
23
|
-
* posMap[strippedIndex] = originalIndex, skipping over ANSI sequences.
|
|
24
|
-
*/
|
|
25
|
-
function buildAnsiPositionMap(data, stripped) {
|
|
26
|
-
const posMap = [];
|
|
27
|
-
for (let di = 0, si = 0; di < data.length; di++) {
|
|
28
|
-
if (data[di] === '\x1b') {
|
|
29
|
-
const seqMatch = data.slice(di).match(/^\x1b\[[0-9;]*[a-zA-Z]/);
|
|
30
|
-
if (seqMatch) {
|
|
31
|
-
di += seqMatch[0].length - 1; // -1 because loop increments
|
|
32
|
-
continue;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
posMap[si] = di;
|
|
36
|
-
si++;
|
|
37
|
-
}
|
|
38
|
-
posMap[stripped.length] = data.length; // sentinel for end-of-string markers
|
|
39
|
-
return posMap;
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Transform {{scenario:Name:ID}} markers in PTY output into OSC 8 hyperlinks.
|
|
43
|
-
* OSC 8 format: \x1b]8;;URL\x07VISIBLE_TEXT\x1b]8;;\x07
|
|
44
|
-
* xterm.js renders the visible text as a clickable link.
|
|
45
|
-
*
|
|
46
|
-
* Claude Code's renderer inserts ANSI escape codes (colors/styles) within the
|
|
47
|
-
* marker text, so we can't regex match on the raw PTY data directly. Instead,
|
|
48
|
-
* strip ANSI codes to find markers, then map positions back to the original
|
|
49
|
-
* string for replacement.
|
|
50
|
-
*/
|
|
51
|
-
function transformScenarioMarkers(data, port) {
|
|
52
|
-
// Strip ANSI escape sequences to get clean text for marker detection
|
|
53
|
-
const stripped = data.replace(ANSI_ESCAPE_RE, '');
|
|
54
|
-
if (!stripped.includes('{{scenario:'))
|
|
55
|
-
return data;
|
|
56
|
-
const posMap = buildAnsiPositionMap(data, stripped);
|
|
57
|
-
// Find markers in the stripped text
|
|
58
|
-
const markerRegex = /\{\{scenario:([^:}]+):([^}]+)\}\}/g;
|
|
59
|
-
const replacements = [];
|
|
60
|
-
let m;
|
|
61
|
-
while ((m = markerRegex.exec(stripped)) !== null) {
|
|
62
|
-
const url = `http://localhost:${port}/editor?scenario=${m[2]}&ref=link`;
|
|
63
|
-
const visibleName = m[1];
|
|
64
|
-
// Pad replacement to match the original marker's visible width so table
|
|
65
|
-
// columns stay aligned after the shorter hyperlink text replaces the marker.
|
|
66
|
-
const pad = ' '.repeat(Math.max(0, m[0].length - visibleName.length));
|
|
67
|
-
replacements.push({
|
|
68
|
-
origStart: posMap[m.index],
|
|
69
|
-
origEnd: posMap[m.index + m[0].length],
|
|
70
|
-
replacement: `\x1b]8;;${url}\x07${visibleName}\x1b]8;;\x07${pad}`,
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
if (replacements.length === 0)
|
|
74
|
-
return data;
|
|
75
|
-
// Replace from end to start so earlier positions stay valid
|
|
76
|
-
let result = data;
|
|
77
|
-
for (let i = replacements.length - 1; i >= 0; i--) {
|
|
78
|
-
const r = replacements[i];
|
|
79
|
-
result =
|
|
80
|
-
result.slice(0, r.origStart) + r.replacement + result.slice(r.origEnd);
|
|
81
|
-
}
|
|
82
|
-
return result;
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Create a stateful scenario marker transformer that buffers partial markers
|
|
86
|
-
* across PTY chunks. Claude Code streams output token by token, so the PTY
|
|
87
|
-
* can split a {{scenario:Name:ID}} marker across two (or more) data events.
|
|
88
|
-
* Without buffering, split markers pass through un-transformed as raw text.
|
|
89
|
-
*/
|
|
90
|
-
function createMarkerTransformer(port) {
|
|
91
|
-
let buffer = '';
|
|
92
|
-
return function transform(data) {
|
|
93
|
-
// Prepend any buffered partial-marker text from the previous chunk
|
|
94
|
-
const combined = buffer + data;
|
|
95
|
-
buffer = '';
|
|
96
|
-
// Strip ANSI to detect partial markers at the end
|
|
97
|
-
const stripped = combined.replace(ANSI_ESCAPE_RE, '');
|
|
98
|
-
// Check for an unclosed {{ at the end — potential partial marker
|
|
99
|
-
const lastOpen = stripped.lastIndexOf('{{');
|
|
100
|
-
if (lastOpen !== -1 && !stripped.slice(lastOpen).includes('}}')) {
|
|
101
|
-
// Map the stripped position back to the original string
|
|
102
|
-
const posMap = buildAnsiPositionMap(combined, stripped);
|
|
103
|
-
const splitPos = posMap[lastOpen];
|
|
104
|
-
// Safety: if partial marker exceeds 500 chars, it's not a real marker — flush it
|
|
105
|
-
if (combined.length - splitPos > 500) {
|
|
106
|
-
return transformScenarioMarkers(combined, port);
|
|
107
|
-
}
|
|
108
|
-
buffer = combined.slice(splitPos);
|
|
109
|
-
const toSend = combined.slice(0, splitPos);
|
|
110
|
-
// If nothing to send yet (entire chunk is a partial marker), return empty
|
|
111
|
-
if (toSend.length === 0)
|
|
112
|
-
return '';
|
|
113
|
-
return transformScenarioMarkers(toSend, port);
|
|
114
|
-
}
|
|
115
|
-
return transformScenarioMarkers(combined, port);
|
|
116
|
-
};
|
|
117
|
-
}
|
|
118
116
|
// Ping interval reference — shared so cleanup can clear it
|
|
119
117
|
let pingInterval = globalThis.__codeyamPingInterval ?? null;
|
|
120
118
|
// Keys to forward from the server env into the PTY shell.
|
|
@@ -149,9 +147,22 @@ const ENV_PASSTHROUGH_KEYS = [
|
|
|
149
147
|
'HOMEBREW_CELLAR',
|
|
150
148
|
'HOMEBREW_REPOSITORY',
|
|
151
149
|
];
|
|
152
|
-
|
|
150
|
+
// Additional env vars needed on Windows
|
|
151
|
+
const WINDOWS_ENV_PASSTHROUGH_KEYS = [
|
|
152
|
+
'USERPROFILE',
|
|
153
|
+
'APPDATA',
|
|
154
|
+
'LOCALAPPDATA',
|
|
155
|
+
'COMSPEC',
|
|
156
|
+
'SystemRoot',
|
|
157
|
+
'TEMP',
|
|
158
|
+
'TMP',
|
|
159
|
+
];
|
|
160
|
+
export function buildPtyEnv(options) {
|
|
153
161
|
const env = {};
|
|
154
|
-
|
|
162
|
+
const keys = process.platform === 'win32'
|
|
163
|
+
? [...ENV_PASSTHROUGH_KEYS, ...WINDOWS_ENV_PASSTHROUGH_KEYS]
|
|
164
|
+
: ENV_PASSTHROUGH_KEYS;
|
|
165
|
+
for (const key of keys) {
|
|
155
166
|
const val = process.env[key];
|
|
156
167
|
if (val != null)
|
|
157
168
|
env[key] = val;
|
|
@@ -159,8 +170,45 @@ function buildPtyEnv() {
|
|
|
159
170
|
// Always set TERM for proper terminal behavior
|
|
160
171
|
if (!env.TERM)
|
|
161
172
|
env.TERM = 'xterm-256color';
|
|
173
|
+
// Signal to hooks that this is an editor Build session.
|
|
174
|
+
// Without this, editor hooks fire in ALL Claude sessions in the project.
|
|
175
|
+
if (options?.editorMode) {
|
|
176
|
+
env.CODEYAM_EDITOR_ACTIVE = '1';
|
|
177
|
+
}
|
|
162
178
|
return env;
|
|
163
179
|
}
|
|
180
|
+
/**
|
|
181
|
+
* Returns the shell executable and arguments for PTY spawning,
|
|
182
|
+
* handling platform differences (Windows uses PowerShell, Unix uses $SHELL).
|
|
183
|
+
*/
|
|
184
|
+
export function getShellConfig() {
|
|
185
|
+
if (process.platform === 'win32') {
|
|
186
|
+
return {
|
|
187
|
+
shell: 'powershell.exe',
|
|
188
|
+
args: ['-ExecutionPolicy', 'Bypass', '-NoLogo'],
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
const defaultShell = process.platform === 'darwin' ? '/bin/zsh' : '/bin/sh';
|
|
192
|
+
return {
|
|
193
|
+
shell: process.env.SHELL || defaultShell,
|
|
194
|
+
args: ['-l'],
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* Returns a safe working directory for the PTY, falling back through
|
|
199
|
+
* CODEYAM_ROOT_PATH → cwd → HOME/USERPROFILE → os.tmpdir().
|
|
200
|
+
*/
|
|
201
|
+
export function getSafeCwd() {
|
|
202
|
+
const cwd = process.env.CODEYAM_ROOT_PATH || process.cwd();
|
|
203
|
+
if (fs.existsSync(cwd))
|
|
204
|
+
return cwd;
|
|
205
|
+
const home = process.platform === 'win32'
|
|
206
|
+
? process.env.USERPROFILE || process.env.HOME
|
|
207
|
+
: process.env.HOME;
|
|
208
|
+
if (home && fs.existsSync(home))
|
|
209
|
+
return home;
|
|
210
|
+
return os.tmpdir();
|
|
211
|
+
}
|
|
164
212
|
/**
|
|
165
213
|
* Convert a name to a safe file name matching CodeYam's convention.
|
|
166
214
|
* e.g. "Default Scenario" -> "Default_Scenario"
|
|
@@ -287,7 +335,7 @@ function writeDevModeContext(ctx) {
|
|
|
287
335
|
// Server
|
|
288
336
|
const serverPort = process.env.CODEYAM_PORT || '3111';
|
|
289
337
|
lines.push('## Server');
|
|
290
|
-
lines.push(`- **Refresh preview:** \`curl -X POST http://localhost:${serverPort}/api/dev-mode-
|
|
338
|
+
lines.push(`- **Refresh preview:** \`curl -X POST http://localhost:${serverPort}/api/dev-mode-preview -H 'Content-Type: application/json' -d '{"dimension":"Desktop"}'\` (dimension is REQUIRED)`);
|
|
291
339
|
lines.push('');
|
|
292
340
|
fs.writeFileSync(contextPath, lines.join('\n'), 'utf8');
|
|
293
341
|
return true;
|
|
@@ -324,28 +372,34 @@ function writeEditorModeContext(ctx) {
|
|
|
324
372
|
`- **Proxy:** http://localhost:${proxyPort} (used by the browser iframe only — do NOT use for health checks)`,
|
|
325
373
|
'',
|
|
326
374
|
'## Workflow',
|
|
327
|
-
'- **Guided steps:** Run `codeyam editor` for the next step (plan → prototype → confirm → deconstruct → extract → glossary → analyze → app scenarios → user scenarios → verify → review)',
|
|
328
|
-
'- Each feature follows
|
|
329
|
-
'-
|
|
375
|
+
'- **Guided steps:** Run `codeyam editor steps` for the next step (plan → prepare → prototype → verify prototype → confirm → deconstruct → extract → glossary → analyze → app scenarios → user scenarios → verify → journal → review → present → commit → finalize → push)',
|
|
376
|
+
'- Each feature follows 18 steps — run `codeyam editor steps` to see what to do next. Never expose `codeyam editor` commands to the user.',
|
|
377
|
+
'- **Run ONE step at a time.** Read the FULL output, complete every checklist item, then advance. NEVER batch-run steps in a loop or delegate them to a subagent.',
|
|
378
|
+
'- Steps 1, 5, 15, and 18 require user confirmation before proceeding',
|
|
379
|
+
'',
|
|
380
|
+
'## Preview Updates',
|
|
381
|
+
'- **Refresh the preview frequently** — the user watches the preview as you work. Refresh after every meaningful change (new page, UI section, data seeding, styling), not just at the end.',
|
|
382
|
+
`- **Refresh command:** \`curl -s -X POST http://localhost:${serverPort}/api/dev-mode-preview -H 'Content-Type: application/json' -d '{"dimension":"Desktop"}'\` (dimension is REQUIRED)`,
|
|
383
|
+
'- Aim for 4-8+ preview updates during a typical building session.',
|
|
330
384
|
'',
|
|
331
385
|
'## Verifying the Dev Server',
|
|
332
386
|
'- Get the dev server URL: `curl -s http://localhost:' +
|
|
333
387
|
serverPort +
|
|
334
388
|
'/api/editor-dev-server` → look at the `"url"` field (e.g., `http://localhost:3000`)',
|
|
335
|
-
'-
|
|
336
|
-
'- Check API routes work: `curl -s http://localhost:3000/api/your-route` (should return JSON, not "Internal Server Error")',
|
|
389
|
+
'- Verify pages and API routes: `codeyam editor verify-routes \'{"paths":["/"],"apiRoutes":["/api/your-route"]}\'` (checks HTTP status and JSON validity)',
|
|
337
390
|
'- **NEVER check localhost:' +
|
|
338
391
|
proxyPort +
|
|
339
392
|
' for health** — the proxy returns 200 even when the app is broken',
|
|
340
393
|
'',
|
|
341
394
|
'## API Endpoints',
|
|
342
|
-
`- **Register scenario (auto-captures screenshot):** \`codeyam editor register '{"name":"...","
|
|
395
|
+
`- **Register scenario (auto-captures screenshot):** \`codeyam editor register '{"name":"...","url":"/page-to-screenshot","type":"application","seed":{...}}'\` — ALWAYS include "url" for the page to screenshot. For large payloads, write JSON to a file and use @ prefix: \`codeyam editor register @/tmp/scenario.json\``,
|
|
343
396
|
`- **Get active scenario data:** \`curl http://localhost:${serverPort}/api/editor-scenario-data\``,
|
|
344
|
-
`- **Refresh preview:** \`curl -X POST http://localhost:${serverPort}/api/dev-mode-
|
|
397
|
+
`- **Refresh/navigate/switch preview:** \`curl -X POST http://localhost:${serverPort}/api/dev-mode-preview -H 'Content-Type: application/json' -d '{"dimension":"Desktop"}'\` (dimension is REQUIRED in every call; add \`"path":"/route"\` to navigate; add \`"scenarioId":"..."\` to switch scenario). Clears logs, waits for HMR, checks SSR health.`,
|
|
345
398
|
`- **Refresh config:** \`curl -X POST http://localhost:${serverPort}/api/editor-refresh\` (also starts dev server if a webapp is detected)`,
|
|
346
399
|
`- **Dev server status:** \`curl http://localhost:${serverPort}/api/editor-dev-server\``,
|
|
347
400
|
`- **Start dev server:** \`curl -X POST http://localhost:${serverPort}/api/editor-dev-server -H 'Content-Type: application/json' -d '{"action":"start"}'\``,
|
|
348
401
|
`- **Restart dev server:** \`curl -X POST http://localhost:${serverPort}/api/editor-dev-server -H 'Content-Type: application/json' -d '{"action":"restart"}'\``,
|
|
402
|
+
`- **Feature complete (after push):** \`curl -s -X POST http://localhost:${serverPort}/api/editor-feature-complete\` — signals the UI that the feature is done. Call this after step 18 push/skip, then STOP.`,
|
|
349
403
|
`- **Re-capture scenario screenshot:** \`curl -X POST http://localhost:${serverPort}/api/editor-capture-scenario -H 'Content-Type: application/json' -d '{"scenarioId":"...","url":"..."}'\` (for manual re-capture; register auto-captures)`,
|
|
350
404
|
`- **Journal screenshot:** \`curl -X POST http://localhost:${serverPort}/api/editor-journal-screenshot -H 'Content-Type: application/json' -d '{"url":"...","filename":"..."}'\``,
|
|
351
405
|
`- **Journal entry:** \`curl -X POST http://localhost:${serverPort}/api/editor-journal-entry -H 'Content-Type: application/json' -d '{"title":"...","type":"feature","description":"..."}'\``,
|
|
@@ -358,17 +412,21 @@ function writeEditorModeContext(ctx) {
|
|
|
358
412
|
'- POST/PUT/DELETE always go through to the real dev server',
|
|
359
413
|
'',
|
|
360
414
|
'## Component Isolation Routes',
|
|
361
|
-
'-
|
|
362
|
-
' -
|
|
363
|
-
'
|
|
415
|
+
'- Create isolation route dirs: `codeyam editor isolate ComponentA ComponentB ...`',
|
|
416
|
+
' - This creates the layout guard and a directory per component under `app/isolated-components/`',
|
|
417
|
+
'- Create ONE isolation route page per component:',
|
|
418
|
+
' - **Remix:** `app/routes/isolated-components.ComponentName.tsx` → `/isolated-components/ComponentName`',
|
|
419
|
+
' - **Next.js:** `app/isolated-components/ComponentName/page.tsx` → `/isolated-components/ComponentName`',
|
|
420
|
+
' - **Expo:** `app/isolated-components/ComponentName.tsx` → `/isolated-components/ComponentName` (use `useLocalSearchParams` from expo-router)',
|
|
364
421
|
'- The route defines a `scenarios` object mapping scenario names to props, reads `?s=ScenarioName` from the URL, and renders the component',
|
|
365
|
-
'- Wrap the component in a centered container: `<div style="display:flex;justify-content:center;align-items:center;min-height:100vh
|
|
422
|
+
'- For web apps: Wrap the component in a centered container: `<div style="display:flex;justify-content:center;align-items:center;min-height:100vh"><div style="width:100%;max-width:...">` — set max-width to match the component\'s real container (e.g. card in 3-col grid → 24rem)',
|
|
423
|
+
'- For Expo: Wrap with `<View nativeID="codeyam-capture">` (nativeID maps to id on web for screenshot capture)',
|
|
366
424
|
'- **Create multiple scenarios per component** (like tests): default/happy path, edge cases (empty data, long text, max items), different visual states (loading, error, disabled)',
|
|
367
|
-
'- Register each scenario: `codeyam editor register \'{"name":"ComponentName - Scenario","componentName":"ComponentName","componentPath":"path/to/file.tsx","url":"/
|
|
425
|
+
'- Register each scenario: `codeyam editor register \'{"name":"ComponentName - Scenario","componentName":"ComponentName","componentPath":"path/to/file.tsx","url":"/isolated-components/ComponentName?s=Scenario","mockData":{"routes":{"/api/...":{"body":[...]}}}}\'`',
|
|
368
426
|
'- The url is a PATH, not a full URL — the proxy appends it and intercepts API calls the component makes',
|
|
369
427
|
'- `mockData.routes` provides data for any API calls the component makes internally (omit if none)',
|
|
370
428
|
'- Isolation routes stay in the project so the editor preview can display them',
|
|
371
|
-
'- Ensure `.gitignore` includes `**/
|
|
429
|
+
'- Ensure `.gitignore` includes `**/isolated-components*` so they are not committed',
|
|
372
430
|
'',
|
|
373
431
|
'## Files',
|
|
374
432
|
'- **Scenario data:** .codeyam/editor-scenarios/{scenario-id}.json',
|
|
@@ -382,9 +440,21 @@ function writeEditorModeContext(ctx) {
|
|
|
382
440
|
const hasPackageJson = fs.existsSync(path.join(codeyamRoot, 'package.json'));
|
|
383
441
|
if (!hasPackageJson) {
|
|
384
442
|
lines.push('## Status');
|
|
385
|
-
lines.push('- **Empty project** — no package.json found.
|
|
443
|
+
lines.push('- **Empty project** — no package.json found. Run `codeyam editor steps` to begin.');
|
|
386
444
|
lines.push('');
|
|
387
445
|
}
|
|
446
|
+
// Include handoff context if a provider switch generated one
|
|
447
|
+
try {
|
|
448
|
+
const handoffContextPath = path.join(codeyamRoot, '.codeyam', 'handoff-context.md');
|
|
449
|
+
if (fs.existsSync(handoffContextPath)) {
|
|
450
|
+
lines.push('');
|
|
451
|
+
lines.push(fs.readFileSync(handoffContextPath, 'utf8'));
|
|
452
|
+
lines.push('');
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
catch {
|
|
456
|
+
// Non-fatal
|
|
457
|
+
}
|
|
388
458
|
fs.writeFileSync(contextPath, lines.join('\n'), 'utf8');
|
|
389
459
|
return true;
|
|
390
460
|
}
|
|
@@ -422,6 +492,12 @@ export function attachTerminalServer(httpServer) {
|
|
|
422
492
|
}
|
|
423
493
|
}, PING_INTERVAL_MS);
|
|
424
494
|
globalThis.__codeyamPingInterval = pingInterval;
|
|
495
|
+
// Subscribe to mock state events and broadcast to all terminal clients
|
|
496
|
+
mockStateEventEmitter.on('event', (event) => {
|
|
497
|
+
if (event.type === 'data-mutation-forwarded') {
|
|
498
|
+
broadcastDataMutationForwarded(event.method, event.pathname);
|
|
499
|
+
}
|
|
500
|
+
});
|
|
425
501
|
wss.on('connection', (ws, req) => {
|
|
426
502
|
// Parse entity context from query params
|
|
427
503
|
const url = new URL(req.url || '', `http://${req.headers.host}`);
|
|
@@ -435,6 +511,9 @@ export function attachTerminalServer(httpServer) {
|
|
|
435
511
|
const projectSlug = url.searchParams.get('projectSlug') || '';
|
|
436
512
|
const editorMode = url.searchParams.get('editorMode') === 'true';
|
|
437
513
|
const reconnectId = url.searchParams.get('reconnectId') || '';
|
|
514
|
+
const claudeStartMode = url.searchParams.get('claudeStartMode') || '';
|
|
515
|
+
const claudeSessionId = url.searchParams.get('claudeSessionId') || '';
|
|
516
|
+
const editorStepLabel = url.searchParams.get('editorStepLabel') || '';
|
|
438
517
|
// --- Reconnection: reattach to a detached PTY ---
|
|
439
518
|
if (reconnectId && detachedPtys.has(reconnectId)) {
|
|
440
519
|
const detached = detachedPtys.get(reconnectId);
|
|
@@ -461,13 +540,27 @@ export function attachTerminalServer(httpServer) {
|
|
|
461
540
|
let detachedFlag = false;
|
|
462
541
|
const reconnectPort = process.env.CODEYAM_PORT || '3111';
|
|
463
542
|
const reconnectTransformMarkers = createMarkerTransformer(reconnectPort);
|
|
543
|
+
const reconnectIdleDetector = new IdleDetector({
|
|
544
|
+
onIdle: () => {
|
|
545
|
+
if (ws.readyState === WebSocket.OPEN) {
|
|
546
|
+
console.log('[terminalServer] Sending claude-idle (reconnected)');
|
|
547
|
+
ws.send(JSON.stringify({ type: 'claude-idle' }));
|
|
548
|
+
}
|
|
549
|
+
},
|
|
550
|
+
onActive: () => {
|
|
551
|
+
if (ws.readyState === WebSocket.OPEN) {
|
|
552
|
+
console.log('[terminalServer] Sending claude-active (reconnected)');
|
|
553
|
+
ws.send(JSON.stringify({ type: 'claude-active' }));
|
|
554
|
+
}
|
|
555
|
+
},
|
|
556
|
+
}, { activeOutputPattern: /[✶✢·◼]/ });
|
|
464
557
|
detached.ptyProcess.onData((data) => {
|
|
465
558
|
if (detachedFlag)
|
|
466
559
|
return; // Superseded by a newer listener
|
|
467
560
|
if (ws.readyState === WebSocket.OPEN) {
|
|
468
561
|
if (!detached.hasClearedScreen &&
|
|
469
562
|
detached.hasContext &&
|
|
470
|
-
data
|
|
563
|
+
isBannerChunk(data)) {
|
|
471
564
|
detached.hasClearedScreen = true;
|
|
472
565
|
ws.send(JSON.stringify({ type: 'output', data: '\x1b[2J\x1b[H' }));
|
|
473
566
|
}
|
|
@@ -475,14 +568,12 @@ export function attachTerminalServer(httpServer) {
|
|
|
475
568
|
if (transformed.length > 0) {
|
|
476
569
|
ws.send(JSON.stringify({ type: 'output', data: transformed }));
|
|
477
570
|
}
|
|
478
|
-
|
|
479
|
-
if (stripped.includes('Editor Mode \u2014')) {
|
|
480
|
-
console.log('[terminalServer] Detected claude-idle signal (reconnect)');
|
|
481
|
-
ws.send(JSON.stringify({ type: 'claude-idle' }));
|
|
482
|
-
}
|
|
571
|
+
reconnectIdleDetector.onPtyOutput(data);
|
|
483
572
|
}
|
|
484
573
|
});
|
|
485
574
|
detached.ptyProcess.onExit(() => {
|
|
575
|
+
console.log('[terminalServer] PTY exited (reconnected), flushing idle state');
|
|
576
|
+
reconnectIdleDetector.disposeAndFlush();
|
|
486
577
|
sessions.delete(session);
|
|
487
578
|
if (ws.readyState === WebSocket.OPEN) {
|
|
488
579
|
ws.close();
|
|
@@ -493,6 +584,7 @@ export function attachTerminalServer(httpServer) {
|
|
|
493
584
|
try {
|
|
494
585
|
const msg = JSON.parse(raw.toString());
|
|
495
586
|
if (msg.type === 'input') {
|
|
587
|
+
reconnectIdleDetector.onUserInput();
|
|
496
588
|
detached.ptyProcess.write(msg.data);
|
|
497
589
|
}
|
|
498
590
|
else if (msg.type === 'resize' && msg.cols && msg.rows) {
|
|
@@ -513,19 +605,17 @@ export function attachTerminalServer(httpServer) {
|
|
|
513
605
|
return;
|
|
514
606
|
}
|
|
515
607
|
// --- New connection: spawn a fresh PTY ---
|
|
516
|
-
const shell
|
|
517
|
-
const
|
|
518
|
-
// Verify cwd exists, fall back to HOME
|
|
519
|
-
const safeCwd = fs.existsSync(cwd) ? cwd : process.env.HOME || '/tmp';
|
|
608
|
+
const { shell, args: shellArgs } = getShellConfig();
|
|
609
|
+
const safeCwd = getSafeCwd();
|
|
520
610
|
// Spawn PTY with a clean env (no giant JSON blobs from CODEYAM_PROJECT etc.)
|
|
521
611
|
let ptyProcess;
|
|
522
612
|
try {
|
|
523
|
-
ptyProcess = pty.spawn(shell,
|
|
613
|
+
ptyProcess = pty.spawn(shell, shellArgs, {
|
|
524
614
|
name: 'xterm-256color',
|
|
525
615
|
cols: 120,
|
|
526
616
|
rows: 30,
|
|
527
617
|
cwd: safeCwd,
|
|
528
|
-
env: buildPtyEnv(),
|
|
618
|
+
env: buildPtyEnv({ editorMode }),
|
|
529
619
|
});
|
|
530
620
|
}
|
|
531
621
|
catch (error) {
|
|
@@ -565,9 +655,41 @@ export function attachTerminalServer(httpServer) {
|
|
|
565
655
|
projectSlug,
|
|
566
656
|
});
|
|
567
657
|
let hasClearedScreen = false;
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
658
|
+
const filterStartup = shouldFilterStartup({ hasContext, editorMode });
|
|
659
|
+
const startupFilter = filterStartup ? new StartupOutputFilter() : null;
|
|
660
|
+
// Safety timeout: stop suppressing output after 5s even if ╭ never arrives.
|
|
661
|
+
// Prevents "Starting Claude..." hanging forever if the banner format changes.
|
|
662
|
+
if (filterStartup) {
|
|
663
|
+
setTimeout(() => {
|
|
664
|
+
const output = startupFilter.getTimeoutOutput();
|
|
665
|
+
if (output !== null) {
|
|
666
|
+
hasClearedScreen = true;
|
|
667
|
+
console.log('[terminalServer] Suppression timeout — showing output');
|
|
668
|
+
if (ws.readyState === WebSocket.OPEN) {
|
|
669
|
+
// Clear the "Starting Claude..." message
|
|
670
|
+
ws.send(JSON.stringify({ type: 'output', data: '\x1b[2J\x1b[H' }));
|
|
671
|
+
const transformed = transformMarkers(output);
|
|
672
|
+
if (transformed.length > 0) {
|
|
673
|
+
ws.send(JSON.stringify({ type: 'output', data: transformed }));
|
|
674
|
+
}
|
|
675
|
+
}
|
|
676
|
+
}
|
|
677
|
+
}, 5000);
|
|
678
|
+
}
|
|
679
|
+
const idleDetector = new IdleDetector({
|
|
680
|
+
onIdle: () => {
|
|
681
|
+
if (ws.readyState === WebSocket.OPEN) {
|
|
682
|
+
console.log('[terminalServer] Sending claude-idle');
|
|
683
|
+
ws.send(JSON.stringify({ type: 'claude-idle' }));
|
|
684
|
+
}
|
|
685
|
+
},
|
|
686
|
+
onActive: () => {
|
|
687
|
+
if (ws.readyState === WebSocket.OPEN) {
|
|
688
|
+
console.log('[terminalServer] Sending claude-active');
|
|
689
|
+
ws.send(JSON.stringify({ type: 'claude-active' }));
|
|
690
|
+
}
|
|
691
|
+
},
|
|
692
|
+
}, { activeOutputPattern: /[✶✢·◼]/ });
|
|
571
693
|
// PTY output -> WebSocket
|
|
572
694
|
const serverPort = process.env.CODEYAM_PORT || '3111';
|
|
573
695
|
// Stateful transformer that buffers partial {{scenario:...}} markers
|
|
@@ -575,35 +697,37 @@ export function attachTerminalServer(httpServer) {
|
|
|
575
697
|
const transformMarkers = createMarkerTransformer(serverPort);
|
|
576
698
|
ptyProcess.onData((data) => {
|
|
577
699
|
if (ws.readyState === WebSocket.OPEN) {
|
|
578
|
-
//
|
|
579
|
-
// clear
|
|
580
|
-
if (
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
const combined = idleDetectBuffer + stripped;
|
|
595
|
-
if (combined.includes(IDLE_MARKER)) {
|
|
596
|
-
console.log('[terminalServer] Detected claude-idle signal');
|
|
597
|
-
ws.send(JSON.stringify({ type: 'claude-idle' }));
|
|
598
|
-
idleDetectBuffer = '';
|
|
700
|
+
// During startup, suppress output until Claude's welcome banner (╭)
|
|
701
|
+
// arrives, then clear screen and strip the raw command from the chunk.
|
|
702
|
+
if (startupFilter && !hasClearedScreen) {
|
|
703
|
+
const result = startupFilter.processChunk(data);
|
|
704
|
+
if (result.type === 'clear-and-send') {
|
|
705
|
+
hasClearedScreen = true;
|
|
706
|
+
ws.send(JSON.stringify({ type: 'output', data: '\x1b[2J\x1b[H' }));
|
|
707
|
+
if (result.data.length > 0) {
|
|
708
|
+
const transformed = transformMarkers(result.data);
|
|
709
|
+
if (transformed.length > 0) {
|
|
710
|
+
ws.send(JSON.stringify({ type: 'output', data: transformed }));
|
|
711
|
+
}
|
|
712
|
+
}
|
|
713
|
+
idleDetector.onPtyOutput(data);
|
|
714
|
+
}
|
|
715
|
+
// type === 'suppress': skip sending and idle detection
|
|
599
716
|
}
|
|
600
717
|
else {
|
|
601
|
-
//
|
|
602
|
-
|
|
718
|
+
// Transform {{scenario:Name:ID}} markers into OSC 8 clickable hyperlinks.
|
|
719
|
+
// Uses stateful buffering to handle markers split across PTY chunks.
|
|
720
|
+
const transformed = transformMarkers(data);
|
|
721
|
+
if (transformed.length > 0) {
|
|
722
|
+
ws.send(JSON.stringify({ type: 'output', data: transformed }));
|
|
723
|
+
}
|
|
724
|
+
idleDetector.onPtyOutput(data);
|
|
603
725
|
}
|
|
604
726
|
}
|
|
605
727
|
});
|
|
606
728
|
ptyProcess.onExit(() => {
|
|
729
|
+
console.log('[terminalServer] PTY exited, flushing idle state');
|
|
730
|
+
idleDetector.disposeAndFlush();
|
|
607
731
|
sessions.delete(session);
|
|
608
732
|
// Also clean up from detachedPtys if it was detached
|
|
609
733
|
if (detachedPtys.has(sessionId)) {
|
|
@@ -619,6 +743,7 @@ export function attachTerminalServer(httpServer) {
|
|
|
619
743
|
try {
|
|
620
744
|
const msg = JSON.parse(raw.toString());
|
|
621
745
|
if (msg.type === 'input') {
|
|
746
|
+
idleDetector.onUserInput();
|
|
622
747
|
ptyProcess.write(msg.data);
|
|
623
748
|
}
|
|
624
749
|
else if (msg.type === 'resize' && msg.cols && msg.rows) {
|
|
@@ -636,11 +761,54 @@ export function attachTerminalServer(httpServer) {
|
|
|
636
761
|
ws.on('close', () => {
|
|
637
762
|
detachSession(session, hasContext, hasClearedScreen);
|
|
638
763
|
});
|
|
764
|
+
// Show a loading indicator while Claude Code starts up.
|
|
765
|
+
// PTY output is suppressed until Claude's welcome banner (╭) appears
|
|
766
|
+
// and triggers a screen clear, so the user never sees the raw command.
|
|
767
|
+
if (filterStartup) {
|
|
768
|
+
ws.send(JSON.stringify({
|
|
769
|
+
type: 'output',
|
|
770
|
+
data: '\x1b[2J\x1b[H\r\n\x1b[90m Starting Claude...\x1b[0m\r\n',
|
|
771
|
+
}));
|
|
772
|
+
}
|
|
639
773
|
// Start Claude Code with the appropriate skill.
|
|
640
774
|
// Using a skill avoids shell escaping issues and multi-line paste detection.
|
|
775
|
+
//
|
|
776
|
+
// Session recovery modes (editor only):
|
|
777
|
+
// resume + sessionId → claude --resume <uuid> (resumes exact conversation)
|
|
778
|
+
// resume, no sessionId → claude --continue (fallback for pre-existing sessions)
|
|
779
|
+
// fresh → generate UUID, write to .codeyam/claude-session-id.txt,
|
|
780
|
+
// launch claude --session-id <uuid> '/codeyam-editor'
|
|
781
|
+
//
|
|
782
|
+
// The UUID is generated HERE (not in printStep1) so it's available before
|
|
783
|
+
// Claude launches. printStep1 runs inside the session — too late.
|
|
641
784
|
setTimeout(() => {
|
|
642
785
|
if (editorMode && hasContext) {
|
|
643
|
-
|
|
786
|
+
if (claudeStartMode === 'resume' && claudeSessionId) {
|
|
787
|
+
const resumePrompt = editorStepLabel === 'Present'
|
|
788
|
+
? 'The session was interrupted. Please rerun show-results.'
|
|
789
|
+
: 'The session was interrupted. Please continue where you left off.';
|
|
790
|
+
ptyProcess.write(`claude --resume '${claudeSessionId}' '${resumePrompt}'\r`);
|
|
791
|
+
}
|
|
792
|
+
else if (claudeStartMode === 'resume') {
|
|
793
|
+
// No session ID available — fall back to most recent session
|
|
794
|
+
const resumePrompt = editorStepLabel === 'Present'
|
|
795
|
+
? 'The session was interrupted. Please rerun show-results.'
|
|
796
|
+
: 'The session was interrupted. Please continue where you left off.';
|
|
797
|
+
ptyProcess.write(`claude --continue '${resumePrompt}'\r`);
|
|
798
|
+
}
|
|
799
|
+
else {
|
|
800
|
+
// Fresh session: generate a trackable UUID
|
|
801
|
+
const newSessionId = crypto.randomUUID();
|
|
802
|
+
const sessionIdPath = path.join(safeCwd, '.codeyam', 'claude-session-id.txt');
|
|
803
|
+
try {
|
|
804
|
+
fs.mkdirSync(path.dirname(sessionIdPath), { recursive: true });
|
|
805
|
+
fs.writeFileSync(sessionIdPath, newSessionId, 'utf8');
|
|
806
|
+
}
|
|
807
|
+
catch (err) {
|
|
808
|
+
console.error('[terminalServer] Failed to write claude-session-id.txt:', err);
|
|
809
|
+
}
|
|
810
|
+
ptyProcess.write(`claude --session-id '${newSessionId}' '/codeyam-editor'\r`);
|
|
811
|
+
}
|
|
644
812
|
}
|
|
645
813
|
else if (hasContext) {
|
|
646
814
|
ptyProcess.write("claude '/codeyam-dev-mode'\r");
|
|
@@ -696,8 +864,116 @@ function detachSession(session, hasContext = false, hasClearedScreen = false) {
|
|
|
696
864
|
* Send a refresh-preview message to all connected terminal WebSocket clients.
|
|
697
865
|
* The Terminal component relays this to the parent page to reload the iframe.
|
|
698
866
|
*/
|
|
699
|
-
export function broadcastPreviewRefresh() {
|
|
700
|
-
const msg = JSON.stringify({
|
|
867
|
+
export function broadcastPreviewRefresh(path, scenarioId) {
|
|
868
|
+
const msg = JSON.stringify({
|
|
869
|
+
type: 'refresh-preview',
|
|
870
|
+
...(path && { path }),
|
|
871
|
+
...(scenarioId && { scenarioId }),
|
|
872
|
+
});
|
|
873
|
+
let count = 0;
|
|
874
|
+
for (const session of sessions) {
|
|
875
|
+
try {
|
|
876
|
+
if (session.ws.readyState === WebSocket.OPEN) {
|
|
877
|
+
session.ws.send(msg);
|
|
878
|
+
count++;
|
|
879
|
+
}
|
|
880
|
+
}
|
|
881
|
+
catch {
|
|
882
|
+
// Ignore send errors
|
|
883
|
+
}
|
|
884
|
+
}
|
|
885
|
+
return count;
|
|
886
|
+
}
|
|
887
|
+
/**
|
|
888
|
+
* Notify all connected terminal WebSocket clients that a data mutation
|
|
889
|
+
* was forwarded to the real dev server (seed-based scenario).
|
|
890
|
+
* The Terminal component relays this to editor.tsx to show a save banner.
|
|
891
|
+
*/
|
|
892
|
+
export function broadcastDataMutationForwarded(method, pathname) {
|
|
893
|
+
const msg = JSON.stringify({
|
|
894
|
+
type: 'data-mutation-forwarded',
|
|
895
|
+
method,
|
|
896
|
+
pathname,
|
|
897
|
+
});
|
|
898
|
+
let count = 0;
|
|
899
|
+
for (const session of sessions) {
|
|
900
|
+
try {
|
|
901
|
+
if (session.ws.readyState === WebSocket.OPEN) {
|
|
902
|
+
session.ws.send(msg);
|
|
903
|
+
count++;
|
|
904
|
+
}
|
|
905
|
+
}
|
|
906
|
+
catch {
|
|
907
|
+
// Ignore send errors
|
|
908
|
+
}
|
|
909
|
+
}
|
|
910
|
+
return count;
|
|
911
|
+
}
|
|
912
|
+
/**
|
|
913
|
+
* Show the results panel below the terminal in the Build tab.
|
|
914
|
+
* Triggered by Claude at end of step 12.
|
|
915
|
+
*/
|
|
916
|
+
export function broadcastShowResults() {
|
|
917
|
+
const msg = JSON.stringify({ type: 'show-results' });
|
|
918
|
+
let count = 0;
|
|
919
|
+
for (const session of sessions) {
|
|
920
|
+
try {
|
|
921
|
+
if (session.ws.readyState === WebSocket.OPEN) {
|
|
922
|
+
session.ws.send(msg);
|
|
923
|
+
count++;
|
|
924
|
+
}
|
|
925
|
+
}
|
|
926
|
+
catch {
|
|
927
|
+
// Ignore send errors
|
|
928
|
+
}
|
|
929
|
+
}
|
|
930
|
+
return count;
|
|
931
|
+
}
|
|
932
|
+
/**
|
|
933
|
+
* Hide the results panel (e.g. after Save & Commit).
|
|
934
|
+
*/
|
|
935
|
+
export function broadcastHideResults() {
|
|
936
|
+
const msg = JSON.stringify({ type: 'hide-results' });
|
|
937
|
+
let count = 0;
|
|
938
|
+
for (const session of sessions) {
|
|
939
|
+
try {
|
|
940
|
+
if (session.ws.readyState === WebSocket.OPEN) {
|
|
941
|
+
session.ws.send(msg);
|
|
942
|
+
count++;
|
|
943
|
+
}
|
|
944
|
+
}
|
|
945
|
+
catch {
|
|
946
|
+
// Ignore send errors
|
|
947
|
+
}
|
|
948
|
+
}
|
|
949
|
+
return count;
|
|
950
|
+
}
|
|
951
|
+
/**
|
|
952
|
+
* Notify the editor UI that the current feature is complete (after push/skip).
|
|
953
|
+
* The UI shows a transition overlay letting the user start fresh or continue.
|
|
954
|
+
*/
|
|
955
|
+
export function broadcastFeatureComplete() {
|
|
956
|
+
const msg = JSON.stringify({ type: 'feature-complete' });
|
|
957
|
+
let count = 0;
|
|
958
|
+
for (const session of sessions) {
|
|
959
|
+
try {
|
|
960
|
+
if (session.ws.readyState === WebSocket.OPEN) {
|
|
961
|
+
session.ws.send(msg);
|
|
962
|
+
count++;
|
|
963
|
+
}
|
|
964
|
+
}
|
|
965
|
+
catch {
|
|
966
|
+
// Ignore send errors
|
|
967
|
+
}
|
|
968
|
+
}
|
|
969
|
+
return count;
|
|
970
|
+
}
|
|
971
|
+
/**
|
|
972
|
+
* Send a set-viewport message to all connected terminal WebSocket clients.
|
|
973
|
+
* The Terminal component relays this to the parent page to update the preview viewport.
|
|
974
|
+
*/
|
|
975
|
+
export function broadcastSetViewport(viewport) {
|
|
976
|
+
const msg = JSON.stringify({ type: 'set-viewport', ...viewport });
|
|
701
977
|
let count = 0;
|
|
702
978
|
for (const session of sessions) {
|
|
703
979
|
try {
|