Provided by: libxaw7-dev_1.0.13-1_amd64 bug

NAME

        Xaw - X Athena Widgets

DESCRIPTION

       Xaw is a widget set based on the X Toolkit Intrinsics (Xt) Library.  This release by the X.Org Foundation
       includes additions and modifications originally made for The XFree86  Project,  Inc.   This  manual  page
       describes  these  changes as well as some of the common interfaces between its version and the previous X
       Consortium release (Xaw6).

       The bulk of the Xaw documentation is  located  in  the  API  specification  which  may  be  installed  in
       /usr/share/doc/libxaw7-dev, or found on the X.Org website.

ACTIONS

       All  of  the  Xaw  widgets  now  have the additional translations call-proc, declare, get-values and set-
       values. The syntax for these actions is:

       action-name (boolean-expression, arguments)

       Action-name is one of call-proc, declare, get-values or set-values.

       Boolean-expression is composed with the operators | (or), & (and), ^ (xor), and ~ (not). The operands can
       be  a  variable  name, which starts with a $; a resource name without the bindings .  or *; or a constant
       name, including mine (event->xany.window == XtWindow(widget)), faked (event->xany.send_event != 0),  true
       (1) and false (0).

       Arguments  are  self-explanatory; when starting with a $ they name a variable, otherwise, they indicate a
       resource name.

       call-proc (boolean-expression, procedure-name)
               This action allows the evaluation of a boolean expression in the first parameter before calling a
               action procedure.  The procedure is only called if the expression evaluates as true.  Example:
               call-proc("$inside & $pressed", notify)

       declare (boolean-expression, variable, value, ...)
               This action is used to create new variables or change their values.  Any number of variable-value
               tuples may be specified.  Example:
               declare(1, $pressed, 1)

       get-values (boolean-expression, variable, value, ...)
               This action reads a widget resource value into a variable.  Any number of  variable-value  tuples
               may be specified.  Example:
               get-values(1, $fg, foreground, $bg, background)

       set-values (boolean-expression, variable, value, ...)
               This  action  sets  a widget resource to the given value, which may be a variable.  Any number of
               variable-value tuples may be specified.  Example:
               set-values(1, foreground, $bg, background, $fg)

       Here is a sample translation to make a label widget behave like a button:

       <Map>:      get-values(1, $fg, foreground, $bg, background)\n\
       <Btn1Down>: set-values(1, foreground, yellow, background, gray30)\n\
       <Btn1Up>:   set-values(1, foreground, $fg, background, $bg)

