From 00813828f3c09b827bb0271e8627425eea464505 Mon Sep 17 00:00:00 2001 From: Bilal Elmoussaoui Date: Wed, 3 Jan 2024 16:13:41 +0100 Subject: [PATCH] tray: Adapt to meta_x11_error_* removal By switching to use the mtk helpers instead Part-of: --- src/tray/na-tray-child.c | 24 +++++++-------- src/tray/na-tray-child.h | 2 -- src/tray/na-tray-manager.c | 9 +++--- src/tray/na-xembed.c | 60 ++++++++++++++++++++------------------ 4 files changed, 48 insertions(+), 47 deletions(-) diff --git a/src/tray/na-tray-child.c b/src/tray/na-tray-child.c index 508fb533f..53a66cee7 100644 --- a/src/tray/na-tray-child.c +++ b/src/tray/na-tray-child.c @@ -22,6 +22,7 @@ #include "na-tray-child.h" +#include #include #include @@ -61,10 +62,10 @@ na_tray_child_new (MetaX11Display *x11_display, * the socket in the same visual. */ - meta_x11_error_trap_push (x11_display); + mtk_x11_error_trap_push (xdisplay); result = XGetWindowAttributes (xdisplay, icon_window, &window_attributes); - meta_x11_error_trap_pop (x11_display); + mtk_x11_error_trap_pop (xdisplay); if (!result) /* Window already gone */ return NULL; @@ -97,7 +98,7 @@ na_tray_child_get_title (NaTrayChild *child) utf8_string = XInternAtom (xdisplay, "UTF8_STRING", False); atom = XInternAtom (xdisplay, "_NET_WM_NAME", False); - meta_x11_error_trap_push (x11_display); + mtk_x11_error_trap_push (xdisplay); result = XGetWindowProperty (xdisplay, na_xembed_get_plug_window (NA_XEMBED (child)), @@ -107,7 +108,7 @@ na_tray_child_get_title (NaTrayChild *child) &type, &format, &nitems, &bytes_after, (guchar **)&val); - if (meta_x11_error_trap_pop_with_return (x11_display) || result != Success) + if (mtk_x11_error_trap_pop_with_return (xdisplay) || result != Success) return NULL; if (type != utf8_string || @@ -166,9 +167,9 @@ _get_wmclass (MetaX11Display *x11_display, xdisplay = meta_x11_display_get_xdisplay (x11_display); - meta_x11_error_trap_push (x11_display); + mtk_x11_error_trap_push (xdisplay); XGetClassHint (xdisplay, xwindow, &ch); - meta_x11_error_trap_pop (x11_display); + mtk_x11_error_trap_pop (xdisplay); if (res_class) *res_class = NULL; @@ -234,7 +235,7 @@ na_tray_child_get_pid (NaTrayChild *child) xdisplay = meta_x11_display_get_xdisplay (x11_display); xdisplay = meta_x11_display_get_xdisplay (x11_display); - meta_x11_error_trap_push (x11_display); + mtk_x11_error_trap_push (xdisplay); result = XGetWindowProperty (xdisplay, na_xembed_get_plug_window (NA_XEMBED (child)), XInternAtom (xdisplay, "_NET_WM_PID", False), @@ -242,7 +243,7 @@ na_tray_child_get_pid (NaTrayChild *child) &type, &format, &nitems, &bytes_after, (guchar **)&val); - if (!meta_x11_error_trap_pop_with_return (x11_display) && + if (!mtk_x11_error_trap_pop_with_return (xdisplay) && result == Success && type == XA_CARDINAL && nitems == 1) @@ -272,6 +273,7 @@ na_tray_child_emulate_event (NaTrayChild *tray_child, event_type == CLUTTER_KEY_RELEASE); x11_display = na_xembed_get_x11_display (NA_XEMBED (tray_child)); + xdisplay = meta_x11_display_get_xdisplay (x11_display); xwindow = na_xembed_get_plug_window (NA_XEMBED (tray_child)); if (xwindow == None) @@ -282,9 +284,7 @@ na_tray_child_emulate_event (NaTrayChild *tray_child, na_xembed_get_size (NA_XEMBED (tray_child), &width, &height); - meta_x11_error_trap_push (x11_display); - - xdisplay = meta_x11_display_get_xdisplay (x11_display); + mtk_x11_error_trap_push (xdisplay); xrootwindow = XDefaultRootWindow (xdisplay); /* First make the icon believe the pointer is inside it */ @@ -358,5 +358,5 @@ na_tray_child_emulate_event (NaTrayChild *tray_child, xcevent.type = LeaveNotify; XSendEvent (xdisplay, xwindow, False, 0, (XEvent *)&xcevent); - meta_x11_error_trap_pop (x11_display); + mtk_x11_error_trap_pop (xdisplay); } diff --git a/src/tray/na-tray-child.h b/src/tray/na-tray-child.h index 29133eb2b..7ff8a8d1d 100644 --- a/src/tray/na-tray-child.h +++ b/src/tray/na-tray-child.h @@ -23,8 +23,6 @@ #include "na-xembed.h" -#include - G_BEGIN_DECLS #define NA_TYPE_TRAY_CHILD (na_tray_child_get_type ()) diff --git a/src/tray/na-tray-manager.c b/src/tray/na-tray-manager.c index a500bcfaf..48a405e77 100644 --- a/src/tray/na-tray-manager.c +++ b/src/tray/na-tray-manager.c @@ -24,6 +24,7 @@ #include "na-tray-manager.h" +#include #include #include @@ -603,7 +604,7 @@ na_tray_manager_manage (NaTrayManager *manager) xdisplay = meta_x11_display_get_xdisplay (manager->x11_display); - meta_x11_error_trap_push (manager->x11_display); + mtk_x11_error_trap_push (xdisplay); manager->window = XCreateSimpleWindow (xdisplay, XDefaultRootWindow (xdisplay), 0, 0, 1, 1, @@ -611,7 +612,7 @@ na_tray_manager_manage (NaTrayManager *manager) XSelectInput (xdisplay, manager->window, StructureNotifyMask | PropertyChangeMask); - if (meta_x11_error_trap_pop_with_return (manager->x11_display) || + if (mtk_x11_error_trap_pop_with_return (xdisplay) || !manager->window) return FALSE; @@ -620,13 +621,13 @@ na_tray_manager_manage (NaTrayManager *manager) na_tray_manager_set_visual_property (manager); na_tray_manager_set_colors_property (manager); - meta_x11_error_trap_push (manager->x11_display); + mtk_x11_error_trap_push (xdisplay); XSetSelectionOwner (xdisplay, manager->selection_atom, manager->window, CurrentTime); /* Check if we could set the selection owner successfully */ - if (!meta_x11_error_trap_pop_with_return (manager->x11_display)) + if (!mtk_x11_error_trap_pop_with_return (xdisplay)) { XClientMessageEvent xev; diff --git a/src/tray/na-xembed.c b/src/tray/na-xembed.c index 2183c9fcd..8f785305a 100644 --- a/src/tray/na-xembed.c +++ b/src/tray/na-xembed.c @@ -23,7 +23,7 @@ #include "na-xembed.h" -#include +#include #include #include #include @@ -110,6 +110,7 @@ xembed_send_message (NaXembed *xembed, glong data2) { NaXembedPrivate *priv = na_xembed_get_instance_private (xembed); + Display *xdisplay = meta_x11_display_get_xdisplay (priv->x11_display); XClientMessageEvent xclient; memset (&xclient, 0, sizeof (xclient)); @@ -123,11 +124,11 @@ xembed_send_message (NaXembed *xembed, xclient.data.l[3] = data1; xclient.data.l[4] = data2; - meta_x11_error_trap_push (priv->x11_display); - XSendEvent (meta_x11_display_get_xdisplay (priv->x11_display), + mtk_x11_error_trap_push (xdisplay); + XSendEvent (xdisplay, recipient, False, NoEventMask, (XEvent*) &xclient); - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); } static void @@ -147,6 +148,7 @@ na_xembed_send_configure_event (NaXembed *xembed) { NaXembedPrivate *priv = na_xembed_get_instance_private (xembed); XConfigureEvent xconfigure; + Display *xdisplay = meta_x11_display_get_xdisplay (priv->x11_display); memset (&xconfigure, 0, sizeof (xconfigure)); xconfigure.type = ConfigureNotify; @@ -163,12 +165,12 @@ na_xembed_send_configure_event (NaXembed *xembed) xconfigure.above = None; xconfigure.override_redirect = False; - meta_x11_error_trap_push (priv->x11_display); - XSendEvent (meta_x11_display_get_xdisplay (priv->x11_display), + mtk_x11_error_trap_push (xdisplay); + XSendEvent (xdisplay, priv->plug_window, False, NoEventMask, (XEvent*) &xconfigure); - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); } static void @@ -190,7 +192,7 @@ na_xembed_synchronize_size (NaXembed *xembed) if (priv->plug_window) { - meta_x11_error_trap_push (priv->x11_display); + mtk_x11_error_trap_push (xdisplay); if (width != priv->current_width || height != priv->current_height) @@ -218,7 +220,7 @@ na_xembed_synchronize_size (NaXembed *xembed) priv->resize_count--; } - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); } } @@ -238,17 +240,18 @@ static void na_xembed_resize (NaXembed *xembed) { NaXembedPrivate *priv = na_xembed_get_instance_private (xembed); + Display *xdisplay = meta_x11_display_get_xdisplay (priv->x11_display); XSizeHints hints; long supplied; g_clear_handle_id (&priv->resize_id, g_source_remove); - meta_x11_error_trap_push (priv->x11_display); + mtk_x11_error_trap_push (xdisplay); priv->request_width = 1; priv->request_height = 1; - if (XGetWMNormalHints (meta_x11_display_get_xdisplay (priv->x11_display), + if (XGetWMNormalHints (xdisplay, priv->plug_window, &hints, &supplied)) { @@ -265,7 +268,7 @@ na_xembed_resize (NaXembed *xembed) } priv->have_size = TRUE; - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); priv->resize_id = g_idle_add (synchronize_size_cb, xembed); } @@ -286,7 +289,7 @@ na_xembed_get_info (NaXembed *xembed, unsigned long *data_long; int status; - meta_x11_error_trap_push (x11_display); + mtk_x11_error_trap_push (xdisplay); status = XGetWindowProperty (xdisplay, xwindow, priv->atom__XEMBED_INFO, @@ -294,7 +297,7 @@ na_xembed_get_info (NaXembed *xembed, priv->atom__XEMBED_INFO, &type, &format, &nitems, &bytes_after, &data); - meta_x11_error_trap_pop (x11_display); + mtk_x11_error_trap_pop (xdisplay); if (status != Success) return FALSE; @@ -339,13 +342,13 @@ na_xembed_add_window (NaXembed *xembed, priv->plug_window = xid; - meta_x11_error_trap_push (priv->x11_display); + mtk_x11_error_trap_push (xdisplay); XSelectInput (xdisplay, priv->plug_window, StructureNotifyMask | PropertyChangeMask); - if (meta_x11_error_trap_pop_with_return (priv->x11_display)) + if (mtk_x11_error_trap_pop_with_return (xdisplay)) { priv->plug_window = None; return; @@ -353,7 +356,7 @@ na_xembed_add_window (NaXembed *xembed, /* OK, we now will reliably get destroy notification on socket->plug_window */ - meta_x11_error_trap_push (priv->x11_display); + mtk_x11_error_trap_push (xdisplay); if (need_reparent) { @@ -364,21 +367,20 @@ na_xembed_add_window (NaXembed *xembed, result = XGetWindowAttributes (xdisplay, priv->plug_window, &plug_attrs); if (result == 0) { - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); priv->plug_window = None; return; } template.visualid = plug_attrs.visual->visualid; - priv->xvisual_info = - XGetVisualInfo (meta_x11_display_get_xdisplay (priv->x11_display), - VisualIDMask, - &template, - &n_xvisuals); + priv->xvisual_info = XGetVisualInfo (xdisplay, + VisualIDMask, + &template, + &n_xvisuals); if (!priv->xvisual_info) { - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); priv->plug_window = None; return; } @@ -423,12 +425,12 @@ na_xembed_add_window (NaXembed *xembed, priv->need_map = priv->is_mapped; - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); - meta_x11_error_trap_push (priv->x11_display); + mtk_x11_error_trap_push (xdisplay); XFixesChangeSaveSet (xdisplay, priv->plug_window, SetModeInsert, SaveSetRoot, SaveSetUnmap); - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); xembed_send_message (xembed, priv->plug_window, @@ -571,9 +573,9 @@ xembed_filter_func (MetaX11Display *x11_display, } else { - meta_x11_error_trap_push (priv->x11_display); + mtk_x11_error_trap_push (xdisplay); XMapWindow (xdisplay, priv->plug_window); - meta_x11_error_trap_pop (priv->x11_display); + mtk_x11_error_trap_pop (xdisplay); na_xembed_handle_unmap_notify (xembed); }