@gguf/coder 0.3.1 → 0.3.3

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 (413) hide show
  1. package/package.json +5 -2
  2. package/.editorconfig +0 -16
  3. package/.env.example +0 -63
  4. package/.gitattributes +0 -1
  5. package/.semgrepignore +0 -19
  6. package/coder-dummy-file.ts +0 -52
  7. package/coder.config.example.json +0 -59
  8. package/coder.config.json +0 -13
  9. package/color_picker.html +0 -36
  10. package/scripts/extract-changelog.js +0 -73
  11. package/scripts/fetch-models.js +0 -143
  12. package/scripts/test.sh +0 -40
  13. package/scripts/update-homebrew-formula.sh +0 -125
  14. package/scripts/update-nix-version.sh +0 -157
  15. package/source/ai-sdk-client/AISDKClient.spec.ts +0 -117
  16. package/source/ai-sdk-client/AISDKClient.ts +0 -155
  17. package/source/ai-sdk-client/chat/chat-handler.spec.ts +0 -121
  18. package/source/ai-sdk-client/chat/chat-handler.ts +0 -276
  19. package/source/ai-sdk-client/chat/streaming-handler.spec.ts +0 -173
  20. package/source/ai-sdk-client/chat/streaming-handler.ts +0 -110
  21. package/source/ai-sdk-client/chat/tool-processor.spec.ts +0 -92
  22. package/source/ai-sdk-client/chat/tool-processor.ts +0 -70
  23. package/source/ai-sdk-client/converters/message-converter.spec.ts +0 -220
  24. package/source/ai-sdk-client/converters/message-converter.ts +0 -113
  25. package/source/ai-sdk-client/converters/tool-converter.spec.ts +0 -90
  26. package/source/ai-sdk-client/converters/tool-converter.ts +0 -46
  27. package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +0 -55
  28. package/source/ai-sdk-client/error-handling/error-extractor.ts +0 -15
  29. package/source/ai-sdk-client/error-handling/error-parser.spec.ts +0 -169
  30. package/source/ai-sdk-client/error-handling/error-parser.ts +0 -161
  31. package/source/ai-sdk-client/index.ts +0 -7
  32. package/source/ai-sdk-client/providers/provider-factory.spec.ts +0 -71
  33. package/source/ai-sdk-client/providers/provider-factory.ts +0 -41
  34. package/source/ai-sdk-client/types.ts +0 -9
  35. package/source/ai-sdk-client-empty-message.spec.ts +0 -141
  36. package/source/ai-sdk-client-error-handling.spec.ts +0 -186
  37. package/source/ai-sdk-client-maxretries.spec.ts +0 -114
  38. package/source/ai-sdk-client-preparestep.spec.ts +0 -279
  39. package/source/app/App.spec.tsx +0 -32
  40. package/source/app/App.tsx +0 -480
  41. package/source/app/components/AppContainer.spec.tsx +0 -96
  42. package/source/app/components/AppContainer.tsx +0 -56
  43. package/source/app/components/ChatInterface.spec.tsx +0 -163
  44. package/source/app/components/ChatInterface.tsx +0 -144
  45. package/source/app/components/ModalSelectors.spec.tsx +0 -141
  46. package/source/app/components/ModalSelectors.tsx +0 -135
  47. package/source/app/helpers.spec.ts +0 -97
  48. package/source/app/helpers.ts +0 -63
  49. package/source/app/index.ts +0 -4
  50. package/source/app/types.ts +0 -39
  51. package/source/app/utils/appUtils.ts +0 -294
  52. package/source/app/utils/conversationState.ts +0 -310
  53. package/source/app.spec.tsx +0 -244
  54. package/source/cli.spec.ts +0 -73
  55. package/source/cli.tsx +0 -51
  56. package/source/client-factory.spec.ts +0 -48
  57. package/source/client-factory.ts +0 -178
  58. package/source/command-parser.spec.ts +0 -127
  59. package/source/command-parser.ts +0 -36
  60. package/source/commands/checkpoint.spec.tsx +0 -277
  61. package/source/commands/checkpoint.tsx +0 -366
  62. package/source/commands/clear.tsx +0 -22
  63. package/source/commands/custom-commands.tsx +0 -121
  64. package/source/commands/exit.ts +0 -21
  65. package/source/commands/export.spec.tsx +0 -131
  66. package/source/commands/export.tsx +0 -79
  67. package/source/commands/help.tsx +0 -120
  68. package/source/commands/index.ts +0 -17
  69. package/source/commands/init.tsx +0 -339
  70. package/source/commands/lsp-command.spec.tsx +0 -281
  71. package/source/commands/lsp.tsx +0 -120
  72. package/source/commands/mcp-command.spec.tsx +0 -313
  73. package/source/commands/mcp.tsx +0 -162
  74. package/source/commands/model-database.spec.tsx +0 -758
  75. package/source/commands/model-database.tsx +0 -418
  76. package/source/commands/model.ts +0 -12
  77. package/source/commands/provider.ts +0 -12
  78. package/source/commands/setup-config.tsx +0 -16
  79. package/source/commands/simple-commands.spec.tsx +0 -175
  80. package/source/commands/status.ts +0 -12
  81. package/source/commands/theme.ts +0 -12
  82. package/source/commands/update.spec.tsx +0 -261
  83. package/source/commands/update.tsx +0 -201
  84. package/source/commands/usage.spec.tsx +0 -495
  85. package/source/commands/usage.tsx +0 -100
  86. package/source/commands.spec.ts +0 -436
  87. package/source/commands.ts +0 -83
  88. package/source/components/assistant-message.spec.tsx +0 -796
  89. package/source/components/assistant-message.tsx +0 -34
  90. package/source/components/bash-execution-indicator.tsx +0 -21
  91. package/source/components/cancelling-indicator.tsx +0 -16
  92. package/source/components/chat-queue.spec.tsx +0 -83
  93. package/source/components/chat-queue.tsx +0 -36
  94. package/source/components/checkpoint-display.spec.tsx +0 -219
  95. package/source/components/checkpoint-display.tsx +0 -126
  96. package/source/components/checkpoint-selector.spec.tsx +0 -173
  97. package/source/components/checkpoint-selector.tsx +0 -173
  98. package/source/components/development-mode-indicator.spec.tsx +0 -268
  99. package/source/components/development-mode-indicator.tsx +0 -38
  100. package/source/components/message-box.spec.tsx +0 -427
  101. package/source/components/message-box.tsx +0 -87
  102. package/source/components/model-selector.tsx +0 -132
  103. package/source/components/provider-selector.tsx +0 -75
  104. package/source/components/random-spinner.tsx +0 -19
  105. package/source/components/security-disclaimer.tsx +0 -73
  106. package/source/components/status-connection-display.spec.tsx +0 -133
  107. package/source/components/status.tsx +0 -267
  108. package/source/components/theme-selector.tsx +0 -126
  109. package/source/components/tool-confirmation.tsx +0 -190
  110. package/source/components/tool-execution-indicator.tsx +0 -33
  111. package/source/components/tool-message.tsx +0 -85
  112. package/source/components/ui/titled-box.spec.tsx +0 -207
  113. package/source/components/ui/titled-box.tsx +0 -57
  114. package/source/components/usage/progress-bar.spec.tsx +0 -398
  115. package/source/components/usage/progress-bar.tsx +0 -30
  116. package/source/components/usage/usage-display.spec.tsx +0 -780
  117. package/source/components/usage/usage-display.tsx +0 -291
  118. package/source/components/user-input.spec.tsx +0 -327
  119. package/source/components/user-input.tsx +0 -533
  120. package/source/components/user-message.spec.tsx +0 -230
  121. package/source/components/user-message.tsx +0 -84
  122. package/source/components/welcome-message.tsx +0 -76
  123. package/source/config/env-substitution.ts +0 -65
  124. package/source/config/index.spec.ts +0 -171
  125. package/source/config/index.ts +0 -154
  126. package/source/config/paths.spec.ts +0 -241
  127. package/source/config/paths.ts +0 -55
  128. package/source/config/preferences.ts +0 -51
  129. package/source/config/themes.ts +0 -315
  130. package/source/constants.ts +0 -130
  131. package/source/context/mode-context.spec.ts +0 -79
  132. package/source/context/mode-context.ts +0 -24
  133. package/source/custom-commands/executor.spec.ts +0 -142
  134. package/source/custom-commands/executor.ts +0 -64
  135. package/source/custom-commands/loader.spec.ts +0 -314
  136. package/source/custom-commands/loader.ts +0 -153
  137. package/source/custom-commands/parser.ts +0 -196
  138. package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +0 -39
  139. package/source/hooks/chat-handler/conversation/conversation-loop.tsx +0 -511
  140. package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +0 -50
  141. package/source/hooks/chat-handler/conversation/tool-executor.tsx +0 -109
  142. package/source/hooks/chat-handler/index.ts +0 -12
  143. package/source/hooks/chat-handler/state/streaming-state.spec.ts +0 -26
  144. package/source/hooks/chat-handler/state/streaming-state.ts +0 -19
  145. package/source/hooks/chat-handler/types.ts +0 -38
  146. package/source/hooks/chat-handler/useChatHandler.spec.tsx +0 -321
  147. package/source/hooks/chat-handler/useChatHandler.tsx +0 -194
  148. package/source/hooks/chat-handler/utils/context-checker.spec.ts +0 -60
  149. package/source/hooks/chat-handler/utils/context-checker.tsx +0 -73
  150. package/source/hooks/chat-handler/utils/message-helpers.spec.ts +0 -42
  151. package/source/hooks/chat-handler/utils/message-helpers.tsx +0 -36
  152. package/source/hooks/chat-handler/utils/tool-filters.spec.ts +0 -109
  153. package/source/hooks/chat-handler/utils/tool-filters.ts +0 -64
  154. package/source/hooks/useAppHandlers.tsx +0 -291
  155. package/source/hooks/useAppInitialization.tsx +0 -422
  156. package/source/hooks/useAppState.tsx +0 -311
  157. package/source/hooks/useDirectoryTrust.tsx +0 -98
  158. package/source/hooks/useInputState.ts +0 -414
  159. package/source/hooks/useModeHandlers.tsx +0 -302
  160. package/source/hooks/useNonInteractiveMode.ts +0 -140
  161. package/source/hooks/useTerminalWidth.tsx +0 -81
  162. package/source/hooks/useTheme.ts +0 -18
  163. package/source/hooks/useToolHandler.tsx +0 -349
  164. package/source/hooks/useUIState.ts +0 -61
  165. package/source/init/agents-template-generator.ts +0 -421
  166. package/source/init/existing-rules-extractor.ts +0 -319
  167. package/source/init/file-scanner.spec.ts +0 -227
  168. package/source/init/file-scanner.ts +0 -238
  169. package/source/init/framework-detector.ts +0 -382
  170. package/source/init/language-detector.ts +0 -269
  171. package/source/init/project-analyzer.spec.ts +0 -231
  172. package/source/init/project-analyzer.ts +0 -458
  173. package/source/lsp/index.ts +0 -31
  174. package/source/lsp/lsp-client.spec.ts +0 -508
  175. package/source/lsp/lsp-client.ts +0 -487
  176. package/source/lsp/lsp-manager.spec.ts +0 -477
  177. package/source/lsp/lsp-manager.ts +0 -419
  178. package/source/lsp/protocol.spec.ts +0 -502
  179. package/source/lsp/protocol.ts +0 -360
  180. package/source/lsp/server-discovery.spec.ts +0 -654
  181. package/source/lsp/server-discovery.ts +0 -515
  182. package/source/markdown-parser/html-entities.spec.ts +0 -88
  183. package/source/markdown-parser/html-entities.ts +0 -45
  184. package/source/markdown-parser/index.spec.ts +0 -281
  185. package/source/markdown-parser/index.ts +0 -126
  186. package/source/markdown-parser/table-parser.spec.ts +0 -133
  187. package/source/markdown-parser/table-parser.ts +0 -114
  188. package/source/markdown-parser/utils.spec.ts +0 -70
  189. package/source/markdown-parser/utils.ts +0 -13
  190. package/source/mcp/mcp-client.spec.ts +0 -81
  191. package/source/mcp/mcp-client.ts +0 -625
  192. package/source/mcp/transport-factory.spec.ts +0 -406
  193. package/source/mcp/transport-factory.ts +0 -312
  194. package/source/message-handler.ts +0 -67
  195. package/source/model-database/database-engine.spec.ts +0 -494
  196. package/source/model-database/database-engine.ts +0 -50
  197. package/source/model-database/model-database.spec.ts +0 -363
  198. package/source/model-database/model-database.ts +0 -91
  199. package/source/model-database/model-engine.spec.ts +0 -447
  200. package/source/model-database/model-engine.ts +0 -65
  201. package/source/model-database/model-fetcher.spec.ts +0 -583
  202. package/source/model-database/model-fetcher.ts +0 -330
  203. package/source/models/index.ts +0 -1
  204. package/source/models/models-cache.spec.ts +0 -214
  205. package/source/models/models-cache.ts +0 -78
  206. package/source/models/models-dev-client.spec.ts +0 -379
  207. package/source/models/models-dev-client.ts +0 -329
  208. package/source/models/models-types.ts +0 -68
  209. package/source/prompt-history.ts +0 -155
  210. package/source/security/command-injection.spec.ts +0 -240
  211. package/source/services/checkpoint-manager.spec.ts +0 -523
  212. package/source/services/checkpoint-manager.ts +0 -466
  213. package/source/services/file-snapshot.spec.ts +0 -569
  214. package/source/services/file-snapshot.ts +0 -220
  215. package/source/test-utils/render-with-theme.tsx +0 -48
  216. package/source/tokenization/index.ts +0 -1
  217. package/source/tokenization/tokenizer-factory.spec.ts +0 -170
  218. package/source/tokenization/tokenizer-factory.ts +0 -125
  219. package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +0 -200
  220. package/source/tokenization/tokenizers/anthropic-tokenizer.ts +0 -43
  221. package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +0 -236
  222. package/source/tokenization/tokenizers/fallback-tokenizer.ts +0 -26
  223. package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +0 -224
  224. package/source/tokenization/tokenizers/llama-tokenizer.ts +0 -41
  225. package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +0 -184
  226. package/source/tokenization/tokenizers/openai-tokenizer.ts +0 -57
  227. package/source/tool-calling/index.ts +0 -5
  228. package/source/tool-calling/json-parser.spec.ts +0 -639
  229. package/source/tool-calling/json-parser.ts +0 -247
  230. package/source/tool-calling/tool-parser.spec.ts +0 -395
  231. package/source/tool-calling/tool-parser.ts +0 -120
  232. package/source/tool-calling/xml-parser.spec.ts +0 -662
  233. package/source/tool-calling/xml-parser.ts +0 -289
  234. package/source/tools/execute-bash.spec.tsx +0 -353
  235. package/source/tools/execute-bash.tsx +0 -219
  236. package/source/tools/execute-function.spec.ts +0 -130
  237. package/source/tools/fetch-url.spec.tsx +0 -342
  238. package/source/tools/fetch-url.tsx +0 -172
  239. package/source/tools/find-files.spec.tsx +0 -924
  240. package/source/tools/find-files.tsx +0 -293
  241. package/source/tools/index.ts +0 -102
  242. package/source/tools/lsp-get-diagnostics.tsx +0 -192
  243. package/source/tools/needs-approval.spec.ts +0 -282
  244. package/source/tools/read-file.spec.tsx +0 -801
  245. package/source/tools/read-file.tsx +0 -387
  246. package/source/tools/search-file-contents.spec.tsx +0 -1273
  247. package/source/tools/search-file-contents.tsx +0 -293
  248. package/source/tools/string-replace.spec.tsx +0 -730
  249. package/source/tools/string-replace.tsx +0 -548
  250. package/source/tools/tool-manager.ts +0 -210
  251. package/source/tools/tool-registry.spec.ts +0 -415
  252. package/source/tools/tool-registry.ts +0 -228
  253. package/source/tools/web-search.tsx +0 -223
  254. package/source/tools/write-file.spec.tsx +0 -559
  255. package/source/tools/write-file.tsx +0 -228
  256. package/source/types/app.ts +0 -37
  257. package/source/types/checkpoint.ts +0 -48
  258. package/source/types/commands.ts +0 -46
  259. package/source/types/components.ts +0 -27
  260. package/source/types/config.ts +0 -103
  261. package/source/types/core-connection-status.spec.ts +0 -67
  262. package/source/types/core.ts +0 -181
  263. package/source/types/hooks.ts +0 -50
  264. package/source/types/index.ts +0 -12
  265. package/source/types/markdown-parser.ts +0 -11
  266. package/source/types/mcp.ts +0 -52
  267. package/source/types/system.ts +0 -16
  268. package/source/types/tokenization.ts +0 -41
  269. package/source/types/ui.ts +0 -40
  270. package/source/types/usage.ts +0 -58
  271. package/source/types/utils.ts +0 -16
  272. package/source/usage/calculator.spec.ts +0 -385
  273. package/source/usage/calculator.ts +0 -104
  274. package/source/usage/storage.spec.ts +0 -703
  275. package/source/usage/storage.ts +0 -238
  276. package/source/usage/tracker.spec.ts +0 -456
  277. package/source/usage/tracker.ts +0 -102
  278. package/source/utils/atomic-deletion.spec.ts +0 -194
  279. package/source/utils/atomic-deletion.ts +0 -127
  280. package/source/utils/bounded-map.spec.ts +0 -300
  281. package/source/utils/bounded-map.ts +0 -193
  282. package/source/utils/checkpoint-utils.spec.ts +0 -222
  283. package/source/utils/checkpoint-utils.ts +0 -92
  284. package/source/utils/error-formatter.spec.ts +0 -169
  285. package/source/utils/error-formatter.ts +0 -194
  286. package/source/utils/file-autocomplete.spec.ts +0 -173
  287. package/source/utils/file-autocomplete.ts +0 -196
  288. package/source/utils/file-cache.spec.ts +0 -309
  289. package/source/utils/file-cache.ts +0 -195
  290. package/source/utils/file-content-loader.spec.ts +0 -180
  291. package/source/utils/file-content-loader.ts +0 -179
  292. package/source/utils/file-mention-handler.spec.ts +0 -261
  293. package/source/utils/file-mention-handler.ts +0 -84
  294. package/source/utils/file-mention-parser.spec.ts +0 -182
  295. package/source/utils/file-mention-parser.ts +0 -170
  296. package/source/utils/fuzzy-matching.spec.ts +0 -149
  297. package/source/utils/fuzzy-matching.ts +0 -146
  298. package/source/utils/indentation-normalizer.spec.ts +0 -216
  299. package/source/utils/indentation-normalizer.ts +0 -76
  300. package/source/utils/installation-detector.spec.ts +0 -178
  301. package/source/utils/installation-detector.ts +0 -153
  302. package/source/utils/logging/config.spec.ts +0 -311
  303. package/source/utils/logging/config.ts +0 -210
  304. package/source/utils/logging/console-facade.spec.ts +0 -184
  305. package/source/utils/logging/console-facade.ts +0 -384
  306. package/source/utils/logging/correlation.spec.ts +0 -679
  307. package/source/utils/logging/correlation.ts +0 -474
  308. package/source/utils/logging/formatters.spec.ts +0 -464
  309. package/source/utils/logging/formatters.ts +0 -207
  310. package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +0 -93
  311. package/source/utils/logging/health-monitor/alerts/alert-manager.ts +0 -79
  312. package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +0 -56
  313. package/source/utils/logging/health-monitor/checks/configuration-check.ts +0 -43
  314. package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +0 -56
  315. package/source/utils/logging/health-monitor/checks/logging-check.ts +0 -58
  316. package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +0 -100
  317. package/source/utils/logging/health-monitor/checks/memory-check.ts +0 -78
  318. package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +0 -56
  319. package/source/utils/logging/health-monitor/checks/performance-check.ts +0 -56
  320. package/source/utils/logging/health-monitor/checks/request-check.spec.ts +0 -56
  321. package/source/utils/logging/health-monitor/checks/request-check.ts +0 -76
  322. package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +0 -70
  323. package/source/utils/logging/health-monitor/core/health-check-runner.ts +0 -138
  324. package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +0 -58
  325. package/source/utils/logging/health-monitor/core/health-monitor.ts +0 -344
  326. package/source/utils/logging/health-monitor/core/scoring.spec.ts +0 -65
  327. package/source/utils/logging/health-monitor/core/scoring.ts +0 -91
  328. package/source/utils/logging/health-monitor/index.ts +0 -15
  329. package/source/utils/logging/health-monitor/instances.ts +0 -48
  330. package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +0 -141
  331. package/source/utils/logging/health-monitor/middleware/http-middleware.ts +0 -75
  332. package/source/utils/logging/health-monitor/types.ts +0 -126
  333. package/source/utils/logging/index.spec.ts +0 -284
  334. package/source/utils/logging/index.ts +0 -236
  335. package/source/utils/logging/integration.spec.ts +0 -441
  336. package/source/utils/logging/log-method-factory.spec.ts +0 -573
  337. package/source/utils/logging/log-method-factory.ts +0 -233
  338. package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +0 -277
  339. package/source/utils/logging/log-query/aggregation/aggregator.ts +0 -159
  340. package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +0 -159
  341. package/source/utils/logging/log-query/aggregation/facet-generator.ts +0 -47
  342. package/source/utils/logging/log-query/index.ts +0 -23
  343. package/source/utils/logging/log-query/query/filter-predicates.spec.ts +0 -247
  344. package/source/utils/logging/log-query/query/filter-predicates.ts +0 -154
  345. package/source/utils/logging/log-query/query/query-builder.spec.ts +0 -182
  346. package/source/utils/logging/log-query/query/query-builder.ts +0 -151
  347. package/source/utils/logging/log-query/query/query-engine.spec.ts +0 -214
  348. package/source/utils/logging/log-query/query/query-engine.ts +0 -45
  349. package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +0 -143
  350. package/source/utils/logging/log-query/storage/circular-buffer.ts +0 -75
  351. package/source/utils/logging/log-query/storage/index-manager.spec.ts +0 -150
  352. package/source/utils/logging/log-query/storage/index-manager.ts +0 -71
  353. package/source/utils/logging/log-query/storage/log-storage.spec.ts +0 -257
  354. package/source/utils/logging/log-query/storage/log-storage.ts +0 -80
  355. package/source/utils/logging/log-query/types.ts +0 -163
  356. package/source/utils/logging/log-query/utils/helpers.spec.ts +0 -263
  357. package/source/utils/logging/log-query/utils/helpers.ts +0 -72
  358. package/source/utils/logging/log-query/utils/sorting.spec.ts +0 -182
  359. package/source/utils/logging/log-query/utils/sorting.ts +0 -61
  360. package/source/utils/logging/logger-provider.spec.ts +0 -262
  361. package/source/utils/logging/logger-provider.ts +0 -362
  362. package/source/utils/logging/performance.spec.ts +0 -209
  363. package/source/utils/logging/performance.ts +0 -757
  364. package/source/utils/logging/pino-logger.spec.ts +0 -425
  365. package/source/utils/logging/pino-logger.ts +0 -514
  366. package/source/utils/logging/redaction.spec.ts +0 -490
  367. package/source/utils/logging/redaction.ts +0 -267
  368. package/source/utils/logging/request-tracker.spec.ts +0 -1198
  369. package/source/utils/logging/request-tracker.ts +0 -803
  370. package/source/utils/logging/transports.spec.ts +0 -505
  371. package/source/utils/logging/transports.ts +0 -305
  372. package/source/utils/logging/types.ts +0 -216
  373. package/source/utils/message-builder.spec.ts +0 -179
  374. package/source/utils/message-builder.ts +0 -101
  375. package/source/utils/message-queue.tsx +0 -486
  376. package/source/utils/paste-detection.spec.ts +0 -69
  377. package/source/utils/paste-detection.ts +0 -124
  378. package/source/utils/paste-roundtrip.spec.ts +0 -442
  379. package/source/utils/paste-utils.spec.ts +0 -128
  380. package/source/utils/paste-utils.ts +0 -52
  381. package/source/utils/programming-language-helper.spec.ts +0 -74
  382. package/source/utils/programming-language-helper.ts +0 -32
  383. package/source/utils/prompt-assembly.spec.ts +0 -221
  384. package/source/utils/prompt-processor.ts +0 -173
  385. package/source/utils/tool-args-parser.spec.ts +0 -136
  386. package/source/utils/tool-args-parser.ts +0 -54
  387. package/source/utils/tool-cancellation.spec.ts +0 -230
  388. package/source/utils/tool-cancellation.ts +0 -28
  389. package/source/utils/tool-result-display.spec.tsx +0 -469
  390. package/source/utils/tool-result-display.tsx +0 -90
  391. package/source/utils/update-checker.spec.ts +0 -383
  392. package/source/utils/update-checker.ts +0 -183
  393. package/source/wizard/config-wizard.spec.tsx +0 -103
  394. package/source/wizard/config-wizard.tsx +0 -382
  395. package/source/wizard/steps/location-step.spec.tsx +0 -186
  396. package/source/wizard/steps/location-step.tsx +0 -147
  397. package/source/wizard/steps/mcp-step.spec.tsx +0 -607
  398. package/source/wizard/steps/mcp-step.tsx +0 -632
  399. package/source/wizard/steps/provider-step.spec.tsx +0 -342
  400. package/source/wizard/steps/provider-step.tsx +0 -957
  401. package/source/wizard/steps/summary-step.spec.tsx +0 -749
  402. package/source/wizard/steps/summary-step.tsx +0 -228
  403. package/source/wizard/templates/mcp-templates.spec.ts +0 -613
  404. package/source/wizard/templates/mcp-templates.ts +0 -570
  405. package/source/wizard/templates/provider-templates.spec.ts +0 -152
  406. package/source/wizard/templates/provider-templates.ts +0 -485
  407. package/source/wizard/utils/fetch-cloud-models.spec.ts +0 -428
  408. package/source/wizard/utils/fetch-cloud-models.ts +0 -223
  409. package/source/wizard/utils/fetch-local-models.spec.ts +0 -297
  410. package/source/wizard/utils/fetch-local-models.ts +0 -192
  411. package/source/wizard/validation-array.spec.ts +0 -264
  412. package/source/wizard/validation.spec.ts +0 -373
  413. package/source/wizard/validation.ts +0 -232
