|  | DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes | 
This is an automatic "excavation" of a thematic subset of
 See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. | 
top - metrics - downloadIndex: T X
    Length: 40080 (0x9c90)
    Types: TextFile
    Names: »XrTextEdit.3x«
└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
    └─⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« 
        └─⟦2109abc41⟧ 
            └─⟦this⟧ »./X.V10R4/Toolkit/Xr/usr/man/man3/XrTextEdit.3x« 
.TH XRTEXTEDIT 3X "Xrlib Version 10"
.fi
.ad 1
.SH NAME
XrTextEdit - an editor for entering and editing a line of text.
.SH SYNOPSIS
#include <X/Xlib.h>
.br
#include <Xr/Xrlib.h>
.br
.sp 1
xrEditor *
.br
.B XrTextEdit (instance, message, data)
.in 7
.br
xrEditor * instance;
.br
INT32      message;
.br
INT8     * data;
.in
.sp 1
.SH DESCRIPTION
.P
The text edit editor provides an application with the means
for placing a single line of editable text anywhere within 
the bounds of a window.
In addition to allowing the text string to be specified, an optional
field label and font may also be specified.
The application must pass in a definition for the rectangular
region into which the editor instance will be drawn.
If the rectangle is not the correct size to hold the instance,
then the editor will refuse to create the instance.
To prevent this from happening, an application should use the
.B MSG_SIZE
message to obtain this rectangle.
.sp
.P
.ul 1
ACTIVE FIELD
.P
The text edit editor supports the concept of an active field.
When a given text editor instance has control of the input stream,
it is considered to be active, and it will indicate this by
visibly changing its format.
The means by which it indicates this fact is twofold:
.sp
.in 8
It will display a text cursor at the current
character position within the instance.
.sp
It will redraw the border for the text string (which is
usually 1 pixel wide) as a 3 pixel wide border.
.in
.P
There are two means by which a text edit field is told to
become active:
.sp
.in 8
By issuing a MSG_ACTIVATE request to the editor.
.sp
By issuing a MSG_EDIT request to the editor, and passing
it any input event understood by the text editor.
.in
.sp
.P
.ul 1
COMPONENTS
.P
The two most important pieces of a text editor instance are the
text cursor and the text string being edited.
The purpose of the text cursor, is to indicate to the user
where the next character typed will be placed, and also
what portion of the text string will be modified when one
of the editing keys is pressed.
As the user types keys, the information will be added at
the location of the text cursor; 
if insert mode is enabled, then those characters to
the right of the text cursor will be shifted one position
further to the right - otherwise they are left unchanged.
After the new character has been placed, the text cursor 
will be moved to the right of the newly added character.
Only printable ASCII characters will be displayed as part of
a text string.
Once the number of characters in the string has reached the maximum
allowable number (as specified when the instance was created),
no more characters will be added to the string.
.P
When the instance is first created, the application program will
pass in a pointer to a buffer, which will be used by the editor
to store the current value of the string typed by the user;
the buffer must be large enough to hold the whole string, plus
a terminating 
.B NULL.
When the buffer is passed in, it must contain the initial value
for the field; it must also be 
.B NULL 
terminated.
If the field is to be initially empty, then the first byte of
the buffer must be the 
.B NULL 
character.
If the specified string is too long to fit within the field,
then it will be truncated, until it does fit.
.sp
.P
.ul 1
TEXT INSERTION AREA
.P
The text insertion area is the portion of a text edit instance
in which the editable string is displayed.
The width of this area is dependent upon two factors: the maximum
number of characters which may be entered, and the character cell
width; both of these are specified by the application when an 
instance is created.
.P
Working with proportional fonts can be tricky, since the character
cell width differs from character to character.
What this means is that if a text edit instance needs to hold 20
characters, it's impossible to determine the width of the editing
region, without leaving alot of blank space.
.P
This editor tackles this problem by allowing the application to
specify the character cell width to use.
If an application wants to guarantee that all characters typed
will be visible, then it should set the cell width to XrMAXWIDTH,
when the instance is created.
If an application wants all characters to be visible most of the
time, then it can set the cell width to XrAVGWIDTH.
A third option is that the application can specify a particular
cell width to use (specified in pixels).
.P
If a user types into a text edit field, and his information will
not fit within the text insertion area, the cursor will turn off;
the editor will continue to collect the input, it just will not
be displayed.
The cursor will remain invisible, until it is repositioned back
in the visible portion of the editing region.
.sp
.P
.ul 1
EDITING MODES
.P
The text editor supports two modes of character 
entering: normal and insert mode.
.P
When the instance is operating in 'normal' mode, the text
cursor is displayed as an inverse video rectangle, and
will appear on top of the character at the current cursor
position.
When a new character is entered, it is placed at the cursor
position, and will overwrite any previous character at that
position; those characters to the right of the text cursor
are left unchanged.  Afterwards, if the text cursor is not
already at the end of the text edit field, then the text 
cursor will be moved one position to the right.
.P
When the instance is operating in 'insert character' mode,
the text cursor is displayed as a vertical bar, and will
appear between two character positions.
When a new character is entered, all characters to the
right of the insertion bar are shifted one position to
the right, and the character is then placed at the
insertion bar position.  Afterwards, if the text edit field
is not already full, then
the insertion bar is moved one position to the right.
.P
Insert mode is entered and exited by pressing the 'insert mode'
key on your keyboard; this mode acts as a toggle.
.sp
.P
.ul 1
EDITING
.P
The text editor supports most of the standard line editing
commands which a user may generate from the keyboard.
Among the editing commands which will be supported are the following:
.sp
.in 7
.ul 1
Cursor Left
.br
.in
.in 9
This will cause the text cursor to be moved one character
position to the left, within the text area.
.in
.sp
.in 7
.ul 1
Cursor Right
.br
.in
.in 9
This will cause the text cursor to be moved one character
position to the right, within the text string displayed in
the text area.
.in
.sp
.in 7
.ul 1
Backspace
.br
.in
.in 9
This will cause the character to the left of the 
text cursor to be deleted, and all characters to its right to be
shifted one position to the left; the text cursor will
also move one position to the left.
.in
.sp
.in 7
.ul 1
Delete Char
.br
.in
.in 9
This will cause the character underneath the 
text cursor to be deleted, and all characters to its right will be 
shifted one position to the left; the text cursor will
remain in its same position.
.in
.sp
.in 7
.ul 1
Delete Line
.br
.in
.in 9
This will clear all characters from the text region, and
will move the text cursor back to the beginning of the
text area.
.in
.sp
.in 7
.ul 1
Clear Line
.br
.in
.in 9
This will cause all characters under and to the right of the text 
cursor to be deleted.
The location of the text cursor will be unchanged.
.in
.sp
.P
.ul 1
MOUSE
.P
As was mentioned above, the text cursor's position is automatically
updated after each character placement operation or editing request.
There is, however, another method for specifying a new
text cursor position.
By using the mouse, you can move the cursor to anywhere
within the current text string, and then 'click' the mouse button.
This will cause the text cursor to be placed at the selected
character position.
If a position past the end of the text string is selected,
then the text cursor will automatically be placed after
the last character in the string.
.sp
.P
.ul 1
DEACTIVATION
.P
Once a text edit field has been made 'active', there will be
several ways for it to become 'inactive'.
When a text edit field is deactivated, it will turn off its
text cursor, and it will redraw the text border as a 1 pixel
wide box.
The instance will no longer accept input, until it has been
reactivated.
.P
The first method for deactivating a text field, is to use
the mouse to select a region outside the editor's rectangular
region; this region includes the text region and the optional
label.
When the text editor code determines that a select event occurred outside
its domain, it will deactivate the field, and then place two
input events onto the front of the application's input queue:
.sp
.in 7
.ul 1
Input event 1
.br
.in
.in 9
This first input event placed on the input queue will be a copy
of the select event which caused the field to be deactivated.
This event will notify the application that a select occurred
somewhere else within the display.
.in
.sp
.in 7
.ul 1
Input event 2
.br
.in
.in 9
This will be the event information generated by the text edit
editor.
It will inform the application that the field has been exited,
and that editing is now complete.
.in
.P
A second method of deactivating a text field, is by pressing
one of the special keys, which are collectively known as 'traversal' keys.
Traversal keys are frequently used by a forms controller, to provide
a means for a user to exit a field in a form, and then advance to the
next field.
The following traversal keys are defined:
.sp
.in 7
.ul 1
Return
.br
.in
.in 9
When the 'return' key is pressed, the text editor will deactivate
the active field, and return an input event.  
The input event will be used to notify the application
program that a text field was exited.
If the application is a 
forms controller, then it can use this information to force the
next field in the form to become active.
.in
.sp
.in 7
.ul 1
Tab
.br
.in
.in 9
When the 'tab' key is pressed, the text editor will deactivate
the active field, and return an input event.  
The input event will be used to notify the application
program that a text field was exited.
If the application was a
forms controller, then it can use this information to force the
next field in the form to become active.
.in
.sp
.in 7
.ul 1
Backtab
.br
.in
.in 9
When the 'backtab' key is pressed, the text editor will deactivate
the active field, and return an input event.  
The input event will be used to notify the application
program (and the forms controller) that a text field was exited.
If the application is a
forms controller, then it can use this information to force the
previous field in the form to become active.
.in
.P
When a traversal key causes a field to be exited, only a single
input event is added to the application's input queue.
.sp
.P
.ul 1
RETURNED INFORMATION
.P
The text editor will not return an input event to the
calling application each time the text field is modified.
Instead, it will only return to the application when a
major event occurs; these are also referred to as break conditions.
There are four categories of break conditions:
.sp
.in 7
- The field has been exited [by a traversal key].
.br
.sp
- The field has now become empty, or the first
character was typed.
.br
.sp
- An X event other than a KeyPressed, KeyReleased, XrSELECT
or XrSELECTUP event is received.
.br
.sp
- A control character is received.
.in
.P
For the first type, the editor will return, and not expect
to be called again, until the field has again been activated.
However, for the second type, the editor is merely returning
some status information to the application.
As soon as the application has processed the status information,
it should immediately re-invoke the editor, either directly (by issuing
a MSG_ACTIVATE),
or by means of the forms controller.
Failing to follow this rule may produce unpredicatable results.
The third and fourth types are similar to the second type, in that
they too are only returning some status information.
They will return a status event telling the application that an
unknown X event was received, along with the unknown X event.
The application should then process the X event, which is on the
input queue AFTER the status event, and then re-invoke the editor in
one of the two fashions listed above.
.sp
.P
.ul 1
INSTANCE LAYOUT
.P
The layout for a text editor instance depends upon how it was defined.
When an instance is drawn, it will be drawn within the bounds of
the supplied 'editorRect'.
If the 'editorRect' is not large enough to hold the specified
instance, then the create request will fail.
.SH EDITOR MESSAGES
.IP MSG_NEW
This message will be the means by which an application program
can create an editable text field within a window.  It will
expect the 
.I instance
parameter to be set to
.B NULL,
and the
.I data 
parameter to point to a filled out instance of the following structure:
.sp
.nf
     typedef struct {
          Window       editorWindowId;
          RECTANGLE    editorRect;
          INT8         editorState;
          INT32        editorFGColor;
          INT32        editorBGColor;
          FontInfo   * editorFont;
          INT8       * label;
          INT8       * string;
          INT32        maxChars;
          INT32        insertPos;
          INT8         insertMode;
          INT8         labelPosition;
          INT8         cellWidth;
      } xrTextEditInfo;
