Skip to main content

vtcode_config/models/model_id/
provider.rs

1use crate::models::Provider;
2
3use super::ModelId;
4
5impl ModelId {
6    /// Get the provider for this model
7    pub fn provider(&self) -> Provider {
8        if self.openrouter_metadata().is_some() {
9            return Provider::OpenRouter;
10        }
11        match self {
12            ModelId::Gemini31ProPreview
13            | ModelId::Gemini31ProPreviewCustomTools
14            | ModelId::Gemini3ProPreview
15            | ModelId::Gemini3FlashPreview => Provider::Gemini,
16            ModelId::GPT5
17            | ModelId::GPT52
18            | ModelId::GPT52Codex
19            | ModelId::GPT5Codex
20            | ModelId::GPT5Mini
21            | ModelId::GPT5Nano
22            | ModelId::GPT51
23            | ModelId::GPT51Codex
24            | ModelId::GPT51CodexMax
25            | ModelId::GPT51Mini
26            | ModelId::CodexMiniLatest
27            | ModelId::OpenAIGptOss20b
28            | ModelId::OpenAIGptOss120b => Provider::OpenAI,
29            ModelId::ClaudeOpus46
30            | ModelId::ClaudeSonnet46
31            | ModelId::ClaudeOpus45
32            | ModelId::ClaudeOpus41
33            | ModelId::ClaudeSonnet45
34            | ModelId::ClaudeHaiku45
35            | ModelId::ClaudeSonnet4
36            | ModelId::ClaudeOpus4
37            | ModelId::ClaudeSonnet37
38            | ModelId::ClaudeHaiku35 => Provider::Anthropic,
39            ModelId::DeepSeekChat | ModelId::DeepSeekReasoner => Provider::DeepSeek,
40            ModelId::HuggingFaceDeepseekV32
41            | ModelId::HuggingFaceOpenAIGptOss20b
42            | ModelId::HuggingFaceOpenAIGptOss120b
43            | ModelId::HuggingFaceMinimaxM25Novita
44            | ModelId::HuggingFaceDeepseekV32Novita
45            | ModelId::HuggingFaceXiaomiMimoV2FlashNovita
46            | ModelId::HuggingFaceGlm5Novita
47            | ModelId::HuggingFaceQwen3CoderNextNovita => Provider::HuggingFace,
48            ModelId::XaiGrok4
49            | ModelId::XaiGrok4Mini
50            | ModelId::XaiGrok4Code
51            | ModelId::XaiGrok4CodeLatest
52            | ModelId::XaiGrok4Vision => Provider::XAI,
53            ModelId::ZaiGlm5 => Provider::ZAI,
54            ModelId::MoonshotMinimaxM25 | ModelId::MoonshotQwen3CoderNext => Provider::Moonshot,
55            ModelId::OllamaGptOss20b
56            | ModelId::OllamaGptOss20bCloud
57            | ModelId::OllamaGptOss120bCloud
58            | ModelId::OllamaQwen317b
59            | ModelId::OllamaDeepseekV32Cloud
60            | ModelId::OllamaQwen3Next80bCloud
61            | ModelId::OllamaMistralLarge3675bCloud
62            | ModelId::OllamaQwen3Coder480bCloud
63            | ModelId::OllamaGemini3ProPreviewLatestCloud
64            | ModelId::OllamaGemini3FlashPreviewCloud
65            | ModelId::OllamaDevstral2123bCloud
66            | ModelId::OllamaMinimaxM2Cloud
67            | ModelId::OllamaMinimaxM25Cloud
68            | ModelId::OllamaNemotron3Nano30bCloud
69            | ModelId::OllamaGlm5Cloud => Provider::Ollama,
70            ModelId::LmStudioMetaLlama38BInstruct
71            | ModelId::LmStudioMetaLlama318BInstruct
72            | ModelId::LmStudioQwen257BInstruct
73            | ModelId::LmStudioGemma22BIt
74            | ModelId::LmStudioGemma29BIt
75            | ModelId::LmStudioPhi31Mini4kInstruct => Provider::LmStudio,
76            ModelId::MinimaxM25 | ModelId::MinimaxM2 => Provider::Minimax,
77            ModelId::OpenRouterMinimaxM25 | ModelId::OpenRouterQwen3CoderNext => {
78                Provider::OpenRouter
79            }
80            _ => unreachable!(),
81        }
82    }
83
84    /// Whether this model supports configurable reasoning effort levels
85    pub fn supports_reasoning_effort(&self) -> bool {
86        self.provider().supports_reasoning_effort(self.as_str())
87    }
88}