diff options
author | Dan Nicholson <dbn.lists@gmail.com> | 2009-09-29 06:14:09 -0700 |
---|---|---|
committer | Dan Nicholson <dbn.lists@gmail.com> | 2009-09-29 06:14:09 -0700 |
commit | 9a56e5e5bfa4bc56b8ed0108ca314f5fbd0e6c52 (patch) | |
tree | c5bd903da3b5773d5d7add6f8aaa959560fbdb26 /xts5/XI/XUngrabDevice.m | |
parent | 81e754dfd0fbed32efe8f3cc89675e0ff4f3b86d (diff) |
xts5: Flatten XI directory more
Diffstat (limited to 'xts5/XI/XUngrabDevice.m')
-rw-r--r-- | xts5/XI/XUngrabDevice.m | 398 |
1 files changed, 398 insertions, 0 deletions
diff --git a/xts5/XI/XUngrabDevice.m b/xts5/XI/XUngrabDevice.m new file mode 100644 index 00000000..d8f3bf7d --- /dev/null +++ b/xts5/XI/XUngrabDevice.m @@ -0,0 +1,398 @@ +Copyright (c) 2005 X.Org Foundation L.L.C. + +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 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. + +Copyright (c) Applied Testing and Technology, Inc. 1995 +All Rights Reserved. + +>># Project: VSW5 +>># +>># File: xts5/XI/ungrbdvc/ungrbdvc.m +>># +>># Description: +>># Tests for XUngrabDevice() +>># +>># Modifications: +>># $Log: ungrbdv.m,v $ +>># Revision 1.2 2005-11-03 08:42:09 jmichael +>># clean up all vsw5 paths to use xts5 instead. +>># +>># Revision 1.1.1.2 2005/04/15 14:05:14 anderson +>># Reimport of the base with the legal name in the copyright fixed. +>># +>># Revision 8.0 1998/12/23 23:32:10 mar +>># Branch point for Release 5.0.2 +>># +>># Revision 7.0 1998/10/30 22:52:29 mar +>># Branch point for Release 5.0.2b1 +>># +>># Revision 6.1 1998/09/03 02:07:08 mar +>># vswsr212 - avoid conflict with sys/time.h definition of time +>># +>># Revision 6.0 1998/03/02 05:23:43 tbr +>># Branch point for Release 5.0.1 +>># +>># Revision 5.0 1998/01/26 03:20:15 tbr +>># Branch point for Release 5.0.1b1 +>># +>># Revision 4.0 1995/12/15 09:04:19 tbr +>># Branch point for Release 5.0.0 +>># +>># Revision 3.2 1995/12/15 01:02:44 andy +>># Prepare for GA Release +>># +/* +Copyright (c) 1990, 1991 X Consortium + +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 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 +X CONSORTIUM 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. + +Except as contained in this notice, the name of the X Consortium shall not be +used in advertising or otherwise to promote the sale, use or other dealings +in this Software without prior written authorization from the X Consortium. + +Copyright 1993 by the Hewlett-Packard Company. + +Copyright 1990, 1991 UniSoft Group Limited. + +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, and that the names of HP, and UniSoft not be +used in advertising or publicity pertaining to distribution of the +software without specific, written prior permission. HP, and UniSoft +make no representations about the suitability of this software for any +purpose. It is provided "as is" without express or implied warranty. +*/ +>>TITLE XUngrabDevice XI +void + +Display *display = Dsp; +XDevice *device; +Time time1=CurrentTime; +>>EXTERN +extern int MinKeyCode; +extern ExtDeviceInfo Devs; + +>>ASSERTION Good B 3 +When the client has actively grabbed the device, then a +call to UngrabDevice releases the device and any queued +events. +>>STRATEGY +Create grab window. +Grab and freeze device. +If no extensions: + Touch test xname. +else + Press and release key. + Call xname. + Verify that events are released. + Create new window. + Verify that device events can be received on it. +>>CODE +Window win; +int n; +int first; +XEvent ev; +XEventClass dkclass[2]; +int dkp, dkr; + + if (!Setup_Extension_DeviceInfo(KeyMask)) + { + untested("%s: No input extension key device.\n", TestName); + return; + } + device = Devs.Key; + DeviceKeyPress(device, dkp, dkclass[0]); + DeviceKeyRelease(device, dkr, dkclass[1]); + win = defwin(display); + XSelectExtensionEvent(display, win, dkclass, 2); + + XGrabDevice(display, device, win, False, 0, NULL, GrabModeSync, GrabModeAsync, time1); + + if (noext(0)) { + XCALL; + untested("There is no reliable test method, but a touch test was performed"); + return; + } else + CHECK; + + (void) warppointer(display, win, 10, 10); + XSync(display,1); + devicekeypress(display, Devs.Key, MinKeyCode); + devicekeyrel(display, Devs.Key, MinKeyCode); + XSync(display,0); + + if (XPending(display)) { + report("Got events while device was meant to be frozen"); + FAIL; + } else + CHECK; + + XCALL; + XSync(display,0); + + n = getevent(display, &ev); + if (n != 2) { + report("Expecting two events to be released after grab"); + report(" got %d", n); + FAIL; + } else { + first = ev.type; + (void) getevent(display, &ev); + + if (ev.type != dkp && first != dkp) { + report("Did not get DeviceKeyPress event after releasing grab"); + FAIL; + } else + CHECK; + if (ev.type != dkr && first != dkr) { + report("Did not get DeviceKeyRelease event after releasing grab"); + FAIL; + } else + CHECK; + } + + win = defwin(display); + XSelectExtensionEvent(display, win, &dkclass[0], 1); + (void) warppointer(display, win, 5, 5); + devicekeypress(display, Devs.Key, MinKeyCode); + if (XPending(display)) { + XNextEvent(display, &ev); + if (ev.type == dkp) + CHECK; + } else { + report("Device grab was not released"); + FAIL; + } + + CHECKPASS(5); + + devicekeyrel(display, Devs.Key, MinKeyCode); + devicerelkeys(Devs.Key); + restoredevstate(); + +>>ASSERTION Good B 3 +When the specified time is earlier than the last-device- +grab time or is later than the current X server time, then a +call to UngrabDevice does not release the device and any +queued events. +>>STRATEGY +Get current time. +Grab device and freeze other devices with this time. +Call xname with earlier time. +Verify that the pointer is still frozen and therefore device grab is not +released. + +Get current time and add several seconds to get future time. +Call xname with this time. +Verify that the pointer is still frozen and therefore keyboard grab is not +released. +>>EXTERN + +static Status +ispfrozen() +{ +Window win; +XEvent ev; + + win = defwin(display); + XSelectInput(display, win, PointerMotionMask); + + (void) warppointer(display, win, 0, 0); + (void) warppointer(display, win, 1, 1); + + if (XCheckWindowEvent(display, win, PointerMotionMask, &ev)) + return(False); + else + return(True); +} + +>>CODE +Window win; + + if (!Setup_Extension_DeviceInfo(KeyMask)) + { + untested("%s: No input extension key device.\n", TestName); + return; + } + device = Devs.Key; + win = defwin(display); + time1 = gettime(display); + + XGrabDevice(display, device, win, False, 0, NULL, GrabModeSync, GrabModeSync, time1); + + time1 -= 1; + XCALL; + + if (ispfrozen()) + CHECK; + else { + report("Grab released for time earlier than last-device-grab time"); + FAIL; + } + + time1 = gettime(display); + time1 += (config.speedfactor+1) * 1000000; + + XCALL; + + if (ispfrozen()) + CHECK; + else { + report("Grab release for time later than current X server time"); + FAIL; + } + + CHECKPASS(2); +>>ASSERTION Good B 3 +A call to UngrabDevice generates DeviceFocusIn and DeviceFocusOut +events as though the focus were to change from the grab +window to the current focus window. +>>STRATEGY +Create grab window. +Create a focus window and set focus to that window. +Grab device. +Enable events on windows. +Call xname to release device. +Verify that DeviceFocusIn and DeviceFocusOut events are received. +>>CODE +Window grabwin; +Window win; +Window ofocus; +XEvent ev; +XDeviceFocusInEvent figood; +XDeviceFocusOutEvent fogood; +int orevert; +Time otime; +int dfi, dfo; +XEventClass dfclass[2]; + + if (!Setup_Extension_DeviceInfo(AnyMask)) + { + untested("%s: Required input extension device not present.\n", TestName); + return; + } + device = Devs.Any; + DeviceFocusIn(device, dfi, dfclass[0]); + DeviceFocusOut(device, dfo, dfclass[1]); + /* + * Save current input focus to pose as little inconvenience as + * possible. + */ + XGetDeviceFocus(display, device, &ofocus, &orevert, &otime); + + grabwin = defwin(display); + win = defwin(display); + XSetDeviceFocus(display, device, win, RevertToNone, CurrentTime); + if (isdeleted()) { + report("Could not set up focus"); + return; + } + XGrabDevice(display, device, grabwin, False, 1, dfclass, GrabModeSync, GrabModeSync, time1); + + XSelectExtensionEvent(display, grabwin, dfclass, 2); + XSelectExtensionEvent(display, win, dfclass, 2); + + XCALL; + + /* + * Set up the expected good events. + */ + defsetevent(figood, display, dfi); + figood.window = win; + figood.mode = NotifyUngrab; + figood.detail = NotifyNonlinear; + figood.deviceid = device->device_id; + + defsetevent(fogood, display, dfo); + fogood.window = grabwin; + fogood.mode = NotifyUngrab; + fogood.detail = NotifyNonlinear; + fogood.deviceid = device->device_id; + + if (getevent(display, &ev) == 0 || ev.type != dfo) { + report("Did not get expected DeviceFocusOut event"); + FAIL; + } else + CHECK; + + if (checkevent((XEvent*)&fogood, &ev)) + FAIL; + else + CHECK; + + if (getevent(display, &ev) == 0 || ev.type != dfi) { + report("Did not get expected DeviceFocusIn event"); + FAIL; + } else + CHECK; + + if (checkevent((XEvent*)&figood, &ev)) + FAIL; + else + CHECK; + + /* Reset old focus */ + XSetDeviceFocus(display, device, ofocus, orevert, CurrentTime); + XSync(display,0); + + CHECKPASS(4); + +>>ASSERTION Bad B 3 +A call to xname will fail with a BadDevice error if an invalid device +is specified. +>>STRATEGY +Make the call with an invalid device. +>>CODE baddevice +XDevice nodevice; +XID baddevice; +int ximajor, first, err; + + if (!XQueryExtension (display, INAME, &ximajor, &first, &err)) + { + untested("%s: Input extension not supported.\n", TestName); + return; + } + + BadDevice (display, baddevice); + nodevice.device_id = -1; + device = &nodevice; + + XCALL; + + if (geterr() == baddevice) + PASS; + else + FAIL; |