.fi
.sp
.in 7
.ul 1
editorWindowId
.br
.in
.in 9
This field indicates the window to which the editor instance
is to be attached.
Anytime the instance is redrawn, it will be redrawn in this window.
.in
.sp
.in 7
.ul 1
editorRect
.br
.in
.in 9
This describes the location and size of the region 
into which the text edit field is to be displayed.
If a rectangle too small to hold the instance is
specified, then the editor will refuse to
handle the request, and it will fail.
.in
.sp
.in 7
.ul 1
editorState
.br
.in
.in 9
This field contains the initial value of the state flags
for this editor instance.
It can be composed of any combination of the
.B XrSENSITIVE
and
.B XrVISIBLE
flags.
.in
.sp
.in 7
.ul 1
editorFGColor
.br
.in
.in 9
This field specifies the foreground color
to be used when drawing the editor instance.
The borders and all text are drawn using the foreground color.
If this is set to -1, the default foreground color (see
.B XrInit(3X)
) will be used.
.in
.sp
.in 7
.ul 1
editorBGColor
.br
.in
.in 9
This field specifies the background color
to be used when drawing the editor instance.
The interior of the text region is drawn using the background color.
If this is set to -1, the default background color (see
.B XrInit(3X)
) will be used.
.in
.sp
.in 7
.ul 1
editorFont
.br
.in
.in 9
This points to the structure which contains all of the information
necessary to describe the font to be used when displaying
the text edit field.
If this pointer is 
.B NULL, 
then the default system base
font will be used.
.in
.sp
.in 7
.ul 1
label
.br
.in
.in 9
This is a pointer to the optional 
.B NULL 
terminated label, which
will be displayed to the left of the text edit region.
It will be displayed using the same font used within the
text edit region.
If this pointer is 
.B NULL, 
or if the string has a length of 0,
then no label will be displayed.
.in
.sp
.in 7
.ul 1
string
.br
.in
.in 9
This is a pointer to the buffer which will be used by the
editor to store the working copy of the data in the text region.
The editor will expect the buffer to be large enough to hold the
maximum size string for this field, along with a terminating 
.B NULL.
The buffer must contain the 
.B NULL 
terminated string representing
the initial value for the text region.
It will be by means of this buffer that an application program 
will have access to the current value of the text editor instance.
.in
.sp
.in 7
.ul 1
maxChars
.br
.in
.in 9
This value represents the maximum number of characters which will
be allowed in the text editor instance.
This information will be used by the editor to prevent a user from 
entering too much data into a field.
It is also used by the editor, when calculating the size of
the text region and the frame rectangle.
This value should not include space taken up by the 
.B NULL 
character used to terminate the string.
.in
.sp
.in 7
.ul 1
insertPos
.br
.in
.in 9
This value allows an application program to specify the
initial position of the text cursor.
The specified value indicates the character position within
the buffer, for where the next character typed should be placed;
e.g. 0 means place the cursor at the first character position, and the
next character typed with be saved in buffer[0].
If a value is specified which is greater than the current
length of the text string, then the text cursor will be
placed at the last character position in the string.
.in
.sp
.in 7
.ul 1
insertMode
.br
.in
.in 9
This value allows an application to specify the type of
insertion mode the field editor should operate under.
If the field is set to
.B XrALWAYS_ON
then insert mode will be forced on for the duration of
the editing session; the insert character key will be
ignored.
If the field is set to
.B XrALWAYS_OFF
then insert mode will be forced off for the duration of
the editing session, and the editor will operate
in 'normal' mode; the insert character key will be ignored.
If the field is set to 
.B XrINTERACTIVE
then the editing mode will be controlled by the user pressing
the insert character key; the editor will toggle in and out
of insert mode each time the insert character key is pressed.
.in
.sp
.in 7
.ul 1
labelPosition
.br
.in
.in 9
This value allows an application to specify whether the optional
label should be displayed to the left or right of the text editing
region.
If a label is not specified for an instance, then this field will
be ignored.
The two valid settings for this field are
.B XrLEFT_ALIGNED
and
.B XrRIGHT_ALIGNED.
.in
.sp
.in 7
.ul 1
cellWidth
.br
.in
.in 9
This parameter specifies the character cell width which should be
used when calculating the size of the text editing region.
For the maximum cell width for a given font, use the define
.B XrMAXWIDTH.
For a cell width which is the average size for a given font, use
the define
.B XrAVGWIDTH.
If any other value is desired, then the cell width (in pixels)
may be specified directly; this information can be obtained by
using the 
.B XrStringWidth()
utility routine.
.in
.IP
The editor will then draw the text edit field in the specified
window.
.IP
Upon successful completion, a pointer to the newly created
editor structure will be returned to the application.
This value must be used there after, whenever the application
wishes to refer to this particular editor instance.
.IP MSG_FREE
This message is the mechanism by which an editor instance can be destroyed.
The only parameter of importance is the 
.I instance
parameter, which is a pointer to the
editor structure, returned by
.B MSG_NEW ;
this parameter specifies which instance is to be destroyed.
.IP
When a text editor instance is destroyed, it will be internally
disconnected from the window to which it was attached, it will
no longer handle mouse selects or keyboard input, and it will
be removed from the window, if the instance is visible.
.IP
After an editor instance has been destroyed, no further
messages should be issued in regard to that instance.
.IP MSG_GETSTATE
This message returns the current state of the 
.B XrVISIBLE 
and 
.B XrSENSITIVE
flags for the specified text edit instance.
The 
.I instance
parameter specifies which instance to use. 
The 
.I data 
parameter should be a pointer to an 8 bit integer value,
into which the current state flags will be placed.
.IP MSG_SETSTATE
This message allows an application program to modify the setting of
the 
.B XrSENSITIVE 
and 
.B XrVISIBLE 
flags, for a given text edit instance.
The 
.I data 
parameter is interpreted as an 8 bit integer value, containing
the new state flag values.
After saving the new state flags, the editor instance will be redrawn,
to reflect the new state.
If an instance is not visible, then the
rectangle which it occupies will be drawn using the background tile
for the window, thus making it invisible. 
If a field is visible, but not sensitive, then the insertion area
will be drawn and filled with a 50% pattern; the current field value
will also be displayed.
.IP MSG_GETITEMCOUNT
This message allows an application to obtain a count, which
indicates the number of insertion areas in the specified instance.
The editor will assume that the 
.I instance
parameter specifies the editor instance to query, and the
.I data 
parameter points
to a 32 bit integer value; the item count value will be
returned by means of this integer.
.IP
This message is useful when used in conjunction with the
.B MSG_GETITEMRECTS 
message.
It allows an application to obtain the number of items in the
instance, so that the application can then allocate enough
memory to hold the rectangle information returned by
.B MSG_GETITEMRECTS.
.IP
For this editor, a value of 1 will always be returned, since a text edit
instance can presently only have one insertion area.
.IP MSG_GETITEMRECTS
This message returns the coordinates for the rectangle which
describes the insertion area; this rectangle describes only the
insertion area - it does not include the label.
The message will expect the
.I instance
parameter to specify the editor instance to query, and the
.I data 
parameter to point to a structure of the following format:
.sp
.nf
	rectangle   itemRects;
