@gguf/coder 0.3.1 → 0.3.2
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.
- package/package.json +2 -2
- package/pnpm-workspace.yaml +15 -0
- package/color_picker.html +0 -36
- package/scripts/extract-changelog.js +0 -73
- package/scripts/fetch-models.js +0 -143
- package/scripts/test.sh +0 -40
- package/scripts/update-homebrew-formula.sh +0 -125
- package/scripts/update-nix-version.sh +0 -157
- package/source/ai-sdk-client/AISDKClient.spec.ts +0 -117
- package/source/ai-sdk-client/AISDKClient.ts +0 -155
- package/source/ai-sdk-client/chat/chat-handler.spec.ts +0 -121
- package/source/ai-sdk-client/chat/chat-handler.ts +0 -276
- package/source/ai-sdk-client/chat/streaming-handler.spec.ts +0 -173
- package/source/ai-sdk-client/chat/streaming-handler.ts +0 -110
- package/source/ai-sdk-client/chat/tool-processor.spec.ts +0 -92
- package/source/ai-sdk-client/chat/tool-processor.ts +0 -70
- package/source/ai-sdk-client/converters/message-converter.spec.ts +0 -220
- package/source/ai-sdk-client/converters/message-converter.ts +0 -113
- package/source/ai-sdk-client/converters/tool-converter.spec.ts +0 -90
- package/source/ai-sdk-client/converters/tool-converter.ts +0 -46
- package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +0 -55
- package/source/ai-sdk-client/error-handling/error-extractor.ts +0 -15
- package/source/ai-sdk-client/error-handling/error-parser.spec.ts +0 -169
- package/source/ai-sdk-client/error-handling/error-parser.ts +0 -161
- package/source/ai-sdk-client/index.ts +0 -7
- package/source/ai-sdk-client/providers/provider-factory.spec.ts +0 -71
- package/source/ai-sdk-client/providers/provider-factory.ts +0 -41
- package/source/ai-sdk-client/types.ts +0 -9
- package/source/ai-sdk-client-empty-message.spec.ts +0 -141
- package/source/ai-sdk-client-error-handling.spec.ts +0 -186
- package/source/ai-sdk-client-maxretries.spec.ts +0 -114
- package/source/ai-sdk-client-preparestep.spec.ts +0 -279
- package/source/app/App.spec.tsx +0 -32
- package/source/app/App.tsx +0 -480
- package/source/app/components/AppContainer.spec.tsx +0 -96
- package/source/app/components/AppContainer.tsx +0 -56
- package/source/app/components/ChatInterface.spec.tsx +0 -163
- package/source/app/components/ChatInterface.tsx +0 -144
- package/source/app/components/ModalSelectors.spec.tsx +0 -141
- package/source/app/components/ModalSelectors.tsx +0 -135
- package/source/app/helpers.spec.ts +0 -97
- package/source/app/helpers.ts +0 -63
- package/source/app/index.ts +0 -4
- package/source/app/types.ts +0 -39
- package/source/app/utils/appUtils.ts +0 -294
- package/source/app/utils/conversationState.ts +0 -310
- package/source/app.spec.tsx +0 -244
- package/source/cli.spec.ts +0 -73
- package/source/cli.tsx +0 -51
- package/source/client-factory.spec.ts +0 -48
- package/source/client-factory.ts +0 -178
- package/source/command-parser.spec.ts +0 -127
- package/source/command-parser.ts +0 -36
- package/source/commands/checkpoint.spec.tsx +0 -277
- package/source/commands/checkpoint.tsx +0 -366
- package/source/commands/clear.tsx +0 -22
- package/source/commands/custom-commands.tsx +0 -121
- package/source/commands/exit.ts +0 -21
- package/source/commands/export.spec.tsx +0 -131
- package/source/commands/export.tsx +0 -79
- package/source/commands/help.tsx +0 -120
- package/source/commands/index.ts +0 -17
- package/source/commands/init.tsx +0 -339
- package/source/commands/lsp-command.spec.tsx +0 -281
- package/source/commands/lsp.tsx +0 -120
- package/source/commands/mcp-command.spec.tsx +0 -313
- package/source/commands/mcp.tsx +0 -162
- package/source/commands/model-database.spec.tsx +0 -758
- package/source/commands/model-database.tsx +0 -418
- package/source/commands/model.ts +0 -12
- package/source/commands/provider.ts +0 -12
- package/source/commands/setup-config.tsx +0 -16
- package/source/commands/simple-commands.spec.tsx +0 -175
- package/source/commands/status.ts +0 -12
- package/source/commands/theme.ts +0 -12
- package/source/commands/update.spec.tsx +0 -261
- package/source/commands/update.tsx +0 -201
- package/source/commands/usage.spec.tsx +0 -495
- package/source/commands/usage.tsx +0 -100
- package/source/commands.spec.ts +0 -436
- package/source/commands.ts +0 -83
- package/source/components/assistant-message.spec.tsx +0 -796
- package/source/components/assistant-message.tsx +0 -34
- package/source/components/bash-execution-indicator.tsx +0 -21
- package/source/components/cancelling-indicator.tsx +0 -16
- package/source/components/chat-queue.spec.tsx +0 -83
- package/source/components/chat-queue.tsx +0 -36
- package/source/components/checkpoint-display.spec.tsx +0 -219
- package/source/components/checkpoint-display.tsx +0 -126
- package/source/components/checkpoint-selector.spec.tsx +0 -173
- package/source/components/checkpoint-selector.tsx +0 -173
- package/source/components/development-mode-indicator.spec.tsx +0 -268
- package/source/components/development-mode-indicator.tsx +0 -38
- package/source/components/message-box.spec.tsx +0 -427
- package/source/components/message-box.tsx +0 -87
- package/source/components/model-selector.tsx +0 -132
- package/source/components/provider-selector.tsx +0 -75
- package/source/components/random-spinner.tsx +0 -19
- package/source/components/security-disclaimer.tsx +0 -73
- package/source/components/status-connection-display.spec.tsx +0 -133
- package/source/components/status.tsx +0 -267
- package/source/components/theme-selector.tsx +0 -126
- package/source/components/tool-confirmation.tsx +0 -190
- package/source/components/tool-execution-indicator.tsx +0 -33
- package/source/components/tool-message.tsx +0 -85
- package/source/components/ui/titled-box.spec.tsx +0 -207
- package/source/components/ui/titled-box.tsx +0 -57
- package/source/components/usage/progress-bar.spec.tsx +0 -398
- package/source/components/usage/progress-bar.tsx +0 -30
- package/source/components/usage/usage-display.spec.tsx +0 -780
- package/source/components/usage/usage-display.tsx +0 -291
- package/source/components/user-input.spec.tsx +0 -327
- package/source/components/user-input.tsx +0 -533
- package/source/components/user-message.spec.tsx +0 -230
- package/source/components/user-message.tsx +0 -84
- package/source/components/welcome-message.tsx +0 -76
- package/source/config/env-substitution.ts +0 -65
- package/source/config/index.spec.ts +0 -171
- package/source/config/index.ts +0 -154
- package/source/config/paths.spec.ts +0 -241
- package/source/config/paths.ts +0 -55
- package/source/config/preferences.ts +0 -51
- package/source/config/themes.ts +0 -315
- package/source/constants.ts +0 -130
- package/source/context/mode-context.spec.ts +0 -79
- package/source/context/mode-context.ts +0 -24
- package/source/custom-commands/executor.spec.ts +0 -142
- package/source/custom-commands/executor.ts +0 -64
- package/source/custom-commands/loader.spec.ts +0 -314
- package/source/custom-commands/loader.ts +0 -153
- package/source/custom-commands/parser.ts +0 -196
- package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +0 -39
- package/source/hooks/chat-handler/conversation/conversation-loop.tsx +0 -511
- package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +0 -50
- package/source/hooks/chat-handler/conversation/tool-executor.tsx +0 -109
- package/source/hooks/chat-handler/index.ts +0 -12
- package/source/hooks/chat-handler/state/streaming-state.spec.ts +0 -26
- package/source/hooks/chat-handler/state/streaming-state.ts +0 -19
- package/source/hooks/chat-handler/types.ts +0 -38
- package/source/hooks/chat-handler/useChatHandler.spec.tsx +0 -321
- package/source/hooks/chat-handler/useChatHandler.tsx +0 -194
- package/source/hooks/chat-handler/utils/context-checker.spec.ts +0 -60
- package/source/hooks/chat-handler/utils/context-checker.tsx +0 -73
- package/source/hooks/chat-handler/utils/message-helpers.spec.ts +0 -42
- package/source/hooks/chat-handler/utils/message-helpers.tsx +0 -36
- package/source/hooks/chat-handler/utils/tool-filters.spec.ts +0 -109
- package/source/hooks/chat-handler/utils/tool-filters.ts +0 -64
- package/source/hooks/useAppHandlers.tsx +0 -291
- package/source/hooks/useAppInitialization.tsx +0 -422
- package/source/hooks/useAppState.tsx +0 -311
- package/source/hooks/useDirectoryTrust.tsx +0 -98
- package/source/hooks/useInputState.ts +0 -414
- package/source/hooks/useModeHandlers.tsx +0 -302
- package/source/hooks/useNonInteractiveMode.ts +0 -140
- package/source/hooks/useTerminalWidth.tsx +0 -81
- package/source/hooks/useTheme.ts +0 -18
- package/source/hooks/useToolHandler.tsx +0 -349
- package/source/hooks/useUIState.ts +0 -61
- package/source/init/agents-template-generator.ts +0 -421
- package/source/init/existing-rules-extractor.ts +0 -319
- package/source/init/file-scanner.spec.ts +0 -227
- package/source/init/file-scanner.ts +0 -238
- package/source/init/framework-detector.ts +0 -382
- package/source/init/language-detector.ts +0 -269
- package/source/init/project-analyzer.spec.ts +0 -231
- package/source/init/project-analyzer.ts +0 -458
- package/source/lsp/index.ts +0 -31
- package/source/lsp/lsp-client.spec.ts +0 -508
- package/source/lsp/lsp-client.ts +0 -487
- package/source/lsp/lsp-manager.spec.ts +0 -477
- package/source/lsp/lsp-manager.ts +0 -419
- package/source/lsp/protocol.spec.ts +0 -502
- package/source/lsp/protocol.ts +0 -360
- package/source/lsp/server-discovery.spec.ts +0 -654
- package/source/lsp/server-discovery.ts +0 -515
- package/source/markdown-parser/html-entities.spec.ts +0 -88
- package/source/markdown-parser/html-entities.ts +0 -45
- package/source/markdown-parser/index.spec.ts +0 -281
- package/source/markdown-parser/index.ts +0 -126
- package/source/markdown-parser/table-parser.spec.ts +0 -133
- package/source/markdown-parser/table-parser.ts +0 -114
- package/source/markdown-parser/utils.spec.ts +0 -70
- package/source/markdown-parser/utils.ts +0 -13
- package/source/mcp/mcp-client.spec.ts +0 -81
- package/source/mcp/mcp-client.ts +0 -625
- package/source/mcp/transport-factory.spec.ts +0 -406
- package/source/mcp/transport-factory.ts +0 -312
- package/source/message-handler.ts +0 -67
- package/source/model-database/database-engine.spec.ts +0 -494
- package/source/model-database/database-engine.ts +0 -50
- package/source/model-database/model-database.spec.ts +0 -363
- package/source/model-database/model-database.ts +0 -91
- package/source/model-database/model-engine.spec.ts +0 -447
- package/source/model-database/model-engine.ts +0 -65
- package/source/model-database/model-fetcher.spec.ts +0 -583
- package/source/model-database/model-fetcher.ts +0 -330
- package/source/models/index.ts +0 -1
- package/source/models/models-cache.spec.ts +0 -214
- package/source/models/models-cache.ts +0 -78
- package/source/models/models-dev-client.spec.ts +0 -379
- package/source/models/models-dev-client.ts +0 -329
- package/source/models/models-types.ts +0 -68
- package/source/prompt-history.ts +0 -155
- package/source/security/command-injection.spec.ts +0 -240
- package/source/services/checkpoint-manager.spec.ts +0 -523
- package/source/services/checkpoint-manager.ts +0 -466
- package/source/services/file-snapshot.spec.ts +0 -569
- package/source/services/file-snapshot.ts +0 -220
- package/source/test-utils/render-with-theme.tsx +0 -48
- package/source/tokenization/index.ts +0 -1
- package/source/tokenization/tokenizer-factory.spec.ts +0 -170
- package/source/tokenization/tokenizer-factory.ts +0 -125
- package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +0 -200
- package/source/tokenization/tokenizers/anthropic-tokenizer.ts +0 -43
- package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +0 -236
- package/source/tokenization/tokenizers/fallback-tokenizer.ts +0 -26
- package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +0 -224
- package/source/tokenization/tokenizers/llama-tokenizer.ts +0 -41
- package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +0 -184
- package/source/tokenization/tokenizers/openai-tokenizer.ts +0 -57
- package/source/tool-calling/index.ts +0 -5
- package/source/tool-calling/json-parser.spec.ts +0 -639
- package/source/tool-calling/json-parser.ts +0 -247
- package/source/tool-calling/tool-parser.spec.ts +0 -395
- package/source/tool-calling/tool-parser.ts +0 -120
- package/source/tool-calling/xml-parser.spec.ts +0 -662
- package/source/tool-calling/xml-parser.ts +0 -289
- package/source/tools/execute-bash.spec.tsx +0 -353
- package/source/tools/execute-bash.tsx +0 -219
- package/source/tools/execute-function.spec.ts +0 -130
- package/source/tools/fetch-url.spec.tsx +0 -342
- package/source/tools/fetch-url.tsx +0 -172
- package/source/tools/find-files.spec.tsx +0 -924
- package/source/tools/find-files.tsx +0 -293
- package/source/tools/index.ts +0 -102
- package/source/tools/lsp-get-diagnostics.tsx +0 -192
- package/source/tools/needs-approval.spec.ts +0 -282
- package/source/tools/read-file.spec.tsx +0 -801
- package/source/tools/read-file.tsx +0 -387
- package/source/tools/search-file-contents.spec.tsx +0 -1273
- package/source/tools/search-file-contents.tsx +0 -293
- package/source/tools/string-replace.spec.tsx +0 -730
- package/source/tools/string-replace.tsx +0 -548
- package/source/tools/tool-manager.ts +0 -210
- package/source/tools/tool-registry.spec.ts +0 -415
- package/source/tools/tool-registry.ts +0 -228
- package/source/tools/web-search.tsx +0 -223
- package/source/tools/write-file.spec.tsx +0 -559
- package/source/tools/write-file.tsx +0 -228
- package/source/types/app.ts +0 -37
- package/source/types/checkpoint.ts +0 -48
- package/source/types/commands.ts +0 -46
- package/source/types/components.ts +0 -27
- package/source/types/config.ts +0 -103
- package/source/types/core-connection-status.spec.ts +0 -67
- package/source/types/core.ts +0 -181
- package/source/types/hooks.ts +0 -50
- package/source/types/index.ts +0 -12
- package/source/types/markdown-parser.ts +0 -11
- package/source/types/mcp.ts +0 -52
- package/source/types/system.ts +0 -16
- package/source/types/tokenization.ts +0 -41
- package/source/types/ui.ts +0 -40
- package/source/types/usage.ts +0 -58
- package/source/types/utils.ts +0 -16
- package/source/usage/calculator.spec.ts +0 -385
- package/source/usage/calculator.ts +0 -104
- package/source/usage/storage.spec.ts +0 -703
- package/source/usage/storage.ts +0 -238
- package/source/usage/tracker.spec.ts +0 -456
- package/source/usage/tracker.ts +0 -102
- package/source/utils/atomic-deletion.spec.ts +0 -194
- package/source/utils/atomic-deletion.ts +0 -127
- package/source/utils/bounded-map.spec.ts +0 -300
- package/source/utils/bounded-map.ts +0 -193
- package/source/utils/checkpoint-utils.spec.ts +0 -222
- package/source/utils/checkpoint-utils.ts +0 -92
- package/source/utils/error-formatter.spec.ts +0 -169
- package/source/utils/error-formatter.ts +0 -194
- package/source/utils/file-autocomplete.spec.ts +0 -173
- package/source/utils/file-autocomplete.ts +0 -196
- package/source/utils/file-cache.spec.ts +0 -309
- package/source/utils/file-cache.ts +0 -195
- package/source/utils/file-content-loader.spec.ts +0 -180
- package/source/utils/file-content-loader.ts +0 -179
- package/source/utils/file-mention-handler.spec.ts +0 -261
- package/source/utils/file-mention-handler.ts +0 -84
- package/source/utils/file-mention-parser.spec.ts +0 -182
- package/source/utils/file-mention-parser.ts +0 -170
- package/source/utils/fuzzy-matching.spec.ts +0 -149
- package/source/utils/fuzzy-matching.ts +0 -146
- package/source/utils/indentation-normalizer.spec.ts +0 -216
- package/source/utils/indentation-normalizer.ts +0 -76
- package/source/utils/installation-detector.spec.ts +0 -178
- package/source/utils/installation-detector.ts +0 -153
- package/source/utils/logging/config.spec.ts +0 -311
- package/source/utils/logging/config.ts +0 -210
- package/source/utils/logging/console-facade.spec.ts +0 -184
- package/source/utils/logging/console-facade.ts +0 -384
- package/source/utils/logging/correlation.spec.ts +0 -679
- package/source/utils/logging/correlation.ts +0 -474
- package/source/utils/logging/formatters.spec.ts +0 -464
- package/source/utils/logging/formatters.ts +0 -207
- package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +0 -93
- package/source/utils/logging/health-monitor/alerts/alert-manager.ts +0 -79
- package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/configuration-check.ts +0 -43
- package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/logging-check.ts +0 -58
- package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +0 -100
- package/source/utils/logging/health-monitor/checks/memory-check.ts +0 -78
- package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/performance-check.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.ts +0 -76
- package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +0 -70
- package/source/utils/logging/health-monitor/core/health-check-runner.ts +0 -138
- package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +0 -58
- package/source/utils/logging/health-monitor/core/health-monitor.ts +0 -344
- package/source/utils/logging/health-monitor/core/scoring.spec.ts +0 -65
- package/source/utils/logging/health-monitor/core/scoring.ts +0 -91
- package/source/utils/logging/health-monitor/index.ts +0 -15
- package/source/utils/logging/health-monitor/instances.ts +0 -48
- package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +0 -141
- package/source/utils/logging/health-monitor/middleware/http-middleware.ts +0 -75
- package/source/utils/logging/health-monitor/types.ts +0 -126
- package/source/utils/logging/index.spec.ts +0 -284
- package/source/utils/logging/index.ts +0 -236
- package/source/utils/logging/integration.spec.ts +0 -441
- package/source/utils/logging/log-method-factory.spec.ts +0 -573
- package/source/utils/logging/log-method-factory.ts +0 -233
- package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +0 -277
- package/source/utils/logging/log-query/aggregation/aggregator.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.ts +0 -47
- package/source/utils/logging/log-query/index.ts +0 -23
- package/source/utils/logging/log-query/query/filter-predicates.spec.ts +0 -247
- package/source/utils/logging/log-query/query/filter-predicates.ts +0 -154
- package/source/utils/logging/log-query/query/query-builder.spec.ts +0 -182
- package/source/utils/logging/log-query/query/query-builder.ts +0 -151
- package/source/utils/logging/log-query/query/query-engine.spec.ts +0 -214
- package/source/utils/logging/log-query/query/query-engine.ts +0 -45
- package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +0 -143
- package/source/utils/logging/log-query/storage/circular-buffer.ts +0 -75
- package/source/utils/logging/log-query/storage/index-manager.spec.ts +0 -150
- package/source/utils/logging/log-query/storage/index-manager.ts +0 -71
- package/source/utils/logging/log-query/storage/log-storage.spec.ts +0 -257
- package/source/utils/logging/log-query/storage/log-storage.ts +0 -80
- package/source/utils/logging/log-query/types.ts +0 -163
- package/source/utils/logging/log-query/utils/helpers.spec.ts +0 -263
- package/source/utils/logging/log-query/utils/helpers.ts +0 -72
- package/source/utils/logging/log-query/utils/sorting.spec.ts +0 -182
- package/source/utils/logging/log-query/utils/sorting.ts +0 -61
- package/source/utils/logging/logger-provider.spec.ts +0 -262
- package/source/utils/logging/logger-provider.ts +0 -362
- package/source/utils/logging/performance.spec.ts +0 -209
- package/source/utils/logging/performance.ts +0 -757
- package/source/utils/logging/pino-logger.spec.ts +0 -425
- package/source/utils/logging/pino-logger.ts +0 -514
- package/source/utils/logging/redaction.spec.ts +0 -490
- package/source/utils/logging/redaction.ts +0 -267
- package/source/utils/logging/request-tracker.spec.ts +0 -1198
- package/source/utils/logging/request-tracker.ts +0 -803
- package/source/utils/logging/transports.spec.ts +0 -505
- package/source/utils/logging/transports.ts +0 -305
- package/source/utils/logging/types.ts +0 -216
- package/source/utils/message-builder.spec.ts +0 -179
- package/source/utils/message-builder.ts +0 -101
- package/source/utils/message-queue.tsx +0 -486
- package/source/utils/paste-detection.spec.ts +0 -69
- package/source/utils/paste-detection.ts +0 -124
- package/source/utils/paste-roundtrip.spec.ts +0 -442
- package/source/utils/paste-utils.spec.ts +0 -128
- package/source/utils/paste-utils.ts +0 -52
- package/source/utils/programming-language-helper.spec.ts +0 -74
- package/source/utils/programming-language-helper.ts +0 -32
- package/source/utils/prompt-assembly.spec.ts +0 -221
- package/source/utils/prompt-processor.ts +0 -173
- package/source/utils/tool-args-parser.spec.ts +0 -136
- package/source/utils/tool-args-parser.ts +0 -54
- package/source/utils/tool-cancellation.spec.ts +0 -230
- package/source/utils/tool-cancellation.ts +0 -28
- package/source/utils/tool-result-display.spec.tsx +0 -469
- package/source/utils/tool-result-display.tsx +0 -90
- package/source/utils/update-checker.spec.ts +0 -383
- package/source/utils/update-checker.ts +0 -183
- package/source/wizard/config-wizard.spec.tsx +0 -103
- package/source/wizard/config-wizard.tsx +0 -382
- package/source/wizard/steps/location-step.spec.tsx +0 -186
- package/source/wizard/steps/location-step.tsx +0 -147
- package/source/wizard/steps/mcp-step.spec.tsx +0 -607
- package/source/wizard/steps/mcp-step.tsx +0 -632
- package/source/wizard/steps/provider-step.spec.tsx +0 -342
- package/source/wizard/steps/provider-step.tsx +0 -957
- package/source/wizard/steps/summary-step.spec.tsx +0 -749
- package/source/wizard/steps/summary-step.tsx +0 -228
- package/source/wizard/templates/mcp-templates.spec.ts +0 -613
- package/source/wizard/templates/mcp-templates.ts +0 -570
- package/source/wizard/templates/provider-templates.spec.ts +0 -152
- package/source/wizard/templates/provider-templates.ts +0 -485
- package/source/wizard/utils/fetch-cloud-models.spec.ts +0 -428
- package/source/wizard/utils/fetch-cloud-models.ts +0 -223
- package/source/wizard/utils/fetch-local-models.spec.ts +0 -297
- package/source/wizard/utils/fetch-local-models.ts +0 -192
- package/source/wizard/validation-array.spec.ts +0 -264
- package/source/wizard/validation.spec.ts +0 -373
- package/source/wizard/validation.ts +0 -232
|
@@ -1,261 +0,0 @@
|
|
|
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.
|
|
@@ -1,201 +0,0 @@
|
|
|
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
|
-
};
|