Files
xserver/Xi/xiallowev.c
Enrico Weigelt, metux IT consult a28cacbef2 Xi: inline SProcXIAllowEvents()
No need to have a hole bunch of extra functions, if we can just easily
inline the few relevant lines.

Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
2025-10-21 10:21:31 +02:00

151 lines
4.5 KiB
C

/*
* Copyright © 2009 Red Hat, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice (including the next
* paragraph) shall be included in all copies or substantial portions of the
* Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*
* Author: Peter Hutterer
*/
/***********************************************************************
*
* Request to allow some device events.
*
*/
#include <dix-config.h>
#include <X11/extensions/XI2.h>
#include <X11/extensions/XI2proto.h>
#include "dix/dix_priv.h"
#include "dix/exevents_priv.h"
#include "dix/input_priv.h"
#include "os/fmt.h"
#include "Xi/handlers.h"
#include "inputstr.h" /* DeviceIntPtr */
#include "windowstr.h" /* window structure */
#include "mi.h"
#include "eventstr.h"
#include "exglobals.h" /* BadDevice */
int
ProcXIAllowEvents(ClientPtr client)
{
if (client->swapped) {
REQUEST(xXIAllowEventsReq);
REQUEST_AT_LEAST_SIZE(xXIAllowEventsReq);
swaps(&stuff->deviceid);
swapl(&stuff->time);
if (client->req_len > 3) {
xXI2_2AllowEventsReq *req_xi22 = (xXI2_2AllowEventsReq *) stuff;
REQUEST_AT_LEAST_SIZE(xXI2_2AllowEventsReq);
swapl(&req_xi22->touchid);
swapl(&req_xi22->grab_window);
}
}
Bool have_xi22 = FALSE;
CARD32 clientTime;
int deviceId;
int mode;
Window grabWindow = 0;
uint32_t touchId = 0;
XIClientPtr xi_client = XIClientPriv(client);
if (!xi_client)
return BadImplementation;
if (version_compare(xi_client->major_version,
xi_client->minor_version, 2, 2) >= 0) {
// Xi >= v2.2 request
REQUEST(xXI2_2AllowEventsReq);
REQUEST_AT_LEAST_SIZE(xXI2_2AllowEventsReq);
have_xi22 = TRUE;
clientTime = stuff->time;
deviceId = stuff->deviceid;
mode = stuff->mode;
grabWindow = stuff->grab_window;
touchId = stuff->touchid;
}
else {
// Xi < v2.2 request
REQUEST(xXIAllowEventsReq);
REQUEST_AT_LEAST_SIZE(xXIAllowEventsReq);
clientTime = stuff->time;
deviceId = stuff->deviceid;
mode = stuff->mode;
}
DeviceIntPtr dev;
int ret = dixLookupDevice(&dev, deviceId, client, DixGetAttrAccess);
if (ret != Success)
return ret;
TimeStamp time = ClientTimeToServerTime(clientTime);
switch (mode) {
case XIReplayDevice:
AllowSome(client, time, dev, GRAB_STATE_NOT_GRABBED);
break;
case XISyncDevice:
AllowSome(client, time, dev, GRAB_STATE_FREEZE_NEXT_EVENT);
break;
case XIAsyncDevice:
AllowSome(client, time, dev, GRAB_STATE_THAWED);
break;
case XIAsyncPairedDevice:
if (InputDevIsMaster(dev))
AllowSome(client, time, dev, GRAB_STATE_THAW_OTHERS);
break;
case XISyncPair:
if (InputDevIsMaster(dev))
AllowSome(client, time, dev, GRAB_STATE_FREEZE_BOTH_NEXT_EVENT);
break;
case XIAsyncPair:
if (InputDevIsMaster(dev))
AllowSome(client, time, dev, GRAB_STATE_THAWED_BOTH);
break;
case XIRejectTouch:
case XIAcceptTouch:
{
int rc;
WindowPtr win;
if (!have_xi22)
return BadValue;
rc = dixLookupWindow(&win, grabWindow, client, DixReadAccess);
if (rc != Success)
return rc;
ret = TouchAcceptReject(client, dev, mode, touchId,
grabWindow, &client->errorValue);
}
break;
default:
client->errorValue = mode;
ret = BadValue;
}
return ret;
}