@codeyam/codeyam-cli 0.1.0-staging.036391e → 0.1.0-staging.07d8f7b
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 +14 -14
- package/analyzer-template/packages/ai/index.ts +1 -0
- package/analyzer-template/packages/ai/package.json +1 -1
- package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +14 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
- package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
- package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
- package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
- package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +435 -13
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +70 -19
- package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
- package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
- package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +110 -7
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +134 -2
- package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
- package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
- package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
- package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +6 -0
- package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
- package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +18 -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/gatherDataForMocks.ts +50 -25
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +83 -0
- package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +176 -80
- package/analyzer-template/packages/aws/package.json +10 -10
- package/analyzer-template/packages/database/index.ts +1 -0
- package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
- package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
- package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +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/projectToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
- package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
- package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
- package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
- package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
- package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
- package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
- package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
- package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/index.js +1 -0
- package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +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/debugReportsTable.d.ts +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/projectToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
- package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
- package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
- package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
- package/analyzer-template/packages/github/dist/types/src/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/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/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
- package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
- package/analyzer-template/playwright/captureFromUrl.ts +89 -82
- package/analyzer-template/project/constructMockCode.ts +170 -50
- package/analyzer-template/project/orchestrateCapture.ts +4 -1
- package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
- package/analyzer-template/project/start.ts +3 -0
- package/analyzer-template/project/startScenarioCapture.ts +9 -0
- package/analyzer-template/project/writeClientLogRoute.ts +125 -0
- package/analyzer-template/project/writeMockDataTsx.ts +17 -0
- package/analyzer-template/project/writeScenarioComponents.ts +110 -17
- package/analyzer-template/tsconfig.json +13 -1
- package/background/src/lib/local/createLocalAnalyzer.js +1 -1
- package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
- package/background/src/lib/virtualized/project/constructMockCode.js +145 -41
- package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
- package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
- package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
- package/background/src/lib/virtualized/project/start.js +2 -0
- package/background/src/lib/virtualized/project/start.js.map +1 -1
- package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
- package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
- package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
- package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
- package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
- package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
- package/background/src/lib/virtualized/project/writeScenarioComponents.js +83 -12
- package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
- package/codeyam-cli/scripts/apply-setup.js +209 -12
- package/codeyam-cli/scripts/apply-setup.js.map +1 -1
- package/codeyam-cli/src/cli.js +33 -24
- package/codeyam-cli/src/cli.js.map +1 -1
- package/codeyam-cli/src/codeyam-cli.js +18 -2
- package/codeyam-cli/src/codeyam-cli.js.map +1 -1
- package/codeyam-cli/src/commands/analyze.js +21 -9
- package/codeyam-cli/src/commands/analyze.js.map +1 -1
- package/codeyam-cli/src/commands/baseline.js +2 -0
- package/codeyam-cli/src/commands/baseline.js.map +1 -1
- package/codeyam-cli/src/commands/debug.js +2 -0
- package/codeyam-cli/src/commands/debug.js.map +1 -1
- package/codeyam-cli/src/commands/default.js +87 -21
- package/codeyam-cli/src/commands/default.js.map +1 -1
- package/codeyam-cli/src/commands/editor.js +697 -0
- package/codeyam-cli/src/commands/editor.js.map +1 -0
- package/codeyam-cli/src/commands/init.js +75 -259
- package/codeyam-cli/src/commands/init.js.map +1 -1
- package/codeyam-cli/src/commands/memory.js +95 -81
- package/codeyam-cli/src/commands/memory.js.map +1 -1
- package/codeyam-cli/src/commands/recapture.js +2 -0
- package/codeyam-cli/src/commands/recapture.js.map +1 -1
- package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
- package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
- package/codeyam-cli/src/commands/setup-simulations.js +284 -0
- package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
- package/codeyam-cli/src/commands/test-startup.js +2 -0
- package/codeyam-cli/src/commands/test-startup.js.map +1 -1
- package/codeyam-cli/src/commands/verify.js +14 -2
- package/codeyam-cli/src/commands/verify.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
- package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
- package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
- package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +154 -86
- package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
- package/codeyam-cli/src/utils/analyzer.js +7 -0
- package/codeyam-cli/src/utils/analyzer.js.map +1 -1
- package/codeyam-cli/src/utils/backgroundServer.js +109 -26
- package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/utils/devModeEvents.js +40 -0
- package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
- package/codeyam-cli/src/utils/fileMetadata.js +5 -0
- package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
- package/codeyam-cli/src/utils/fileWatcher.js +25 -9
- package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
- package/codeyam-cli/src/utils/generateReport.js +2 -2
- package/codeyam-cli/src/utils/git.js +52 -0
- package/codeyam-cli/src/utils/git.js.map +1 -1
- package/codeyam-cli/src/utils/install-skills.js +74 -63
- package/codeyam-cli/src/utils/install-skills.js.map +1 -1
- package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
- package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
- package/codeyam-cli/src/utils/labsAutoCheck.js +0 -29
- package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -1
- package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
- package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
- package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
- package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
- package/codeyam-cli/src/utils/progress.js +7 -0
- package/codeyam-cli/src/utils/progress.js.map +1 -1
- package/codeyam-cli/src/utils/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/requireSimulations.js +10 -0
- package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
- package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +7 -8
- package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +1 -1
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -1
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +0 -1
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -1
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +97 -6
- package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -1
- package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +4 -6
- package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
- package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +3 -3
- package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -1
- package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
- package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
- package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
- package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +23 -23
- package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -1
- package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
- package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
- package/codeyam-cli/src/utils/rules/index.js +1 -0
- package/codeyam-cli/src/utils/rules/index.js.map +1 -1
- package/codeyam-cli/src/utils/rules/parser.js +19 -4
- package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
- package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
- package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
- package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
- package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
- package/codeyam-cli/src/utils/rules/ruleState.js +10 -10
- package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -1
- package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
- package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
- package/codeyam-cli/src/utils/rules/staleness.js +6 -6
- package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
- package/codeyam-cli/src/utils/serverState.js +64 -12
- package/codeyam-cli/src/utils/serverState.js.map +1 -1
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +61 -43
- package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
- package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
- package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
- package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
- package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
- package/codeyam-cli/src/utils/testRunner.js +158 -0
- package/codeyam-cli/src/utils/testRunner.js.map +1 -0
- package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
- package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
- package/codeyam-cli/src/utils/versionInfo.js +46 -0
- package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
- package/codeyam-cli/src/utils/webappDetection.js +14 -2
- package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
- package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
- package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
- package/codeyam-cli/src/webserver/app/lib/database.js +55 -30
- package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
- package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
- package/codeyam-cli/src/webserver/backgroundServer.js +144 -25
- package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
- package/codeyam-cli/src/webserver/bootstrap.js +11 -0
- package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-CA3JxPb7.js → CopyButton-DmJveP3T.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-B86KKU7e.js → EntityItem-C76mRRiF.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-B5ctlSYt.js → EntityTypeBadge-g3saevPb.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BqY8gDAW.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-BDhPilK7.js → InteractivePreview-DYFW3lDD.js} +3 -3
- package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-VeqEBv9v.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-Bs7Nn1Jr.js → LoadingDots-BU_OAEMP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-Bm3PmcCz.js → LogViewer-ceAyBX-H.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-C6PKeMYR.js → ReportIssueModal-djPLI-WV.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-Gq3Ocjo6.js → SafeScreenshot-BED4B6sP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BNLaXBHR.js → ScenarioViewer-B76aig_2.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
- package/codeyam-cli/src/webserver/build/client/assets/Terminal-BaIiqg_w.js +41 -0
- package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-CiwXDxLh.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{_index-B3TDXxnk.js → _index-C96V0n15.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BtBFH820.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.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-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-switch-scenario-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{book-open-PttOB2SF.js → book-open-D_nMCFmP.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-TJp6ofnp.js → chevron-down-BH2h1Ea2.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-JE9ZIoBl.js → chunk-JZWAC4HX-C4pqxYJB.js} +9 -9
- package/codeyam-cli/src/webserver/build/client/assets/{circle-check-CXhHQYrI.js → circle-check-DyIKORY6.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{copy-6y9ALfGT.js → copy-NDbZjXao.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-Ca9fAY46.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-Ba0jejiv.js +7 -0
- package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-n38keI1k.js → entity._sha._-CrjR3zZW.js} +10 -10
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-DloHYjtt.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-38yPijoD.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
- package/codeyam-cli/src/webserver/build/client/assets/{entry.client-BSHEfydn.js → entry.client-DTvKq3TY.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DCPhhSMo.js → fileTableUtils-cPo8LiG3.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{files-0N0YJQv7.js → files-DO4CZ16O.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{git-DXnyr8uP.js → git-CFCTYk9I.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/globals-BH6uYxPM.css +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{index-ChN9-fAY.js → index-10oVnAAH.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{index-CcsFv748.js → index-BcvgDzbZ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-CTqLEAGU.js → loader-circle-BAXYRVEO.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-dcea65f8.js +1 -0
- package/codeyam-cli/src/webserver/build/client/assets/memory-FweZHj5U.js +93 -0
- package/codeyam-cli/src/webserver/build/client/assets/{pause-D6vreykR.js → pause-DTAcYxBt.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/root-Dzn8nIkU.js +67 -0
- package/codeyam-cli/src/webserver/build/client/assets/{search-B8VUL8nl.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-CPoAg7Zo.js → simulations-B3aOzpCZ.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{terminal-BrCP7uQo.js → terminal-BG4heKCG.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BZz2NjYa.js → triangle-alert-DtSmdtM4.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-DNwUduNu.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-CpZgwliL.js → useReportContext-O-jkvSPx.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/{useToast-Bv9JFvUO.js → useToast-9FIWuYfK.js} +1 -1
- package/codeyam-cli/src/webserver/build/client/assets/xterm-DMSzMhqy.js +9 -0
- package/codeyam-cli/src/webserver/build/server/assets/index-mE6GlU_8.js +1 -0
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BApEk7IO.js +362 -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 +272 -0
- package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
- package/codeyam-cli/src/webserver/scripts/journalCapture.ts +121 -0
- package/codeyam-cli/src/webserver/server.js +177 -1
- package/codeyam-cli/src/webserver/server.js.map +1 -1
- package/codeyam-cli/src/webserver/terminalServer.js +606 -0
- package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
- package/codeyam-cli/templates/{codeyam:debug.md → codeyam-debug.md} +1 -1
- package/codeyam-cli/templates/codeyam-dev-mode.md +237 -0
- package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
- package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
- package/codeyam-cli/templates/codeyam-editor.md +67 -0
- package/codeyam-cli/templates/codeyam-memory-hook.sh +14 -14
- package/codeyam-cli/templates/{codeyam:memory.md → codeyam-memory.md} +16 -24
- package/codeyam-cli/templates/{codeyam:new-rule.md → codeyam-new-rule.md} +1 -3
- package/codeyam-cli/templates/{codeyam:setup.md → codeyam-setup.md} +13 -1
- package/codeyam-cli/templates/{codeyam:sim.md → codeyam-sim.md} +1 -1
- package/codeyam-cli/templates/{codeyam:test.md → codeyam-test.md} +1 -1
- package/codeyam-cli/templates/{codeyam:verify.md → codeyam-verify.md} +1 -1
- package/codeyam-cli/templates/editor-step-hook.py +143 -0
- package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
- package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
- package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
- package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
- package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
- package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
- package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
- package/codeyam-cli/templates/nextjs-prisma-sqlite/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/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 +44 -0
- package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
- package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
- package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
- package/codeyam-cli/templates/rule-notification-hook.py +44 -17
- package/codeyam-cli/templates/rule-reflection-hook.py +88 -31
- package/codeyam-cli/templates/rules-instructions.md +45 -90
- package/package.json +15 -13
- package/packages/ai/index.js +1 -1
- package/packages/ai/index.js.map +1 -1
- package/packages/ai/src/lib/analyzeScope.js +14 -0
- package/packages/ai/src/lib/analyzeScope.js.map +1 -1
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
- package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
- package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
- package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
- package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
- package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
- package/packages/ai/src/lib/completionCall.js +10 -7
- package/packages/ai/src/lib/completionCall.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +362 -10
- 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/convertDotNotation.js +59 -17
- package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
- package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
- package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
- package/packages/ai/src/lib/dataStructureChunking.js +30 -11
- package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
- package/packages/ai/src/lib/generateEntityScenarioData.js +79 -5
- package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlows.js +97 -2
- package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
- package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
- package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
- package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
- package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
- package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
- package/packages/analyze/src/lib/ProjectAnalyzer.js +3 -0
- package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
- package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
- package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +11 -1
- package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.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/gatherDataForMocks.js +42 -13
- package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.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 +141 -71
- 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/analysisBranchToDb.js +1 -1
- package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
- package/packages/database/src/lib/analysisToDb.js +1 -1
- package/packages/database/src/lib/analysisToDb.js.map +1 -1
- package/packages/database/src/lib/branchToDb.js +1 -1
- package/packages/database/src/lib/branchToDb.js.map +1 -1
- package/packages/database/src/lib/commitBranchToDb.js +1 -1
- package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
- package/packages/database/src/lib/commitToDb.js +1 -1
- package/packages/database/src/lib/commitToDb.js.map +1 -1
- package/packages/database/src/lib/fileToDb.js +1 -1
- package/packages/database/src/lib/fileToDb.js.map +1 -1
- package/packages/database/src/lib/kysely/db.js +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/projectToDb.js +1 -1
- package/packages/database/src/lib/projectToDb.js.map +1 -1
- package/packages/database/src/lib/saveFiles.js +1 -1
- package/packages/database/src/lib/saveFiles.js.map +1 -1
- package/packages/database/src/lib/scenarioToDb.js +1 -1
- package/packages/database/src/lib/scenarioToDb.js.map +1 -1
- package/packages/database/src/lib/updateCommitMetadata.js +100 -89
- package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
- package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
- package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
- package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
- package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
- package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
- package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
- package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
- package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
- package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
- package/scripts/finalize-analyzer.cjs +8 -76
- package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
- package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
- package/codeyam-cli/src/commands/list.js +0 -31
- package/codeyam-cli/src/commands/list.js.map +0 -1
- package/codeyam-cli/src/commands/webapp-info.js +0 -146
- package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
- package/codeyam-cli/src/utils/universal-mocks.js +0 -152
- package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-ClaLpuOo.js +0 -34
- package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DfKzxuoe.js +0 -11
- package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C5lqplTC.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CBoafmVs.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DGgZjdFg.js +0 -6
- package/codeyam-cli/src/webserver/build/client/assets/globals-DoeDFXZN.css +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/labs-CmBYA0PH.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/manifest-76786b8e.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/memory-CrNQfdMO.js +0 -76
- package/codeyam-cli/src/webserver/build/client/assets/root-QAY34PIo.js +0 -62
- package/codeyam-cli/src/webserver/build/client/assets/settings-eBI36Yv5.js +0 -1
- package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-COky1GVF.js +0 -2
- package/codeyam-cli/src/webserver/build/server/assets/index-DV1ykEI6.js +0 -1
- package/codeyam-cli/src/webserver/build/server/assets/server-build-BrcVrUEv.js +0 -260
- package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
- package/codeyam-cli/templates/codeyam:diagnose.md +0 -805
- /package/codeyam-cli/src/webserver/build/client/assets/{api.labs-survey-l0sNRNKZ.js → api.dev-mode-events-l0sNRNKZ.js} +0 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
FIRST: Read `.codeyam/rules/instructions.md` — it contains the required format, rule placement via the rule-path API, and an example rule. You MUST follow this format exactly when creating or editing rules.
|
|
2
|
+
|
|
3
|
+
THEN: Read the file {{CONTEXT_FILE}} and follow the instructions inside.
|
|
4
|
+
|
|
5
|
+
Analyze the conversation transcript for rule-worthy learnings:
|
|
6
|
+
- User corrections, redirections, or information Claude didn't know
|
|
7
|
+
- Investigation results and debugging knowledge
|
|
8
|
+
- Architecture and relationships not obvious from code
|
|
9
|
+
- Commands, workflows, and processes
|
|
10
|
+
|
|
11
|
+
Access and read files in the repo or in the .claude folder as needed.
|
|
12
|
+
|
|
13
|
+
Create new rules only when the learnings meet the guidelines in the context file.
|
|
14
|
+
|
|
15
|
+
IMPORTANT: If you create ANY rule files, write a short summary to `{{NOTIFICATION_FILE}}`. The summary should list each rule change, e.g.:
|
|
16
|
+
```
|
|
17
|
+
The background rule-reflection agent created the following rules:
|
|
18
|
+
- Created `.claude/rules/tooling/new-pattern.md` — documents X pattern
|
|
19
|
+
```
|
|
20
|
+
Only write the notification file when rules are created.
|
|
21
|
+
|
|
22
|
+
The project root is {{PROJECT_DIR}}
|
|
23
|
+
|
|
24
|
+
CRITICAL: All rule files MUST be written to {{PROJECT_DIR}}/.claude/rules/ (the project directory). Always use the full absolute path when writing rule files.
|
|
25
|
+
|
|
26
|
+
CRITICAL: Before writing any rule file, you MUST run the rule-path command to determine the correct subdirectory:
|
|
27
|
+
codeyam memory rule-path path/one path/two
|
|
28
|
+
Pass all paths from your frontmatter. The command returns the correct .claude/rules/ subdirectory as JSON. Do NOT guess the placement from the first path — rules with paths spanning multiple directories belong at their common ancestor.
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
FIRST: Read `.codeyam/rules/instructions.md` — it contains the required format, rule placement via the rule-path API, and an example rule. You MUST follow this format exactly when creating or editing rules.
|
|
2
|
+
|
|
3
|
+
THEN: Read the file {{CONTEXT_FILE}} and follow the instructions inside.
|
|
4
|
+
|
|
5
|
+
The user interrupted Claude mid-response — a strong signal of confusion or misunderstanding.
|
|
6
|
+
Analyze both Claude's interrupted output and the user's follow-up to determine what went wrong.
|
|
7
|
+
|
|
8
|
+
Look for:
|
|
9
|
+
- Claude heading in a wrong direction that the user had to correct
|
|
10
|
+
- Misunderstanding of project conventions, architecture, or dependencies
|
|
11
|
+
- Missing context that caused Claude to make incorrect assumptions
|
|
12
|
+
- Patterns that would recur in future sessions without a rule
|
|
13
|
+
|
|
14
|
+
Access and read files in the repo or in the .claude folder as needed.
|
|
15
|
+
|
|
16
|
+
Create new rules only when the learnings meet the guidelines in the context file.
|
|
17
|
+
|
|
18
|
+
IMPORTANT: If you create ANY rule files, write a short summary to `{{NOTIFICATION_FILE}}`. The summary should list each rule change, e.g.:
|
|
19
|
+
```
|
|
20
|
+
The background rule-reflection agent created the following rules:
|
|
21
|
+
- Created `.claude/rules/tooling/new-pattern.md` — documents X pattern
|
|
22
|
+
```
|
|
23
|
+
Only write the notification file when rules are created.
|
|
24
|
+
|
|
25
|
+
The project root is {{PROJECT_DIR}}
|
|
26
|
+
|
|
27
|
+
CRITICAL: All rule files MUST be written to {{PROJECT_DIR}}/.claude/rules/ (the project directory). Always use the full absolute path when writing rule files.
|
|
28
|
+
|
|
29
|
+
CRITICAL: Before writing any rule file, you MUST run the rule-path command to determine the correct subdirectory:
|
|
30
|
+
codeyam memory rule-path path/one path/two
|
|
31
|
+
Pass all paths from your frontmatter. The command returns the correct .claude/rules/ subdirectory as JSON. Do NOT guess the placement from the first path — rules with paths spanning multiple directories belong at their common ancestor.
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
FIRST: Read `.codeyam/rules/instructions.md` — it contains the required format, rule placement via the rule-path API, and an example rule. You MUST follow this format exactly when creating or editing rules.
|
|
2
|
+
|
|
3
|
+
THEN: Read the file {{CONTEXT_FILE}} and follow the instructions inside.
|
|
4
|
+
|
|
5
|
+
For each stale rule:
|
|
6
|
+
1. Review the inline rule content and the diff to determine if the rule needs updating
|
|
7
|
+
2. If it needs updating, edit the rule file in .claude/rules/ — also trim prose and unnecessary headers (most rules should be a few bullets)
|
|
8
|
+
3. Run `codeyam memory touch <rule-path1> <rule-path2> ...` with the SPECIFIC rule paths you reviewed to mark them as audited in .claude/codeyam-rule-state.json
|
|
9
|
+
Example: `codeyam memory touch tooling/cli-build.md packages/ai/execution-flow-prioritization.md`
|
|
10
|
+
|
|
11
|
+
Write a summary to `{{NOTIFICATION_FILE}}` listing each action taken, even if you only ran `codeyam memory touch` without content changes. Example:
|
|
12
|
+
```
|
|
13
|
+
The background rule-reflection agent updated the following rules:
|
|
14
|
+
- Reviewed `.claude/rules/example.md` — no content changes, ran `codeyam memory touch`
|
|
15
|
+
- Created `.claude/rules/tooling/new-pattern.md` — documents X pattern
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
The project root is {{PROJECT_DIR}}
|
|
19
|
+
|
|
20
|
+
CRITICAL: All rule files MUST be written to {{PROJECT_DIR}}/.claude/rules/ (the project directory), NOT ~/.claude/rules/ (the user home directory). Always use the full absolute path when writing rule files.
|
|
21
|
+
|
|
22
|
+
CRITICAL: Before writing any rule file, you MUST run the rule-path command to determine the correct subdirectory:
|
|
23
|
+
codeyam memory rule-path path/one path/two
|
|
24
|
+
Pass all paths from your frontmatter. The command returns the correct .claude/rules/ subdirectory as JSON. Do NOT guess the placement from the first path — rules with paths spanning multiple directories belong at their common ancestor.
|
|
@@ -14,6 +14,7 @@ Supports four notification files (legacy combined + split agents):
|
|
|
14
14
|
- rule-notification-interruption.md (interruption review agent)
|
|
15
15
|
"""
|
|
16
16
|
|
|
17
|
+
import json
|
|
17
18
|
import os
|
|
18
19
|
import sys
|
|
19
20
|
|
|
@@ -26,27 +27,53 @@ NOTIFICATION_FILES = [
|
|
|
26
27
|
]
|
|
27
28
|
|
|
28
29
|
|
|
30
|
+
def get_project_slug():
|
|
31
|
+
"""
|
|
32
|
+
Derive project slug from .codeyam/config.json (matching getProjectSlug() on the TS side).
|
|
33
|
+
Falls back to os.path.basename(project_dir) if config is absent or malformed.
|
|
34
|
+
"""
|
|
35
|
+
project_dir = os.environ.get('CLAUDE_PROJECT_DIR', os.getcwd())
|
|
36
|
+
try:
|
|
37
|
+
config_path = os.path.join(project_dir, '.codeyam', 'config.json')
|
|
38
|
+
with open(config_path, 'r') as f:
|
|
39
|
+
config = json.load(f)
|
|
40
|
+
slug = config.get('projectSlug', '')
|
|
41
|
+
if slug:
|
|
42
|
+
return slug
|
|
43
|
+
except (IOError, json.JSONDecodeError, KeyError):
|
|
44
|
+
pass
|
|
45
|
+
return os.path.basename(project_dir)
|
|
46
|
+
|
|
47
|
+
|
|
29
48
|
def main():
|
|
30
49
|
collected = []
|
|
50
|
+
slug = get_project_slug()
|
|
51
|
+
|
|
52
|
+
# Check slug subdirectory first, then fall back to flat directory
|
|
53
|
+
dirs_to_check = [os.path.join(MARKER_DIR, slug), MARKER_DIR]
|
|
31
54
|
|
|
32
55
|
for filename in NOTIFICATION_FILES:
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
56
|
+
for check_dir in dirs_to_check:
|
|
57
|
+
filepath = os.path.join(check_dir, filename)
|
|
58
|
+
if not os.path.exists(filepath):
|
|
59
|
+
continue
|
|
60
|
+
|
|
61
|
+
try:
|
|
62
|
+
with open(filepath, 'r') as f:
|
|
63
|
+
content = f.read().strip()
|
|
64
|
+
except IOError:
|
|
65
|
+
continue
|
|
66
|
+
|
|
67
|
+
if content:
|
|
68
|
+
collected.append(content)
|
|
69
|
+
|
|
70
|
+
try:
|
|
71
|
+
os.remove(filepath)
|
|
72
|
+
except OSError:
|
|
73
|
+
pass
|
|
74
|
+
|
|
75
|
+
# Found in this directory — don't check the fallback
|
|
76
|
+
break
|
|
50
77
|
|
|
51
78
|
if collected:
|
|
52
79
|
print('\n\n'.join(collected))
|
|
@@ -120,6 +120,51 @@ def read_rule_content(rule_name):
|
|
|
120
120
|
return text
|
|
121
121
|
|
|
122
122
|
|
|
123
|
+
def get_project_slug():
|
|
124
|
+
"""
|
|
125
|
+
Derive project slug from .codeyam/config.json (matching getProjectSlug() on the TS side).
|
|
126
|
+
Falls back to os.path.basename(project_dir) if config is absent or malformed.
|
|
127
|
+
"""
|
|
128
|
+
project_dir = os.environ.get('CLAUDE_PROJECT_DIR', os.getcwd())
|
|
129
|
+
try:
|
|
130
|
+
config_path = os.path.join(project_dir, '.codeyam', 'config.json')
|
|
131
|
+
with open(config_path, 'r') as f:
|
|
132
|
+
config = json.load(f)
|
|
133
|
+
slug = config.get('projectSlug', '')
|
|
134
|
+
if slug:
|
|
135
|
+
return slug
|
|
136
|
+
except (IOError, json.JSONDecodeError, KeyError):
|
|
137
|
+
pass
|
|
138
|
+
return os.path.basename(project_dir)
|
|
139
|
+
|
|
140
|
+
|
|
141
|
+
def load_memory_settings():
|
|
142
|
+
"""
|
|
143
|
+
Load memory settings from .codeyam/config.json.
|
|
144
|
+
Returns dict with safe defaults when absent or malformed.
|
|
145
|
+
"""
|
|
146
|
+
defaults = {
|
|
147
|
+
'conversationReflection': True,
|
|
148
|
+
'ruleMaintenance': True,
|
|
149
|
+
'promptModel': 'haiku',
|
|
150
|
+
}
|
|
151
|
+
try:
|
|
152
|
+
project_dir = os.environ.get('CLAUDE_PROJECT_DIR', os.getcwd())
|
|
153
|
+
config_path = os.path.join(project_dir, '.codeyam', 'config.json')
|
|
154
|
+
with open(config_path, 'r') as f:
|
|
155
|
+
config = json.load(f)
|
|
156
|
+
memory = config.get('memory', {})
|
|
157
|
+
if not isinstance(memory, dict):
|
|
158
|
+
return defaults
|
|
159
|
+
return {
|
|
160
|
+
'conversationReflection': memory.get('conversationReflection', True),
|
|
161
|
+
'ruleMaintenance': memory.get('ruleMaintenance', True),
|
|
162
|
+
'promptModel': memory.get('promptModel', 'haiku'),
|
|
163
|
+
}
|
|
164
|
+
except (IOError, json.JSONDecodeError, KeyError):
|
|
165
|
+
return defaults
|
|
166
|
+
|
|
167
|
+
|
|
123
168
|
def get_stale_rules():
|
|
124
169
|
"""
|
|
125
170
|
Run `codeyam memory status` and parse the output to find stale rules.
|
|
@@ -157,8 +202,8 @@ def get_stale_rules():
|
|
|
157
202
|
# Look for the next few lines for details
|
|
158
203
|
for j in range(i + 1, min(i + 4, len(lines))):
|
|
159
204
|
detail = lines[j].strip()
|
|
160
|
-
if detail.startswith('
|
|
161
|
-
rule_info['
|
|
205
|
+
if detail.startswith('Last audited:'):
|
|
206
|
+
rule_info['last_audited'] = detail.replace('Last audited:', '').strip()
|
|
162
207
|
elif detail.startswith('Newest file:'):
|
|
163
208
|
rule_info['newest_file'] = detail.replace('Newest file:', '').strip()
|
|
164
209
|
elif detail.startswith('File modified:'):
|
|
@@ -286,7 +331,7 @@ def build_stale_rules_context(stale_rules):
|
|
|
286
331
|
parts.append("For each rule, review the rule content and the diff of changes, then:")
|
|
287
332
|
parts.append("1. Determine if the rule content needs updating based on the code changes")
|
|
288
333
|
parts.append("2. Update the rule if needed")
|
|
289
|
-
parts.append("3.
|
|
334
|
+
parts.append("3. Run `codeyam memory touch <rule-path1> <rule-path2> ...` with the SPECIFIC rule paths you reviewed to mark them as audited\n")
|
|
290
335
|
|
|
291
336
|
for rule in stale_rules:
|
|
292
337
|
parts.append(f"### {rule['name']}")
|
|
@@ -298,8 +343,8 @@ def build_stale_rules_context(stale_rules):
|
|
|
298
343
|
parts.append(f" Changed file: {rule['newest_file']}")
|
|
299
344
|
if rule.get('file_modified'):
|
|
300
345
|
parts.append(f" File modified: {rule['file_modified']}")
|
|
301
|
-
if rule.get('
|
|
302
|
-
parts.append(f"
|
|
346
|
+
if rule.get('last_audited'):
|
|
347
|
+
parts.append(f" Last audited: {rule['last_audited']}")
|
|
303
348
|
if rule.get('diff'):
|
|
304
349
|
parts.append(f" Changes:")
|
|
305
350
|
for line in rule['diff'].split('\n'):
|
|
@@ -373,7 +418,7 @@ def build_interruption_context(conversation_snippets, follow_up_prompt, modified
|
|
|
373
418
|
return '\n'.join(parts)
|
|
374
419
|
|
|
375
420
|
|
|
376
|
-
def spawn_claude_agent(prompt, log_file, project_dir):
|
|
421
|
+
def spawn_claude_agent(prompt, log_file, project_dir, model='haiku'):
|
|
377
422
|
"""Spawn a detached claude -p agent as a background process."""
|
|
378
423
|
try:
|
|
379
424
|
log_fh = open(log_file, 'w')
|
|
@@ -381,7 +426,8 @@ def spawn_claude_agent(prompt, log_file, project_dir):
|
|
|
381
426
|
env['CODEYAM_RULE_AGENT'] = '1'
|
|
382
427
|
subprocess.Popen(
|
|
383
428
|
['claude', '-p', prompt,
|
|
384
|
-
'--model',
|
|
429
|
+
'--model', model,
|
|
430
|
+
'--no-session-persistence',
|
|
385
431
|
'--output-format', 'stream-json', '--verbose',
|
|
386
432
|
'--allowedTools', 'Read,Edit,Write,Bash,Glob,Grep'],
|
|
387
433
|
cwd=project_dir,
|
|
@@ -427,14 +473,17 @@ def handle_stop(hook_input):
|
|
|
427
473
|
agent spawn) runs first. The slow `get_stale_rules()` call (~10s) runs last
|
|
428
474
|
so the hook timeout doesn't kill us before the critical work is done.
|
|
429
475
|
"""
|
|
476
|
+
settings = load_memory_settings()
|
|
477
|
+
|
|
430
478
|
session_id = hook_input.get('session_id', '')
|
|
431
479
|
transcript_path = hook_input.get('transcript_path', '')
|
|
432
480
|
|
|
433
481
|
if not session_id or not transcript_path:
|
|
434
482
|
return
|
|
435
483
|
|
|
436
|
-
|
|
437
|
-
marker_dir
|
|
484
|
+
slug = get_project_slug()
|
|
485
|
+
marker_dir = Path('/tmp/claude-rule-markers') / slug
|
|
486
|
+
marker_dir.mkdir(parents=True, exist_ok=True)
|
|
438
487
|
marker_file = marker_dir / f'{session_id}.marker'
|
|
439
488
|
|
|
440
489
|
last_line, _ = read_marker(marker_file)
|
|
@@ -452,8 +501,8 @@ def handle_stop(hook_input):
|
|
|
452
501
|
invocation_ts = datetime.now().strftime('%Y%m%d-%H%M%S')
|
|
453
502
|
invocation_id = f'{session_id}-{invocation_ts}'
|
|
454
503
|
|
|
455
|
-
# Fast: spawn conversation review agent first
|
|
456
|
-
if len(conversation_snippets) > 0:
|
|
504
|
+
# Fast: spawn conversation review agent first (if enabled)
|
|
505
|
+
if settings['conversationReflection'] and len(conversation_snippets) > 0:
|
|
457
506
|
conv_context = build_conversation_context(conversation_snippets, modified_files)
|
|
458
507
|
conv_context_file = marker_dir / f'{invocation_id}-conversation.context'
|
|
459
508
|
conv_context_file.write_text(conv_context)
|
|
@@ -466,26 +515,27 @@ def handle_stop(hook_input):
|
|
|
466
515
|
NOTIFICATION_FILE=str(conv_notification_file),
|
|
467
516
|
PROJECT_DIR=project_dir,
|
|
468
517
|
)
|
|
469
|
-
spawn_claude_agent(conv_prompt, conv_log_file, project_dir)
|
|
518
|
+
spawn_claude_agent(conv_prompt, conv_log_file, project_dir, model=settings['promptModel'])
|
|
470
519
|
|
|
471
520
|
# Slow (~10s): check for stale rules last — if the hook timeout kills us
|
|
472
521
|
# here, the conversation agent and marker are already handled
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
522
|
+
if settings['ruleMaintenance']:
|
|
523
|
+
stale_rules = get_stale_rules()
|
|
524
|
+
|
|
525
|
+
if len(stale_rules) > 0:
|
|
526
|
+
stale_context = build_stale_rules_context(stale_rules)
|
|
527
|
+
stale_context_file = marker_dir / f'{invocation_id}-stale.context'
|
|
528
|
+
stale_context_file.write_text(stale_context)
|
|
529
|
+
|
|
530
|
+
stale_log_file = marker_dir / f'{invocation_id}-stale.log'
|
|
531
|
+
stale_notification_file = marker_dir / 'rule-notification-stale.md'
|
|
532
|
+
stale_prompt = load_prompt_template(
|
|
533
|
+
'stale-rules-prompt.txt',
|
|
534
|
+
CONTEXT_FILE=str(stale_context_file),
|
|
535
|
+
NOTIFICATION_FILE=str(stale_notification_file),
|
|
536
|
+
PROJECT_DIR=project_dir,
|
|
537
|
+
)
|
|
538
|
+
spawn_claude_agent(stale_prompt, stale_log_file, project_dir, model=settings['promptModel'])
|
|
489
539
|
|
|
490
540
|
|
|
491
541
|
def handle_user_prompt_submit(hook_input):
|
|
@@ -495,6 +545,12 @@ def handle_user_prompt_submit(hook_input):
|
|
|
495
545
|
marker file is stale (transcript has lines beyond the marker). If so, spawns a
|
|
496
546
|
rule-reflection agent focused on the interruption.
|
|
497
547
|
"""
|
|
548
|
+
settings = load_memory_settings()
|
|
549
|
+
|
|
550
|
+
# Interruption detection is part of conversation reflection
|
|
551
|
+
if not settings['conversationReflection']:
|
|
552
|
+
return
|
|
553
|
+
|
|
498
554
|
session_id = hook_input.get('session_id', '')
|
|
499
555
|
transcript_path = hook_input.get('transcript_path', '')
|
|
500
556
|
follow_up_prompt = hook_input.get('prompt', '')
|
|
@@ -502,8 +558,9 @@ def handle_user_prompt_submit(hook_input):
|
|
|
502
558
|
if not session_id or not transcript_path:
|
|
503
559
|
return
|
|
504
560
|
|
|
505
|
-
|
|
506
|
-
marker_dir
|
|
561
|
+
slug = get_project_slug()
|
|
562
|
+
marker_dir = Path('/tmp/claude-rule-markers') / slug
|
|
563
|
+
marker_dir.mkdir(parents=True, exist_ok=True)
|
|
507
564
|
marker_file = marker_dir / f'{session_id}.marker'
|
|
508
565
|
|
|
509
566
|
last_line, was_stop = read_marker(marker_file)
|
|
@@ -561,7 +618,7 @@ def handle_user_prompt_submit(hook_input):
|
|
|
561
618
|
NOTIFICATION_FILE=str(notification_file),
|
|
562
619
|
PROJECT_DIR=project_dir,
|
|
563
620
|
)
|
|
564
|
-
spawn_claude_agent(prompt, log_file, project_dir)
|
|
621
|
+
spawn_claude_agent(prompt, log_file, project_dir, model=settings['promptModel'])
|
|
565
622
|
|
|
566
623
|
|
|
567
624
|
def main():
|
|
@@ -4,120 +4,75 @@ Rules provide context-specific guidance when working in files matching their `pa
|
|
|
4
4
|
|
|
5
5
|
## Core Principles
|
|
6
6
|
|
|
7
|
-
1. **One concept per rule**
|
|
8
|
-
2. **Paths must match content scope**
|
|
9
|
-
3. **
|
|
7
|
+
1. **One concept per rule** — If you're documenting two unrelated things, create two rules.
|
|
8
|
+
2. **Paths must match content scope** — A rule about one file should have that file in `paths`, not a broad `**/*.ts` pattern.
|
|
9
|
+
3. **Keep rules SHORT** — Most rules should be **1-4 bullets**. Only complex multi-file architectures should exceed ~10 lines.
|
|
10
10
|
|
|
11
|
-
|
|
11
|
+
**Example** — a typical rule:
|
|
12
12
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
-
|
|
17
|
-
|
|
18
|
-
- An existing rule is covering multiple unrelated topics (split it)
|
|
19
|
-
|
|
20
|
-
## Before Creating: The Confusion Test
|
|
21
|
-
|
|
22
|
-
Only create rules that document genuinely confusing aspects—not things Claude can figure out by reading code and will likely come up again in future sessions.
|
|
23
|
-
|
|
24
|
-
**Ask yourself:**
|
|
25
|
-
|
|
26
|
-
1. **Could Claude figure this out by reading the code?**
|
|
27
|
-
- If YES → don't create the rule
|
|
28
|
-
- If NO → proceed
|
|
29
|
-
|
|
30
|
-
2. **Does this explain "why" not just "what"?**
|
|
31
|
-
- Good: Historical context, gotchas, non-obvious behavior, non-obvious architectural decisions
|
|
32
|
-
- Bad: Bug fixes, Limitations (unless the user requests the limitation be noted), What functions do (unless providing a high-level architectural overview)
|
|
33
|
-
|
|
34
|
-
3. **Would this have prevented a past mistake?**
|
|
35
|
-
- If you can point to a bug or confusion this would have prevented → create it
|
|
36
|
-
- If it's just "nice to know" → skip it
|
|
37
|
-
|
|
38
|
-
### Examples
|
|
39
|
-
|
|
40
|
-
**✅ Worth documenting:**
|
|
41
|
-
|
|
42
|
-
- Where to add new functionality
|
|
43
|
-
- An overview of all files, classes, functions, etc used in a particular part of the repo
|
|
44
|
-
- Debugging strategies for a particular area of the repo
|
|
45
|
-
- "Use `pnpm test` to run tests" (if there is more than one way to run tests and this way is preferred)
|
|
46
|
-
|
|
47
|
-
**❌ Not worth documenting:**
|
|
48
|
-
|
|
49
|
-
- "The auth module handles authentication" (obvious from reading code)
|
|
50
|
-
- "This function takes X and returns Y" (Claude can read the signature)
|
|
13
|
+
```markdown
|
|
14
|
+
---
|
|
15
|
+
paths:
|
|
16
|
+
- 'packages/ai/src/lib/generateMockData.ts'
|
|
17
|
+
---
|
|
51
18
|
|
|
52
|
-
|
|
19
|
+
# Mock Data Generation
|
|
53
20
|
|
|
54
|
-
|
|
21
|
+
- Entry point: `generateMockData()` in `generateMockData.ts`
|
|
22
|
+
- Uses `convertDotNotation` to transform flat schema into nested objects
|
|
23
|
+
- Schema entry ORDER matters — `key[]` must come before `key[].property` or arrays get overwritten
|
|
24
|
+
- Test with exact ordering from database, not just same entries
|
|
25
|
+
```
|
|
55
26
|
|
|
56
|
-
|
|
57
|
-
| ------------- | ----------------------- | ------------------------------------------------------ |
|
|
58
|
-
| Single file | `'path/to/file.ts'` | Rule about `processExpression.ts` specifically |
|
|
59
|
-
| Related files | `'path/to/feature*.ts'` | Rule about `generateExecutionFlows*.ts` files |
|
|
60
|
-
| Directory | `'path/to/dir/**/*.ts'` | Rule about the queue system in `utils/queue/` |
|
|
61
|
-
| Cross-cutting | Multiple specific paths | Testing rule with paths to test configs and test files |
|
|
27
|
+
## When to Create a Rule
|
|
62
28
|
|
|
63
|
-
|
|
29
|
+
Create a rule when you learn something that **reading the code alone wouldn't reveal**:
|
|
64
30
|
|
|
65
|
-
|
|
31
|
+
- Non-obvious gotchas or behavior that caused real confusion or bugs
|
|
32
|
+
- Architecture, file relationships, or data flows that take time to piece together
|
|
33
|
+
- Debugging strategies for a tricky area of the codebase
|
|
34
|
+
- Preferred commands or workflows when multiple options exist (e.g. "Use `pnpm test` to run tests")
|
|
35
|
+
- User corrections or explanations that aren't captured in the code itself
|
|
66
36
|
|
|
67
|
-
|
|
37
|
+
**Skip** rules that restate what the code says — function signatures, type definitions, "this module handles X." Claude can read the code.
|
|
68
38
|
|
|
69
|
-
|
|
70
|
-
| -------------------- | --------------------------------------- |
|
|
71
|
-
| `src/api/auth.ts` | `.claude/rules/src/api/auth.md` |
|
|
72
|
-
| `src/utils/queue/**` | `.claude/rules/src/utils/queue.md` |
|
|
73
|
-
| Test configuration | `.claude/rules/testing/jest-configs.md` |
|
|
39
|
+
## Frontmatter & Paths
|
|
74
40
|
|
|
75
|
-
|
|
41
|
+
Every rule needs a `paths` frontmatter field. Be specific to avoid loading rules unnecessarily:
|
|
76
42
|
|
|
77
43
|
```yaml
|
|
78
44
|
---
|
|
79
45
|
paths:
|
|
80
46
|
- 'specific/path/to/file.ts'
|
|
81
47
|
- 'another/specific/path/*.ts'
|
|
82
|
-
timestamp: 2026-01-30T00:00:00Z
|
|
83
48
|
---
|
|
84
49
|
```
|
|
85
50
|
|
|
86
|
-
|
|
|
87
|
-
|
|
|
88
|
-
| `
|
|
89
|
-
| `
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
### Be Actionable
|
|
94
|
-
|
|
95
|
-
- Good: "Run `pnpm test:api` for API tests"
|
|
96
|
-
- Bad: "Make sure to run the appropriate tests"
|
|
51
|
+
| Content Scope | Path Pattern | Example |
|
|
52
|
+
| ------------- | ----------------------- | ---------------------------------------------- |
|
|
53
|
+
| Single file | `'path/to/file.ts'` | Rule about `processExpression.ts` specifically |
|
|
54
|
+
| Related files | `'path/to/feature*.ts'` | Rule about `generateExecutionFlows*.ts` files |
|
|
55
|
+
| Directory | `'path/to/dir/**/*.ts'` | Rule about the queue system in `utils/queue/` |
|
|
56
|
+
| Cross-cutting | Multiple specific paths | Testing rule spanning test configs and tests |
|
|
97
57
|
|
|
98
|
-
|
|
58
|
+
Audit dates live in `.claude/codeyam-rule-state.json` (managed by `codeyam memory touch`). Keep frontmatter limited to `paths`.
|
|
99
59
|
|
|
100
|
-
|
|
101
|
-
- Bad: "WARNING: Don't store tokens in localStorage!"
|
|
60
|
+
## File Placement
|
|
102
61
|
|
|
103
|
-
|
|
62
|
+
Rules must be written to `.claude/rules/`, NOT `.codeyam/rules/`. The instructions file lives in `.codeyam/` but actual rule files go in `.claude/rules/`.
|
|
104
63
|
|
|
105
|
-
|
|
106
|
-
- If a rule exceeds 60 lines, consider splitting it
|
|
64
|
+
Use `codeyam memory rule-path` to compute the correct directory from your frontmatter paths:
|
|
107
65
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
- "These three files must change together because..."
|
|
113
|
-
- "Data flows from X → Y → Z"
|
|
114
|
-
|
|
115
|
-
**testing** - Test commands, mock patterns, fixtures
|
|
66
|
+
```
|
|
67
|
+
$ codeyam memory rule-path packages/ai/src/lib/foo.ts packages/ai/src/utils/bar.ts
|
|
68
|
+
{"result":".claude/rules/packages/ai/src/"}
|
|
69
|
+
```
|
|
116
70
|
|
|
117
|
-
|
|
118
|
-
- "Must run `pnpm pretest` first because..."
|
|
71
|
+
The command computes the deepest common directory shared by all paths and returns the `.claude/rules/` subdirectory where the rule file should live. Reserve the top level of `.claude/rules/` for rules whose paths genuinely span the entire repo.
|
|
119
72
|
|
|
120
|
-
|
|
73
|
+
## Content Guidelines
|
|
121
74
|
|
|
122
|
-
- "
|
|
123
|
-
-
|
|
75
|
+
- **Be actionable** — "Run `pnpm test:api` for API tests" not "Make sure to run the appropriate tests"
|
|
76
|
+
- **Focus on why, not what** — Gotchas, non-obvious behavior, architectural decisions. The code already shows "what."
|
|
77
|
+
- **Point to specifics** — "Auth tokens are stored in httpOnly cookies via `src/auth/cookies.ts`" beats a vague description.
|
|
78
|
+
- **Be short!** - Context window space is precious! Do not ramble, use bullets, focus on providing clear actionable information.
|
package/package.json
CHANGED
|
@@ -1,27 +1,27 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@codeyam/codeyam-cli",
|
|
3
|
-
"version": "0.1.0-staging.
|
|
3
|
+
"version": "0.1.0-staging.07d8f7b",
|
|
4
4
|
"description": "Local development CLI for CodeYam analysis",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
7
7
|
"codeyam": "./codeyam-cli/src/codeyam-cli.js"
|
|
8
8
|
},
|
|
9
9
|
"scripts": {
|
|
10
|
-
"postinstall": "node ./scripts/finalize-analyzer.cjs"
|
|
10
|
+
"postinstall": "node ./scripts/finalize-analyzer.cjs && chmod +x ./node_modules/node-pty/prebuilds/darwin-arm64/spawn-helper 2>/dev/null; chmod +x ./node_modules/node-pty/prebuilds/darwin-x64/spawn-helper 2>/dev/null; true"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@anthropic-ai/claude-code": "^2.
|
|
14
|
-
"@anthropic-ai/sdk": "^0.
|
|
15
|
-
"@aws-sdk/client-dynamodb": "^3.
|
|
16
|
-
"@aws-sdk/s3-request-presigner": "^3.
|
|
17
|
-
"@aws-sdk/util-dynamodb": "^3.
|
|
18
|
-
"@modelcontextprotocol/sdk": "^1.
|
|
13
|
+
"@anthropic-ai/claude-code": "^2.1.7",
|
|
14
|
+
"@anthropic-ai/sdk": "^0.74.0",
|
|
15
|
+
"@aws-sdk/client-dynamodb": "^3.990.0",
|
|
16
|
+
"@aws-sdk/s3-request-presigner": "^3.990.0",
|
|
17
|
+
"@aws-sdk/util-dynamodb": "^3.990.0",
|
|
18
|
+
"@modelcontextprotocol/sdk": "^1.26.0",
|
|
19
19
|
"@octokit/auth-app": "^8.1.0",
|
|
20
20
|
"@octokit/request": "^10.0.3",
|
|
21
21
|
"@octokit/rest": "^22.0.0",
|
|
22
|
-
"@react-router/express": "^7.
|
|
22
|
+
"@react-router/express": "^7.13.0",
|
|
23
23
|
"@react-router/node": "^7.11.0",
|
|
24
|
-
"react-router": "^7.
|
|
24
|
+
"react-router": "^7.13.0",
|
|
25
25
|
"@sendgrid/mail": "^8.1.4",
|
|
26
26
|
"@supabase/supabase-js": "2.88.0",
|
|
27
27
|
"better-sqlite3": "^12.4.1",
|
|
@@ -33,13 +33,13 @@
|
|
|
33
33
|
"express": "^5.2.1",
|
|
34
34
|
"fetch-retry": "^6.0.0",
|
|
35
35
|
"get-port": "^7.1.0",
|
|
36
|
-
"htmlparser2": "^10.
|
|
36
|
+
"htmlparser2": "^10.1.0",
|
|
37
37
|
"isbot": "^4",
|
|
38
38
|
"jsdom": "^27.4.0",
|
|
39
39
|
"json5": "^2.2.3",
|
|
40
40
|
"jsonc-parser": "^3.2.1",
|
|
41
|
-
"kysely": "^0.28.
|
|
42
|
-
"lru-cache": "^11.2.
|
|
41
|
+
"kysely": "^0.28.11",
|
|
42
|
+
"lru-cache": "^11.2.5",
|
|
43
43
|
"lucide-react": "^0.556.0",
|
|
44
44
|
"minimatch": "^10.0.1",
|
|
45
45
|
"openai": "^6.16.0",
|
|
@@ -58,7 +58,9 @@
|
|
|
58
58
|
"react-resizable": "^3.0.5",
|
|
59
59
|
"react-syntax-highlighter": "^15.6.1",
|
|
60
60
|
"remark-gfm": "^4.0.1",
|
|
61
|
+
"node-pty": "^1.0.0",
|
|
61
62
|
"sharp": "^0.34.5",
|
|
63
|
+
"ws": "^8.18.3",
|
|
62
64
|
"simple-git": "^3.28.0",
|
|
63
65
|
"typescript": "^5.9.3",
|
|
64
66
|
"uuid": "^11.1.0",
|
package/packages/ai/index.js
CHANGED
|
@@ -26,7 +26,7 @@ export { default as describeCodeChange } from "./src/lib/describeCodeChange.js";
|
|
|
26
26
|
export { default as validateTypeStructure } from "./src/lib/validateTypeStructure.js";
|
|
27
27
|
export { default as validateDataStructure } from "./src/lib/validateDataStructure.js";
|
|
28
28
|
export { default as isolateScopes } from "./src/lib/isolateScopes.js";
|
|
29
|
-
export { default as analyzeScope, destroyWorkerPool, } from "./src/lib/analyzeScope.js";
|
|
29
|
+
export { default as analyzeScope, destroyWorkerPool, skipWorkerPool, } from "./src/lib/analyzeScope.js";
|
|
30
30
|
export { default as logOrderedMap } from "./src/lib/logOrderedMap.js";
|
|
31
31
|
export { default as splitOutsideParentheses, splitOutsideParenthesesAndArrays, joinParenthesesAndArrays, functionArguments, } from "./src/lib/splitOutsideParentheses.js";
|
|
32
32
|
export { cleanKnownObjectFunctionsFromMapping } from "./src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js";
|
package/packages/ai/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/ai/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,qBAAqB,EACrB,oBAAoB,GACrB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,IAAI,2BAA2B,EAAE,MAAM,uCAAuC,CAAC;AAC/F,OAAO,EAAE,OAAO,IAAI,kCAAkC,EAAE,MAAM,8CAA8C,CAAC;AAC7G,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,qCAAqC,CAAC;AAC3F,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,IAAI,2BAA2B,EAAE,MAAM,uCAAuC,CAAC;AAC/F,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AACvF,OAAO,EACL,OAAO,IAAI,0BAA0B,EACrC,uBAAuB,GACxB,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EAAE,OAAO,IAAI,8BAA8B,EAAE,MAAM,0CAA0C,CAAC;AACrG,OAAO,EAAE,OAAO,IAAI,iCAAiC,EAAE,MAAM,6CAA6C,CAAC;AAC3G,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AACrF,OAAO,EACL,OAAO,IAAI,yBAAyB,GAErC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACL,OAAO,IAAI,gCAAgC,GAG5C,MAAM,4CAA4C,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AACvF,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,oCAAoC,CAAC;AACzF,OAAO,EAAE,OAAO,IAAI,0CAA0C,EAAE,MAAM,sDAAsD,CAAC;AAC7H,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EACL,OAAO,IAAI,YAAY,EACvB,iBAAiB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/ai/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,qBAAqB,EACrB,oBAAoB,GACrB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,IAAI,2BAA2B,EAAE,MAAM,uCAAuC,CAAC;AAC/F,OAAO,EAAE,OAAO,IAAI,kCAAkC,EAAE,MAAM,8CAA8C,CAAC;AAC7G,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,qCAAqC,CAAC;AAC3F,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,IAAI,2BAA2B,EAAE,MAAM,uCAAuC,CAAC;AAC/F,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AACvF,OAAO,EACL,OAAO,IAAI,0BAA0B,EACrC,uBAAuB,GACxB,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EAAE,OAAO,IAAI,8BAA8B,EAAE,MAAM,0CAA0C,CAAC;AACrG,OAAO,EAAE,OAAO,IAAI,iCAAiC,EAAE,MAAM,6CAA6C,CAAC;AAC3G,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AACrF,OAAO,EACL,OAAO,IAAI,yBAAyB,GAErC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACL,OAAO,IAAI,gCAAgC,GAG5C,MAAM,4CAA4C,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AACvF,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,oCAAoC,CAAC;AACzF,OAAO,EAAE,OAAO,IAAI,0CAA0C,EAAE,MAAM,sDAAsD,CAAC;AAC7H,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EACL,OAAO,IAAI,YAAY,EACvB,iBAAiB,EACjB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EACL,OAAO,IAAI,uBAAuB,EAClC,gCAAgC,EAChC,wBAAwB,EACxB,iBAAiB,GAClB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,oCAAoC,EAAE,MAAM,2DAA2D,CAAC;AACjH,OAAO,EACL,0BAA0B,EAC1B,4BAA4B,GAC7B,MAAM,yDAAyD,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AACnG,OAAO,EAAE,OAAO,IAAI,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;AAC3H,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AACzE,OAAO,EACL,iCAAiC,EACjC,kBAAkB,GAEnB,MAAM,6DAA6D,CAAC;AACrE,OAAO,EAAE,OAAO,IAAI,0BAA0B,EAAE,MAAM,4DAA4D,CAAC;AACnH,OAAO,EAAE,OAAO,IAAI,4BAA4B,EAAE,MAAM,wCAAwC,CAAC;AAajG,OAAO,EACL,2BAA2B,EAC3B,oBAAoB,EACpB,cAAc,EACd,qBAAqB,EACrB,sBAAsB,EACtB,+BAA+B,EAC/B,oBAAoB,EACpB,qBAAqB,EACrB,uBAAuB,EACvB,gCAAgC,EAChC,qBAAqB,GACtB,MAAM,4CAA4C,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAErE,+EAA+E;AAC/E,wEAAwE;AACxE,2FAA2F;AAE3F,oBAAoB;AACpB,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,sDAAsD,CAAC;AAC5G,OAAO,EAAE,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAGnF,cAAc,qBAAqB,CAAC;AAEpC,OAAO,EAAE,EAAE,EAAE,MAAM,uBAAuB,CAAC;AAE3C,2CAA2C;AAC3C,OAAO,EACL,uBAAuB,EACvB,gBAAgB,EAChB,eAAe,EACf,kBAAkB,GACnB,MAAM,kCAAkC,CAAC"}
|