Commit 41b4edf6 authored by Emilio Cobos Álvarez's avatar Emilio Cobos Álvarez Committed by Mikhail Zolotukhin
Browse files

Don't apply window_decorations.css to non-Breeze themes.

Some applications might want to switch GTK themes dynamically, for a
variety of reasons.

For example, Firefox Nightly recently started doing this, so that
Firefox theme users have a better experience if they choose a Firefox
theme different from their GTK theme:


However, this causes some issues in KDE. While we usually try to switch
to the most compatible theme, we might fall back to Adwaita Dark. In
such case, this CSS would still apply causing artifacts as shown here:


Listen to the theme dynamically to make sure we don't apply
window_decorations.css in such case.

I plan to figure out how to work around this in Firefox / figure out why
Breeze dark is not working properly, but this seems worth it anyways.
parent 9e55858a
......@@ -21,6 +21,8 @@ GtkCssProvider *css_provider;
void manage_css_provider(GFileMonitor *monitor, GFile *file, GFile *other_file, GFileMonitorEvent event_type, gpointer user_data);
void reload_css_provider();
void remove_css_provider();
int theme_is_breeze();
void theme_changed(GtkSettings *settings, GParamSpec *param_spec, void *user_data);
__attribute__((visibility("default"))) void gtk_module_init(gint *argc, gchar ***argv[])
......@@ -35,6 +37,7 @@ __attribute__((visibility("default"))) void gtk_module_init(gint *argc, gchar **
css_provider = NULL;
g_signal_connect(window_decorations_css_monitor, "changed", G_CALLBACK(manage_css_provider), NULL);
g_signal_connect(gtk_settings_get_default(), "notify::gtk-theme-name", G_CALLBACK(theme_changed), NULL);
......@@ -55,8 +58,10 @@ void manage_css_provider(GFileMonitor *monitor, GFile *file, GFile *other_file,
void reload_css_provider()
if (css_provider != NULL) {
if (!theme_is_breeze()) {
css_provider = gtk_css_provider_new();
......@@ -69,6 +74,30 @@ void reload_css_provider()
void remove_css_provider()
if (!css_provider) {
gtk_style_context_remove_provider_for_screen(gdk_screen_get_default(), GTK_STYLE_PROVIDER(css_provider));
int theme_is_breeze()
GtkSettings *settings = gtk_settings_get_default();
char *theme_name = NULL;
g_object_get(settings, "gtk-theme-name", &theme_name, NULL);
if (!theme_name) {
return 0;
int ret = !strcmp(theme_name, "Breeze");
return ret;
void theme_changed(GtkSettings *settings, GParamSpec *param_spec, void *user_data)
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment