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,624 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- import React, { Fragment, useEffect, useId } from 'react';
8
- import { Box, Text } from 'ink';
9
- import stringWidth from 'string-width';
10
- import { Colors } from '../../colors.js';
11
- import { toCodePoints } from '../../utils/textUtils.js';
12
- import { useOverflowActions } from '../../contexts/OverflowContext.js';
13
-
14
- let enableDebugLog = false;
15
-
16
- /**
17
- * Minimum height for the MaxSizedBox component.
18
- * This ensures there is room for at least one line of content as well as the
19
- * message that content was truncated.
20
- */
21
- export const MINIMUM_MAX_HEIGHT = 2;
22
-
23
- export function setMaxSizedBoxDebugging(value: boolean) {
24
- enableDebugLog = value;
25
- }
26
-
27
- function debugReportError(message: string, element: React.ReactNode) {
28
- if (!enableDebugLog) return;
29
-
30
- if (!React.isValidElement(element)) {
31
- console.error(
32
- message,
33
- `Invalid element: '${String(element)}' typeof=${typeof element}`,
34
- );
35
- return;
36
- }
37
-
38
- let sourceMessage = '<Unknown file>';
39
- try {
40
- const elementWithSource = element as {
41
- _source?: { fileName?: string; lineNumber?: number };
42
- };
43
- const fileName = elementWithSource._source?.fileName;
44
- const lineNumber = elementWithSource._source?.lineNumber;
45
- sourceMessage = fileName ? `${fileName}:${lineNumber}` : '<Unknown file>';
46
- } catch (error) {
47
- console.error('Error while trying to get file name:', error);
48
- }
49
-
50
- console.error(message, `${String(element.type)}. Source: ${sourceMessage}`);
51
- }
52
- interface MaxSizedBoxProps {
53
- children?: React.ReactNode;
54
- maxWidth?: number;
55
- maxHeight: number | undefined;
56
- overflowDirection?: 'top' | 'bottom';
57
- additionalHiddenLinesCount?: number;
58
- }
59
-
60
- /**
61
- * A React component that constrains the size of its children and provides
62
- * content-aware truncation when the content exceeds the specified `maxHeight`.
63
- *
64
- * `MaxSizedBox` requires a specific structure for its children to correctly
65
- * measure and render the content:
66
- *
67
- * 1. **Direct children must be `<Box>` elements.** Each `<Box>` represents a
68
- * single row of content.
69
- * 2. **Row `<Box>` elements must contain only `<Text>` elements.** These
70
- * `<Text>` elements can be nested and there are no restrictions to Text
71
- * element styling other than that non-wrapping text elements must be
72
- * before wrapping text elements.
73
- *
74
- * **Constraints:**
75
- * - **Box Properties:** Custom properties on the child `<Box>` elements are
76
- * ignored. In debug mode, runtime checks will report errors for any
77
- * unsupported properties.
78
- * - **Text Wrapping:** Within a single row, `<Text>` elements with no wrapping
79
- * (e.g., headers, labels) must appear before any `<Text>` elements that wrap.
80
- * - **Element Types:** Runtime checks will warn if unsupported element types
81
- * are used as children.
82
- *
83
- * @example
84
- * <MaxSizedBox maxWidth={80} maxHeight={10}>
85
- * <Box>
86
- * <Text>This is the first line.</Text>
87
- * </Box>
88
- * <Box>
89
- * <Text color="cyan" wrap="truncate">Non-wrapping Header: </Text>
90
- * <Text>This is the rest of the line which will wrap if it's too long.</Text>
91
- * </Box>
92
- * <Box>
93
- * <Text>
94
- * Line 3 with <Text color="yellow">nested styled text</Text> inside of it.
95
- * </Text>
96
- * </Box>
97
- * </MaxSizedBox>
98
- */
99
- export const MaxSizedBox: React.FC<MaxSizedBoxProps> = ({
100
- children,
101
- maxWidth,
102
- maxHeight,
103
- overflowDirection = 'top',
104
- additionalHiddenLinesCount = 0,
105
- }) => {
106
- const id = useId();
107
- const { addOverflowingId, removeOverflowingId } = useOverflowActions() || {};
108
-
109
- const laidOutStyledText: StyledText[][] = [];
110
- const targetMaxHeight = Math.max(
111
- Math.round(maxHeight ?? Number.MAX_SAFE_INTEGER),
112
- MINIMUM_MAX_HEIGHT,
113
- );
114
-
115
- if (maxWidth === undefined) {
116
- throw new Error('maxWidth must be defined when maxHeight is set.');
117
- }
118
- function visitRows(element: React.ReactNode) {
119
- if (!React.isValidElement<{ children?: React.ReactNode }>(element)) {
120
- return;
121
- }
122
-
123
- if (element.type === Fragment) {
124
- React.Children.forEach(element.props.children, visitRows);
125
- return;
126
- }
127
-
128
- if (element.type === Box) {
129
- layoutInkElementAsStyledText(element, maxWidth!, laidOutStyledText);
130
- return;
131
- }
132
-
133
- debugReportError('MaxSizedBox children must be <Box> elements', element);
134
- }
135
-
136
- React.Children.forEach(children, visitRows);
137
-
138
- const contentWillOverflow =
139
- (targetMaxHeight !== undefined &&
140
- laidOutStyledText.length > targetMaxHeight) ||
141
- additionalHiddenLinesCount > 0;
142
- const visibleContentHeight =
143
- contentWillOverflow && targetMaxHeight !== undefined
144
- ? targetMaxHeight - 1
145
- : targetMaxHeight;
146
-
147
- const hiddenLinesCount =
148
- visibleContentHeight !== undefined
149
- ? Math.max(0, laidOutStyledText.length - visibleContentHeight)
150
- : 0;
151
- const totalHiddenLines = hiddenLinesCount + additionalHiddenLinesCount;
152
-
153
- useEffect(() => {
154
- if (totalHiddenLines > 0) {
155
- addOverflowingId?.(id);
156
- } else {
157
- removeOverflowingId?.(id);
158
- }
159
-
160
- return () => {
161
- removeOverflowingId?.(id);
162
- };
163
- }, [id, totalHiddenLines, addOverflowingId, removeOverflowingId]);
164
-
165
- const visibleStyledText =
166
- hiddenLinesCount > 0
167
- ? overflowDirection === 'top'
168
- ? laidOutStyledText.slice(hiddenLinesCount, laidOutStyledText.length)
169
- : laidOutStyledText.slice(0, visibleContentHeight)
170
- : laidOutStyledText;
171
-
172
- const visibleLines = visibleStyledText.map((line, index) => (
173
- <Box key={index}>
174
- {line.length > 0 ? (
175
- line.map((segment, segIndex) => (
176
- <Text key={segIndex} {...segment.props}>
177
- {segment.text}
178
- </Text>
179
- ))
180
- ) : (
181
- <Text> </Text>
182
- )}
183
- </Box>
184
- ));
185
-
186
- return (
187
- <Box flexDirection="column" width={maxWidth} flexShrink={0}>
188
- {totalHiddenLines > 0 && overflowDirection === 'top' && (
189
- <Text color={Colors.Gray} wrap="truncate">
190
- ... first {totalHiddenLines} line{totalHiddenLines === 1 ? '' : 's'}{' '}
191
- hidden ...
192
- </Text>
193
- )}
194
- {visibleLines}
195
- {totalHiddenLines > 0 && overflowDirection === 'bottom' && (
196
- <Text color={Colors.Gray} wrap="truncate">
197
- ... last {totalHiddenLines} line{totalHiddenLines === 1 ? '' : 's'}{' '}
198
- hidden ...
199
- </Text>
200
- )}
201
- </Box>
202
- );
203
- };
204
-
205
- // Define a type for styled text segments
206
- interface StyledText {
207
- text: string;
208
- props: Record<string, unknown>;
209
- }
210
-
211
- /**
212
- * Single row of content within the MaxSizedBox.
213
- *
214
- * A row can contain segments that are not wrapped, followed by segments that
215
- * are. This is a minimal implementation that only supports the functionality
216
- * needed today.
217
- */
218
- interface Row {
219
- noWrapSegments: StyledText[];
220
- segments: StyledText[];
221
- }
222
-
223
- /**
224
- * Flattens the child elements of MaxSizedBox into an array of `Row` objects.
225
- *
226
- * This function expects a specific child structure to function correctly:
227
- * 1. The top-level child of `MaxSizedBox` should be a single `<Box>`. This
228
- * outer box is primarily for structure and is not directly rendered.
229
- * 2. Inside the outer `<Box>`, there should be one or more children. Each of
230
- * these children must be a `<Box>` that represents a row.
231
- * 3. Inside each "row" `<Box>`, the children must be `<Text>` components.
232
- *
233
- * The structure should look like this:
234
- * <MaxSizedBox>
235
- * <Box> // Row 1
236
- * <Text>...</Text>
237
- * <Text>...</Text>
238
- * </Box>
239
- * <Box> // Row 2
240
- * <Text>...</Text>
241
- * </Box>
242
- * </MaxSizedBox>
243
- *
244
- * It is an error for a <Text> child without wrapping to appear after a
245
- * <Text> child with wrapping within the same row Box.
246
- *
247
- * @param element The React node to flatten.
248
- * @returns An array of `Row` objects.
249
- */
250
- function visitBoxRow(element: React.ReactNode): Row {
251
- if (
252
- !React.isValidElement<{ children?: React.ReactNode }>(element) ||
253
- element.type !== Box
254
- ) {
255
- debugReportError(
256
- `All children of MaxSizedBox must be <Box> elements`,
257
- element,
258
- );
259
- return {
260
- noWrapSegments: [{ text: '<ERROR>', props: {} }],
261
- segments: [],
262
- };
263
- }
264
-
265
- if (enableDebugLog) {
266
- const boxProps = element.props as {
267
- children?: React.ReactNode | undefined;
268
- readonly flexDirection?:
269
- | 'row'
270
- | 'column'
271
- | 'row-reverse'
272
- | 'column-reverse'
273
- | undefined;
274
- };
275
- // Ensure the Box has no props other than the default ones and key.
276
- let maxExpectedProps = 4;
277
- if (boxProps.children !== undefined) {
278
- // Allow the key prop, which is automatically added by React.
279
- maxExpectedProps += 1;
280
- }
281
- if (
282
- boxProps.flexDirection !== undefined &&
283
- boxProps.flexDirection !== 'row'
284
- ) {
285
- debugReportError(
286
- 'MaxSizedBox children must have flexDirection="row".',
287
- element,
288
- );
289
- }
290
- if (Object.keys(boxProps).length > maxExpectedProps) {
291
- debugReportError(
292
- `Boxes inside MaxSizedBox must not have additional props. ${Object.keys(
293
- boxProps,
294
- ).join(', ')}`,
295
- element,
296
- );
297
- }
298
- }
299
-
300
- const row: Row = {
301
- noWrapSegments: [],
302
- segments: [],
303
- };
304
-
305
- let hasSeenWrapped = false;
306
-
307
- function visitRowChild(
308
- element: React.ReactNode,
309
- parentProps: Record<string, unknown> | undefined,
310
- ) {
311
- if (element === null) {
312
- return;
313
- }
314
- if (typeof element === 'string' || typeof element === 'number') {
315
- const text = String(element);
316
- // Ignore empty strings as they don't need to be rendered.
317
- if (!text) {
318
- return;
319
- }
320
-
321
- const segment: StyledText = { text, props: parentProps ?? {} };
322
-
323
- // Check the 'wrap' property from the merged props to decide the segment type.
324
- if (parentProps === undefined || parentProps['wrap'] === 'wrap') {
325
- hasSeenWrapped = true;
326
- row.segments.push(segment);
327
- } else {
328
- if (!hasSeenWrapped) {
329
- row.noWrapSegments.push(segment);
330
- } else {
331
- // put in the wrapped segment as the row is already stuck in wrapped mode.
332
- row.segments.push(segment);
333
- debugReportError(
334
- 'Text elements without wrapping cannot appear after elements with wrapping in the same row.',
335
- element,
336
- );
337
- }
338
- }
339
- return;
340
- }
341
-
342
- if (!React.isValidElement<{ children?: React.ReactNode }>(element)) {
343
- debugReportError('Invalid element.', element);
344
- return;
345
- }
346
-
347
- if (element.type === Fragment) {
348
- React.Children.forEach(element.props.children, (child) =>
349
- visitRowChild(child, parentProps),
350
- );
351
- return;
352
- }
353
-
354
- if (element.type !== Text) {
355
- debugReportError(
356
- 'Children of a row Box must be <Text> elements.',
357
- element,
358
- );
359
- return;
360
- }
361
-
362
- // Merge props from parent <Text> elements. Child props take precedence.
363
- const { children, ...currentProps } = element.props;
364
- const mergedProps =
365
- parentProps === undefined
366
- ? currentProps
367
- : { ...parentProps, ...currentProps };
368
- React.Children.forEach(children, (child) =>
369
- visitRowChild(child, mergedProps),
370
- );
371
- }
372
-
373
- React.Children.forEach(element.props.children, (child) =>
374
- visitRowChild(child, undefined),
375
- );
376
-
377
- return row;
378
- }
379
-
380
- function layoutInkElementAsStyledText(
381
- element: React.ReactElement,
382
- maxWidth: number,
383
- output: StyledText[][],
384
- ) {
385
- const row = visitBoxRow(element);
386
- if (row.segments.length === 0 && row.noWrapSegments.length === 0) {
387
- // Return a single empty line if there are no segments to display
388
- output.push([]);
389
- return;
390
- }
391
-
392
- const lines: StyledText[][] = [];
393
- const nonWrappingContent: StyledText[] = [];
394
- let noWrappingWidth = 0;
395
-
396
- // First, lay out the non-wrapping segments
397
- row.noWrapSegments.forEach((segment) => {
398
- nonWrappingContent.push(segment);
399
- noWrappingWidth += stringWidth(segment.text);
400
- });
401
-
402
- if (row.segments.length === 0) {
403
- // This is a bit of a special case when there are no segments that allow
404
- // wrapping. It would be ideal to unify.
405
- const lines: StyledText[][] = [];
406
- let currentLine: StyledText[] = [];
407
- nonWrappingContent.forEach((segment) => {
408
- const textLines = segment.text.split('\n');
409
- textLines.forEach((text, index) => {
410
- if (index > 0) {
411
- lines.push(currentLine);
412
- currentLine = [];
413
- }
414
- if (text) {
415
- currentLine.push({ text, props: segment.props });
416
- }
417
- });
418
- });
419
- if (
420
- currentLine.length > 0 ||
421
- (nonWrappingContent.length > 0 &&
422
- nonWrappingContent[nonWrappingContent.length - 1].text.endsWith('\n'))
423
- ) {
424
- lines.push(currentLine);
425
- }
426
- for (const line of lines) {
427
- output.push(line);
428
- }
429
- return;
430
- }
431
-
432
- const availableWidth = maxWidth - noWrappingWidth;
433
-
434
- if (availableWidth < 1) {
435
- // No room to render the wrapping segments. Truncate the non-wrapping
436
- // content and append an ellipsis so the line always fits within maxWidth.
437
-
438
- // Handle line breaks in non-wrapping content when truncating
439
- const lines: StyledText[][] = [];
440
- let currentLine: StyledText[] = [];
441
- let currentLineWidth = 0;
442
-
443
- for (const segment of nonWrappingContent) {
444
- const textLines = segment.text.split('\n');
445
- textLines.forEach((text, index) => {
446
- if (index > 0) {
447
- // New line encountered, finish current line and start new one
448
- lines.push(currentLine);
449
- currentLine = [];
450
- currentLineWidth = 0;
451
- }
452
-
453
- if (text) {
454
- const textWidth = stringWidth(text);
455
-
456
- // When there's no room for wrapping content, be very conservative
457
- // For lines after the first line break, show only ellipsis if the text would be truncated
458
- if (index > 0 && textWidth > 0) {
459
- // This is content after a line break - just show ellipsis to indicate truncation
460
- currentLine.push({ text: '…', props: {} });
461
- currentLineWidth = stringWidth('…');
462
- } else {
463
- // This is the first line or a continuation, try to fit what we can
464
- const maxContentWidth = Math.max(0, maxWidth - stringWidth('…'));
465
-
466
- if (textWidth <= maxContentWidth && currentLineWidth === 0) {
467
- // Text fits completely on this line
468
- currentLine.push({ text, props: segment.props });
469
- currentLineWidth += textWidth;
470
- } else {
471
- // Text needs truncation
472
- const codePoints = toCodePoints(text);
473
- let truncatedWidth = currentLineWidth;
474
- let sliceEndIndex = 0;
475
-
476
- for (const char of codePoints) {
477
- const charWidth = stringWidth(char);
478
- if (truncatedWidth + charWidth > maxContentWidth) {
479
- break;
480
- }
481
- truncatedWidth += charWidth;
482
- sliceEndIndex++;
483
- }
484
-
485
- const slice = codePoints.slice(0, sliceEndIndex).join('');
486
- if (slice) {
487
- currentLine.push({ text: slice, props: segment.props });
488
- }
489
- currentLine.push({ text: '…', props: {} });
490
- currentLineWidth = truncatedWidth + stringWidth('…');
491
- }
492
- }
493
- }
494
- });
495
- }
496
-
497
- // Add the last line if it has content or if the last segment ended with \n
498
- if (
499
- currentLine.length > 0 ||
500
- (nonWrappingContent.length > 0 &&
501
- nonWrappingContent[nonWrappingContent.length - 1].text.endsWith('\n'))
502
- ) {
503
- lines.push(currentLine);
504
- }
505
-
506
- // If we don't have any lines yet, add an ellipsis line
507
- if (lines.length === 0) {
508
- lines.push([{ text: '…', props: {} }]);
509
- }
510
-
511
- for (const line of lines) {
512
- output.push(line);
513
- }
514
- return;
515
- }
516
-
517
- // Now, lay out the wrapping segments
518
- let wrappingPart: StyledText[] = [];
519
- let wrappingPartWidth = 0;
520
-
521
- function addWrappingPartToLines() {
522
- if (lines.length === 0) {
523
- lines.push([...nonWrappingContent, ...wrappingPart]);
524
- } else {
525
- if (noWrappingWidth > 0) {
526
- lines.push([
527
- ...[{ text: ' '.repeat(noWrappingWidth), props: {} }],
528
- ...wrappingPart,
529
- ]);
530
- } else {
531
- lines.push(wrappingPart);
532
- }
533
- }
534
- wrappingPart = [];
535
- wrappingPartWidth = 0;
536
- }
537
-
538
- function addToWrappingPart(text: string, props: Record<string, unknown>) {
539
- if (
540
- wrappingPart.length > 0 &&
541
- wrappingPart[wrappingPart.length - 1].props === props
542
- ) {
543
- wrappingPart[wrappingPart.length - 1].text += text;
544
- } else {
545
- wrappingPart.push({ text, props });
546
- }
547
- }
548
-
549
- row.segments.forEach((segment) => {
550
- const linesFromSegment = segment.text.split('\n');
551
-
552
- linesFromSegment.forEach((lineText, lineIndex) => {
553
- if (lineIndex > 0) {
554
- addWrappingPartToLines();
555
- }
556
-
557
- const words = lineText.split(/(\s+)/); // Split by whitespace
558
-
559
- words.forEach((word) => {
560
- if (!word) return;
561
- const wordWidth = stringWidth(word);
562
-
563
- if (
564
- wrappingPartWidth + wordWidth > availableWidth &&
565
- wrappingPartWidth > 0
566
- ) {
567
- addWrappingPartToLines();
568
- if (/^\s+$/.test(word)) {
569
- return;
570
- }
571
- }
572
-
573
- if (wordWidth > availableWidth) {
574
- // Word is too long, needs to be split across lines
575
- const wordAsCodePoints = toCodePoints(word);
576
- let remainingWordAsCodePoints = wordAsCodePoints;
577
- while (remainingWordAsCodePoints.length > 0) {
578
- let splitIndex = 0;
579
- let currentSplitWidth = 0;
580
- for (const char of remainingWordAsCodePoints) {
581
- const charWidth = stringWidth(char);
582
- if (
583
- wrappingPartWidth + currentSplitWidth + charWidth >
584
- availableWidth
585
- ) {
586
- break;
587
- }
588
- currentSplitWidth += charWidth;
589
- splitIndex++;
590
- }
591
-
592
- if (splitIndex > 0) {
593
- const part = remainingWordAsCodePoints
594
- .slice(0, splitIndex)
595
- .join('');
596
- addToWrappingPart(part, segment.props);
597
- wrappingPartWidth += stringWidth(part);
598
- remainingWordAsCodePoints =
599
- remainingWordAsCodePoints.slice(splitIndex);
600
- }
601
-
602
- if (remainingWordAsCodePoints.length > 0) {
603
- addWrappingPartToLines();
604
- }
605
- }
606
- } else {
607
- addToWrappingPart(word, segment.props);
608
- wrappingPartWidth += wordWidth;
609
- }
610
- });
611
- });
612
- // Split omits a trailing newline, so we need to handle it here
613
- if (segment.text.endsWith('\n')) {
614
- addWrappingPartToLines();
615
- }
616
- });
617
-
618
- if (wrappingPart.length > 0) {
619
- addWrappingPartToLines();
620
- }
621
- for (const line of lines) {
622
- output.push(line);
623
- }
624
- }