| T.R | Title | User | Personal Name
 | Date | Lines | 
|---|
| 2649.1 | determined by the widget... | R2ME2::OBRYAN | When in doubt, let the user decide. | Tue Apr 24 1990 17:42 | 8 | 
|  | 
re:.0
>             -< Does order matter for XtSetArg with XtSetValues? >-
The widget's SetValues-processing routine determines the order in which each
SetValued argument is processed... the order in which you specified the
arguments in the Arg list is (typically) irrelevant.
 | 
| 2649.2 |  | FREZEN::PROJECTS |  | Tue Apr 24 1990 18:57 | 12 | 
|  | re. 1
If you don't mind me asking... How does the widget's  SetValues-processing
routine determine this sequence.
The SetValues routine I have created for my widget coincides with what has
been documented in the manuals to a great extent. I see no indications in
the examples of the widget's  SetValues-processing routine determining the
set sequence of the argument list.
Could you expand a little more?
Thanks
 | 
| 2649.3 | getting closer? | R2ME2::OBRYAN | When in doubt, let the user decide. | Wed Apr 25 1990 11:32 | 20 | 
|  | 
re:.2
   When a calling application calls XtSetValues on a widget, the intrinsics
is in charge of processing the (entire) arg list, populating a new widget
instance with the values specified in that list.  The widget is then in charge
of making any special arrangements to respond to the new values in the new
widget instance record (handled by the widget's SetValues routine.)  Since the
widget does not see the caller's arg list, the order of appearance of values
in the arg list is irrelevant to the widget.  The widget, by scanning the
new widget instance field-by-field, determines the effective "order of
processing" of the caller's supplied args.
   After rereading your original note, I'm getting the impression that you
are expecting the widget's SetValues routine to be called once for each
argument in the arg list... this is not the case (as explained above).
Have I misunderstood your base note?  (My response in .1 was only to address
question #1.  I don't understand questions #2 and 3.)
Michael
 | 
| 2649.4 |  | FREZEN::PROJECTS |  | Wed Apr 25 1990 11:45 | 22 | 
|  | >After rereading your original note, I'm getting the impression that you
>are expecting the widget's SetValues routine to be called once for each
>argument in the arg list... 
I have been told that the widget is called each time for each Arg on the list.
>The widget, by scanning the new widget instance field-by-field, determines the
>effective "order of processing" of the caller's supplied args.
How can I do this? All I see as parms to my setvalues are
	static Boolean SetValues(old, request, new)
which are of my subclass struct type.
I don't mean to be ignorant... I just can't grasp how you can scan the new 
widget instance (what is that? where is it? what struct is it?). I also don't
see how I can determine the effective order of processing by looking at the
fields of the widget instance record. What fields indicate this order?
Much appreciated
Ken
 | 
| 2649.5 | DoSetValues | DECWIN::JMSYNGE | James M Synge, VMS Development | Wed Apr 25 1990 13:14 | 50 | 
|  |     >I have been told that the widget is called each time for each Arg on
    >the list.
    
    I don't believe that is correct.  XtSetValues creates two copies of
    your widget record (oldW and refW in the example below).  The first
    argument to your widget's setvalues routine is a COPY of your widget
    record with the values it had before any changes were made.  The second
    argument is a COPY of your widget, with all the changes applied.  And
    (if I understand correctly) the third argument IS your widget, with the
    changes applied, after your widget's ancestors in the class hierarchy
    have had a chance to make any changes they wanted to.
    
    I've included a copy of one of a widget's setvalues routine as an
    example of handling multiple changes:
    
    
    
#define Changed(f) (w->f != oldW->f)
static int DoSetValues(oldW, refW, w)
    VIconWidget oldW, refW, w;
{
	if (Changed(label_widget))
		AmendLabelWidget(w);
	if (Changed(core.background_pixmap)) {
		w->normal_pixmap = w->core.background_pixmap;
		if (w->highlighted)
			/* The 'wrong' pixmap got changed. */
			w->core.background_pixmap = w->highlight_pixmap;
	}
	if (Changed(highlight_pixmap))
		if (w->highlighted)
			w->core.background_pixmap = w->highlight_pixmap;
	if (!XtIsRealized (w)) return 0;
	if (Changed(core.background_pixmap))
		SetWidgetBackgroundPixmap(w, w->core.background_pixmap, True);
	if (Changed(core.x) | Changed(core.y) |
	    Changed(core.width) | Changed(core.height) |
	    Changed(label_widget) | Changed(label_alignment)) {
		CenterLabel(w);
	}
}
    
 | 
| 2649.6 | XtSetValues is superclass -> subclass chained | LEOVAX::TREGGIARI |  | Thu Apr 26 1990 08:20 | 15 | 
|  |     .5 is correct.  The only point I'd like to expand upon is that the
    SetValues method is "Chained" from superclass to subclass.  That
    is, when XtSetValues is called on your widget, the SetValues method
    of all of your widget's superclasses are called before your SetValues
    method is called.  So, for the most part, you only need to worry
    about changes to the fields within your own instance part (although
    sometimes changes to fields within your superclasses need to be
    examined).  That is why .5 said:
    
    "the third argument IS your widget, with the
     changes applied, after your widget's ancestors in the class hierarchy
     have had a chance to make any changes they wanted to."
                                
    Leo
       
 |