@codeyam/codeyam-cli 0.1.0-staging.323686 → 0.1.0-staging.4057bd2

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 (737) 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 +22 -22
  4. package/analyzer-template/packages/ai/index.ts +7 -1
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +62 -18
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +101 -12
  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 +409 -50
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +21 -6
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +1250 -253
  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/BatchSchemaProcessor.ts +16 -3
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +31 -3
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +37 -15
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +367 -96
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  26. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  27. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  28. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +393 -8
  29. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +9 -5
  30. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +145 -5
  31. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  32. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +649 -142
  33. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +1 -1
  34. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  35. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  36. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  37. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  38. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  39. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  40. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +25 -13
  41. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +4 -3
  42. package/analyzer-template/packages/analyze/index.ts +2 -0
  43. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  44. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +119 -26
  45. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  46. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  47. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  48. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  49. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  50. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  51. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  52. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +89 -9
  53. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +27 -4
  54. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  55. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  56. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  57. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +0 -3
  58. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  59. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  60. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  61. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +61 -13
  62. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +87 -25
  63. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +312 -19
  64. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +117 -9
  65. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +591 -75
  66. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  67. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  68. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  69. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  70. package/analyzer-template/packages/aws/package.json +10 -10
  71. package/analyzer-template/packages/database/index.ts +1 -0
  72. package/analyzer-template/packages/database/package.json +4 -4
  73. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  74. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  75. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  76. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  77. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  78. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  79. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  80. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  81. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +62 -0
  82. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  83. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  84. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  85. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  86. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  87. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  88. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  89. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  90. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  91. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  92. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  93. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  94. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  95. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  96. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  97. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  98. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  99. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  100. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  101. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  104. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  107. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  111. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  113. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +20 -0
  116. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  117. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
  118. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  119. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  120. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  121. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  122. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  123. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  124. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  125. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  126. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  127. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  128. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  129. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  130. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  131. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  132. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  134. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  135. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  136. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  137. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  139. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  142. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  143. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  144. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  145. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  146. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  147. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  148. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  149. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  150. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  151. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  152. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  153. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  154. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  155. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  156. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  157. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  158. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  159. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  160. package/analyzer-template/packages/github/package.json +2 -2
  161. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  162. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  163. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +6 -5
  164. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  165. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  166. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  167. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  168. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  169. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +5 -5
  170. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  171. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  172. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  173. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  174. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  175. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  176. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  177. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  178. package/analyzer-template/project/constructMockCode.ts +260 -60
  179. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  180. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  181. package/analyzer-template/project/start.ts +3 -0
  182. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  183. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  184. package/analyzer-template/project/writeMockDataTsx.ts +198 -8
  185. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  186. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  187. package/analyzer-template/tsconfig.json +13 -1
  188. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  189. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  190. package/background/src/lib/virtualized/project/constructMockCode.js +220 -45
  191. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  192. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  193. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  194. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  195. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  196. package/background/src/lib/virtualized/project/start.js +2 -0
  197. package/background/src/lib/virtualized/project/start.js.map +1 -1
  198. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  199. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  200. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  201. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  202. package/background/src/lib/virtualized/project/writeMockDataTsx.js +174 -4
  203. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  204. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  205. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  206. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  207. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  208. package/codeyam-cli/scripts/apply-setup.js +386 -9
  209. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  210. package/codeyam-cli/src/cli.js +33 -24
  211. package/codeyam-cli/src/cli.js.map +1 -1
  212. package/codeyam-cli/src/codeyam-cli.js +18 -2
  213. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  214. package/codeyam-cli/src/commands/analyze.js +21 -9
  215. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  216. package/codeyam-cli/src/commands/baseline.js +2 -0
  217. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  218. package/codeyam-cli/src/commands/debug.js +9 -5
  219. package/codeyam-cli/src/commands/debug.js.map +1 -1
  220. package/codeyam-cli/src/commands/default.js +87 -21
  221. package/codeyam-cli/src/commands/default.js.map +1 -1
  222. package/codeyam-cli/src/commands/editor.js +1839 -0
  223. package/codeyam-cli/src/commands/editor.js.map +1 -0
  224. package/codeyam-cli/src/commands/init.js +81 -260
  225. package/codeyam-cli/src/commands/init.js.map +1 -1
  226. package/codeyam-cli/src/commands/memory.js +97 -92
  227. package/codeyam-cli/src/commands/memory.js.map +1 -1
  228. package/codeyam-cli/src/commands/recapture.js +2 -0
  229. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  230. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  231. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  232. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  233. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  234. package/codeyam-cli/src/commands/test-startup.js +2 -0
  235. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  236. package/codeyam-cli/src/commands/verify.js +14 -2
  237. package/codeyam-cli/src/commands/verify.js.map +1 -1
  238. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +246 -0
  239. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  240. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +126 -0
  241. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  242. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +295 -0
  243. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  244. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  245. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  246. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +100 -0
  247. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  248. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +147 -0
  249. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  250. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +76 -0
  251. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  252. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  253. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  254. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  255. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  256. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  257. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  258. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  259. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  260. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  261. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  262. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +154 -86
  263. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  264. package/codeyam-cli/src/utils/analyzer.js +7 -0
  265. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  266. package/codeyam-cli/src/utils/backgroundServer.js +109 -22
  267. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  268. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  269. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  270. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  271. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  272. package/codeyam-cli/src/utils/editorAudit.js +82 -0
  273. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  274. package/codeyam-cli/src/utils/editorDevServer.js +98 -0
  275. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  276. package/codeyam-cli/src/utils/editorJournal.js +137 -0
  277. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  278. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  279. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  280. package/codeyam-cli/src/utils/editorPreloadHelpers.js +64 -0
  281. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  282. package/codeyam-cli/src/utils/editorPreview.js +66 -0
  283. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  284. package/codeyam-cli/src/utils/editorScenarios.js +56 -0
  285. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  286. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  287. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  288. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  289. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  290. package/codeyam-cli/src/utils/generateReport.js +2 -2
  291. package/codeyam-cli/src/utils/git.js +103 -0
  292. package/codeyam-cli/src/utils/git.js.map +1 -1
  293. package/codeyam-cli/src/utils/install-skills.js +114 -47
  294. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  295. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  296. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  297. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  298. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  299. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  300. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  301. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  302. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  303. package/codeyam-cli/src/utils/progress.js +7 -0
  304. package/codeyam-cli/src/utils/progress.js.map +1 -1
  305. package/codeyam-cli/src/utils/project.js +15 -5
  306. package/codeyam-cli/src/utils/project.js.map +1 -1
  307. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  308. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  309. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  310. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  311. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  312. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  313. package/codeyam-cli/src/utils/queue/job.js +74 -1
  314. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  315. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  316. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  317. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  318. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  319. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  320. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  321. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  322. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  323. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  324. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  325. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  326. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  327. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  328. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  329. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  330. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  331. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  332. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  333. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  334. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  335. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  336. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  337. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  338. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  339. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  340. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  341. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  342. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  343. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  344. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  345. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  346. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  347. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  348. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  349. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  350. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  351. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  352. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  353. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  354. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  355. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  356. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  357. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  358. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  359. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  360. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  361. package/codeyam-cli/src/utils/rules/index.js +2 -0
  362. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  363. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  364. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  365. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  366. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  367. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  368. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  369. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  370. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  371. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  372. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  373. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  374. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  375. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  376. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  377. package/codeyam-cli/src/utils/serverState.js +64 -12
  378. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  379. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +61 -43
  380. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  381. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  382. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  383. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  384. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  385. package/codeyam-cli/src/utils/testRunner.js +158 -0
  386. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  387. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  388. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  389. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  390. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  391. package/codeyam-cli/src/utils/webappDetection.js +14 -2
  392. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  393. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  394. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  395. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  396. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  397. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  398. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  399. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  400. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  401. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  402. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-DmJveP3T.js +1 -0
  403. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-C76mRRiF.js} +1 -1
  404. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  405. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CobE682z.js} +1 -1
  406. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  407. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  408. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  409. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  410. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  411. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-djPLI-WV.js} +3 -8
  412. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  413. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-B76aig_2.js} +2 -2
  414. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  415. package/codeyam-cli/src/webserver/build/client/assets/Terminal-Dnj5CY9R.js +41 -0
  416. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  417. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-C96V0n15.js} +1 -1
  418. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BpKzcsJz.js} +6 -11
  419. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +1 -0
  420. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  421. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-D9hemwl6.js +22 -0
  422. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  423. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  424. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  425. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  426. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  427. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  428. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  429. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  430. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  431. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  432. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  433. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  434. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  435. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  436. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  437. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  438. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  439. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  440. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  441. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  442. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  443. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  444. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  445. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  446. package/codeyam-cli/src/webserver/build/client/assets/book-open-D_nMCFmP.js +6 -0
  447. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-BH2h1Ea2.js} +1 -1
  448. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  449. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-DyIKORY6.js} +1 -1
  450. package/codeyam-cli/src/webserver/build/client/assets/copy-NDbZjXao.js +11 -0
  451. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-BdhJEx6B.js → createLucideIcon-CMT1jU2q.js} +1 -1
  452. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +1 -0
  453. package/codeyam-cli/src/webserver/build/client/assets/editor-D1DAKXtT.js +8 -0
  454. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-CrjR3zZW.js} +11 -11
  455. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-DkzqFzFj.js +6 -0
  456. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.js +6 -0
  457. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  459. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  460. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  461. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-DO4CZ16O.js} +1 -1
  462. package/codeyam-cli/src/webserver/build/client/assets/{git-CPTZZ-JZ.js → git-CFCTYk9I.js} +1 -1
  463. package/codeyam-cli/src/webserver/build/client/assets/globals-B17TBSS6.css +1 -0
  464. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  466. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  467. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-BAXYRVEO.js} +1 -1
  468. package/codeyam-cli/src/webserver/build/client/assets/manifest-a632de18.js +1 -0
  469. package/codeyam-cli/src/webserver/build/client/assets/memory-Dg0mvYrI.js +96 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/pause-DTAcYxBt.js +11 -0
  471. package/codeyam-cli/src/webserver/build/client/assets/root-DUKqhFlb.js +67 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-fKo7v0Zo.js} +1 -1
  473. package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +1 -0
  474. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-B3aOzpCZ.js} +1 -1
  475. package/codeyam-cli/src/webserver/build/client/assets/terminal-BG4heKCG.js +11 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-DtSmdtM4.js} +1 -1
  477. package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-C1v1PQzo.js → useCustomSizes-ByhSyh0W.js} +1 -1
  478. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  479. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  480. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  481. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  482. package/codeyam-cli/src/webserver/build/server/assets/index-HfLydfDq.js +1 -0
  483. package/codeyam-cli/src/webserver/build/server/assets/server-build-CUu_F-oo.js +366 -0
  484. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  485. package/codeyam-cli/src/webserver/build-info.json +5 -5
  486. package/codeyam-cli/src/webserver/devServer.js +39 -5
  487. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  488. package/codeyam-cli/src/webserver/editorProxy.js +440 -0
  489. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  490. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +175 -0
  491. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +140 -0
  492. package/codeyam-cli/src/webserver/server.js +226 -1
  493. package/codeyam-cli/src/webserver/server.js.map +1 -1
  494. package/codeyam-cli/src/webserver/terminalServer.js +698 -0
  495. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  496. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  497. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  498. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  499. package/codeyam-cli/templates/editor-step-hook.py +147 -0
  500. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  501. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  502. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  503. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  504. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  505. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  506. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  507. package/codeyam-cli/templates/nextjs-prisma-sqlite/PRISMA_SETUP.md +84 -0
  508. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  509. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  510. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  511. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +19 -0
  512. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  513. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  514. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +43 -0
  515. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  516. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +35 -0
  517. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  518. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  519. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +37 -0
  520. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  521. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  522. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  523. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  524. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  525. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  526. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  527. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  528. package/codeyam-cli/templates/rules-instructions.md +78 -0
  529. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  530. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  531. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +69 -0
  532. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  533. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  534. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.sh +108 -0
  535. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh +69 -0
  536. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  537. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  538. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.sh +12 -0
  539. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter.jq +45 -0
  540. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.sh +139 -0
  541. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  542. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  543. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  544. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  545. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  546. package/package.json +16 -14
  547. package/packages/ai/index.js +3 -2
  548. package/packages/ai/index.js.map +1 -1
  549. package/packages/ai/src/lib/analyzeScope.js +50 -13
  550. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  551. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +76 -12
  552. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  553. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  554. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  555. package/packages/ai/src/lib/astScopes/processExpression.js +317 -44
  556. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  557. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  558. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  559. package/packages/ai/src/lib/completionCall.js +10 -7
  560. package/packages/ai/src/lib/completionCall.js.map +1 -1
  561. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +996 -173
  562. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  563. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  564. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  565. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  566. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  567. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  568. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  569. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +33 -3
  570. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  571. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +36 -11
  572. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  573. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  574. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  575. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  576. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  577. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  578. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  579. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  580. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  581. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  582. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  583. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +309 -84
  584. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  585. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  586. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  587. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  588. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  589. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  590. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  591. package/packages/ai/src/lib/generateEntityScenarioData.js +284 -6
  592. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  593. package/packages/ai/src/lib/generateEntityScenarios.js +7 -1
  594. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  595. package/packages/ai/src/lib/generateExecutionFlows.js +107 -4
  596. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  597. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +447 -80
  598. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  599. package/packages/ai/src/lib/isolateScopes.js +39 -3
  600. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  601. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  602. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  603. package/packages/ai/src/lib/mergeStatements.js +70 -51
  604. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  605. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  606. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  607. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  608. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  609. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  610. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  611. package/packages/ai/src/lib/resolvePathToControllable.js +24 -14
  612. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  613. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  614. package/packages/analyze/index.js +1 -0
  615. package/packages/analyze/index.js.map +1 -1
  616. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  617. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  618. package/packages/analyze/src/lib/ProjectAnalyzer.js +99 -26
  619. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  620. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  621. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  622. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  623. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  624. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  625. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  626. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  627. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  628. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  629. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  630. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  631. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  632. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  633. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  634. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +65 -7
  635. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  636. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +24 -4
  637. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  638. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  639. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  640. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  641. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  642. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  643. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  644. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +0 -3
  645. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  646. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  647. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  648. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  649. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  650. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  651. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  652. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +56 -10
  653. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  654. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +75 -21
  655. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  656. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +215 -17
  657. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  658. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +56 -8
  659. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  660. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +494 -56
  661. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  662. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  663. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  664. package/packages/analyze/src/lib/index.js +1 -0
  665. package/packages/analyze/src/lib/index.js.map +1 -1
  666. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  667. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  668. package/packages/database/index.js +1 -0
  669. package/packages/database/index.js.map +1 -1
  670. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  671. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  672. package/packages/database/src/lib/analysisToDb.js +1 -1
  673. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  674. package/packages/database/src/lib/branchToDb.js +1 -1
  675. package/packages/database/src/lib/branchToDb.js.map +1 -1
  676. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  677. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  678. package/packages/database/src/lib/commitToDb.js +1 -1
  679. package/packages/database/src/lib/commitToDb.js.map +1 -1
  680. package/packages/database/src/lib/fileToDb.js +1 -1
  681. package/packages/database/src/lib/fileToDb.js.map +1 -1
  682. package/packages/database/src/lib/kysely/db.js +8 -0
  683. package/packages/database/src/lib/kysely/db.js.map +1 -1
  684. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +45 -0
  685. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  686. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  687. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  688. package/packages/database/src/lib/loadCommits.js +23 -13
  689. package/packages/database/src/lib/loadCommits.js.map +1 -1
  690. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  691. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  692. package/packages/database/src/lib/projectToDb.js +1 -1
  693. package/packages/database/src/lib/projectToDb.js.map +1 -1
  694. package/packages/database/src/lib/saveFiles.js +1 -1
  695. package/packages/database/src/lib/saveFiles.js.map +1 -1
  696. package/packages/database/src/lib/scenarioToDb.js +1 -1
  697. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  698. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  699. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  700. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  701. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  702. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  703. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  704. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  705. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  706. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  707. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  708. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  709. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  710. package/scripts/npm-post-install.cjs +34 -0
  711. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  712. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  713. package/codeyam-cli/src/commands/list.js +0 -31
  714. package/codeyam-cli/src/commands/list.js.map +0 -1
  715. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  716. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  717. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  718. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  719. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  720. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  721. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  722. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  723. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  724. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  725. package/codeyam-cli/src/webserver/build/client/assets/globals-D3yhhV8x.css +0 -1
  726. package/codeyam-cli/src/webserver/build/client/assets/manifest-7522edd4.js +0 -1
  727. package/codeyam-cli/src/webserver/build/client/assets/memory-yxFcrxBX.js +0 -92
  728. package/codeyam-cli/src/webserver/build/client/assets/root-eVAaavTS.js +0 -62
  729. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  730. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  731. package/codeyam-cli/src/webserver/build/server/assets/index-DVzYx8PN.js +0 -1
  732. package/codeyam-cli/src/webserver/build/server/assets/server-build-4Cr0uToj.js +0 -257
  733. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  734. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  735. package/codeyam-cli/templates/codeyam:memory.md +0 -462
  736. package/codeyam-cli/templates/codeyam:new-rule.md +0 -13
  737. package/scripts/finalize-analyzer.cjs +0 -81
