@codeyam/codeyam-cli 0.1.0-staging.036391e → 0.1.0-staging.039fa00

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.
Files changed (588) hide show
  1. package/analyzer-template/.build-info.json +7 -7
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +19 -19
  4. package/analyzer-template/packages/ai/index.ts +1 -0
  5. package/analyzer-template/packages/ai/package.json +2 -2
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +14 -0
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  8. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
  9. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
  11. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  12. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +435 -13
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +70 -19
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  16. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  17. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +110 -7
  18. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +134 -2
  19. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
  20. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  21. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  22. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  23. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +6 -0
  24. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  25. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +18 -0
  26. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +9 -1
  27. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  28. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  29. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +65 -28
  30. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +50 -25
  31. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +83 -0
  32. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +176 -80
  33. package/analyzer-template/packages/aws/package.json +10 -10
  34. package/analyzer-template/packages/database/index.ts +1 -0
  35. package/analyzer-template/packages/database/package.json +3 -3
  36. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  37. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  38. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  39. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  40. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  41. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  42. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
  43. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  44. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +62 -0
  45. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  46. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  47. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  48. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  49. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  50. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  51. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  52. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  53. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  54. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  55. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  56. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  57. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  58. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  59. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  60. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  61. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  62. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  63. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  64. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  65. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  66. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  67. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  68. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  69. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  70. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  71. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  72. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  73. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  74. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  75. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  77. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +20 -0
  78. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  79. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
  80. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  81. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  82. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  85. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  88. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  90. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  92. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  93. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  94. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  95. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  96. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  97. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  98. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  99. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  100. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  101. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  103. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  104. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  105. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  106. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  107. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  108. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  109. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  111. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  112. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  113. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  114. package/analyzer-template/packages/github/package.json +1 -1
  115. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  116. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  117. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  118. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  119. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  120. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  121. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  122. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  123. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  124. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  125. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  126. package/analyzer-template/project/constructMockCode.ts +170 -50
  127. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  128. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  129. package/analyzer-template/project/start.ts +3 -0
  130. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  131. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  132. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  133. package/analyzer-template/project/writeScenarioComponents.ts +110 -17
  134. package/analyzer-template/tsconfig.json +13 -1
  135. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  136. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  137. package/background/src/lib/virtualized/project/constructMockCode.js +145 -41
  138. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  139. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  140. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  141. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  142. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  143. package/background/src/lib/virtualized/project/start.js +2 -0
  144. package/background/src/lib/virtualized/project/start.js.map +1 -1
  145. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  146. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  147. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  148. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  149. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  150. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  151. package/background/src/lib/virtualized/project/writeScenarioComponents.js +83 -12
  152. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  153. package/codeyam-cli/scripts/apply-setup.js +209 -12
  154. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  155. package/codeyam-cli/src/cli.js +33 -24
  156. package/codeyam-cli/src/cli.js.map +1 -1
  157. package/codeyam-cli/src/codeyam-cli.js +18 -2
  158. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  159. package/codeyam-cli/src/commands/analyze.js +21 -9
  160. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  161. package/codeyam-cli/src/commands/baseline.js +2 -0
  162. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  163. package/codeyam-cli/src/commands/debug.js +2 -0
  164. package/codeyam-cli/src/commands/debug.js.map +1 -1
  165. package/codeyam-cli/src/commands/default.js +87 -21
  166. package/codeyam-cli/src/commands/default.js.map +1 -1
  167. package/codeyam-cli/src/commands/editor.js +1839 -0
  168. package/codeyam-cli/src/commands/editor.js.map +1 -0
  169. package/codeyam-cli/src/commands/init.js +81 -260
  170. package/codeyam-cli/src/commands/init.js.map +1 -1
  171. package/codeyam-cli/src/commands/memory.js +95 -81
  172. package/codeyam-cli/src/commands/memory.js.map +1 -1
  173. package/codeyam-cli/src/commands/recapture.js +2 -0
  174. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  175. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  176. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  177. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  178. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  179. package/codeyam-cli/src/commands/test-startup.js +2 -0
  180. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  181. package/codeyam-cli/src/commands/verify.js +14 -2
  182. package/codeyam-cli/src/commands/verify.js.map +1 -1
  183. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +246 -0
  184. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  185. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +126 -0
  186. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  187. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +295 -0
  188. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  189. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  190. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  191. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +100 -0
  192. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  193. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +147 -0
  194. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  195. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +76 -0
  196. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  197. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  198. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  199. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  200. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  201. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  202. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  203. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  204. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  205. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  206. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  207. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +154 -86
  208. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  209. package/codeyam-cli/src/utils/analyzer.js +7 -0
  210. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  211. package/codeyam-cli/src/utils/backgroundServer.js +109 -26
  212. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  213. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  214. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  215. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  216. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  217. package/codeyam-cli/src/utils/editorAudit.js +82 -0
  218. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  219. package/codeyam-cli/src/utils/editorDevServer.js +98 -0
  220. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  221. package/codeyam-cli/src/utils/editorJournal.js +137 -0
  222. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  223. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  224. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  225. package/codeyam-cli/src/utils/editorPreloadHelpers.js +64 -0
  226. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  227. package/codeyam-cli/src/utils/editorPreview.js +66 -0
  228. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  229. package/codeyam-cli/src/utils/editorScenarios.js +56 -0
  230. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  231. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  232. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  233. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  234. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  235. package/codeyam-cli/src/utils/generateReport.js +2 -2
  236. package/codeyam-cli/src/utils/git.js +103 -0
  237. package/codeyam-cli/src/utils/git.js.map +1 -1
  238. package/codeyam-cli/src/utils/install-skills.js +87 -65
  239. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  240. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  241. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  242. package/codeyam-cli/src/utils/labsAutoCheck.js +0 -29
  243. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -1
  244. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  245. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  246. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  247. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  248. package/codeyam-cli/src/utils/progress.js +7 -0
  249. package/codeyam-cli/src/utils/progress.js.map +1 -1
  250. package/codeyam-cli/src/utils/project.js +15 -5
  251. package/codeyam-cli/src/utils/project.js.map +1 -1
  252. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  253. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  254. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  255. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  256. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  257. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  258. package/codeyam-cli/src/utils/queue/job.js +70 -1
  259. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  260. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  261. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  262. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  263. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  264. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +7 -8
  265. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
  266. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +1 -1
  267. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -1
  268. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +0 -1
  269. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -1
  270. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +97 -6
  271. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -1
  272. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +4 -6
  273. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
  274. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +3 -3
  275. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -1
  276. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  277. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  278. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  279. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  280. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  281. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  282. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +23 -23
  283. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -1
  284. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  285. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  286. package/codeyam-cli/src/utils/rules/index.js +1 -0
  287. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  288. package/codeyam-cli/src/utils/rules/parser.js +19 -4
  289. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  290. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  291. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  292. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  293. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  294. package/codeyam-cli/src/utils/rules/ruleState.js +10 -10
  295. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -1
  296. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  297. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  298. package/codeyam-cli/src/utils/rules/staleness.js +6 -6
  299. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  300. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  301. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  302. package/codeyam-cli/src/utils/serverState.js +64 -12
  303. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  304. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +61 -43
  305. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  306. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  307. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  308. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  309. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  310. package/codeyam-cli/src/utils/testRunner.js +158 -0
  311. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  312. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  313. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  314. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  315. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  316. package/codeyam-cli/src/utils/webappDetection.js +14 -2
  317. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  318. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  319. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  320. package/codeyam-cli/src/webserver/app/lib/database.js +55 -30
  321. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  322. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  323. package/codeyam-cli/src/webserver/backgroundServer.js +144 -25
  324. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  325. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  326. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  327. package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-CA3JxPb7.js → CopyButton-DmJveP3T.js} +1 -1
  328. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-B86KKU7e.js → EntityItem-C76mRRiF.js} +1 -1
  329. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-B5ctlSYt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  330. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BqY8gDAW.js → EntityTypeIcon-CobE682z.js} +1 -1
  331. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  332. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-BDhPilK7.js → InteractivePreview-DYFW3lDD.js} +3 -3
  333. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-VeqEBv9v.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  334. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-Bs7Nn1Jr.js → LoadingDots-BU_OAEMP.js} +1 -1
  335. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-Bm3PmcCz.js → LogViewer-ceAyBX-H.js} +1 -1
  336. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-C6PKeMYR.js → ReportIssueModal-djPLI-WV.js} +2 -2
  337. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-Gq3Ocjo6.js → SafeScreenshot-BED4B6sP.js} +1 -1
  338. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BNLaXBHR.js → ScenarioViewer-B76aig_2.js} +2 -2
  339. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  340. package/codeyam-cli/src/webserver/build/client/assets/Terminal-Dnj5CY9R.js +41 -0
  341. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-CiwXDxLh.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  342. package/codeyam-cli/src/webserver/build/client/assets/{_index-B3TDXxnk.js → _index-C96V0n15.js} +1 -1
  343. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BtBFH820.js → activity.(_tab)-BpKzcsJz.js} +1 -1
  344. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +1 -0
  345. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  346. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-D9hemwl6.js +22 -0
  347. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  348. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  349. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  350. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  351. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  352. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  353. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  354. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  355. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  356. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  357. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  358. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  359. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  360. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  361. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  362. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  363. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  364. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  365. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  366. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  367. package/codeyam-cli/src/webserver/build/client/assets/{book-open-PttOB2SF.js → book-open-D_nMCFmP.js} +1 -1
  368. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-TJp6ofnp.js → chevron-down-BH2h1Ea2.js} +1 -1
  369. package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-JE9ZIoBl.js → chunk-JZWAC4HX-C4pqxYJB.js} +9 -9
  370. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-CXhHQYrI.js → circle-check-DyIKORY6.js} +1 -1
  371. package/codeyam-cli/src/webserver/build/client/assets/{copy-6y9ALfGT.js → copy-NDbZjXao.js} +1 -1
  372. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-Ca9fAY46.js → createLucideIcon-CMT1jU2q.js} +1 -1
  373. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +1 -0
  374. package/codeyam-cli/src/webserver/build/client/assets/editor-D1DAKXtT.js +8 -0
  375. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-n38keI1k.js → entity._sha._-CrjR3zZW.js} +10 -10
  376. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-DkzqFzFj.js +6 -0
  377. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.js +6 -0
  378. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  379. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-38yPijoD.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  380. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-BSHEfydn.js → entry.client-DTvKq3TY.js} +1 -1
  381. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DCPhhSMo.js → fileTableUtils-cPo8LiG3.js} +1 -1
  382. package/codeyam-cli/src/webserver/build/client/assets/{files-0N0YJQv7.js → files-DO4CZ16O.js} +1 -1
  383. package/codeyam-cli/src/webserver/build/client/assets/{git-DXnyr8uP.js → git-CFCTYk9I.js} +1 -1
  384. package/codeyam-cli/src/webserver/build/client/assets/globals-B17TBSS6.css +1 -0
  385. package/codeyam-cli/src/webserver/build/client/assets/{index-ChN9-fAY.js → index-10oVnAAH.js} +1 -1
  386. package/codeyam-cli/src/webserver/build/client/assets/{index-CcsFv748.js → index-BcvgDzbZ.js} +1 -1
  387. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  388. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-CTqLEAGU.js → loader-circle-BAXYRVEO.js} +1 -1
  389. package/codeyam-cli/src/webserver/build/client/assets/manifest-a632de18.js +1 -0
  390. package/codeyam-cli/src/webserver/build/client/assets/memory-Dg0mvYrI.js +96 -0
  391. package/codeyam-cli/src/webserver/build/client/assets/{pause-D6vreykR.js → pause-DTAcYxBt.js} +1 -1
  392. package/codeyam-cli/src/webserver/build/client/assets/root-DUKqhFlb.js +67 -0
  393. package/codeyam-cli/src/webserver/build/client/assets/{search-B8VUL8nl.js → search-fKo7v0Zo.js} +1 -1
  394. package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +1 -0
  395. package/codeyam-cli/src/webserver/build/client/assets/{simulations-CPoAg7Zo.js → simulations-B3aOzpCZ.js} +1 -1
  396. package/codeyam-cli/src/webserver/build/client/assets/{terminal-BrCP7uQo.js → terminal-BG4heKCG.js} +1 -1
  397. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BZz2NjYa.js → triangle-alert-DtSmdtM4.js} +1 -1
  398. package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-DNwUduNu.js → useCustomSizes-ByhSyh0W.js} +1 -1
  399. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  400. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-CpZgwliL.js → useReportContext-O-jkvSPx.js} +1 -1
  401. package/codeyam-cli/src/webserver/build/client/assets/{useToast-Bv9JFvUO.js → useToast-9FIWuYfK.js} +1 -1
  402. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  403. package/codeyam-cli/src/webserver/build/server/assets/index-HfLydfDq.js +1 -0
  404. package/codeyam-cli/src/webserver/build/server/assets/server-build-CUu_F-oo.js +366 -0
  405. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  406. package/codeyam-cli/src/webserver/build-info.json +5 -5
  407. package/codeyam-cli/src/webserver/devServer.js +39 -5
  408. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  409. package/codeyam-cli/src/webserver/editorProxy.js +440 -0
  410. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  411. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +175 -0
  412. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +140 -0
  413. package/codeyam-cli/src/webserver/server.js +226 -1
  414. package/codeyam-cli/src/webserver/server.js.map +1 -1
  415. package/codeyam-cli/src/webserver/terminalServer.js +698 -0
  416. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  417. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  418. package/codeyam-cli/templates/codeyam-memory-hook.sh +14 -14
  419. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  420. package/codeyam-cli/templates/editor-step-hook.py +147 -0
  421. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  422. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  423. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  424. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  425. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  426. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  427. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  428. package/codeyam-cli/templates/nextjs-prisma-sqlite/PRISMA_SETUP.md +84 -0
  429. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  430. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  431. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  432. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +19 -0
  433. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  434. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  435. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +43 -0
  436. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  437. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +35 -0
  438. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  439. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  440. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +37 -0
  441. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  442. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  443. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  444. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  445. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  446. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  447. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  448. package/codeyam-cli/templates/rule-reflection-hook.py +88 -31
  449. package/codeyam-cli/templates/rules-instructions.md +45 -90
  450. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  451. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  452. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +69 -0
  453. package/codeyam-cli/templates/{codeyam:memory.md → skills/codeyam-memory/SKILL.md} +231 -24
  454. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  455. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.sh +108 -0
  456. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh +69 -0
  457. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  458. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  459. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.sh +12 -0
  460. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter.jq +45 -0
  461. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.sh +139 -0
  462. package/codeyam-cli/templates/{codeyam:new-rule.md → skills/codeyam-new-rule/SKILL.md} +1 -3
  463. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  464. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  465. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  466. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  467. package/package.json +15 -13
  468. package/packages/ai/index.js +1 -1
  469. package/packages/ai/index.js.map +1 -1
  470. package/packages/ai/src/lib/analyzeScope.js +14 -0
  471. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  472. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  473. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  474. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  475. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  476. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  477. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  478. package/packages/ai/src/lib/completionCall.js +10 -7
  479. package/packages/ai/src/lib/completionCall.js.map +1 -1
  480. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +362 -10
  481. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  482. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  483. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  484. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +59 -17
  485. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  486. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  487. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  488. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  489. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  490. package/packages/ai/src/lib/generateEntityScenarioData.js +79 -5
  491. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  492. package/packages/ai/src/lib/generateExecutionFlows.js +97 -2
  493. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  494. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  495. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  496. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  497. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  498. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  499. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  500. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  501. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  502. package/packages/analyze/src/lib/ProjectAnalyzer.js +3 -0
  503. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  504. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  505. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  506. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +11 -1
  507. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  508. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +8 -1
  509. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  510. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  511. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  512. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  513. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  514. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  515. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  516. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +42 -13
  517. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  518. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +65 -0
  519. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  520. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +141 -71
  521. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  522. package/packages/database/index.js +1 -0
  523. package/packages/database/index.js.map +1 -1
  524. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  525. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  526. package/packages/database/src/lib/analysisToDb.js +1 -1
  527. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  528. package/packages/database/src/lib/branchToDb.js +1 -1
  529. package/packages/database/src/lib/branchToDb.js.map +1 -1
  530. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  531. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  532. package/packages/database/src/lib/commitToDb.js +1 -1
  533. package/packages/database/src/lib/commitToDb.js.map +1 -1
  534. package/packages/database/src/lib/fileToDb.js +1 -1
  535. package/packages/database/src/lib/fileToDb.js.map +1 -1
  536. package/packages/database/src/lib/kysely/db.js +5 -0
  537. package/packages/database/src/lib/kysely/db.js.map +1 -1
  538. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
  539. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  540. package/packages/database/src/lib/loadCommits.js +23 -13
  541. package/packages/database/src/lib/loadCommits.js.map +1 -1
  542. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  543. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  544. package/packages/database/src/lib/projectToDb.js +1 -1
  545. package/packages/database/src/lib/projectToDb.js.map +1 -1
  546. package/packages/database/src/lib/saveFiles.js +1 -1
  547. package/packages/database/src/lib/saveFiles.js.map +1 -1
  548. package/packages/database/src/lib/scenarioToDb.js +1 -1
  549. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  550. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  551. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  552. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  553. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  554. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  555. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  556. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  557. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  558. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  559. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  560. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  561. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  562. package/scripts/npm-post-install.cjs +34 -0
  563. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  564. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  565. package/codeyam-cli/src/commands/list.js +0 -31
  566. package/codeyam-cli/src/commands/list.js.map +0 -1
  567. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  568. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  569. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  570. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  571. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-ClaLpuOo.js +0 -34
  572. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DfKzxuoe.js +0 -11
  573. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C5lqplTC.js +0 -1
  574. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CBoafmVs.js +0 -6
  575. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DGgZjdFg.js +0 -6
  576. package/codeyam-cli/src/webserver/build/client/assets/globals-DoeDFXZN.css +0 -1
  577. package/codeyam-cli/src/webserver/build/client/assets/labs-CmBYA0PH.js +0 -1
  578. package/codeyam-cli/src/webserver/build/client/assets/manifest-76786b8e.js +0 -1
  579. package/codeyam-cli/src/webserver/build/client/assets/memory-CrNQfdMO.js +0 -76
  580. package/codeyam-cli/src/webserver/build/client/assets/root-QAY34PIo.js +0 -62
  581. package/codeyam-cli/src/webserver/build/client/assets/settings-eBI36Yv5.js +0 -1
  582. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-COky1GVF.js +0 -2
  583. package/codeyam-cli/src/webserver/build/server/assets/index-DV1ykEI6.js +0 -1
  584. package/codeyam-cli/src/webserver/build/server/assets/server-build-BrcVrUEv.js +0 -260
  585. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  586. package/codeyam-cli/templates/codeyam:diagnose.md +0 -805
  587. package/scripts/finalize-analyzer.cjs +0 -81
  588. /package/codeyam-cli/src/webserver/build/client/assets/{api.labs-survey-l0sNRNKZ.js → api.dev-mode-events-l0sNRNKZ.js} +0 -0
