diff options
author | Mihai Moldovan <ionic@ionic.de> | 2023-07-28 20:27:28 +0200 |
---|---|---|
committer | Colomban Wendling <cwendling@hypra.fr> | 2023-10-24 10:58:14 +0200 |
commit | fdfc8bdd01242a38d87684b9c5e80e06edd2adad (patch) | |
tree | 068ec4b8361df7fff819638016b0b8fec8a71e47 /src | |
parent | a67e582bc96aac4a779b0fe28e7a005ca166bd03 (diff) | |
download | marco-fdfc8bdd01242a38d87684b9c5e80e06edd2adad.tar.bz2 marco-fdfc8bdd01242a38d87684b9c5e80e06edd2adad.tar.xz |
ui/tabpopup: likewise only enable compositing code if available.
Diffstat (limited to 'src')
-rw-r--r-- | src/core/screen.c | 2 | ||||
-rw-r--r-- | src/include/tabpopup.h | 2 | ||||
-rw-r--r-- | src/ui/tabpopup.c | 9 |
3 files changed, 11 insertions, 2 deletions
diff --git a/src/core/screen.c b/src/core/screen.c index c5962cb2..e4b686ef 100644 --- a/src/core/screen.c +++ b/src/core/screen.c @@ -1406,6 +1406,7 @@ meta_screen_ensure_tab_popup (MetaScreen *screen, } screen->tab_popup = meta_ui_tab_popup_new (entries, + screen, len, meta_prefs_get_alt_tab_max_columns(), meta_prefs_get_alt_tab_expand_to_fit_title(), @@ -1485,6 +1486,7 @@ meta_screen_ensure_workspace_popup (MetaScreen *screen) } screen->tab_popup = meta_ui_tab_popup_new (entries, + screen, len, layout.cols, FALSE, /* expand_for_titles */ diff --git a/src/include/tabpopup.h b/src/include/tabpopup.h index 19e8621b..8f249511 100644 --- a/src/include/tabpopup.h +++ b/src/include/tabpopup.h @@ -28,6 +28,7 @@ /* Don't include gtk.h or gdk.h here */ #include "common.h" #include "boxes.h" +#include "types.h" #include <X11/Xlib.h> #include <glib.h> #include <gdk-pixbuf/gdk-pixbuf.h> @@ -58,6 +59,7 @@ struct _MetaTabEntry }; MetaTabPopup* meta_ui_tab_popup_new (const MetaTabEntry *entries, + MetaScreen *meta_screen, int entry_count, int width, gboolean expand_for_titles, diff --git a/src/ui/tabpopup.c b/src/ui/tabpopup.c index d3b9ba62..57973fb0 100644 --- a/src/ui/tabpopup.c +++ b/src/ui/tabpopup.c @@ -30,6 +30,7 @@ #include "tabpopup.h" #include "theme.h" #include "prefs.h" +#include "screen.h" /* FIXME these two includes are 100% broken... */ #include "../core/workspace.h" #include "../core/frame-private.h" @@ -235,6 +236,7 @@ tab_entry_new (const MetaTabEntry *entry, MetaTabPopup* meta_ui_tab_popup_new (const MetaTabEntry *entries, + MetaScreen *meta_screen, int entry_count, int width, gboolean expand_for_titles, @@ -285,7 +287,8 @@ meta_ui_tab_popup_new (const MetaTabEntry *entries, gtk_window_set_resizable (GTK_WINDOW (popup->window), TRUE); /* This style should only be set for composited mode. */ - if (meta_prefs_get_compositing_manager ()) + if (meta_prefs_get_compositing_manager () && meta_screen && + !!(meta_display_get_compositor (meta_screen_get_display (meta_screen)))) { frame_shadow = GTK_SHADOW_NONE; gtk_style_context_add_class (gtk_widget_get_style_context (GTK_WIDGET (popup->window)), @@ -1117,13 +1120,15 @@ meta_select_workspace_draw (GtkWidget *widget, { GtkStyleContext *context; GdkRGBA color; + MetaScreen *screen = META_SELECT_WORKSPACE (widget)->workspace->screen; context = gtk_widget_get_style_context (widget); gtk_style_context_set_state (context, gtk_widget_get_state_flags (widget)); - if (meta_prefs_get_compositing_manager ()) + if (meta_prefs_get_compositing_manager () && screen && + !!(meta_display_get_compositor (meta_screen_get_display (screen)))) { /* compositing manager creates a dark background: show the selection in a light color */ meta_gtk_style_get_light_color (context, GTK_STATE_FLAG_SELECTED, &color); |