mirror of
https://github.com/brl/mutter.git
synced 2024-11-22 16:10:41 -05:00
backend-x11: Fix leak of the event data
This commit is contained in:
parent
6111bb9dec
commit
97074ccdad
@ -84,8 +84,6 @@ maybe_spoof_event_as_stage_event (MetaBackendX11 *x11,
|
|||||||
if (event->type == GenericEvent &&
|
if (event->type == GenericEvent &&
|
||||||
event->xcookie.extension == priv->xinput_opcode)
|
event->xcookie.extension == priv->xinput_opcode)
|
||||||
{
|
{
|
||||||
XGetEventData (priv->xdisplay, &event->xcookie);
|
|
||||||
|
|
||||||
XIEvent *input_event = (XIEvent *) event->xcookie.data;
|
XIEvent *input_event = (XIEvent *) event->xcookie.data;
|
||||||
XIDeviceEvent *device_event = ((XIDeviceEvent *) input_event);
|
XIDeviceEvent *device_event = ((XIDeviceEvent *) input_event);
|
||||||
|
|
||||||
@ -115,6 +113,8 @@ handle_host_xevent (MetaBackend *backend,
|
|||||||
MetaBackendX11Private *priv = meta_backend_x11_get_instance_private (x11);
|
MetaBackendX11Private *priv = meta_backend_x11_get_instance_private (x11);
|
||||||
gboolean bypass_clutter = FALSE;
|
gboolean bypass_clutter = FALSE;
|
||||||
|
|
||||||
|
XGetEventData (priv->xdisplay, &event->xcookie);
|
||||||
|
|
||||||
if (event->type == (priv->xsync_event_base + XSyncAlarmNotify))
|
if (event->type == (priv->xsync_event_base + XSyncAlarmNotify))
|
||||||
handle_alarm_notify (backend, event);
|
handle_alarm_notify (backend, event);
|
||||||
|
|
||||||
@ -133,6 +133,8 @@ handle_host_xevent (MetaBackend *backend,
|
|||||||
out:
|
out:
|
||||||
if (!bypass_clutter)
|
if (!bypass_clutter)
|
||||||
clutter_x11_handle_event (event);
|
clutter_x11_handle_event (event);
|
||||||
|
|
||||||
|
XFreeEventData (priv->xdisplay, &event->xcookie);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
Loading…
Reference in New Issue
Block a user