Skip to content

Commit

Permalink
Improve error handling for config-reload (helix-editor#3668)
Browse files Browse the repository at this point in the history
* Don't change config to default when refreshing invalid config

* Propely handle theme errors with config-reload

* Extract refresh theme into seperate function
  • Loading branch information
A-Walrus authored and jdrst committed Sep 13, 2022
1 parent 6da826e commit e694115
Showing 1 changed file with 29 additions and 19 deletions.
48 changes: 29 additions & 19 deletions helix-term/src/application.rs
Original file line number Diff line number Diff line change
Expand Up @@ -366,29 +366,39 @@ impl Application {
self.editor.refresh_config();
}

fn refresh_config(&mut self) {
let config = Config::load_default().unwrap_or_else(|err| {
self.editor.set_error(err.to_string());
Config::default()
});

// Refresh theme
/// Refresh theme after config change
fn refresh_theme(&mut self, config: &Config) {
if let Some(theme) = config.theme.clone() {
let true_color = self.true_color();
self.editor.set_theme(
self.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.theme_loader.default_theme(true_color)),
);
match self.theme_loader.load(&theme) {
Ok(theme) => {
if true_color || theme.is_16_color() {
self.editor.set_theme(theme);
} else {
self.editor
.set_error("theme requires truecolor support, which is not available");
}
}
Err(err) => {
let err_string = format!("failed to load theme `{}` - {}", theme, err);
self.editor.set_error(err_string);
}
}
}
}

self.config.store(Arc::new(config));
fn refresh_config(&mut self) {
match Config::load_default() {
Ok(config) => {
self.refresh_theme(&config);

// Store new config
self.config.store(Arc::new(config));
}
Err(err) => {
self.editor.set_error(err.to_string());
}
}
}

fn true_color(&self) -> bool {
Expand Down

0 comments on commit e694115

Please sign in to comment.