@@ -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('Rule timestamp:'):
161
- rule_info['rule_timestamp'] = detail.replace('Rule timestamp:', '').strip()
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. ALWAYS update the timestamp (run `codeyam memory touch`)\n")
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('rule_timestamp'):
302
- parts.append(f" Rule timestamp: {rule['rule_timestamp']}")
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', 'haiku',
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
- marker_dir = Path('/tmp/claude-rule-markers')
437
- marker_dir.mkdir(exist_ok=True)
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
- stale_rules = get_stale_rules()
474
-
475
- if len(stale_rules) > 0:
476
- stale_context = build_stale_rules_context(stale_rules)
477
- stale_context_file = marker_dir / f'{invocation_id}-stale.context'
478
- stale_context_file.write_text(stale_context)
479
-
480
- stale_log_file = marker_dir / f'{invocation_id}-stale.log'
481
- stale_notification_file = marker_dir / 'rule-notification-stale.md'
482
- stale_prompt = load_prompt_template(
483
- 'stale-rules-prompt.txt',
484
- CONTEXT_FILE=str(stale_context_file),
485
- NOTIFICATION_FILE=str(stale_notification_file),
486
- PROJECT_DIR=project_dir,
487
- )
488
- spawn_claude_agent(stale_prompt, stale_log_file, project_dir)
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
- marker_dir = Path('/tmp/claude-rule-markers')
506
- marker_dir.mkdir(exist_ok=True)
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** - Each rule should cover a single topic. If you're documenting two unrelated things, create two rules.
8
- 2. **Paths must match content scope** - A rule about one specific file should have that file in `paths`, not a broad `**/*.ts` pattern.
9
- 3. **Be concise** - Every word costs context. Use bullets and tables.
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
- ## When to Create a New Rule
11
+ **Example** a typical rule:
12
12
 
