@machina.ai/cell-cli 1.8.2-rc1 → 1.11.0-rc1

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 (637) hide show
  1. package/dist/index.js +5 -5
  2. package/dist/index.js.map +1 -1
  3. package/dist/package.json +8 -7
  4. package/dist/src/commands/extensions/disable.js +8 -5
  5. package/dist/src/commands/extensions/disable.js.map +1 -1
  6. package/dist/src/commands/extensions/enable.js +8 -6
  7. package/dist/src/commands/extensions/enable.js.map +1 -1
  8. package/dist/src/commands/extensions/examples/context/GEMINI.md +9 -3
  9. package/dist/src/commands/extensions/examples/mcp-server/example.d.ts +6 -0
  10. package/dist/src/commands/extensions/examples/mcp-server/example.js +46 -0
  11. package/dist/src/commands/extensions/examples/mcp-server/example.js.map +1 -0
  12. package/dist/src/commands/extensions/install.d.ts +2 -0
  13. package/dist/src/commands/extensions/install.js +25 -5
  14. package/dist/src/commands/extensions/install.js.map +1 -1
  15. package/dist/src/commands/extensions/install.test.js +9 -9
  16. package/dist/src/commands/extensions/install.test.js.map +1 -1
  17. package/dist/src/commands/extensions/link.js +5 -4
  18. package/dist/src/commands/extensions/link.js.map +1 -1
  19. package/dist/src/commands/extensions/list.js +7 -5
  20. package/dist/src/commands/extensions/list.js.map +1 -1
  21. package/dist/src/commands/extensions/new.js +14 -20
  22. package/dist/src/commands/extensions/new.js.map +1 -1
  23. package/dist/src/commands/extensions/uninstall.js +4 -3
  24. package/dist/src/commands/extensions/uninstall.js.map +1 -1
  25. package/dist/src/commands/extensions/update.js +18 -22
  26. package/dist/src/commands/extensions/update.js.map +1 -1
  27. package/dist/src/commands/mcp/add.js +7 -4
  28. package/dist/src/commands/mcp/add.js.map +1 -1
  29. package/dist/src/commands/mcp/add.test.d.ts +6 -0
  30. package/dist/src/commands/mcp/add.test.js +244 -0
  31. package/dist/src/commands/mcp/add.test.js.map +1 -0
  32. package/dist/src/commands/mcp/list.js +11 -9
  33. package/dist/src/commands/mcp/list.js.map +1 -1
  34. package/dist/src/commands/mcp/list.test.d.ts +6 -0
  35. package/dist/src/commands/mcp/list.test.js +118 -0
  36. package/dist/src/commands/mcp/list.test.js.map +1 -0
  37. package/dist/src/commands/mcp/remove.js +3 -2
  38. package/dist/src/commands/mcp/remove.js.map +1 -1
  39. package/dist/src/commands/mcp/remove.test.d.ts +6 -0
  40. package/dist/src/commands/mcp/remove.test.js +175 -0
  41. package/dist/src/commands/mcp/remove.test.js.map +1 -0
  42. package/dist/src/commands/mcp.test.d.ts +6 -0
  43. package/dist/src/commands/mcp.test.js +62 -0
  44. package/dist/src/commands/mcp.test.js.map +1 -0
  45. package/dist/src/config/auth.js +3 -1
  46. package/dist/src/config/auth.js.map +1 -1
  47. package/dist/src/config/config.d.ts +4 -16
  48. package/dist/src/config/config.integration.test.d.ts +6 -0
  49. package/dist/src/config/config.integration.test.js +321 -0
  50. package/dist/src/config/config.integration.test.js.map +1 -0
  51. package/dist/src/config/config.js +80 -105
  52. package/dist/src/config/config.js.map +1 -1
  53. package/dist/src/config/config.test.d.ts +6 -0
  54. package/dist/src/config/config.test.js +1949 -0
  55. package/dist/src/config/config.test.js.map +1 -0
  56. package/dist/src/config/extension.d.ts +19 -27
  57. package/dist/src/config/extension.js +159 -139
  58. package/dist/src/config/extension.js.map +1 -1
  59. package/dist/src/config/extension.test.d.ts +6 -0
  60. package/dist/src/config/extension.test.js +1088 -0
  61. package/dist/src/config/extension.test.js.map +1 -0
  62. package/dist/src/config/extensions/extensionEnablement.d.ts +3 -3
  63. package/dist/src/config/extensions/extensionEnablement.js +5 -5
  64. package/dist/src/config/extensions/extensionEnablement.js.map +1 -1
  65. package/dist/src/config/extensions/extensionEnablement.test.js +26 -22
  66. package/dist/src/config/extensions/extensionEnablement.test.js.map +1 -1
  67. package/dist/src/config/extensions/github.d.ts +23 -7
  68. package/dist/src/config/extensions/github.js +139 -88
  69. package/dist/src/config/extensions/github.js.map +1 -1
  70. package/dist/src/config/extensions/github.test.js +74 -22
  71. package/dist/src/config/extensions/github.test.js.map +1 -1
  72. package/dist/src/config/extensions/github_fetch.d.ts +7 -0
  73. package/dist/src/config/extensions/github_fetch.js +34 -0
  74. package/dist/src/config/extensions/github_fetch.js.map +1 -0
  75. package/dist/src/config/extensions/update.d.ts +5 -4
  76. package/dist/src/config/extensions/update.js +23 -16
  77. package/dist/src/config/extensions/update.js.map +1 -1
  78. package/dist/src/config/extensions/update.test.js +57 -57
  79. package/dist/src/config/extensions/update.test.js.map +1 -1
  80. package/dist/src/config/extensions/variableSchema.d.ts +2 -0
  81. package/dist/src/config/extensions/variableSchema.js.map +1 -1
  82. package/dist/src/config/keyBindings.d.ts +2 -1
  83. package/dist/src/config/keyBindings.js +5 -3
  84. package/dist/src/config/keyBindings.js.map +1 -1
  85. package/dist/src/config/policy.d.ts +3 -2
  86. package/dist/src/config/policy.js +33 -24
  87. package/dist/src/config/policy.js.map +1 -1
  88. package/dist/src/config/policy.test.js +60 -36
  89. package/dist/src/config/policy.test.js.map +1 -1
  90. package/dist/src/config/sandboxConfig.d.ts +0 -1
  91. package/dist/src/config/sandboxConfig.js +1 -3
  92. package/dist/src/config/sandboxConfig.js.map +1 -1
  93. package/dist/src/config/settings.d.ts +10 -1
  94. package/dist/src/config/settings.js +24 -9
  95. package/dist/src/config/settings.js.map +1 -1
  96. package/dist/src/config/settings.test.d.ts +6 -0
  97. package/dist/src/config/settings.test.js +1941 -0
  98. package/dist/src/config/settings.test.js.map +1 -0
  99. package/dist/src/config/settingsSchema.d.ts +124 -3
  100. package/dist/src/config/settingsSchema.js +125 -4
  101. package/dist/src/config/settingsSchema.js.map +1 -1
  102. package/dist/src/config/trustedFolders.d.ts +0 -1
  103. package/dist/src/config/trustedFolders.js +2 -3
  104. package/dist/src/config/trustedFolders.js.map +1 -1
  105. package/dist/src/gemini.js +46 -33
  106. package/dist/src/gemini.js.map +1 -1
  107. package/dist/src/gemini.test.js +62 -19
  108. package/dist/src/gemini.test.js.map +1 -1
  109. package/dist/src/generated/git-commit.d.ts +2 -2
  110. package/dist/src/generated/git-commit.js +2 -2
  111. package/dist/src/generated/git-commit.js.map +1 -1
  112. package/dist/src/nonInteractiveCli.js +105 -4
  113. package/dist/src/nonInteractiveCli.js.map +1 -1
  114. package/dist/src/nonInteractiveCli.test.d.ts +6 -0
  115. package/dist/src/nonInteractiveCli.test.js +741 -0
  116. package/dist/src/nonInteractiveCli.test.js.map +1 -0
  117. package/dist/src/nonInteractiveCliCommands.js +2 -3
  118. package/dist/src/nonInteractiveCliCommands.js.map +1 -1
  119. package/dist/src/services/BuiltinCommandLoader.js +3 -0
  120. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  121. package/dist/src/services/BuiltinCommandLoader.test.js +37 -0
  122. package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
  123. package/dist/src/services/CommandService.js +2 -1
  124. package/dist/src/services/CommandService.js.map +1 -1
  125. package/dist/src/services/FileCommandLoader.d.ts +1 -1
  126. package/dist/src/services/FileCommandLoader.js +4 -4
  127. package/dist/src/services/FileCommandLoader.js.map +1 -1
  128. package/dist/src/services/FileCommandLoader.test.d.ts +6 -0
  129. package/dist/src/services/FileCommandLoader.test.js +971 -0
  130. package/dist/src/services/FileCommandLoader.test.js.map +1 -0
  131. package/dist/src/services/prompt-processors/argumentProcessor.test.d.ts +6 -0
  132. package/dist/src/services/prompt-processors/argumentProcessor.test.js +40 -0
  133. package/dist/src/services/prompt-processors/argumentProcessor.test.js.map +1 -0
  134. package/dist/src/services/prompt-processors/atFileProcessor.js +3 -2
  135. package/dist/src/services/prompt-processors/atFileProcessor.js.map +1 -1
  136. package/dist/src/services/prompt-processors/shellProcessor.js +1 -1
  137. package/dist/src/services/prompt-processors/shellProcessor.js.map +1 -1
  138. package/dist/src/services/prompt-processors/shellProcessor.test.d.ts +6 -0
  139. package/dist/src/services/prompt-processors/shellProcessor.test.js +482 -0
  140. package/dist/src/services/prompt-processors/shellProcessor.test.js.map +1 -0
  141. package/dist/src/test-utils/render.d.ts +12 -4
  142. package/dist/src/test-utils/render.js +56 -2
  143. package/dist/src/test-utils/render.js.map +1 -1
  144. package/dist/src/ui/App.js +1 -17
  145. package/dist/src/ui/App.js.map +1 -1
  146. package/dist/src/ui/App.test.d.ts +6 -0
  147. package/dist/src/ui/App.test.js +110 -0
  148. package/dist/src/ui/App.test.js.map +1 -0
  149. package/dist/src/ui/AppContainer.js +69 -39
  150. package/dist/src/ui/AppContainer.js.map +1 -1
  151. package/dist/src/ui/AppContainer.test.js +35 -9
  152. package/dist/src/ui/AppContainer.test.js.map +1 -1
  153. package/dist/src/ui/auth/AuthDialog.d.ts +1 -1
  154. package/dist/src/ui/auth/AuthDialog.js +5 -3
  155. package/dist/src/ui/auth/AuthDialog.js.map +1 -1
  156. package/dist/src/ui/auth/AuthInProgress.js +2 -2
  157. package/dist/src/ui/auth/AuthInProgress.js.map +1 -1
  158. package/dist/src/ui/auth/useAuth.d.ts +1 -1
  159. package/dist/src/ui/auth/useAuth.js +5 -3
  160. package/dist/src/ui/auth/useAuth.js.map +1 -1
  161. package/dist/src/ui/commands/aboutCommand.js +1 -1
  162. package/dist/src/ui/commands/aboutCommand.test.d.ts +6 -0
  163. package/dist/src/ui/commands/aboutCommand.test.js +130 -0
  164. package/dist/src/ui/commands/aboutCommand.test.js.map +1 -0
  165. package/dist/src/ui/commands/authCommand.js +1 -1
  166. package/dist/src/ui/commands/authCommand.test.d.ts +6 -0
  167. package/dist/src/ui/commands/authCommand.test.js +30 -0
  168. package/dist/src/ui/commands/authCommand.test.js.map +1 -0
  169. package/dist/src/ui/commands/bugCommand.js +1 -1
  170. package/dist/src/ui/commands/bugCommand.test.d.ts +6 -0
  171. package/dist/src/ui/commands/bugCommand.test.js +105 -0
  172. package/dist/src/ui/commands/bugCommand.test.js.map +1 -0
  173. package/dist/src/ui/commands/chatCommand.js +8 -25
  174. package/dist/src/ui/commands/chatCommand.js.map +1 -1
  175. package/dist/src/ui/commands/chatCommand.test.d.ts +6 -0
  176. package/dist/src/ui/commands/chatCommand.test.js +555 -0
  177. package/dist/src/ui/commands/chatCommand.test.js.map +1 -0
  178. package/dist/src/ui/commands/clearCommand.js +1 -1
  179. package/dist/src/ui/commands/clearCommand.test.d.ts +6 -0
  180. package/dist/src/ui/commands/clearCommand.test.js +76 -0
  181. package/dist/src/ui/commands/clearCommand.test.js.map +1 -0
  182. package/dist/src/ui/commands/compressCommand.js +1 -1
  183. package/dist/src/ui/commands/compressCommand.js.map +1 -1
  184. package/dist/src/ui/commands/compressCommand.test.d.ts +6 -0
  185. package/dist/src/ui/commands/compressCommand.test.js +98 -0
  186. package/dist/src/ui/commands/compressCommand.test.js.map +1 -0
  187. package/dist/src/ui/commands/copyCommand.js +2 -1
  188. package/dist/src/ui/commands/copyCommand.js.map +1 -1
  189. package/dist/src/ui/commands/copyCommand.test.d.ts +6 -0
  190. package/dist/src/ui/commands/copyCommand.test.js +242 -0
  191. package/dist/src/ui/commands/copyCommand.test.js.map +1 -0
  192. package/dist/src/ui/commands/corgiCommand.js +1 -1
  193. package/dist/src/ui/commands/corgiCommand.js.map +1 -1
  194. package/dist/src/ui/commands/corgiCommand.test.d.ts +6 -0
  195. package/dist/src/ui/commands/corgiCommand.test.js +28 -0
  196. package/dist/src/ui/commands/corgiCommand.test.js.map +1 -0
  197. package/dist/src/ui/commands/directoryCommand.js +1 -1
  198. package/dist/src/ui/commands/directoryCommand.js.map +1 -1
  199. package/dist/src/ui/commands/directoryCommand.test.d.ts +6 -0
  200. package/dist/src/ui/commands/directoryCommand.test.js +144 -0
  201. package/dist/src/ui/commands/directoryCommand.test.js.map +1 -0
  202. package/dist/src/ui/commands/docsCommand.js +1 -1
  203. package/dist/src/ui/commands/docsCommand.test.d.ts +6 -0
  204. package/dist/src/ui/commands/docsCommand.test.js +72 -0
  205. package/dist/src/ui/commands/docsCommand.test.js.map +1 -0
  206. package/dist/src/ui/commands/editorCommand.js +1 -1
  207. package/dist/src/ui/commands/editorCommand.test.d.ts +6 -0
  208. package/dist/src/ui/commands/editorCommand.test.js +27 -0
  209. package/dist/src/ui/commands/editorCommand.test.js.map +1 -0
  210. package/dist/src/ui/commands/extensionsCommand.js +30 -32
  211. package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
  212. package/dist/src/ui/commands/extensionsCommand.test.d.ts +6 -0
  213. package/dist/src/ui/commands/extensionsCommand.test.js +244 -0
  214. package/dist/src/ui/commands/extensionsCommand.test.js.map +1 -0
  215. package/dist/src/ui/commands/helpCommand.js +1 -1
  216. package/dist/src/ui/commands/helpCommand.test.d.ts +6 -0
  217. package/dist/src/ui/commands/helpCommand.test.js +42 -0
  218. package/dist/src/ui/commands/helpCommand.test.js.map +1 -0
  219. package/dist/src/ui/commands/ideCommand.js +6 -6
  220. package/dist/src/ui/commands/ideCommand.test.d.ts +6 -0
  221. package/dist/src/ui/commands/ideCommand.test.js +205 -0
  222. package/dist/src/ui/commands/ideCommand.test.js.map +1 -0
  223. package/dist/src/ui/commands/initCommand.js +1 -1
  224. package/dist/src/ui/commands/initCommand.js.map +1 -1
  225. package/dist/src/ui/commands/initCommand.test.d.ts +6 -0
  226. package/dist/src/ui/commands/initCommand.test.js +80 -0
  227. package/dist/src/ui/commands/initCommand.test.js.map +1 -0
  228. package/dist/src/ui/commands/mcpCommand.js +98 -88
  229. package/dist/src/ui/commands/mcpCommand.js.map +1 -1
  230. package/dist/src/ui/commands/mcpCommand.test.d.ts +6 -0
  231. package/dist/src/ui/commands/mcpCommand.test.js +148 -0
  232. package/dist/src/ui/commands/mcpCommand.test.js.map +1 -0
  233. package/dist/src/ui/commands/memoryCommand.js +27 -9
  234. package/dist/src/ui/commands/memoryCommand.js.map +1 -1
  235. package/dist/src/ui/commands/memoryCommand.test.d.ts +6 -0
  236. package/dist/src/ui/commands/memoryCommand.test.js +266 -0
  237. package/dist/src/ui/commands/memoryCommand.test.js.map +1 -0
  238. package/dist/src/ui/commands/privacyCommand.js +1 -1
  239. package/dist/src/ui/commands/privacyCommand.test.d.ts +6 -0
  240. package/dist/src/ui/commands/privacyCommand.test.js +32 -0
  241. package/dist/src/ui/commands/privacyCommand.test.js.map +1 -0
  242. package/dist/src/ui/commands/profileCommand.d.ts +7 -0
  243. package/dist/src/ui/commands/profileCommand.js +23 -0
  244. package/dist/src/ui/commands/profileCommand.js.map +1 -0
  245. package/dist/src/ui/commands/quitCommand.js +1 -1
  246. package/dist/src/ui/commands/quitCommand.test.d.ts +6 -0
  247. package/dist/src/ui/commands/quitCommand.test.js +50 -0
  248. package/dist/src/ui/commands/quitCommand.test.js.map +1 -0
  249. package/dist/src/ui/commands/restoreCommand.test.d.ts +6 -0
  250. package/dist/src/ui/commands/restoreCommand.test.js +190 -0
  251. package/dist/src/ui/commands/restoreCommand.test.js.map +1 -0
  252. package/dist/src/ui/commands/settingsCommand.test.d.ts +6 -0
  253. package/dist/src/ui/commands/settingsCommand.test.js +30 -0
  254. package/dist/src/ui/commands/settingsCommand.test.js.map +1 -0
  255. package/dist/src/ui/commands/setupGithubCommand.js +4 -3
  256. package/dist/src/ui/commands/setupGithubCommand.js.map +1 -1
  257. package/dist/src/ui/commands/statsCommand.js +3 -3
  258. package/dist/src/ui/commands/statsCommand.js.map +1 -1
  259. package/dist/src/ui/commands/statsCommand.test.d.ts +6 -0
  260. package/dist/src/ui/commands/statsCommand.test.js +53 -0
  261. package/dist/src/ui/commands/statsCommand.test.js.map +1 -0
  262. package/dist/src/ui/commands/terminalSetupCommand.test.d.ts +6 -0
  263. package/dist/src/ui/commands/terminalSetupCommand.test.js +66 -0
  264. package/dist/src/ui/commands/terminalSetupCommand.test.js.map +1 -0
  265. package/dist/src/ui/commands/themeCommand.js +1 -1
  266. package/dist/src/ui/commands/themeCommand.test.d.ts +6 -0
  267. package/dist/src/ui/commands/themeCommand.test.js +32 -0
  268. package/dist/src/ui/commands/themeCommand.test.js.map +1 -0
  269. package/dist/src/ui/commands/toolsCommand.js +1 -1
  270. package/dist/src/ui/commands/toolsCommand.test.d.ts +6 -0
  271. package/dist/src/ui/commands/toolsCommand.test.js +100 -0
  272. package/dist/src/ui/commands/toolsCommand.test.js.map +1 -0
  273. package/dist/src/ui/commands/types.d.ts +2 -0
  274. package/dist/src/ui/commands/types.js.map +1 -1
  275. package/dist/src/ui/commands/vimCommand.js +1 -1
  276. package/dist/src/ui/components/AnsiOutput.d.ts +1 -0
  277. package/dist/src/ui/components/AnsiOutput.js +5 -5
  278. package/dist/src/ui/components/AnsiOutput.js.map +1 -1
  279. package/dist/src/ui/components/AnsiOutput.test.js +6 -6
  280. package/dist/src/ui/components/AnsiOutput.test.js.map +1 -1
  281. package/dist/src/ui/components/AsciiArt.d.ts +3 -3
  282. package/dist/src/ui/components/AsciiArt.js +3 -3
  283. package/dist/src/ui/components/CliSpinner.d.ts +10 -0
  284. package/dist/src/ui/components/CliSpinner.js +20 -0
  285. package/dist/src/ui/components/CliSpinner.js.map +1 -0
  286. package/dist/src/ui/components/Composer.js +8 -9
  287. package/dist/src/ui/components/Composer.js.map +1 -1
  288. package/dist/src/ui/components/Composer.test.js +16 -1
  289. package/dist/src/ui/components/Composer.test.js.map +1 -1
  290. package/dist/src/ui/components/ContextSummaryDisplay.d.ts +0 -1
  291. package/dist/src/ui/components/ContextSummaryDisplay.js +4 -14
  292. package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
  293. package/dist/src/ui/components/ContextSummaryDisplay.test.d.ts +6 -0
  294. package/dist/src/ui/components/ContextSummaryDisplay.test.js +66 -0
  295. package/dist/src/ui/components/ContextSummaryDisplay.test.js.map +1 -0
  296. package/dist/src/ui/components/DebugProfiler.d.ts +18 -0
  297. package/dist/src/ui/components/DebugProfiler.js +158 -12
  298. package/dist/src/ui/components/DebugProfiler.js.map +1 -1
  299. package/dist/src/ui/components/DebugProfiler.test.d.ts +6 -0
  300. package/dist/src/ui/components/DebugProfiler.test.js +140 -0
  301. package/dist/src/ui/components/DebugProfiler.test.js.map +1 -0
  302. package/dist/src/ui/components/DialogManager.js +1 -5
  303. package/dist/src/ui/components/DialogManager.js.map +1 -1
  304. package/dist/src/ui/components/EditorSettingsDialog.js +1 -1
  305. package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
  306. package/dist/src/ui/components/FolderTrustDialog.js +9 -5
  307. package/dist/src/ui/components/FolderTrustDialog.js.map +1 -1
  308. package/dist/src/ui/components/FolderTrustDialog.test.js +14 -14
  309. package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
  310. package/dist/src/ui/components/Footer.js +7 -6
  311. package/dist/src/ui/components/Footer.js.map +1 -1
  312. package/dist/src/ui/components/Footer.test.d.ts +6 -0
  313. package/dist/src/ui/components/Footer.test.js +231 -0
  314. package/dist/src/ui/components/Footer.test.js.map +1 -0
  315. package/dist/src/ui/components/GeminiRespondingSpinner.js +2 -2
  316. package/dist/src/ui/components/GeminiRespondingSpinner.js.map +1 -1
  317. package/dist/src/ui/components/Help.js +1 -1
  318. package/dist/src/ui/components/Help.js.map +1 -1
  319. package/dist/src/ui/components/HistoryItemDisplay.js +2 -1
  320. package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
  321. package/dist/src/ui/components/InputPrompt.d.ts +11 -1
  322. package/dist/src/ui/components/InputPrompt.js +103 -29
  323. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  324. package/dist/src/ui/components/InputPrompt.test.d.ts +6 -0
  325. package/dist/src/ui/components/InputPrompt.test.js +1737 -0
  326. package/dist/src/ui/components/InputPrompt.test.js.map +1 -0
  327. package/dist/src/ui/components/MainContent.js +1 -1
  328. package/dist/src/ui/components/MainContent.js.map +1 -1
  329. package/dist/src/ui/components/ModelStatsDisplay.test.d.ts +6 -0
  330. package/dist/src/ui/components/ModelStatsDisplay.test.js +285 -0
  331. package/dist/src/ui/components/ModelStatsDisplay.test.js.map +1 -0
  332. package/dist/src/ui/components/Notifications.js +12 -4
  333. package/dist/src/ui/components/Notifications.js.map +1 -1
  334. package/dist/src/ui/components/PermissionsModifyTrustDialog.js +22 -18
  335. package/dist/src/ui/components/PermissionsModifyTrustDialog.js.map +1 -1
  336. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js +10 -2
  337. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js.map +1 -1
  338. package/dist/src/ui/components/QueuedMessageDisplay.js +3 -3
  339. package/dist/src/ui/components/QueuedMessageDisplay.js.map +1 -1
  340. package/dist/src/ui/components/QueuedMessageDisplay.test.js +4 -0
  341. package/dist/src/ui/components/QueuedMessageDisplay.test.js.map +1 -1
  342. package/dist/src/ui/components/RawMarkdownIndicator.d.ts +7 -0
  343. package/dist/src/ui/components/RawMarkdownIndicator.js +8 -0
  344. package/dist/src/ui/components/RawMarkdownIndicator.js.map +1 -0
  345. package/dist/src/ui/components/SessionSummaryDisplay.test.d.ts +6 -0
  346. package/dist/src/ui/components/SessionSummaryDisplay.test.js +74 -0
  347. package/dist/src/ui/components/SessionSummaryDisplay.test.js.map +1 -0
  348. package/dist/src/ui/components/SettingsDialog.js +12 -11
  349. package/dist/src/ui/components/SettingsDialog.js.map +1 -1
  350. package/dist/src/ui/components/SettingsDialog.test.js +190 -77
  351. package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
  352. package/dist/src/ui/components/StatsDisplay.test.d.ts +6 -0
  353. package/dist/src/ui/components/StatsDisplay.test.js +351 -0
  354. package/dist/src/ui/components/StatsDisplay.test.js.map +1 -0
  355. package/dist/src/ui/components/ThemeDialog.d.ts +4 -2
  356. package/dist/src/ui/components/ThemeDialog.js +3 -3
  357. package/dist/src/ui/components/ThemeDialog.js.map +1 -1
  358. package/dist/src/ui/components/ThemeDialog.test.js +13 -0
  359. package/dist/src/ui/components/ThemeDialog.test.js.map +1 -1
  360. package/dist/src/ui/components/ToolStatsDisplay.test.d.ts +6 -0
  361. package/dist/src/ui/components/ToolStatsDisplay.test.js +227 -0
  362. package/dist/src/ui/components/ToolStatsDisplay.test.js.map +1 -0
  363. package/dist/src/ui/components/messages/CompressionMessage.js +3 -3
  364. package/dist/src/ui/components/messages/CompressionMessage.js.map +1 -1
  365. package/dist/src/ui/components/messages/GeminiMessage.js +3 -1
  366. package/dist/src/ui/components/messages/GeminiMessage.js.map +1 -1
  367. package/dist/src/ui/components/messages/GeminiMessage.test.d.ts +6 -0
  368. package/dist/src/ui/components/messages/GeminiMessage.test.js +35 -0
  369. package/dist/src/ui/components/messages/GeminiMessage.test.js.map +1 -0
  370. package/dist/src/ui/components/messages/GeminiMessageContent.js +3 -1
  371. package/dist/src/ui/components/messages/GeminiMessageContent.js.map +1 -1
  372. package/dist/src/ui/components/messages/Todo.d.ts +7 -0
  373. package/dist/src/ui/components/messages/Todo.js +69 -0
  374. package/dist/src/ui/components/messages/Todo.js.map +1 -0
  375. package/dist/src/ui/components/messages/Todo.test.d.ts +6 -0
  376. package/dist/src/ui/components/messages/Todo.test.js +102 -0
  377. package/dist/src/ui/components/messages/Todo.test.js.map +1 -0
  378. package/dist/src/ui/components/messages/ToolConfirmationMessage.js +1 -1
  379. package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
  380. package/dist/src/ui/components/messages/ToolGroupMessage.js +2 -2
  381. package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
  382. package/dist/src/ui/components/messages/ToolMessage.js +9 -4
  383. package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
  384. package/dist/src/ui/components/messages/ToolMessage.test.js +2 -2
  385. package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
  386. package/dist/src/ui/components/messages/ToolMessageRawMarkdown.test.d.ts +6 -0
  387. package/dist/src/ui/components/messages/ToolMessageRawMarkdown.test.js +30 -0
  388. package/dist/src/ui/components/messages/ToolMessageRawMarkdown.test.js.map +1 -0
  389. package/dist/src/ui/components/messages/UserShellMessage.js +1 -1
  390. package/dist/src/ui/components/messages/UserShellMessage.js.map +1 -1
  391. package/dist/src/ui/components/shared/BaseSelectionList.test.js +33 -24
  392. package/dist/src/ui/components/shared/BaseSelectionList.test.js.map +1 -1
  393. package/dist/src/ui/components/shared/text-buffer.js +1 -1
  394. package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
  395. package/dist/src/ui/components/shared/text-buffer.test.d.ts +6 -0
  396. package/dist/src/ui/components/shared/text-buffer.test.js +1578 -0
  397. package/dist/src/ui/components/shared/text-buffer.test.js.map +1 -0
  398. package/dist/src/ui/components/shared/vim-buffer-actions.test.d.ts +6 -0
  399. package/dist/src/ui/components/shared/vim-buffer-actions.test.js +951 -0
  400. package/dist/src/ui/components/shared/vim-buffer-actions.test.js.map +1 -0
  401. package/dist/src/ui/components/views/ChatList.d.ts +12 -0
  402. package/dist/src/ui/components/views/ChatList.js +17 -0
  403. package/dist/src/ui/components/views/ChatList.js.map +1 -0
  404. package/dist/src/ui/components/views/ChatList.test.d.ts +6 -0
  405. package/dist/src/ui/components/views/ChatList.test.js +42 -0
  406. package/dist/src/ui/components/views/ChatList.test.js.map +1 -0
  407. package/dist/src/ui/components/views/ExtensionsList.js +3 -4
  408. package/dist/src/ui/components/views/ExtensionsList.js.map +1 -1
  409. package/dist/src/ui/components/views/ExtensionsList.test.js +2 -9
  410. package/dist/src/ui/components/views/ExtensionsList.test.js.map +1 -1
  411. package/dist/src/ui/components/views/McpStatus.d.ts +0 -1
  412. package/dist/src/ui/components/views/McpStatus.js +4 -4
  413. package/dist/src/ui/components/views/McpStatus.js.map +1 -1
  414. package/dist/src/ui/components/views/McpStatus.test.js +0 -5
  415. package/dist/src/ui/components/views/McpStatus.test.js.map +1 -1
  416. package/dist/src/ui/components/views/ToolsList.test.js +4 -4
  417. package/dist/src/ui/components/views/ToolsList.test.js.map +1 -1
  418. package/dist/src/ui/contexts/KeypressContext.d.ts +1 -0
  419. package/dist/src/ui/contexts/KeypressContext.js +219 -53
  420. package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
  421. package/dist/src/ui/contexts/KeypressContext.test.js +536 -10
  422. package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
  423. package/dist/src/ui/contexts/SessionContext.test.d.ts +6 -0
  424. package/dist/src/ui/contexts/SessionContext.test.js +177 -0
  425. package/dist/src/ui/contexts/SessionContext.test.js.map +1 -0
  426. package/dist/src/ui/contexts/UIActionsContext.d.ts +5 -4
  427. package/dist/src/ui/contexts/UIActionsContext.js.map +1 -1
  428. package/dist/src/ui/contexts/UIStateContext.d.ts +6 -4
  429. package/dist/src/ui/contexts/UIStateContext.js.map +1 -1
  430. package/dist/src/ui/hooks/atCommandProcessor.js +2 -2
  431. package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
  432. package/dist/src/ui/hooks/shellCommandProcessor.js +5 -7
  433. package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
  434. package/dist/src/ui/hooks/shellCommandProcessor.test.js +19 -32
  435. package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
  436. package/dist/src/ui/hooks/slashCommandProcessor.d.ts +2 -1
  437. package/dist/src/ui/hooks/slashCommandProcessor.js +11 -7
  438. package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
  439. package/dist/src/ui/hooks/slashCommandProcessor.test.d.ts +6 -0
  440. package/dist/src/ui/hooks/slashCommandProcessor.test.js +779 -0
  441. package/dist/src/ui/hooks/slashCommandProcessor.test.js.map +1 -0
  442. package/dist/src/ui/hooks/useAtCompletion.js +2 -2
  443. package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
  444. package/dist/src/ui/hooks/useAtCompletion.test.d.ts +6 -0
  445. package/dist/src/ui/hooks/useAtCompletion.test.js +385 -0
  446. package/dist/src/ui/hooks/useAtCompletion.test.js.map +1 -0
  447. package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js +0 -1
  448. package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js.map +1 -1
  449. package/dist/src/ui/hooks/useCommandCompletion.d.ts +1 -1
  450. package/dist/src/ui/hooks/useCommandCompletion.js +5 -3
  451. package/dist/src/ui/hooks/useCommandCompletion.js.map +1 -1
  452. package/dist/src/ui/hooks/useCommandCompletion.test.d.ts +6 -0
  453. package/dist/src/ui/hooks/useCommandCompletion.test.js +375 -0
  454. package/dist/src/ui/hooks/useCommandCompletion.test.js.map +1 -0
  455. package/dist/src/ui/hooks/useConsoleMessages.test.d.ts +6 -0
  456. package/dist/src/ui/hooks/useConsoleMessages.test.js +110 -0
  457. package/dist/src/ui/hooks/useConsoleMessages.test.js.map +1 -0
  458. package/dist/src/ui/hooks/useExtensionUpdates.d.ts +2 -1
  459. package/dist/src/ui/hooks/useExtensionUpdates.js +71 -19
  460. package/dist/src/ui/hooks/useExtensionUpdates.js.map +1 -1
  461. package/dist/src/ui/hooks/useExtensionUpdates.test.js +28 -13
  462. package/dist/src/ui/hooks/useExtensionUpdates.test.js.map +1 -1
  463. package/dist/src/ui/hooks/useFlickerDetector.d.ts +14 -0
  464. package/dist/src/ui/hooks/useFlickerDetector.js +37 -0
  465. package/dist/src/ui/hooks/useFlickerDetector.js.map +1 -0
  466. package/dist/src/ui/hooks/useFlickerDetector.test.d.ts +6 -0
  467. package/dist/src/ui/hooks/useFlickerDetector.test.js +102 -0
  468. package/dist/src/ui/hooks/useFlickerDetector.test.js.map +1 -0
  469. package/dist/src/ui/hooks/useFocus.test.d.ts +6 -0
  470. package/dist/src/ui/hooks/useFocus.test.js +115 -0
  471. package/dist/src/ui/hooks/useFocus.test.js.map +1 -0
  472. package/dist/src/ui/hooks/useFolderTrust.d.ts +2 -1
  473. package/dist/src/ui/hooks/useFolderTrust.js +12 -3
  474. package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
  475. package/dist/src/ui/hooks/useFolderTrust.test.d.ts +6 -0
  476. package/dist/src/ui/hooks/useFolderTrust.test.js +164 -0
  477. package/dist/src/ui/hooks/useFolderTrust.test.js.map +1 -0
  478. package/dist/src/ui/hooks/useGeminiStream.js +95 -56
  479. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  480. package/dist/src/ui/hooks/useGeminiStream.test.d.ts +6 -0
  481. package/dist/src/ui/hooks/useGeminiStream.test.js +1971 -0
  482. package/dist/src/ui/hooks/useGeminiStream.test.js.map +1 -0
  483. package/dist/src/ui/hooks/useHistoryManager.js +3 -3
  484. package/dist/src/ui/hooks/useHistoryManager.js.map +1 -1
  485. package/dist/src/ui/hooks/useInputHistoryStore.js +2 -1
  486. package/dist/src/ui/hooks/useInputHistoryStore.js.map +1 -1
  487. package/dist/src/ui/hooks/useKeypress.test.d.ts +6 -0
  488. package/dist/src/ui/hooks/useKeypress.test.js +234 -0
  489. package/dist/src/ui/hooks/useKeypress.test.js.map +1 -0
  490. package/dist/src/ui/hooks/useLoadingIndicator.test.js +5 -0
  491. package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
  492. package/dist/src/ui/hooks/useMessageQueue.d.ts +1 -0
  493. package/dist/src/ui/hooks/useMessageQueue.js +14 -0
  494. package/dist/src/ui/hooks/useMessageQueue.js.map +1 -1
  495. package/dist/src/ui/hooks/useMessageQueue.test.js +121 -0
  496. package/dist/src/ui/hooks/useMessageQueue.test.js.map +1 -1
  497. package/dist/src/ui/hooks/usePhraseCycler.d.ts +1 -0
  498. package/dist/src/ui/hooks/usePhraseCycler.js +157 -5
  499. package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
  500. package/dist/src/ui/hooks/usePhraseCycler.test.d.ts +6 -0
  501. package/dist/src/ui/hooks/usePhraseCycler.test.js +155 -0
  502. package/dist/src/ui/hooks/usePhraseCycler.test.js.map +1 -0
  503. package/dist/src/ui/hooks/useReactToolScheduler.js +2 -2
  504. package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
  505. package/dist/src/ui/hooks/useSelectionList.js +50 -23
  506. package/dist/src/ui/hooks/useSelectionList.js.map +1 -1
  507. package/dist/src/ui/hooks/useSelectionList.test.js +24 -0
  508. package/dist/src/ui/hooks/useSelectionList.test.js.map +1 -1
  509. package/dist/src/ui/hooks/useShellHistory.test.js +16 -10
  510. package/dist/src/ui/hooks/useShellHistory.test.js.map +1 -1
  511. package/dist/src/ui/hooks/useShowMemoryCommand.d.ts +1 -1
  512. package/dist/src/ui/hooks/useShowMemoryCommand.js +4 -3
  513. package/dist/src/ui/hooks/useShowMemoryCommand.js.map +1 -1
  514. package/dist/src/ui/hooks/useSlashCompletion.js +2 -1
  515. package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
  516. package/dist/src/ui/hooks/useTerminalSize.js +2 -3
  517. package/dist/src/ui/hooks/useTerminalSize.js.map +1 -1
  518. package/dist/src/ui/hooks/useThemeCommand.d.ts +2 -1
  519. package/dist/src/ui/hooks/useThemeCommand.js +6 -0
  520. package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
  521. package/dist/src/ui/hooks/useToolScheduler.test.js +3 -0
  522. package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
  523. package/dist/src/ui/hooks/vim.js +2 -1
  524. package/dist/src/ui/hooks/vim.js.map +1 -1
  525. package/dist/src/ui/hooks/vim.test.d.ts +6 -0
  526. package/dist/src/ui/hooks/vim.test.js +1389 -0
  527. package/dist/src/ui/hooks/vim.test.js.map +1 -0
  528. package/dist/src/ui/keyMatchers.test.js +9 -3
  529. package/dist/src/ui/keyMatchers.test.js.map +1 -1
  530. package/dist/src/ui/layouts/DefaultAppLayout.d.ts +1 -3
  531. package/dist/src/ui/layouts/DefaultAppLayout.js +5 -2
  532. package/dist/src/ui/layouts/DefaultAppLayout.js.map +1 -1
  533. package/dist/src/ui/layouts/ScreenReaderAppLayout.js +4 -1
  534. package/dist/src/ui/layouts/ScreenReaderAppLayout.js.map +1 -1
  535. package/dist/src/ui/noninteractive/nonInteractiveUi.js +1 -0
  536. package/dist/src/ui/noninteractive/nonInteractiveUi.js.map +1 -1
  537. package/dist/src/ui/state/extensions.d.ts +22 -3
  538. package/dist/src/ui/state/extensions.js +26 -4
  539. package/dist/src/ui/state/extensions.js.map +1 -1
  540. package/dist/src/ui/themes/color-utils.js +2 -1
  541. package/dist/src/ui/themes/color-utils.js.map +1 -1
  542. package/dist/src/ui/themes/theme-manager.js +8 -7
  543. package/dist/src/ui/themes/theme-manager.js.map +1 -1
  544. package/dist/src/ui/themes/theme.test.d.ts +6 -0
  545. package/dist/src/ui/themes/theme.test.js +85 -0
  546. package/dist/src/ui/themes/theme.test.js.map +1 -0
  547. package/dist/src/ui/types.d.ts +11 -3
  548. package/dist/src/ui/types.js +1 -0
  549. package/dist/src/ui/types.js.map +1 -1
  550. package/dist/src/ui/utils/CodeColorizer.d.ts +1 -1
  551. package/dist/src/ui/utils/CodeColorizer.js +4 -2
  552. package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
  553. package/dist/src/ui/utils/MarkdownDisplay.d.ts +1 -0
  554. package/dist/src/ui/utils/MarkdownDisplay.js +8 -1
  555. package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
  556. package/dist/src/ui/utils/commandUtils.js +20 -3
  557. package/dist/src/ui/utils/commandUtils.js.map +1 -1
  558. package/dist/src/ui/utils/commandUtils.test.js +61 -6
  559. package/dist/src/ui/utils/commandUtils.test.js.map +1 -1
  560. package/dist/src/ui/utils/computeStats.js +5 -2
  561. package/dist/src/ui/utils/computeStats.js.map +1 -1
  562. package/dist/src/ui/utils/computeStats.test.d.ts +6 -0
  563. package/dist/src/ui/utils/computeStats.test.js +262 -0
  564. package/dist/src/ui/utils/computeStats.test.js.map +1 -0
  565. package/dist/src/ui/utils/terminalSetup.js +3 -2
  566. package/dist/src/ui/utils/terminalSetup.js.map +1 -1
  567. package/dist/src/ui/utils/ui-sizing.d.ts +7 -0
  568. package/dist/src/ui/utils/ui-sizing.js +23 -0
  569. package/dist/src/ui/utils/ui-sizing.js.map +1 -0
  570. package/dist/src/ui/utils/updateCheck.d.ts +2 -1
  571. package/dist/src/ui/utils/updateCheck.js +6 -2
  572. package/dist/src/ui/utils/updateCheck.js.map +1 -1
  573. package/dist/src/ui/utils/updateCheck.test.js +25 -10
  574. package/dist/src/ui/utils/updateCheck.test.js.map +1 -1
  575. package/dist/src/utils/cleanup.test.d.ts +6 -0
  576. package/dist/src/utils/cleanup.test.js +49 -0
  577. package/dist/src/utils/cleanup.test.js.map +1 -0
  578. package/dist/src/utils/commentJson.js +95 -13
  579. package/dist/src/utils/commentJson.js.map +1 -1
  580. package/dist/src/utils/commentJson.test.js +161 -0
  581. package/dist/src/utils/commentJson.test.js.map +1 -1
  582. package/dist/src/utils/errors.d.ts +9 -3
  583. package/dist/src/utils/errors.js +87 -16
  584. package/dist/src/utils/errors.js.map +1 -1
  585. package/dist/src/utils/errors.test.js +40 -46
  586. package/dist/src/utils/errors.test.js.map +1 -1
  587. package/dist/src/utils/events.d.ts +2 -1
  588. package/dist/src/utils/events.js +1 -0
  589. package/dist/src/utils/events.js.map +1 -1
  590. package/dist/src/utils/gitUtils.js +3 -2
  591. package/dist/src/utils/gitUtils.js.map +1 -1
  592. package/dist/src/utils/handleAutoUpdate.js +4 -1
  593. package/dist/src/utils/handleAutoUpdate.js.map +1 -1
  594. package/dist/src/utils/handleAutoUpdate.test.d.ts +6 -0
  595. package/dist/src/utils/handleAutoUpdate.test.js +225 -0
  596. package/dist/src/utils/handleAutoUpdate.test.js.map +1 -0
  597. package/dist/src/utils/installationInfo.d.ts +1 -0
  598. package/dist/src/utils/installationInfo.js +4 -2
  599. package/dist/src/utils/installationInfo.js.map +1 -1
  600. package/dist/src/utils/installationInfo.test.js +8 -4
  601. package/dist/src/utils/installationInfo.test.js.map +1 -1
  602. package/dist/src/utils/readStdin.js +2 -1
  603. package/dist/src/utils/readStdin.js.map +1 -1
  604. package/dist/src/utils/sandbox-macos-permissive-open.sb +2 -0
  605. package/dist/src/utils/sandbox.js +20 -20
  606. package/dist/src/utils/sandbox.js.map +1 -1
  607. package/dist/src/utils/sessionCleanup.d.ts +22 -0
  608. package/dist/src/utils/sessionCleanup.integration.test.d.ts +6 -0
  609. package/dist/src/utils/sessionCleanup.integration.test.js +182 -0
  610. package/dist/src/utils/sessionCleanup.integration.test.js.map +1 -0
  611. package/dist/src/utils/sessionCleanup.js +214 -0
  612. package/dist/src/utils/sessionCleanup.js.map +1 -0
  613. package/dist/src/utils/sessionCleanup.test.d.ts +6 -0
  614. package/dist/src/utils/sessionCleanup.test.js +1232 -0
  615. package/dist/src/utils/sessionCleanup.test.js.map +1 -0
  616. package/dist/src/utils/sessionUtils.d.ts +37 -0
  617. package/dist/src/utils/sessionUtils.js +71 -0
  618. package/dist/src/utils/sessionUtils.js.map +1 -0
  619. package/dist/src/utils/startupWarnings.test.d.ts +6 -0
  620. package/dist/src/utils/startupWarnings.test.js +61 -0
  621. package/dist/src/utils/startupWarnings.test.js.map +1 -0
  622. package/dist/src/validateNonInterActiveAuth.js +8 -9
  623. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  624. package/dist/src/zed-integration/acp.js +1 -2
  625. package/dist/src/zed-integration/acp.js.map +1 -1
  626. package/dist/src/zed-integration/schema.d.ts +176 -176
  627. package/dist/src/zed-integration/zedIntegration.d.ts +2 -3
  628. package/dist/src/zed-integration/zedIntegration.js +12 -33
  629. package/dist/src/zed-integration/zedIntegration.js.map +1 -1
  630. package/dist/tsconfig.tsbuildinfo +1 -1
  631. package/package.json +7 -6
  632. package/dist/src/ui/components/WorkspaceMigrationDialog.d.ts +0 -11
  633. package/dist/src/ui/components/WorkspaceMigrationDialog.js +0 -44
  634. package/dist/src/ui/components/WorkspaceMigrationDialog.js.map +0 -1
  635. package/dist/src/ui/hooks/useWorkspaceMigration.d.ts +0 -13
  636. package/dist/src/ui/hooks/useWorkspaceMigration.js +0 -54
  637. package/dist/src/ui/hooks/useWorkspaceMigration.js.map +0 -1
