From 74a74246ea975400f4b876240d3040bba6e82a7a Mon Sep 17 00:00:00 2001 From: Victor Kareh Date: Thu, 23 May 2019 13:08:13 -0400 Subject: frame: make frame window transparent upstream commit: https://gitlab.gnome.org/GNOME/metacity/commit/74db1f11 --- src/core/frame.c | 26 ++++++++++++++++++++------ 1 file changed, 20 insertions(+), 6 deletions(-) diff --git a/src/core/frame.c b/src/core/frame.c index 4b0b112f..07837c19 100644 --- a/src/core/frame.c +++ b/src/core/frame.c @@ -66,8 +66,11 @@ void meta_window_ensure_frame (MetaWindow *window) { MetaFrame *frame; + MetaScreen *screen; XSetWindowAttributes attrs; + XVisualInfo visual_info; Visual *visual; + int status; if (window->frame) return; @@ -110,13 +113,24 @@ meta_window_ensure_frame (MetaWindow *window) * the default of NULL. */ - /* Special case for depth 32 windows (assumed to be ARGB), - * we use the window's visual. Otherwise we just use the system visual. - */ - if (window->depth == 32) - visual = window->xvisual; + screen = meta_window_get_screen (window); + status = XMatchVisualInfo (window->display->xdisplay, + XScreenNumberOfScreen (screen->xscreen), + 32, TrueColor, + &visual_info); + + if (!status) + { + /* Special case for depth 32 windows (assumed to be ARGB), + * we use the window's visual. Otherwise we just use the system visual. + */ + if (window->depth == 32) + visual = window->xvisual; + else + visual = NULL; + } else - visual = NULL; + visual = visual_info.visual; frame->xwindow = meta_ui_create_frame_window (window->screen->ui, window->display->xdisplay, -- cgit v1.2.1