@codeyam/codeyam-cli 0.1.0-staging.483fdc2 → 0.1.0-staging.57cd50f

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (822) 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 +24 -24
  4. package/analyzer-template/packages/ai/index.ts +1 -0
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +588 -13
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +20 -1
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  24. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  25. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +124 -7
  26. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +101 -2
  27. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
  28. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  29. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  30. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  31. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  32. package/analyzer-template/packages/analyze/index.ts +2 -0
  33. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  34. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  35. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  36. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
  37. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +13 -0
  38. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  39. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  40. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  41. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
  42. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
  43. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
  44. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  45. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
  46. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  47. package/analyzer-template/packages/aws/package.json +10 -10
  48. package/analyzer-template/packages/database/index.ts +1 -0
  49. package/analyzer-template/packages/database/package.json +4 -4
  50. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  51. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  52. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  53. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  54. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  55. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  56. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  57. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  58. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +82 -0
  59. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  60. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  61. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  62. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  63. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  64. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  65. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  66. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  67. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  68. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  69. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  70. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  71. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  72. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  74. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  77. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  88. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  90. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +24 -0
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  96. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  98. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  99. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  100. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  101. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  116. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  119. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  122. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  125. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  126. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  127. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  128. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  129. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  130. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  132. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  134. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  135. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  136. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  137. package/analyzer-template/packages/github/package.json +1 -1
  138. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  139. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  140. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  141. package/analyzer-template/packages/ui-components/package.json +1 -1
  142. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  143. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  144. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  145. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  146. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  147. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  148. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  149. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  150. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  151. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  152. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  153. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  154. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  155. package/analyzer-template/project/constructMockCode.ts +206 -51
  156. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  157. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  158. package/analyzer-template/project/start.ts +3 -0
  159. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  160. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  161. package/analyzer-template/project/writeMockDataTsx.ts +136 -17
  162. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  163. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  164. package/analyzer-template/tsconfig.json +13 -1
  165. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  166. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  167. package/background/src/lib/virtualized/project/constructMockCode.js +175 -42
  168. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  169. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  170. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  171. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  172. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  173. package/background/src/lib/virtualized/project/start.js +2 -0
  174. package/background/src/lib/virtualized/project/start.js.map +1 -1
  175. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  176. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  177. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  178. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  179. package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
  180. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  181. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  182. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  183. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  184. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  185. package/codeyam-cli/scripts/apply-setup.js +252 -21
  186. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  187. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  188. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  189. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  190. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  191. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  192. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  193. package/codeyam-cli/src/cli.js +33 -24
  194. package/codeyam-cli/src/cli.js.map +1 -1
  195. package/codeyam-cli/src/codeyam-cli.js +18 -2
  196. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  197. package/codeyam-cli/src/commands/analyze.js +21 -9
  198. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  199. package/codeyam-cli/src/commands/baseline.js +2 -0
  200. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  201. package/codeyam-cli/src/commands/debug.js +2 -0
  202. package/codeyam-cli/src/commands/debug.js.map +1 -1
  203. package/codeyam-cli/src/commands/default.js +44 -21
  204. package/codeyam-cli/src/commands/default.js.map +1 -1
  205. package/codeyam-cli/src/commands/editor.js +2868 -0
  206. package/codeyam-cli/src/commands/editor.js.map +1 -0
  207. package/codeyam-cli/src/commands/init.js +81 -260
  208. package/codeyam-cli/src/commands/init.js.map +1 -1
  209. package/codeyam-cli/src/commands/memory.js +97 -92
  210. package/codeyam-cli/src/commands/memory.js.map +1 -1
  211. package/codeyam-cli/src/commands/recapture.js +2 -0
  212. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  213. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  214. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  215. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  216. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  217. package/codeyam-cli/src/commands/test-startup.js +2 -0
  218. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  219. package/codeyam-cli/src/commands/verify.js +14 -2
  220. package/codeyam-cli/src/commands/verify.js.map +1 -1
  221. package/codeyam-cli/src/data/techStacks.js +77 -0
  222. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  223. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  224. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  225. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  226. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  227. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  228. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  229. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  230. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  231. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  232. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  233. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  234. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  235. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  236. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  237. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  238. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  239. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  240. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  241. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  242. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  243. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  244. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  245. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  246. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  247. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
  248. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  249. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  250. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  251. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  252. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  253. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  254. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  255. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +275 -0
  256. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  257. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  258. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  259. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  260. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  261. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  262. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  263. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  264. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  266. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  268. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  270. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  271. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  272. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
  280. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  281. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  282. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  284. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/analyzer.js +7 -0
  286. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  287. package/codeyam-cli/src/utils/backgroundServer.js +198 -29
  288. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  289. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  290. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  291. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  292. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  293. package/codeyam-cli/src/utils/devServerState.js +71 -0
  294. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  295. package/codeyam-cli/src/utils/editorApi.js +73 -0
  296. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  297. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  298. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  299. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  300. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  301. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  302. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  303. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  304. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  305. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  306. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  307. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  308. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  309. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  310. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  311. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  312. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  313. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  314. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  315. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  316. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  317. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  318. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  319. package/codeyam-cli/src/utils/editorScenarios.js +126 -0
  320. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  321. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  322. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  323. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  324. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  325. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  326. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  327. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  328. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  329. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  330. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  331. package/codeyam-cli/src/utils/generateReport.js +2 -2
  332. package/codeyam-cli/src/utils/git.js +103 -0
  333. package/codeyam-cli/src/utils/git.js.map +1 -1
  334. package/codeyam-cli/src/utils/install-skills.js +101 -56
  335. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  336. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  337. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  338. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  339. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  340. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  341. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  342. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  343. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  344. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  345. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  346. package/codeyam-cli/src/utils/progress.js +7 -0
  347. package/codeyam-cli/src/utils/progress.js.map +1 -1
  348. package/codeyam-cli/src/utils/project.js +15 -5
  349. package/codeyam-cli/src/utils/project.js.map +1 -1
  350. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  351. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  352. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  353. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  354. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  355. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  356. package/codeyam-cli/src/utils/queue/job.js +74 -1
  357. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  358. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  359. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  360. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  361. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  362. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  363. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  364. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  365. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  366. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  367. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  368. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  369. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  370. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  371. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  372. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  373. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  374. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  375. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  376. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  377. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  378. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  379. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  380. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  381. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  383. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  384. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  385. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  386. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  387. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  388. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  389. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  390. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  391. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  392. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  393. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  394. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  395. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  396. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  397. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  398. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  399. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  400. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  401. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  402. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  403. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  404. package/codeyam-cli/src/utils/rules/index.js +2 -0
  405. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  406. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  407. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  409. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  410. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  411. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  413. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  415. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  417. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  418. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  419. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  420. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  421. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  422. package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
  423. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  424. package/codeyam-cli/src/utils/serverState.js +94 -12
  425. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  426. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
  427. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  428. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  429. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  430. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  431. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  432. package/codeyam-cli/src/utils/testRunner.js +158 -0
  433. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  434. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  435. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  436. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  437. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  438. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  439. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  440. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +31 -0
  441. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  442. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  443. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  444. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +487 -0
  445. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  446. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  447. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  448. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  449. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  450. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  451. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  452. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  453. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  454. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  455. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  456. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  457. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
  459. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  460. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  461. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  462. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  463. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  464. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  466. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
  467. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  468. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-0DY_NKil.js} +3 -3
  469. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  471. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
  473. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
  474. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  477. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  479. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  480. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  481. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  483. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  484. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  486. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  487. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  489. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  491. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  493. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  497. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  500. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  502. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  506. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  507. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  509. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  510. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  511. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/editor-vgc8jrQL.js +10 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-BF4oLwaE.js} +12 -12
  517. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  521. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  522. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  523. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
  524. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  527. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  528. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  531. package/codeyam-cli/src/webserver/build/client/assets/manifest-05e71e0b.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +96 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/root-ClvYBUSA.js +67 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  536. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
  538. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  540. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  543. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  544. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  545. package/codeyam-cli/src/webserver/build/server/assets/index-B4lc-hKc.js +1 -0
  546. package/codeyam-cli/src/webserver/build/server/assets/server-build-BbkD6mNV.js +426 -0
  547. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  548. package/codeyam-cli/src/webserver/build-info.json +5 -5
  549. package/codeyam-cli/src/webserver/devServer.js +39 -5
  550. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  551. package/codeyam-cli/src/webserver/editorProxy.js +846 -0
  552. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  553. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  554. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  555. package/codeyam-cli/src/webserver/server.js +258 -1
  556. package/codeyam-cli/src/webserver/server.js.map +1 -1
  557. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  558. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  559. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  560. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  561. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  562. package/codeyam-cli/templates/chrome-extension-react/package.json +26 -0
  563. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  564. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  565. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  566. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  567. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  568. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  569. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  570. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  571. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  572. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  573. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  574. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  575. package/codeyam-cli/templates/editor-step-hook.py +231 -0
  576. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  577. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  578. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  579. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  580. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  581. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  582. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  583. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  584. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  585. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  586. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  587. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  588. package/codeyam-cli/templates/expo-react-native/package.json +37 -0
  589. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  590. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  591. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  592. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  593. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  594. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  595. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  596. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  597. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  598. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  599. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  600. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  601. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  602. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  603. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  604. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  605. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  606. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  607. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  608. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  609. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  610. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  611. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  612. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
  613. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  614. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  615. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  616. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  617. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  618. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  619. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  620. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  621. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  622. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  623. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  624. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  625. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  626. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  627. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  628. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  629. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  630. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  631. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +36 -0
  632. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  633. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  634. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  635. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  636. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  637. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  638. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  639. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  640. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  641. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  642. package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
  643. package/codeyam-cli/templates/rules-instructions.md +45 -93
  644. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  645. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  646. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  647. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  648. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  649. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  650. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  651. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  652. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  653. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  654. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  655. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  656. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  657. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  658. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  659. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  660. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  661. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  662. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  663. package/package.json +28 -21
  664. package/packages/ai/index.js +1 -1
  665. package/packages/ai/index.js.map +1 -1
  666. package/packages/ai/src/lib/analyzeScope.js +21 -1
  667. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  668. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  669. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  670. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  671. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  672. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  673. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  674. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  675. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  676. package/packages/ai/src/lib/completionCall.js +10 -7
  677. package/packages/ai/src/lib/completionCall.js.map +1 -1
  678. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
  679. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  680. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  681. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
  683. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  684. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
  685. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  686. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  687. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  688. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  689. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  690. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  691. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  692. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
  693. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
  694. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
  695. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  696. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  697. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  698. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  699. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  700. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  701. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  702. package/packages/ai/src/lib/generateEntityScenarioData.js +89 -5
  703. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  704. package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
  705. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  706. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  707. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  708. package/packages/ai/src/lib/isolateScopes.js +39 -3
  709. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  710. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  711. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  712. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  713. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  714. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  715. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  716. package/packages/analyze/index.js +1 -0
  717. package/packages/analyze/index.js.map +1 -1
  718. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  719. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  720. package/packages/analyze/src/lib/asts/index.js +4 -2
  721. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  722. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  723. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  724. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
  725. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  726. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
  727. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  728. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  729. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  730. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  731. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  732. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  733. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  734. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
  735. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  736. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
  737. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  738. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
  739. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  740. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  741. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  742. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
  743. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  744. package/packages/analyze/src/lib/index.js +1 -0
  745. package/packages/analyze/src/lib/index.js.map +1 -1
  746. package/packages/database/index.js +1 -0
  747. package/packages/database/index.js.map +1 -1
  748. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  749. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  750. package/packages/database/src/lib/analysisToDb.js +1 -1
  751. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  752. package/packages/database/src/lib/branchToDb.js +1 -1
  753. package/packages/database/src/lib/branchToDb.js.map +1 -1
  754. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  755. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  756. package/packages/database/src/lib/commitToDb.js +1 -1
  757. package/packages/database/src/lib/commitToDb.js.map +1 -1
  758. package/packages/database/src/lib/fileToDb.js +1 -1
  759. package/packages/database/src/lib/fileToDb.js.map +1 -1
  760. package/packages/database/src/lib/kysely/db.js +8 -0
  761. package/packages/database/src/lib/kysely/db.js.map +1 -1
  762. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  763. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  764. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  765. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  766. package/packages/database/src/lib/loadCommits.js +23 -13
  767. package/packages/database/src/lib/loadCommits.js.map +1 -1
  768. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  769. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  770. package/packages/database/src/lib/projectToDb.js +1 -1
  771. package/packages/database/src/lib/projectToDb.js.map +1 -1
  772. package/packages/database/src/lib/saveFiles.js +1 -1
  773. package/packages/database/src/lib/saveFiles.js.map +1 -1
  774. package/packages/database/src/lib/scenarioToDb.js +1 -1
  775. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  776. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  777. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  778. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  779. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  780. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  781. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  782. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  783. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  784. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  785. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  786. package/packages/types/src/enums/ProjectFramework.js +2 -0
  787. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  788. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  789. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  790. package/scripts/npm-post-install.cjs +34 -0
  791. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  792. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  793. package/codeyam-cli/src/commands/list.js +0 -31
  794. package/codeyam-cli/src/commands/list.js.map +0 -1
  795. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  796. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  797. package/codeyam-cli/src/utils/reviewedRules.js +0 -92
  798. package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
  799. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  800. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  801. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  802. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  803. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  804. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  805. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  806. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  807. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  808. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  809. package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
  810. package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
  811. package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
  812. package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
  813. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  814. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  815. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  816. package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
  817. package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
  818. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  819. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  820. package/codeyam-cli/templates/codeyam:memory.md +0 -403
  821. package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
  822. package/scripts/finalize-analyzer.cjs +0 -81
