summaryrefslogtreecommitdiff
path: root/xts5/Xlib12/XNextEvent.m
diff options
context:
space:
mode:
Diffstat (limited to 'xts5/Xlib12/XNextEvent.m')
-rw-r--r--xts5/Xlib12/XNextEvent.m267
1 files changed, 267 insertions, 0 deletions
diff --git a/xts5/Xlib12/XNextEvent.m b/xts5/Xlib12/XNextEvent.m
new file mode 100644
index 00000000..bbf0e43a
--- /dev/null
+++ b/xts5/Xlib12/XNextEvent.m
@@ -0,0 +1,267 @@
+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/Xlib12/XNextEvent.m
+>>#
+>># Description:
+>># Tests for XNextEvent()
+>>#
+>># Modifications:
+>># $Log: nxtevnt.m,v $
+>># Revision 1.2 2005-11-03 08:42:35 jmichael
+>># clean up all vsw5 paths to use xts5 instead.
+>>#
+>># Revision 1.1.1.2 2005/04/15 14:05:18 anderson
+>># Reimport of the base with the legal name in the copyright fixed.
+>>#
+>># Revision 8.0 1998/12/23 23:33:23 mar
+>># Branch point for Release 5.0.2
+>>#
+>># Revision 7.0 1998/10/30 22:54:49 mar
+>># Branch point for Release 5.0.2b1
+>>#
+>># Revision 6.0 1998/03/02 05:24:48 tbr
+>># Branch point for Release 5.0.1
+>>#
+>># Revision 5.0 1998/01/26 03:21:20 tbr
+>># Branch point for Release 5.0.1b1
+>>#
+>># Revision 4.0 1995/12/15 09:07:37 tbr
+>># Branch point for Release 5.0.0
+>>#
+>># Revision 3.1 1995/12/15 01:08:05 andy
+>># Prepare for GA Release
+>>#
+/*
+Portions of this software are based on Xlib and X Protocol Test Suite.
+We have used this material under the terms of its copyright, which grants
+free use, subject to the conditions below. Note however that those
+portions of this software that are based on the original Test Suite have
+been significantly revised and that all such revisions are copyright (c)
+1995 Applied Testing and Technology, Inc. Insomuch as the proprietary
+revisions cannot be separated from the freely copyable material, the net
+result is that use of this software is governed by the ApTest copyright.
+
+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.
+
+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 name of UniSoft not be
+used in advertising or publicity pertaining to distribution of the
+software without specific, written prior permission. UniSoft
+makes no representations about the suitability of this software for any
+purpose. It is provided "as is" without express or implied warranty.
+*/
+>>TITLE XNextEvent Xlib12
+void
+XNextEvent(display, event_return)
+Display *display = Dsp;
+XEvent *event_return = &_event;
+>>EXTERN
+static XEvent _event;
+/*
+ * Can not use "xcall" because it empties the event queue.
+ */
+#define _xcall_() \
+ _startcall(display);\
+ XNextEvent(display, event_return);\
+ _endcall(display)
+>>ASSERTION Good A
+When the event queue is not empty,
+the a call to xname
+returns the first event from the event queue in
+.A event_return .
+>>STRATEGY
+Discard all events on the event queue.
+Call XPutBackEvent to put events on the event queue.
+Call XNextEvent.
+Verify that XNextEvent returned the correct event.
+>>CODE
+XEvent event;
+
+/* Discard all events on the event queue. */
+ XSync(display, True);
+/* Call XPutBackEvent to put events on the event queue. */
+ event.type = KeyPress;
+ XPutBackEvent(display, &event);
+ event.type = KeyRelease;
+ XPutBackEvent(display, &event);
+ event.type = ButtonPress;
+ XPutBackEvent(display, &event);
+/* Call XNextEvent. */
+ _xcall_();
+/* Verify that XNextEvent returned the correct event. */
+ if (event_return->type != event.type) {
+ report("Returned %s, expected %s", eventname(event_return->type), eventname(event.type));
+ FAIL;
+ }
+ else
+ CHECK;
+ /* empty event queue */
+ XSync(display, True);
+
+ CHECKPASS(1);
+>>ASSERTION Good A
+A call to xname removes the returned event from the event queue.
+>>STRATEGY
+Discard all events on the event queue.
+Call XPutBackEvent to put a three events on the event queue.
+Call XNextEvent.
+Verify that XNextEvent returned the correct event.
+Call XNextEvent.
+Verify that XNextEvent returned the correct event.
+Call XNextEvent.
+Verify that XNextEvent returned the correct event.
+Verify that the event queue is now empty.
+>>CODE
+XEvent event;
+
+/* Discard all events on the event queue. */
+ XSync(display, True);
+/* Call XPutBackEvent to put a three events on the event queue. */
+ event.type = KeyPress;
+ XPutBackEvent(display, &event);
+ XPutBackEvent(display, &event);
+ XPutBackEvent(display, &event);
+/* Call XNextEvent. */
+ _xcall_();
+/* Verify that XNextEvent returned the correct event. */
+ if (event_return->type != event.type) {
+ report("Returned %s, expected %s", eventname(event_return->type), eventname(event.type));
+ FAIL;
+ }
+ else
+ CHECK;
+/* Call XNextEvent. */
+ _xcall_();
+/* Verify that XNextEvent returned the correct event. */
+ if (event_return->type != event.type) {
+ report("Returned %s, expected %s", eventname(event_return->type), eventname(event.type));
+ FAIL;
+ }
+ else
+ CHECK;
+/* Call XNextEvent. */
+ _xcall_();
+/* Verify that XNextEvent returned the correct event. */
+ if (event_return->type != event.type) {
+ report("Returned %s, expected %s", eventname(event_return->type), eventname(event.type));
+ FAIL;
+ }
+ else
+ CHECK;
+/* Verify that the event queue is now empty. */
+ if (XPending(display) != 0) {
+ report("Events not removed from the event queue.");
+ FAIL;
+ }
+ else
+ CHECK;
+ /* empty event queue */
+ XSync(display, True);
+
+ CHECKPASS(4);
+>>ASSERTION Good A
+When the event queue is empty,
+then a call to xname
+flushes the output buffer and
+blocks until an event is received and
+returns the event in
+.A event_return .
+>>STRATEGY
+Create bad pixmap.
+Discard all events on the event queue.
+Call XFreePixmap with bad pixmap.
+Call XNextEvent and verify that blocking did occur.
+Verify that output buffer was flushed.
+>>CODE
+Block_Info info;
+int block_status;
+Pixmap pm;
+Display *client2;
+
+/* Create client2. */
+ client2 = opendisplay();
+ if (client2 == (Display *) NULL) {
+ delete("Can not open display");
+ return;
+ }
+ else
+ CHECK;
+/* Discard all events on the event queue. */
+ XSync(display, True);
+/* Create pixmap. */
+ /* avoid using makepixm() */
+ pm = XCreatePixmap(display, DRW(display), 10, 10, 1);
+/* Call XNextEvent and verify that blocking did occur. */
+ XNextEvent_Type(info);
+ block_status = block(display, (XEvent *) NULL, &info);
+ if (block_status == -1)
+ return;
+ else
+ CHECK;
+ if (block_status == 0) {
+ report("Blocking did not occur.");
+ FAIL;
+ }
+ else
+ CHECK;
+/* Verify that the output buffer was flushed. */
+ _startcall(client2);
+ XFreePixmap(client2, pm);
+ XSync(client2, True);
+ _endcall(client2);
+ if (geterr() != Success) {
+ report("The output buffer was not flushed.");
+ XFreePixmap(display, pm);
+ FAIL;
+ }
+ else
+ CHECK;
+
+ CHECKPASS(4);