@codeyam/codeyam-cli 0.1.6 → 0.1.8
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 +6 -6
- package/analyzer-template/packages/ai/package.json +1 -1
- package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
- package/analyzer-template/packages/ai/src/lib/completionCall.ts +14 -2
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +27 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +78 -2
- package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +6 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +9 -1
- 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 +65 -28
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +83 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +23 -4
- package/analyzer-template/packages/aws/package.json +1 -1
- package/analyzer-template/packages/database/index.ts +1 -0
- package/analyzer-template/packages/database/package.json +3 -3
- package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
- package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +62 -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/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/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/kysely/db.d.ts +2 -0
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -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/editorScenariosTable.d.ts +20 -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 +45 -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/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/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/types/ProjectMetadata.d.ts +1 -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/types/ProjectMetadata.ts +1 -0
- package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
- package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -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/playwright/captureFromUrl.ts +89 -82
- package/analyzer-template/project/constructMockCode.ts +136 -43
- 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 +17 -0
- package/analyzer-template/project/writeScenarioComponents.ts +36 -7
- package/analyzer-template/tsconfig.json +13 -1
- package/background/src/lib/virtualized/project/constructMockCode.js +115 -34
- package/background/src/lib/virtualized/project/constructMockCode.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 +12 -0
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +29 -7
- package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
- package/codeyam-cli/scripts/apply-setup.js +208 -11
- package/codeyam-cli/scripts/apply-setup.js.map +1 -1
- package/codeyam-cli/src/cli.js +2 -0
- package/codeyam-cli/src/cli.js.map +1 -1
- package/codeyam-cli/src/commands/analyze.js +17 -7
- package/codeyam-cli/src/commands/analyze.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +58 -3
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/editor.js +1839 -0
- package/codeyam-cli/src/commands/editor.js.map +1 -0
- package/codeyam-cli/src/commands/init.js +40 -11
- package/codeyam-cli/src/commands/init.js.map +1 -1
- package/codeyam-cli/src/commands/memory.js +26 -2
- package/codeyam-cli/src/commands/memory.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +246 -0
- package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +126 -0
- package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +295 -0
- package/codeyam-cli/src/utils/__tests__/editorJournal.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 +100 -0
- package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +147 -0
- package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +76 -0
- package/codeyam-cli/src/utils/__tests__/editorScenarios.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__/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__/scenarioMarkers.test.js +121 -0
- package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +26 -0
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
- package/codeyam-cli/src/utils/backgroundServer.js +19 -3
- 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/editorAudit.js +82 -0
- package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
- package/codeyam-cli/src/utils/editorDevServer.js +98 -0
- package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
- package/codeyam-cli/src/utils/editorJournal.js +137 -0
- package/codeyam-cli/src/utils/editorJournal.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 +64 -0
- package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
- package/codeyam-cli/src/utils/editorPreview.js +66 -0
- package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
- package/codeyam-cli/src/utils/editorScenarios.js +56 -0
- package/codeyam-cli/src/utils/editorScenarios.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/git.js +103 -0
- package/codeyam-cli/src/utils/git.js.map +1 -1
- package/codeyam-cli/src/utils/install-skills.js +55 -13
- 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/pathIgnoring.js +19 -7
- package/codeyam-cli/src/utils/pathIgnoring.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 +70 -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/scenarioMarkers.js +134 -0
- package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
- package/codeyam-cli/src/utils/serverState.js +27 -2
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +45 -4
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.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/webappDetection.js +14 -2
- package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
- package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
- package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
- package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
- package/codeyam-cli/src/webserver/backgroundServer.js +109 -19
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-CtmbP4Gl.js → CopyButton-DmJveP3T.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DlMph_Hm.js → EntityItem-C76mRRiF.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-B-0PjGOU.js → EntityTypeBadge-g3saevPb.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-DN9eiJAO.js → EntityTypeIcon-CobE682z.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-rE_fI2h2.js → InteractivePreview-DYFW3lDD.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CnatsCw2.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-CSP6DZrh.js → LoadingDots-BU_OAEMP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CMK8Q7yk.js → LogViewer-ceAyBX-H.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-TCV_HBjy.js → ReportIssueModal-djPLI-WV.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CG2uh31y.js → SafeScreenshot-BED4B6sP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-CU_TDYd8.js → ScenarioViewer-B76aig_2.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/Terminal-Dnj5CY9R.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-D7IoaWUW.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{_index-B8z7mjR-.js → _index-C96V0n15.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-DZu78RI1.js → activity.(_tab)-BpKzcsJz.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-D9hemwl6.js +22 -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-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-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-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/{book-open-Bp5FLkd4.js → book-open-D_nMCFmP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-DQJA9f4o.js → chevron-down-BH2h1Ea2.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-7VptmeIr.js → chunk-JZWAC4HX-C4pqxYJB.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-B6C4LY9o.js → circle-check-DyIKORY6.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{copy-6nzYCu0G.js → copy-NDbZjXao.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-D-QUFOwe.js → createLucideIcon-CMT1jU2q.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/editor-D1DAKXtT.js +8 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._--zvFJ4OH.js → entity._sha._-CrjR3zZW.js} +10 -10
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-DkzqFzFj.js +6 -0
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.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-C7ysA4Jq.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CU6EUArK.js → entry.client-DTvKq3TY.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-EWpfFU4X.js → fileTableUtils-cPo8LiG3.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{files-CrxAoWIL.js → files-DO4CZ16O.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{git-BldHtKeW.js → git-CFCTYk9I.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/globals-B17TBSS6.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-7-1FmlHo.js → index-10oVnAAH.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{index-DuYcwYp_.js → index-BcvgDzbZ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{labs-CPPVOSWB.js → labs-Zk7ryIM1.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BnDcD54R.js → loader-circle-BAXYRVEO.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-a632de18.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-Dg0mvYrI.js +96 -0
- package/codeyam-cli/src/webserver/build/client/assets/{pause-DhQX2g22.js → pause-DTAcYxBt.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/root-DUKqhFlb.js +67 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-DborVoKD.js → search-fKo7v0Zo.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{simulations-BtrtCYJg.js → simulations-B3aOzpCZ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{terminal-Bs4NC-VZ.js → terminal-BG4heKCG.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-DTf3Jojp.js → triangle-alert-DtSmdtM4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-D_bDZyDU.js → useCustomSizes-ByhSyh0W.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
- package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-BsQb6rFd.js → useReportContext-O-jkvSPx.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-BOur3mUv.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-HfLydfDq.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-CUu_F-oo.js +366 -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 +440 -0
- package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
- package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +175 -0
- package/codeyam-cli/src/webserver/scripts/journalCapture.ts +140 -0
- package/codeyam-cli/src/webserver/server.js +226 -1
- package/codeyam-cli/src/webserver/server.js.map +1 -1
- package/codeyam-cli/src/webserver/terminalServer.js +698 -0
- package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
- package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
- package/codeyam-cli/templates/editor-step-hook.py +147 -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/PRISMA_SETUP.md +84 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -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 +19 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +43 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +35 -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 +37 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
- package/codeyam-cli/templates/prompts/conversation-guidance.txt +12 -0
- package/codeyam-cli/templates/prompts/conversation-prompt.txt +3 -3
- package/codeyam-cli/templates/prompts/interruption-prompt.txt +3 -3
- package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +3 -3
- package/codeyam-cli/templates/rule-notification-hook.py +44 -17
- package/codeyam-cli/templates/rule-reflection-hook.py +24 -4
- package/codeyam-cli/templates/rules-instructions.md +4 -3
- package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
- package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +69 -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.sh +108 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh +69 -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/session-mining/analyze-prompt.md +46 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.sh +12 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter.jq +45 -0
- package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.sh +139 -0
- package/package.json +4 -2
- 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/completionCall.js +10 -2
- package/packages/ai/src/lib/completionCall.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +21 -0
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
- 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/stripNullableMarkers.js +34 -0
- package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
- package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/analyze/src/lib/ProjectAnalyzer.js +3 -0
- package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +8 -1
- 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 +54 -27
- package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +65 -0
- package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +18 -4
- package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
- package/packages/database/index.js +1 -0
- package/packages/database/index.js.map +1 -1
- package/packages/database/src/lib/kysely/db.js +5 -0
- package/packages/database/src/lib/kysely/db.js.map +1 -1
- package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
- package/packages/database/src/lib/kysely/tables/editorScenariosTable.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/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/scripts/npm-post-install.cjs +34 -0
- package/codeyam-cli/src/webserver/app/routes/api.agent-transcripts.js +0 -486
- package/codeyam-cli/src/webserver/app/routes/api.agent-transcripts.js.map +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C1rIyZdV.js +0 -34
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DxCa1oBt.js +0 -23
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-DmzSmblj.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DVTcUnur.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-BVgNO76F.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/globals-B4MPiL7S.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-c1fc3656.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/memory-CfpYxpNu.js +0 -93
- package/codeyam-cli/src/webserver/build/client/assets/root-CAAbm4U5.js +0 -62
- package/codeyam-cli/src/webserver/build/client/assets/settings-BpLDWmGh.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DZp6rrQD.js +0 -2
- package/codeyam-cli/src/webserver/build/server/assets/index-B8A_aaGG.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-69rRZnZo.js +0 -286
- 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
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: codeyam-dev-mode
|
|
3
|
+
autoApprove: true
|
|
4
|
+
description: |
|
|
5
|
+
Use this skill when working in CodeYam Dev Mode — an interactive environment for iterating on
|
|
6
|
+
components and scenarios with a live preview panel alongside a Claude Code terminal.
|
|
7
|
+
Use when: The embedded terminal in Dev Mode auto-invokes this skill to provide entity/scenario context.
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# CodeYam Dev Mode
|
|
11
|
+
|
|
12
|
+
You are working inside CodeYam Dev Mode — a split-screen environment with this Claude Code terminal on the left and a live preview on the right.
|
|
13
|
+
|
|
14
|
+
## Step 1: Read Session Context
|
|
15
|
+
|
|
16
|
+
Read the dev mode context file to understand the current entity and scenario:
|
|
17
|
+
|
|
18
|
+
```
|
|
19
|
+
cat .codeyam/dev-mode-context.md
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
The context file contains all the specific paths you need — source file, mock data, dev server project, and **server log**. All paths are fully resolved; no placeholders to fill in.
|
|
23
|
+
|
|
24
|
+
## Step 2: Gather Context While Server Sets Up
|
|
25
|
+
|
|
26
|
+
The dev server needs time to set up the sandboxed project (copying files, installing deps, starting Vite). The mock data files in the tmp project **do not exist yet** when you first start. Use this time productively.
|
|
27
|
+
|
|
28
|
+
**Do these in parallel:**
|
|
29
|
+
|
|
30
|
+
1. **Read the source file** from the real repo (exists immediately).
|
|
31
|
+
|
|
32
|
+
2. **Query the database** for all scenarios belonging to this entity's analysis. Use the **Analysis ID** from the context file:
|
|
33
|
+
|
|
34
|
+
```
|
|
35
|
+
sqlite3 .codeyam/db.sqlite3 "SELECT name, description FROM scenarios WHERE analysis_id = '<ANALYSIS_ID>'"
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
Each scenario's `description` explains what data shape it tests — e.g. "empty list", "many items", "error state". This tells you what data attributes matter most for the component's visual states.
|
|
39
|
+
|
|
40
|
+
3. **Monitor the server log** listed in the context file under **Server log**:
|
|
41
|
+
|
|
42
|
+
```
|
|
43
|
+
tail -f <server log path from context file>
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
Wait until you see a local URL like `http://localhost:...` indicating the Vite server has started. Do NOT try to read mock data or other files from the tmp project until the logs confirm setup is complete.
|
|
47
|
+
|
|
48
|
+
## Step 3: Read Mock Data and Present Overview
|
|
49
|
+
|
|
50
|
+
Once the dev server is ready, read the **mock data file** from the tmp project path listed in the context file.
|
|
51
|
+
|
|
52
|
+
Then present a **concise** overview to the user:
|
|
53
|
+
|
|
54
|
+
1. **Component Summary** — 2-3 sentences on what the component does and the current scenario being previewed.
|
|
55
|
+
|
|
56
|
+
2. **Suggested Tests** — Compare the component's code paths (conditionals, edge cases, visual states) against the existing scenarios from the database. Recommend 2-4 specific ways to test the component that are **not yet covered** by saved scenarios. Focus on interesting visual states — e.g. "What does this look like with a very long title?", "What happens when the list is empty?", "How does the error state render?". Be specific to this component, not generic.
|
|
57
|
+
|
|
58
|
+
Keep it brief — no tables, no exhaustive attribute lists. The user can see the preview and wants actionable suggestions, not a data dump.
|
|
59
|
+
|
|
60
|
+
## How Dev Mode Works
|
|
61
|
+
|
|
62
|
+
**Layout:**
|
|
63
|
+
|
|
64
|
+
- **Left panel** — This Claude Code terminal (you)
|
|
65
|
+
- **Right panel** — Live preview iframe showing the rendered component/scenario
|
|
66
|
+
|
|
67
|
+
**Architecture:**
|
|
68
|
+
|
|
69
|
+
- The preview runs from a sandboxed project at the tmp path listed in the context file
|
|
70
|
+
- Source code edits in the real repo auto-sync to the preview via HMR (hot module replacement)
|
|
71
|
+
- Mock data files live in the tmp project under `__codeyamMocks__/`
|
|
72
|
+
|
|
73
|
+
**What you can edit:**
|
|
74
|
+
|
|
75
|
+
- **Source code** (the entity's file in the real repo) — edits sync automatically to the preview
|
|
76
|
+
- **Mock data** (the `MockData_*.tsx` file in the tmp project) — edits also sync via HMR
|
|
77
|
+
- Both types of edits show up in the preview almost instantly
|
|
78
|
+
|
|
79
|
+
**CRITICAL — What you must NEVER edit for functional changes:**
|
|
80
|
+
|
|
81
|
+
- **Shimmed component files** (`*_Scenario.tsx` in the tmp project) — these are auto-generated files that wire up the component with mocked dependencies. **NEVER modify these to change what renders.** Any functional changes you make here:
|
|
82
|
+
- Will be lost when the scenario is recaptured or regenerated
|
|
83
|
+
- Cannot be saved as a scenario (only mock data is persisted to the database)
|
|
84
|
+
- Break the ability to reproduce the scenario in the future
|
|
85
|
+
- To change what the component displays, **always edit the `MockData_*.tsx` file**. The shimmed component reads mock data via `scenarios().data()` — that's the mechanism for controlling component behavior and visual state.
|
|
86
|
+
- The ONLY acceptable edit to a shimmed component file is adding temporary `console.log` statements for debugging (see Client-Side Logging below). Never change imports, state initialization, hooks, memos, or rendering logic.
|
|
87
|
+
|
|
88
|
+
## Workflow
|
|
89
|
+
|
|
90
|
+
1. Read the context file (`.codeyam/dev-mode-context.md`)
|
|
91
|
+
2. While dev server sets up, do in parallel:
|
|
92
|
+
- Read the source file (from real repo — available immediately)
|
|
93
|
+
- Query database for scenario names/descriptions (available immediately)
|
|
94
|
+
- Monitor server log until dev server is ready
|
|
95
|
+
3. Read the mock data file (from tmp project — only after setup completes)
|
|
96
|
+
4. Present concise overview: component summary + suggested untested scenarios
|
|
97
|
+
5. Ask the user what they want to change
|
|
98
|
+
6. Make incremental edits to **source code or mock data only** — the preview updates live
|
|
99
|
+
7. After making changes, refresh the preview (curl command from context file)
|
|
100
|
+
8. Iterate based on user feedback
|
|
101
|
+
|
|
102
|
+
## Client-Side Logging (Required)
|
|
103
|
+
|
|
104
|
+
**Always add `console.log` statements to trace the execution flow when making changes.** This is critical — you cannot see the preview, so logging is your only way to verify the component renders as expected.
|
|
105
|
+
|
|
106
|
+
Client-side `console.log` and `console.error` calls are automatically captured by the `/api/client-log` endpoint and written to the server log file. This means you can add logging in component code and read it from the server log.
|
|
107
|
+
|
|
108
|
+
**When to add logging:**
|
|
109
|
+
|
|
110
|
+
- Before and after every change you make to the shimmed component or mock data
|
|
111
|
+
- At key data flow checkpoints: after state initialization, after useMemo computations, before the render return
|
|
112
|
+
- In useEffect callbacks to confirm they fire
|
|
113
|
+
- Around conditional branches you're targeting (e.g. "this condition should now be true")
|
|
114
|
+
|
|
115
|
+
**How to log:**
|
|
116
|
+
|
|
117
|
+
Add `console.log` with a `[CY-DEBUG]` prefix in the shimmed component file (the `*_Default_Scenario.tsx` file in the tmp project). **This is the ONLY acceptable edit to shimmed component files — temporary debug logging. Never change the component's logic, imports, state, or rendering in these files.**
|
|
118
|
+
|
|
119
|
+
```typescript
|
|
120
|
+
// After state declarations:
|
|
121
|
+
console.log(
|
|
122
|
+
'[CY-DEBUG] render: myState:',
|
|
123
|
+
myState?.length,
|
|
124
|
+
'otherData:',
|
|
125
|
+
otherData,
|
|
126
|
+
);
|
|
127
|
+
|
|
128
|
+
// Inside useEffect:
|
|
129
|
+
useEffect(() => {
|
|
130
|
+
console.log('[CY-DEBUG] useEffect fired, setting data');
|
|
131
|
+
// ...
|
|
132
|
+
}, []);
|
|
133
|
+
|
|
134
|
+
// Before return:
|
|
135
|
+
console.log(
|
|
136
|
+
'[CY-DEBUG] PRE-RENDER: showThumbnails:',
|
|
137
|
+
items?.length > 0,
|
|
138
|
+
'showLoader:',
|
|
139
|
+
!items,
|
|
140
|
+
);
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
**After refreshing, always check the log** for your `[CY-DEBUG]` lines:
|
|
144
|
+
|
|
145
|
+
```
|
|
146
|
+
tail -30 <server log path from context file>
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
If you don't see your debug logs but see `[CLIENT CONSOLE.ERROR]` or `Application Error`, the component is crashing before your code runs. Read the error stack trace to find the failing component.
|
|
150
|
+
|
|
151
|
+
**Keep logging in place** as you iterate — it costs nothing and saves significant debugging time.
|
|
152
|
+
|
|
153
|
+
## Refreshing the Preview
|
|
154
|
+
|
|
155
|
+
After making changes, refresh the live preview so it picks up your edits. The exact curl command is in the context file under **Server > Refresh preview** — copy and run it:
|
|
156
|
+
|
|
157
|
+
```
|
|
158
|
+
curl -s -X POST http://localhost:<port>/api/dev-mode-preview
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
**Always refresh after making changes.** This triggers the preview iframe to reload, **clears the server log file**, waits for the page to re-render, and then fetches the preview URL to check for SSR errors.
|
|
162
|
+
|
|
163
|
+
**The response includes preview health info.** Check the `preview` field in the JSON response:
|
|
164
|
+
|
|
165
|
+
```json
|
|
166
|
+
{
|
|
167
|
+
"success": true,
|
|
168
|
+
"sessionsNotified": 1,
|
|
169
|
+
"logCleared": true,
|
|
170
|
+
"preview": {
|
|
171
|
+
"status": 200,
|
|
172
|
+
"healthy": true
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
If the preview is unhealthy (e.g., SSR error caught by an error boundary), the response will include the error:
|
|
178
|
+
|
|
179
|
+
```json
|
|
180
|
+
{
|
|
181
|
+
"preview": {
|
|
182
|
+
"status": 500,
|
|
183
|
+
"healthy": false,
|
|
184
|
+
"error": "ReferenceError: myVariable is not defined\n at Component (/path/to/file.tsx:42:5)"
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
**After every refresh:**
|
|
190
|
+
|
|
191
|
+
1. **Check `preview.healthy`** in the JSON response. If `false`, the `error` field contains the SSR error — fix it before proceeding.
|
|
192
|
+
2. **Check the log** for your `[CY-DEBUG]` lines to confirm the execution path:
|
|
193
|
+
|
|
194
|
+
```
|
|
195
|
+
tail -30 <server log path from context file>
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
If the preview was unhealthy, the log will also contain `[DEV-MODE-CHECK]` lines with the error details.
|
|
199
|
+
|
|
200
|
+
Look for your `[CY-DEBUG]` lines to confirm the execution path. If you see errors instead, the component is crashing. If you see nothing, the page may still be loading — wait a moment and check again.
|
|
201
|
+
|
|
202
|
+
## Debugging with Server Logs
|
|
203
|
+
|
|
204
|
+
The **Server log** path in the context file captures all output from the dev server process — Vite compilation errors, SSR errors, HMR updates, and runtime warnings. **Client-side errors** (React rendering errors, unhandled exceptions, console.error calls) are also automatically reported to this log via the `/api/client-log` endpoint. This means both server and client errors appear in the same log file.
|
|
205
|
+
|
|
206
|
+
Since the log is **cleared on every refresh**, you always see fresh output. No need to scroll past old errors.
|
|
207
|
+
|
|
208
|
+
**When to check the server log:**
|
|
209
|
+
|
|
210
|
+
- **After every refresh** — always verify your debug logs appear and no errors are present
|
|
211
|
+
- The preview shows a blank page, error boundary, or 500 error
|
|
212
|
+
- HMR updates aren't taking effect after edits
|
|
213
|
+
- The preview is stuck loading or shows unexpected content
|
|
214
|
+
|
|
215
|
+
**How to check:**
|
|
216
|
+
|
|
217
|
+
```
|
|
218
|
+
tail -50 <server log path from context file>
|
|
219
|
+
```
|
|
220
|
+
|
|
221
|
+
**What to look for:**
|
|
222
|
+
|
|
223
|
+
- `[CY-DEBUG]` — your trace logs confirming the execution path and data values
|
|
224
|
+
- `[CLIENT CONSOLE.ERROR]` — client-side React errors or unhandled exceptions
|
|
225
|
+
- `[vite]` error messages — TypeScript compilation failures
|
|
226
|
+
- `Application Error` — React error boundary activated (component crashed during render)
|
|
227
|
+
- No output at all — the page hasn't loaded yet, or the component never rendered
|
|
228
|
+
|
|
229
|
+
## Tips
|
|
230
|
+
|
|
231
|
+
- **NEVER modify shimmed component files** (`*_Scenario.tsx`) to change rendering behavior — only edit `MockData_*.tsx` files to change what the component displays. Shimmed components are auto-generated; functional changes to them won't persist and can't be saved as scenarios.
|
|
232
|
+
- Keep edits small and incremental so the user can see changes in the preview as you go
|
|
233
|
+
- **Always add `[CY-DEBUG]` logging before refreshing** — never refresh without a way to verify the result
|
|
234
|
+
- Mock data files are TypeScript (`.tsx`) — they export scenario-specific props/data
|
|
235
|
+
- The database at `.codeyam/db.sqlite3` has entity and scenario metadata if you need deeper investigation
|
|
236
|
+
- If the preview breaks, check the server log (path in context file) for compilation or runtime errors
|
|
237
|
+
- You can also modify other files in the repo that the entity imports — those changes sync too
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: codeyam-editor
|
|
3
|
+
autoApprove: true
|
|
4
|
+
description: CodeYam Editor Mode — scaffold a project and build code + data scenarios together
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# CodeYam Editor Mode
|
|
8
|
+
|
|
9
|
+
You are in **Editor Mode**. The user sees a split-screen: this terminal on the left, live preview on the right.
|
|
10
|
+
|
|
11
|
+
## CRITICAL: How This Works
|
|
12
|
+
|
|
13
|
+
You MUST follow a step-by-step workflow driven by `codeyam editor` commands. Each command tells you exactly what to do next. **You do NOT have all the instructions upfront** — the commands provide them incrementally.
|
|
14
|
+
|
|
15
|
+
**Your first action:** Run `codeyam editor`.
|
|
16
|
+
|
|
17
|
+
**The rule:** After completing what a command tells you to do, run the NEXT command it specifies. The commands are your instructions — follow them one at a time.
|
|
18
|
+
|
|
19
|
+
## The Cycle
|
|
20
|
+
|
|
21
|
+
Every feature follows 12 gated steps:
|
|
22
|
+
|
|
23
|
+
```
|
|
24
|
+
codeyam editor → Setup (if new) or cycle overview
|
|
25
|
+
codeyam editor 1 → Plan the feature (confirm with user)
|
|
26
|
+
codeyam editor 2 → Build a working prototype fast
|
|
27
|
+
codeyam editor 3 → Confirm prototype with user
|
|
28
|
+
codeyam editor 4 → Plan extraction (read code, list everything to extract)
|
|
29
|
+
codeyam editor 5 → Execute extraction (TDD for functions, extract components)
|
|
30
|
+
codeyam editor 6 → Record functions in glossary
|
|
31
|
+
codeyam editor 7 → Analyze and verify components
|
|
32
|
+
codeyam editor 8 → Create app-level scenarios
|
|
33
|
+
codeyam editor 9 → Create user-persona scenarios
|
|
34
|
+
codeyam editor 10 → Verify screenshots and check for errors
|
|
35
|
+
codeyam editor 11 → Create/update journal entry
|
|
36
|
+
codeyam editor 12 → Present summary, get final approval
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
**You MUST run each command and follow its checklist before moving to the next.** Steps 1, 3, and 12 require user confirmation. After step 12, loop back to step 1.
|
|
40
|
+
|
|
41
|
+
## Key Rules
|
|
42
|
+
|
|
43
|
+
- **Run the commands** — they ARE your instructions, not suggestions
|
|
44
|
+
- **Every feature gets scenarios** — this is the core value of CodeYam
|
|
45
|
+
- **Always scaffold with a database** (Prisma + SQLite)
|
|
46
|
+
- **Build real API routes** — the proxy handles scenario data transparently
|
|
47
|
+
- **Start the dev server via the CodeYam API** — it handles proxy setup automatically
|
|
48
|
+
- **Verify the preview after changes** — check the dev server URL, not the proxy
|
|
49
|
+
|
|
50
|
+
## Quick Reference
|
|
51
|
+
|
|
52
|
+
```bash
|
|
53
|
+
# Register scenario (auto-captures screenshot)
|
|
54
|
+
curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/editor-register-scenario \
|
|
55
|
+
-H 'Content-Type: application/json' \
|
|
56
|
+
-d '{"name":"...","description":"...","mockData":{"routes":{"/api/...":{"body":[...]}}}}'
|
|
57
|
+
|
|
58
|
+
# Journal entry (one per feature, references scenario names)
|
|
59
|
+
curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/editor-journal-entry \
|
|
60
|
+
-H 'Content-Type: application/json' \
|
|
61
|
+
-d '{"title":"...","type":"feature","description":"...","scenarios":["..."]}'
|
|
62
|
+
|
|
63
|
+
# Refresh preview
|
|
64
|
+
curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/dev-mode-preview
|
|
65
|
+
|
|
66
|
+
# Restart dev server (only for config/dependency changes)
|
|
67
|
+
curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/editor-dev-server \
|
|
68
|
+
-H 'Content-Type: application/json' -d '{"action":"restart"}'
|
|
69
|
+
```
|
|
@@ -208,6 +208,215 @@ Prioritize areas with stronger confusion signals:
|
|
|
208
208
|
|
|
209
209
|
Focus your documentation efforts on areas with the highest confusion scores.
|
|
210
210
|
|
|
211
|
+
Holistic source analysis signals (from the Holistic Source Analysis phase below) also feed into this scoring. Session mining signals (from the Session Log Mining phase below) feed into this same table.
|
|
212
|
+
|
|
213
|
+
---
|
|
214
|
+
|
|
215
|
+
## Phase 3B: Analysis Sizing & Menu
|
|
216
|
+
|
|
217
|
+
Before running the expensive LLM-powered analysis phases, run the fast extraction scripts to gather sizing metrics and let the user choose which phases to run.
|
|
218
|
+
|
|
219
|
+
### Step 1: Run fast extraction scripts (concurrent)
|
|
220
|
+
|
|
221
|
+
Clear stale data from any previous run, then run all three scripts in parallel:
|
|
222
|
+
|
|
223
|
+
```bash
|
|
224
|
+
rm -rf /tmp/codeyam-memory/ /tmp/cc-session-analysis/
|
|
225
|
+
```
|
|
226
|
+
|
|
227
|
+
```bash
|
|
228
|
+
bash .claude/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.sh
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
```bash
|
|
232
|
+
bash .claude/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh
|
|
233
|
+
```
|
|
234
|
+
|
|
235
|
+
```bash
|
|
236
|
+
bash .claude/skills/codeyam-memory/scripts/session-mining/preprocess.sh 2>/dev/null
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
Capture the stdout of `preprocess.sh` — each line is a path to a filtered session file.
|
|
240
|
+
|
|
241
|
+
### Step 2: Extract sizing metrics
|
|
242
|
+
|
|
243
|
+
Use quick `jq` one-liners to extract counts — do NOT read the full JSON files into the main context:
|
|
244
|
+
|
|
245
|
+
```bash
|
|
246
|
+
jq '.dependencies | length' /tmp/codeyam-memory/deprecated-scan.json
|
|
247
|
+
jq '.explicit_markers | length' /tmp/codeyam-memory/deprecated-scan.json
|
|
248
|
+
jq '.stats.total_exports' /tmp/codeyam-memory/exports-scan.json
|
|
249
|
+
jq '.stats.total_files' /tmp/codeyam-memory/exports-scan.json
|
|
250
|
+
```
|
|
251
|
+
|
|
252
|
+
The session count is the number of lines from `preprocess.sh` stdout.
|
|
253
|
+
|
|
254
|
+
**Time estimate formulas:**
|
|
255
|
+
|
|
256
|
+
| Phase | Formula | Example |
|
|
257
|
+
| ------------------------ | --------------------------------------- | ----------------------- |
|
|
258
|
+
| Holistic source analysis | `3 + (total_exports / 500)` min, cap 12 | 3,470 exports → ~10 min |
|
|
259
|
+
| Session log mining | `1 + (sessions × 0.25)` min, cap 12 | 25 sessions → ~7 min |
|
|
260
|
+
|
|
261
|
+
### Step 3: Present the menu
|
|
262
|
+
|
|
263
|
+
Use `AskUserQuestion` with `multiSelect: true`. Include actual numbers from Step 2:
|
|
264
|
+
|
|
265
|
+
> **Which additional analysis phases would you like to run?**
|
|
266
|
+
>
|
|
267
|
+
> 📦 **Holistic Source Analysis** — {exports} exports across {files} files, {deps} dependencies, {markers} deprecation markers. Estimated: ~{N} min
|
|
268
|
+
>
|
|
269
|
+
> 💬 **Session Log Mining** — {sessions} qualifying sessions found. Estimated: ~{N} min
|
|
270
|
+
|
|
271
|
+
Options (as `multiSelect: true`):
|
|
272
|
+
|
|
273
|
+
- **Holistic Source Analysis (~N min)** — "Deep-read exports to find misleading APIs and deprecated patterns"
|
|
274
|
+
- **Session Log Mining (~N min)** — "Mine Claude session history for confusion signals"
|
|
275
|
+
- **Skip both** — "Proceed with git archaeology results only"
|
|
276
|
+
|
|
277
|
+
Omit any option where the data count is zero (e.g., if no sessions qualify, don't show the session mining option). If both counts are zero, skip the menu entirely and proceed to Phase 4.
|
|
278
|
+
|
|
279
|
+
### Step 4: Execute selected phases
|
|
280
|
+
|
|
281
|
+
Based on the user's selection:
|
|
282
|
+
|
|
283
|
+
- **Holistic Source Analysis selected:** Jump to the "Holistic Source Analysis" section below, starting at **Step 2** (scripts already ran in Step 1 above).
|
|
284
|
+
- **Session Log Mining selected:** Jump to the "Session Log Mining" section below, starting at **Step 2** (preprocessing already ran in Step 1 above). Use the session file paths captured in Step 1.
|
|
285
|
+
- **Both selected:** Run both, starting each at Step 2.
|
|
286
|
+
- **Skip both:** Proceed directly to Phase 4.
|
|
287
|
+
|
|
288
|
+
### Step 5: Cleanup
|
|
289
|
+
|
|
290
|
+
Regardless of what the user selected, clean up temporary files before proceeding to Phase 4:
|
|
291
|
+
|
|
292
|
+
```bash
|
|
293
|
+
rm -rf /tmp/codeyam-memory/ /tmp/cc-session-analysis/
|
|
294
|
+
```
|
|
295
|
+
|
|
296
|
+
---
|
|
297
|
+
|
|
298
|
+
## Additional Analysis Phase: Holistic Source Analysis
|
|
299
|
+
|
|
300
|
+
Holistic analysis reads the codebase cross-cuttingly to find **latent confusion** — problems
|
|
301
|
+
that haven't caused bugs yet but will mislead a future agent reading code locally.
|
|
302
|
+
|
|
303
|
+
### Prerequisites
|
|
304
|
+
|
|
305
|
+
- Project must contain `.ts`, `.tsx`, `.js`, or `.jsx` source files
|
|
306
|
+
- If no source files are found, skip this phase entirely
|
|
307
|
+
|
|
308
|
+
### Step 1: Run extraction scripts
|
|
309
|
+
|
|
310
|
+
Handled by Phase 3B. Proceed to Step 2.
|
|
311
|
+
|
|
312
|
+
### Step 2: Launch analysis subagents (concurrent)
|
|
313
|
+
|
|
314
|
+
Read the prompt templates and launch both as Task agents concurrently. **Do NOT read the
|
|
315
|
+
scan data into the main context** — it can be hundreds of KB. Each subagent reads its own
|
|
316
|
+
data file via the Read tool.
|
|
317
|
+
|
|
318
|
+
1. **Deprecated Pattern agent** — Read `.claude/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md` for the
|
|
319
|
+
prompt template. Launch as a foreground Task agent (model: sonnet) with the prompt template
|
|
320
|
+
content. The agent reads `/tmp/codeyam-memory/deprecated-scan.json` itself, uses Grep to
|
|
321
|
+
find remaining callsites, and returns its findings JSON in the response.
|
|
322
|
+
|
|
323
|
+
2. **Misleading API agent** — Read `.claude/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md` for the
|
|
324
|
+
prompt template. Launch as a foreground Task agent (model: sonnet) with the prompt template
|
|
325
|
+
content. The agent reads `/tmp/codeyam-memory/exports-scan.json` itself, uses Read to
|
|
326
|
+
inspect suspicious functions, and returns its findings JSON in the response.
|
|
327
|
+
|
|
328
|
+
Both agents return their findings JSON and a brief summary directly in their response.
|
|
329
|
+
|
|
330
|
+
**Context budget note:** The exports index alone can be 400KB+. Never read it into the main
|
|
331
|
+
context. Subagents run as foreground Task agents and have full filesystem access including
|
|
332
|
+
`/tmp/`.
|
|
333
|
+
|
|
334
|
+
### Step 3: Integrate findings
|
|
335
|
+
|
|
336
|
+
Parse the findings JSON from each subagent's response. For each finding:
|
|
337
|
+
|
|
338
|
+
- **Deprecated patterns** get confusion score **4** (comparable to "workaround/hack" signal).
|
|
339
|
+
If an explicit `@deprecated` marker exists, bump to **5**.
|
|
340
|
+
- **Misleading APIs** get confusion score **4** for medium severity, **6** for high severity
|
|
341
|
+
(where "high" means the mismatch could cause data corruption or silent failures).
|
|
342
|
+
|
|
343
|
+
Add findings to the evidence pool alongside git archaeology results. They flow into
|
|
344
|
+
Phase 4 (evidence-based user questions) and Phase 5 (rule generation) normally.
|
|
345
|
+
|
|
346
|
+
### Step 4: Cleanup
|
|
347
|
+
|
|
348
|
+
Handled by Phase 3B Step 5.
|
|
349
|
+
|
|
350
|
+
---
|
|
351
|
+
|
|
352
|
+
## Additional Analysis Phase: Session Log Mining
|
|
353
|
+
|
|
354
|
+
This phase mines Claude Code session transcripts for empirical confusion: user corrections, wrong assumptions, re-edits, tribal knowledge gaps. It complements the git archaeology in Phase 2 with direct evidence from actual Claude sessions.
|
|
355
|
+
|
|
356
|
+
### Step 1: Preprocess Sessions
|
|
357
|
+
|
|
358
|
+
Handled by Phase 3B. Use the session file paths captured there.
|
|
359
|
+
|
|
360
|
+
### Step 2: Launch Haiku Subagents
|
|
361
|
+
|
|
362
|
+
Read the prompt template from `.claude/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md`.
|
|
363
|
+
|
|
364
|
+
For each filtered session file from Step 1:
|
|
365
|
+
|
|
366
|
+
- If the file is **<200KB**: launch one Haiku Task agent
|
|
367
|
+
- If the file is **>200KB**: chunk into ~200KB segments, launch one agent per chunk
|
|
368
|
+
|
|
369
|
+
**Do NOT read session files into the main context** — they can be 20-40KB each and will
|
|
370
|
+
exhaust the context window. Each subagent reads its own file via the Read tool. Each agent
|
|
371
|
+
receives:
|
|
372
|
+
|
|
373
|
+
1. The prompt template content
|
|
374
|
+
2. The `/tmp/` file path to read (the agent reads it itself)
|
|
375
|
+
3. Instruction to return a JSON array
|
|
376
|
+
|
|
377
|
+
Launch agents in batches of **10** using the Task tool with `model: "haiku"`. **Use unique descriptions** for each agent (e.g., "Session mining batch 1 - session 1", "Session mining batch 1 - session 2", etc.; increment the batch number for each batch of 10). Wait for each batch to complete before launching the next. This keeps machine load manageable — a poweruser may have 30+ sessions qualifying.
|
|
378
|
+
|
|
379
|
+
### Step 3: Collect and Validate Findings
|
|
380
|
+
|
|
381
|
+
Parse each agent's response as JSON. Validate:
|
|
382
|
+
|
|
383
|
+
- Must be an array
|
|
384
|
+
- Each element must have `signal` and `summary` fields
|
|
385
|
+
- `signal` must be one of: `USER_CORRECTION`, `RE_EDIT`, `FAILED_PIVOT`, `WRONG_ASSUMPTION`, `TRIBAL_KNOWLEDGE`, `APPROACH_PIVOT`
|
|
386
|
+
|
|
387
|
+
If >50% of agents return invalid output, warn the user before continuing. Otherwise, silently skip invalid results.
|
|
388
|
+
|
|
389
|
+
**Filter out environment-specific findings.** Discard any finding that relates to the developer's local machine setup rather than the project's codebase — e.g., bare repo checkout layouts, local tool versions, IDE configuration, shell aliases, filesystem paths, or permission issues. The rules we generate must be useful to _any_ developer cloning the repo, not just the one whose sessions we mined.
|
|
390
|
+
|
|
391
|
+
### Step 4: Deduplicate Across Sessions
|
|
392
|
+
|
|
393
|
+
Three-pass merge:
|
|
394
|
+
|
|
395
|
+
1. **Cluster by `topic`** — group all findings with the same topic label
|
|
396
|
+
2. **Rank within each cluster** — priority order: `USER_CORRECTION` > `TRIBAL_KNOWLEDGE` > `WRONG_ASSUMPTION` > `FAILED_PIVOT` > `RE_EDIT` > `APPROACH_PIVOT`
|
|
397
|
+
3. **Count session occurrences** — add `session_count` to each merged finding
|
|
398
|
+
|
|
399
|
+
Output: one merged finding per topic, with `session_count`, strongest signal type, and collected file paths.
|
|
400
|
+
|
|
401
|
+
### Step 5: Feed into Phase 3 Scoring
|
|
402
|
+
|
|
403
|
+
Additional scoring weights for session-mining signals:
|
|
404
|
+
|
|
405
|
+
| Signal | Weight |
|
|
406
|
+
| ----------------------------------- | -------- |
|
|
407
|
+
| User correction (session) | 7 |
|
|
408
|
+
| Tribal knowledge provided (session) | 6 |
|
|
409
|
+
| Wrong assumption caught (session) | 5 |
|
|
410
|
+
| Re-edit of same file (session) | 4 |
|
|
411
|
+
| Failed-then-pivoted (session) | 3 |
|
|
412
|
+
| Appearing in 3+ sessions | +3 bonus |
|
|
413
|
+
|
|
414
|
+
These merge into the Phase 3 scoring table above. Session-mined findings then flow into Phase 4 (evidence-based questions) and Phase 5 (rule generation) alongside git archaeology findings.
|
|
415
|
+
|
|
416
|
+
### Step 6: Cleanup
|
|
417
|
+
|
|
418
|
+
Handled by Phase 3B Step 5.
|
|
419
|
+
|
|
211
420
|
---
|
|
212
421
|
|
|
213
422
|
## Phase 4: Ask Evidence-Based Questions
|
|
@@ -282,6 +491,12 @@ Before generating each rule, verify it passes these tests:
|
|
|
282
491
|
- If YES → definitely document it
|
|
283
492
|
- If NO → reconsider its value
|
|
284
493
|
|
|
494
|
+
**For holistic analysis findings**, the validation checks apply with these adjustments:
|
|
495
|
+
|
|
496
|
+
- **Evidence check:** Satisfied by structural evidence from source analysis (e.g., "name implies pure computation but implementation writes to cache on line 47") rather than git commit history.
|
|
497
|
+
- **Code-derivable check:** These findings ARE derived from code — but from a cross-cutting read that a local reader wouldn't perform. The rule is valuable if it captures insight that requires reading multiple files or tracing non-obvious call chains.
|
|
498
|
+
- **Prevention check:** "Would this rule prevent a future agent from being misled?" rather than "would it have prevented a past commit?"
|
|
499
|
+
|
|
285
500
|
### Rule Quality Examples
|
|
286
501
|
|
|
287
502
|
**✅ Good rule** (passes all tests):
|
package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md
ADDED
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
# Deprecated Pattern Analysis
|
|
2
|
+
|
|
3
|
+
You are analyzing a codebase for **deprecated patterns** — situations where two approaches to the same problem coexist, with one fading in favor of another. These create confusion because a coding agent reading locally may follow the old pattern.
|
|
4
|
+
|
|
5
|
+
## Input
|
|
6
|
+
|
|
7
|
+
Read the scan data from `/tmp/codeyam-memory/deprecated-scan.json`. It contains:
|
|
8
|
+
|
|
9
|
+
- `dependencies`: All npm dependency names from the project
|
|
10
|
+
- `explicit_markers`: Lines containing `@deprecated`, `// legacy`, etc., with file, line number, and text
|
|
11
|
+
- `git_recency`: Per-dependency counts of `recent_imports` (last 3 months) vs `old_imports` (3–12 months ago)
|
|
12
|
+
|
|
13
|
+
## Analysis Steps
|
|
14
|
+
|
|
15
|
+
### 1. Dependency Overlap Analysis
|
|
16
|
+
|
|
17
|
+
Review the full dependency list and identify pairs or groups that serve **overlapping purposes**. Use your domain knowledge of the npm ecosystem — don't rely on name similarity alone.
|
|
18
|
+
|
|
19
|
+
Common overlap categories:
|
|
20
|
+
|
|
21
|
+
- **ORMs / query builders**: knex, kysely, prisma, drizzle, typeorm, sequelize, supabase-js (when used for queries)
|
|
22
|
+
- **Date libraries**: moment, dayjs, date-fns, luxon
|
|
23
|
+
- **HTTP clients**: axios, got, node-fetch, ky, superagent, undici
|
|
24
|
+
- **State management**: redux, zustand, jotai, recoil, mobx, valtio
|
|
25
|
+
- **Schema validation**: zod, yup, joi, ajv, io-ts, superstruct, valibot
|
|
26
|
+
- **CSS-in-JS / styling**: styled-components, emotion, tailwind, vanilla-extract, stitches
|
|
27
|
+
- **Testing**: jest, vitest, mocha, ava
|
|
28
|
+
- **Bundlers**: webpack, vite, esbuild, rollup, parcel, turbopack
|
|
29
|
+
- **Logging**: winston, pino, bunyan, log4js
|
|
30
|
+
|
|
31
|
+
Also look for:
|
|
32
|
+
|
|
33
|
+
- Internal packages that wrap the same underlying library differently
|
|
34
|
+
- Old utility files alongside newer replacements
|
|
35
|
+
|
|
36
|
+
### 2. Cross-Reference with Git Recency
|
|
37
|
+
|
|
38
|
+
For each overlapping pair you identified, check the `git_recency` data:
|
|
39
|
+
|
|
40
|
+
- Is one dependency's import count **growing** (more recent than old) while the other is **fading** (fewer recent than old)?
|
|
41
|
+
- A clear growth-vs-fade pattern confirms a migration in progress.
|
|
42
|
+
- If both are stable or both are growing, it may be intentional coexistence rather than a migration.
|
|
43
|
+
|
|
44
|
+
### 3. Cross-Reference with Explicit Markers
|
|
45
|
+
|
|
46
|
+
Check if any `@deprecated` or `// legacy` markers corroborate your dependency findings:
|
|
47
|
+
|
|
48
|
+
- A marker on code that imports the fading dependency strengthens the signal
|
|
49
|
+
- A marker on a wrapper/utility that abstracts one of the approaches is strong evidence
|
|
50
|
+
|
|
51
|
+
### 4. Find Remaining Callsites
|
|
52
|
+
|
|
53
|
+
For each confirmed deprecated pattern, use Grep to find all files still importing or using the old dependency/pattern. Count the callsites to assess migration completeness.
|
|
54
|
+
|
|
55
|
+
Search patterns:
|
|
56
|
+
|
|
57
|
+
```
|
|
58
|
+
from ['"]<old-dep>
|
|
59
|
+
require(['"]<old-dep>
|
|
60
|
+
import <old-dep>
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
### 5. Assess Severity
|
|
64
|
+
|
|
65
|
+
- **high**: Active migration with significant remaining old callsites (>10 files), or explicit deprecation markers present
|
|
66
|
+
- **medium**: Clear trend in git recency but no explicit markers and fewer remaining callsites
|
|
67
|
+
- **low**: Slight trend, possibly intentional coexistence
|
|
68
|
+
|
|
69
|
+
## Output
|
|
70
|
+
|
|
71
|
+
Return your findings as a JSON code block in your response, using this format:
|
|
72
|
+
|
|
73
|
+
```json
|
|
74
|
+
{
|
|
75
|
+
"findings": [
|
|
76
|
+
{
|
|
77
|
+
"type": "deprecated-pattern",
|
|
78
|
+
"old_pattern": "descriptive name of the old approach",
|
|
79
|
+
"new_pattern": "descriptive name of the new approach",
|
|
80
|
+
"evidence": "concise summary of the evidence (git recency numbers, markers found)",
|
|
81
|
+
"files_still_using_old": ["path/to/file1.ts", "path/to/file2.ts"],
|
|
82
|
+
"severity": "high|medium|low",
|
|
83
|
+
"suggested_rule_paths": ["src/relevant/**/*.ts"]
|
|
84
|
+
}
|
|
85
|
+
],
|
|
86
|
+
"stats": {
|
|
87
|
+
"deps_analyzed": 0,
|
|
88
|
+
"overlapping_pairs_found": 0,
|
|
89
|
+
"confirmed_deprecated": 0
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
After the JSON block, return a **brief one-paragraph summary** of your findings. Include the number of confirmed deprecated patterns and the highest-severity finding.
|
|
95
|
+
|
|
96
|
+
## Important Notes
|
|
97
|
+
|
|
98
|
+
- Be conservative: only flag patterns where there is clear evidence of transition, not just the presence of two similar libraries
|
|
99
|
+
- Some projects intentionally use multiple tools in the same category (e.g., jest for unit tests and playwright for e2e) — that's not deprecation
|
|
100
|
+
- Focus on patterns that would **mislead a coding agent** — if both approaches are valid and documented, it may not need a rule
|