@@ -1,10 +1,10 @@
1
1
  {
2
- "buildTimestamp": "2026-01-30T00:55:52.181Z",
3
- "buildTime": 1769734552181,
4
- "gitCommit": "03236865a7602ab6d30df31e0ad3bee876906fb9",
2
+ "buildTimestamp": "2026-03-03T20:30:23.298Z",
3
+ "buildTime": 1772569823298,
4
+ "gitCommit": "4057bd228dde59242c41a3d90c5f9229bff18564",
5
5
  "nodeVersion": "v20.20.0",
6
- "contentHash": "05d53efd18fbc545b72ac5e31193346a32efa60861ecfb3bf24454bef6533f43",
7
- "buildNumber": 549,
8
- "semanticVersion": "0.1.549",
9
- "version": "0.1.549 (2026-01-30T00:55+05d53ef)"
6
+ "contentHash": "56095f026fcf9575b86866f4fe3d3d61b9466cf70e4d3f16001752fd1febd7c2",
7
+ "buildNumber": 829,
8
+ "semanticVersion": "0.1.829",
9
+ "version": "0.1.829 (2026-03-03T20:30+56095f0)"
10
10
  }
@@ -1,7 +1,7 @@
1
1
 
2
- [1/30/2026, 12:55:52 AM] > codeyam-combo@1.0.0 mergeDependencies
3
- [1/30/2026, 12:55:52 AM] > node ./scripts/mergePackageJsonFiles.cjs
2
+ [3/3/2026, 8:30:23 PM] > codeyam-combo@1.0.0 mergeDependencies
3
+ [3/3/2026, 8:30:23 PM] > node ./scripts/mergePackageJsonFiles.cjs
4
4
 