.fi
.sp
This structure will then be filled with the rectangle information, and
returned to the application.
.IP
Before an application can make this call, it needs to know
the number of insertion areas in the specified instance, so that it can
allocate a structure large enough to hold all of the rectangle
information.
The application should use the 
.B MSG_GETITEMCOUNT 
message to
obtain this information; the application can then allocate
an array large enough to hold all of the rectangle entries.
.IP
This message is useful to those applications which have a need
of knowing where the insertion area in a text edit instance is located.
The most common use would be by a forms controller, which would
use the information to place an 'active field' indicator by a
given item.
.IP MSG_ACTIVATE
This message allows an application to force a text edit instance
active, thus causing it to turn on the text cursor, widen the
editing region border, and start monitoring all incoming keyboard
events.
This message also serves as the only means for re-entering an active 
text edit field, after an application has received a status event 
from the instance.
When a
.B MSG_ACTIVATE
message is issued, the editor instance must be both visible and
sensitive; if this is not the case, then the message will fail.
.IP
When this message is issued, the
.I instance
parameter must specify the text edit instance which is to be activated;
the
.I data
parameter is unused, and should be set to
.B NULL.
.IP MSG_DEACTIVATE
This message allows an application to force a text edit instance
inactive.  
Normally, when a text edit instance returns a status event to an
application (such as the field is now empty, or an unknown X event
was received), the application processes the status event and then
reinvokes the text editor.
However, it is possible for an application to decide that it does
not want to reinvoke the editor instance, but rather, it wants the
instance to be deactivated.
The instance will be drawn as inactive in the same fashion as when
a traversal key is received.
.IP
When this message is issued, the 
.I instance
parameter must specify the text edit instance which is to be
deactivated; the
.I data
parameter is unused.
If the text edit field is already inactive, then this request
will be ignored.
.IP MSG_INSERTMODE
This message allows an application to modify the insert mode
under which the field editor will operate.
.IP
When this message is issued, the
.I instance
parameter must be a pointer to the editor structure associated
with the instance to be modified.
The
.I data
parameter must be a 8 bit integer value, set to either
.B XrALWAYS_ON, XrALWAYS_OFF
or
.B XrINTERACTIVE.
If
.B XrALWAYS_ON
is selected, then the editor will always operate with insert
mode enabled; the insert character key will be ignored.
If
.B XrALWAYS_OFF
is selected, then the editor will always operate with
insert mode disabled (in normal mode); the insert character
key will be ignored.
If
.B XrINTERACTIVE
is selected, then the editor will allow the user to toggle
into and out of insert mode, by pressing the insert character
key on the keyboard.
.IP
If any other mode is selected, then the request will fail.
.IP MSG_REDRAW
This editor provides an application with the means
for requesting that a text edit instance be redrawn.
.IP
When this message is issued, the
.I instance
parameter must be a pointer to the editor structure associated
with the instance to be redrawn.
The
.I data
parameter must be a 32 bit integer
which specifies the type of redraw to perform.
.IP
The text editor supports the following redraw modes:
.sp
.in 8
.nf
.B - XrREDRAW_ALL
.sp
.B - XrREDRAW_ACTIVE
.in
.fi
.IP
.B XrREDRAW_ALL 
will cause the editor to redraw the complete editor
instance, while 
.B XrREDRAW_ACTIVE 
will cause only the text string portion of the instance to be redrawn.
.IP
If any other redraw mode is specified, then the request will fail.
.IP MSG_SIZE
This message allows an application to obtain the 
rectangle needed to contain a given text edit instance.
.IP
The text editor expects the 
.I instance
parameter to be set to
.B NULL,
and the
.I data 
parameter to point to an instance of the following structure:
.sp
.nf
     typedef struct {
          Window       editorWindowId;
          RECTANGLE    editorRect;
          INT8         editorState;
          INT32        editorFGColor;
          INT32        editorBGColor;
          FontInfo   * editorFont;
          INT8       * label;
          INT8       * string;
          INT32        maxChars;
          INT32        insertPos;
          INT8         insertMode;
          INT8         labelPosition;
          INT8         cellWidth;
      } xrTextEditInfo;
