tray: Adapt to meta_x11_error_* removal
By switching to use the mtk helpers instead Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/3087>
This commit is contained in:
parent
71befc5ff7
commit
00813828f3
@ -22,6 +22,7 @@
|
||||
|
||||
#include "na-tray-child.h"
|
||||
|
||||
#include <mtk/mtk-x11.h>
|
||||
#include <X11/Xatom.h>
|
||||
#include <X11/Xutil.h>
|
||||
|
||||
@ -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);
|
||||
}
|
||||
|
@ -23,8 +23,6 @@
|
||||
|
||||
#include "na-xembed.h"
|
||||
|
||||
#include <meta/meta-x11-errors.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
#define NA_TYPE_TRAY_CHILD (na_tray_child_get_type ())
|
||||
|
@ -24,6 +24,7 @@
|
||||
|
||||
#include "na-tray-manager.h"
|
||||
|
||||
#include <mtk/mtk-x11.h>
|
||||
#include <X11/Xatom.h>
|
||||
#include <X11/Xutil.h>
|
||||
|
||||
@ -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;
|
||||
|
||||
|
@ -23,7 +23,7 @@
|
||||
|
||||
#include "na-xembed.h"
|
||||
|
||||
#include <meta/meta-x11-errors.h>
|
||||
#include <mtk/mtk-x11.h>
|
||||
#include <X11/extensions/Xfixes.h>
|
||||
#include <X11/Xlib.h>
|
||||
#include <X11/Xutil.h>
|
||||
@ -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),
|
||||
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);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user