DISPLAY LISTS

       All of the Xaw widgets have now the additional resource displayList.  This resource  allows  drawing  the
       widget  decorations  using  commands  embedded  in  a  resource string.  The displayList resource has the
       syntax:

       [class-name:]function-name arguments[[{;\n}]...]

       Class-name is any registered set of functions to draw in the widget.  Currently the only  existing  class
       is xlib, which provides access to the Xlib drawing primitives.

       Function-name is the drawing or configuration function to be called, described bellow.

       Arguments may be anything suitable to the displayList function being called. When the function requires a
       coordinate, the syntax is {+-}<integer> or <integer>/<integer>. Examples:
            +0,+0      top, left
            -0,-0      bottom, right
            -+10,-+10  bottom+10, right+10
            +0,1/2     left, vertical-center

       arc-mode mode
               Sets the arc mode.  Accepted modes are "pieslice" and "chord", which set the arc  to  ArcPieSlice
               or ArcChord, respectively.  Example:
               arc-mode chord

       bg color-spec
       background color-spec
               Sets the  background color.  color-spec must a valid color specification.  Example:
               background red

       cap-style style
               Sets  the cap style.  Accepted styles are "notlast", "butt", "round", and "projecting", which set
               the cap style to CapNotLast, CapBut, CapRound or CapProjecting, respectively.  Example:
               cap-style round

       clip-mask pixmap-spec
               Sets the pixmap for the clip mask.  Requires a pixmap parameter,  as  described  in  the  PIXMAPS
               section below.  Example:
               clip-mask xlogo11

       clip-origin x,y
               Sets the clip x and y origin.  Requires two arguments, the x and y coordinates.  Example:
               clip-origin 10,10

       clip-rects x1,y1,x2,y2 [...,xn,yn]
       clip-rectangles x1,y1,x2,y2 [...,xn,yn]
               Sets  a list of rectangles to the clip mask.  The number of arguments must be a multiple of four.
               The arguments are coordinates.  The parser calculates the width and  height  of  the  rectangles.
               Example:
               clip-rects 0,0,10,20, 20,10,30,30

       coord-mode mode
               Changes  the  coord  mode for fill-polygon, draw-lines, and draw-points.  Accepted parameters are
               "modeorigin" and "previous", that sets the coord mode to  CoordModeOrigin  or  CoordModePrevious,
               respectively.  Example:
               coord-mode previous

       copy-area {pixmap-spec|.},dstx,dsty[,x2,y2,srcx,srcy]
               Calls  XCopyArea.   The  character . means copy the window contents; pixmap-spec is as defined in
               the PIXMAPS section below.  X2 and y2 are the coordinates of the end  copy,  not  the  width  and
               height; if not defined, the parser calculates them. src_x and src_y default to zero.  Example:
               copy-area Term,10,10

       copy-plane {pixmap-spec|.},dstx,dsty[,x2,y2,srcx,srcy,plane]
               Calls  XCopyPlane.  The  character . means copy the window contents; pixmap-spec is as defined in
               the PIXMAPS section below.  X2 and y2 are the coordinates of the end  copy,  not  the  width  and
               height;  if  not  defined,  the  parser  calculates them.  src_x and src_y default to zero. Plane
               defaults to one.  Example:
               copy-plane star,10,10

       dashes i1[...,in]
               Sets the dashes for line drawing.  Accepts up to 127 arguments.  Example:
               dashes 3,7 9,10

       draw-arc x1,y1,x2,y2[,start-angle,end-angle]
               Draws an arc.  The four first arguments are the rectangle enclosing the arc.  The  two  remaining
               arguments, if specified, are the start and end angle, in degrees.  Example:
               draw-arc +0,+0,-1,-1,0,90

       draw-rect x1,y1,x2,y2
       draw-rectangle x1,y1,x2,y2
               Draws  a  rectangle.   Requires  four  arguments,  which  are the start and end coordinate pairs.
               Example:
               draw-rect +1,+1,-5,-5

       draw-string x,y,"string"
               Draws a text string.  Requires three arguments, a x coordinate, a y  coordinate,  and  a  string.
               Strings  that  have white space can be quoted with the " character; the backslash character \ can
               also be used, but it will be necessary escape it twice.  Example:
                draw-string 10,10, "Hello world!"

       exposures boolean
               Sets graphics exposures in the GC.  Allowed parameters are  a  integer  or  the  strings  "true",
               "false", "on" and "off".  Example:
               exposures true

       fill-arc x1,y1,x2,y2[,start-angle,end-angle]
               Like  draw-arc,  but  fills  the  contents  of  the  arc  with the currently selected foreground.
               Example:
               fill-arc +0,+0,-1,-1,0,180

       fill-poly x1,y1 [...,xn,yn]
       fill-polygon x1,y1 [...,xn,yn]
               Like draw-lines, but fills the enclosed polygon and joins the first and last point, if  they  are
               not at the same position.  Example:
               fill-poly +0,+10, +10,+20, +30,+0

       fill-rect x1,y1,x2,y2
       fill-rectangle x1,y1,x2,y2
               Like  draw-rect,  but  fills  the  contents  of the rectangle with the selected foreground color.
               Example:
               fill-rect +10,+10,-20,-20

       fill-rule rule
               Sets the fill rule.  Accepted parameters are "evenodd" and "winding", which set the fill rule  to
               EvenOddRule or WindingRule, respectively.  Example:
               fill-rule winding

       fill-style style
               Sets  the  fill style.  Allowed parameters are "solid", "tiled", "stippled" and "opaquestippled",
               which  set  the  fill  style  to  FillSolid,  FillTiled,  FillStippled   or   FillOpaqueStippled,
               respectively.  Example:
               fill-style tiled

       font font-spec
               Sets the font for text functions.  Example:
               font -*-*-*-R-*-*-*-120-*-*-*-*-ISO8859-1

       fg color-spec
       foreground color-spec
               Like background, but sets the current foreground color.  Example:
               foreground blue

       mask    This  command  is  useful  when  you  want  to  draw  only  in the region that really needs to be
               repainted.  Requires no arguments.

       function function-spec
               Sets the specific GC function.  Allowed  parameters  are  "set",  "clear",  "and",  "andreverse",
               "copy", "andinverted", "noop", "xor", "or", "nor", "equiv", "invert", "orreverse", "copyinverted"
               and "nand", which set the function to GXset, GXclear, GXand, GXandReverse, GXcopy, GXandInverted,
               GXnoop,   GXxor,   GXor,   GXnor,  GXequiv,  GXinvert,  GXorReverse,  GXcopyInverted  or  GXnand,
               respectively.  Example:
               function xor

       join-style style
               Sets the join style.  Allowed parameters are "miter", "round" and "bevel",  which  set  the  join
               style to JoinMiter, JoinRound and JoinBevel, respectively.  Example:
               join-style round

       image {pixmap-spec},xs,ys,[xe,ye]
               This function is implemented as a way to quickly compose complex decorations in widgets.  Pixmap-
               spec is as defined in the PIXMAPS section below. xs and ys are  the  coordinates  from  where  to
               start  copying  the  pixmap;  xe  and ye are optional (they default to xs + pixmap.width and ys +
               pixmap.height, respectively).  If the  pixmap  has  a  mask,  the  copy  is  masked  accordingly.
               Example:
               image pixmap.xpm,0,0,20,20

       line x1,y1,x2,y2
       draw-line x1,y1,x2,y2
               Draws a line with the current foreground color.  Requires four arguments, the starting and ending
               coordinate pairs.  Example:
               line +0,+0, -1,-1

       line-width integer
               Selects a line width for drawing.  Example:
               line-width 2

       line-style style
               Sets the line style.  Accepted parameters are "solid", "onoffdash" and  "doubledash",  which  set
               the line style to LineSolid, LineOnOffDash or LineDoubleDash, respectively.  Example:
               line-style onoffdash

       lines x1,y1,x2,y2 [...,xn,yn]
       draw-lines x1,y1,x2,y2 [...,xn,yn]
               Draws a list of lines. Any number of argument pairs may be supplied.  Example:
               lines +0,-1, -1,-1, -1,+0

       paint-string x,y,"string"
               Identical to draw-string, but also uses the background color.  Example:
                paint-string 10,20, "Sample text"

       point x,y
       draw-point x,y
               Draws a point.  Requires two arguments, a coordinate pair.  Example:
               point +10,+10

       plane-mask integer
               Sets the plane mask.  Requires an integer parameter.  Example:
               plane-mask -1

       points x1,y1 [...,xn,yn]
       draw-points x1,y1 [...,xn,yn]
               Draws a list of points at the specified coordinates.  Example:
               points +1,+2, +1,+4, +1,+6

       segments x1,y1,x2,y2 [...,xn,yn]
       draw-segments x1,y1,x2,y2 [...,xn,yn]
               Draws a list of segment lines.  The number of parameters must be multiple of 4.  Example:
               segments +1,+2,+1,-3, +2,-2,-3,-2

       shape-mode mode
               Sets  the  shape  mode  used  in  fill-polygon.   Accepted  parameters are "complex", "convex" or
               "nonconvex", which set the shape mode to Complex, Convex or Nonconvex, accordingly.  Example:
               shape-mode convex

       stipple pixmap-spec
               Sets the pixmap for a stipple.  Requires a pixmap parameter, as described in the PIXMAPS  section
               below.  Example:
               stipple plaid

       subwindow-mode mode
               Sets   the   subwindow   mode   in  the  GC.   Accepted  parameters  are  "includeinferiors"  and
               "clipbychildren",  which  set  the  subwindow  mode  to   IncludeInferiors   or   ClipByChildren,
               respectively.  Example:
               subwindow-mode includeinferiors

       tile pixmap-spec
               Sets  the  pixmap  for  a tile.  Requires a pixmap parameter, as described in the PIXMAPS section
               below.  Example:
               tile xlogo11?foreground=red&background=gray80

       ts-origin x,y
               Sets the tile stipple x and y origin.  Requires two arguments, a x and y coordinate.  Example:
               ts-origin 10,10

       umask   Disables the GC mask, if it has been set with the command mask.  Requires no arguments.

       Example for drawing a shadow effect in a widget:
       foreground gray30;\
       draw-lines +1,-1,-1,-1,-1,+1;\
       foreground gray85;\
       draw-lines -1,+0,+0,+0,+0,-1