.fi
.sp
.IP
The fields which must be filled out by the application program BEFORE
issuing this call, are the 
.I label, maxChars, cellWidth 
and 
.I editorFont 
fields. 
.IP
If 
.I editorFont 
has been set to 
.B NULL, 
then the default
system base font will be used when calculating
the rectangle size; if a particular font is
requested, then it will be used.
.IP
The rectangle calculated will be the smallest 0 based
rectangle, into which the specified text edit instance 
will fit, using the specified font and character cell width.
.IP
In return, 
.I editorRect
will be set to describe the optimal rectangle
into which the described instance will fit.
An application should feel free to lengthen this 
rectangle, but it should refrain from modifying the height.
.IP
It should be noted that if a cell size smaller than the maximum
cell size for a given font is specified, there is no guarantee
that the complete string typed by a user will be visible at one time.
.IP MSG_MOVE
This message provides an application with a means for quickly relocating 
a particular editor instance within a window.
The size of the 
.I editorRect 
associated with the instance is not changed.
To relocate an editor instance, a new origin point for the instance's
.I editorRect 
must be specified; the top left corner of the editor rectangle 
will then be translated such that it now coincides with the new origin.
The origin point is interpreted as an absolute position within the window.
.IP
When this message is issued, the
.I instance
parameter must point to the editor structure associated with the
instance which is to be moved, while the
.I data
parameter must point to a 
.I POINT 
structure, containing the new
.I editorRect 
origin.
.IP
When an editor instance is relocated, the field editor will automatically
remove the visual image of the instance from the window, and will then redraw
the instance at its new location; this occurs only if the instance is visible.
.IP MSG_RESIZE
This message provides an application with a means for both changing the
size of the 
.I editorRect
associated with a particular editor instance, and also the location of
the new
.I editorRect.
All restrictions regarding the
.I editorRect
size which applied when the instance was first created using
.B MSG_NEW,
still apply.
If an invalid 
.I editorRect
is specified, then the resize request will fail.
.IP
When this message is issued, the
.I instance
parameter must point to the editor structure associated with the instance
which is to be resized, while the
.I data
parameter must point to a 
.I RECTANGLE 
structure containing the
new size and origin for the 
.I editorRect.
.IP
When an editor instance is resized, the field editor will automatically
remove the visual image of the instance from the window, and will then
redraw the instance using the new size and location information; this
occurs only if the instance is visible.
.IP MSG_EDIT
Normally, an application will not issue this message;
it is usually issued by the Xrlib input routine,
when an input event occurs while a text edit
field is active.
.IP
When such an event occurs, a 
.B MSG_EDIT 
message will be issued to the editor, with
the
.I instance
parameter indicating which text edit instance to process, and the
.I data
parameter pointing to an 
.I XEvent
structure.
.IP
The 
.B MSG_EDIT 
handler for the text edit editor is much more complex than most editors,
since it understands a much broader range of input events.
Making up the list of valid input types for this editor are:
.sp
.in 11
.nf
Most X KeyPressed and KeyReleased events.
All X button events which map into either an XrSELECT or 
    XrSELECTUP event (see XrMapButton(3X) and XrInit(3X)).
