fss-link 1.0.49 → 1.0.51

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 (419) hide show
  1. package/dist/index.js +0 -0
  2. package/dist/package.json +2 -2
  3. package/dist/src/config/auth.js +8 -5
  4. package/dist/src/config/auth.js.map +1 -1
  5. package/dist/src/config/database.d.ts +103 -11
  6. package/dist/src/config/database.js +301 -59
  7. package/dist/src/config/database.js.map +1 -1
  8. package/dist/src/config/databaseBackup.d.ts +114 -0
  9. package/dist/src/config/databaseBackup.js +334 -0
  10. package/dist/src/config/databaseBackup.js.map +1 -0
  11. package/dist/src/config/databaseMigrations.d.ts +63 -0
  12. package/dist/src/config/databaseMigrations.js +379 -0
  13. package/dist/src/config/databaseMigrations.js.map +1 -0
  14. package/dist/src/config/databasePool.d.ts +70 -0
  15. package/dist/src/config/databasePool.js +193 -0
  16. package/dist/src/config/databasePool.js.map +1 -0
  17. package/dist/src/config/queryOptimizer.d.ts +127 -0
  18. package/dist/src/config/queryOptimizer.js +309 -0
  19. package/dist/src/config/queryOptimizer.js.map +1 -0
  20. package/dist/src/utils/sandbox.js +2 -8
  21. package/dist/src/utils/sandbox.js.map +1 -1
  22. package/dist/src/validateNonInterActiveAuth.js +3 -7
  23. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  24. package/dist/tsconfig.tsbuildinfo +1 -1
  25. package/package.json +2 -2
  26. package/dist/commands/mcp/add.test.ts +0 -122
  27. package/dist/commands/mcp/add.ts +0 -222
  28. package/dist/commands/mcp/list.test.ts +0 -154
  29. package/dist/commands/mcp/list.ts +0 -139
  30. package/dist/commands/mcp/remove.test.ts +0 -69
  31. package/dist/commands/mcp/remove.ts +0 -60
  32. package/dist/commands/mcp.test.ts +0 -55
  33. package/dist/commands/mcp.ts +0 -27
  34. package/dist/config/apiValidation.test.ts +0 -118
  35. package/dist/config/auth.test.ts +0 -79
  36. package/dist/config/auth.ts +0 -100
  37. package/dist/config/config.integration.test.ts +0 -407
  38. package/dist/config/config.test.ts +0 -1952
  39. package/dist/config/config.ts +0 -690
  40. package/dist/config/database.test.ts +0 -96
  41. package/dist/config/database.ts +0 -824
  42. package/dist/config/extension.test.ts +0 -236
  43. package/dist/config/extension.ts +0 -180
  44. package/dist/config/keyBindings.test.ts +0 -62
  45. package/dist/config/keyBindings.ts +0 -184
  46. package/dist/config/modelManager.ts +0 -326
  47. package/dist/config/providerManager.ts +0 -244
  48. package/dist/config/providerPersistence.test.ts +0 -377
  49. package/dist/config/providerPersistence.ts +0 -105
  50. package/dist/config/sandboxConfig.ts +0 -107
  51. package/dist/config/settings.test.ts +0 -1424
  52. package/dist/config/settings.ts +0 -517
  53. package/dist/config/settingsSchema.test.ts +0 -252
  54. package/dist/config/settingsSchema.ts +0 -728
  55. package/dist/config/trustedFolders.test.ts +0 -208
  56. package/dist/config/trustedFolders.ts +0 -167
  57. package/dist/gemini.test.tsx +0 -252
  58. package/dist/gemini.tsx +0 -357
  59. package/dist/generated/git-commit.ts +0 -10
  60. package/dist/index.ts +0 -21
  61. package/dist/nonInteractiveCli.test.ts +0 -276
  62. package/dist/nonInteractiveCli.ts +0 -143
  63. package/dist/patches/is-in-ci.ts +0 -17
  64. package/dist/services/BuiltinCommandLoader.test.ts +0 -127
  65. package/dist/services/BuiltinCommandLoader.ts +0 -95
  66. package/dist/services/CommandService.test.ts +0 -352
  67. package/dist/services/CommandService.ts +0 -103
  68. package/dist/services/FileCommandLoader.test.ts +0 -1002
  69. package/dist/services/FileCommandLoader.ts +0 -289
  70. package/dist/services/McpPromptLoader.ts +0 -231
  71. package/dist/services/SearchEngineConfigProvider.ts +0 -100
  72. package/dist/services/prompt-processors/argumentProcessor.test.ts +0 -41
  73. package/dist/services/prompt-processors/argumentProcessor.ts +0 -23
  74. package/dist/services/prompt-processors/shellProcessor.test.ts +0 -709
  75. package/dist/services/prompt-processors/shellProcessor.ts +0 -248
  76. package/dist/services/prompt-processors/types.ts +0 -44
  77. package/dist/services/types.ts +0 -24
  78. package/dist/src/config/apiValidation.test.d.ts +0 -6
  79. package/dist/src/config/apiValidation.test.js +0 -99
  80. package/dist/src/config/apiValidation.test.js.map +0 -1
  81. package/dist/src/config/database.test.d.ts +0 -6
  82. package/dist/src/config/database.test.js +0 -80
  83. package/dist/src/config/database.test.js.map +0 -1
  84. package/dist/src/config/providerManager.d.ts +0 -74
  85. package/dist/src/config/providerManager.js +0 -203
  86. package/dist/src/config/providerManager.js.map +0 -1
  87. package/dist/src/config/providerPersistence.test.d.ts +0 -6
  88. package/dist/src/config/providerPersistence.test.js +0 -283
  89. package/dist/src/config/providerPersistence.test.js.map +0 -1
  90. package/dist/src/ui/components/GeminiKeyDialog.d.ts +0 -11
  91. package/dist/src/ui/components/GeminiKeyDialog.js +0 -156
  92. package/dist/src/ui/components/GeminiKeyDialog.js.map +0 -1
  93. package/dist/src/ui/components/OpenAIEndpointDialog.d.ts +0 -19
  94. package/dist/src/ui/components/OpenAIEndpointDialog.js +0 -163
  95. package/dist/src/ui/components/OpenAIEndpointDialog.js.map +0 -1
  96. package/dist/test-setup.ts +0 -12
  97. package/dist/test-utils/customMatchers.ts +0 -65
  98. package/dist/test-utils/mockCommandContext.test.ts +0 -62
  99. package/dist/test-utils/mockCommandContext.ts +0 -105
  100. package/dist/test-utils/render.tsx +0 -18
  101. package/dist/ui/App.test.tsx +0 -2181
  102. package/dist/ui/App.tsx +0 -1344
  103. package/dist/ui/IdeIntegrationNudge.tsx +0 -98
  104. package/dist/ui/__snapshots__/App.test.tsx.snap +0 -124
  105. package/dist/ui/colors.ts +0 -56
  106. package/dist/ui/commands/aboutCommand.test.ts +0 -153
  107. package/dist/ui/commands/aboutCommand.ts +0 -49
  108. package/dist/ui/commands/authCommand.test.ts +0 -36
  109. package/dist/ui/commands/authCommand.ts +0 -17
  110. package/dist/ui/commands/bugCommand.test.ts +0 -114
  111. package/dist/ui/commands/bugCommand.ts +0 -92
  112. package/dist/ui/commands/chatCommand.test.ts +0 -414
  113. package/dist/ui/commands/chatCommand.ts +0 -280
  114. package/dist/ui/commands/clearCommand.test.ts +0 -100
  115. package/dist/ui/commands/clearCommand.ts +0 -29
  116. package/dist/ui/commands/compressCommand.test.ts +0 -129
  117. package/dist/ui/commands/compressCommand.ts +0 -78
  118. package/dist/ui/commands/contextCommand.ts +0 -132
  119. package/dist/ui/commands/copyCommand.test.ts +0 -296
  120. package/dist/ui/commands/copyCommand.ts +0 -67
  121. package/dist/ui/commands/corgiCommand.test.ts +0 -34
  122. package/dist/ui/commands/corgiCommand.ts +0 -16
  123. package/dist/ui/commands/directoryCommand.test.tsx +0 -185
  124. package/dist/ui/commands/directoryCommand.tsx +0 -179
  125. package/dist/ui/commands/docsCommand.test.ts +0 -99
  126. package/dist/ui/commands/docsCommand.ts +0 -42
  127. package/dist/ui/commands/editorCommand.test.ts +0 -30
  128. package/dist/ui/commands/editorCommand.ts +0 -21
  129. package/dist/ui/commands/extensionsCommand.test.ts +0 -67
  130. package/dist/ui/commands/extensionsCommand.ts +0 -46
  131. package/dist/ui/commands/helpCommand.test.ts +0 -52
  132. package/dist/ui/commands/helpCommand.ts +0 -23
  133. package/dist/ui/commands/ideCommand.test.ts +0 -255
  134. package/dist/ui/commands/ideCommand.ts +0 -283
  135. package/dist/ui/commands/initCommand.test.ts +0 -127
  136. package/dist/ui/commands/initCommand.ts +0 -117
  137. package/dist/ui/commands/mcpCommand.test.ts +0 -1057
  138. package/dist/ui/commands/mcpCommand.ts +0 -531
  139. package/dist/ui/commands/memoryCommand.test.ts +0 -344
  140. package/dist/ui/commands/memoryCommand.ts +0 -305
  141. package/dist/ui/commands/privacyCommand.test.ts +0 -38
  142. package/dist/ui/commands/privacyCommand.ts +0 -17
  143. package/dist/ui/commands/quitCommand.test.ts +0 -55
  144. package/dist/ui/commands/quitCommand.ts +0 -36
  145. package/dist/ui/commands/restoreCommand.test.ts +0 -250
  146. package/dist/ui/commands/restoreCommand.ts +0 -157
  147. package/dist/ui/commands/searchEngineSetupCommand.ts +0 -18
  148. package/dist/ui/commands/settingsCommand.test.ts +0 -36
  149. package/dist/ui/commands/settingsCommand.ts +0 -17
  150. package/dist/ui/commands/setupGithubCommand.test.ts +0 -238
  151. package/dist/ui/commands/setupGithubCommand.ts +0 -212
  152. package/dist/ui/commands/speakCommand.ts +0 -175
  153. package/dist/ui/commands/statsCommand.test.ts +0 -78
  154. package/dist/ui/commands/statsCommand.ts +0 -70
  155. package/dist/ui/commands/terminalSetupCommand.test.ts +0 -85
  156. package/dist/ui/commands/terminalSetupCommand.ts +0 -45
  157. package/dist/ui/commands/themeCommand.test.ts +0 -38
  158. package/dist/ui/commands/themeCommand.ts +0 -17
  159. package/dist/ui/commands/toolsCommand.test.ts +0 -105
  160. package/dist/ui/commands/toolsCommand.ts +0 -71
  161. package/dist/ui/commands/ttsCommand.ts +0 -143
  162. package/dist/ui/commands/types.ts +0 -204
  163. package/dist/ui/commands/vimCommand.ts +0 -25
  164. package/dist/ui/commands/voiceCommand.ts +0 -125
  165. package/dist/ui/components/AboutBox.tsx +0 -133
  166. package/dist/ui/components/AsciiArt.ts +0 -54
  167. package/dist/ui/components/AuthDialog.test.tsx +0 -334
  168. package/dist/ui/components/AuthDialog.tsx +0 -289
  169. package/dist/ui/components/AuthInProgress.tsx +0 -62
  170. package/dist/ui/components/AutoAcceptIndicator.tsx +0 -47
  171. package/dist/ui/components/ConsoleSummaryDisplay.tsx +0 -35
  172. package/dist/ui/components/ContextSummaryDisplay.test.tsx +0 -85
  173. package/dist/ui/components/ContextSummaryDisplay.tsx +0 -120
  174. package/dist/ui/components/ContextUsageDisplay.tsx +0 -77
  175. package/dist/ui/components/DebugProfiler.tsx +0 -36
  176. package/dist/ui/components/DetailedMessagesDisplay.tsx +0 -82
  177. package/dist/ui/components/EditorSettingsDialog.tsx +0 -172
  178. package/dist/ui/components/FolderTrustDialog.test.tsx +0 -36
  179. package/dist/ui/components/FolderTrustDialog.tsx +0 -74
  180. package/dist/ui/components/Footer.test.tsx +0 -159
  181. package/dist/ui/components/Footer.tsx +0 -158
  182. package/dist/ui/components/GeminiKeyDialog.tsx +0 -252
  183. package/dist/ui/components/GeminiRespondingSpinner.tsx +0 -34
  184. package/dist/ui/components/Header.test.tsx +0 -44
  185. package/dist/ui/components/Header.tsx +0 -70
  186. package/dist/ui/components/Help.tsx +0 -174
  187. package/dist/ui/components/HistoryItemDisplay.test.tsx +0 -125
  188. package/dist/ui/components/HistoryItemDisplay.tsx +0 -98
  189. package/dist/ui/components/InputPrompt.test.tsx +0 -1467
  190. package/dist/ui/components/InputPrompt.tsx +0 -641
  191. package/dist/ui/components/LMStudioModelPrompt.tsx +0 -215
  192. package/dist/ui/components/LoadingIndicator.test.tsx +0 -296
  193. package/dist/ui/components/LoadingIndicator.tsx +0 -82
  194. package/dist/ui/components/MemoryUsageDisplay.tsx +0 -36
  195. package/dist/ui/components/ModelStatsDisplay.test.tsx +0 -252
  196. package/dist/ui/components/ModelStatsDisplay.tsx +0 -197
  197. package/dist/ui/components/OllamaModelPrompt.tsx +0 -206
  198. package/dist/ui/components/OpenAIEndpointDialog.tsx +0 -261
  199. package/dist/ui/components/OpenAIKeyPrompt.test.tsx +0 -64
  200. package/dist/ui/components/OpenAIKeyPrompt.tsx +0 -197
  201. package/dist/ui/components/PrepareLabel.tsx +0 -48
  202. package/dist/ui/components/SearchEngineConfigDialog.tsx +0 -280
  203. package/dist/ui/components/SessionSummaryDisplay.test.tsx +0 -75
  204. package/dist/ui/components/SessionSummaryDisplay.tsx +0 -18
  205. package/dist/ui/components/SettingsDialog.test.tsx +0 -865
  206. package/dist/ui/components/SettingsDialog.tsx +0 -753
  207. package/dist/ui/components/ShellConfirmationDialog.test.tsx +0 -53
  208. package/dist/ui/components/ShellConfirmationDialog.tsx +0 -103
  209. package/dist/ui/components/ShellModeIndicator.tsx +0 -18
  210. package/dist/ui/components/ShowMoreLines.tsx +0 -40
  211. package/dist/ui/components/StatsDisplay.test.tsx +0 -401
  212. package/dist/ui/components/StatsDisplay.tsx +0 -273
  213. package/dist/ui/components/SuggestionsDisplay.tsx +0 -102
  214. package/dist/ui/components/ThemeDialog.tsx +0 -310
  215. package/dist/ui/components/Tips.tsx +0 -45
  216. package/dist/ui/components/TodoDisplay.test.tsx +0 -97
  217. package/dist/ui/components/TodoDisplay.tsx +0 -72
  218. package/dist/ui/components/ToolStatsDisplay.test.tsx +0 -180
  219. package/dist/ui/components/ToolStatsDisplay.tsx +0 -208
  220. package/dist/ui/components/UpdateNotification.tsx +0 -23
  221. package/dist/ui/components/WelcomeBackDialog.tsx +0 -290
  222. package/dist/ui/components/__snapshots__/IDEContextDetailDisplay.test.tsx.snap +0 -24
  223. package/dist/ui/components/__snapshots__/ModelStatsDisplay.test.tsx.snap +0 -121
  224. package/dist/ui/components/__snapshots__/SessionSummaryDisplay.test.tsx.snap +0 -30
  225. package/dist/ui/components/__snapshots__/ShellConfirmationDialog.test.tsx.snap +0 -21
  226. package/dist/ui/components/__snapshots__/StatsDisplay.test.tsx.snap +0 -264
  227. package/dist/ui/components/__snapshots__/ToolStatsDisplay.test.tsx.snap +0 -91
  228. package/dist/ui/components/messages/CompressionMessage.tsx +0 -49
  229. package/dist/ui/components/messages/DiffRenderer.test.tsx +0 -365
  230. package/dist/ui/components/messages/DiffRenderer.tsx +0 -358
  231. package/dist/ui/components/messages/ErrorMessage.tsx +0 -31
  232. package/dist/ui/components/messages/GeminiMessage.tsx +0 -43
  233. package/dist/ui/components/messages/GeminiMessageContent.tsx +0 -43
  234. package/dist/ui/components/messages/InfoMessage.tsx +0 -32
  235. package/dist/ui/components/messages/ToolConfirmationMessage.test.tsx +0 -58
  236. package/dist/ui/components/messages/ToolConfirmationMessage.tsx +0 -297
  237. package/dist/ui/components/messages/ToolGroupMessage.tsx +0 -126
  238. package/dist/ui/components/messages/ToolMessage.test.tsx +0 -183
  239. package/dist/ui/components/messages/ToolMessage.tsx +0 -296
  240. package/dist/ui/components/messages/UserMessage.tsx +0 -43
  241. package/dist/ui/components/messages/UserShellMessage.tsx +0 -25
  242. package/dist/ui/components/shared/MaxSizedBox.test.tsx +0 -425
  243. package/dist/ui/components/shared/MaxSizedBox.tsx +0 -624
  244. package/dist/ui/components/shared/RadioButtonSelect.test.tsx +0 -181
  245. package/dist/ui/components/shared/RadioButtonSelect.tsx +0 -234
  246. package/dist/ui/components/shared/__snapshots__/RadioButtonSelect.test.tsx.snap +0 -47
  247. package/dist/ui/components/shared/text-buffer.test.ts +0 -1728
  248. package/dist/ui/components/shared/text-buffer.ts +0 -2227
  249. package/dist/ui/components/shared/vim-buffer-actions.test.ts +0 -1119
  250. package/dist/ui/components/shared/vim-buffer-actions.ts +0 -814
  251. package/dist/ui/constants.ts +0 -17
  252. package/dist/ui/contexts/KeypressContext.test.tsx +0 -391
  253. package/dist/ui/contexts/KeypressContext.tsx +0 -440
  254. package/dist/ui/contexts/OverflowContext.tsx +0 -87
  255. package/dist/ui/contexts/SessionContext.test.tsx +0 -132
  256. package/dist/ui/contexts/SessionContext.tsx +0 -143
  257. package/dist/ui/contexts/SettingsContext.tsx +0 -20
  258. package/dist/ui/contexts/StreamingContext.tsx +0 -22
  259. package/dist/ui/contexts/VimModeContext.tsx +0 -79
  260. package/dist/ui/editors/editorSettingsManager.ts +0 -66
  261. package/dist/ui/hooks/atCommandProcessor.test.ts +0 -1102
  262. package/dist/ui/hooks/atCommandProcessor.ts +0 -485
  263. package/dist/ui/hooks/shellCommandProcessor.test.ts +0 -481
  264. package/dist/ui/hooks/shellCommandProcessor.ts +0 -314
  265. package/dist/ui/hooks/slashCommandProcessor.test.ts +0 -1044
  266. package/dist/ui/hooks/slashCommandProcessor.ts +0 -595
  267. package/dist/ui/hooks/useAtCompletion.test.ts +0 -497
  268. package/dist/ui/hooks/useAtCompletion.ts +0 -244
  269. package/dist/ui/hooks/useAuthCommand.ts +0 -129
  270. package/dist/ui/hooks/useAutoAcceptIndicator.test.ts +0 -300
  271. package/dist/ui/hooks/useAutoAcceptIndicator.ts +0 -52
  272. package/dist/ui/hooks/useBracketedPaste.ts +0 -37
  273. package/dist/ui/hooks/useCommandCompletion.test.ts +0 -518
  274. package/dist/ui/hooks/useCommandCompletion.tsx +0 -238
  275. package/dist/ui/hooks/useCompletion.ts +0 -128
  276. package/dist/ui/hooks/useConsoleMessages.test.ts +0 -147
  277. package/dist/ui/hooks/useConsoleMessages.ts +0 -110
  278. package/dist/ui/hooks/useEditorSettings.test.ts +0 -283
  279. package/dist/ui/hooks/useEditorSettings.ts +0 -75
  280. package/dist/ui/hooks/useFocus.test.ts +0 -119
  281. package/dist/ui/hooks/useFocus.ts +0 -48
  282. package/dist/ui/hooks/useFolderTrust.test.ts +0 -159
  283. package/dist/ui/hooks/useFolderTrust.ts +0 -72
  284. package/dist/ui/hooks/useGeminiStream.test.tsx +0 -1998
  285. package/dist/ui/hooks/useGeminiStream.ts +0 -1017
  286. package/dist/ui/hooks/useGitBranchName.test.ts +0 -280
  287. package/dist/ui/hooks/useGitBranchName.ts +0 -79
  288. package/dist/ui/hooks/useHistoryManager.test.ts +0 -202
  289. package/dist/ui/hooks/useHistoryManager.ts +0 -111
  290. package/dist/ui/hooks/useInputHistory.test.ts +0 -261
  291. package/dist/ui/hooks/useInputHistory.ts +0 -111
  292. package/dist/ui/hooks/useKeypress.test.ts +0 -280
  293. package/dist/ui/hooks/useKeypress.ts +0 -39
  294. package/dist/ui/hooks/useKittyKeyboardProtocol.ts +0 -31
  295. package/dist/ui/hooks/useLoadingIndicator.test.ts +0 -139
  296. package/dist/ui/hooks/useLoadingIndicator.ts +0 -57
  297. package/dist/ui/hooks/useLogger.ts +0 -32
  298. package/dist/ui/hooks/useMessageQueue.test.ts +0 -226
  299. package/dist/ui/hooks/useMessageQueue.ts +0 -69
  300. package/dist/ui/hooks/usePhraseCycler.test.ts +0 -145
  301. package/dist/ui/hooks/usePhraseCycler.ts +0 -198
  302. package/dist/ui/hooks/usePrivacySettings.test.ts +0 -242
  303. package/dist/ui/hooks/usePrivacySettings.ts +0 -150
  304. package/dist/ui/hooks/useReactToolScheduler.ts +0 -309
  305. package/dist/ui/hooks/useRefreshMemoryCommand.ts +0 -7
  306. package/dist/ui/hooks/useReverseSearchCompletion.test.tsx +0 -260
  307. package/dist/ui/hooks/useReverseSearchCompletion.tsx +0 -95
  308. package/dist/ui/hooks/useSettingsCommand.ts +0 -25
  309. package/dist/ui/hooks/useShellHistory.test.ts +0 -219
  310. package/dist/ui/hooks/useShellHistory.ts +0 -133
  311. package/dist/ui/hooks/useShowMemoryCommand.ts +0 -75
  312. package/dist/ui/hooks/useSlashCompletion.test.ts +0 -434
  313. package/dist/ui/hooks/useSlashCompletion.ts +0 -187
  314. package/dist/ui/hooks/useStateAndRef.ts +0 -36
  315. package/dist/ui/hooks/useTerminalSize.ts +0 -32
  316. package/dist/ui/hooks/useThemeCommand.ts +0 -110
  317. package/dist/ui/hooks/useTimer.test.ts +0 -120
  318. package/dist/ui/hooks/useTimer.ts +0 -65
  319. package/dist/ui/hooks/useToolScheduler.test.ts +0 -1123
  320. package/dist/ui/hooks/useWelcomeBack.ts +0 -253
  321. package/dist/ui/hooks/vim.test.ts +0 -1691
  322. package/dist/ui/hooks/vim.ts +0 -784
  323. package/dist/ui/keyMatchers.test.ts +0 -337
  324. package/dist/ui/keyMatchers.ts +0 -105
  325. package/dist/ui/privacy/CloudFreePrivacyNotice.tsx +0 -117
  326. package/dist/ui/privacy/CloudPaidPrivacyNotice.tsx +0 -59
  327. package/dist/ui/privacy/GeminiPrivacyNotice.tsx +0 -62
  328. package/dist/ui/privacy/PrivacyNotice.tsx +0 -42
  329. package/dist/ui/semantic-colors.ts +0 -26
  330. package/dist/ui/themes/ansi-light.ts +0 -150
  331. package/dist/ui/themes/ansi.ts +0 -159
  332. package/dist/ui/themes/atom-one-dark.ts +0 -147
  333. package/dist/ui/themes/ayu-light.ts +0 -139
  334. package/dist/ui/themes/ayu.ts +0 -113
  335. package/dist/ui/themes/color-utils.test.ts +0 -221
  336. package/dist/ui/themes/color-utils.ts +0 -231
  337. package/dist/ui/themes/default-light.ts +0 -108
  338. package/dist/ui/themes/default.ts +0 -151
  339. package/dist/ui/themes/dracula.ts +0 -124
  340. package/dist/ui/themes/fss-code-dark.ts +0 -156
  341. package/dist/ui/themes/fss-dark.ts +0 -113
  342. package/dist/ui/themes/fss-light.ts +0 -139
  343. package/dist/ui/themes/github-dark.ts +0 -147
  344. package/dist/ui/themes/github-light.ts +0 -149
  345. package/dist/ui/themes/googlecode.ts +0 -146
  346. package/dist/ui/themes/no-color.ts +0 -125
  347. package/dist/ui/themes/qwen-dark.ts +0 -118
  348. package/dist/ui/themes/qwen-light.ts +0 -144
  349. package/dist/ui/themes/semantic-tokens.ts +0 -127
  350. package/dist/ui/themes/shades-of-purple.ts +0 -352
  351. package/dist/ui/themes/theme-manager.test.ts +0 -99
  352. package/dist/ui/themes/theme-manager.ts +0 -257
  353. package/dist/ui/themes/theme.test.ts +0 -97
  354. package/dist/ui/themes/theme.ts +0 -451
  355. package/dist/ui/themes/xcode.ts +0 -154
  356. package/dist/ui/types.ts +0 -255
  357. package/dist/ui/utils/CodeColorizer.tsx +0 -217
  358. package/dist/ui/utils/ConsolePatcher.ts +0 -71
  359. package/dist/ui/utils/InlineMarkdownRenderer.tsx +0 -173
  360. package/dist/ui/utils/MarkdownDisplay.test.tsx +0 -244
  361. package/dist/ui/utils/MarkdownDisplay.tsx +0 -415
  362. package/dist/ui/utils/TableRenderer.tsx +0 -159
  363. package/dist/ui/utils/__snapshots__/MarkdownDisplay.test.tsx.snap +0 -93
  364. package/dist/ui/utils/clipboardUtils.test.ts +0 -76
  365. package/dist/ui/utils/clipboardUtils.ts +0 -149
  366. package/dist/ui/utils/commandUtils.test.ts +0 -384
  367. package/dist/ui/utils/commandUtils.ts +0 -106
  368. package/dist/ui/utils/computeStats.test.ts +0 -292
  369. package/dist/ui/utils/computeStats.ts +0 -86
  370. package/dist/ui/utils/displayUtils.test.ts +0 -58
  371. package/dist/ui/utils/displayUtils.ts +0 -32
  372. package/dist/ui/utils/formatters.test.ts +0 -72
  373. package/dist/ui/utils/formatters.ts +0 -63
  374. package/dist/ui/utils/isNarrowWidth.ts +0 -9
  375. package/dist/ui/utils/kittyProtocolDetector.ts +0 -105
  376. package/dist/ui/utils/markdownUtilities.test.ts +0 -50
  377. package/dist/ui/utils/markdownUtilities.ts +0 -125
  378. package/dist/ui/utils/platformConstants.ts +0 -52
  379. package/dist/ui/utils/terminalSetup.ts +0 -342
  380. package/dist/ui/utils/textUtils.ts +0 -40
  381. package/dist/ui/utils/updateCheck.test.ts +0 -163
  382. package/dist/ui/utils/updateCheck.ts +0 -100
  383. package/dist/utils/checks.ts +0 -28
  384. package/dist/utils/cleanup.test.ts +0 -68
  385. package/dist/utils/cleanup.ts +0 -36
  386. package/dist/utils/dialogScopeUtils.ts +0 -64
  387. package/dist/utils/events.ts +0 -14
  388. package/dist/utils/gitUtils.test.ts +0 -149
  389. package/dist/utils/gitUtils.ts +0 -116
  390. package/dist/utils/handleAutoUpdate.test.ts +0 -272
  391. package/dist/utils/handleAutoUpdate.ts +0 -145
  392. package/dist/utils/installationInfo.test.ts +0 -315
  393. package/dist/utils/installationInfo.ts +0 -176
  394. package/dist/utils/package.ts +0 -38
  395. package/dist/utils/readStdin.ts +0 -51
  396. package/dist/utils/resolvePath.ts +0 -21
  397. package/dist/utils/sandbox-macos-permissive-closed.sb +0 -32
  398. package/dist/utils/sandbox-macos-permissive-open.sb +0 -25
  399. package/dist/utils/sandbox-macos-permissive-proxied.sb +0 -37
  400. package/dist/utils/sandbox-macos-restrictive-closed.sb +0 -93
  401. package/dist/utils/sandbox-macos-restrictive-open.sb +0 -96
  402. package/dist/utils/sandbox-macos-restrictive-proxied.sb +0 -98
  403. package/dist/utils/sandbox.ts +0 -962
  404. package/dist/utils/settingsUtils.test.ts +0 -797
  405. package/dist/utils/settingsUtils.ts +0 -489
  406. package/dist/utils/spawnWrapper.ts +0 -9
  407. package/dist/utils/startupWarnings.test.ts +0 -83
  408. package/dist/utils/startupWarnings.ts +0 -40
  409. package/dist/utils/updateEventEmitter.ts +0 -13
  410. package/dist/utils/userStartupWarnings.test.ts +0 -87
  411. package/dist/utils/userStartupWarnings.ts +0 -69
  412. package/dist/utils/version.ts +0 -12
  413. package/dist/validateNonInterActiveAuth.test.ts +0 -260
  414. package/dist/validateNonInterActiveAuth.ts +0 -51
  415. package/dist/vitest.config.ts +0 -37
  416. package/dist/zed-integration/acp.ts +0 -366
  417. package/dist/zed-integration/fileSystemService.ts +0 -47
  418. package/dist/zed-integration/schema.ts +0 -466
  419. package/dist/zed-integration/zedIntegration.ts +0 -944
