/* Copyright 1993 by Davor Matic Permission to use, copy, modify, distribute, and sell this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. Davor Matic makes no representations about the suitability of this software for any purpose. It is provided "as is" without express or implied warranty. */ #include #include #include #include #include #include #include #include "screenint.h" #include "input.h" #include "misc.h" #include "cursorstr.h" #include "scrnintstr.h" #include "servermd.h" #include "mipointrst.h" #include "xnest-xcb.h" #include "Display.h" #include "Screen.h" #include "XNCursor.h" #include "Keyboard.h" #include "Args.h" xnestCursorFuncRec xnestCursorFuncs = { NULL }; Bool xnestRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScreen, CursorPtr pCursor) { uint32_t valuemask = XCB_GC_FUNCTION | XCB_GC_PLANE_MASK | XCB_GC_FOREGROUND | XCB_GC_BACKGROUND | XCB_GC_CLIP_MASK; xcb_params_gc_t values = { .function = XCB_GX_COPY, .plane_mask = ((uint32_t)~0L), .foreground = 1L, }; xcb_aux_change_gc(xnestUpstreamInfo.conn, xnestBitmapGC, valuemask, &values); uint32_t const winId = xnestDefaultWindows[pScreen->myNum]; Pixmap const source = xcb_generate_id(xnestUpstreamInfo.conn); xcb_create_pixmap(xnestUpstreamInfo.conn, 1, source, winId, pCursor->bits->width, pCursor->bits->height); Pixmap const mask = xcb_generate_id(xnestUpstreamInfo.conn); xcb_create_pixmap(xnestUpstreamInfo.conn, 1, mask, winId, pCursor->bits->width, pCursor->bits->height); int const pixmap_len = BitmapBytePad(pCursor->bits->width) * pCursor->bits->height; xcb_put_image(xnestUpstreamInfo.conn, XCB_IMAGE_FORMAT_XY_BITMAP, source, xnestBitmapGC, pCursor->bits->width, pCursor->bits->height, 0, // x 0, // y 0, // left_pad 1, // depth pixmap_len, (uint8_t*) pCursor->bits->source); xcb_put_image(xnestUpstreamInfo.conn, XCB_IMAGE_FORMAT_XY_BITMAP, mask, xnestBitmapGC, pCursor->bits->width, pCursor->bits->height, 0, // x 0, // y 0, // left_pad 1, // depth pixmap_len, (uint8_t*) pCursor->bits->mask); xnestSetCursorPriv(pCursor, pScreen, calloc(1, sizeof(xnestPrivCursor))); uint32_t cursor = xcb_generate_id(xnestUpstreamInfo.conn); xcb_create_cursor(xnestUpstreamInfo.conn, cursor, source, mask, pCursor->foreRed, pCursor->foreGreen, pCursor->foreBlue, pCursor->backRed, pCursor->backGreen, pCursor->backBlue, pCursor->bits->xhot, pCursor->bits->yhot); xnestCursor(pCursor, pScreen) = cursor; xcb_free_pixmap(xnestUpstreamInfo.conn, source); xcb_free_pixmap(xnestUpstreamInfo.conn, mask); return TRUE; } Bool xnestUnrealizeCursor(DeviceIntPtr pDev, ScreenPtr pScreen, CursorPtr pCursor) { xcb_free_cursor(xnestUpstreamInfo.conn, xnestCursor(pCursor, pScreen)); free(xnestGetCursorPriv(pCursor, pScreen)); return TRUE; } void xnestRecolorCursor(ScreenPtr pScreen, CursorPtr pCursor, Bool displayed) { xcb_recolor_cursor(xnestUpstreamInfo.conn, xnestCursor(pCursor, pScreen), pCursor->foreRed, pCursor->foreGreen, pCursor->foreBlue, pCursor->backRed, pCursor->backGreen, pCursor->backBlue); } void xnestSetCursor(DeviceIntPtr pDev, ScreenPtr pScreen, CursorPtr pCursor, int x, int y) { if (pCursor) { uint32_t cursor = xnestCursor(pCursor, pScreen); xcb_change_window_attributes(xnestUpstreamInfo.conn, xnestDefaultWindows[pScreen->myNum], XCB_CW_CURSOR, &cursor); } } void xnestMoveCursor(DeviceIntPtr pDev, ScreenPtr pScreen, int x, int y) { } Bool xnestDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScreen) { xnestCursorFuncPtr pScreenPriv; pScreenPriv = (xnestCursorFuncPtr) dixLookupPrivate(&pScreen->devPrivates, &xnestScreenCursorFuncKeyRec); return pScreenPriv->spriteFuncs->DeviceCursorInitialize(pDev, pScreen); } void xnestDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScreen) { xnestCursorFuncPtr pScreenPriv; pScreenPriv = (xnestCursorFuncPtr) dixLookupPrivate(&pScreen->devPrivates, &xnestScreenCursorFuncKeyRec); pScreenPriv->spriteFuncs->DeviceCursorCleanup(pDev, pScreen); }