From: havoc Date: Sat, 10 May 2008 07:50:09 +0000 (+0000) Subject: fixed bug where vid_dgamouse cvar broke support for absolute mouse X-Git-Tag: xonotic-v0.1.0preview~2237 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=5de1b2e6b1639f66f9aca218f0327687cb269402;p=xonotic%2Fdarkplaces.git fixed bug where vid_dgamouse cvar broke support for absolute mouse positioning git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@8295 d7cf8633-e32d-0410-b094-e92efae38249 --- diff --git a/vid_glx.c b/vid_glx.c index 243e3e3e..00e1cb5c 100644 --- a/vid_glx.c +++ b/vid_glx.c @@ -249,12 +249,18 @@ static Cursor CreateNullCursor(Display *display, Window root) void VID_GrabMouse(qboolean grab) { + qboolean usedgamouse; if (!vidx11_display) return; + usedgamouse = grab && vid.mouseaim && vid_dgamouse.integer; +#if !defined(__APPLE__) && !defined(SUNOS) + if (!vid_x11_dgasupported) + usedgamouse = false; +#endif if (grab) { #if !defined(__APPLE__) && !defined(SUNOS) - if(vid_usingmouse && (vid_usingdgamouse != !!vid_dgamouse.integer)) + if(vid_usingmouse && (vid_usingdgamouse != usedgamouse)) VID_GrabMouse(false); // ungrab first! #endif if (!vid_usingmouse && mouse_avail && win) @@ -272,7 +278,8 @@ void VID_GrabMouse(qboolean grab) XGrabPointer(vidx11_display, win, True, 0, GrabModeAsync, GrabModeAsync, win, None, CurrentTime); #if !defined(__APPLE__) && !defined(SUNOS) - if (vid_dgamouse.integer && vid_x11_dgasupported) + vid_usingdgamouse = usedgamouse; + if (usedgamouse) { XF86DGADirectVideo(vidx11_display, DefaultScreen(vidx11_display), XF86DGADirectMouse); XWarpPointer(vidx11_display, None, win, 0, 0, 0, 0, 0, 0); @@ -286,9 +293,6 @@ void VID_GrabMouse(qboolean grab) cl_ignoremousemoves = 2; vid_usingmouse = true; -#if !defined(__APPLE__) && !defined(SUNOS) - vid_usingdgamouse = !!vid_dgamouse.integer; -#endif } } else @@ -296,8 +300,9 @@ void VID_GrabMouse(qboolean grab) if (vid_usingmouse) { #if !defined(__APPLE__) && !defined(SUNOS) - if (vid_x11_dgasupported) + if (vid_usingdgamouse) XF86DGADirectVideo(vidx11_display, DefaultScreen(vidx11_display), 0); + vid_usingdgamouse = false; #endif XUngrabPointer(vidx11_display, CurrentTime); @@ -368,7 +373,7 @@ static void HandleEvents(void) if (vid.mouseaim) { #if !defined(__APPLE__) && !defined(SUNOS) - if (vid_dgamouse.integer == 1 && vid_x11_dgasupported) + if (vid_usingdgamouse) { in_mouse_x += event.xmotion.x_root; in_mouse_y += event.xmotion.y_root;