@@ -1,105 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- let detectionComplete = false;
8
- let protocolSupported = false;
9
- let protocolEnabled = false;
10
-
11
- /**
12
- * Detects Kitty keyboard protocol support.
13
- * Definitive document about this protocol lives at https://sw.kovidgoyal.net/kitty/keyboard-protocol/
14
- * This function should be called once at app startup.
15
- */
16
- export async function detectAndEnableKittyProtocol(): Promise<boolean> {
17
- if (detectionComplete) {
18
- return protocolSupported;
19
- }
20
-
21
- return new Promise((resolve) => {
22
- if (!process.stdin.isTTY || !process.stdout.isTTY) {
23
- detectionComplete = true;
24
- resolve(false);
25
- return;
26
- }
27
-
28
- const originalRawMode = process.stdin.isRaw;
29
- if (!originalRawMode) {
30
- process.stdin.setRawMode(true);
31
- }
32
-
33
- let responseBuffer = '';
34
- let progressiveEnhancementReceived = false;
35
- let checkFinished = false;
36
-
37
- const handleData = (data: Buffer) => {
38
- responseBuffer += data.toString();
39
-
40
- // Check for progressive enhancement response (CSI ? <flags> u)
41
- if (responseBuffer.includes('\x1b[?') && responseBuffer.includes('u')) {
42
- progressiveEnhancementReceived = true;
43
- }
44
-
45
- // Check for device attributes response (CSI ? <attrs> c)
46
- if (responseBuffer.includes('\x1b[?') && responseBuffer.includes('c')) {
47
- if (!checkFinished) {
48
- checkFinished = true;
49
- process.stdin.removeListener('data', handleData);
50
-
51
- if (!originalRawMode) {
52
- process.stdin.setRawMode(false);
53
- }
54
-
55
- if (progressiveEnhancementReceived) {
56
- // Enable the protocol
57
- process.stdout.write('\x1b[>1u');
58
- protocolSupported = true;
59
- protocolEnabled = true;
60
-
61
- // Set up cleanup on exit
62
- process.on('exit', disableProtocol);
63
- process.on('SIGTERM', disableProtocol);
64
- }
65
-
66
- detectionComplete = true;
67
- resolve(protocolSupported);
68
- }
69
- }
70
- };
71
-
72
- process.stdin.on('data', handleData);
73
-
74
- // Send queries
75
- process.stdout.write('\x1b[?u'); // Query progressive enhancement
76
- process.stdout.write('\x1b[c'); // Query device attributes
77
-
78
- // Timeout after 50ms
79
- setTimeout(() => {
80
- if (!checkFinished) {
81
- process.stdin.removeListener('data', handleData);
82
- if (!originalRawMode) {
83
- process.stdin.setRawMode(false);
84
- }
85
- detectionComplete = true;
86
- resolve(false);
87
- }
88
- }, 50);
89
- });
90
- }
91
-
92
- function disableProtocol() {
93
- if (protocolEnabled) {
94
- process.stdout.write('\x1b[<u');
95
- protocolEnabled = false;
96
- }
97
- }
98
-
99
- export function isKittyProtocolEnabled(): boolean {
100
- return protocolEnabled;
101
- }
102
-
103
- export function isKittyProtocolSupported(): boolean {
104
- return protocolSupported;
105
- }
@@ -1,50 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- import { describe, it, expect } from 'vitest';
8
- import { findLastSafeSplitPoint } from './markdownUtilities.js';
9
-
10
- describe('markdownUtilities', () => {
11
- describe('findLastSafeSplitPoint', () => {
12
- it('should split at the last double newline if not in a code block', () => {
13
- const content = 'paragraph1\n\nparagraph2\n\nparagraph3';
14
- expect(findLastSafeSplitPoint(content)).toBe(24); // After the second \n\n
15
- });
16
-
17
- it('should return content.length if no safe split point is found', () => {
18
- const content = 'longstringwithoutanysafesplitpoint';
19
- expect(findLastSafeSplitPoint(content)).toBe(content.length);
20
- });
21
-
22
- it('should prioritize splitting at \n\n over being at the very end of the string if the end is not in a code block', () => {
23
- const content = 'Some text here.\n\nAnd more text here.';
24
- expect(findLastSafeSplitPoint(content)).toBe(17); // after the \n\n
25
- });
26
-
27
- it('should return content.length if the only \n\n is inside a code block and the end of content is not', () => {
28
- const content = '```\nignore this\n\nnewline\n```KeepThis';
29
- expect(findLastSafeSplitPoint(content)).toBe(content.length);
30
- });
31
-
32
- it('should correctly identify the last \n\n even if it is followed by text not in a code block', () => {
33
- const content =
34
- 'First part.\n\nSecond part.\n\nThird part, then some more text.';
35
- // Split should be after "Second part.\n\n"
36
- // "First part.\n\n" is 13 chars. "Second part.\n\n" is 14 chars. Total 27.
37
- expect(findLastSafeSplitPoint(content)).toBe(27);
38
- });
39
-
40
- it('should return content.length if content is empty', () => {
41
- const content = '';
42
- expect(findLastSafeSplitPoint(content)).toBe(0);
43
- });
44
-
45
- it('should return content.length if content has no newlines and no code blocks', () => {
46
- const content = 'Single line of text';
47
- expect(findLastSafeSplitPoint(content)).toBe(content.length);
48
- });
49
- });
50
- });
@@ -1,125 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /*
8
- **Background & Purpose:**
9
-
10
- The `findSafeSplitPoint` function is designed to address the challenge of displaying or processing large, potentially streaming, pieces of Markdown text. When content (e.g., from an LLM like Gemini) arrives in chunks or grows too large for a single display unit (like a message bubble), it needs to be split. A naive split (e.g., just at a character limit) can break Markdown formatting, especially critical for multi-line elements like code blocks, lists, or blockquotes, leading to incorrect rendering.
11
-
12
- This function aims to find an *intelligent* or "safe" index within the provided `content` string at which to make such a split, prioritizing the preservation of Markdown integrity.
13
-
14
- **Key Expectations & Behavior (Prioritized):**
15
-
16
- 1. **No Split if Short Enough:**
17
- * If `content.length` is less than or equal to `idealMaxLength`, the function should return `content.length` (indicating no split is necessary for length reasons).
18
-
19
- 2. **Code Block Integrity (Highest Priority for Safety):**
20
- * The function must try to avoid splitting *inside* a fenced code block (i.e., between ` ``` ` and ` ``` `).
21
- * If `idealMaxLength` falls within a code block:
22
- * The function will attempt to return an index that splits the content *before* the start of that code block.
23
- * If a code block starts at the very beginning of the `content` and `idealMaxLength` falls within it (meaning the block itself is too long for the first chunk), the function might return `0`. This effectively makes the first chunk empty, pushing the entire oversized code block to the second part of the split.
24
- * When considering splits near code blocks, the function prefers to keep the entire code block intact in one of the resulting chunks.
25
-
26
- 3. **Markdown-Aware Newline Splitting (If Not Governed by Code Block Logic):**
27
- * If `idealMaxLength` does not fall within a code block (or after code block considerations have been made), the function will look for natural break points by scanning backwards from `idealMaxLength`:
28
- * **Paragraph Breaks:** It prioritizes splitting after a double newline (`\n\n`), as this typically signifies the end of a paragraph or a block-level element.
29
- * **Single Line Breaks:** If no double newline is found in a suitable range, it will look for a single newline (`\n`).
30
- * Any newline chosen as a split point must also not be inside a code block.
31
-
32
- 4. **Fall back to `idealMaxLength`:**
33
- * If no "safer" split point (respecting code blocks or finding suitable newlines) is identified before or at `idealMaxLength`, and `idealMaxLength` itself is not determined to be an unsafe split point (e.g., inside a code block), the function may return a length larger than `idealMaxLength`, again it CANNOT break markdown formatting. This could happen with very long lines of text without Markdown block structures or newlines.
34
-
35
- **In essence, `findSafeSplitPoint` tries to be a good Markdown citizen when forced to divide content, preferring structural boundaries over arbitrary character limits, with a strong emphasis on not corrupting code blocks.**
36
- */
37
-
38
- /**
39
- * Checks if a given character index within a string is inside a fenced (```) code block.
40
- * @param content The full string content.
41
- * @param indexToTest The character index to test.
42
- * @returns True if the index is inside a code block's content, false otherwise.
43
- */
44
- const isIndexInsideCodeBlock = (
45
- content: string,
46
- indexToTest: number,
47
- ): boolean => {
48
- let fenceCount = 0;
49
- let searchPos = 0;
50
- while (searchPos < content.length) {
51
- const nextFence = content.indexOf('```', searchPos);
52
- if (nextFence === -1 || nextFence >= indexToTest) {
53
- break;
54
- }
55
- fenceCount++;
56
- searchPos = nextFence + 3;
57
- }
58
- return fenceCount % 2 === 1;
59
- };
60
-
61
- /**
62
- * Finds the starting index of the code block that encloses the given index.
63
- * Returns -1 if the index is not inside a code block.
64
- * @param content The markdown content.
65
- * @param index The index to check.
66
- * @returns Start index of the enclosing code block or -1.
67
- */
68
- const findEnclosingCodeBlockStart = (
69
- content: string,
70
- index: number,
71
- ): number => {
72
- if (!isIndexInsideCodeBlock(content, index)) {
73
- return -1;
74
- }
75
- let currentSearchPos = 0;
76
- while (currentSearchPos < index) {
77
- const blockStartIndex = content.indexOf('```', currentSearchPos);
78
- if (blockStartIndex === -1 || blockStartIndex >= index) {
79
- break;
80
- }
81
- const blockEndIndex = content.indexOf('```', blockStartIndex + 3);
82
- if (blockStartIndex < index) {
83
- if (blockEndIndex === -1 || index < blockEndIndex + 3) {
84
- return blockStartIndex;
85
- }
86
- }
87
- if (blockEndIndex === -1) break;
88
- currentSearchPos = blockEndIndex + 3;
89
- }
90
- return -1;
91
- };
92
-
93
- export const findLastSafeSplitPoint = (content: string) => {
94
- const enclosingBlockStart = findEnclosingCodeBlockStart(
95
- content,
96
- content.length,
97
- );
98
- if (enclosingBlockStart !== -1) {
99
- // The end of the content is contained in a code block. Split right before.
100
- return enclosingBlockStart;
101
- }
102
-
103
- // Search for the last double newline (\n\n) not in a code block.
104
- let searchStartIndex = content.length;
105
- while (searchStartIndex >= 0) {
106
- const dnlIndex = content.lastIndexOf('\n\n', searchStartIndex);
107
- if (dnlIndex === -1) {
108
- // No more double newlines found.
109
- break;
110
- }
111
-
112
- const potentialSplitPoint = dnlIndex + 2;
113
- if (!isIndexInsideCodeBlock(content, potentialSplitPoint)) {
114
- return potentialSplitPoint;
115
- }
116
-
117
- // If potentialSplitPoint was inside a code block,
118
- // the next search should start *before* the \n\n we just found to ensure progress.
119
- searchStartIndex = dnlIndex - 1;
120
- }
121
-
122
- // If no safe double newline is found, return content.length
123
- // to keep the entire content as one piece.
124
- return content.length;
125
- };
@@ -1,52 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /**
8
- * Terminal Platform Constants
9
- *
10
- * This file contains terminal-related constants used throughout the application,
11
- * specifically for handling keyboard inputs and terminal protocols.
12
- */
13
-
14
- /**
15
- * Kitty keyboard protocol sequences for enhanced keyboard input.
16
- * @see https://sw.kovidgoyal.net/kitty/keyboard-protocol/
17
- */
18
- export const KITTY_CTRL_C = '[99;5u';
19
-
20
- /**
21
- * Kitty keyboard protocol keycodes
22
- */
23
- export const KITTY_KEYCODE_ENTER = 13;
24
- export const KITTY_KEYCODE_NUMPAD_ENTER = 57414;
25
- export const KITTY_KEYCODE_TAB = 9;
26
- export const KITTY_KEYCODE_BACKSPACE = 127;
27
-
28
- /**
29
- * Timing constants for terminal interactions
30
- */
31
- export const CTRL_EXIT_PROMPT_DURATION_MS = 1000;
32
-
33
- /**
34
- * VS Code terminal integration constants
35
- */
36
- export const VSCODE_SHIFT_ENTER_SEQUENCE = '\\\r\n';
37
-
38
- /**
39
- * Backslash + Enter detection window in milliseconds.
40
- * Used to detect Shift+Enter pattern where backslash
41
- * is followed by Enter within this timeframe.
42
- */
43
- export const BACKSLASH_ENTER_DETECTION_WINDOW_MS = 5;
44
-
45
- /**
46
- * Maximum expected length of a Kitty keyboard protocol sequence.
47
- * Format: ESC [ <keycode> ; <modifiers> u/~
48
- * Example: \x1b[13;2u (Shift+Enter) = 8 chars
49
- * Longest reasonable: \x1b[127;15~ = 11 chars (Del with all modifiers)
50
- * We use 12 to provide a small buffer.
51
- */
52
- export const MAX_KITTY_SEQUENCE_LENGTH = 12;
@@ -1,342 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /**
8
- * Terminal setup utility for configuring Shift+Enter and Ctrl+Enter support.
9
- *
10
- * This module provides automatic detection and configuration of various terminal
11
- * emulators to support multiline input through modified Enter keys.
12
- *
13
- * Supported terminals:
14
- * - VS Code: Configures keybindings.json to send \\\r\n
15
- * - Cursor: Configures keybindings.json to send \\\r\n (VS Code fork)
16
- * - Windsurf: Configures keybindings.json to send \\\r\n (VS Code fork)
17
- *
18
- * For VS Code and its forks:
19
- * - Shift+Enter: Sends \\\r\n (backslash followed by CRLF)
20
- * - Ctrl+Enter: Sends \\\r\n (backslash followed by CRLF)
21
- *
22
- * The module will not modify existing shift+enter or ctrl+enter keybindings
23
- * to avoid conflicts with user customizations.
24
- */
25
-
26
- import { promises as fs } from 'fs';
27
- import * as os from 'os';
28
- import * as path from 'path';
29
- import { exec } from 'child_process';
30
- import { promisify } from 'util';
31
- import { isKittyProtocolEnabled } from './kittyProtocolDetector.js';
32
- import { VSCODE_SHIFT_ENTER_SEQUENCE } from './platformConstants.js';
33
-
34
- const execAsync = promisify(exec);
35
-
36
- /**
37
- * Removes single-line JSON comments (// ...) from a string to allow parsing
38
- * VS Code style JSON files that may contain comments.
39
- */
40
- function stripJsonComments(content: string): string {
41
- // Remove single-line comments (// ...)
42
- return content.replace(/^\s*\/\/.*$/gm, '');
43
- }
44
-
45
- export interface TerminalSetupResult {
46
- success: boolean;
47
- message: string;
48
- requiresRestart?: boolean;
49
- }
50
-
51
- type SupportedTerminal = 'vscode' | 'cursor' | 'windsurf';
52
-
53
- // Terminal detection
54
- async function detectTerminal(): Promise<SupportedTerminal | null> {
55
- const termProgram = process.env['TERM_PROGRAM'];
56
-
57
- // Check VS Code and its forks - check forks first to avoid false positives
58
- // Check for Cursor-specific indicators
59
- if (
60
- process.env['CURSOR_TRACE_ID'] ||
61
- process.env['VSCODE_GIT_ASKPASS_MAIN']?.toLowerCase().includes('cursor')
62
- ) {
63
- return 'cursor';
64
- }
65
- // Check for Windsurf-specific indicators
66
- if (
67
- process.env['VSCODE_GIT_ASKPASS_MAIN']?.toLowerCase().includes('windsurf')
68
- ) {
69
- return 'windsurf';
70
- }
71
- // Check VS Code last since forks may also set VSCODE env vars
72
- if (termProgram === 'vscode' || process.env['VSCODE_GIT_IPC_HANDLE']) {
73
- return 'vscode';
74
- }
75
-
76
- // Check parent process name
77
- if (os.platform() !== 'win32') {
78
- try {
79
- const { stdout } = await execAsync('ps -o comm= -p $PPID');
80
- const parentName = stdout.trim();
81
-
82
- // Check forks before VS Code to avoid false positives
83
- if (parentName.includes('windsurf') || parentName.includes('Windsurf'))
84
- return 'windsurf';
85
- if (parentName.includes('cursor') || parentName.includes('Cursor'))
86
- return 'cursor';
87
- if (parentName.includes('code') || parentName.includes('Code'))
88
- return 'vscode';
89
- } catch (error) {
90
- // Continue detection even if process check fails
91
- console.debug('Parent process detection failed:', error);
92
- }
93
- }
94
-
95
- return null;
96
- }
97
-
98
- // Backup file helper
99
- async function backupFile(filePath: string): Promise<void> {
100
- try {
101
- const timestamp = new Date().toISOString().replace(/[:.]/g, '-');
102
- const backupPath = `${filePath}.backup.${timestamp}`;
103
- await fs.copyFile(filePath, backupPath);
104
- } catch (error) {
105
- // Log backup errors but continue with operation
106
- console.warn(`Failed to create backup of ${filePath}:`, error);
107
- }
108
- }
109
-
110
- // Helper function to get VS Code-style config directory
111
- function getVSCodeStyleConfigDir(appName: string): string | null {
112
- const platform = os.platform();
113
-
114
- if (platform === 'darwin') {
115
- return path.join(
116
- os.homedir(),
117
- 'Library',
118
- 'Application Support',
119
- appName,
120
- 'User',
121
- );
122
- } else if (platform === 'win32') {
123
- if (!process.env['APPDATA']) {
124
- return null;
125
- }
126
- return path.join(process.env['APPDATA'], appName, 'User');
127
- } else {
128
- return path.join(os.homedir(), '.config', appName, 'User');
129
- }
130
- }
131
-
132
- // Generic VS Code-style terminal configuration
133
- async function configureVSCodeStyle(
134
- terminalName: string,
135
- appName: string,
136
- ): Promise<TerminalSetupResult> {
137
- const configDir = getVSCodeStyleConfigDir(appName);
138
-
139
- if (!configDir) {
140
- return {
141
- success: false,
142
- message: `Could not determine ${terminalName} config path on Windows: APPDATA environment variable is not set.`,
143
- };
144
- }
145
-
146
- const keybindingsFile = path.join(configDir, 'keybindings.json');
147
-
148
- try {
149
- await fs.mkdir(configDir, { recursive: true });
150
-
151
- let keybindings: unknown[] = [];
152
- try {
153
- const content = await fs.readFile(keybindingsFile, 'utf8');
154
- await backupFile(keybindingsFile);
155
- try {
156
- const cleanContent = stripJsonComments(content);
157
- const parsedContent = JSON.parse(cleanContent);
158
- if (!Array.isArray(parsedContent)) {
159
- return {
160
- success: false,
161
- message:
162
- `${terminalName} keybindings.json exists but is not a valid JSON array. ` +
163
- `Please fix the file manually or delete it to allow automatic configuration.\n` +
164
- `File: ${keybindingsFile}`,
165
- };
166
- }
167
- keybindings = parsedContent;
168
- } catch (parseError) {
169
- return {
170
- success: false,
171
- message:
172
- `Failed to parse ${terminalName} keybindings.json. The file contains invalid JSON.\n` +
173
- `Please fix the file manually or delete it to allow automatic configuration.\n` +
174
- `File: ${keybindingsFile}\n` +
175
- `Error: ${parseError}`,
176
- };
177
- }
178
- } catch {
179
- // File doesn't exist, will create new one
180
- }
181
-
182
- const shiftEnterBinding = {
183
- key: 'shift+enter',
184
- command: 'workbench.action.terminal.sendSequence',
185
- when: 'terminalFocus',
186
- args: { text: VSCODE_SHIFT_ENTER_SEQUENCE },
187
- };
188
-
189
- const ctrlEnterBinding = {
190
- key: 'ctrl+enter',
191
- command: 'workbench.action.terminal.sendSequence',
192
- when: 'terminalFocus',
193
- args: { text: VSCODE_SHIFT_ENTER_SEQUENCE },
194
- };
195
-
196
- // Check if ANY shift+enter or ctrl+enter bindings already exist
197
- const existingShiftEnter = keybindings.find((kb) => {
198
- const binding = kb as { key?: string };
199
- return binding.key === 'shift+enter';
200
- });
201
-
202
- const existingCtrlEnter = keybindings.find((kb) => {
203
- const binding = kb as { key?: string };
204
- return binding.key === 'ctrl+enter';
205
- });
206
-
207
- if (existingShiftEnter || existingCtrlEnter) {
208
- const messages: string[] = [];
209
- if (existingShiftEnter) {
210
- messages.push(`- Shift+Enter binding already exists`);
211
- }
212
- if (existingCtrlEnter) {
213
- messages.push(`- Ctrl+Enter binding already exists`);
214
- }
215
- return {
216
- success: false,
217
- message:
218
- `Existing keybindings detected. Will not modify to avoid conflicts.\n` +
219
- messages.join('\n') +
220
- '\n' +
221
- `Please check and modify manually if needed: ${keybindingsFile}`,
222
- };
223
- }
224
-
225
- // Check if our specific bindings already exist
226
- const hasOurShiftEnter = keybindings.some((kb) => {
227
- const binding = kb as {
228
- command?: string;
229
- args?: { text?: string };
230
- key?: string;
231
- };
232
- return (
233
- binding.key === 'shift+enter' &&
234
- binding.command === 'workbench.action.terminal.sendSequence' &&
235
- binding.args?.text === '\\\r\n'
236
- );
237
- });
238
-
239
- const hasOurCtrlEnter = keybindings.some((kb) => {
240
- const binding = kb as {
241
- command?: string;
242
- args?: { text?: string };
243
- key?: string;
244
- };
245
- return (
246
- binding.key === 'ctrl+enter' &&
247
- binding.command === 'workbench.action.terminal.sendSequence' &&
248
- binding.args?.text === '\\\r\n'
249
- );
250
- });
251
-
252
- if (!hasOurShiftEnter || !hasOurCtrlEnter) {
253
- if (!hasOurShiftEnter) keybindings.unshift(shiftEnterBinding);
254
- if (!hasOurCtrlEnter) keybindings.unshift(ctrlEnterBinding);
255
-
256
- await fs.writeFile(keybindingsFile, JSON.stringify(keybindings, null, 4));
257
- return {
258
- success: true,
259
- message: `Added Shift+Enter and Ctrl+Enter keybindings to ${terminalName}.\nModified: ${keybindingsFile}`,
260
- requiresRestart: true,
261
- };
262
- } else {
263
- return {
264
- success: true,
265
- message: `${terminalName} keybindings already configured.`,
266
- };
267
- }
268
- } catch (error) {
269
- return {
270
- success: false,
271
- message: `Failed to configure ${terminalName}.\nFile: ${keybindingsFile}\nError: ${error}`,
272
- };
273
- }
274
- }
275
-
276
- // Terminal-specific configuration functions
277
-
278
- async function configureVSCode(): Promise<TerminalSetupResult> {
279
- return configureVSCodeStyle('VS Code', 'Code');
280
- }
281
-
282
- async function configureCursor(): Promise<TerminalSetupResult> {
283
- return configureVSCodeStyle('Cursor', 'Cursor');
284
- }
285
-
286
- async function configureWindsurf(): Promise<TerminalSetupResult> {
287
- return configureVSCodeStyle('Windsurf', 'Windsurf');
288
- }
289
-
290
- /**
291
- * Main terminal setup function that detects and configures the current terminal.
292
- *
293
- * This function:
294
- * 1. Detects the current terminal emulator
295
- * 2. Applies appropriate configuration for Shift+Enter and Ctrl+Enter support
296
- * 3. Creates backups of configuration files before modifying them
297
- *
298
- * @returns Promise<TerminalSetupResult> Result object with success status and message
299
- *
300
- * @example
301
- * const result = await terminalSetup();
302
- * if (result.success) {
303
- * console.log(result.message);
304
- * if (result.requiresRestart) {
305
- * console.log('Please restart your terminal');
306
- * }
307
- * }
308
- */
309
- export async function terminalSetup(): Promise<TerminalSetupResult> {
310
- // Check if terminal already has optimal keyboard support
311
- if (isKittyProtocolEnabled()) {
312
- return {
313
- success: true,
314
- message:
315
- 'Your terminal is already configured for an optimal experience with multiline input (Shift+Enter and Ctrl+Enter).',
316
- };
317
- }
318
-
319
- const terminal = await detectTerminal();
320
-
321
- if (!terminal) {
322
- return {
323
- success: false,
324
- message:
325
- 'Could not detect terminal type. Supported terminals: VS Code, Cursor, and Windsurf.',
326
- };
327
- }
328
-
329
- switch (terminal) {
330
- case 'vscode':
331
- return configureVSCode();
332
- case 'cursor':
333
- return configureCursor();
334
- case 'windsurf':
335
- return configureWindsurf();
336
- default:
337
- return {
338
- success: false,
339
- message: `Terminal "${terminal}" is not supported yet.`,
340
- };
341
- }
342
- }