@gguf/coder 0.3.0 → 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 (414) 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/package.json +2 -14
  10. package/scripts/extract-changelog.js +73 -0
  11. package/scripts/fetch-models.js +143 -0
  12. package/scripts/test.sh +40 -0
  13. package/scripts/update-homebrew-formula.sh +125 -0
  14. package/scripts/update-nix-version.sh +157 -0
  15. package/source/ai-sdk-client/AISDKClient.spec.ts +117 -0
  16. package/source/ai-sdk-client/AISDKClient.ts +155 -0
  17. package/source/ai-sdk-client/chat/chat-handler.spec.ts +121 -0
  18. package/source/ai-sdk-client/chat/chat-handler.ts +276 -0
  19. package/source/ai-sdk-client/chat/streaming-handler.spec.ts +173 -0
  20. package/source/ai-sdk-client/chat/streaming-handler.ts +110 -0
  21. package/source/ai-sdk-client/chat/tool-processor.spec.ts +92 -0
  22. package/source/ai-sdk-client/chat/tool-processor.ts +70 -0
  23. package/source/ai-sdk-client/converters/message-converter.spec.ts +220 -0
  24. package/source/ai-sdk-client/converters/message-converter.ts +113 -0
  25. package/source/ai-sdk-client/converters/tool-converter.spec.ts +90 -0
  26. package/source/ai-sdk-client/converters/tool-converter.ts +46 -0
  27. package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +55 -0
  28. package/source/ai-sdk-client/error-handling/error-extractor.ts +15 -0
  29. package/source/ai-sdk-client/error-handling/error-parser.spec.ts +169 -0
  30. package/source/ai-sdk-client/error-handling/error-parser.ts +161 -0
  31. package/source/ai-sdk-client/index.ts +7 -0
  32. package/source/ai-sdk-client/providers/provider-factory.spec.ts +71 -0
  33. package/source/ai-sdk-client/providers/provider-factory.ts +41 -0
  34. package/source/ai-sdk-client/types.ts +9 -0
  35. package/source/ai-sdk-client-empty-message.spec.ts +141 -0
  36. package/source/ai-sdk-client-error-handling.spec.ts +186 -0
  37. package/source/ai-sdk-client-maxretries.spec.ts +114 -0
  38. package/source/ai-sdk-client-preparestep.spec.ts +279 -0
  39. package/source/app/App.spec.tsx +32 -0
  40. package/source/app/App.tsx +480 -0
  41. package/source/app/components/AppContainer.spec.tsx +96 -0
  42. package/source/app/components/AppContainer.tsx +56 -0
  43. package/source/app/components/ChatInterface.spec.tsx +163 -0
  44. package/source/app/components/ChatInterface.tsx +144 -0
  45. package/source/app/components/ModalSelectors.spec.tsx +141 -0
  46. package/source/app/components/ModalSelectors.tsx +135 -0
  47. package/source/app/helpers.spec.ts +97 -0
  48. package/source/app/helpers.ts +63 -0
  49. package/source/app/index.ts +4 -0
  50. package/source/app/types.ts +39 -0
  51. package/source/app/utils/appUtils.ts +294 -0
  52. package/source/app/utils/conversationState.ts +310 -0
  53. package/source/app.spec.tsx +244 -0
  54. package/source/cli.spec.ts +73 -0
  55. package/source/cli.tsx +51 -0
  56. package/source/client-factory.spec.ts +48 -0
  57. package/source/client-factory.ts +178 -0
  58. package/source/command-parser.spec.ts +127 -0
  59. package/source/command-parser.ts +36 -0
  60. package/source/commands/checkpoint.spec.tsx +277 -0
  61. package/source/commands/checkpoint.tsx +366 -0
  62. package/source/commands/clear.tsx +22 -0
  63. package/source/commands/custom-commands.tsx +121 -0
  64. package/source/commands/exit.ts +21 -0
  65. package/source/commands/export.spec.tsx +131 -0
  66. package/source/commands/export.tsx +79 -0
  67. package/source/commands/help.tsx +120 -0
  68. package/source/commands/index.ts +17 -0
  69. package/source/commands/init.tsx +339 -0
  70. package/source/commands/lsp-command.spec.tsx +281 -0
  71. package/source/commands/lsp.tsx +120 -0
  72. package/source/commands/mcp-command.spec.tsx +313 -0
  73. package/source/commands/mcp.tsx +162 -0
  74. package/source/commands/model-database.spec.tsx +758 -0
  75. package/source/commands/model-database.tsx +418 -0
  76. package/source/commands/model.ts +12 -0
  77. package/source/commands/provider.ts +12 -0
  78. package/source/commands/setup-config.tsx +16 -0
  79. package/source/commands/simple-commands.spec.tsx +175 -0
  80. package/source/commands/status.ts +12 -0
  81. package/source/commands/theme.ts +12 -0
  82. package/source/commands/update.spec.tsx +261 -0
  83. package/source/commands/update.tsx +201 -0
  84. package/source/commands/usage.spec.tsx +495 -0
  85. package/source/commands/usage.tsx +100 -0
  86. package/source/commands.spec.ts +436 -0
  87. package/source/commands.ts +83 -0
  88. package/source/components/assistant-message.spec.tsx +796 -0
  89. package/source/components/assistant-message.tsx +34 -0
  90. package/source/components/bash-execution-indicator.tsx +21 -0
  91. package/source/components/cancelling-indicator.tsx +16 -0
  92. package/source/components/chat-queue.spec.tsx +83 -0
  93. package/source/components/chat-queue.tsx +36 -0
  94. package/source/components/checkpoint-display.spec.tsx +219 -0
  95. package/source/components/checkpoint-display.tsx +126 -0
  96. package/source/components/checkpoint-selector.spec.tsx +173 -0
  97. package/source/components/checkpoint-selector.tsx +173 -0
  98. package/source/components/development-mode-indicator.spec.tsx +268 -0
  99. package/source/components/development-mode-indicator.tsx +38 -0
  100. package/source/components/message-box.spec.tsx +427 -0
  101. package/source/components/message-box.tsx +87 -0
  102. package/source/components/model-selector.tsx +132 -0
  103. package/source/components/provider-selector.tsx +75 -0
  104. package/source/components/random-spinner.tsx +19 -0
  105. package/source/components/security-disclaimer.tsx +73 -0
  106. package/source/components/status-connection-display.spec.tsx +133 -0
  107. package/source/components/status.tsx +267 -0
  108. package/source/components/theme-selector.tsx +126 -0
  109. package/source/components/tool-confirmation.tsx +190 -0
  110. package/source/components/tool-execution-indicator.tsx +33 -0
  111. package/source/components/tool-message.tsx +85 -0
  112. package/source/components/ui/titled-box.spec.tsx +207 -0
  113. package/source/components/ui/titled-box.tsx +57 -0
  114. package/source/components/usage/progress-bar.spec.tsx +398 -0
  115. package/source/components/usage/progress-bar.tsx +30 -0
  116. package/source/components/usage/usage-display.spec.tsx +780 -0
  117. package/source/components/usage/usage-display.tsx +291 -0
  118. package/source/components/user-input.spec.tsx +327 -0
  119. package/source/components/user-input.tsx +533 -0
  120. package/source/components/user-message.spec.tsx +230 -0
  121. package/source/components/user-message.tsx +84 -0
  122. package/source/components/welcome-message.tsx +76 -0
  123. package/source/config/env-substitution.ts +65 -0
  124. package/source/config/index.spec.ts +171 -0
  125. package/source/config/index.ts +154 -0
  126. package/source/config/paths.spec.ts +241 -0
  127. package/source/config/paths.ts +55 -0
  128. package/source/config/preferences.ts +51 -0
  129. package/source/config/themes.ts +315 -0
  130. package/source/constants.ts +130 -0
  131. package/source/context/mode-context.spec.ts +79 -0
  132. package/source/context/mode-context.ts +24 -0
  133. package/source/custom-commands/executor.spec.ts +142 -0
  134. package/source/custom-commands/executor.ts +64 -0
  135. package/source/custom-commands/loader.spec.ts +314 -0
  136. package/source/custom-commands/loader.ts +153 -0
  137. package/source/custom-commands/parser.ts +196 -0
  138. package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +39 -0
  139. package/source/hooks/chat-handler/conversation/conversation-loop.tsx +511 -0
  140. package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +50 -0
  141. package/source/hooks/chat-handler/conversation/tool-executor.tsx +109 -0
  142. package/source/hooks/chat-handler/index.ts +12 -0
  143. package/source/hooks/chat-handler/state/streaming-state.spec.ts +26 -0
  144. package/source/hooks/chat-handler/state/streaming-state.ts +19 -0
  145. package/source/hooks/chat-handler/types.ts +38 -0
  146. package/source/hooks/chat-handler/useChatHandler.spec.tsx +321 -0
  147. package/source/hooks/chat-handler/useChatHandler.tsx +194 -0
  148. package/source/hooks/chat-handler/utils/context-checker.spec.ts +60 -0
  149. package/source/hooks/chat-handler/utils/context-checker.tsx +73 -0
  150. package/source/hooks/chat-handler/utils/message-helpers.spec.ts +42 -0
  151. package/source/hooks/chat-handler/utils/message-helpers.tsx +36 -0
  152. package/source/hooks/chat-handler/utils/tool-filters.spec.ts +109 -0
  153. package/source/hooks/chat-handler/utils/tool-filters.ts +64 -0
  154. package/source/hooks/useAppHandlers.tsx +291 -0
  155. package/source/hooks/useAppInitialization.tsx +422 -0
  156. package/source/hooks/useAppState.tsx +311 -0
  157. package/source/hooks/useDirectoryTrust.tsx +98 -0
  158. package/source/hooks/useInputState.ts +414 -0
  159. package/source/hooks/useModeHandlers.tsx +302 -0
  160. package/source/hooks/useNonInteractiveMode.ts +140 -0
  161. package/source/hooks/useTerminalWidth.tsx +81 -0
  162. package/source/hooks/useTheme.ts +18 -0
  163. package/source/hooks/useToolHandler.tsx +349 -0
  164. package/source/hooks/useUIState.ts +61 -0
  165. package/source/init/agents-template-generator.ts +421 -0
  166. package/source/init/existing-rules-extractor.ts +319 -0
  167. package/source/init/file-scanner.spec.ts +227 -0
  168. package/source/init/file-scanner.ts +238 -0
  169. package/source/init/framework-detector.ts +382 -0
  170. package/source/init/language-detector.ts +269 -0
  171. package/source/init/project-analyzer.spec.ts +231 -0
  172. package/source/init/project-analyzer.ts +458 -0
  173. package/source/lsp/index.ts +31 -0
  174. package/source/lsp/lsp-client.spec.ts +508 -0
  175. package/source/lsp/lsp-client.ts +487 -0
  176. package/source/lsp/lsp-manager.spec.ts +477 -0
  177. package/source/lsp/lsp-manager.ts +419 -0
  178. package/source/lsp/protocol.spec.ts +502 -0
  179. package/source/lsp/protocol.ts +360 -0
  180. package/source/lsp/server-discovery.spec.ts +654 -0
  181. package/source/lsp/server-discovery.ts +515 -0
  182. package/source/markdown-parser/html-entities.spec.ts +88 -0
  183. package/source/markdown-parser/html-entities.ts +45 -0
  184. package/source/markdown-parser/index.spec.ts +281 -0
  185. package/source/markdown-parser/index.ts +126 -0
  186. package/source/markdown-parser/table-parser.spec.ts +133 -0
  187. package/source/markdown-parser/table-parser.ts +114 -0
  188. package/source/markdown-parser/utils.spec.ts +70 -0
  189. package/source/markdown-parser/utils.ts +13 -0
  190. package/source/mcp/mcp-client.spec.ts +81 -0
  191. package/source/mcp/mcp-client.ts +625 -0
  192. package/source/mcp/transport-factory.spec.ts +406 -0
  193. package/source/mcp/transport-factory.ts +312 -0
  194. package/source/message-handler.ts +67 -0
  195. package/source/model-database/database-engine.spec.ts +494 -0
  196. package/source/model-database/database-engine.ts +50 -0
  197. package/source/model-database/model-database.spec.ts +363 -0
  198. package/source/model-database/model-database.ts +91 -0
  199. package/source/model-database/model-engine.spec.ts +447 -0
  200. package/source/model-database/model-engine.ts +65 -0
  201. package/source/model-database/model-fetcher.spec.ts +583 -0
  202. package/source/model-database/model-fetcher.ts +330 -0
  203. package/source/models/index.ts +1 -0
  204. package/source/models/models-cache.spec.ts +214 -0
  205. package/source/models/models-cache.ts +78 -0
  206. package/source/models/models-dev-client.spec.ts +379 -0
  207. package/source/models/models-dev-client.ts +329 -0
  208. package/source/models/models-types.ts +68 -0
  209. package/source/prompt-history.ts +155 -0
  210. package/source/security/command-injection.spec.ts +240 -0
  211. package/source/services/checkpoint-manager.spec.ts +523 -0
  212. package/source/services/checkpoint-manager.ts +466 -0
  213. package/source/services/file-snapshot.spec.ts +569 -0
  214. package/source/services/file-snapshot.ts +220 -0
  215. package/source/test-utils/render-with-theme.tsx +48 -0
  216. package/source/tokenization/index.ts +1 -0
  217. package/source/tokenization/tokenizer-factory.spec.ts +170 -0
  218. package/source/tokenization/tokenizer-factory.ts +125 -0
  219. package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +200 -0
  220. package/source/tokenization/tokenizers/anthropic-tokenizer.ts +43 -0
  221. package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +236 -0
  222. package/source/tokenization/tokenizers/fallback-tokenizer.ts +26 -0
  223. package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +224 -0
  224. package/source/tokenization/tokenizers/llama-tokenizer.ts +41 -0
  225. package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +184 -0
  226. package/source/tokenization/tokenizers/openai-tokenizer.ts +57 -0
  227. package/source/tool-calling/index.ts +5 -0
  228. package/source/tool-calling/json-parser.spec.ts +639 -0
  229. package/source/tool-calling/json-parser.ts +247 -0
  230. package/source/tool-calling/tool-parser.spec.ts +395 -0
  231. package/source/tool-calling/tool-parser.ts +120 -0
  232. package/source/tool-calling/xml-parser.spec.ts +662 -0
  233. package/source/tool-calling/xml-parser.ts +289 -0
  234. package/source/tools/execute-bash.spec.tsx +353 -0
  235. package/source/tools/execute-bash.tsx +219 -0
  236. package/source/tools/execute-function.spec.ts +130 -0
  237. package/source/tools/fetch-url.spec.tsx +342 -0
  238. package/source/tools/fetch-url.tsx +172 -0
  239. package/source/tools/find-files.spec.tsx +924 -0
  240. package/source/tools/find-files.tsx +293 -0
  241. package/source/tools/index.ts +102 -0
  242. package/source/tools/lsp-get-diagnostics.tsx +192 -0
  243. package/source/tools/needs-approval.spec.ts +282 -0
  244. package/source/tools/read-file.spec.tsx +801 -0
  245. package/source/tools/read-file.tsx +387 -0
  246. package/source/tools/search-file-contents.spec.tsx +1273 -0
  247. package/source/tools/search-file-contents.tsx +293 -0
  248. package/source/tools/string-replace.spec.tsx +730 -0
  249. package/source/tools/string-replace.tsx +548 -0
  250. package/source/tools/tool-manager.ts +210 -0
  251. package/source/tools/tool-registry.spec.ts +415 -0
  252. package/source/tools/tool-registry.ts +228 -0
  253. package/source/tools/web-search.tsx +223 -0
  254. package/source/tools/write-file.spec.tsx +559 -0
  255. package/source/tools/write-file.tsx +228 -0
  256. package/source/types/app.ts +37 -0
  257. package/source/types/checkpoint.ts +48 -0
  258. package/source/types/commands.ts +46 -0
  259. package/source/types/components.ts +27 -0
  260. package/source/types/config.ts +103 -0
  261. package/source/types/core-connection-status.spec.ts +67 -0
  262. package/source/types/core.ts +181 -0
  263. package/source/types/hooks.ts +50 -0
  264. package/source/types/index.ts +12 -0
  265. package/source/types/markdown-parser.ts +11 -0
  266. package/source/types/mcp.ts +52 -0
  267. package/source/types/system.ts +16 -0
  268. package/source/types/tokenization.ts +41 -0
  269. package/source/types/ui.ts +40 -0
  270. package/source/types/usage.ts +58 -0
  271. package/source/types/utils.ts +16 -0
  272. package/source/usage/calculator.spec.ts +385 -0
  273. package/source/usage/calculator.ts +104 -0
  274. package/source/usage/storage.spec.ts +703 -0
  275. package/source/usage/storage.ts +238 -0
  276. package/source/usage/tracker.spec.ts +456 -0
  277. package/source/usage/tracker.ts +102 -0
  278. package/source/utils/atomic-deletion.spec.ts +194 -0
  279. package/source/utils/atomic-deletion.ts +127 -0
  280. package/source/utils/bounded-map.spec.ts +300 -0
  281. package/source/utils/bounded-map.ts +193 -0
  282. package/source/utils/checkpoint-utils.spec.ts +222 -0
  283. package/source/utils/checkpoint-utils.ts +92 -0
  284. package/source/utils/error-formatter.spec.ts +169 -0
  285. package/source/utils/error-formatter.ts +194 -0
  286. package/source/utils/file-autocomplete.spec.ts +173 -0
  287. package/source/utils/file-autocomplete.ts +196 -0
  288. package/source/utils/file-cache.spec.ts +309 -0
  289. package/source/utils/file-cache.ts +195 -0
  290. package/source/utils/file-content-loader.spec.ts +180 -0
  291. package/source/utils/file-content-loader.ts +179 -0
  292. package/source/utils/file-mention-handler.spec.ts +261 -0
  293. package/source/utils/file-mention-handler.ts +84 -0
  294. package/source/utils/file-mention-parser.spec.ts +182 -0
  295. package/source/utils/file-mention-parser.ts +170 -0
  296. package/source/utils/fuzzy-matching.spec.ts +149 -0
  297. package/source/utils/fuzzy-matching.ts +146 -0
  298. package/source/utils/indentation-normalizer.spec.ts +216 -0
  299. package/source/utils/indentation-normalizer.ts +76 -0
  300. package/source/utils/installation-detector.spec.ts +178 -0
  301. package/source/utils/installation-detector.ts +153 -0
  302. package/source/utils/logging/config.spec.ts +311 -0
  303. package/source/utils/logging/config.ts +210 -0
  304. package/source/utils/logging/console-facade.spec.ts +184 -0
  305. package/source/utils/logging/console-facade.ts +384 -0
  306. package/source/utils/logging/correlation.spec.ts +679 -0
  307. package/source/utils/logging/correlation.ts +474 -0
  308. package/source/utils/logging/formatters.spec.ts +464 -0
  309. package/source/utils/logging/formatters.ts +207 -0
  310. package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +93 -0
  311. package/source/utils/logging/health-monitor/alerts/alert-manager.ts +79 -0
  312. package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +56 -0
  313. package/source/utils/logging/health-monitor/checks/configuration-check.ts +43 -0
  314. package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +56 -0
  315. package/source/utils/logging/health-monitor/checks/logging-check.ts +58 -0
  316. package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +100 -0
  317. package/source/utils/logging/health-monitor/checks/memory-check.ts +78 -0
  318. package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +56 -0
  319. package/source/utils/logging/health-monitor/checks/performance-check.ts +56 -0
  320. package/source/utils/logging/health-monitor/checks/request-check.spec.ts +56 -0
  321. package/source/utils/logging/health-monitor/checks/request-check.ts +76 -0
  322. package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +70 -0
  323. package/source/utils/logging/health-monitor/core/health-check-runner.ts +138 -0
  324. package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +58 -0
  325. package/source/utils/logging/health-monitor/core/health-monitor.ts +344 -0
  326. package/source/utils/logging/health-monitor/core/scoring.spec.ts +65 -0
  327. package/source/utils/logging/health-monitor/core/scoring.ts +91 -0
  328. package/source/utils/logging/health-monitor/index.ts +15 -0
  329. package/source/utils/logging/health-monitor/instances.ts +48 -0
  330. package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +141 -0
  331. package/source/utils/logging/health-monitor/middleware/http-middleware.ts +75 -0
  332. package/source/utils/logging/health-monitor/types.ts +126 -0
  333. package/source/utils/logging/index.spec.ts +284 -0
  334. package/source/utils/logging/index.ts +236 -0
  335. package/source/utils/logging/integration.spec.ts +441 -0
  336. package/source/utils/logging/log-method-factory.spec.ts +573 -0
  337. package/source/utils/logging/log-method-factory.ts +233 -0
  338. package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +277 -0
  339. package/source/utils/logging/log-query/aggregation/aggregator.ts +159 -0
  340. package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +159 -0
  341. package/source/utils/logging/log-query/aggregation/facet-generator.ts +47 -0
  342. package/source/utils/logging/log-query/index.ts +23 -0
  343. package/source/utils/logging/log-query/query/filter-predicates.spec.ts +247 -0
  344. package/source/utils/logging/log-query/query/filter-predicates.ts +154 -0
  345. package/source/utils/logging/log-query/query/query-builder.spec.ts +182 -0
  346. package/source/utils/logging/log-query/query/query-builder.ts +151 -0
  347. package/source/utils/logging/log-query/query/query-engine.spec.ts +214 -0
  348. package/source/utils/logging/log-query/query/query-engine.ts +45 -0
  349. package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +143 -0
  350. package/source/utils/logging/log-query/storage/circular-buffer.ts +75 -0
  351. package/source/utils/logging/log-query/storage/index-manager.spec.ts +150 -0
  352. package/source/utils/logging/log-query/storage/index-manager.ts +71 -0
  353. package/source/utils/logging/log-query/storage/log-storage.spec.ts +257 -0
  354. package/source/utils/logging/log-query/storage/log-storage.ts +80 -0
  355. package/source/utils/logging/log-query/types.ts +163 -0
  356. package/source/utils/logging/log-query/utils/helpers.spec.ts +263 -0
  357. package/source/utils/logging/log-query/utils/helpers.ts +72 -0
  358. package/source/utils/logging/log-query/utils/sorting.spec.ts +182 -0
  359. package/source/utils/logging/log-query/utils/sorting.ts +61 -0
  360. package/source/utils/logging/logger-provider.spec.ts +262 -0
  361. package/source/utils/logging/logger-provider.ts +362 -0
  362. package/source/utils/logging/performance.spec.ts +209 -0
  363. package/source/utils/logging/performance.ts +757 -0
  364. package/source/utils/logging/pino-logger.spec.ts +425 -0
  365. package/source/utils/logging/pino-logger.ts +514 -0
  366. package/source/utils/logging/redaction.spec.ts +490 -0
  367. package/source/utils/logging/redaction.ts +267 -0
  368. package/source/utils/logging/request-tracker.spec.ts +1198 -0
  369. package/source/utils/logging/request-tracker.ts +803 -0
  370. package/source/utils/logging/transports.spec.ts +505 -0
  371. package/source/utils/logging/transports.ts +305 -0
  372. package/source/utils/logging/types.ts +216 -0
  373. package/source/utils/message-builder.spec.ts +179 -0
  374. package/source/utils/message-builder.ts +101 -0
  375. package/source/utils/message-queue.tsx +486 -0
  376. package/source/utils/paste-detection.spec.ts +69 -0
  377. package/source/utils/paste-detection.ts +124 -0
  378. package/source/utils/paste-roundtrip.spec.ts +442 -0
  379. package/source/utils/paste-utils.spec.ts +128 -0
  380. package/source/utils/paste-utils.ts +52 -0
  381. package/source/utils/programming-language-helper.spec.ts +74 -0
  382. package/source/utils/programming-language-helper.ts +32 -0
  383. package/source/utils/prompt-assembly.spec.ts +221 -0
  384. package/source/utils/prompt-processor.ts +173 -0
  385. package/source/utils/tool-args-parser.spec.ts +136 -0
  386. package/source/utils/tool-args-parser.ts +54 -0
  387. package/source/utils/tool-cancellation.spec.ts +230 -0
  388. package/source/utils/tool-cancellation.ts +28 -0
  389. package/source/utils/tool-result-display.spec.tsx +469 -0
  390. package/source/utils/tool-result-display.tsx +90 -0
  391. package/source/utils/update-checker.spec.ts +383 -0
  392. package/source/utils/update-checker.ts +183 -0
  393. package/source/wizard/config-wizard.spec.tsx +103 -0
  394. package/source/wizard/config-wizard.tsx +382 -0
  395. package/source/wizard/steps/location-step.spec.tsx +186 -0
  396. package/source/wizard/steps/location-step.tsx +147 -0
  397. package/source/wizard/steps/mcp-step.spec.tsx +607 -0
  398. package/source/wizard/steps/mcp-step.tsx +632 -0
  399. package/source/wizard/steps/provider-step.spec.tsx +342 -0
  400. package/source/wizard/steps/provider-step.tsx +957 -0
  401. package/source/wizard/steps/summary-step.spec.tsx +749 -0
  402. package/source/wizard/steps/summary-step.tsx +228 -0
  403. package/source/wizard/templates/mcp-templates.spec.ts +613 -0
  404. package/source/wizard/templates/mcp-templates.ts +570 -0
  405. package/source/wizard/templates/provider-templates.spec.ts +152 -0
  406. package/source/wizard/templates/provider-templates.ts +485 -0
  407. package/source/wizard/utils/fetch-cloud-models.spec.ts +428 -0
  408. package/source/wizard/utils/fetch-cloud-models.ts +223 -0
  409. package/source/wizard/utils/fetch-local-models.spec.ts +297 -0
  410. package/source/wizard/utils/fetch-local-models.ts +192 -0
  411. package/source/wizard/validation-array.spec.ts +264 -0
  412. package/source/wizard/validation.spec.ts +373 -0
  413. package/source/wizard/validation.ts +232 -0
  414. package/source/app/prompts/main-prompt.md +0 -122