5
5
 
6
- [1/30/2026, 12:55:52 AM] Merged dependencies into root package.json
6
+ [3/3/2026, 8:30:23 PM] Merged dependencies into root package.json
7
7
 
@@ -7,18 +7,18 @@
7
7
  "build": "tsc && node ./scripts/postbuild.cjs"
8
8
  },
9
9
  "dependencies": {
10
- "@aws-sdk/client-cloudwatch-logs": "^3.966.0",
11
- "@aws-sdk/client-cloudfront": "^3.966.0",
12
- "@aws-sdk/client-codebuild": "^3.948.0",
13
- "@aws-sdk/client-dynamodb": "^3.956.0",
14
- "@aws-sdk/client-ec2": "^3.899.0",
15
- "@aws-sdk/client-ecr": "^3.948.0",
16
- "@aws-sdk/client-ecs": "^3.956.0",
17
- "@aws-sdk/client-s3": "^3.940.0",
18
- "@aws-sdk/client-sqs": "^3.956.0",
19
- "@aws-sdk/lib-storage": "^3.975.0",
20
- "@aws-sdk/util-dynamodb": "^3.971.0",
21
- "@octokit/auth-app": "^8.1.0",
10
+ "@aws-sdk/client-cloudwatch-logs": "^3.990.0",
11
+ "@aws-sdk/client-cloudfront": "^3.990.0",
12
+ "@aws-sdk/client-codebuild": "^3.990.0",
13
+ "@aws-sdk/client-dynamodb": "^3.990.0",
14
+ "@aws-sdk/client-ec2": "^3.990.0",
15
+ "@aws-sdk/client-ecr": "^3.990.0",
16
+ "@aws-sdk/client-ecs": "^3.990.0",
17
+ "@aws-sdk/client-s3": "^3.990.0",
18
+ "@aws-sdk/client-sqs": "^3.990.0",
19
+ "@aws-sdk/lib-storage": "^3.990.0",
20
+ "@aws-sdk/util-dynamodb": "^3.990.0",
21
+ "@octokit/auth-app": "^8.2.0",
22
22
  "@octokit/rest": "^22.0.0",
23
23
  "@sendgrid/mail": "^8.1.4",
24
24
  "@supabase/supabase-js": "2.88.0",
@@ -26,13 +26,13 @@
26
26
  "dotenv": "^17.2.3",
27
27
  "express": "^5.2.1",
28
28
  "get-port": "^7.1.0",
29
- "htmlparser2": "^10.0.0",
29
+ "htmlparser2": "^10.1.0",
30
30
  "jest": "^30.2.0",
31
31
  "jsdom": "^27.4.0",
32
32
  "jsonc-parser": "^3.2.1",
33
- "lru-cache": "^11.2.4",
33
+ "lru-cache": "^11.2.5",
34
34
  "openai": "^6.16.0",
35
- "p-queue": "^8.1.0",
35
+ "p-queue": "^9.1.0",
36
36
  "p-retry": "^7.1.1",
37
37
  "piscina": "^5.1.4",
38
38
  "pixelmatch": "^5.3.0",
@@ -44,12 +44,12 @@
44
44
  "pluralize": "^8.0.0",
45
45
  "yargs": "^18.0.0",
46
46
  "json5": "^2.2.3",
47
- "@anthropic-ai/sdk": "^0.71.0",
48
- "@aws-sdk/s3-request-presigner": "^3.940.0",
49
- "better-sqlite3": "^12.4.1",
47
+ "@anthropic-ai/sdk": "^0.78.0",
48
+ "@aws-sdk/s3-request-presigner": "^3.990.0",
49
+ "better-sqlite3": "^12.6.2",
50
50
  "fetch-retry": "^6.0.0",
51
- "kysely": "^0.28.5",
52
- "pg": "^8.16.3",
51
+ "kysely": "^0.28.11",
52
+ "pg": "^8.19.0",
53
53
  "@octokit/request": "^10.0.3",
54
54
  "lucide-react": "^0.556.0",
55
55
  "react-resizable": "^3.0.5"
@@ -62,9 +62,9 @@
62
62
  "@types/jsdom": "^27.0.0",
63
63
  "@types/better-sqlite3": "^7.6.13",
64
64
  "@types/jest": "^30.0.0",
65
- "@types/pg": "^8.15.5",
65
+ "@types/pg": "^8.18.0",
66
66
  "@types/ws": "^8.18.1",
67
- "@octokit/types": "^15.0.0",
67
+ "@octokit/types": "^16.0.0",
68
68
  "@types/react": "^19.2.7",
69
69
  "@types/react-dom": "^19.2.3",
70
70
  "@types/react-resizable": "^3.0.7",
@@ -43,6 +43,7 @@ export { default as isolateScopes } from './src/lib/isolateScopes';
43
43
  export {
44
44
  default as analyzeScope,
45
45
  destroyWorkerPool,
46
+ skipWorkerPool,
46
47
  } from './src/lib/analyzeScope';
47
48
  export { default as logOrderedMap } from './src/lib/logOrderedMap';
48
49
  export {
@@ -57,8 +58,13 @@ export {
57
58
  removeDuplicateFunctionCalls,
58
59
  } from './src/lib/dataStructure/helpers/cleanNonObjectFunctions';
59
60
  export { default as convertDotNotation } from './src/lib/dataStructure/helpers/convertDotNotation';
61
+ export { default as convertTypeAnnotationsToValues } from './src/lib/dataStructure/helpers/convertTypeAnnotationsToValues';
60
62
  export { default as cleanOutBoundary } from './src/lib/cleanOutBoundary';
61
- export { fillInDirectSchemaGapsAndUnknowns } from './src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns';
63
+ export {
64
+ fillInDirectSchemaGapsAndUnknowns,
65
+ buildSchemaIndexes,
66
+ type SchemaIndexes,
67
+ } from './src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns';
62
68
  export { default as deduplicateFunctionSchemas } from './src/lib/dataStructure/helpers/deduplicateFunctionSchemas';
63
69
  export { default as getConditionalUsagesFromCode } from './src/lib/getConditionalUsagesFromCode';
64
70
  export type {
@@ -9,12 +9,12 @@
9
9
  "author": "",
10
10
  "license": "ISC",
11
11
  "dependencies": {
12
- "@anthropic-ai/sdk": "^0.71.0",
12
+ "@anthropic-ai/sdk": "^0.78.0",
13
13
  "jsdom": "^27.4.0",
14
- "p-queue": "^8.1.0",
14
+ "p-queue": "^9.1.0",
15
15
  "p-retry": "^7.1.1",
16
16
  "piscina": "^5.1.4",
17
- "lru-cache": "^11.2.4"
17
+ "lru-cache": "^11.2.5"
18
18
  },
19
19
  "devDependencies": {
20
20
  "@types/jsdom": "^27.0.0"
@@ -50,6 +50,19 @@ let workerPool: Piscina<
50
50
  AnalyzeScopeWorkerOutput
51
51
  > | null = null;
52
52
  let workerPoolDestroyed = false;
53
+ let workerPoolSkipped = false;
54
+
55
+ /**
56
+ * Skip worker pool initialization for the current session.
57
+ *
58
+ * The worker thread creates its own ProjectAnalyzer (ts.Program), which takes
59
+ * 50-70s — far longer than the actual entity processing (<2s for typical batches).
60
+ * When the entity count is small, running analyzeScopeLocal on the main thread
61
+ * reuses the existing ProjectAnalyzer and avoids this overhead entirely.
62
+ */
63
+ export function skipWorkerPool() {
64
+ workerPoolSkipped = true;
65
+ }
53
66
 
54
67
  /**
55
68
  * Check if we're in Node.js main thread
@@ -108,6 +121,7 @@ function ensureWorkerPool() {
108
121
  'analyzeScope should not be called after data structure preparation completes.',
109
122
  );
110
123
  }
124
+ if (workerPoolSkipped) return;
111
125
  if (workerPool !== null) return;
112
126
 
113
127
  // Only initialize worker pool in Node.js environment
@@ -123,10 +137,17 @@ function ensureWorkerPool() {
123
137
  // Note: WORKER_PATH is null when __mocks__/analyzeScope.ts is active
124
138
  const { WORKER_PATH } = analyzeScopeWorkerPaths();
125
139
 
140
+ // Disable workers when tracing is enabled - we need access to ScopeDataStructure
141
+ // instance in the main thread to capture pre-serialization state
142
+ const tracingEnabled =
143
+ process.env.CODEYAM_TRACE_TRANSFORMS === '1' ||
144
+ process.env.CODEYAM_TRACE_TRANSFORMS === 'true';
145
+
126
146
  if (
127
147
  process.env.USE_WORKER_THREADS &&
128
148
  WORKER_PATH &&
129
- fs.existsSync(WORKER_PATH)
149
+ fs.existsSync(WORKER_PATH) &&
150
+ !tracingEnabled
130
151
  ) {
131
152
  console.log('CodeYam: Using worker threads for analyzeScope', {
132
153
  WORKER_PATH,
@@ -159,6 +180,7 @@ function ensureWorkerPool() {
159
180
  WORKER_PATH,
160
181
  workerExists: WORKER_PATH ? fs.existsSync(WORKER_PATH) : false,
161
182
  USE_WORKER_THREADS: process.env.USE_WORKER_THREADS,
183
+ tracingEnabled,
162
184
  });
163
185
  workerPool = null; // Explicitly set to indicate "no workers"
164
186
  }
@@ -372,7 +394,7 @@ export async function analyzeScopeLocal({
372
394
  }
373
395
 
374
396
  for (const mapping of [structure, equivalentVariables]) {
375
- for (let [key, value] of Object.entries(mapping)) {
397
+ for (let [key, rawValue] of Object.entries(mapping)) {
376
398
  for (const [childScopeId, childScope] of sortedEntries) {
377
399
  const scopeText = fileAnalyzer.sourceFile.text.slice(
378
400
  childScope.start,
@@ -392,27 +414,49 @@ export async function analyzeScopeLocal({
392
414
  return text;
393
415
  };
394
416
 
395
- if (value.includes(scopeText)) {
396
- // DEBUG: Log when replacement happens
397
- if (key.includes('Fetcher') || key.includes('fetcher')) {
398
- console.log(
399
- 'CodeYam DEBUG value replacement:',
400
- JSON.stringify({
401
- key,
402
- oldValue: value,
403
- childScopeId,
404
- scopeTextPreview: scopeText.slice(0, 50),
405
- }),
406
- );
417
+ // Handle both string and string[] values (for OR expressions)
418
+ const processValue = (value: string): string => {
419
+ if (value.includes(scopeText)) {
420
+ // DEBUG: Log when replacement happens
421
+ if (key.includes('Fetcher') || key.includes('fetcher')) {
422
+ console.log(
423
+ 'CodeYam DEBUG value replacement:',
424
+ JSON.stringify({
425
+ key,
426
+ oldValue: value,
427
+ childScopeId,
428
+ scopeTextPreview: scopeText.slice(0, 50),
429
+ }),
430
+ );
431
+ }
432
+ return replaceChildScopeId(value);
433
+ }
434
+ return value;
435
+ };
436
+
437
+ if (Array.isArray(rawValue)) {
438
+ const newValues = rawValue.map(processValue);
439
+ (mapping as Record<string, string | string[]>)[key] =
440
+ newValues;
441
+ rawValue = newValues;
442
+ } else if (typeof rawValue === 'string') {
443
+ const newValue = processValue(rawValue);
444
+ if (newValue !== rawValue) {
445
+ (mapping as Record<string, string | string[]>)[key] =
446
+ newValue;
447
+ rawValue = newValue;
407
448
  }
408
- value = replaceChildScopeId(value);
409
- mapping[key] = value;
410
449
  }
450
+
411
451
  if (key.includes(scopeText)) {
412
452
  const oldKey = key;
413
453
  key = replaceChildScopeId(key);
414
- mapping[key] = mapping[oldKey];
415
- delete mapping[oldKey];
454
+ (mapping as Record<string, string | string[]>)[key] = (
455
+ mapping as Record<string, string | string[]>
456
+ )[oldKey];
457
+ delete (mapping as Record<string, string | string[]>)[
458
+ oldKey
459
+ ];
416
460
  }
417
461
  }
418
462
  }
@@ -102,7 +102,7 @@ import { ThrowStatementHandler } from './patterns/throwStatementHandler';
102
102
  */
103
103
  export class ASTScopeAnalyzer {
104
104
  private structure: Record<string, string> = {};
105
- private equivalentVariables: Record<string, string> = {};
105
+ private equivalentVariables: Record<string, string | string[]> = {};
106
106
  private environmentVariables: string[] = [];
107
107
  private conditionalUsages: Record<string, ConditionalUsage[]> = {};
108
108
  private compoundConditionals: CompoundConditional[] = [];
@@ -235,6 +235,8 @@ export class ASTScopeAnalyzer {
235
235
  typeChecker: this.fileAnalyzer.typeChecker,
236
236
  addEquivalence: (leftSide, rightSide) =>
237
237
  this.addEquivalence(leftSide, rightSide),
238
+ addMultipleEquivalencies: (leftSide, rightSides) =>
239
+ this.addMultipleEquivalencies(leftSide, rightSides),
238
240
  addType: (path, type) => this.addType(path, type),
239
241
  addEnvironmentVariable: (variablePath) =>
240
242
  this.addEnvironmentVariable(variablePath),
@@ -592,7 +594,9 @@ export class ASTScopeAnalyzer {
592
594
  }
593
595
 
594
596
  /**
595
- * Adds an equivalence relationship between two variable paths
597
+ * Adds an equivalence relationship between two variable paths.
598
+ * Uses overwrite semantics - if an equivalence already exists, the new value replaces it
599
+ * (unless the new value is 'undefined' or 'null').
596
600
  */
597
601
  private addEquivalence(
598
602
  leftSide: StructuredPath,
@@ -622,6 +626,44 @@ export class ASTScopeAnalyzer {
622
626
  }
623
627
  }
624
628
 
629
+ /**
630
+ * Adds multiple equivalence relationships for a single variable path.
631
+ * Used for OR expressions like `x = a || b` where x is equivalent to both a and b.
632
+ * The values are stored as an array to track all possible sources.
633
+ */
634
+ private addMultipleEquivalencies(
635
+ leftSide: StructuredPath,
636
+ rightSides: StructuredPath[],
637
+ ): void {
638
+ if (leftSide?.isLiteral()) {
639
+ return;
640
+ }
641
+
642
+ const leftSideStr = leftSide?.toLeftHandSideString();
643
+ if (!leftSideStr) return;
644
+
645
+ // Filter out invalid paths and convert to strings
646
+ const validRightSides = rightSides
647
+ .map((r) => r?.toRightHandSideString())
648
+ .filter((r): r is string => !!r && r !== leftSideStr);
649
+
650
+ // Remove duplicates while preserving order
651
+ const uniqueRightSides = [...new Set(validRightSides)];
652
+
653
+ // Filter out 'undefined' and 'null' unless they're the only values
654
+ const meaningfulValues = uniqueRightSides.filter(
655
+ (v) => v !== 'undefined' && v !== 'null',
656
+ );
657
+ const finalValues =
658
+ meaningfulValues.length > 0 ? meaningfulValues : uniqueRightSides;
659
+
660
+ if (finalValues.length === 0) return;
661
+
662
+ // Store as single value if only one, otherwise as array
663
+ this.equivalentVariables[leftSideStr] =
664
+ finalValues.length === 1 ? finalValues[0] : finalValues;
665
+ }
666
+
625
667
  /**
626
668
  * Adds a type for a variable path
627
669
  */
@@ -785,22 +827,38 @@ export class ASTScopeAnalyzer {
785
827
  // Update the type for the given path
786
828
  this.structure[pathStr] = newType;
787
829
 
788
- // Also update the type for any equivalent path
830
+ // Also update the type for any equivalent path(s)
789
831
  // e.g., if "state" -> "signature[0]", update "signature[0]" as well
790
- const equivalentPath = this.equivalentVariables[pathStr];
791
- if (equivalentPath) {
792
- this.structure[equivalentPath] = newType;
832
+ const rawEquivalentPath = this.equivalentVariables[pathStr];
833
+ const equivalentPaths = Array.isArray(rawEquivalentPath)
834
+ ? rawEquivalentPath
835
+ : rawEquivalentPath
836
+ ? [rawEquivalentPath]
837
+ : [];
838
+ for (const equivalentPath of equivalentPaths) {
839
+ if (typeof equivalentPath === 'string') {
840
+ this.structure[equivalentPath] = newType;
841
+ }
793
842
  }
794
843
 
795
844
  // For property paths like "data.status", check if the base has an equivalence
796
845
  // e.g., if "data" -> "signature[0]", transform "data.status" to "signature[0].status"
797
- for (const [varPath, equivalence] of Object.entries(
846
+ for (const [varPath, rawEquivalence] of Object.entries(
798
847
  this.equivalentVariables,
799
848
  )) {
800
849
  if (pathStr.startsWith(varPath + '.')) {
850
+ const equivalences = Array.isArray(rawEquivalence)
851
+ ? rawEquivalence
852
+ : rawEquivalence
853
+ ? [rawEquivalence]
854
+ : [];
801
855
  const suffix = pathStr.slice(varPath.length);
802
- const transformedPath = equivalence + suffix;
803
- this.structure[transformedPath] = newType;
856
+ for (const equivalence of equivalences) {
857
+ if (typeof equivalence === 'string') {
858
+ const transformedPath = equivalence + suffix;
859
+ this.structure[transformedPath] = newType;
860
+ }
861
+ }
804
862
  }
805
863
  }
806
864
  }
@@ -851,11 +909,42 @@ export class ASTScopeAnalyzer {
851
909
  if (tsType.flags & ts.TypeFlags.Union) {
852
910
  const unionType = tsType as ts.UnionType;
853
911
 
854
- // Check if it's a string literal union
855
- const isAllStringLiterals = unionType.types.every(
912
+ // Check if it's a string literal union (optionally with null/undefined).
913
+ // Preserve literal values so the LLM knows which values are valid when
914
+ // generating mock data. Without this, types like
915
+ // 'suggestion' | 'warning' | 'achievement' | 'tip' become just 'string'
916
+ // and the LLM generates invalid values (e.g. "Motivational").
917
+ const stringLiterals = unionType.types.filter(
856
918
  (t) => (t.flags & ts.TypeFlags.StringLiteral) !== 0,
857
919
  );
858
- if (isAllStringLiterals) return 'string';
920
+ const nullishTypes = unionType.types.filter(
921
+ (t) =>
922
+ (t.flags & ts.TypeFlags.Undefined) !== 0 ||
923
+ (t.flags & ts.TypeFlags.Null) !== 0,
924
+ );
925
+
926
+ if (
927
+ stringLiterals.length > 0 &&
928
+ stringLiterals.length + nullishTypes.length === unionType.types.length
929
+ ) {
930
+ const literalValues = stringLiterals.map(
931
+ (t) => `'${(t as ts.LiteralType).value}'`,
932
+ );
933
+ const literalUnion = literalValues.join(' | ');
934
+
935
+ if (nullishTypes.length > 0) {
936
+ const nullishParts: string[] = [];
937
+ if (nullishTypes.some((t) => (t.flags & ts.TypeFlags.Null) !== 0))
938
+ nullishParts.push('null');
939
+ if (
940
+ nullishTypes.some((t) => (t.flags & ts.TypeFlags.Undefined) !== 0)
941
+ )
942
+ nullishParts.push('undefined');
943
+ return `${literalUnion} | ${nullishParts.join(' | ')}`;
944
+ }
945
+
946
+ return literalUnion;
947
+ }
859
948
 
860
949
  // Check if it's a number literal union
861
950
  const isAllNumberLiterals = unionType.types.every(
@@ -22,11 +22,8 @@ export class ForInStatementHandler implements PatternHandler {
22
22
  // Process the expression being iterated over first (e.g., object)
23
23
  context.processExpression(node.expression);
24
24
 
25
- // Get the path of the object being iterated
26
- const expressionPath = context.getStructuralPath(node.expression);
27
-
28
- // If the initializer is a variable declaration with an identifier, establish equivalence
29
- // to indicate it's iterating over the keys of the expression
25
+ // If the initializer is a variable declaration with an identifier,
26
+ // type it as 'string' since for-in keys are always strings
30
27
  if (ts.isVariableDeclarationList(node.initializer)) {
31
28
  const declarations = node.initializer.declarations;
32
29
  if (
@@ -36,25 +33,21 @@ export class ForInStatementHandler implements PatternHandler {
36
33
  ) {
37
34
  const variableName = StructuredPath.fromBase(declarations[0].name.text);
38
35
 
39
- // Add type for the key variable (string for object keys)
36
+ // Type the key variable as 'string' for-in keys are always strings.
37
+ // Note: We intentionally do NOT equivalence the key variable to
38
+ // expressionPath[*key*]. The key variable is the KEY (a string),
39
+ // while [*key*] in the schema represents the VALUE at a dynamic key.
40
+ // Creating that equivalence would cause the 'string' type to propagate
41
+ // to the value path. The value access (e.g., obj[key]) is handled
42
+ // correctly by the element access handler in processExpression.
40
43
  context.addType(variableName, 'string');
41
-
42
- if (expressionPath) {
43
- // For for...in loops, the variable is equivalent to the keys of the object
44
- // We represent this with a *key* suffix to indicate it's a key, not a value
45
- context.addEquivalence(variableName, expressionPath.withKey('key'));
46
- }
47
44
  }
48
45
  } else if (ts.isIdentifier(node.initializer)) {
49
46
  // If the initializer is directly an identifier (rare but possible)
50
47
  const variableName = StructuredPath.fromBase(node.initializer.text);
51
48
 
52
- // Add type for the key variable
49
+ // See comment above — type as string but don't equivalence to value path
53
50
  context.addType(variableName, 'string');
54
-
55
- if (expressionPath) {
56
- context.addEquivalence(variableName, expressionPath.withKey('key'));
57
- }
58
51
  } else {
59
52
  context.processExpression(node.initializer);
60
53
  }