@gguf/coder 0.2.9 → 0.3.1

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 (439) hide show
  1. package/.editorconfig +16 -0
  2. package/.env.example +63 -0
  3. package/.gitattributes +1 -0
  4. package/.semgrepignore +19 -0
  5. package/coder-dummy-file.ts +52 -0
  6. package/coder.config.example.json +59 -0
  7. package/coder.config.json +13 -0
  8. package/color_picker.html +36 -0
  9. package/dist/tools/execute-bash.js +3 -3
  10. package/dist/tools/execute-bash.js.map +1 -1
  11. package/dist/tools/fetch-url.js +3 -3
  12. package/dist/tools/fetch-url.js.map +1 -1
  13. package/dist/tools/find-files.d.ts.map +1 -1
  14. package/dist/tools/find-files.js +1 -1
  15. package/dist/tools/find-files.js.map +1 -1
  16. package/dist/tools/lsp-get-diagnostics.js +1 -1
  17. package/dist/tools/lsp-get-diagnostics.js.map +1 -1
  18. package/dist/tools/read-file.d.ts.map +1 -1
  19. package/dist/tools/read-file.js +6 -6
  20. package/dist/tools/read-file.js.map +1 -1
  21. package/dist/tools/search-file-contents.d.ts.map +1 -1
  22. package/dist/tools/search-file-contents.js +1 -1
  23. package/dist/tools/search-file-contents.js.map +1 -1
  24. package/dist/tools/string-replace.js +11 -11
  25. package/dist/tools/string-replace.js.map +1 -1
  26. package/dist/tools/web-search.d.ts.map +1 -1
  27. package/dist/tools/web-search.js +3 -3
  28. package/dist/tools/web-search.js.map +1 -1
  29. package/dist/tools/write-file.js +4 -4
  30. package/dist/tools/write-file.js.map +1 -1
  31. package/dist/utils/tool-result-display.d.ts.map +1 -1
  32. package/dist/utils/tool-result-display.js +3 -3
  33. package/dist/utils/tool-result-display.js.map +1 -1
  34. package/package.json +2 -14
  35. package/scripts/extract-changelog.js +73 -0
  36. package/scripts/fetch-models.js +143 -0
  37. package/scripts/test.sh +40 -0
  38. package/scripts/update-homebrew-formula.sh +125 -0
  39. package/scripts/update-nix-version.sh +157 -0
  40. package/source/ai-sdk-client/AISDKClient.spec.ts +117 -0
  41. package/source/ai-sdk-client/AISDKClient.ts +155 -0
  42. package/source/ai-sdk-client/chat/chat-handler.spec.ts +121 -0
  43. package/source/ai-sdk-client/chat/chat-handler.ts +276 -0
  44. package/source/ai-sdk-client/chat/streaming-handler.spec.ts +173 -0
  45. package/source/ai-sdk-client/chat/streaming-handler.ts +110 -0
  46. package/source/ai-sdk-client/chat/tool-processor.spec.ts +92 -0
  47. package/source/ai-sdk-client/chat/tool-processor.ts +70 -0
  48. package/source/ai-sdk-client/converters/message-converter.spec.ts +220 -0
  49. package/source/ai-sdk-client/converters/message-converter.ts +113 -0
  50. package/source/ai-sdk-client/converters/tool-converter.spec.ts +90 -0
  51. package/source/ai-sdk-client/converters/tool-converter.ts +46 -0
  52. package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +55 -0
  53. package/source/ai-sdk-client/error-handling/error-extractor.ts +15 -0
  54. package/source/ai-sdk-client/error-handling/error-parser.spec.ts +169 -0
  55. package/source/ai-sdk-client/error-handling/error-parser.ts +161 -0
  56. package/source/ai-sdk-client/index.ts +7 -0
  57. package/source/ai-sdk-client/providers/provider-factory.spec.ts +71 -0
  58. package/source/ai-sdk-client/providers/provider-factory.ts +41 -0
  59. package/source/ai-sdk-client/types.ts +9 -0
  60. package/source/ai-sdk-client-empty-message.spec.ts +141 -0
  61. package/source/ai-sdk-client-error-handling.spec.ts +186 -0
  62. package/source/ai-sdk-client-maxretries.spec.ts +114 -0
  63. package/source/ai-sdk-client-preparestep.spec.ts +279 -0
  64. package/source/app/App.spec.tsx +32 -0
  65. package/source/app/App.tsx +480 -0
  66. package/source/app/components/AppContainer.spec.tsx +96 -0
  67. package/source/app/components/AppContainer.tsx +56 -0
  68. package/source/app/components/ChatInterface.spec.tsx +163 -0
  69. package/source/app/components/ChatInterface.tsx +144 -0
  70. package/source/app/components/ModalSelectors.spec.tsx +141 -0
  71. package/source/app/components/ModalSelectors.tsx +135 -0
  72. package/source/app/helpers.spec.ts +97 -0
  73. package/source/app/helpers.ts +63 -0
  74. package/source/app/index.ts +4 -0
  75. package/source/app/types.ts +39 -0
  76. package/source/app/utils/appUtils.ts +294 -0
  77. package/source/app/utils/conversationState.ts +310 -0
  78. package/source/app.spec.tsx +244 -0
  79. package/source/cli.spec.ts +73 -0
  80. package/source/cli.tsx +51 -0
  81. package/source/client-factory.spec.ts +48 -0
  82. package/source/client-factory.ts +178 -0
  83. package/source/command-parser.spec.ts +127 -0
  84. package/source/command-parser.ts +36 -0
  85. package/source/commands/checkpoint.spec.tsx +277 -0
  86. package/source/commands/checkpoint.tsx +366 -0
  87. package/source/commands/clear.tsx +22 -0
  88. package/source/commands/custom-commands.tsx +121 -0
  89. package/source/commands/exit.ts +21 -0
  90. package/source/commands/export.spec.tsx +131 -0
  91. package/source/commands/export.tsx +79 -0
  92. package/source/commands/help.tsx +120 -0
  93. package/source/commands/index.ts +17 -0
  94. package/source/commands/init.tsx +339 -0
  95. package/source/commands/lsp-command.spec.tsx +281 -0
  96. package/source/commands/lsp.tsx +120 -0
  97. package/source/commands/mcp-command.spec.tsx +313 -0
  98. package/source/commands/mcp.tsx +162 -0
  99. package/source/commands/model-database.spec.tsx +758 -0
  100. package/source/commands/model-database.tsx +418 -0
  101. package/source/commands/model.ts +12 -0
  102. package/source/commands/provider.ts +12 -0
  103. package/source/commands/setup-config.tsx +16 -0
  104. package/source/commands/simple-commands.spec.tsx +175 -0
  105. package/source/commands/status.ts +12 -0
  106. package/source/commands/theme.ts +12 -0
  107. package/source/commands/update.spec.tsx +261 -0
  108. package/source/commands/update.tsx +201 -0
  109. package/source/commands/usage.spec.tsx +495 -0
  110. package/source/commands/usage.tsx +100 -0
  111. package/source/commands.spec.ts +436 -0
  112. package/source/commands.ts +83 -0
  113. package/source/components/assistant-message.spec.tsx +796 -0
  114. package/source/components/assistant-message.tsx +34 -0
  115. package/source/components/bash-execution-indicator.tsx +21 -0
  116. package/source/components/cancelling-indicator.tsx +16 -0
  117. package/source/components/chat-queue.spec.tsx +83 -0
  118. package/source/components/chat-queue.tsx +36 -0
  119. package/source/components/checkpoint-display.spec.tsx +219 -0
  120. package/source/components/checkpoint-display.tsx +126 -0
  121. package/source/components/checkpoint-selector.spec.tsx +173 -0
  122. package/source/components/checkpoint-selector.tsx +173 -0
  123. package/source/components/development-mode-indicator.spec.tsx +268 -0
  124. package/source/components/development-mode-indicator.tsx +38 -0
  125. package/source/components/message-box.spec.tsx +427 -0
  126. package/source/components/message-box.tsx +87 -0
  127. package/source/components/model-selector.tsx +132 -0
  128. package/source/components/provider-selector.tsx +75 -0
  129. package/source/components/random-spinner.tsx +19 -0
  130. package/source/components/security-disclaimer.tsx +73 -0
  131. package/source/components/status-connection-display.spec.tsx +133 -0
  132. package/source/components/status.tsx +267 -0
  133. package/source/components/theme-selector.tsx +126 -0
  134. package/source/components/tool-confirmation.tsx +190 -0
  135. package/source/components/tool-execution-indicator.tsx +33 -0
  136. package/source/components/tool-message.tsx +85 -0
  137. package/source/components/ui/titled-box.spec.tsx +207 -0
  138. package/source/components/ui/titled-box.tsx +57 -0
  139. package/source/components/usage/progress-bar.spec.tsx +398 -0
  140. package/source/components/usage/progress-bar.tsx +30 -0
  141. package/source/components/usage/usage-display.spec.tsx +780 -0
  142. package/source/components/usage/usage-display.tsx +291 -0
  143. package/source/components/user-input.spec.tsx +327 -0
  144. package/source/components/user-input.tsx +533 -0
  145. package/source/components/user-message.spec.tsx +230 -0
  146. package/source/components/user-message.tsx +84 -0
  147. package/source/components/welcome-message.tsx +76 -0
  148. package/source/config/env-substitution.ts +65 -0
  149. package/source/config/index.spec.ts +171 -0
  150. package/source/config/index.ts +154 -0
  151. package/source/config/paths.spec.ts +241 -0
  152. package/source/config/paths.ts +55 -0
  153. package/source/config/preferences.ts +51 -0
  154. package/source/config/themes.ts +315 -0
  155. package/source/constants.ts +130 -0
  156. package/source/context/mode-context.spec.ts +79 -0
  157. package/source/context/mode-context.ts +24 -0
  158. package/source/custom-commands/executor.spec.ts +142 -0
  159. package/source/custom-commands/executor.ts +64 -0
  160. package/source/custom-commands/loader.spec.ts +314 -0
  161. package/source/custom-commands/loader.ts +153 -0
  162. package/source/custom-commands/parser.ts +196 -0
  163. package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +39 -0
  164. package/source/hooks/chat-handler/conversation/conversation-loop.tsx +511 -0
  165. package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +50 -0
  166. package/source/hooks/chat-handler/conversation/tool-executor.tsx +109 -0
  167. package/source/hooks/chat-handler/index.ts +12 -0
  168. package/source/hooks/chat-handler/state/streaming-state.spec.ts +26 -0
  169. package/source/hooks/chat-handler/state/streaming-state.ts +19 -0
  170. package/source/hooks/chat-handler/types.ts +38 -0
  171. package/source/hooks/chat-handler/useChatHandler.spec.tsx +321 -0
  172. package/source/hooks/chat-handler/useChatHandler.tsx +194 -0
  173. package/source/hooks/chat-handler/utils/context-checker.spec.ts +60 -0
  174. package/source/hooks/chat-handler/utils/context-checker.tsx +73 -0
  175. package/source/hooks/chat-handler/utils/message-helpers.spec.ts +42 -0
  176. package/source/hooks/chat-handler/utils/message-helpers.tsx +36 -0
  177. package/source/hooks/chat-handler/utils/tool-filters.spec.ts +109 -0
  178. package/source/hooks/chat-handler/utils/tool-filters.ts +64 -0
  179. package/source/hooks/useAppHandlers.tsx +291 -0
  180. package/source/hooks/useAppInitialization.tsx +422 -0
  181. package/source/hooks/useAppState.tsx +311 -0
  182. package/source/hooks/useDirectoryTrust.tsx +98 -0
  183. package/source/hooks/useInputState.ts +414 -0
  184. package/source/hooks/useModeHandlers.tsx +302 -0
  185. package/source/hooks/useNonInteractiveMode.ts +140 -0
  186. package/source/hooks/useTerminalWidth.tsx +81 -0
  187. package/source/hooks/useTheme.ts +18 -0
  188. package/source/hooks/useToolHandler.tsx +349 -0
  189. package/source/hooks/useUIState.ts +61 -0
  190. package/source/init/agents-template-generator.ts +421 -0
  191. package/source/init/existing-rules-extractor.ts +319 -0
  192. package/source/init/file-scanner.spec.ts +227 -0
  193. package/source/init/file-scanner.ts +238 -0
  194. package/source/init/framework-detector.ts +382 -0
  195. package/source/init/language-detector.ts +269 -0
  196. package/source/init/project-analyzer.spec.ts +231 -0
  197. package/source/init/project-analyzer.ts +458 -0
  198. package/source/lsp/index.ts +31 -0
  199. package/source/lsp/lsp-client.spec.ts +508 -0
  200. package/source/lsp/lsp-client.ts +487 -0
  201. package/source/lsp/lsp-manager.spec.ts +477 -0
  202. package/source/lsp/lsp-manager.ts +419 -0
  203. package/source/lsp/protocol.spec.ts +502 -0
  204. package/source/lsp/protocol.ts +360 -0
  205. package/source/lsp/server-discovery.spec.ts +654 -0
  206. package/source/lsp/server-discovery.ts +515 -0
  207. package/source/markdown-parser/html-entities.spec.ts +88 -0
  208. package/source/markdown-parser/html-entities.ts +45 -0
  209. package/source/markdown-parser/index.spec.ts +281 -0
  210. package/source/markdown-parser/index.ts +126 -0
  211. package/source/markdown-parser/table-parser.spec.ts +133 -0
  212. package/source/markdown-parser/table-parser.ts +114 -0
  213. package/source/markdown-parser/utils.spec.ts +70 -0
  214. package/source/markdown-parser/utils.ts +13 -0
  215. package/source/mcp/mcp-client.spec.ts +81 -0
  216. package/source/mcp/mcp-client.ts +625 -0
  217. package/source/mcp/transport-factory.spec.ts +406 -0
  218. package/source/mcp/transport-factory.ts +312 -0
  219. package/source/message-handler.ts +67 -0
  220. package/source/model-database/database-engine.spec.ts +494 -0
  221. package/source/model-database/database-engine.ts +50 -0
  222. package/source/model-database/model-database.spec.ts +363 -0
  223. package/source/model-database/model-database.ts +91 -0
  224. package/source/model-database/model-engine.spec.ts +447 -0
  225. package/source/model-database/model-engine.ts +65 -0
  226. package/source/model-database/model-fetcher.spec.ts +583 -0
  227. package/source/model-database/model-fetcher.ts +330 -0
  228. package/source/models/index.ts +1 -0
  229. package/source/models/models-cache.spec.ts +214 -0
  230. package/source/models/models-cache.ts +78 -0
  231. package/source/models/models-dev-client.spec.ts +379 -0
  232. package/source/models/models-dev-client.ts +329 -0
  233. package/source/models/models-types.ts +68 -0
  234. package/source/prompt-history.ts +155 -0
  235. package/source/security/command-injection.spec.ts +240 -0
  236. package/source/services/checkpoint-manager.spec.ts +523 -0
  237. package/source/services/checkpoint-manager.ts +466 -0
  238. package/source/services/file-snapshot.spec.ts +569 -0
  239. package/source/services/file-snapshot.ts +220 -0
  240. package/source/test-utils/render-with-theme.tsx +48 -0
  241. package/source/tokenization/index.ts +1 -0
  242. package/source/tokenization/tokenizer-factory.spec.ts +170 -0
  243. package/source/tokenization/tokenizer-factory.ts +125 -0
  244. package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +200 -0
  245. package/source/tokenization/tokenizers/anthropic-tokenizer.ts +43 -0
  246. package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +236 -0
  247. package/source/tokenization/tokenizers/fallback-tokenizer.ts +26 -0
  248. package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +224 -0
  249. package/source/tokenization/tokenizers/llama-tokenizer.ts +41 -0
  250. package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +184 -0
  251. package/source/tokenization/tokenizers/openai-tokenizer.ts +57 -0
  252. package/source/tool-calling/index.ts +5 -0
  253. package/source/tool-calling/json-parser.spec.ts +639 -0
  254. package/source/tool-calling/json-parser.ts +247 -0
  255. package/source/tool-calling/tool-parser.spec.ts +395 -0
  256. package/source/tool-calling/tool-parser.ts +120 -0
  257. package/source/tool-calling/xml-parser.spec.ts +662 -0
  258. package/source/tool-calling/xml-parser.ts +289 -0
  259. package/source/tools/execute-bash.spec.tsx +353 -0
  260. package/source/tools/execute-bash.tsx +219 -0
  261. package/source/tools/execute-function.spec.ts +130 -0
  262. package/source/tools/fetch-url.spec.tsx +342 -0
  263. package/source/tools/fetch-url.tsx +172 -0
  264. package/source/tools/find-files.spec.tsx +924 -0
  265. package/source/tools/find-files.tsx +293 -0
  266. package/source/tools/index.ts +102 -0
  267. package/source/tools/lsp-get-diagnostics.tsx +192 -0
  268. package/source/tools/needs-approval.spec.ts +282 -0
  269. package/source/tools/read-file.spec.tsx +801 -0
  270. package/source/tools/read-file.tsx +387 -0
  271. package/source/tools/search-file-contents.spec.tsx +1273 -0
  272. package/source/tools/search-file-contents.tsx +293 -0
  273. package/source/tools/string-replace.spec.tsx +730 -0
  274. package/source/tools/string-replace.tsx +548 -0
  275. package/source/tools/tool-manager.ts +210 -0
  276. package/source/tools/tool-registry.spec.ts +415 -0
  277. package/source/tools/tool-registry.ts +228 -0
  278. package/source/tools/web-search.tsx +223 -0
  279. package/source/tools/write-file.spec.tsx +559 -0
  280. package/source/tools/write-file.tsx +228 -0
  281. package/source/types/app.ts +37 -0
  282. package/source/types/checkpoint.ts +48 -0
  283. package/source/types/commands.ts +46 -0
  284. package/source/types/components.ts +27 -0
  285. package/source/types/config.ts +103 -0
  286. package/source/types/core-connection-status.spec.ts +67 -0
  287. package/source/types/core.ts +181 -0
  288. package/source/types/hooks.ts +50 -0
  289. package/source/types/index.ts +12 -0
  290. package/source/types/markdown-parser.ts +11 -0
  291. package/source/types/mcp.ts +52 -0
  292. package/source/types/system.ts +16 -0
  293. package/source/types/tokenization.ts +41 -0
  294. package/source/types/ui.ts +40 -0
  295. package/source/types/usage.ts +58 -0
  296. package/source/types/utils.ts +16 -0
  297. package/source/usage/calculator.spec.ts +385 -0
  298. package/source/usage/calculator.ts +104 -0
  299. package/source/usage/storage.spec.ts +703 -0
  300. package/source/usage/storage.ts +238 -0
  301. package/source/usage/tracker.spec.ts +456 -0
  302. package/source/usage/tracker.ts +102 -0
  303. package/source/utils/atomic-deletion.spec.ts +194 -0
  304. package/source/utils/atomic-deletion.ts +127 -0
  305. package/source/utils/bounded-map.spec.ts +300 -0
  306. package/source/utils/bounded-map.ts +193 -0
  307. package/source/utils/checkpoint-utils.spec.ts +222 -0
  308. package/source/utils/checkpoint-utils.ts +92 -0
  309. package/source/utils/error-formatter.spec.ts +169 -0
  310. package/source/utils/error-formatter.ts +194 -0
  311. package/source/utils/file-autocomplete.spec.ts +173 -0
  312. package/source/utils/file-autocomplete.ts +196 -0
  313. package/source/utils/file-cache.spec.ts +309 -0
  314. package/source/utils/file-cache.ts +195 -0
  315. package/source/utils/file-content-loader.spec.ts +180 -0
  316. package/source/utils/file-content-loader.ts +179 -0
  317. package/source/utils/file-mention-handler.spec.ts +261 -0
  318. package/source/utils/file-mention-handler.ts +84 -0
  319. package/source/utils/file-mention-parser.spec.ts +182 -0
  320. package/source/utils/file-mention-parser.ts +170 -0
  321. package/source/utils/fuzzy-matching.spec.ts +149 -0
  322. package/source/utils/fuzzy-matching.ts +146 -0
  323. package/source/utils/indentation-normalizer.spec.ts +216 -0
  324. package/source/utils/indentation-normalizer.ts +76 -0
  325. package/source/utils/installation-detector.spec.ts +178 -0
  326. package/source/utils/installation-detector.ts +153 -0
  327. package/source/utils/logging/config.spec.ts +311 -0
  328. package/source/utils/logging/config.ts +210 -0
  329. package/source/utils/logging/console-facade.spec.ts +184 -0
  330. package/source/utils/logging/console-facade.ts +384 -0
  331. package/source/utils/logging/correlation.spec.ts +679 -0
  332. package/source/utils/logging/correlation.ts +474 -0
  333. package/source/utils/logging/formatters.spec.ts +464 -0
  334. package/source/utils/logging/formatters.ts +207 -0
  335. package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +93 -0
  336. package/source/utils/logging/health-monitor/alerts/alert-manager.ts +79 -0
  337. package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +56 -0
  338. package/source/utils/logging/health-monitor/checks/configuration-check.ts +43 -0
  339. package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +56 -0
  340. package/source/utils/logging/health-monitor/checks/logging-check.ts +58 -0
  341. package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +100 -0
  342. package/source/utils/logging/health-monitor/checks/memory-check.ts +78 -0
  343. package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +56 -0
  344. package/source/utils/logging/health-monitor/checks/performance-check.ts +56 -0
  345. package/source/utils/logging/health-monitor/checks/request-check.spec.ts +56 -0
  346. package/source/utils/logging/health-monitor/checks/request-check.ts +76 -0
  347. package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +70 -0
  348. package/source/utils/logging/health-monitor/core/health-check-runner.ts +138 -0
  349. package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +58 -0
  350. package/source/utils/logging/health-monitor/core/health-monitor.ts +344 -0
  351. package/source/utils/logging/health-monitor/core/scoring.spec.ts +65 -0
  352. package/source/utils/logging/health-monitor/core/scoring.ts +91 -0
  353. package/source/utils/logging/health-monitor/index.ts +15 -0
  354. package/source/utils/logging/health-monitor/instances.ts +48 -0
  355. package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +141 -0
  356. package/source/utils/logging/health-monitor/middleware/http-middleware.ts +75 -0
  357. package/source/utils/logging/health-monitor/types.ts +126 -0
  358. package/source/utils/logging/index.spec.ts +284 -0
  359. package/source/utils/logging/index.ts +236 -0
  360. package/source/utils/logging/integration.spec.ts +441 -0
  361. package/source/utils/logging/log-method-factory.spec.ts +573 -0
  362. package/source/utils/logging/log-method-factory.ts +233 -0
  363. package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +277 -0
  364. package/source/utils/logging/log-query/aggregation/aggregator.ts +159 -0
  365. package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +159 -0
  366. package/source/utils/logging/log-query/aggregation/facet-generator.ts +47 -0
  367. package/source/utils/logging/log-query/index.ts +23 -0
  368. package/source/utils/logging/log-query/query/filter-predicates.spec.ts +247 -0
  369. package/source/utils/logging/log-query/query/filter-predicates.ts +154 -0
  370. package/source/utils/logging/log-query/query/query-builder.spec.ts +182 -0
  371. package/source/utils/logging/log-query/query/query-builder.ts +151 -0
  372. package/source/utils/logging/log-query/query/query-engine.spec.ts +214 -0
  373. package/source/utils/logging/log-query/query/query-engine.ts +45 -0
  374. package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +143 -0
  375. package/source/utils/logging/log-query/storage/circular-buffer.ts +75 -0
  376. package/source/utils/logging/log-query/storage/index-manager.spec.ts +150 -0
  377. package/source/utils/logging/log-query/storage/index-manager.ts +71 -0
  378. package/source/utils/logging/log-query/storage/log-storage.spec.ts +257 -0
  379. package/source/utils/logging/log-query/storage/log-storage.ts +80 -0
  380. package/source/utils/logging/log-query/types.ts +163 -0
  381. package/source/utils/logging/log-query/utils/helpers.spec.ts +263 -0
  382. package/source/utils/logging/log-query/utils/helpers.ts +72 -0
  383. package/source/utils/logging/log-query/utils/sorting.spec.ts +182 -0
  384. package/source/utils/logging/log-query/utils/sorting.ts +61 -0
  385. package/source/utils/logging/logger-provider.spec.ts +262 -0
  386. package/source/utils/logging/logger-provider.ts +362 -0
  387. package/source/utils/logging/performance.spec.ts +209 -0
  388. package/source/utils/logging/performance.ts +757 -0
  389. package/source/utils/logging/pino-logger.spec.ts +425 -0
  390. package/source/utils/logging/pino-logger.ts +514 -0
  391. package/source/utils/logging/redaction.spec.ts +490 -0
  392. package/source/utils/logging/redaction.ts +267 -0
  393. package/source/utils/logging/request-tracker.spec.ts +1198 -0
  394. package/source/utils/logging/request-tracker.ts +803 -0
  395. package/source/utils/logging/transports.spec.ts +505 -0
  396. package/source/utils/logging/transports.ts +305 -0
  397. package/source/utils/logging/types.ts +216 -0
  398. package/source/utils/message-builder.spec.ts +179 -0
  399. package/source/utils/message-builder.ts +101 -0
  400. package/source/utils/message-queue.tsx +486 -0
  401. package/source/utils/paste-detection.spec.ts +69 -0
  402. package/source/utils/paste-detection.ts +124 -0
  403. package/source/utils/paste-roundtrip.spec.ts +442 -0
  404. package/source/utils/paste-utils.spec.ts +128 -0
  405. package/source/utils/paste-utils.ts +52 -0
  406. package/source/utils/programming-language-helper.spec.ts +74 -0
  407. package/source/utils/programming-language-helper.ts +32 -0
  408. package/source/utils/prompt-assembly.spec.ts +221 -0
  409. package/source/utils/prompt-processor.ts +173 -0
  410. package/source/utils/tool-args-parser.spec.ts +136 -0
  411. package/source/utils/tool-args-parser.ts +54 -0
  412. package/source/utils/tool-cancellation.spec.ts +230 -0
  413. package/source/utils/tool-cancellation.ts +28 -0
  414. package/source/utils/tool-result-display.spec.tsx +469 -0
  415. package/source/utils/tool-result-display.tsx +90 -0
  416. package/source/utils/update-checker.spec.ts +383 -0
  417. package/source/utils/update-checker.ts +183 -0
  418. package/source/wizard/config-wizard.spec.tsx +103 -0
  419. package/source/wizard/config-wizard.tsx +382 -0
  420. package/source/wizard/steps/location-step.spec.tsx +186 -0
  421. package/source/wizard/steps/location-step.tsx +147 -0
  422. package/source/wizard/steps/mcp-step.spec.tsx +607 -0
  423. package/source/wizard/steps/mcp-step.tsx +632 -0
  424. package/source/wizard/steps/provider-step.spec.tsx +342 -0
  425. package/source/wizard/steps/provider-step.tsx +957 -0
  426. package/source/wizard/steps/summary-step.spec.tsx +749 -0
  427. package/source/wizard/steps/summary-step.tsx +228 -0
  428. package/source/wizard/templates/mcp-templates.spec.ts +613 -0
  429. package/source/wizard/templates/mcp-templates.ts +570 -0
  430. package/source/wizard/templates/provider-templates.spec.ts +152 -0
  431. package/source/wizard/templates/provider-templates.ts +485 -0
  432. package/source/wizard/utils/fetch-cloud-models.spec.ts +428 -0
  433. package/source/wizard/utils/fetch-cloud-models.ts +223 -0
  434. package/source/wizard/utils/fetch-local-models.spec.ts +297 -0
  435. package/source/wizard/utils/fetch-local-models.ts +192 -0
  436. package/source/wizard/validation-array.spec.ts +264 -0
  437. package/source/wizard/validation.spec.ts +373 -0
  438. package/source/wizard/validation.ts +232 -0
  439. package/source/app/prompts/main-prompt.md +0 -122