PIXMAPS

       A String to Pixmap converter has been  added to Xaw.  This converter is meant to  be  extended,  and  has
       enough  abstraction  to allow loading several image formats.  It uses a format that resembles a URL, with
       the syntax:

       [type:]name[?arg=val[{&}...]]

       Type can be one of bitmap, gradient or xpm.

       Name may be a file name, or, in the case of type gradient, may be either vertical or horizontal.

       Arg=val is a list of arguments to the converter.  An argument list is preceded by a  question  mark,  and
       multiple arguments are separated by ampersands.  The most common arguments are foreground and background.
       Gradients also support the arguments start and end (colors with which to start and end the gradient); the
       steps  argument,  to  allow  using  less  colors;  and  the dimension argument to specify the size of the
       gradient.     The xpm converter understands the closeness argument, which  aids  in  using  fewer  colors
       (useful if you have a limited colormap).

TEXT WIDGET

       Most  of  the  changes  to  this  version  of the Xaw library were done in the TextWidget, TextSrcObject,
       TextSinkObject and related files.

       A couple of highly visible changes in the Text widget are due to many bugs  in  the  Xaw6  implementation
       involving  scrollbars  and  auto-resizing.   Scrollbars being added or removed caused several problems in
       keeping the text cursor visible, and in Xaw6 it was very easy to have a widget thinking  the  cursor  was
       visible, when it was not.  Also, permitting automatic resizing of the widget to a larger geometry created
       other problems, making it difficult to have a consistent layout in the application, and,  if  the  window
       manager  did  not  interfere, windows larger than the screen could result.  Therefore, some functionality
       involving scrollbars and auto-resizing has been disabled; see the section on new and modified Text widget
       resources below.

       The  Text widget's default key bindings were originally based on the Emacs text editor.  In this release,
       even more operations familiar to Emacs users have been added.  New text actions include:

       indent  Indents text blocks.  Not bound by default.  The Text widget also does  not  attempt  to  perform
               auto-indentation of its source object by default.

       keyboard-reset
               Resets  the  keyboard state.  Reverts the action multiplier to 1, and if undo is enabled, toggles
               between undo and redo.  Bound by default to Control<Key>G.

       kill-ring-yank
               In this version of Xaw, text killed in any text field is kept in memory, allowing cut  and  paste
               operations internally to the program between text fields.  Bound by default to Meta<Key>Y.

       numeric Listed  here only for purposes of documentation.  Called by default when one of the characters 1,
               2, 3, 4, 5, 6, 7, 8, 9, 0, or - is typed, allowing composition of the  multiplication  number  of
               text actions.

       set-keyboard-focus
               Sets  the  input  focus  of  the top level widget to the text field.  Not enabled by default, but
               bound to the <Btn1Down> event.

       toggle-overwrite
               Toggles overwrite mode.  In overwrite mode, any text  inserted  in  a  text  field  will  replace
               existing text.  Bound by default to <Key>Insert.

       undo    Sets  the  enableUndo  resource  of  the  textSrcObject.   Not  enabled  by default, but bound to
               Control<Key>_.

       New and modified Text widget resources include:

       justify (Class Justify)
               Sets the text justification.  Can be one of left, right, center, or full.  Only enabled when  the
               autoFill resource is set, and the resources leftColumn and rightColumn are correctly set.

       leftColumn (Class Column)
               Specifies  the  left  column  at  which  to  break text.  Text lines started with an alphanumeric
               character will automatically start at this column.

       positionCallback (Class Callback)
               Allows installation of a callback to be called every time the cursor is moved,  and/or  the  file
               changes  its size.  The callback is called with a pointer to a structure containing the following
               data:
               typedef struct {
                   int line_number;
                   int column_number;
                   XawTextPosition insert_position;
                   XawTextPosition last_position;
                   Boolean overwrite_mode;
               } XawTextPositionInfo;
               This callback is intended to help programmers write text editors based on the Xaw widget set.

       resize (Class Resize)
               No longer supported, but recognized  for  backward  compatibility  with  resource  specifications
               written for the Xaw6 Text widget.

       rightColumn (Class Column)
               Specifies  the  right  column  at  which  to break text.  Text lines started with an alphanumeric
               character will automatically end at this column.

       scrollHorizontal (Class Scroll)
       scrollVertical (Class Scroll)
               These resources control the placement of scrollbars on the left and  bottom  edges  of  the  Text
               widget.   They  accept  the  values  XawtextScrollAlways  and XawtextScrollNever.  A converter is
               registered for this resource that will convert the following  strings:  always  and  never.   The
               value  XawtextScrollWhenNeeded  (and  whenNeeded,  recognized  by the converter), is accepted for
               backwards compatibility with resource specifications  written  for  the  Xaw6  Text  widget,  but
               ignored (effectively treated as XawtextScrollNever).