@@ -1,169 +0,0 @@
1
- import test from 'ava';
2
- import {APICallError} from 'ai';
3
- import {parseAPIError} from './error-parser.js';
4
-
5
- test('parseAPIError handles non-Error values', t => {
6
- const result = parseAPIError('not an error');
7
- t.is(result, 'An unknown error occurred while communicating with the model');
8
- });
9
-
10
- test('parseAPIError handles APICallError with 400 status', t => {
11
- const error = new APICallError({
12
- message: 'Invalid request',
13
- url: 'https://api.example.com',
14
- requestBodyValues: {},
15
- statusCode: 400,
16
- responseBody: JSON.stringify({error: {message: 'Bad input'}}),
17
- responseHeaders: {},
18
- isRetryable: false,
19
- });
20
-
21
- const result = parseAPIError(error);
22
- t.is(result, 'Bad request: Bad input');
23
- });
24
-
25
- test('parseAPIError handles APICallError with 401 status', t => {
26
- const error = new APICallError({
27
- message: 'Unauthorized',
28
- url: 'https://api.example.com',
29
- requestBodyValues: {},
30
- statusCode: 401,
31
- responseBody: '{}',
32
- responseHeaders: {},
33
- isRetryable: false,
34
- });
35
-
36
- const result = parseAPIError(error);
37
- t.is(result, 'Authentication failed: Invalid API key or credentials');
38
- });
39
-
40
- test('parseAPIError handles APICallError with 404 status', t => {
41
- const error = new APICallError({
42
- message: 'Not found',
43
- url: 'https://api.example.com',
44
- requestBodyValues: {},
45
- statusCode: 404,
46
- responseBody: '{}',
47
- responseHeaders: {},
48
- isRetryable: false,
49
- });
50
-
51
- const result = parseAPIError(error);
52
- t.is(
53
- result,
54
- 'Model not found: The requested model may not exist or is unavailable',
55
- );
56
- });
57
-
58
- test('parseAPIError handles APICallError with 429 status and quota message', t => {
59
- const error = new APICallError({
60
- message: 'Rate limited',
61
- url: 'https://api.example.com',
62
- requestBodyValues: {},
63
- statusCode: 429,
64
- responseBody: JSON.stringify({
65
- error: {message: 'You have exceeded your usage limit'},
66
- }),
67
- responseHeaders: {},
68
- isRetryable: true,
69
- });
70
-
71
- const result = parseAPIError(error);
72
- t.is(result, 'Rate limit: You have exceeded your usage limit');
73
- });
74
-
75
- test('parseAPIError handles APICallError with 429 status without quota message', t => {
76
- const error = new APICallError({
77
- message: 'Rate limited',
78
- url: 'https://api.example.com',
79
- requestBodyValues: {},
80
- statusCode: 429,
81
- responseBody: '{}',
82
- responseHeaders: {},
83
- isRetryable: true,
84
- });
85
-
86
- const result = parseAPIError(error);
87
- t.is(
88
- result,
89
- 'Rate limit exceeded: Too many requests. Please wait and try again',
90
- );
91
- });
92
-
93
- test('parseAPIError handles APICallError with 500 status', t => {
94
- const error = new APICallError({
95
- message: 'Server error',
96
- url: 'https://api.example.com',
97
- requestBodyValues: {},
98
- statusCode: 500,
99
- responseBody: JSON.stringify({message: 'Internal server error'}),
100
- responseHeaders: {},
101
- isRetryable: true,
102
- });
103
-
104
- const result = parseAPIError(error);
105
- t.is(result, 'Server error: Internal server error');
106
- });
107
-
108
- test('parseAPIError handles Error with status code in message', t => {
109
- const error = new Error('400 Bad Request: Invalid parameters');
110
- const result = parseAPIError(error);
111
- t.is(result, 'Bad request: Invalid parameters');
112
- });
113
-
114
- test('parseAPIError handles Ollama unmarshal errors', t => {
115
- const error = new Error(
116
- 'invalid character after top-level value: unmarshal error',
117
- );
118
- const result = parseAPIError(error);
119
- t.true(result.includes('Ollama server error'));
120
- t.true(result.includes('malformed JSON'));
121
- });
122
-
123
- test('parseAPIError handles timeout errors', t => {
124
- const error = new Error('Request timeout: ETIMEDOUT');
125
- const result = parseAPIError(error);
126
- t.is(result, 'Request timed out: The model took too long to respond');
127
- });
128
-
129
- test('parseAPIError handles connection errors', t => {
130
- const error = new Error('ECONNREFUSED: connection refused');
131
- const result = parseAPIError(error);
132
- t.is(result, 'Connection failed: Unable to reach the model server');
133
- });
134
-
135
- test('parseAPIError handles context length errors', t => {
136
- const error = new Error('context length exceeded');
137
- const result = parseAPIError(error);
138
- t.is(
139
- result,
140
- 'Context too large: Please reduce the conversation length or message size',
141
- );
142
- });
143
-
144
- test('parseAPIError handles token limit errors', t => {
145
- const error = new Error('Please reduce the number of tokens in your message');
146
- const result = parseAPIError(error);
147
- t.is(
148
- result,
149
- 'Too many tokens: Please shorten your message or clear conversation history',
150
- );
151
- });
152
-
153
- test('parseAPIError handles generic errors', t => {
154
- const error = new Error('Something went wrong');
155
- const result = parseAPIError(error);
156
- t.is(result, 'Something went wrong');
157
- });
158
-
159
- test('parseAPIError removes "Error:" prefix from generic errors', t => {
160
- const error = new Error('Error: Something went wrong');
161
- const result = parseAPIError(error);
162
- t.is(result, 'Something went wrong');
163
- });
164
-
165
- test('parseAPIError extracts first line from multiline errors', t => {
166
- const error = new Error('First line\nSecond line\nThird line');
167
- const result = parseAPIError(error);
168
- t.is(result, 'First line');
169
- });
@@ -1,161 +0,0 @@
1
- import {APICallError} from 'ai';
2
- import {extractRootError} from './error-extractor.js';
3
-
4
- /**
5
- * Parses API errors into user-friendly messages.
6
- * Exported for testing purposes.
7
- */
8
- export function parseAPIError(error: unknown): string {
9
- // First extract the root error from any wrappers
10
- const rootError = extractRootError(error);
11
-
12
- if (!(rootError instanceof Error)) {
13
- return 'An unknown error occurred while communicating with the model';
14
- }
15
-
16
- // Handle AI SDK APICallError - it has statusCode and responseBody
17
- if (APICallError.isInstance(rootError)) {
18
- const statusCode = rootError.statusCode;
19
- // Try to extract a clean message from responseBody or use the error message
20
- let cleanMessage = rootError.message;
21
-
22
- // Parse the response body if available for more details
23
- if (rootError.responseBody) {
24
- try {
25
- const body = JSON.parse(rootError.responseBody) as {
26
- error?: {message?: string};
27
- message?: string;
28
- };
29
- if (body.error?.message) {
30
- cleanMessage = body.error.message;
31
- } else if (body.message) {
32
- cleanMessage = body.message;
33
- }
34
- } catch {
35
- // If not JSON, try to extract message from the raw response
36
- const msgMatch = rootError.responseBody.match(
37
- /["']?message["']?\s*[:=]\s*["']([^"']+)["']/i,
38
- );
39
- if (msgMatch) {
40
- cleanMessage = msgMatch[1];
41
- }
42
- }
43
- }
44
-
45
- // Format based on status code
46
- if (statusCode) {
47
- switch (statusCode) {
48
- case 400:
49
- return `Bad request: ${cleanMessage}`;
50
- case 401:
51
- return 'Authentication failed: Invalid API key or credentials';
52
- case 403:
53
- return 'Access forbidden: Check your API permissions';
54
- case 404:
55
- return 'Model not found: The requested model may not exist or is unavailable';
56
- case 429:
57
- if (
58
- cleanMessage.includes('usage limit') ||
59
- cleanMessage.includes('quota')
60
- ) {
61
- return `Rate limit: ${cleanMessage}`;
62
- }
63
- return 'Rate limit exceeded: Too many requests. Please wait and try again';
64
- case 500:
65
- case 502:
66
- case 503:
67
- return `Server error: ${cleanMessage}`;
68
- default:
69
- return `Request failed (${statusCode}): ${cleanMessage}`;
70
- }
71
- }
72
- }
73
-
74
- const errorMessage = rootError.message;
75
-
76
- // Extract status code and clean message from common error patterns FIRST
77
- // This ensures HTTP status codes are properly parsed before falling through
78
- // to more generic pattern matching (like Ollama-specific errors)
79
- const statusMatch = errorMessage.match(
80
- /(?:Error: )?(\d{3})\s+(?:\d{3}\s+)?(?:Bad Request|[^:]+):\s*(.+)/i,
81
- );
82
- if (statusMatch) {
83
- const [, statusCode, message] = statusMatch;
84
- const cleanMessage = message.trim();
85
-
86
- switch (statusCode) {
87
- case '400':
88
- return `Bad request: ${cleanMessage}`;
89
- case '401':
90
- return 'Authentication failed: Invalid API key or credentials';
91
- case '403':
92
- return 'Access forbidden: Check your API permissions';
93
- case '404':
94
- return 'Model not found: The requested model may not exist or is unavailable';
95
- case '429':
96
- // Include the original message if it has useful details
97
- if (
98
- cleanMessage.includes('usage limit') ||
99
- cleanMessage.includes('quota')
100
- ) {
101
- return `Rate limit: ${cleanMessage}`;
102
- }
103
- return 'Rate limit exceeded: Too many requests. Please wait and try again';
104
- case '500':
105
- case '502':
106
- case '503':
107
- return `Server error: ${cleanMessage}`;
108
- default:
109
- return `Request failed (${statusCode}): ${cleanMessage}`;
110
- }
111
- }
112
-
113
- // Handle Ollama-specific unmarshal/JSON parsing errors
114
- // This runs AFTER status code parsing to avoid misclassifying HTTP errors
115
- // that happen to contain JSON parsing error text in their message
116
- if (
117
- errorMessage.includes('unmarshal') ||
118
- (errorMessage.includes('invalid character') &&
119
- errorMessage.includes('after top-level value'))
120
- ) {
121
- return (
122
- 'Ollama server error: The model returned malformed JSON. ' +
123
- 'This usually indicates an issue with the Ollama server or model. ' +
124
- 'Try:\n' +
125
- ' 1. Restart Ollama: systemctl restart ollama (Linux) or restart the Ollama app\n' +
126
- ' 2. Re-pull the model: ollama pull <model-name>\n' +
127
- ' 3. Check Ollama logs for more details\n' +
128
- ' 4. Try a different model to see if the issue is model-specific\n' +
129
- `Original error: ${errorMessage}`
130
- );
131
- }
132
-
133
- // Handle timeout errors
134
- if (errorMessage.includes('timeout') || errorMessage.includes('ETIMEDOUT')) {
135
- return 'Request timed out: The model took too long to respond';
136
- }
137
-
138
- // Handle network errors
139
- if (
140
- errorMessage.includes('ECONNREFUSED') ||
141
- errorMessage.includes('connect')
142
- ) {
143
- return 'Connection failed: Unable to reach the model server';
144
- }
145
-
146
- // Handle context length errors
147
- if (
148
- errorMessage.includes('context length') ||
149
- errorMessage.includes('too many tokens')
150
- ) {
151
- return 'Context too large: Please reduce the conversation length or message size';
152
- }
153
-
154
- // Handle token limit errors
155
- if (errorMessage.includes('reduce the number of tokens')) {
156
- return 'Too many tokens: Please shorten your message or clear conversation history';
157
- }
158
-
159
- // If we can't parse it, return a cleaned up version
160
- return errorMessage.replace(/^Error:\s*/i, '').split('\n')[0];
161
- }
@@ -1,7 +0,0 @@
1
- // Main client export
2
- export {AISDKClient} from './AISDKClient.js';
3
-
4
- // Exported for testing purposes
5
- export {parseAPIError} from './error-handling/error-parser.js';
6
- export {isEmptyAssistantMessage} from './converters/message-converter.js';
7
- export type {TestableMessage} from './types.js';
@@ -1,71 +0,0 @@
1
- import test from 'ava';
2
- import type {AIProviderConfig} from '@/types/index';
3
- import {Agent} from 'undici';
4
- import {createProvider} from './provider-factory.js';
5
-
6
- test('createProvider creates provider with basic config', t => {
7
- const config: AIProviderConfig = {
8
- name: 'TestProvider',
9
- type: 'openai',
10
- models: ['test-model'],
11
- config: {
12
- baseURL: 'https://api.test.com',
13
- apiKey: 'test-key',
14
- },
15
- };
16
-
17
- const agent = new Agent();
18
- const provider = createProvider(config, agent);
19
-
20
- t.truthy(provider);
21
- t.is(typeof provider, 'function');
22
- });
23
-
24
- test('createProvider adds OpenRouter headers for openrouter provider', t => {
25
- const config: AIProviderConfig = {
26
- name: 'OpenRouter',
27
- type: 'openai',
28
- models: ['test-model'],
29
- config: {
30
- baseURL: 'https://openrouter.ai/api/v1',
31
- apiKey: 'test-key',
32
- },
33
- };
34
-
35
- const agent = new Agent();
36
- const provider = createProvider(config, agent);
37
-
38
- t.truthy(provider);
39
- });
40
-
41
- test('createProvider handles provider with no API key', t => {
42
- const config: AIProviderConfig = {
43
- name: 'TestProvider',
44
- type: 'openai',
45
- models: ['test-model'],
46
- config: {
47
- baseURL: 'https://api.test.com',
48
- },
49
- };
50
-
51
- const agent = new Agent();
52
- const provider = createProvider(config, agent);
53
-
54
- t.truthy(provider);
55
- });
56
-
57
- test('createProvider handles provider with no baseURL', t => {
58
- const config: AIProviderConfig = {
59
- name: 'TestProvider',
60
- type: 'openai',
61
- models: ['test-model'],
62
- config: {
63
- apiKey: 'test-key',
64
- },
65
- };
66
-
67
- const agent = new Agent();
68
- const provider = createProvider(config, agent);
69
-
70
- t.truthy(provider);
71
- });
@@ -1,41 +0,0 @@
1
- import type {AIProviderConfig} from '@/types/index';
2
- import {createOpenAICompatible} from '@ai-sdk/openai-compatible';
3
- import {type Agent, fetch as undiciFetch} from 'undici';
4
-
5
- /**
6
- * Creates an OpenAI-compatible provider with custom fetch using undici
7
- */
8
- export function createProvider(
9
- providerConfig: AIProviderConfig,
10
- undiciAgent: Agent,
11
- ): ReturnType<typeof createOpenAICompatible> {
12
- const {config} = providerConfig;
13
-
14
- // Custom fetch using undici
15
- const customFetch = (
16
- url: string | URL | Request,
17
- options?: RequestInit,
18
- ): Promise<Response> => {
19
- // Type cast to string | URL since undici's fetch accepts these types
20
- // Request objects are converted to URL internally by the fetch spec
21
- return undiciFetch(url as string | URL, {
22
- ...options,
23
- dispatcher: undiciAgent,
24
- }) as Promise<Response>;
25
- };
26
-
27
- // Add OpenRouter-specific headers for app attribution
28
- const headers: Record<string, string> = {};
29
- if (providerConfig.name.toLowerCase() === 'openrouter') {
30
- headers['HTTP-Referer'] = 'https://github.com/Nano-Collective/coder';
31
- headers['X-Title'] = 'Coder';
32
- }
33
-
34
- return createOpenAICompatible({
35
- name: providerConfig.name,
36
- baseURL: config.baseURL ?? '',
37
- apiKey: config.apiKey ?? 'dummy-key',
38
- fetch: customFetch,
39
- headers,
40
- });
41
- }
@@ -1,9 +0,0 @@
1
- /**
2
- * Message type used for testing the empty assistant message filter.
3
- * This is a simplified version of the AI SDK's internal message format.
4
- */
5
- export interface TestableMessage {
6
- role: 'system' | 'user' | 'assistant' | 'tool';
7
- content: string | unknown[];
8
- toolCalls?: unknown[];
9
- }
@@ -1,141 +0,0 @@
1
- import test from 'ava';
2
- import {isEmptyAssistantMessage, type TestableMessage} from '@/ai-sdk-client';
3
-
4
- // Tests for isEmptyAssistantMessage function
5
- // This function is used to filter out empty assistant messages that would cause API errors:
6
- // "400 Bad Request: Assistant message must have either content or tool_calls, but not none."
7
-
8
- // ============================================================================
9
- // Non-assistant messages should never be considered empty
10
- // ============================================================================
11
-
12
- test('isEmptyAssistantMessage - user message is not empty', t => {
13
- const message: TestableMessage = {
14
- role: 'user',
15
- content: '',
16
- };
17
- t.false(isEmptyAssistantMessage(message));
18
- });
19
-
20
- test('isEmptyAssistantMessage - system message is not empty', t => {
21
- const message: TestableMessage = {
22
- role: 'system',
23
- content: '',
24
- };
25
- t.false(isEmptyAssistantMessage(message));
26
- });
27
-
28
- test('isEmptyAssistantMessage - tool message is not empty', t => {
29
- const message: TestableMessage = {
30
- role: 'tool',
31
- content: '',
32
- };
33
- t.false(isEmptyAssistantMessage(message));
34
- });
35
-
36
- // ============================================================================
37
- // Empty assistant messages (should be filtered out)
38
- // ============================================================================
39
-
40
- test('isEmptyAssistantMessage - assistant with empty string content is empty', t => {
41
- const message: TestableMessage = {
42
- role: 'assistant',
43
- content: '',
44
- };
45
- t.true(isEmptyAssistantMessage(message));
46
- });
47
-
48
- test('isEmptyAssistantMessage - assistant with whitespace-only content is empty', t => {
49
- const message: TestableMessage = {
50
- role: 'assistant',
51
- content: ' \n\t ',
52
- };
53
- t.true(isEmptyAssistantMessage(message));
54
- });
55
-
56
- test('isEmptyAssistantMessage - assistant with empty array content is empty', t => {
57
- const message: TestableMessage = {
58
- role: 'assistant',
59
- content: [],
60
- };
61
- t.true(isEmptyAssistantMessage(message));
62
- });
63
-
64
- test('isEmptyAssistantMessage - assistant with empty content and empty toolCalls is empty', t => {
65
- const message: TestableMessage = {
66
- role: 'assistant',
67
- content: '',
68
- toolCalls: [],
69
- };
70
- t.true(isEmptyAssistantMessage(message));
71
- });
72
-
73
- test('isEmptyAssistantMessage - assistant with undefined toolCalls is empty', t => {
74
- const message: TestableMessage = {
75
- role: 'assistant',
76
- content: '',
77
- toolCalls: undefined,
78
- };
79
- t.true(isEmptyAssistantMessage(message));
80
- });
81
-
82
- // ============================================================================
83
- // Valid assistant messages (should NOT be filtered out)
84
- // ============================================================================
85
-
86
- test('isEmptyAssistantMessage - assistant with text content is not empty', t => {
87
- const message: TestableMessage = {
88
- role: 'assistant',
89
- content: 'Hello, how can I help you?',
90
- };
91
- t.false(isEmptyAssistantMessage(message));
92
- });
93
-
94
- test('isEmptyAssistantMessage - assistant with single character content is not empty', t => {
95
- const message: TestableMessage = {
96
- role: 'assistant',
97
- content: 'a',
98
- };
99
- t.false(isEmptyAssistantMessage(message));
100
- });
101
-
102
- test('isEmptyAssistantMessage - assistant with array content is not empty', t => {
103
- const message: TestableMessage = {
104
- role: 'assistant',
105
- content: [{type: 'text', text: 'Hello'}],
106
- };
107
- t.false(isEmptyAssistantMessage(message));
108
- });
109
-
110
- test('isEmptyAssistantMessage - assistant with toolCalls is not empty', t => {
111
- const message: TestableMessage = {
112
- role: 'assistant',
113
- content: '',
114
- toolCalls: [
115
- {toolName: 'read_file', toolCallId: '123', input: {path: 'test.txt'}},
116
- ],
117
- };
118
- t.false(isEmptyAssistantMessage(message));
119
- });
120
-
121
- test('isEmptyAssistantMessage - assistant with content and toolCalls is not empty', t => {
122
- const message: TestableMessage = {
123
- role: 'assistant',
124
- content: 'Let me read that file for you.',
125
- toolCalls: [
126
- {toolName: 'read_file', toolCallId: '123', input: {path: 'test.txt'}},
127
- ],
128
- };
129
- t.false(isEmptyAssistantMessage(message));
130
- });
131
-
132
- test('isEmptyAssistantMessage - assistant with whitespace content but toolCalls is not empty', t => {
133
- const message: TestableMessage = {
134
- role: 'assistant',
135
- content: ' ',
136
- toolCalls: [
137
- {toolName: 'read_file', toolCallId: '123', input: {path: 'test.txt'}},
138
- ],
139
- };
140
- t.false(isEmptyAssistantMessage(message));
141
- });