All other X events will be treated by the editor as an unknown
    event, and will be returned to the application for local
    processing.  This is discussed further in a later section
    dealing with unknown events.
.fi
.in
.IP
The sections below will attempt to describe how the editor
handles each of the above input types.
.IP
.ul 1
X KeyPressed and KeyReleased events (Printable ASCII keys only)
.sp
.in 11
If the text field is already full, or if this is a KeyReleased
event, then the editor will ignore the event.
Otherwise, the following will occur:
.sp
.in
.in 14
If the editor is currently operating with insert mode enabled,
then all characters in the buffer, which are at or to the right
of the text cursor, will be shifted one place to the right
within the work buffer.
.sp
The new keycode will be inserted at buffer[insertion point].
.sp
The insertion point (text cursor) will be moved one character position to the right.
.sp
The text cursor will be forced on (if not already).
.sp
The instance will be redrawn.
.in
.in 11
.sp
Afterwards, a check will be made to see if the string was
previously empty and this was the first character in the string.
If it was, then the following status event will be appended
to the front of the application's input queue, and the editor
will return:
.sp
.nf
   type      = XrXRAY
   source    = the window Id
   inputType = XrEDITOR
   inputCode = XrTEXTEDIT
   value1    = XrTEDIT_FIRST
   valuePtr  = pointer to instance's editor structure