@@ -0,0 +1,210 @@
1
+ import {MCPClient} from '@/mcp/mcp-client';
2
+ import {
3
+ nativeToolsRegistry as staticNativeToolsRegistry,
4
+ toolFormatters as staticToolFormatters,
5
+ toolRegistry as staticToolRegistry,
6
+ toolValidators as staticToolValidators,
7
+ } from '@/tools/index';
8
+ import {ToolRegistry} from '@/tools/tool-registry';
9
+ import type {
10
+ AISDKCoreTool,
11
+ MCPInitResult,
12
+ MCPServer,
13
+ MCPTool,
14
+ ToolEntry,
15
+ ToolFormatter,
16
+ ToolHandler,
17
+ ToolValidator,
18
+ } from '@/types/index';
19
+
20
+ /**
21
+ * Manages both static tools and dynamic MCP tools
22
+ * All tools are stored in unified ToolEntry format via ToolRegistry
23
+ */
24
+ export class ToolManager {
25
+ /**
26
+ * Unified tool registry using ToolRegistry helper class
27
+ */
28
+ private registry: ToolRegistry;
29
+
30
+ /**
31
+ * MCP client for dynamic tool discovery and execution
32
+ */
33
+ private mcpClient: MCPClient | null = null;
34
+
35
+ constructor() {
36
+ // Initialize with static tools using ToolRegistry factory method
37
+ this.registry = ToolRegistry.fromRegistries(
38
+ staticToolRegistry,
39
+ staticNativeToolsRegistry,
40
+ staticToolFormatters,
41
+ staticToolValidators,
42
+ );
43
+ }
44
+
45
+ /**
46
+ * Initialize MCP servers and register their tools
47
+ */
48
+ async initializeMCP(
49
+ servers: MCPServer[],
50
+ onProgress?: (result: MCPInitResult) => void,
51
+ ): Promise<MCPInitResult[]> {
52
+ if (servers && servers.length > 0) {
53
+ this.mcpClient = new MCPClient();
54
+
55
+ const results = await this.mcpClient.connectToServers(
56
+ servers,
57
+ onProgress,
58
+ );
59
+
60
+ // Register MCP tools using ToolRegistry
61
+ // getToolEntries() returns structured ToolEntry objects
62
+ const mcpToolEntries = this.mcpClient.getToolEntries();
63
+ this.registry.registerMany(mcpToolEntries);
64
+
65
+ return results;
66
+ }
67
+ return [];
68
+ }
69
+
70
+ /**
71
+ * Get all available native AI SDK tools (static + MCP)
72
+ */
73
+ getAllTools(): Record<string, AISDKCoreTool> {
74
+ return this.registry.getNativeTools();
75
+ }
76
+
77
+ /**
78
+ * Get all tool handlers
79
+ */
80
+ getToolRegistry(): Record<string, ToolHandler> {
81
+ return this.registry.getHandlers();
82
+ }
83
+
84
+ /**
85
+ * Get a specific tool handler
86
+ */
87
+ getToolHandler(toolName: string): ToolHandler | undefined {
88
+ return this.registry.getHandler(toolName);
89
+ }
90
+
91
+ /**
92
+ * Get a specific tool formatter
93
+ */
94
+ getToolFormatter(toolName: string): ToolFormatter | undefined {
95
+ return this.registry.getFormatter(toolName);
96
+ }
97
+
98
+ /**
99
+ * Get a specific tool validator
100
+ */
101
+ getToolValidator(toolName: string): ToolValidator | undefined {
102
+ return this.registry.getValidator(toolName);
103
+ }
104
+
105
+ /**
106
+ * Check if a tool exists
107
+ */
108
+ hasTool(toolName: string): boolean {
109
+ return this.registry.hasTool(toolName);
110
+ }
111
+
112
+ /**
113
+ * Check if a tool is an MCP tool and get server info
114
+ */
115
+ getMCPToolInfo(toolName: string): {isMCPTool: boolean; serverName?: string} {
116
+ if (!this.mcpClient) {
117
+ return {isMCPTool: false};
118
+ }
119
+
120
+ const toolMapping = this.mcpClient.getToolMapping();
121
+ const mapping = toolMapping.get(toolName);
122
+
123
+ if (mapping) {
124
+ return {
125
+ isMCPTool: true,
126
+ serverName: mapping.serverName,
127
+ };
128
+ }
129
+
130
+ return {isMCPTool: false};
131
+ }
132
+
133
+ /**
134
+ * Disconnect from MCP servers and remove their tools
135
+ */
136
+ async disconnectMCP(): Promise<void> {
137
+ if (this.mcpClient) {
138
+ // Get list of MCP tool names
139
+ const mcpTools = this.mcpClient.getNativeToolsRegistry();
140
+ const mcpToolNames = Object.keys(mcpTools);
141
+
142
+ // Remove all MCP tools from registry in one operation
143
+ this.registry.unregisterMany(mcpToolNames);
144
+
145
+ // Disconnect from servers
146
+ await this.mcpClient.disconnect();
147
+
148
+ // Reset registry to only static tools
149
+ this.registry = ToolRegistry.fromRegistries(
150
+ staticToolRegistry,
151
+ staticNativeToolsRegistry,
152
+ staticToolFormatters,
153
+ staticToolValidators,
154
+ );
155
+
156
+ this.mcpClient = null;
157
+ }
158
+ }
159
+
160
+ /**
161
+ * Get a complete tool entry (all metadata)
162
+ *
163
+ * Returns the full ToolEntry with all components (tool, handler, formatter, validator)
164
+ */
165
+ getToolEntry(toolName: string): ToolEntry | undefined {
166
+ return this.registry.getEntry(toolName);
167
+ }
168
+
169
+ /**
170
+ * Get all registered tool names
171
+ */
172
+ getToolNames(): string[] {
173
+ return this.registry.getToolNames();
174
+ }
175
+
176
+ /**
177
+ * Get total number of registered tools
178
+ */
179
+ getToolCount(): number {
180
+ return this.registry.getToolCount();
181
+ }
182
+
183
+ /**
184
+ * Get connected MCP servers
185
+ */
186
+ getConnectedServers(): string[] {
187
+ return this.mcpClient?.getConnectedServers() || [];
188
+ }
189
+
190
+ /**
191
+ * Get tools for a specific MCP server
192
+ */
193
+ getServerTools(serverName: string): MCPTool[] {
194
+ return this.mcpClient?.getServerTools(serverName) || [];
195
+ }
196
+
197
+ /**
198
+ * Get server information including transport type and URL
199
+ */
200
+ getServerInfo(serverName: string) {
201
+ return this.mcpClient?.getServerInfo(serverName);
202
+ }
203
+
204
+ /**
205
+ * Get the MCP client instance
206
+ */
207
+ getMCPClient() {
208
+ return this.mcpClient;
209
+ }
210
+ }
@@ -0,0 +1,415 @@
1
+ import test from 'ava';
2
+ import { ToolRegistry } from './tool-registry';
3
+ import type { ToolEntry } from '@/types/index';
4
+
5
+ // Mock tool handler function - returns Promise<string>
6
+ const mockHandler: ToolEntry['handler'] = async () => 'test result';
7
+
8
+ // Mock formatter function
9
+ const mockFormatter: ToolEntry['formatter'] = (output: unknown) => {
10
+ return String(output);
11
+ };
12
+
13
+ // Mock validator function - returns Promise<{valid: true} | {valid: false, error: string}>
14
+ const mockValidator: ToolEntry['validator'] = async () => ({ valid: true });
15
+
16
+ // Mock AI SDK tool - cast to any since we're just testing registry functionality
17
+ const mockTool: ToolEntry['tool'] = {
18
+ execute: async () => 'test result',
19
+ } as any;
20
+
21
+ function createMockToolEntry(overrides: Partial<ToolEntry> = {}): ToolEntry {
22
+ return {
23
+ name: 'test-tool',
24
+ handler: mockHandler,
25
+ tool: mockTool,
26
+ formatter: mockFormatter,
27
+ validator: mockValidator,
28
+ ...overrides
29
+ } as ToolEntry;
30
+ }
31
+
32
+ test('ToolRegistry - register adds a tool entry', t => {
33
+ const registry = new ToolRegistry();
34
+ const entry = createMockToolEntry();
35
+
36
+ registry.register(entry);
37
+
38
+ t.true(registry.hasTool('test-tool'));
39
+ t.is(registry.getToolCount(), 1);
40
+ });
41
+
42
+ test('ToolRegistry - registerMany adds multiple tools', t => {
43
+ const registry = new ToolRegistry();
44
+ const entries = [
45
+ createMockToolEntry({ name: 'tool1' }),
46
+ createMockToolEntry({ name: 'tool2' }),
47
+ createMockToolEntry({ name: 'tool3' })
48
+ ];
49
+
50
+ registry.registerMany(entries);
51
+
52
+ t.is(registry.getToolCount(), 3);
53
+ t.true(registry.hasTool('tool1'));
54
+ t.true(registry.hasTool('tool2'));
55
+ t.true(registry.hasTool('tool3'));
56
+ });
57
+
58
+ test('ToolRegistry - registerMany with empty array', t => {
59
+ const registry = new ToolRegistry();
60
+
61
+ registry.registerMany([]);
62
+
63
+ t.is(registry.getToolCount(), 0);
64
+ });
65
+
66
+ test('ToolRegistry - unregister removes a tool', t => {
67
+ const registry = new ToolRegistry();
68
+ const entry = createMockToolEntry();
69
+
70
+ registry.register(entry);
71
+ t.true(registry.hasTool('test-tool'));
72
+
73
+ registry.unregister('test-tool');
74
+ t.false(registry.hasTool('test-tool'));
75
+ });
76
+
77
+ test('ToolRegistry - unregisterMany removes multiple tools', t => {
78
+ const registry = new ToolRegistry();
79
+ registry.registerMany([
80
+ createMockToolEntry({ name: 'tool1' }),
81
+ createMockToolEntry({ name: 'tool2' }),
82
+ createMockToolEntry({ name: 'tool3' })
83
+ ]);
84
+
85
+ registry.unregisterMany(['tool1', 'tool3']);
86
+
87
+ t.false(registry.hasTool('tool1'));
88
+ t.true(registry.hasTool('tool2'));
89
+ t.false(registry.hasTool('tool3'));
90
+ });
91
+
92
+ test('ToolRegistry - unregisterMany with empty array', t => {
93
+ const registry = new ToolRegistry();
94
+ const entry = createMockToolEntry();
95
+
96
+ registry.register(entry);
97
+ registry.unregisterMany([]);
98
+
99
+ t.true(registry.hasTool('test-tool'));
100
+ });
101
+
102
+ test('ToolRegistry - getEntry returns tool entry', t => {
103
+ const registry = new ToolRegistry();
104
+ const entry = createMockToolEntry();
105
+
106
+ registry.register(entry);
107
+ const retrieved = registry.getEntry('test-tool');
108
+
109
+ t.truthy(retrieved);
110
+ t.is(retrieved?.name, 'test-tool');
111
+ });
112
+
113
+ test('ToolRegistry - getEntry returns undefined for non-existent tool', t => {
114
+ const registry = new ToolRegistry();
115
+
116
+ const retrieved = registry.getEntry('non-existent');
117
+
118
+ t.is(retrieved, undefined);
119
+ });
120
+
121
+ test('ToolRegistry - getHandler returns tool handler', t => {
122
+ const registry = new ToolRegistry();
123
+ const entry = createMockToolEntry();
124
+
125
+ registry.register(entry);
126
+ const handler = registry.getHandler('test-tool');
127
+
128
+ t.truthy(handler);
129
+ t.is(handler, mockHandler);
130
+ });
131
+
132
+ test('ToolRegistry - getHandler returns undefined for non-existent tool', t => {
133
+ const registry = new ToolRegistry();
134
+
135
+ const handler = registry.getHandler('non-existent');
136
+
137
+ t.is(handler, undefined);
138
+ });
139
+
140
+ test('ToolRegistry - getFormatter returns tool formatter', t => {
141
+ const registry = new ToolRegistry();
142
+ const entry = createMockToolEntry();
143
+
144
+ registry.register(entry);
145
+ const formatter = registry.getFormatter('test-tool');
146
+
147
+ t.truthy(formatter);
148
+ t.is(formatter, mockFormatter);
149
+ });
150
+
151
+ test('ToolRegistry - getFormatter returns undefined when no formatter', t => {
152
+ const registry = new ToolRegistry();
153
+ const entry = createMockToolEntry({ formatter: undefined });
154
+
155
+ registry.register(entry);
156
+ const formatter = registry.getFormatter('test-tool');
157
+
158
+ t.is(formatter, undefined);
159
+ });
160
+
161
+ test('ToolRegistry - getValidator returns tool validator', t => {
162
+ const registry = new ToolRegistry();
163
+ const entry = createMockToolEntry();
164
+
165
+ registry.register(entry);
166
+ const validator = registry.getValidator('test-tool');
167
+
168
+ t.truthy(validator);
169
+ t.is(validator, mockValidator);
170
+ });
171
+
172
+ test('ToolRegistry - getValidator returns undefined when no validator', t => {
173
+ const registry = new ToolRegistry();
174
+ const entry = createMockToolEntry({ validator: undefined });
175
+
176
+ registry.register(entry);
177
+ const validator = registry.getValidator('test-tool');
178
+
179
+ t.is(validator, undefined);
180
+ });
181
+
182
+ test('ToolRegistry - getTool returns native AI SDK tool', t => {
183
+ const registry = new ToolRegistry();
184
+ const entry = createMockToolEntry();
185
+
186
+ registry.register(entry);
187
+ const tool = registry.getTool('test-tool');
188
+
189
+ t.truthy(tool);
190
+ t.is(tool, mockTool);
191
+ });
192
+
193
+ test('ToolRegistry - getTool returns undefined for non-existent tool', t => {
194
+ const registry = new ToolRegistry();
195
+
196
+ const tool = registry.getTool('non-existent');
197
+
198
+ t.is(tool, undefined);
199
+ });
200
+
201
+ test('ToolRegistry - getHandlers returns record of all handlers', t => {
202
+ const registry = new ToolRegistry();
203
+ const handler1: ToolEntry['handler'] = async () => 'result 1';
204
+ const handler2: ToolEntry['handler'] = async () => 'result 2';
205
+
206
+ registry.registerMany([
207
+ createMockToolEntry({ name: 'tool1', handler: handler1 }),
208
+ createMockToolEntry({ name: 'tool2', handler: handler2 })
209
+ ]);
210
+
211
+ const handlers = registry.getHandlers();
212
+
213
+ t.is(handlers.tool1, handler1);
214
+ t.is(handlers.tool2, handler2);
215
+ });
216
+
217
+ test('ToolRegistry - getHandlers returns empty object when no tools', t => {
218
+ const registry = new ToolRegistry();
219
+
220
+ const handlers = registry.getHandlers();
221
+
222
+ t.deepEqual(handlers, {});
223
+ });
224
+
225
+ test('ToolRegistry - getFormatters returns record of formatters', t => {
226
+ const registry = new ToolRegistry();
227
+ const formatter1: ToolEntry['formatter'] = (o) => String(o);
228
+ const formatter2: ToolEntry['formatter'] = (o) => String(o);
229
+
230
+ registry.registerMany([
231
+ createMockToolEntry({ name: 'tool1', formatter: formatter1 }),
232
+ createMockToolEntry({ name: 'tool2', formatter: formatter2 }),
233
+ createMockToolEntry({ name: 'tool3', formatter: undefined })
234
+ ]);
235
+
236
+ const formatters = registry.getFormatters();
237
+
238
+ t.is(formatters.tool1, formatter1);
239
+ t.is(formatters.tool2, formatter2);
240
+ // tool3 has no formatter, so it shouldn't be in the record
241
+ t.false('tool3' in formatters);
242
+ });
243
+
244
+ test('ToolRegistry - getValidators returns record of validators', t => {
245
+ const registry = new ToolRegistry();
246
+ const validator1: ToolEntry['validator'] = async () => ({ valid: true });
247
+ const validator2: ToolEntry['validator'] = async () => ({ valid: false, error: 'test error' });
248
+
249
+ registry.registerMany([
250
+ createMockToolEntry({ name: 'tool1', validator: validator1 }),
251
+ createMockToolEntry({ name: 'tool2', validator: validator2 }),
252
+ createMockToolEntry({ name: 'tool3', validator: undefined })
253
+ ]);
254
+
255
+ const validators = registry.getValidators();
256
+
257
+ t.is(validators.tool1, validator1);
258
+ t.is(validators.tool2, validator2);
259
+ // tool3 has no validator, so it shouldn't be in the record
260
+ t.false('tool3' in validators);
261
+ });
262
+
263
+ test('ToolRegistry - getNativeTools returns record of native tools', t => {
264
+ const registry = new ToolRegistry();
265
+ const tool1: ToolEntry['tool'] = { execute: async () => 'test 1' } as any;
266
+ const tool2: ToolEntry['tool'] = { execute: async () => 'test 2' } as any;
267
+
268
+ registry.registerMany([
269
+ createMockToolEntry({ name: 'tool1', tool: tool1 }),
270
+ createMockToolEntry({ name: 'tool2', tool: tool2 })
271
+ ]);
272
+
273
+ const nativeTools = registry.getNativeTools();
274
+
275
+ t.is(nativeTools.tool1, tool1);
276
+ t.is(nativeTools.tool2, tool2);
277
+ });
278
+
279
+ test('ToolRegistry - getAllEntries returns array of all entries', t => {
280
+ const registry = new ToolRegistry();
281
+ const entry1 = createMockToolEntry({ name: 'tool1' });
282
+ const entry2 = createMockToolEntry({ name: 'tool2' });
283
+
284
+ registry.registerMany([entry1, entry2]);
285
+
286
+ const entries = registry.getAllEntries();
287
+
288
+ t.is(entries.length, 2);
289
+ t.true(entries.some(e => e.name === 'tool1'));
290
+ t.true(entries.some(e => e.name === 'tool2'));
291
+ });
292
+
293
+ test('ToolRegistry - getAllEntries returns empty array when no tools', t => {
294
+ const registry = new ToolRegistry();
295
+
296
+ const entries = registry.getAllEntries();
297
+
298
+ t.deepEqual(entries, []);
299
+ });
300
+
301
+ test('ToolRegistry - getToolNames returns array of tool names', t => {
302
+ const registry = new ToolRegistry();
303
+ registry.registerMany([
304
+ createMockToolEntry({ name: 'tool1' }),
305
+ createMockToolEntry({ name: 'tool2' }),
306
+ createMockToolEntry({ name: 'tool3' })
307
+ ]);
308
+
309
+ const names = registry.getToolNames();
310
+
311
+ t.is(names.length, 3);
312
+ t.true(names.includes('tool1'));
313
+ t.true(names.includes('tool2'));
314
+ t.true(names.includes('tool3'));
315
+ });
316
+
317
+ test('ToolRegistry - getToolNames returns empty array when no tools', t => {
318
+ const registry = new ToolRegistry();
319
+
320
+ const names = registry.getToolNames();
321
+
322
+ t.deepEqual(names, []);
323
+ });
324
+
325
+ test('ToolRegistry - hasTool returns true for registered tool', t => {
326
+ const registry = new ToolRegistry();
327
+ registry.register(createMockToolEntry());
328
+
329
+ t.true(registry.hasTool('test-tool'));
330
+ });
331
+
332
+ test('ToolRegistry - hasTool returns false for non-existent tool', t => {
333
+ const registry = new ToolRegistry();
334
+
335
+ t.false(registry.hasTool('non-existent'));
336
+ });
337
+
338
+ test('ToolRegistry - getToolCount returns correct count', t => {
339
+ const registry = new ToolRegistry();
340
+
341
+ t.is(registry.getToolCount(), 0);
342
+
343
+ registry.register(createMockToolEntry());
344
+ t.is(registry.getToolCount(), 1);
345
+
346
+ registry.registerMany([
347
+ createMockToolEntry({ name: 'tool1' }),
348
+ createMockToolEntry({ name: 'tool2' })
349
+ ]);
350
+ t.is(registry.getToolCount(), 3);
351
+ });
352
+
353
+ test('ToolRegistry - clear removes all tools', t => {
354
+ const registry = new ToolRegistry();
355
+ registry.registerMany([
356
+ createMockToolEntry({ name: 'tool1' }),
357
+ createMockToolEntry({ name: 'tool2' }),
358
+ createMockToolEntry({ name: 'tool3' })
359
+ ]);
360
+
361
+ registry.clear();
362
+
363
+ t.is(registry.getToolCount(), 0);
364
+ t.false(registry.hasTool('tool1'));
365
+ t.false(registry.hasTool('tool2'));
366
+ t.false(registry.hasTool('tool3'));
367
+ });
368
+
369
+ test('ToolRegistry - fromRegistries creates registry from records', t => {
370
+ const handler1: ToolEntry['handler'] = async () => 'test';
371
+ const handler2: ToolEntry['handler'] = async () => 'test';
372
+ const formatter1: ToolEntry['formatter'] = (o) => String(o);
373
+ const validator1: ToolEntry['validator'] = async () => ({ valid: true });
374
+ const tool1: ToolEntry['tool'] = { execute: async () => 'test' } as any;
375
+ const tool2: ToolEntry['tool'] = { execute: async () => 'test' } as any;
376
+
377
+ const handlers = { tool1: handler1, tool2: handler2 };
378
+ const tools = { tool1, tool2 };
379
+ const formatters = { tool1: formatter1 };
380
+ const validators = { tool1: validator1 };
381
+
382
+ const registry = ToolRegistry.fromRegistries(handlers, tools, formatters, validators);
383
+
384
+ t.is(registry.getToolCount(), 2);
385
+ t.true(registry.hasTool('tool1'));
386
+ t.true(registry.hasTool('tool2'));
387
+ t.is(registry.getHandler('tool1'), handler1);
388
+ t.is(registry.getFormatter('tool1'), formatter1);
389
+ t.is(registry.getValidator('tool1'), validator1);
390
+ });
391
+
392
+ test('ToolRegistry - fromRegistries with optional parameters', t => {
393
+ const handler: ToolEntry['handler'] = async () => 'test';
394
+ const tool: ToolEntry['tool'] = { execute: async () => 'test' } as any;
395
+
396
+ const registry = ToolRegistry.fromRegistries({ tool1: handler }, { tool1: tool });
397
+
398
+ t.is(registry.getToolCount(), 1);
399
+ t.is(registry.getFormatter('tool1'), undefined);
400
+ t.is(registry.getValidator('tool1'), undefined);
401
+ });
402
+
403
+ test('ToolRegistry - fromRegistries skips tools without matching handlers', t => {
404
+ const handler: ToolEntry['handler'] = async () => 'test';
405
+ const tool: ToolEntry['tool'] = { execute: async () => 'test' } as any;
406
+
407
+ const registry = ToolRegistry.fromRegistries(
408
+ { tool1: handler }, // Only has handler for tool1
409
+ { tool1: tool, tool2: tool } // But tools for tool1 and tool2
410
+ );
411
+
412
+ t.is(registry.getToolCount(), 1);
413
+ t.true(registry.hasTool('tool1'));
414
+ t.false(registry.hasTool('tool2'));
415
+ });