summaryrefslogtreecommitdiff
path: root/xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m
diff options
context:
space:
mode:
authorDan Nicholson <dbn.lists@gmail.com>2009-09-16 12:20:41 -0700
committerDan Nicholson <dbn.lists@gmail.com>2009-09-16 12:20:41 -0700
commit704eb8d4cbfa2f8c47882a8ea6c7732cf5fa20d1 (patch)
tree1f48212ecf5556fbff17172c6904e525481e8653 /xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m
parent5d01bd434ff7186701c931883b110c179d4fa8b8 (diff)
xts5: Move tests out of tset directory
The tset directory was mostly useless and causes extra baggage if the scenario files are going to be used on an installed package. The test directories are now flattened into xts5.
Diffstat (limited to 'xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m')
-rw-r--r--xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m647
1 files changed, 647 insertions, 0 deletions
diff --git a/xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m b/xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m
new file mode 100644
index 00000000..1577c241
--- /dev/null
+++ b/xts5/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m
@@ -0,0 +1,647 @@
+Copyright (c) 2005 X.Org Foundation LLC
+
+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/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m,v 1.1 2005-02-12 14:37:57 anderson Exp $
+
+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/Xt13/XtGetSelectionValuesIncremental/XtGetSelectionValuesIncremental.m
+>>#
+>># Description:
+>># Tests for XtGetSelectionValuesIncremental()
+>>#
+>># Modifications:
+>># $Log: tgtslvali.m,v $
+>># Revision 1.1 2005-02-12 14:37:57 anderson
+>># Initial revision
+>>#
+>># Revision 8.0 1998/12/23 23:38:14 mar
+>># Branch point for Release 5.0.2
+>>#
+>># Revision 7.0 1998/10/30 23:01:15 mar
+>># Branch point for Release 5.0.2b1
+>>#
+>># Revision 6.0 1998/03/02 05:29:16 tbr
+>># Branch point for Release 5.0.1
+>>#
+>># Revision 5.0 1998/01/26 03:25:50 tbr
+>># Branch point for Release 5.0.1b1
+>>#
+>># Revision 4.0 1995/12/15 09:21:50 tbr
+>># Branch point for Release 5.0.0
+>>#
+>># Revision 3.1 1995/12/15 02:17:56 andy
+>># Prepare for GA Release
+>>#
+>>EXTERN
+#include <X11/IntrinsicP.h>
+#include <X11/ConstrainP.h>
+#include <X11/CoreP.h>
+#include <X11/Xatom.h>
+
+XtAppContext app_ctext;
+Widget topLevel, panedw, boxw1, boxw2;
+Widget labelw, rowcolw, click_quit;
+
+#define SELECTION XA_PRIMARY
+#define TYPE XA_STRING
+#define HELLO "Hello"
+#define WORLD "World"
+#define FORMAT 8
+
+/*
+** local functions
+*/
+static Boolean convert_proc();
+static Boolean convert_proc3();
+static void lose_proc();
+static void done_proc();
+static void cancel_proc();
+static void requestor_callback();
+int incr_string = 1;
+int incr_int = 1;
+
+static void XtEVT_handler1(sender_widget, client_data, event, continue_to_dispatch)
+Widget sender_widget;
+XtPointer client_data;
+XEvent *event;
+Boolean *continue_to_dispatch;
+{
+
+ Boolean status;
+ XButtonEvent *bevent;
+
+ bevent = (XButtonEvent *)event;
+ status = XtOwnSelectionIncremental(
+ sender_widget,
+ SELECTION,
+ bevent->time,
+ convert_proc,
+ NULL,
+ done_proc,
+ NULL,
+ client_data
+ );
+ check_dec(True, status, "XtOwnSelectionIncremental return value");
+}
+
+static void XtEVT_handler2(receiver_widget, client_data, event, continue_to_dispatch)
+Widget receiver_widget;
+XtPointer client_data;
+XEvent *event;
+Boolean *continue_to_dispatch;
+{
+ XtPointer cd[2] = {
+ (XtPointer) 0,
+ (XtPointer) 0,
+ };
+ Atom targets[2] = {
+ XA_STRING,
+ XA_INTEGER,
+ };
+
+ XButtonEvent *bevent;
+
+ bevent = (XButtonEvent *)event;
+ XtGetSelectionValuesIncremental(
+ receiver_widget,
+ SELECTION,
+ targets,
+ 2,
+ requestor_callback,
+ cd,
+ bevent->time
+ );
+}
+static Boolean
+convert_proc(w, selection, target, type_return, value_return,
+ length_return, format_return, max_length, client_data, request_id)
+Widget w;
+Atom *selection;
+Atom *target;
+Atom *type_return;
+XtPointer *value_return;
+unsigned long *length_return;
+int *format_return;
+unsigned long *max_length;
+XtPointer client_data;
+XtRequestId *request_id;
+{
+
+ char *data;
+ static int int_value = 0;
+ avs_set_event(5, avs_get_event(5)+1);
+ if ( *target == TYPE ) {
+ switch (incr_string) {
+ case 1:
+ *length_return = strlen(HELLO) * sizeof(char) + 1;
+ data = XtMalloc(*length_return);
+ strcpy(data, HELLO);
+ *value_return = data;
+ *type_return = XA_STRING;
+ *format_return = FORMAT;
+ return(True);
+ case 2:
+ *length_return = strlen(WORLD) * sizeof(char) + 1;
+ data = XtMalloc(*length_return);
+ strcpy(data, WORLD);
+ *value_return = data;
+ *type_return = XA_STRING;
+ *format_return = FORMAT;
+ return(True);
+ default:
+ *length_return = 0;
+ break;
+ } /* end switch */
+ } /* end if type XA_STRING */
+ if ( *target == XA_INTEGER) {
+ switch (incr_int) {
+ case 1:
+ *length_return = sizeof(int);
+ *value_return = (char *)&int_value;
+ *type_return = XA_INTEGER;
+ *format_return = FORMAT;
+ return(True);
+ default:
+ *length_return = 0;
+ break;
+ } /* end switch */
+ } /* end if type XA_INTEGER */
+}
+static void
+lose_proc(w, selection, client_data)
+Widget w;
+Atom *selection;
+XtPointer client_data;
+{
+ sprintf(ebuf, "ERROR: labelw_good widget lost selection ownership");
+ tet_infoline(ebuf);
+ tet_result(TET_FAIL);
+}
+static void
+done_proc(w, selection, target, request_id, client_data)
+Widget w;
+Atom *selection;
+Atom *target;
+XtRequestId *request_id;
+XtPointer client_data;
+{
+ XtDisownSelection(w, *selection, CurrentTime);
+}
+static void
+requestor_callback(w, client_data, selection, type, value,
+ length, format)
+Widget w;
+XtPointer client_data;
+Atom *selection;
+Atom *type;
+XtPointer value;
+unsigned long *length;
+int *format;
+{
+ int integer;
+ if ( *type == XA_STRING ) {
+ avs_set_event(1, XA_STRING);
+ switch (incr_string) {
+ case 1:
+ tet_infoline("TEST: values pased to callback for first segment");
+ check_dec(SELECTION, *selection, "*selection");
+ check_dec(XA_STRING , *type, "*type");
+ check_str(HELLO, value, "*value");
+ check_dec(strlen(HELLO)+1, *length, "*length");
+ check_dec(FORMAT, *format, "*format");
+ break;
+ case 2:
+ tet_infoline("TEST: values pased to callback for second segment");
+ check_dec(SELECTION, *selection, "*selection");
+ check_dec(XA_STRING , *type, "*type");
+ check_str(WORLD, value, "*value");
+ check_dec(strlen(WORLD)+1, *length, "*length");
+ check_dec(FORMAT, *format, "*format");
+ break;
+ case 3:
+ tet_infoline("TEST: values pased to callback for third segment");
+ check_dec(0, *length, "*length");
+ if (value == NULL) {
+ tet_infoline("value is NULL");
+ tet_result(TET_FAIL);
+ }
+ default:
+ break;
+ } /* end switch */
+ incr_string += 1;
+ } /* end if type XA_STRING */
+ if ( *type == XA_INTEGER ) {
+ avs_set_event(2, XA_INTEGER);
+ switch (incr_int) {
+ case 1:
+ integer = *(int *)value;
+ check_dec(SELECTION, *selection, "*selection");
+ check_dec(XA_INTEGER , *type, "*type");
+ check_dec(0, integer, "value");
+ check_dec(FORMAT, *format, "*format");
+ exit(0);
+ default:
+ break;
+ } /* end switch */
+ incr_int += 1;
+ } /* end if type XA_INTEGER */
+}
+static void
+requestor_callback2(w, client_data, selection, type, value,
+ length, format)
+Widget w;
+XtPointer client_data;
+Atom *selection;
+Atom *type;
+XtPointer value;
+unsigned long *length;
+int *format;
+{
+ avs_set_event(1, 1);
+ tet_infoline("TEST: callback: length is 0");
+ check_dec(0, *length, "*length");
+ tet_infoline("TEST: callback: value is NULL");
+ if (value != NULL) {
+ tet_infoline("ERROR: value is not NULL");
+ tet_result(TET_FAIL);
+ }
+ exit(0);
+}
+static void XtEVT_handler2_1(receiver_widget, client_data, event, continue_to_dispatch)
+Widget receiver_widget;
+XtPointer client_data;
+XEvent *event;
+Boolean *continue_to_dispatch;
+{
+ XtPointer cd[2] = {
+ (XtPointer) 0,
+ (XtPointer) 0,
+ };
+ Atom targets[2] = {
+ XA_STRING,
+ XA_INTEGER,
+ };
+
+ XButtonEvent *bevent;
+
+ bevent = (XButtonEvent *)event;
+ XtGetSelectionValuesIncremental(
+ receiver_widget,
+ SELECTION,
+ targets,
+ 2,
+ requestor_callback2,
+ cd,
+ bevent->time
+ );
+}
+static void XtEVT_handler1_3(sender_widget, client_data, event, continue_to_dispatch)
+Widget sender_widget;
+XtPointer client_data;
+XEvent *event;
+Boolean *continue_to_dispatch;
+{
+
+ Boolean status;
+ XButtonEvent *bevent;
+
+ bevent = (XButtonEvent *)event;
+ status = XtOwnSelectionIncremental(
+ sender_widget,
+ SELECTION,
+ bevent->time,
+ convert_proc3,
+ NULL,
+ done_proc,
+ NULL,
+ client_data
+ );
+ check_dec(True, status, "XtOwnSelectionIncremental return value");
+}
+
+static void XtEVT_handler2_3(receiver_widget, client_data, event, continue_to_dispatch)
+Widget receiver_widget;
+XtPointer client_data;
+XEvent *event;
+Boolean *continue_to_dispatch;
+{
+ XtPointer cd[2] = {
+ (XtPointer) 0,
+ (XtPointer) 0,
+ };
+ Atom targets[2] = {
+ XA_STRING,
+ XA_INTEGER,
+ };
+
+ XButtonEvent *bevent;
+
+ bevent = (XButtonEvent *)event;
+ XtGetSelectionValuesIncremental(
+ receiver_widget,
+ SELECTION,
+ targets,
+ 2,
+ requestor_callback2,
+ cd,
+ bevent->time
+ );
+}
+static Boolean
+convert_proc3(w, selection, target, type_return, value_return,
+ length_return, format_return, max_length, client_data, request_id)
+Widget w;
+Atom *selection;
+Atom *target;
+Atom *type_return;
+XtPointer *value_return;
+unsigned long *length_return;
+int *format_return;
+unsigned long *max_length;
+XtPointer client_data;
+XtRequestId *request_id;
+{
+
+ return False;
+}
+>>SET tpstartup avs_alloc_sem
+>>SET tpcleanup avs_free_sem
+>>TITLE XtGetSelectionValuesIncremental Xt13
+void
+XtGetSelectionValuesIncremental(w, selection, target, count, selection_callback, client_data, time)
+>>ASSERTION Good A
+A call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time)
+shall cause the callback procedure
+.A selection_callback
+to be called for each segment of the selection value
+converted to each of the
+.A count
+types specified in
+.A targets,
+with the converted value, the widget
+.A w,
+and the corresponding value from the list of data pointed to by
+.A client_data
+passed as arguments.
+>>CODE
+Widget labelw_good;
+pid_t pid2;
+int invoked1, invoked2;
+
+ FORK(pid2);
+ avs_xt_hier("Tgtslvali1", "XtGetSelectionValuesIncremental");
+ tet_infoline("PREP: Create labelw_good widget Hello");
+ labelw_good = (Widget) CreateLabelWidget("Hello", boxw1);
+ tet_infoline("PREP: Register event handler XtEVT_handler1 to handle");
+ tet_infoline(" ButtonPress events to labelw_good widget");
+ XtAddEventHandler(labelw_good,
+ ButtonPressMask,
+ False,
+ XtEVT_handler1,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Register event handler XtEVT_handler2 to handle");
+ tet_infoline(" ButtonRelease events to boxw2 widget");
+ XtAddEventHandler(boxw2,
+ ButtonReleaseMask,
+ False,
+ XtEVT_handler2,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Create windows for widgets and map them");
+ XtRealizeWidget(topLevel);
+ tet_infoline("TEST: Send ButtonPress event");
+ send_event(labelw_good, ButtonPress, ButtonPressMask, FALSE);
+ tet_infoline("TEST: Send ButtonRelease event");
+ send_event(boxw2, ButtonRelease, ButtonReleaseMask, FALSE);
+ XtAppMainLoop(app_ctext);
+ LKROF(pid2, AVSXTTIMEOUT-2);
+ tet_infoline("TEST: Requestor_callback was invoked");
+ invoked1 = avs_get_event(1);
+ check_dec(XA_STRING, invoked1, "Callback invocations for XA_STRING count");
+ invoked2 = avs_get_event(2);
+ check_dec(XA_INTEGER, invoked2, "Callback invocations for XA_INTEGER count");
+ tet_result(TET_PASS);
+>>ASSERTION Good A
+When the selection
+.A selection
+has no owner a call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time)
+shall cause the callback procedure to be called with
+the value parameter set to NULL and length set to zero.
+>>CODE
+Widget labelw_good;
+pid_t pid2;
+int invoked1, invoked2;
+
+ FORK(pid2);
+ avs_xt_hier("Tgtslvali1", "XtGetSelectionValuesIncremental");
+ tet_infoline("PREP: Create labelw_good widget Hello");
+ labelw_good = (Widget) CreateLabelWidget("Hello", boxw1);
+ tet_infoline("PREP: Register event handler XtEVT_handler2 to handle");
+ tet_infoline(" ButtonRelease events to boxw2 widget");
+ XtAddEventHandler(boxw2,
+ ButtonReleaseMask,
+ False,
+ XtEVT_handler2_1,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Create windows for widgets and map them");
+ XtRealizeWidget(topLevel);
+ tet_infoline("TEST: Send ButtonPress event");
+ send_event(labelw_good, ButtonPress, ButtonPressMask, FALSE);
+ tet_infoline("TEST: Send ButtonRelease event");
+ send_event(boxw2, ButtonRelease, ButtonReleaseMask, FALSE);
+ XtAppMainLoop(app_ctext);
+ LKROF(pid2, AVSXTTIMEOUT-2);
+ tet_infoline("TEST: Requestor_callback was invoked");
+ invoked1 = avs_get_event(1);
+ check_dec(1, invoked1, "Callback invocations count");
+ tet_result(TET_PASS);
+>>ASSERTION Good A
+A call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time)
+when the value of the specified selection is not of a type
+specified in
+.A targets
+shall cause the XtConvertSelectionIncrProc procedure of the
+selection owner to be called to convert the selection value
+to the specified type.
+>>CODE
+Widget labelw_good;
+pid_t pid2;
+int invoked1, invoked2;
+
+ FORK(pid2);
+ avs_xt_hier("Tgtslvali1", "XtGetSelectionValuesIncremental");
+ tet_infoline("PREP: Create labelw_good widget Hello");
+ labelw_good = (Widget) CreateLabelWidget("Hello", boxw1);
+ tet_infoline("PREP: Register event handler XtEVT_handler1 to handle");
+ tet_infoline(" ButtonPress events to labelw_good widget");
+ XtAddEventHandler(labelw_good,
+ ButtonPressMask,
+ False,
+ XtEVT_handler1,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Register event handler XtEVT_handler2 to handle");
+ tet_infoline(" ButtonRelease events to boxw2 widget");
+ XtAddEventHandler(boxw2,
+ ButtonReleaseMask,
+ False,
+ XtEVT_handler2,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Create windows for widgets and map them");
+ XtRealizeWidget(topLevel);
+ tet_infoline("TEST: Send ButtonPress event");
+ send_event(labelw_good, ButtonPress, ButtonPressMask, FALSE);
+ tet_infoline("TEST: Send ButtonRelease event");
+ send_event(boxw2, ButtonRelease, ButtonReleaseMask, FALSE);
+ XtAppMainLoop(app_ctext);
+ LKROF(pid2, AVSXTTIMEOUT-2);
+ tet_infoline("TEST: Requestor_callback was invoked");
+ invoked1 = avs_get_event(1);
+ check_dec(XA_STRING, invoked1, "Callback invocations for XA_STRING count");
+ invoked2 = avs_get_event(2);
+ check_dec(XA_INTEGER, invoked2, "Callback invocations for XA_INTEGER count");
+ tet_infoline("TEST: converter procedure was invoked");
+ invoked1 = avs_get_event(5);
+ check_dec(4, invoked1, "convertor invocations");
+ tet_result(TET_PASS);
+>>ASSERTION Good A
+When the owner of the selection
+.A selection
+cannot convert the selection value to a type specified in
+.A targets
+a call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time)
+shall cause the callback procedure to be called with
+the value parameter set to NULL and length set to zero.
+>>CODE
+Widget labelw_good;
+pid_t pid2;
+int invoked1, invoked2;
+
+ FORK(pid2);
+ avs_xt_hier("Tgtslvali1", "XtGetSelectionValuesIncremental");
+ tet_infoline("PREP: Create labelw_good widget Hello");
+ labelw_good = (Widget) CreateLabelWidget("Hello", boxw1);
+ tet_infoline("PREP: Register event handler XtEVT_handler1_3 to handle");
+ tet_infoline(" ButtonPress events to labelw_good widget");
+ XtAddEventHandler(labelw_good,
+ ButtonPressMask,
+ False,
+ XtEVT_handler1_3,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Register event handler XtEVT_handler2_3 to handle");
+ tet_infoline(" ButtonRelease events to boxw2 widget");
+ XtAddEventHandler(boxw2,
+ ButtonReleaseMask,
+ False,
+ XtEVT_handler2_3,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Create windows for widgets and map them");
+ XtRealizeWidget(topLevel);
+ tet_infoline("TEST: Send ButtonPress event");
+ send_event(labelw_good, ButtonPress, ButtonPressMask, FALSE);
+ tet_infoline("TEST: Send ButtonRelease event");
+ send_event(boxw2, ButtonRelease, ButtonReleaseMask, FALSE);
+ XtAppMainLoop(app_ctext);
+ LKROF(pid2, AVSXTTIMEOUT-2);
+ tet_infoline("TEST: Requestor_callback was invoked");
+ invoked1 = avs_get_event(1);
+ check_dec(1, invoked1, "Callback invocations");
+ tet_result(TET_PASS);
+>>ASSERTION Good A
+When the last segment of the incremental transfer is delivered
+the selection callback procedure
+.A selection_callback
+registered by a call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time)
+shall be called with a non-NULL value of length zero.
+>>CODE
+Widget labelw_good;
+pid_t pid2;
+int invoked1, invoked2;
+
+ FORK(pid2);
+ avs_xt_hier("Tgtslvali1", "XtGetSelectionValuesIncremental");
+ tet_infoline("PREP: Create labelw_good widget Hello");
+ labelw_good = (Widget) CreateLabelWidget("Hello", boxw1);
+ tet_infoline("PREP: Register event handler XtEVT_handler1 to handle");
+ tet_infoline(" ButtonPress events to labelw_good widget");
+ XtAddEventHandler(labelw_good,
+ ButtonPressMask,
+ False,
+ XtEVT_handler1,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Register event handler XtEVT_handler2 to handle");
+ tet_infoline(" ButtonRelease events to boxw2 widget");
+ XtAddEventHandler(boxw2,
+ ButtonReleaseMask,
+ False,
+ XtEVT_handler2,
+ (Widget)NULL
+ );
+ tet_infoline("PREP: Create windows for widgets and map them");
+ XtRealizeWidget(topLevel);
+ tet_infoline("TEST: Send ButtonPress event");
+ send_event(labelw_good, ButtonPress, ButtonPressMask, FALSE);
+ tet_infoline("TEST: Send ButtonRelease event");
+ send_event(boxw2, ButtonRelease, ButtonReleaseMask, FALSE);
+ XtAppMainLoop(app_ctext);
+ LKROF(pid2, AVSXTTIMEOUT-2);
+ tet_infoline("TEST: Requestor_callback was invoked");
+ invoked1 = avs_get_event(1);
+ check_dec(XA_STRING, invoked1, "Callback invocations for XA_STRING count");
+ invoked2 = avs_get_event(2);
+ check_dec(XA_INTEGER, invoked2, "Callback invocations for XA_INTEGER count");
+ tet_result(TET_PASS);
+>>ASSERTION Good B 3
+When the incremental transfer is aborted in the middle of a
+transfer the selection callback procedure
+.A selection_callback
+registered by a call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time)
+shall be called with a type value equal to the symbolic
+constant
+.S XT_CONVERT_FAIL.
+>>ASSERTION Good B 3
+The owner of the selection
+.A selection
+shall not be changed during a call to
+void XtGetSelectionValuesIncremental(w, selection, targets, count,
+selection_callback, client_data, time).