@@ -0,0 +1,246 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import * as os from 'os';
4
+ import { readManifest, writeManifest, addScenarioToManifest, removeScenarioFromManifest, buildManifestFromRows, syncManifestToDatabase, } from "../scenariosManifest.js";
5
+ function makeTmpDir() {
6
+ return fs.mkdtempSync(path.join(os.tmpdir(), 'manifest-test-'));
7
+ }
8
+ function makeEntry(overrides = {}) {
9
+ return {
10
+ id: 'test-id-1',
11
+ name: 'Test Scenario',
12
+ description: null,
13
+ componentName: null,
14
+ componentPath: null,
15
+ url: '/',
16
+ mockDataFile: 'editor-scenarios/test-id-1.json',
17
+ screenshotFile: null,
18
+ createdAt: '2024-01-01T00:00:00.000Z',
19
+ updatedAt: '2024-01-01T00:00:00.000Z',
20
+ ...overrides,
21
+ };
22
+ }
23
+ describe('scenariosManifest', () => {
24
+ describe('readManifest / writeManifest round-trip', () => {
25
+ it('should write and read back a manifest', () => {
26
+ const tmp = makeTmpDir();
27
+ const manifest = {
28
+ version: 1,
29
+ updatedAt: '2024-01-01T00:00:00.000Z',
30
+ scenarios: [makeEntry()],
31
+ };
32
+ writeManifest(tmp, manifest);
33
+ const result = readManifest(tmp);
34
+ expect(result).toEqual(manifest);
35
+ });
36
+ it('should return null for missing file', () => {
37
+ const tmp = makeTmpDir();
38
+ expect(readManifest(tmp)).toBeNull();
39
+ });
40
+ });
41
+ describe('addScenarioToManifest', () => {
42
+ it('should create manifest if none exists', () => {
43
+ const tmp = makeTmpDir();
44
+ const entry = makeEntry();
45
+ addScenarioToManifest(tmp, entry);
46
+ const manifest = readManifest(tmp);
47
+ expect(manifest).not.toBeNull();
48
+ expect(manifest.scenarios).toHaveLength(1);
49
+ expect(manifest.scenarios[0].id).toBe('test-id-1');
50
+ });
51
+ it('should append to existing manifest', () => {
52
+ const tmp = makeTmpDir();
53
+ addScenarioToManifest(tmp, makeEntry({ id: 'a', name: 'A' }));
54
+ addScenarioToManifest(tmp, makeEntry({ id: 'b', name: 'B' }));
55
+ const manifest = readManifest(tmp);
56
+ expect(manifest.scenarios).toHaveLength(2);
57
+ });
58
+ it('should deduplicate by id (update existing)', () => {
59
+ const tmp = makeTmpDir();
60
+ addScenarioToManifest(tmp, makeEntry({ id: 'a', name: 'Original' }));
61
+ addScenarioToManifest(tmp, makeEntry({ id: 'a', name: 'Updated' }));
62
+ const manifest = readManifest(tmp);
63
+ expect(manifest.scenarios).toHaveLength(1);
64
+ expect(manifest.scenarios[0].name).toBe('Updated');
65
+ });
66
+ });
67
+ describe('removeScenarioFromManifest', () => {
68
+ it('should remove a scenario by id', () => {
69
+ const tmp = makeTmpDir();
70
+ addScenarioToManifest(tmp, makeEntry({ id: 'a', name: 'A' }));
71
+ addScenarioToManifest(tmp, makeEntry({ id: 'b', name: 'B' }));
72
+ removeScenarioFromManifest(tmp, 'a');
73
+ const manifest = readManifest(tmp);
74
+ expect(manifest.scenarios).toHaveLength(1);
75
+ expect(manifest.scenarios[0].id).toBe('b');
76
+ });
77
+ it('should handle removing from nonexistent manifest', () => {
78
+ const tmp = makeTmpDir();
79
+ // Should not throw
80
+ removeScenarioFromManifest(tmp, 'nonexistent');
81
+ });
82
+ it('should handle removing nonexistent id', () => {
83
+ const tmp = makeTmpDir();
84
+ addScenarioToManifest(tmp, makeEntry({ id: 'a', name: 'A' }));
85
+ removeScenarioFromManifest(tmp, 'nonexistent');
86
+ const manifest = readManifest(tmp);
87
+ expect(manifest.scenarios).toHaveLength(1);
88
+ });
89
+ });
90
+ describe('buildManifestFromRows', () => {
91
+ it('should build manifest from database-like rows', () => {
92
+ const rows = [
93
+ {
94
+ id: 'row-1',
95
+ name: 'Scenario 1',
96
+ description: 'A scenario',
97
+ component_name: 'Button',
98
+ component_path: 'app/components/Button.tsx',
99
+ url: '/isolated-components/Button?s=Default',
100
+ screenshot_path: 'screenshots/row-1.png',
101
+ created_at: '2024-01-01 00:00:00',
102
+ updated_at: '2024-01-02 00:00:00',
103
+ },
104
+ {
105
+ id: 'row-2',
106
+ name: 'Scenario 2',
107
+ description: null,
108
+ component_name: null,
109
+ component_path: null,
110
+ url: '/',
111
+ screenshot_path: null,
112
+ created_at: '2024-01-03 00:00:00',
113
+ updated_at: '2024-01-03 00:00:00',
114
+ },
115
+ ];
116
+ const manifest = buildManifestFromRows(rows);
117
+ expect(manifest.version).toBe(1);
118
+ expect(manifest.scenarios).toHaveLength(2);
119
+ expect(manifest.scenarios[0]).toEqual({
120
+ id: 'row-1',
121
+ name: 'Scenario 1',
122
+ description: 'A scenario',
123
+ componentName: 'Button',
124
+ componentPath: 'app/components/Button.tsx',
125
+ url: '/isolated-components/Button?s=Default',
126
+ mockDataFile: 'editor-scenarios/row-1.json',
127
+ screenshotFile: 'editor-scenarios/screenshots/row-1.png',
128
+ createdAt: '2024-01-01 00:00:00',
129
+ updatedAt: '2024-01-02 00:00:00',
130
+ });
131
+ expect(manifest.scenarios[1].screenshotFile).toBeNull();
132
+ });
133
+ it('should handle empty rows', () => {
134
+ const manifest = buildManifestFromRows([]);
135
+ expect(manifest.scenarios).toEqual([]);
136
+ });
137
+ });
138
+ describe('syncManifestToDatabase', () => {
139
+ it('should insert missing scenarios', async () => {
140
+ const tmp = makeTmpDir();
141
+ const entry = makeEntry({ id: 'new-1', name: 'New Scenario' });
142
+ addScenarioToManifest(tmp, entry);
143
+ const existingRows = [];
144
+ const insertedRows = [];
145
+ const updatedRows = [];
146
+ const result = await syncManifestToDatabase(tmp, 'project-1', existingRows, (row) => {
147
+ insertedRows.push(row);
148
+ }, (id, row) => {
149
+ updatedRows.push({ id, ...row });
150
+ });
151
+ expect(result.inserted).toBe(1);
152
+ expect(result.updated).toBe(0);
153
+ expect(result.skipped).toBe(0);
154
+ expect(insertedRows).toHaveLength(1);
155
+ expect(insertedRows[0].id).toBe('new-1');
156
+ expect(insertedRows[0].project_id).toBe('project-1');
157
+ });
158
+ it('should skip scenarios already in DB with same updatedAt', async () => {
159
+ const tmp = makeTmpDir();
160
+ const entry = makeEntry({
161
+ id: 'existing-1',
162
+ name: 'Existing',
163
+ updatedAt: '2024-01-01T00:00:00.000Z',
164
+ });
165
+ addScenarioToManifest(tmp, entry);
166
+ const existingRows = [
167
+ { id: 'existing-1', updated_at: '2024-01-01T00:00:00.000Z' },
168
+ ];
169
+ const insertedRows = [];
170
+ const updatedRows = [];
171
+ const result = await syncManifestToDatabase(tmp, 'project-1', existingRows, (row) => {
172
+ insertedRows.push(row);
173
+ }, (id, row) => {
174
+ updatedRows.push({ id, ...row });
175
+ });
176
+ expect(result.inserted).toBe(0);
177
+ expect(result.updated).toBe(0);
178
+ expect(result.skipped).toBe(1);
179
+ });
180
+ it('should update scenarios newer than DB row', async () => {
181
+ const tmp = makeTmpDir();
182
+ const entry = makeEntry({
183
+ id: 'existing-1',
184
+ name: 'Updated Name',
185
+ updatedAt: '2024-02-01T00:00:00.000Z',
186
+ });
187
+ addScenarioToManifest(tmp, entry);
188
+ const existingRows = [
189
+ { id: 'existing-1', updated_at: '2024-01-01T00:00:00.000Z' },
190
+ ];
191
+ const insertedRows = [];
192
+ const updatedRows = [];
193
+ const result = await syncManifestToDatabase(tmp, 'project-1', existingRows, (row) => {
194
+ insertedRows.push(row);
195
+ }, (id, row) => {
196
+ updatedRows.push({ id, ...row });
197
+ });
198
+ expect(result.inserted).toBe(0);
199
+ expect(result.updated).toBe(1);
200
+ expect(result.skipped).toBe(0);
201
+ expect(updatedRows[0].name).toBe('Updated Name');
202
+ });
203
+ it('should handle empty manifest', async () => {
204
+ const tmp = makeTmpDir();
205
+ writeManifest(tmp, { version: 1, updatedAt: '', scenarios: [] });
206
+ const result = await syncManifestToDatabase(tmp, 'project-1', [], () => { }, () => { });
207
+ expect(result.inserted).toBe(0);
208
+ expect(result.updated).toBe(0);
209
+ expect(result.skipped).toBe(0);
210
+ });
211
+ it('should handle no manifest file', async () => {
212
+ const tmp = makeTmpDir();
213
+ const result = await syncManifestToDatabase(tmp, 'project-1', [], () => { }, () => { });
214
+ expect(result.inserted).toBe(0);
215
+ expect(result.updated).toBe(0);
216
+ expect(result.skipped).toBe(0);
217
+ });
218
+ it('should handle mixed insert/update/skip', async () => {
219
+ const tmp = makeTmpDir();
220
+ addScenarioToManifest(tmp, makeEntry({
221
+ id: 'new-1',
222
+ name: 'New',
223
+ updatedAt: '2024-01-01T00:00:00.000Z',
224
+ }));
225
+ addScenarioToManifest(tmp, makeEntry({
226
+ id: 'updated-1',
227
+ name: 'Updated',
228
+ updatedAt: '2024-02-01T00:00:00.000Z',
229
+ }));
230
+ addScenarioToManifest(tmp, makeEntry({
231
+ id: 'current-1',
232
+ name: 'Current',
233
+ updatedAt: '2024-01-01T00:00:00.000Z',
234
+ }));
235
+ const existingRows = [
236
+ { id: 'updated-1', updated_at: '2024-01-01T00:00:00.000Z' },
237
+ { id: 'current-1', updated_at: '2024-01-01T00:00:00.000Z' },
238
+ ];
239
+ const result = await syncManifestToDatabase(tmp, 'project-1', existingRows, () => { }, () => { });
240
+ expect(result.inserted).toBe(1);
241
+ expect(result.updated).toBe(1);
242
+ expect(result.skipped).toBe(1);
243
+ });
244
+ });
245
+ });
246
+ //# sourceMappingURL=scenariosManifest.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scenariosManifest.test.js","sourceRoot":"","sources":["../../../../../src/utils/__tests__/scenariosManifest.test.ts"],"names":[],"mappings":"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"}
@@ -6,6 +6,50 @@ jest.mock('fs');
6
6
  jest.mock('path');