TEXT SOURCE OBJECT

       The  textSrcObject  allows  display  of  its  contents  to  more  than  one  window, and also stores undo
       information. The new resources for the textSrcObject are:

       callback (Class Callback)
               Previous versions of Xaw had this resource in subclasses of  the  TextSource  object.   This  was
               changed to make it possible to tell the callback the state of the text when undo is enabled.

       enableUndo (Class Undo)
               A boolean resource that enables or disables the undo function.  The default value is False.

       sourceChanged (Class Changed)
               Like  the callback resource, this resource was previously in subclasses of the TextSource object.
               It is now in the textSrcObject to control the changed/unchanged state when undo is enabled.

TEXT SINK OBJECT

       The textSinkObject subclasses asciiSinkObject and multiSinkObject have been changed slightly to use a new
       cursor  shape  (no longer a caret at the baseline) that indicates the input focus of the text widget, and
       allow specification of the cursor color.  The new resource is:

       cursorColor (Class Color)
               Sets the cursor color of the text.  This color is also used to draw selected text.

SIMPLE MENU WIDGET

       The simpleMenuWidget algorithm to lay out menu entries has been changed to enable multiple columns when a
       single column does not fit on the screen.  It was also modified to enable submenus.

SME BSB OBJECT

       A new resource has been added to the smeBSBObject to allow binding submenus to it.  The new resource is:

       menuName (Class MenuName)
               Specifies  the  name of the popup widget to be popped up when the pointer is over the menu entry,
               or NULL.  Note that the named menu must be a child of the popup parent of the smeBSBObject.

AUTHORS

       The original X Consortium version of the Athena Widget Set and its documentation were the  work  of  many
       people,  including  Chris  D.  Peterson,  Ralph Swick, Mark Ackerman, Donna Converse, Jim Fulton, Loretta
       Guarino-Reid, Charles Haynes, Rich Hyde, Mary Larson, Joel McCormack,  Ron  Newman,  Jeanne  Rich,  Terry
       Weissman, Mike Gancarz, Phil Karlton, Kathleen Langone, Ram Rao, Smokey Wallace, Al Mento, and Jean Diaz.

       The additions and modifications to Xaw which were originally made for XFree86 were written by Paulo César
       Pereira de Andrade.

SEE ALSO

       Athena Widget Set - C Language Interface