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::GPT5Mini
20            | ModelId::GPT5Nano
21            | ModelId::GPT53Codex
22            | ModelId::OpenAIGptOss20b
23            | ModelId::OpenAIGptOss120b => Provider::OpenAI,
24            ModelId::ClaudeOpus46
25            | ModelId::ClaudeSonnet46
26            | ModelId::ClaudeOpus45
27            | ModelId::ClaudeOpus41
28            | ModelId::ClaudeSonnet45
29            | ModelId::ClaudeHaiku45
30            | ModelId::ClaudeSonnet4
31            | ModelId::ClaudeOpus4
32            | ModelId::ClaudeSonnet37
33            | ModelId::ClaudeHaiku35 => Provider::Anthropic,
34            ModelId::DeepSeekChat | ModelId::DeepSeekReasoner => Provider::DeepSeek,
35            ModelId::HuggingFaceDeepseekV32
36            | ModelId::HuggingFaceOpenAIGptOss20b
37            | ModelId::HuggingFaceOpenAIGptOss120b
38            | ModelId::HuggingFaceMinimaxM25Novita
39            | ModelId::HuggingFaceDeepseekV32Novita
40            | ModelId::HuggingFaceXiaomiMimoV2FlashNovita
41            | ModelId::HuggingFaceGlm5Novita
42            | ModelId::HuggingFaceQwen3CoderNextNovita => Provider::HuggingFace,
43            ModelId::XaiGrok4
44            | ModelId::XaiGrok4Mini
45            | ModelId::XaiGrok4Code
46            | ModelId::XaiGrok4CodeLatest
47            | ModelId::XaiGrok4Vision => Provider::XAI,
48            ModelId::ZaiGlm5 => Provider::ZAI,
49            ModelId::MoonshotMinimaxM25 | ModelId::MoonshotQwen3CoderNext => Provider::Moonshot,
50            ModelId::OllamaGptOss20b
51            | ModelId::OllamaGptOss20bCloud
52            | ModelId::OllamaGptOss120bCloud
53            | ModelId::OllamaQwen317b
54            | ModelId::OllamaDeepseekV32Cloud
55            | ModelId::OllamaQwen3Next80bCloud
56            | ModelId::OllamaMistralLarge3675bCloud
57            | ModelId::OllamaQwen3Coder480bCloud
58            | ModelId::OllamaGemini3ProPreviewLatestCloud
59            | ModelId::OllamaGemini3FlashPreviewCloud
60            | ModelId::OllamaDevstral2123bCloud
61            | ModelId::OllamaMinimaxM2Cloud
62            | ModelId::OllamaMinimaxM25Cloud
63            | ModelId::OllamaNemotron3Nano30bCloud
64            | ModelId::OllamaGlm5Cloud => Provider::Ollama,
65            ModelId::LmStudioMetaLlama38BInstruct
66            | ModelId::LmStudioMetaLlama318BInstruct
67            | ModelId::LmStudioQwen257BInstruct
68            | ModelId::LmStudioGemma22BIt
69            | ModelId::LmStudioGemma29BIt
70            | ModelId::LmStudioPhi31Mini4kInstruct => Provider::LmStudio,
71            ModelId::MinimaxM25 | ModelId::MinimaxM2 => Provider::Minimax,
72            ModelId::OpenRouterMinimaxM25 | ModelId::OpenRouterQwen3CoderNext => {
73                Provider::OpenRouter
74            }
75            _ => unreachable!(),
76        }
77    }
78
79    /// Whether this model supports configurable reasoning effort levels
80    pub fn supports_reasoning_effort(&self) -> bool {
81        self.provider().supports_reasoning_effort(self.as_str())
82    }
83}