warn when configured theme is unusable for color reasons (#13058)

if `config.toml` either does not have `editor.true-color` or sets
it to false, many (most?) themes stop being usable. when loading such a
theme, Helix falls back to the default theme, but didn't mention this
anywhere - even in `~/.cache/helix/helix.log` when run with `-v`.

if this occurs when reloading a theme at runtime with `:theme`, there's
a fairly helpful error about

> `theme requires true color support`

seems worth logging about this if it happens during startup too.
This commit is contained in:
iximeow 2025-03-12 13:52:07 -07:00 committed by GitHub
parent e74956fa4d
commit d1e0891260
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -441,7 +441,17 @@ impl Application {
e
})
.ok()
.filter(|theme| (true_color || theme.is_16_color()))
.filter(|theme| {
let colors_ok = true_color || theme.is_16_color();
if !colors_ok {
log::warn!(
"loaded theme `{}` but cannot use it because true color \
support is not enabled",
theme.name()
);
}
colors_ok
})
})
.unwrap_or_else(|| editor.theme_loader.default_theme(true_color));
editor.set_theme(theme);