.fi
.sp
If the above event did not occur, then the
editor will block, waiting for the user to generate the next
input event.
.in
.sp
.IP
.ul 1
X KeyPressed and KeyReleased events (Editing keys)
.sp
.in 11
.ul 1
Cursor Right
.br
.in
.in 14
If the text cursor is not already at the end of the string,
then it will be shifted one character position to the right.
The field will then be redrawn as active, if it was not already.
.in
.sp
.in 11
.ul 1
Cursor Left
.br
.in
.in 14
If the text cursor is not already at the beginning of the string,
then it will be shifted one character position to the left.
The field will then be redrawn as active, if it was not already.
.in
.sp
.in 11
.ul 1
Backspace
.br
.in
.in 14
If the text cursor is not already at the beginning of the string,
then the character to the left of the text cursor will be deleted,
and all character to its right will be shifted one position to the
left.
The text cursor will also move one position to the left.
The field will then be redrawn, and forced active (if it was not already).
If the text field is now empty, then the following status
event will be added to the front of the application's input
queue, and the editor will return:
.sp
.nf
   type      = XrXRAY
   source    = the window Id
   inputType = XrEDITOR
   inputCode = XrTEXTEDIT
   value1    = XrTEDIT_EMPTY
   valuePtr  = pointer to instance's editor structure