13
- Create a new rule when:
14
-
15
- - You learn something non-obvious about the codebase
16
- - You make a mistake and want to prevent it in the future
17
- - The user explains something that isn't clear from the code
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
- ## Path Specificity
19
+ # Mock Data Generation
53
20
 
54
- The `paths` field controls when the rule is shown. Match the scope of your content:
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
- | Content Scope | Path Pattern | Example |
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
- **Anti-pattern**: Don't use `'**/*.ts'` for a rule about one specific feature.
29
+ Create a rule when you learn something that **reading the code alone wouldn't reveal**:
64
30
 
65
- ## File Structure
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
- Rules mirror the source code structure:
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
- | Source Location | Rule Location |
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
- ## Required Frontmatter
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
- | Field | Purpose |
87
- | ----------- | ---------------------------------------------------------------- |
88
- | `paths` | Glob patterns - be specific to avoid loading rules unnecessarily |
89
- | `timestamp` | ISO 8601 - update when rule is reviewed |
90
-
91
- ## Content Guidelines
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
- ### Focus on What, Not What Not
58
+ Audit dates live in `.claude/codeyam-rule-state.json` (managed by `codeyam memory touch`). Keep frontmatter limited to `paths`.
99
59
 
100
- - Good: "Auth tokens are stored in httpOnly cookies via `src/auth/cookies.ts`"
101
- - Bad: "WARNING: Don't store tokens in localStorage!"
60
+ ## File Placement
102
61
 
103
- ### Keep Rules Short
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
- - Target 30-50 lines
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
- ## Categories
109
-
110
- **architecture** - Design decisions, file relationships, data flow
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
- - "Run tests with: `pnpm test path/to/test.ts`"
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
- **faq** - Gotchas, workarounds, common questions
73
+ ## Content Guidelines
121
74
 
122
- - "If you see error X, it means Y"
123
- - "This looks wrong but is intentional because..."
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.
@@ -1,5 +1,5 @@
1
1
  ---
2
- name: codeyam:debug
2
+ name: codeyam-debug
3
3
  autoApprove: true
4
4
  description: |
5
5
  Use this skill when entity analysis or capture fails with errors.
@@ -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