Edit

IABSD.fr/xenocara/xserver/test/xi2/protocol-xiwarppointer.c

Branch :

  • Show log

    Commit

  • Author : matthieu
    Date : 2012-06-10 13:21:05
    Hash : e60da745
    Message : Update to xserver 1.12.2. tested by naddy@, krw@, mpi@.

  • xserver/test/xi2/protocol-xiwarppointer.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.
     */
    
    #ifdef HAVE_DIX_CONFIG_H
    #include <dix-config.h>
    #endif
    
    /*
     * Protocol testing for XIWarpPointer request.
     */
    #include <stdint.h>
    #include <X11/X.h>
    #include <X11/Xproto.h>
    #include <X11/extensions/XI2proto.h>
    #include "inputstr.h"
    #include "windowstr.h"
    #include "scrnintstr.h"
    #include "xiwarppointer.h"
    #include "exevents.h"
    
    #include "protocol-common.h"
    
    static int expected_x = SPRITE_X;
    static int expected_y = SPRITE_Y;
    
    /* dixLookupWindow requires a lot of setup not necessary for this test.
     * Simple wrapper that returns either one of the fake root window or the
     * fake client window. If the requested ID is neither of those wanted,
     * return whatever the real dixLookupWindow does.
     */
    int
    __wrap_dixLookupWindow(WindowPtr *win, XID id, ClientPtr client, Mask access)
    {
        if (id == root.drawable.id) {
            *win = &root;
            return Success;
        }
        else if (id == window.drawable.id) {
            *win = &window;
            return Success;
        }
    
        return __real_dixLookupWindow(win, id, client, access);
    }
    
    /**
     * This function overrides the one in the screen rec.
     */
    static Bool
    ScreenSetCursorPosition(DeviceIntPtr dev, ScreenPtr screen,
                            int x, int y, Bool generateEvent)
    {
        assert(x == expected_x);
        assert(y == expected_y);
        return TRUE;
    }
    
    static void
    request_XIWarpPointer(ClientPtr client, xXIWarpPointerReq * req, int error)
    {
        int rc;
    
        rc = ProcXIWarpPointer(client);
        assert(rc == error);
    
        if (rc == BadDevice)
            assert(client->errorValue == req->deviceid);
        else if (rc == BadWindow)
            assert(client->errorValue == req->dst_win ||
                   client->errorValue == req->src_win);
    
        client->swapped = TRUE;
    
        swapl(&req->src_win);
        swapl(&req->dst_win);
        swapl(&req->src_x);
        swapl(&req->src_y);
        swapl(&req->dst_x);
        swapl(&req->dst_y);
        swaps(&req->src_width);
        swaps(&req->src_height);
        swaps(&req->deviceid);
    
        rc = SProcXIWarpPointer(client);
        assert(rc == error);
    
        if (rc == BadDevice)
            assert(client->errorValue == req->deviceid);
        else if (rc == BadWindow)
            assert(client->errorValue == req->dst_win ||
                   client->errorValue == req->src_win);
    
        client->swapped = FALSE;
    }
    
    static void
    test_XIWarpPointer(void)
    {
        int i;
        ClientRec client_request;
        xXIWarpPointerReq request;
    
        memset(&request, 0, sizeof(request));
    
        request_init(&request, XIWarpPointer);
    
        client_request = init_client(request.length, &request);
    
        request.deviceid = XIAllDevices;
        request_XIWarpPointer(&client_request, &request, BadDevice);
    
        request.deviceid = XIAllMasterDevices;
        request_XIWarpPointer(&client_request, &request, BadDevice);
    
        request.src_win = root.drawable.id;
        request.dst_win = root.drawable.id;
        request.deviceid = devices.vcp->id;
        request_XIWarpPointer(&client_request, &request, Success);
        request.deviceid = devices.vck->id;
        request_XIWarpPointer(&client_request, &request, BadDevice);
        request.deviceid = devices.mouse->id;
        request_XIWarpPointer(&client_request, &request, BadDevice);
        request.deviceid = devices.kbd->id;
        request_XIWarpPointer(&client_request, &request, BadDevice);
    
        devices.mouse->master = NULL;       /* Float, kind-of */
        request.deviceid = devices.mouse->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        for (i = devices.kbd->id + 1; i <= 0xFFFF; i++) {
            request.deviceid = i;
            request_XIWarpPointer(&client_request, &request, BadDevice);
        }
    
        request.src_win = window.drawable.id;
        request.deviceid = devices.vcp->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        request.deviceid = devices.mouse->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        request.src_win = root.drawable.id;
        request.dst_win = 0xFFFF;   /* invalid window */
        request_XIWarpPointer(&client_request, &request, BadWindow);
    
        request.src_win = 0xFFFF;   /* invalid window */
        request.dst_win = root.drawable.id;
        request_XIWarpPointer(&client_request, &request, BadWindow);
    
        request.src_win = None;
        request.dst_win = None;
    
        request.dst_y = 0;
        expected_y = SPRITE_Y;
    
        request.dst_x = 1 << 16;
        expected_x = SPRITE_X + 1;
        request.deviceid = devices.vcp->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        request.dst_x = -1 << 16;
        expected_x = SPRITE_X - 1;
        request.deviceid = devices.vcp->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        request.dst_x = 0;
        expected_x = SPRITE_X;
    
        request.dst_y = 1 << 16;
        expected_y = SPRITE_Y + 1;
        request.deviceid = devices.vcp->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        request.dst_y = -1 << 16;
        expected_y = SPRITE_Y - 1;
        request.deviceid = devices.vcp->id;
        request_XIWarpPointer(&client_request, &request, Success);
    
        /* FIXME: src_x/y checks */
    }
    
    int
    main(int argc, char **argv)
    {
        init_simple();
        screen.SetCursorPosition = ScreenSetCursorPosition;
    
        test_XIWarpPointer();
    
        return 0;
    }