.fi
.in
.sp
.in 11
.ul 1
Delete Char
.br
.in
.in 14
If the text cursor is not at the end of the string, then
the character underneath the text cursor will be deleted,
and all character to its right will be shifted one position
to the left.
The field will then be redrawn, and forced active (if it was not
already).
If the field is now empty, then the following status event
will be appended to the front of the application's input queue,
and the editor will return:
.sp
.nf
   type      = XrXRAY
   source    = the window Id
   inputType = XrEDITOR
   inputCode = XrTEXTEDIT
   value1    = XrTEDIT_EMPTY
   valuePtr  = pointer to instance's editor structure
.fi
.in
.sp
.in 11
.ul 1
Delete Line
.br
.in
.in 14
This will move the text cursor to character position 0,
and then delete all character to its right.
The field will be redrawn, and forced active (if it was
not already).
The following status event will be appended to the front
of the application's input queue, and the editor will return:
.sp
.nf
   type      = XrXRAY
   source    = the window Id
   inputType = XrEDITOR
   inputCode = XrTEXTEDIT
   value1    = XrTEDIT_EMPTY
   valuePtr  = pointer to instance's editor structure
.fi
.in
.sp
.in 11
.ul 1
Clear Line
.br
.in
.in 14
This will operate the same as 'delete line', except that
the text cursor is not moved; only those characters under and to
the right of the text cursor are deleted.
If the field is now empty, then the following status event
will be appended to the front of the application's input queue:
.sp
.nf
   type      = XrXRAY
   source    = the window Id
   inputType = XrEDITOR
   inputCode = XrTEXTEDIT
   value1    = XrTEDIT_EMPTY
   valuePtr  = pointer to instance's editor structure
.fi
.in
.sp
.IP
.ul 1
X KeyPressed and KeyReleased events (Traversal keys)
.sp
.in 11
There are a special set of keys, which are referred to as
traversal keys.
These serve as the mechanism for exiting from a field, and
deactivating it.
The keys making up this list are:
.sp
.nf
.in
.in 14
- Return
- Tab
- Backtab
.in
.in 11
.fi
When a traversal key is pressed by the user, the editor will redraw
the field as inactive, and then place the following input event
onto the front of the application's input queue:
.sp
.nf
   type      = XrXRAY
   source    = the window Id
   inputType = XrEDITOR
   inputCode = XrTEXTEDIT
   value1    = XrTEDIT_BREAK
   value2    = traversal direction indicator
   value3    = traversal key keycode
   valuePtr  = pointer to instance's editor structure
