From e74956fa4d61db3f229e571ab186ca10966030c7 Mon Sep 17 00:00:00 2001 From: Michael Davis Date: Wed, 12 Mar 2025 16:32:52 -0400 Subject: [PATCH] minor: Add a helper function for setting the configured theme This block was duplicated in `Application::new` and in another helper `Application::refresh_theme`. This change adds a helper to cover both cases. --- helix-term/src/application.rs | 65 +++++++++++++---------------------- 1 file changed, 24 insertions(+), 41 deletions(-) diff --git a/helix-term/src/application.rs b/helix-term/src/application.rs index 1da2a700d..7f4913098 100644 --- a/helix-term/src/application.rs +++ b/helix-term/src/application.rs @@ -103,22 +103,6 @@ impl Application { theme_parent_dirs.extend(helix_loader::runtime_dirs().iter().cloned()); let theme_loader = theme::Loader::new(&theme_parent_dirs); - let true_color = config.editor.true_color || crate::true_color(); - let theme = config - .theme - .as_ref() - .and_then(|theme| { - theme_loader - .load(theme) - .map_err(|e| { - log::warn!("failed to load theme `{}` - {}", theme, e); - e - }) - .ok() - .filter(|theme| (true_color || theme.is_16_color())) - }) - .unwrap_or_else(|| theme_loader.default_theme(true_color)); - #[cfg(not(feature = "integration"))] let backend = CrosstermBackend::new(stdout(), &config.editor); @@ -139,7 +123,7 @@ impl Application { })), handlers, ); - editor.set_theme(theme); + Self::load_configured_theme(&mut editor, &config.load()); let keys = Box::new(Map::new(Arc::clone(&config), |config: &Config| { &config.keys @@ -418,35 +402,13 @@ impl Application { Ok(()) } - /// Refresh theme after config change - fn refresh_theme(&mut self, config: &Config) -> Result<(), Error> { - let true_color = config.editor.true_color || crate::true_color(); - let theme = config - .theme - .as_ref() - .and_then(|theme| { - self.editor - .theme_loader - .load(theme) - .map_err(|e| { - log::warn!("failed to load theme `{}` - {}", theme, e); - e - }) - .ok() - .filter(|theme| (true_color || theme.is_16_color())) - }) - .unwrap_or_else(|| self.editor.theme_loader.default_theme(true_color)); - - self.editor.set_theme(theme); - Ok(()) - } - fn refresh_config(&mut self) { let mut refresh_config = || -> Result<(), Error> { let default_config = Config::load_default() .map_err(|err| anyhow::anyhow!("Failed to load config: {}", err))?; self.refresh_language_config()?; - self.refresh_theme(&default_config)?; + // Refresh theme after config change + Self::load_configured_theme(&mut self.editor, &default_config); self.terminal .reconfigure(default_config.editor.clone().into())?; // Store new config @@ -464,6 +426,27 @@ impl Application { } } + /// Load the theme set in configuration + fn load_configured_theme(editor: &mut Editor, config: &Config) { + let true_color = config.editor.true_color || crate::true_color(); + let theme = config + .theme + .as_ref() + .and_then(|theme| { + editor + .theme_loader + .load(theme) + .map_err(|e| { + log::warn!("failed to load theme `{}` - {}", theme, e); + e + }) + .ok() + .filter(|theme| (true_color || theme.is_16_color())) + }) + .unwrap_or_else(|| editor.theme_loader.default_theme(true_color)); + editor.set_theme(theme); + } + #[cfg(windows)] // no signal handling available on windows pub async fn handle_signals(&mut self, _signal: ()) -> bool {