@@ -1,7 +1,7 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import { renderHook, act, waitFor } from '@testing-library/react';
3
3
  import { vi } from 'vitest';
4
- import { KeypressProvider, useKeypressContext, DRAG_COMPLETION_TIMEOUT_MS,
4
+ import { KeypressProvider, useKeypressContext, DRAG_COMPLETION_TIMEOUT_MS, KITTY_SEQUENCE_TIMEOUT_MS,
5
5
  // CSI_END_O,
6
6
  // SS3_END,
7
7
  SINGLE_QUOTE, DOUBLE_QUOTE, } from './KeypressContext.js';
@@ -43,7 +43,7 @@ class MockStdin extends EventEmitter {
43
43
  describe('KeypressContext - Kitty Protocol', () => {
44
44
  let stdin;
45
45
  const mockSetRawMode = vi.fn();
46
- const wrapper = ({ children, kittyProtocolEnabled = true, }) => (_jsx(KeypressProvider, { kittyProtocolEnabled: kittyProtocolEnabled, children: children }));
46
+ const wrapper = ({ children, kittyProtocolEnabled = true, }) => (_jsx(KeypressProvider, { kittyProtocolEnabled: kittyProtocolEnabled ?? false, children: children }));
47
47
  beforeEach(() => {
48
48
  vi.clearAllMocks();
49
49
  stdin = new MockStdin();
@@ -323,11 +323,11 @@ describe('KeypressContext - Kitty Protocol', () => {
323
323
  act(() => {
324
324
  stdin.sendKittySequence('\x1b[27u');
325
325
  });
326
- expect(consoleLogSpy).toHaveBeenCalledWith('[DEBUG] Kitty buffer accumulating:', expect.stringContaining('\x1b[27u'));
326
+ expect(consoleLogSpy).toHaveBeenCalledWith('[DEBUG] Kitty buffer accumulating:', expect.stringContaining('"\\u001b[27u"'));
327
327
  const parsedCall = consoleLogSpy.mock.calls.find((args) => typeof args[0] === 'string' &&
328
328
  args[0].includes('[DEBUG] Kitty sequence parsed successfully'));
329
329
  expect(parsedCall).toBeTruthy();
330
- expect(parsedCall?.[1]).toEqual(expect.stringContaining('\x1b[27u'));
330
+ expect(parsedCall?.[1]).toEqual(expect.stringContaining('\\u001b[27u'));
331
331
  });
332
332
  it('should log kitty buffer overflow when debugKeystrokeLogging is true', async () => {
333
333
  const keyHandler = vi.fn();
@@ -336,10 +336,10 @@ describe('KeypressContext - Kitty Protocol', () => {
336
336
  act(() => {
337
337
  result.current.subscribe(keyHandler);
338
338
  });
339
- // Send an invalid long sequence to trigger overflow
340
- const longInvalidSequence = '\x1b[' + 'x'.repeat(100);
339
+ // Send a long sequence starting with a valid kitty prefix to trigger overflow
340
+ const longSequence = '\x1b[1;' + '1'.repeat(100);
341
341
  act(() => {
342
- stdin.sendKittySequence(longInvalidSequence);
342
+ stdin.sendKittySequence(longSequence);
343
343
  });
344
344
  expect(consoleLogSpy).toHaveBeenCalledWith('[DEBUG] Kitty buffer overflow, clearing:', expect.any(String));
345
345
  });
@@ -396,9 +396,9 @@ describe('KeypressContext - Kitty Protocol', () => {
396
396
  });
397
397
  });
398
398
  // Verify debug logging for accumulation
399
- expect(consoleLogSpy).toHaveBeenCalledWith('[DEBUG] Kitty buffer accumulating:', sequence);
399
+ expect(consoleLogSpy).toHaveBeenCalledWith('[DEBUG] Kitty buffer accumulating:', JSON.stringify(sequence));
400
400
  // Verify warning for char codes
401
- expect(consoleWarnSpy).toHaveBeenCalledWith('Kitty sequence buffer has char codes:', [27, 91, 49, 50]);
401
+ expect(consoleWarnSpy).toHaveBeenCalledWith('Kitty sequence buffer has content:', JSON.stringify(sequence));
402
402
  });
403
403
  });
404
404
  describe('Parameterized functional keys', () => {
@@ -502,7 +502,7 @@ describe('KeypressContext - Kitty Protocol', () => {
502
502
  describe('Drag and Drop Handling', () => {
503
503
  let stdin;
504
504
  const mockSetRawMode = vi.fn();
505
- const wrapper = ({ children }) => (_jsx(KeypressProvider, { kittyProtocolEnabled: true, children: children }));
505
+ const wrapper = ({ children, kittyProtocolEnabled = true, }) => (_jsx(KeypressProvider, { kittyProtocolEnabled: kittyProtocolEnabled, children: children }));
506
506
  beforeEach(() => {
507
507
  vi.clearAllMocks();
508
508
  vi.useFakeTimers();
@@ -668,4 +668,530 @@ describe('Drag and Drop Handling', () => {
668
668
  });
669
669
  });
670
670
  });
671
+ describe('Kitty Sequence Parsing', () => {
672
+ let stdin;
673
+ const mockSetRawMode = vi.fn();
674
+ const wrapper = ({ children, kittyProtocolEnabled = true, }) => (_jsx(KeypressProvider, { kittyProtocolEnabled: kittyProtocolEnabled, children: children }));
675
+ beforeEach(() => {
676
+ vi.clearAllMocks();
677
+ vi.useFakeTimers();
678
+ stdin = new MockStdin();
679
+ useStdin.mockReturnValue({
680
+ stdin,
681
+ setRawMode: mockSetRawMode,
682
+ });
683
+ });
684
+ afterEach(() => {
685
+ vi.useRealTimers();
686
+ });
687
+ // Terminals to test
688
+ const terminals = ['iTerm2', 'Ghostty', 'MacTerminal', 'VSCodeTerminal'];
689
+ // Key mappings: letter -> [keycode, accented character, shouldHaveMeta]
690
+ // Note: µ (mu) is sent with meta:false on iTerm2/VSCode
691
+ const keys = {
692
+ a: [97, 'å', true],
693
+ o: [111, 'ø', true],
694
+ m: [109, 'µ', false],
695
+ };
696
+ it.each(terminals.flatMap((terminal) => Object.entries(keys).map(([key, [keycode, accentedChar, shouldHaveMeta]]) => {
697
+ if (terminal === 'Ghostty') {
698
+ // Ghostty uses kitty protocol sequences
699
+ return {
700
+ terminal,
701
+ key,
702
+ kittySequence: `\x1b[${keycode};3u`,
703
+ expected: {
704
+ name: key,
705
+ ctrl: false,
706
+ meta: true,
707
+ shift: false,
708
+ paste: false,
709
+ kittyProtocol: true,
710
+ },
711
+ };
712
+ }
713
+ else if (terminal === 'MacTerminal') {
714
+ // Mac Terminal sends ESC + letter
715
+ return {
716
+ terminal,
717
+ key,
718
+ kitty: false,
719
+ input: {
720
+ sequence: `\x1b${key}`,
721
+ name: key,
722
+ ctrl: false,
723
+ meta: true,
724
+ shift: false,
725
+ paste: false,
726
+ },
727
+ expected: {
728
+ sequence: `\x1b${key}`,
729
+ name: key,
730
+ ctrl: false,
731
+ meta: true,
732
+ shift: false,
733
+ paste: false,
734
+ },
735
+ };
736
+ }
737
+ else {
738
+ // iTerm2 and VSCode send accented characters (å, ø, µ)
739
+ // Note: µ comes with meta:false but gets converted to m with meta:true
740
+ return {
741
+ terminal,
742
+ key,
743
+ input: {
744
+ name: key,
745
+ ctrl: false,
746
+ meta: shouldHaveMeta,
747
+ shift: false,
748
+ paste: false,
749
+ sequence: accentedChar,
750
+ },
751
+ expected: {
752
+ name: key,
753
+ ctrl: false,
754
+ meta: true, // Always expect meta:true after conversion
755
+ shift: false,
756
+ paste: false,
757
+ sequence: accentedChar,
758
+ },
759
+ };
760
+ }
761
+ })))('should handle Alt+$key in $terminal', ({ kittySequence, input, expected, kitty = true, }) => {
762
+ const keyHandler = vi.fn();
763
+ const testWrapper = ({ children }) => (_jsx(KeypressProvider, { kittyProtocolEnabled: kitty, children: children }));
764
+ const { result } = renderHook(() => useKeypressContext(), {
765
+ wrapper: testWrapper,
766
+ });
767
+ act(() => result.current.subscribe(keyHandler));
768
+ if (kittySequence) {
769
+ act(() => stdin.sendKittySequence(kittySequence));
770
+ }
771
+ else if (input) {
772
+ act(() => stdin.pressKey(input));
773
+ }
774
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining(expected));
775
+ });
776
+ describe('Backslash key handling', () => {
777
+ beforeEach(() => {
778
+ vi.useFakeTimers();
779
+ });
780
+ afterEach(() => {
781
+ vi.useRealTimers();
782
+ });
783
+ it('should treat backslash as a regular keystroke', () => {
784
+ const keyHandler = vi.fn();
785
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
786
+ act(() => result.current.subscribe(keyHandler));
787
+ act(() => stdin.pressKey({
788
+ name: undefined,
789
+ ctrl: false,
790
+ meta: false,
791
+ shift: false,
792
+ paste: false,
793
+ sequence: '\\',
794
+ }));
795
+ // Advance timers to trigger the backslash timeout
796
+ act(() => {
797
+ vi.runAllTimers();
798
+ });
799
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
800
+ sequence: '\\',
801
+ meta: false,
802
+ }));
803
+ });
804
+ });
805
+ it('should timeout and flush incomplete kitty sequences after 50ms', async () => {
806
+ const keyHandler = vi.fn();
807
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
808
+ act(() => {
809
+ result.current.subscribe(keyHandler);
810
+ });
811
+ // Send incomplete kitty sequence
812
+ act(() => {
813
+ stdin.pressKey({
814
+ name: undefined,
815
+ ctrl: false,
816
+ meta: false,
817
+ shift: false,
818
+ paste: false,
819
+ sequence: '\x1b[1;',
820
+ });
821
+ });
822
+ // Should not broadcast immediately
823
+ expect(keyHandler).not.toHaveBeenCalled();
824
+ // Advance time just before timeout
825
+ act(() => {
826
+ vi.advanceTimersByTime(KITTY_SEQUENCE_TIMEOUT_MS - 5);
827
+ });
828
+ // Still shouldn't broadcast
829
+ expect(keyHandler).not.toHaveBeenCalled();
830
+ // Advance past timeout
831
+ act(() => {
832
+ vi.advanceTimersByTime(10);
833
+ });
834
+ // Should now broadcast the incomplete sequence as regular input
835
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
836
+ name: '',
837
+ sequence: '\x1b[1;',
838
+ paste: false,
839
+ }));
840
+ });
841
+ it('should immediately flush non-kitty CSI sequences', async () => {
842
+ const keyHandler = vi.fn();
843
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
844
+ act(() => {
845
+ result.current.subscribe(keyHandler);
846
+ });
847
+ // Send a CSI sequence that doesn't match kitty patterns
848
+ // ESC[m is SGR reset, not a kitty sequence
849
+ act(() => {
850
+ stdin.pressKey({
851
+ name: undefined,
852
+ ctrl: false,
853
+ meta: false,
854
+ shift: false,
855
+ paste: false,
856
+ sequence: '\x1b[m',
857
+ });
858
+ });
859
+ // Should broadcast immediately as it's not a valid kitty pattern
860
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
861
+ name: '',
862
+ sequence: '\x1b[m',
863
+ paste: false,
864
+ }));
865
+ });
866
+ it('should parse valid kitty sequences immediately when complete', async () => {
867
+ const keyHandler = vi.fn();
868
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
869
+ act(() => {
870
+ result.current.subscribe(keyHandler);
871
+ });
872
+ // Send complete kitty sequence for Ctrl+A
873
+ act(() => {
874
+ stdin.pressKey({
875
+ name: undefined,
876
+ ctrl: false,
877
+ meta: false,
878
+ shift: false,
879
+ paste: false,
880
+ sequence: '\x1b[97;5u',
881
+ });
882
+ });
883
+ // Should parse and broadcast immediately
884
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
885
+ name: 'a',
886
+ ctrl: true,
887
+ kittyProtocol: true,
888
+ }));
889
+ });
890
+ it('should handle batched kitty sequences correctly', async () => {
891
+ const keyHandler = vi.fn();
892
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
893
+ act(() => {
894
+ result.current.subscribe(keyHandler);
895
+ });
896
+ // Send multiple kitty sequences at once
897
+ act(() => {
898
+ stdin.pressKey({
899
+ name: undefined,
900
+ ctrl: false,
901
+ meta: false,
902
+ shift: false,
903
+ paste: false,
904
+ sequence: '\x1b[97;5u\x1b[98;5u', // Ctrl+a followed by Ctrl+b
905
+ });
906
+ });
907
+ // Should parse both sequences
908
+ expect(keyHandler).toHaveBeenCalledTimes(2);
909
+ expect(keyHandler).toHaveBeenNthCalledWith(1, expect.objectContaining({
910
+ name: 'a',
911
+ ctrl: true,
912
+ kittyProtocol: true,
913
+ }));
914
+ expect(keyHandler).toHaveBeenNthCalledWith(2, expect.objectContaining({
915
+ name: 'b',
916
+ ctrl: true,
917
+ kittyProtocol: true,
918
+ }));
919
+ });
920
+ it('should clear kitty buffer and timeout on Ctrl+C', async () => {
921
+ const keyHandler = vi.fn();
922
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
923
+ act(() => {
924
+ result.current.subscribe(keyHandler);
925
+ });
926
+ // Send incomplete kitty sequence
927
+ act(() => {
928
+ stdin.pressKey({
929
+ name: undefined,
930
+ ctrl: false,
931
+ meta: false,
932
+ shift: false,
933
+ paste: false,
934
+ sequence: '\x1b[1;',
935
+ });
936
+ });
937
+ // Press Ctrl+C
938
+ act(() => {
939
+ stdin.pressKey({
940
+ name: 'c',
941
+ ctrl: true,
942
+ meta: false,
943
+ shift: false,
944
+ paste: false,
945
+ sequence: '\x03',
946
+ });
947
+ });
948
+ // Advance past timeout
949
+ act(() => {
950
+ vi.advanceTimersByTime(KITTY_SEQUENCE_TIMEOUT_MS + 10);
951
+ });
952
+ // Should only have received Ctrl+C, not the incomplete sequence
953
+ expect(keyHandler).toHaveBeenCalledTimes(1);
954
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
955
+ name: 'c',
956
+ ctrl: true,
957
+ }));
958
+ });
959
+ it('should handle mixed valid and invalid sequences', async () => {
960
+ const keyHandler = vi.fn();
961
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
962
+ act(() => {
963
+ result.current.subscribe(keyHandler);
964
+ });
965
+ // Send valid kitty sequence followed by invalid CSI
966
+ act(() => {
967
+ stdin.pressKey({
968
+ name: undefined,
969
+ ctrl: false,
970
+ meta: false,
971
+ shift: false,
972
+ paste: false,
973
+ sequence: '\x1b[13u\x1b[!', // Valid enter, then invalid sequence
974
+ });
975
+ });
976
+ // Should parse valid sequence and flush invalid immediately
977
+ expect(keyHandler).toHaveBeenCalledTimes(2);
978
+ expect(keyHandler).toHaveBeenNthCalledWith(1, expect.objectContaining({
979
+ name: 'return',
980
+ kittyProtocol: true,
981
+ }));
982
+ expect(keyHandler).toHaveBeenNthCalledWith(2, expect.objectContaining({
983
+ name: '',
984
+ sequence: '\x1b[!',
985
+ }));
986
+ });
987
+ it('should not buffer sequences when kitty protocol is disabled', async () => {
988
+ const keyHandler = vi.fn();
989
+ const { result } = renderHook(() => useKeypressContext(), {
990
+ wrapper: ({ children }) => wrapper({ children, kittyProtocolEnabled: false }),
991
+ });
992
+ act(() => {
993
+ result.current.subscribe(keyHandler);
994
+ });
995
+ // Send what would be a kitty sequence
996
+ act(() => {
997
+ stdin.pressKey({
998
+ name: undefined,
999
+ ctrl: false,
1000
+ meta: false,
1001
+ shift: false,
1002
+ paste: false,
1003
+ sequence: '\x1b[13u',
1004
+ });
1005
+ });
1006
+ // Should pass through without parsing
1007
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
1008
+ sequence: '\x1b[13u',
1009
+ }));
1010
+ expect(keyHandler).not.toHaveBeenCalledWith(expect.objectContaining({
1011
+ name: 'return',
1012
+ kittyProtocol: true,
1013
+ }));
1014
+ });
1015
+ it('should handle sequences arriving character by character', async () => {
1016
+ vi.useRealTimers(); // Required for correct buffering timing.
1017
+ const keyHandler = vi.fn();
1018
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
1019
+ act(() => {
1020
+ result.current.subscribe(keyHandler);
1021
+ });
1022
+ // Send kitty sequence character by character
1023
+ const sequence = '\x1b[27u'; // Escape key
1024
+ for (const char of sequence) {
1025
+ act(() => {
1026
+ stdin.emit('data', Buffer.from(char));
1027
+ });
1028
+ await new Promise((resolve) => setTimeout(resolve, 0));
1029
+ }
1030
+ // Should parse once complete
1031
+ await waitFor(() => {
1032
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
1033
+ name: 'escape',
1034
+ kittyProtocol: true,
1035
+ }));
1036
+ });
1037
+ });
1038
+ it('should reset timeout when new input arrives', async () => {
1039
+ const keyHandler = vi.fn();
1040
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
1041
+ act(() => {
1042
+ result.current.subscribe(keyHandler);
1043
+ });
1044
+ // Start incomplete sequence
1045
+ act(() => {
1046
+ stdin.pressKey({
1047
+ name: undefined,
1048
+ ctrl: false,
1049
+ meta: false,
1050
+ shift: false,
1051
+ paste: false,
1052
+ sequence: '\x1b[1',
1053
+ });
1054
+ });
1055
+ // Advance time partway
1056
+ act(() => {
1057
+ vi.advanceTimersByTime(30);
1058
+ });
1059
+ // Add more to sequence
1060
+ act(() => {
1061
+ stdin.pressKey({
1062
+ name: undefined,
1063
+ ctrl: false,
1064
+ meta: false,
1065
+ shift: false,
1066
+ paste: false,
1067
+ sequence: '3',
1068
+ });
1069
+ });
1070
+ // Advance time from the first timeout point
1071
+ act(() => {
1072
+ vi.advanceTimersByTime(25);
1073
+ });
1074
+ // Should not have timed out yet (timeout restarted)
1075
+ expect(keyHandler).not.toHaveBeenCalled();
1076
+ // Complete the sequence
1077
+ act(() => {
1078
+ stdin.pressKey({
1079
+ name: undefined,
1080
+ ctrl: false,
1081
+ meta: false,
1082
+ shift: false,
1083
+ paste: false,
1084
+ sequence: 'u',
1085
+ });
1086
+ });
1087
+ // Should now parse as complete enter key
1088
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
1089
+ name: 'return',
1090
+ kittyProtocol: true,
1091
+ }));
1092
+ });
1093
+ it('should flush incomplete kitty sequence on FOCUS_IN event', async () => {
1094
+ const keyHandler = vi.fn();
1095
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
1096
+ act(() => {
1097
+ result.current.subscribe(keyHandler);
1098
+ });
1099
+ // Send incomplete kitty sequence
1100
+ act(() => {
1101
+ stdin.pressKey({
1102
+ sequence: '\x1b[1;',
1103
+ });
1104
+ });
1105
+ // Incomplete sequence should be buffered, not broadcast
1106
+ expect(keyHandler).not.toHaveBeenCalled();
1107
+ // Send FOCUS_IN event
1108
+ const FOCUS_IN = '\x1b[I';
1109
+ act(() => {
1110
+ stdin.pressKey({
1111
+ sequence: FOCUS_IN,
1112
+ });
1113
+ });
1114
+ // The buffered sequence should be flushed
1115
+ expect(keyHandler).toHaveBeenCalledTimes(1);
1116
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
1117
+ name: '',
1118
+ sequence: '\x1b[1;',
1119
+ paste: false,
1120
+ }));
1121
+ });
1122
+ it('should flush incomplete kitty sequence on FOCUS_OUT event', async () => {
1123
+ const keyHandler = vi.fn();
1124
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
1125
+ act(() => {
1126
+ result.current.subscribe(keyHandler);
1127
+ });
1128
+ // Send incomplete kitty sequence
1129
+ act(() => {
1130
+ stdin.pressKey({
1131
+ sequence: '\x1b[1;',
1132
+ });
1133
+ });
1134
+ // Incomplete sequence should be buffered, not broadcast
1135
+ expect(keyHandler).not.toHaveBeenCalled();
1136
+ // Send FOCUS_OUT event
1137
+ const FOCUS_OUT = '\x1b[O';
1138
+ act(() => {
1139
+ stdin.pressKey({
1140
+ sequence: FOCUS_OUT,
1141
+ });
1142
+ });
1143
+ // The buffered sequence should be flushed
1144
+ expect(keyHandler).toHaveBeenCalledTimes(1);
1145
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
1146
+ name: '',
1147
+ sequence: '\x1b[1;',
1148
+ paste: false,
1149
+ }));
1150
+ });
1151
+ it('should flush incomplete kitty sequence on paste event', async () => {
1152
+ vi.useFakeTimers();
1153
+ const keyHandler = vi.fn();
1154
+ const { result } = renderHook(() => useKeypressContext(), { wrapper });
1155
+ act(() => {
1156
+ result.current.subscribe(keyHandler);
1157
+ });
1158
+ // Send incomplete kitty sequence
1159
+ act(() => {
1160
+ stdin.pressKey({
1161
+ sequence: '\x1b[1;',
1162
+ });
1163
+ });
1164
+ // Incomplete sequence should be buffered, not broadcast
1165
+ expect(keyHandler).not.toHaveBeenCalled();
1166
+ // Send paste start sequence
1167
+ const PASTE_MODE_PREFIX = `\x1b[200~`;
1168
+ act(() => {
1169
+ stdin.emit('data', Buffer.from(PASTE_MODE_PREFIX));
1170
+ });
1171
+ // The buffered sequence should be flushed
1172
+ expect(keyHandler).toHaveBeenCalledTimes(1);
1173
+ expect(keyHandler).toHaveBeenCalledWith(expect.objectContaining({
1174
+ name: '',
1175
+ sequence: '\x1b[1;',
1176
+ paste: false,
1177
+ }));
1178
+ // Now send some paste content and end paste to make sure paste still works
1179
+ const pastedText = 'hello';
1180
+ const PASTE_MODE_SUFFIX = `\x1b[201~`;
1181
+ act(() => {
1182
+ stdin.emit('data', Buffer.from(pastedText));
1183
+ stdin.emit('data', Buffer.from(PASTE_MODE_SUFFIX));
1184
+ });
1185
+ act(() => {
1186
+ vi.runAllTimers();
1187
+ });
1188
+ // The paste event should be broadcast
1189
+ expect(keyHandler).toHaveBeenCalledTimes(2);
1190
+ expect(keyHandler).toHaveBeenNthCalledWith(2, expect.objectContaining({
1191
+ paste: true,
1192
+ sequence: pastedText,
1193
+ }));
1194
+ vi.useRealTimers();
1195
+ });
1196
+ });
671
1197
  //# sourceMappingURL=KeypressContext.test.js.map