diff options
Diffstat (limited to 'xorg-server/hw/xwin/wincursor.c')
| -rw-r--r-- | xorg-server/hw/xwin/wincursor.c | 16 | 
1 files changed, 13 insertions, 3 deletions
| diff --git a/xorg-server/hw/xwin/wincursor.c b/xorg-server/hw/xwin/wincursor.c index 021b8b82c..0b8f7e7b2 100644 --- a/xorg-server/hw/xwin/wincursor.c +++ b/xorg-server/hw/xwin/wincursor.c @@ -99,8 +99,16 @@ winPointerWarpCursor (ScreenPtr pScreen, int x, int y)        return;      } -  /* Only update the Windows cursor position if we are active */ -  if (pScreenPriv->hwndScreen == GetForegroundWindow ()) +  /* +     Only update the Windows cursor position if root window is active, +     or we are in a rootless mode +  */ +  if ((pScreenPriv->hwndScreen == GetForegroundWindow ()) +      || pScreenPriv->pScreenInfo->fRootless +#ifdef XWIN_MULTIWINDOW +      || pScreenPriv->pScreenInfo->fMultiWindow +#endif +      )      {        /* Get the client area coordinates */        GetClientRect (pScreenPriv->hwndScreen, &rcClient); @@ -601,9 +609,11 @@ winInitCursor (ScreenPtr pScreen)    pPointPriv = (miPointerScreenPtr)        dixLookupPrivate(&pScreen->devPrivates, miPointerScreenKey); +  if (pPointPriv) +  {    pScreenPriv->cursor.spriteFuncs = pPointPriv->spriteFuncs;    pPointPriv->spriteFuncs = &winSpriteFuncsRec; - +  }    pScreenPriv->cursor.handle = NULL;    pScreenPriv->cursor.visible = FALSE; | 