@@ -0,0 +1,261 @@
1
+ import test from 'ava';
2
+ import { toolRegistry } from '../tools/index.js';
3
+ import { hasCommandFailed, updateCommand } from './update.js';
4
+
5
+ console.log(`\nupdate.spec.tsx`);
6
+
7
+ // Command Metadata Tests
8
+ // These tests verify the command is properly configured
9
+
10
+ test('updateCommand: has correct name', t => {
11
+ t.is(updateCommand.name, 'update');
12
+ });
13
+
14
+ test('updateCommand: has description', t => {
15
+ t.truthy(updateCommand.description);
16
+ t.true(updateCommand.description.length > 0);
17
+ t.regex(updateCommand.description, /update/i);
18
+ });
19
+
20
+ test('updateCommand: has handler function', t => {
21
+ t.is(typeof updateCommand.handler, 'function');
22
+ });
23
+
24
+ test('updateCommand: handler is async', t => {
25
+ const result = updateCommand.handler([]);
26
+ t.truthy(result);
27
+ t.true(result instanceof Promise);
28
+ });
29
+
30
+ // Basic behavior: when update available and installed via npm, handler runs npm update -g
31
+ test('updateCommand: runs update command when installed via npm', async t => {
32
+ // Mock fetch to return newer version
33
+ const originalFetch = globalThis.fetch;
34
+ globalThis.fetch = (async () => {
35
+ return {
36
+ ok: true,
37
+ status: 200,
38
+ statusText: 'OK',
39
+ json: async () => ({
40
+ version: '99.99.99',
41
+ name: '@gguf/coder',
42
+ }),
43
+ } as unknown as Response;
44
+ }) as typeof fetch;
45
+
46
+ // Set installation method override
47
+ process.env.CODER_INSTALL_METHOD = 'npm';
48
+
49
+ let called = false;
50
+ const originalExecuteBash = toolRegistry.execute_bash;
51
+ toolRegistry.execute_bash = async ({ command }: { command: string }) => {
52
+ called = true;
53
+ t.is(command, 'npm update -g @gguf/coder');
54
+ return 'ok';
55
+ };
56
+
57
+ await updateCommand.handler([]);
58
+
59
+ // Cleanup
60
+ toolRegistry.execute_bash = originalExecuteBash;
61
+ globalThis.fetch = originalFetch;
62
+ delete process.env.CODER_INSTALL_METHOD;
63
+
64
+ t.true(called);
65
+ });
66
+
67
+ test('updateCommand: does not run execute_bash for nix installations', async t => {
68
+ const originalFetch = globalThis.fetch;
69
+ globalThis.fetch = (async () => {
70
+ return {
71
+ ok: true,
72
+ status: 200,
73
+ statusText: 'OK',
74
+ json: async () => ({
75
+ version: '99.99.99',
76
+ name: '@gguf/coder',
77
+ }),
78
+ } as unknown as Response;
79
+ }) as typeof fetch;
80
+
81
+ process.env.CODER_INSTALL_METHOD = 'nix';
82
+
83
+ let called = false;
84
+ const originalExecuteBash = toolRegistry.execute_bash;
85
+ toolRegistry.execute_bash = async ({ command }: { command: string }) => {
86
+ called = true;
87
+ return 'ok';
88
+ };
89
+
90
+ await updateCommand.handler([]);
91
+
92
+ // Cleanup
93
+ toolRegistry.execute_bash = originalExecuteBash;
94
+ globalThis.fetch = originalFetch;
95
+ delete process.env.CODER_INSTALL_METHOD;
96
+
97
+ t.false(called);
98
+ });
99
+
100
+ test('updateCommand: handles execute_bash failure with error message', async t => {
101
+ const originalFetch = globalThis.fetch;
102
+ globalThis.fetch = (async () => {
103
+ return {
104
+ ok: true,
105
+ status: 200,
106
+ statusText: 'OK',
107
+ json: async () => ({
108
+ version: '99.99.99',
109
+ name: '@gguf/coder',
110
+ }),
111
+ } as unknown as Response;
112
+ }) as typeof fetch;
113
+
114
+ process.env.CODER_INSTALL_METHOD = 'npm';
115
+
116
+ const originalExecuteBash = toolRegistry.execute_bash;
117
+ toolRegistry.execute_bash = async () => {
118
+ throw new Error('command failed: permission denied');
119
+ };
120
+
121
+ const result = await updateCommand.handler([]);
122
+ // Expect the result is a React element with props.message containing 'Failed to execute'
123
+ // @ts-ignore
124
+ t.truthy(result.props?.message?.includes('Failed to execute'));
125
+
126
+ // Cleanup
127
+ toolRegistry.execute_bash = originalExecuteBash;
128
+ globalThis.fetch = originalFetch;
129
+ delete process.env.CODER_INSTALL_METHOD;
130
+ });
131
+
132
+ // Error Detection Tests
133
+ // These tests verify the hasCommandFailed function correctly identifies failures
134
+
135
+ test('hasCommandFailed: detects failure via exit code', t => {
136
+ const output = 'EXIT_CODE: 1\nSome error occurred';
137
+ t.true(hasCommandFailed(output));
138
+ });
139
+
140
+ test('hasCommandFailed: detects success via exit code 0', t => {
141
+ const output = 'EXIT_CODE: 0\nSuccess message';
142
+ t.false(hasCommandFailed(output));
143
+ });
144
+
145
+ test('hasCommandFailed: detects "command not found" error', t => {
146
+ const output = 'EXIT_CODE: 127\nSTDERR:\nbash: foobar: command not found';
147
+ t.true(hasCommandFailed(output));
148
+ });
149
+
150
+ test('hasCommandFailed: detects "permission denied" error', t => {
151
+ const output = 'EXIT_CODE: 1\nSTDERR:\npermission denied';
152
+ t.true(hasCommandFailed(output));
153
+ });
154
+
155
+ test('hasCommandFailed: detects "no such file or directory" error', t => {
156
+ const output = 'EXIT_CODE: 2\nSTDERR:\nno such file or directory';
157
+ t.true(hasCommandFailed(output));
158
+ });
159
+
160
+ test('hasCommandFailed: does not false positive on "0 errors"', t => {
161
+ const output = 'EXIT_CODE: 0\nBuild completed with 0 errors';
162
+ t.false(hasCommandFailed(output));
163
+ });
164
+
165
+ test('hasCommandFailed: does not false positive on "error-free"', t => {
166
+ const output = 'EXIT_CODE: 0\nThe build was error-free';
167
+ t.false(hasCommandFailed(output));
168
+ });
169
+
170
+ test('hasCommandFailed: does not false positive on "no errors found"', t => {
171
+ const output = 'EXIT_CODE: 0\nScan complete: no errors found';
172
+ t.false(hasCommandFailed(output));
173
+ });
174
+
175
+ test('hasCommandFailed: detects "error:" at start of line', t => {
176
+ const output = 'EXIT_CODE: 1\nSTDERR:\nerror: something went wrong';
177
+ t.true(hasCommandFailed(output));
178
+ });
179
+
180
+ test('hasCommandFailed: detects "fatal" error', t => {
181
+ const output = 'EXIT_CODE: 1\nSTDERR:\nfatal: Not a git repository';
182
+ t.true(hasCommandFailed(output));
183
+ });
184
+
185
+ test('hasCommandFailed: detects "failed" message', t => {
186
+ const output = 'EXIT_CODE: 1\nSTDERR:\nOperation failed';
187
+ t.true(hasCommandFailed(output));
188
+ });
189
+
190
+ test('hasCommandFailed: handles output with only STDERR (non-error)', t => {
191
+ // Some tools write progress to stderr
192
+ const output = 'EXIT_CODE: 0\nSTDERR:\nDownloading... 100%\nSTDOUT:\nSuccess';
193
+ t.false(hasCommandFailed(output));
194
+ });
195
+
196
+ test('hasCommandFailed: handles output with only STDERR (with error)', t => {
197
+ const output =
198
+ 'EXIT_CODE: 1\nSTDERR:\nDownload failed due to network error\nSTDOUT:\n';
199
+ t.true(hasCommandFailed(output));
200
+ });
201
+
202
+ test('hasCommandFailed: handles empty output', t => {
203
+ const output = '';
204
+ t.false(hasCommandFailed(output));
205
+ });
206
+
207
+ test('hasCommandFailed: handles null/undefined output', t => {
208
+ // @ts-ignore - testing edge case
209
+ t.false(hasCommandFailed(null));
210
+ // @ts-ignore - testing edge case
211
+ t.false(hasCommandFailed(undefined));
212
+ });
213
+
214
+ test('hasCommandFailed: exit code takes precedence over success messages', t => {
215
+ // Even if output looks successful, exit code 1 means failure
216
+ const output = 'EXIT_CODE: 1\nAll tests passed successfully!';
217
+ t.true(hasCommandFailed(output));
218
+ });
219
+
220
+ // Homebrew error handling
221
+ test('updateCommand: detects homebrew "not found" error', t => {
222
+ const output =
223
+ 'EXIT_CODE: 1\nSTDERR:\nError: coder not found in Homebrew\nPlease install it first with: brew install coder';
224
+ t.true(hasCommandFailed(output));
225
+ });
226
+
227
+ // Edge case: both updateCommand and updateMessage undefined
228
+ test('updateCommand: handles edge case when both updateCommand and updateMessage are undefined', async t => {
229
+ const originalFetch = globalThis.fetch;
230
+ globalThis.fetch = (async () => {
231
+ return {
232
+ ok: true,
233
+ status: 200,
234
+ statusText: 'OK',
235
+ json: async () => ({
236
+ version: '99.99.99',
237
+ name: '@gguf/coder',
238
+ }),
239
+ } as unknown as Response;
240
+ }) as typeof fetch;
241
+
242
+ // Set an unknown installation method that won't return a command or message
243
+ process.env.CODER_INSTALL_METHOD = 'unknown';
244
+
245
+ const result = await updateCommand.handler([]);
246
+
247
+ // Should return the fallback InfoMessage
248
+ // @ts-ignore - accessing React element props
249
+ t.truthy(result.props?.message);
250
+ // @ts-ignore
251
+ t.regex(result.props.message, /package manager/i);
252
+
253
+ // Cleanup
254
+ globalThis.fetch = originalFetch;
255
+ delete process.env.CODER_INSTALL_METHOD;
256
+ });
257
+
258
+ // Note: Full integration tests with mocking would require a more sophisticated
259
+ // test setup with module mocking capabilities. The update-checker.spec.ts file
260
+ // provides comprehensive coverage of the update checking logic itself.
261
+ // This file focuses on verifying the command is properly structured and registered.
@@ -0,0 +1,201 @@
1
+ import {
2
+ ErrorMessage,
3
+ InfoMessage,
4
+ SuccessMessage,
5
+ } from '@/components/message-box';
6
+ import { spawn } from 'node:child_process';
7
+ import { Command } from '@/types/index';
8
+ import { logError, logInfo } from '@/utils/message-queue';
9
+ import { checkForUpdates } from '@/utils/update-checker';
10
+ import React from 'react';
11
+
12
+ /**
13
+ * Determines if a command execution failed based on multiple signals.
14
+ * Checks exit code first (most reliable), then looks for specific error patterns.
15
+ * Exported for testing purposes.
16
+ */
17
+ export function hasCommandFailed(output: string): boolean {
18
+ const outputStr = String(output || '');
19
+
20
+ // Strategy 1: Check exit code (most reliable)
21
+ const exitCodeMatch = outputStr.match(/^EXIT_CODE:\s*(\d+)/m);
22
+ if (exitCodeMatch) {
23
+ const exitCode = parseInt(exitCodeMatch[1], 10);
24
+ // Non-zero exit code indicates failure
25
+ if (exitCode !== 0) {
26
+ return true;
27
+ }
28
+ }
29
+
30
+ // Strategy 2: Check for critical error patterns
31
+ // Use word boundaries and case-sensitive matching to avoid false positives
32
+ const normalized = outputStr.toLowerCase();
33
+
34
+ // Critical errors that definitively indicate failure
35
+ const criticalErrors = [
36
+ /\bcommand not found\b/i,
37
+ /\bno such file or directory\b/i,
38
+ /\bpermission denied\b/i,
39
+ /^error:/im, // Error at start of line
40
+ /\berror:\s*(?!0\b)/i, // "error:" not followed by 0
41
+ /\bfatal\b/i,
42
+ /\bfailed\b/i,
43
+ /\bcannot\b/i,
44
+ ];
45
+
46
+ for (const pattern of criticalErrors) {
47
+ if (pattern.test(normalized)) {
48
+ // Additional check: avoid false positives for success messages
49
+ // like "0 errors", "error-free", "no errors found"
50
+ if (/0\s*errors?|error-?free|no\s*errors?\s*found/i.test(normalized)) {
51
+ continue;
52
+ }
53
+ return true;
54
+ }
55
+ }
56
+
57
+ // Strategy 3: Check if STDERR has content (warning: not always an error)
58
+ // Some tools write progress to stderr, so this is a weak signal
59
+ // Only use this if no other signals present
60
+ const hasStderr = /^STDERR:\s*\S/m.test(outputStr);
61
+ if (hasStderr) {
62
+ // Check if stderr contains actual error indicators, not just warnings/info
63
+ const stderrMatch = outputStr.match(/^STDERR:\s*([\s\S]*?)(?:^STDOUT:|$)/m);
64
+ if (stderrMatch) {
65
+ const stderrContent = stderrMatch[1].toLowerCase();
66
+ // Only treat as error if stderr contains error-like content
67
+ if (/\berror\b|\bfatal\b|\bfailed\b|\bcannot\b/i.test(stderrContent)) {
68
+ return true;
69
+ }
70
+ }
71
+ }
72
+
73
+ return false;
74
+ }
75
+
76
+ export const updateCommand: Command = {
77
+ name: 'update',
78
+ description: 'Update Coder to the latest version',
79
+ handler: async (_args: string[]) => {
80
+ // Show initial checking message
81
+ logInfo('Checking for available updates...', true);
82
+
83
+ try {
84
+ const updateInfo = await checkForUpdates();
85
+
86
+ if (updateInfo.error) {
87
+ const is404 = updateInfo.error.includes('404');
88
+ const message = is404
89
+ ? 'Update check failed: Package not found in registry (HTTP 404). This version might be a private or local build.'
90
+ : `Failed to check for updates: ${updateInfo.error}`;
91
+
92
+ logError(message, true);
93
+ return React.createElement(ErrorMessage, {
94
+ message,
95
+ hideBox: true,
96
+ });
97
+ }
98
+
99
+ if (updateInfo.hasUpdate) {
100
+ // Show updating message
101
+ logInfo(
102
+ 'Downloading and installing the latest Coder update...',
103
+ true,
104
+ );
105
+
106
+ // Run update command if provided; otherwise show informative message
107
+ if (updateInfo.updateCommand) {
108
+ try {
109
+ const result = await new Promise<string>((resolve, reject) => {
110
+ const proc = spawn(updateInfo.updateCommand!, {
111
+ shell: true,
112
+ stdio: ['ignore', 'pipe', 'pipe'],
113
+ });
114
+ let stdout = '';
115
+ let stderr = '';
116
+
117
+ proc.stdout.on('data', (data: Buffer) => {
118
+ stdout += data.toString();
119
+ });
120
+
121
+ proc.stderr.on('data', (data: Buffer) => {
122
+ stderr += data.toString();
123
+ });
124
+
125
+ proc.on('close', (code: number | null) => {
126
+ const exitCodeInfo =
127
+ code !== null ? `EXIT_CODE: ${code}\n` : '';
128
+ if (stderr) {
129
+ resolve(
130
+ `${exitCodeInfo}STDERR:\n${stderr}\nSTDOUT:\n${stdout}`,
131
+ );
132
+ } else {
133
+ resolve(`${exitCodeInfo}${stdout}`);
134
+ }
135
+ });
136
+
137
+ proc.on('error', error => {
138
+ reject(
139
+ new Error(`Error executing command: ${error.message}`),
140
+ );
141
+ });
142
+ });
143
+
144
+ // Check for command failure using multiple strategies
145
+ if (hasCommandFailed(result)) {
146
+ logError('Update command executed but returned an error', true);
147
+ return React.createElement(ErrorMessage, {
148
+ message: `Update command failed. Output: ${String(result)}`,
149
+ hideBox: true,
150
+ });
151
+ }
152
+
153
+ // Show success message
154
+ return React.createElement(SuccessMessage, {
155
+ message:
156
+ 'Coder has been updated to the latest version. Please restart your session to apply the update.',
157
+ hideBox: true,
158
+ });
159
+ } catch (err) {
160
+ const errorMessage =
161
+ err instanceof Error ? err.message : String(err);
162
+ logError(`Failed to execute update command: ${errorMessage}`, true);
163
+ return React.createElement(ErrorMessage, {
164
+ message: `Failed to execute update command: ${errorMessage}`,
165
+ hideBox: true,
166
+ });
167
+ }
168
+ }
169
+
170
+ if (updateInfo.updateMessage) {
171
+ // We cannot run an automated update; show instructions to user
172
+ return React.createElement(InfoMessage, {
173
+ message: updateInfo.updateMessage,
174
+ hideBox: true,
175
+ });
176
+ }
177
+
178
+ // Fallback for unknown installation method
179
+ return React.createElement(InfoMessage, {
180
+ message:
181
+ 'A new version is available. Please update using your package manager.',
182
+ hideBox: true,
183
+ });
184
+ } else {
185
+ // Already up to date
186
+ return React.createElement(InfoMessage, {
187
+ message: 'You are already on the latest version.',
188
+ hideBox: true,
189
+ });
190
+ }
191
+ } catch (error) {
192
+ const errorMessage =
193
+ error instanceof Error ? error.message : String(error);
194
+ logError(`Failed to update Coder: ${errorMessage}`, true);
195
+ return React.createElement(ErrorMessage, {
196
+ message: `Failed to check for updates: ${errorMessage}`,
197
+ hideBox: true,
198
+ });
199
+ }
200
+ },
201
+ };