7
7
  const mockFs = fs;
8
8
  const mockPath = path;
9
+ // Shared permission lists for assertions
10
+ const memoryPermissions = [
11
+ 'Skill(codeyam-memory)',
12
+ 'Skill(codeyam-new-rule)',
13
+ 'Bash(codeyam)',
14
+ 'Bash(codeyam:*)',
15
+ 'Read(.codeyam/**)',
16
+ 'Edit(.codeyam/**)',
17
+ 'Write(.codeyam/**)',
18
+ 'Glob(.codeyam/**)',
19
+ ];
20
+ const editorPermissions = [
21
+ 'Skill(codeyam-editor)',
22
+ 'Bash(git:*)',
23
+ 'Edit(**)',
24
+ 'Write(**)',
25
+ ];
26
+ const simulationPermissions = [
27
+ 'Skill(codeyam-setup)',
28
+ 'Skill(codeyam-sim)',
29
+ 'Skill(codeyam-debug)',
30
+ 'Skill(codeyam-test)',
31
+ 'Skill(codeyam-verify)',
32
+ 'Skill(codeyam-dev-mode)',
33
+ 'Read(/tmp/**)',
34
+ 'Edit(/tmp/**)',
35
+ 'Write(/tmp/**)',
36
+ 'Glob(/tmp/**)',
37
+ 'Bash(npm install:*)',
38
+ 'Bash(npm run:*)',
39
+ 'Bash(npx:*)',
40
+ 'Bash(node:*)',
41
+ 'Bash(cp:*)',
42
+ 'Bash(mkdir:*)',
43
+ 'Bash(chmod:*)',
44
+ 'Bash(rm:*)',
45
+ 'Bash(curl:*)',
46
+ 'Bash(sleep:*)',
47
+ 'Bash(echo:*)',
48
+ 'Bash(grep:*)',
49
+ 'Bash(python3:*)',
50
+ 'Bash(cat:*)',
51
+ 'Bash(printf:*)',
52
+ ];
9
53
  describe('setupClaudeCodeSettings', () => {
10
54
  const projectRoot = '/Users/testuser/myproject';
11
55
  const claudeDir = '/Users/testuser/myproject/.claude';
@@ -23,10 +67,8 @@ describe('setupClaudeCodeSettings', () => {
23
67
  describe('directory and file creation', () => {
24
68
  test('creates .claude directory if it does not exist', () => {
25
69
  mockFs.existsSync.mockImplementation((p) => {
26
- // .claude directory doesn't exist
27
70
  if (p === claudeDir)
28
71
  return false;
29
- // settings.local.json doesn't exist either
30
72
  if (p === settingsPath)
31
73
  return false;
32
74
  return false;
@@ -39,12 +81,10 @@ describe('setupClaudeCodeSettings', () => {
39
81
  });
40
82
  expect(result).toBe(true);
41
83
  });
42
- test('creates new settings file with all CodeYam permissions', () => {
84
+ test('creates new settings file with only memory permissions by default', () => {
43
85
  mockFs.existsSync.mockImplementation((p) => {
44
- // .claude directory exists
45
86
  if (p === claudeDir)
46
87
  return true;
47
- // settings.local.json doesn't exist yet
48
88
  if (p === settingsPath)
49
89
  return false;
50
90
  return false;
@@ -52,92 +92,73 @@ describe('setupClaudeCodeSettings', () => {
52
92
  mockFs.writeFileSync.mockImplementation(() => undefined);
53
93
  const result = setupClaudeCodeSettings(projectRoot);
54
94
  expect(mockFs.writeFileSync).toHaveBeenCalledWith(settingsPath, expect.any(String), 'utf8');
55
- // Parse the written content to verify structure
56
95
  const writtenContent = mockFs.writeFileSync.mock
57
96
  .calls[0][1];
58
97
  const settings = JSON.parse(writtenContent);
59
- expect(settings.permissions.allow).toContain('Skill(codeyam:setup)');
60
- expect(settings.permissions.allow).toContain('Bash(codeyam)');
61
- expect(settings.permissions.allow).toContain('Read(.codeyam/**)');
98
+ // Should include memory permissions
99
+ for (const perm of memoryPermissions) {
100
+ expect(settings.permissions.allow).toContain(perm);
101
+ }
102
+ // Should NOT include simulation permissions
103
+ for (const perm of simulationPermissions) {
104
+ expect(settings.permissions.allow).not.toContain(perm);
105
+ }
62
106
  expect(result).toBe(true);
63
107
  });
64
108
  });
65
- describe('adding permissions to existing settings', () => {
66
- test('adds CodeYam permissions to existing settings without allow list', () => {
109
+ describe('memory mode (default)', () => {
110
+ test('adds only memory permissions when mode is memory', () => {
67
111
  mockFs.existsSync.mockReturnValue(true);
68
112
  mockFs.readFileSync.mockReturnValue(JSON.stringify({ otherSetting: 'value' }));
69
113
  let writtenSettings;
70
114
  mockFs.writeFileSync.mockImplementation((_path, content) => {
71
115
  writtenSettings = JSON.parse(content);
72
116
  });
73
- const result = setupClaudeCodeSettings(projectRoot);
74
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:setup)');
75
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:sim)');
76
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:debug)');
77
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:test)');
78
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:verify)');
79
- expect(writtenSettings.permissions.allow).toContain('Bash(codeyam:*)');
117
+ const result = setupClaudeCodeSettings(projectRoot, { mode: 'memory' });
118
+ for (const perm of memoryPermissions) {
119
+ expect(writtenSettings.permissions.allow).toContain(perm);
120
+ }
121
+ for (const perm of simulationPermissions) {
122
+ expect(writtenSettings.permissions.allow).not.toContain(perm);
123
+ }
80
124
  expect(writtenSettings.otherSetting).toBe('value');
81
125
  expect(result).toBe(true);
82
126
  });
83
- test('adds CodeYam permissions to existing allow list', () => {
127
+ test('default mode (no options) behaves as memory mode', () => {
84
128
  mockFs.existsSync.mockReturnValue(true);
85
- mockFs.readFileSync.mockReturnValue(JSON.stringify({
86
- permissions: {
87
- allow: ['some-other-tool'],
88
- },
89
- }));
129
+ mockFs.readFileSync.mockReturnValue(JSON.stringify({}));
90
130
  let writtenSettings;
91
131
  mockFs.writeFileSync.mockImplementation((_path, content) => {
92
132
  writtenSettings = JSON.parse(content);
93
133
  });
94
- const result = setupClaudeCodeSettings(projectRoot);
95
- expect(writtenSettings.permissions.allow).toContain('some-other-tool');
96
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:setup)');
97
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:sim)');
98
- expect(writtenSettings.permissions.allow).toContain('Write(.codeyam/**)');
99
- expect(result).toBe(true);
134
+ setupClaudeCodeSettings(projectRoot);
135
+ for (const perm of memoryPermissions) {
136
+ expect(writtenSettings.permissions.allow).toContain(perm);
137
+ }
138
+ for (const perm of simulationPermissions) {
139
+ expect(writtenSettings.permissions.allow).not.toContain(perm);
140
+ }
100
141
  });
101
- test('does not duplicate CodeYam permissions if already present', () => {
142
+ test('does not duplicate memory permissions if already present', () => {
102
143
  mockFs.existsSync.mockReturnValue(true);
103
144
  mockFs.readFileSync.mockReturnValue(JSON.stringify({
104
145
  permissions: {
105
- allow: [
106
- 'Skill(codeyam:setup)',
107
- 'Skill(codeyam:sim)',
108
- 'Skill(codeyam:debug)',
109
- 'Skill(codeyam:test)',
110
- 'Skill(codeyam:verify)',
111
- 'Skill(codeyam:memory)',
112
- 'Skill(codeyam:new-rule)',
113
- 'Bash(codeyam)',
114
- 'Bash(codeyam:*)',
115
- 'Read(.codeyam/**)',
116
- 'Edit(.codeyam/**)',
117
- 'Write(.codeyam/**)',
118
- 'Glob(.codeyam/**)',
119
- 'Read(/tmp/codeyam/**)',
120
- 'Edit(/tmp/codeyam/**)',
121
- 'Write(/tmp/codeyam/**)',
122
- 'Glob(/tmp/codeyam/**)',
123
- 'other-tool',
124
- ],
146
+ allow: [...memoryPermissions, 'other-tool'],
125
147
  },
126
148
  }));
127
149
  const result = setupClaudeCodeSettings(projectRoot);
128
- // Should not write if all permissions are already present
150
+ // Should not write if all memory permissions are already present
129
151
  expect(mockFs.writeFileSync).not.toHaveBeenCalled();
130
152
  expect(result).toBe(true);
131
153
  });
132
- test('adds only missing CodeYam permissions', () => {
154
+ test('adds only missing memory permissions', () => {
133
155
  mockFs.existsSync.mockReturnValue(true);
134
156
  mockFs.readFileSync.mockReturnValue(JSON.stringify({
135
157
  permissions: {
136
158
  allow: [
137
- 'Skill(codeyam:setup)',
138
- 'Skill(codeyam:sim)',
159
+ 'Skill(codeyam-memory)',
139
160
  'other-tool',
140
- // Missing: Skill(codeyam:debug), Skill(codeyam:test), Skill(codeyam:verify), all Bash and file ops
161
+ // Missing: Skill(codeyam-new-rule), Bash, file ops
141
162
  ],
142
163
  },
143
164
  }));
@@ -146,20 +167,95 @@ describe('setupClaudeCodeSettings', () => {
146
167
  writtenSettings = JSON.parse(content);
147
168
  });
148
169
  const result = setupClaudeCodeSettings(projectRoot);
149
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:setup)');
150
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:sim)');
151
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:debug)');
152
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:test)');
153
- expect(writtenSettings.permissions.allow).toContain('Skill(codeyam:verify)');
154
- expect(writtenSettings.permissions.allow).toContain('Bash(codeyam)');
170
+ for (const perm of memoryPermissions) {
171
+ expect(writtenSettings.permissions.allow).toContain(perm);
172
+ }
155
173
  expect(writtenSettings.permissions.allow).toContain('other-tool');
156
174
  // Should not duplicate existing ones
157
- const setupCount = writtenSettings.permissions.allow.filter((p) => p === 'Skill(codeyam:setup)').length;
158
- expect(setupCount).toBe(1);
175
+ const memoryCount = writtenSettings.permissions.allow.filter((p) => p === 'Skill(codeyam-memory)').length;
176
+ expect(memoryCount).toBe(1);
177
+ expect(result).toBe(true);
178
+ });
179
+ });
180
+ describe('full mode', () => {
181
+ test('adds all permissions (memory + simulation) in full mode', () => {
182
+ mockFs.existsSync.mockReturnValue(true);
183
+ mockFs.readFileSync.mockReturnValue(JSON.stringify({ otherSetting: 'value' }));
184
+ let writtenSettings;
185
+ mockFs.writeFileSync.mockImplementation((_path, content) => {
186
+ writtenSettings = JSON.parse(content);
187
+ });
188
+ const result = setupClaudeCodeSettings(projectRoot, { mode: 'full' });
189
+ for (const perm of memoryPermissions) {
190
+ expect(writtenSettings.permissions.allow).toContain(perm);
191
+ }
192
+ for (const perm of simulationPermissions) {
193
+ expect(writtenSettings.permissions.allow).toContain(perm);
194
+ }
195
+ expect(writtenSettings.otherSetting).toBe('value');
196
+ expect(result).toBe(true);
197
+ });
198
+ test('does not duplicate full permissions if already present', () => {
199
+ const allPermissions = [...memoryPermissions, ...simulationPermissions];
200
+ mockFs.existsSync.mockReturnValue(true);
201
+ mockFs.readFileSync.mockReturnValue(JSON.stringify({
202
+ permissions: {
203
+ allow: [...allPermissions, 'other-tool'],
204
+ },
205
+ }));
206
+ const result = setupClaudeCodeSettings(projectRoot, { mode: 'full' });
207
+ expect(mockFs.writeFileSync).not.toHaveBeenCalled();
208
+ expect(result).toBe(true);
209
+ });
210
+ test('adds simulation permissions to existing memory-only settings', () => {
211
+ mockFs.existsSync.mockReturnValue(true);
212
+ mockFs.readFileSync.mockReturnValue(JSON.stringify({
213
+ permissions: {
214
+ allow: [...memoryPermissions, 'other-tool'],
215
+ },
216
+ }));
217
+ let writtenSettings;
218
+ mockFs.writeFileSync.mockImplementation((_path, content) => {
219
+ writtenSettings = JSON.parse(content);
220
+ });
221
+ const result = setupClaudeCodeSettings(projectRoot, { mode: 'full' });
222
+ for (const perm of memoryPermissions) {
223
+ expect(writtenSettings.permissions.allow).toContain(perm);
224
+ }
225
+ for (const perm of simulationPermissions) {
226
+ expect(writtenSettings.permissions.allow).toContain(perm);
227
+ }
228
+ expect(writtenSettings.permissions.allow).toContain('other-tool');
229
+ // No duplicates
230
+ const memoryCount = writtenSettings.permissions.allow.filter((p) => p === 'Skill(codeyam-memory)').length;
231
+ expect(memoryCount).toBe(1);
232
+ expect(result).toBe(true);
233
+ });
234
+ });
235
+ describe('editor mode', () => {
236
+ test('adds memory + editor permissions in editor mode', () => {
237
+ mockFs.existsSync.mockReturnValue(true);
238
+ mockFs.readFileSync.mockReturnValue(JSON.stringify({}));
239
+ let writtenSettings;
240
+ mockFs.writeFileSync.mockImplementation((_path, content) => {
241
+ writtenSettings = JSON.parse(content);
242
+ });
243
+ const result = setupClaudeCodeSettings(projectRoot, {
244
+ mode: 'editor',
245
+ });
246
+ for (const perm of memoryPermissions) {
247
+ expect(writtenSettings.permissions.allow).toContain(perm);
248
+ }
249
+ for (const perm of editorPermissions) {
250
+ expect(writtenSettings.permissions.allow).toContain(perm);
251
+ }
252
+ // Editor mode includes simulation permissions too
253
+ for (const perm of simulationPermissions) {
254
+ expect(writtenSettings.permissions.allow).toContain(perm);
255
+ }
159
256
  expect(result).toBe(true);
160
257
  });
161
258
  });
162
- // Note: Stop hook configuration tests removed - hook functionality is currently disabled
163
259
  describe('error handling', () => {
164
260
  test('handles malformed JSON gracefully and creates new settings', () => {
165
261
  mockFs.existsSync.mockReturnValue(true);
@@ -192,33 +288,25 @@ describe('setupClaudeCodeSettings', () => {
192
288
  });
193
289
  });
194
290
  describe('idempotency', () => {
195
- test('returns true when settings are already fully configured', () => {
291
+ test('returns true without writing when memory settings are fully configured', () => {
196
292
  mockFs.existsSync.mockReturnValue(true);
197
293
  mockFs.readFileSync.mockReturnValue(JSON.stringify({
198
294
  permissions: {
199
- allow: [
200
- 'Skill(codeyam:setup)',
201
- 'Skill(codeyam:sim)',
202
- 'Skill(codeyam:debug)',
203
- 'Skill(codeyam:test)',
204
- 'Skill(codeyam:verify)',
205
- 'Skill(codeyam:memory)',
206
- 'Skill(codeyam:new-rule)',
207
- 'Bash(codeyam)',
208
- 'Bash(codeyam:*)',
209
- 'Read(.codeyam/**)',
210
- 'Edit(.codeyam/**)',
211
- 'Write(.codeyam/**)',
212
- 'Glob(.codeyam/**)',
213
- 'Read(/tmp/codeyam/**)',
214
- 'Edit(/tmp/codeyam/**)',
215
- 'Write(/tmp/codeyam/**)',
216
- 'Glob(/tmp/codeyam/**)',
217
- ],
295
+ allow: [...memoryPermissions],
218
296
  },
219
297
  }));
220
298
  const result = setupClaudeCodeSettings(projectRoot);
221
- // Should not write if already configured
299
+ expect(mockFs.writeFileSync).not.toHaveBeenCalled();
300
+ expect(result).toBe(true);
301
+ });
302
+ test('returns true without writing when full settings are fully configured', () => {
303
+ mockFs.existsSync.mockReturnValue(true);
304
+ mockFs.readFileSync.mockReturnValue(JSON.stringify({
305
+ permissions: {
306
+ allow: [...memoryPermissions, ...simulationPermissions],
307
+ },
308
+ }));
309
+ const result = setupClaudeCodeSettings(projectRoot, { mode: 'full' });
222
310
  expect(mockFs.writeFileSync).not.toHaveBeenCalled();
223
311
  expect(result).toBe(true);
224
312
  });