.fi
.in
.in 11
.sp
The traversal direction indicator will assume a value of either
.B XrNEXT
or
.B XrPREVIOUS.
.sp
The traversal key keycode will be either (RETURN_KEY | K_s),
(TAB_KEY | K_s) or (BACKTAB_KEY | K_s), as defined in <Xr/keycode.h>.
The 
.I value3
field within the event structure is defined as an INT16 quantity.
However, the traversal keycode is a UINT16 value; therefore, an
application should coerce the signed
.I value3
value into an unsigned value, before comparing it to any of the
defined keycode values listed above.
.in
.sp
.IP
.ul 1
X ButtonPressed or ButtonReleased events
.sp
.in 11
The only type of X button event understood by this editor is the 
one which maps into either a
.B XrSELECT
or
.B XrSELECTUP
event; all other button events are treated as an unknown event.
When a select occurs, the editor will first check to see if
it occurred within the instance's rectangle.
.sp
If it did not occur within the rectangle, then the field will be
redrawn as 'not active', and two input events will be added
to the front of the application's input queue:
.sp
.nf
   1) A copy of the select input event which we just received.
   2) type      = XrXRAY
      source    = the window Id
      inputType = XrEDITOR
      inputCode = XrTEXTEDIT
      value1    = XrTEDIT_BREAK
      value2    = XrSELECT
      valuePtr  = pointer to instance's editor structure.
.fi
.sp
NOTE: the second input event will end up at the front of the queue.
.sp
The editor will then return, and not expect to be called again,
until the next time it should be made active.
.sp
If the select occurred within the text region, then the field
will be redrawn as active (if it already was not), and the
text cursor will be moved to the character position
nearest to where the select occurred.
The editor will then block, waiting for the user to generate the
next event.
.in
.sp
.IP
.ul 1
Unknown Events and ASCII Control Characters
.sp
.in 11
Any event which is received by the text editor, which does
not fall under any of the groupings discussed above, will
be treated as an unknown event, and will be passed back to
the application for processing.
When the application receives notification of an unknown
event from the text editor, it should request the next
event from its input queue (the unknown event) and then
process it.
Since this is only a temporary break condition, the editor
will expect the application to re-invoke the editor, once
it has finished processing the unknown event.
.br
.sp
The following two events will be pushed onto the front
of the application's input queue:
.sp
.nf
   1) A copy of the unknown X event which we just received.
   2) type      = XrXRAY
      source    = the window Id
      inputType = XrEDITOR
      inputCode = XrTEXTEDIT
      value1    = XrUNKNOWN_EVENT
      valuePtr  = pointer to instance's editor structure.
.fi
.in
.SH RETURN VALUE
Upon successful completion of any of the messages, a non-NULL
value will be returned.
In the case of
.B MSG_NEW,
this non-NULL value will be the pointer to the
newly created editor instance structure.
.P
If a message request fails, then a NULL value is returned.
.SH ERROR CONDITIONS
Messages to the text editor will fail, set the
.I xrErrno
global and return a NULL
value, under the following conditions:
.sp
.IP MSG_NEW
.I data
is set to NULL [XrINVALIDPTR].
.IP
.I editorWindowId
is an invalid Id [XrINVALIDID].
.IP
.I editorRect
is too small to hold the specified instance [XrINVALIDRECT].
.IP
.I string
is set to NULL [XrINVALIDPTR].
.IP
.I maxChars
is set to zero [XrINVALIDPARM].
.IP
.I insertMode
is set to an unknown value [XrINVALIDOPTION].
.IP
.I labelPosition
is set to an unknown value [XrINVALIDOPTION].
.IP
.I cellWidth
is set to an invalid value [XrPARMOUTOFRANGE].
.IP
A call to 'X' failed { XMakePixmap() } [XrXCALLFAILED].
.IP
Memory cannot be allocated [XrOUTOFMEM].
.sp
.IP MSG_REDRAW
A redraw mode other than
.B XrREDRAW_ALL
or
.B XrREDRAW_ACTIVE
is specified [XrINVALIDOPTION].
.sp
.IP MSG_SIZE
.I data
is set to NULL [XrINVALIDPTR].
.IP
.I maxChars
is set to zero [XrINVALIDPARM].
.IP
.I cellWidth
is set to an invalid value [XrPARMOUTOFRANGE].
.sp
.IP MSG_RESIZE
.I data
is set to NULL [XrINVALIDPTR].
.IP
.I editorRect
is too small to hold the specified instance [XrINVALIDRECT].
.sp
.IP MSG_ACTIVATE
The instance is not sensitive and visible [XrINVALIDPARM].
.sp
.IP MSG_INSERTMODE
An unknown insertion mode value is specified [XrINVALIDOPTION].
.sp
.IP "MSG_GETSTATE, MSG_MOVE, MSG_GETITEMCOUNT and MSG_GETITEMRECTS"
.I data
is set to NULL [XrINVALIDPTR].
.sp
.IP "All messages, except MSG_NEW and MSG_SIZE"
The
.I instance
parameter is set to NULL [XrINVALIDID].
.SH "SEE ALSO"
XrInput(3X), XrInit(3X), XrMapButton(3X)