diff options
Diffstat (limited to 'xts5/XtC/XtPeekEvent/XtPeekEvent.m')
-rw-r--r-- | xts5/XtC/XtPeekEvent/XtPeekEvent.m | 341 |
1 files changed, 341 insertions, 0 deletions
diff --git a/xts5/XtC/XtPeekEvent/XtPeekEvent.m b/xts5/XtC/XtPeekEvent/XtPeekEvent.m new file mode 100644 index 00000000..90443970 --- /dev/null +++ b/xts5/XtC/XtPeekEvent/XtPeekEvent.m @@ -0,0 +1,341 @@ +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. +$Header: /cvs/xtest/xtest/xts5/tset/XtC/XtPeekEvent/XtPeekEvent.m,v 1.2 2005-04-21 09:40:42 ajosey Exp $ + +Copyright (c) 1999 The Open Group +Copyright (c) Applied Testing and Technology, Inc. 1993, 1994, 1995 +Copyright (c) 88open Consortium, Ltd. 1990, 1991, 1992, 1993 +All Rights Reserved. + +>># +>># Project: VSW5 +>># +>># File: tset/XtC/XtPeekEvent/XtPeekEvent.m +>># +>># Description: +>># Tests for XtPeekEvent() +>># +>># Modifications: +>># $Log: tpeekevnt.m,v $ +>># Revision 1.2 2005-04-21 09:40:42 ajosey +>># resync to VSW5.1.5 +>># +>># Revision 8.3 2005/01/21 12:29:40 gwc +>># Updated copyright notice +>># +>># Revision 8.2 1999/11/26 12:30:34 vsx +>># avoid fixed file locations (for exec-in-place false) +>># +>># Revision 8.1 1999/11/24 11:34:29 vsx +>># TSD4.W.00162: avoid semctl ERANGE error on fast systems +>># +>># Revision 8.0 1998/12/23 23:38:29 mar +>># Branch point for Release 5.0.2 +>># +>># Revision 7.0 1998/10/30 23:01:33 mar +>># Branch point for Release 5.0.2b1 +>># +>># Revision 6.0 1998/03/02 05:29:31 tbr +>># Branch point for Release 5.0.1 +>># +>># Revision 5.1 1998/02/24 02:49:16 andy +>># Made test2 contingent on coverage +>># +>># Revision 5.0 1998/01/26 03:26:05 tbr +>># Branch point for Release 5.0.1b1 +>># +>># Revision 4.1 1998/01/15 22:01:43 andy +>># Changed type of processing variable to Boolean to match XtPending +>># signature (SR 156). +>># +>># Revision 4.0 1995/12/15 09:22:37 tbr +>># Branch point for Release 5.0.0 +>># +>># Revision 3.1 1995/12/15 02:19:13 andy +>># Prepare for GA Release +>># +>>EXTERN +#include <X11/IntrinsicP.h> +#include <X11/ConstrainP.h> +#include <X11/CoreP.h> + +XtAppContext app_ctext; +Widget topLevel, panedw, boxw1, boxw2; +Widget labelw, rowcolw, click_quit; + +extern char *event_names[]; + +Widget topLevel; +Widget panedw, boxw1, boxw2; + +XtInputId input_ret; +char *msg = "Hello World"; +int acount = 0; +FILE *fid; + +void XtIOP_Proc(client_data, source, id) +XtPointer client_data; +int *source; +XtInputId *id; +{ + avs_set_event(2, 1); +} + +/* +** XtTMO1_Proc +*/ +void XtTMO1_Proc(client_data, id) +XtPointer client_data; +XtIntervalId *id; +{ + exit(0); +} +/* +** XtTMO2_Proc +*/ +void XtTMO2_Proc(client_data, id) +XtPointer client_data; +XtIntervalId *id; +{ + avs_set_event(1, 1); +} +/* +** XtTMO3_Proc +*/ +void XtTMO3_Proc(client_data, id) +XtPointer client_data; +XtIntervalId *id; +{ + /* + ** Send event KeyPress and wake up XtPeekEvent. + */ + send_event(topLevel, KeyPress, KeyPressMask, TRUE ); +} +void XtTMO4_Proc(client_data, id) +XtPointer client_data; +XtIntervalId *id; +{ +char *data; + + avs_set_event(1, 1); + data = "data1"; + sprintf(ebuf, "PREP: Open file %s for read", data); + tet_infoline(ebuf); + if ((fid = (FILE *)fopen(data, "w+")) == NULL) { + sprintf(ebuf, "ERROR: Could not open file %s", data); + tet_infoline(ebuf); + tet_result(TET_FAIL); + } + tet_infoline("TEST: Register file as an input source"); + input_ret = XtAddInput(fileno(fid), (XtPointer)XtInputReadMask, XtIOP_Proc, (XtPointer)msg); + XtAddTimeOut(AVSXTLOOPTIMEOUT, XtTMO3_Proc, NULL); +} + +>>SET tpstartup avs_alloc_sem +>>SET tpcleanup avs_free_sem +>>TITLE XtPeekEvent XtC +Boolean +XtPeekEvent(event_return) +>>ASSERTION Good A +When the calling process has at least one X +event in the input queue a successful call to +Boolean XtPeekEvent(event_return) +shall copy the event at the head of the input +queue in event_return and return a non-zero value. +>>CODE +Widget labelw_msg; +char *msg = "Event widget"; +XEvent loop_event, return_event; +Display *display; +Boolean status; +pid_t pid2; +int i; +pid_t pid3; +int pstatus; + + FORK(pid3); + avs_xt_hier_def("Tpeekevnt1", "XtPeekEvent"); + FORK(pid2); + tet_infoline("PREP: Create windows for widgets and map them"); + XtRealizeWidget(topLevel); + tet_infoline("PREP: Send KeyPress event over wire"); + send_event(boxw1, KeyPress, KeyPressMask, TRUE); + tet_infoline("PREP: Register timeout"); + XtAddTimeOut(AVSXTLOOPTIMEOUT, XtTMO1_Proc, NULL); + tet_infoline("TEST: XtPeekEvent will non-destructively report event"); + display = XtDisplay(boxw1); + /*loop for events*/ + for (i = 0; i == 0;) { + /*peek looking for the KeyPress we sent*/ + status = XtPeekEvent(&return_event); + if (status == True) { + if ( return_event.type == KeyPress ) { + /*check peek was non-destructive*/ + XtNextEvent(&loop_event); + XSync(display, False); + XtDispatchEvent(&loop_event); + if ( loop_event.type != KeyPress ) { + sprintf(ebuf, "ERROR: Peek removed event"); + tet_infoline(ebuf); + tet_result(TET_FAIL); + } + exit(0); + } + else { + XtNextEvent(&loop_event); + XSync(display, False); + XtDispatchEvent(&loop_event); + } + } + else { + XtNextEvent(&loop_event); + XSync(display, False); + XtDispatchEvent(&loop_event); + } + } /* end for */ + LKROF(pid2, AVSXTTIMEOUT-4); + KROF3(pid3, pstatus, AVSXTTIMEOUT-2); + if (pstatus != 0) { + tet_infoline("ERROR: Test process exited abnormally"); + tet_infoline(" May mean display cannot be opened"); + tet_result(TET_UNRESOLVED); + } + else + tet_result(TET_PASS); +>>ASSERTION Good A +When the calling process has no X event in the input queue a call to +Boolean XtPeekEvent(event_return) +shall flush the output buffers of every display +in the calling process, block until an event is +available on the queue, copy the event in +.A event_return, +and return a non-zero value if the event is an X event. +>>CODE +Boolean status; +pid_t pid2; +int waited = 0; +XEvent loop_event, return_event; +Display *display; +Boolean processing; +int i; +pid_t pid3; +int pstatus; + +/*this test is in the process of review vis consistency of the spec, +test suite, and sample code*/ +if (config.coverage == 0) { + FORK(pid3); + avs_xt_hier_def("Tpeekevnt2", "XtPeekEvent"); + FORK(pid2); + XtAddTimeOut(AVSXTLOOPTIMEOUT, XtTMO3_Proc, NULL); + tet_infoline("PREP: Create windows for widgets and map them"); + XtRealizeWidget(topLevel); + tet_infoline("TEST: Loop for events and check XtPeekEvent waited for it"); + /*this is a pretty weak test, but its not clear what a better*/ + /*test method would be*/ + display = XtDisplay(topLevel); + for (i = 0; i == 0;) { + processing = XtPending(); + /*this bit gives things time to settle down after the*/ + /*burst of events after the XtRealize. Ideally, this will*/ + /*cause the peek call to wait for the timeout event.*/ + /*If the user is moving the cursor or whatever, this*/ + /*may do the waking up instead, but it really*/ + /*doesn't matter*/ + if (processing == 0) { + sleep(1); + processing = XtPending(); + } + /*no events*/ + if (processing == 0) { + status = XtPeekEvent(&loop_event); + /*if it comes back and there are events, it must*/ + /*have waited*/ + processing = XtPending(); + if (processing != 0) + break; + else { + sprintf(ebuf, "ERROR: XtPeekEvent returned, no events are pending"); + tet_infoline(ebuf); + tet_result(TET_FAIL); + exit(0); + } + } + /*dispatch events until emptiness happiness*/ + XtNextEvent(&loop_event); + XSync(display, False); + XtDispatchEvent(&loop_event); + } + /*if it timed out, it never returned or the queue never emptied*/ + LKROF(pid2, AVSXTTIMEOUT-4); + KROF3(pid3, pstatus, AVSXTTIMEOUT-2); + if (pstatus != 0) { + tet_infoline("ERROR: Test process exited abnormally"); + tet_result(TET_UNRESOLVED); + } + else + tet_result(TET_PASS); +} else + tet_result(TET_UNTESTED); +>>ASSERTION Good A +When a call to +Boolean XtPeekEvent(event_return) +blocks and input occurs for an alternate input source it +shall return zero. +>>CODE +Boolean status; +pid_t pid2; +int waited = 0; +XEvent loop_event, return_event; +Display *display; +int i; +pid_t pid3; +int pstatus; + + FORK(pid3); + avs_xt_hier_def("Tpeekevnt3", "XtPeekEvent"); + FORK(pid2); + XtAddTimeOut(AVSXTLOOPTIMEOUT, XtTMO4_Proc, NULL); + tet_infoline("PREP: Create windows for widgets and map them"); + XtRealizeWidget(topLevel); + display = XtDisplay(topLevel); + /*dispatch events until the timeout starts the input source*/ + while (avs_get_event(1) == 0) { + XtNextEvent(&loop_event); + XSync(display, False); + XtDispatchEvent(&loop_event); + } + tet_infoline("TEST: XtPeekEvent returns 0 for alternate input"); + status = XtPeekEvent(&loop_event); + if (status != 0) { + sprintf(ebuf, "ERROR: XtPeekEvent returned %s, expected 0", status); + tet_infoline(ebuf); + tet_result(TET_FAIL); + } + LKROF(pid2, AVSXTTIMEOUT-4); + KROF3(pid3, pstatus, AVSXTTIMEOUT-2); + if (pstatus != 0) { + tet_infoline("ERROR: Test process exited abnormally"); + tet_result(TET_UNRESOLVED); + } + else { + tet_result(TET_PASS); + } + unlink("data1"); |