Provided by: libcdk5-dev_5.0.20160131-1_amd64 bug

NAME

       cdk_mentry - curses multiple line entry widget.

SYNOPSIS

       cc [ flag ... ] file ...  -lcdk [ library ... ]

       #include <cdk.h>

       char *activateCDKMentry (
                      CDKMENTRY *mentry,
                      chtype *actions);

       void cleanCDKMentry (
                      CDKMENTRY *mentry);

       void destroyCDKMentry (
                      CDKMENTRY *mentry);

       void drawCDKMentry (
                      CDKMENTRY *mentry,
                      boolean box);

       void drawCDKMentryField (
                      CDKMENTRY *mentry);

       void eraseCDKMentry (
                      CDKMENTRY *mentry);

       boolean getCDKMentryBox (
                      CDKMENTRY *mentry);

       chtype getCDKMentryFillerChar (
                      CDKMENTRY *mentry);

       chtype getCDKMentryHiddenChar (
                      CDKMENTRY *mentry);

       int getCDKMentryMin (
                      CDKMENTRY *mentry);

       char *getCDKMentryValue (
                      CDKMENTRY *mentry);

       char *injectCDKMentry (
                      CDKMENTRY *mentry,
                      chtype input);

       void moveCDKMentry (
                      CDKMENTRY *mentry,
                      int xpos,
                      int ypos,
                      boolean relative,
                      boolean refresh);

       CDKMENTRY *newCDKMentry (
                      CDKSCREEN *cdkscreen,
                      int xpos,
                      int ypos,
                      const char *title,
                      const char *label,
                      chtype fieldAttribute,
                      chtype fillerCharacter,
                      EDisplayType displayType,
                      int fieldWidth,
                      int fieldRows,
                      int logicalRows,
                      int minimumLength,
                      boolean box,
                      boolean shadow);

       void positionCDKMentry (
                      CDKMENTRY *mentry);

       void setCDKMentry (
                      CDKMENTRY *mentry,
                      const char *value,
                      int minimumLength,
                      boolean box);

       void setCDKMentryBackgroundAttrib (
                      CDKMENTRY *mentry,
                      chtype attribute);

       void setCDKMentryBackgroundColor (
                      CDKMENTRY *mentry,
                      const char * color);

       void setCDKMentryBox (
                      CDKMENTRY *mentry,
                      boolean boxWidget);

       void setCDKMentryBoxAttribute (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryCB (
                      CDKMENTRY *mentry,
                      MENTRYCB callBackFunction);

       void setCDKMentryFillerChar (
                      CDKMENTRY *mentry,
                      chtype filler);

       void setCDKMentryHiddenChar (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryHorizontalChar (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryLLChar (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryLRChar (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryMin (
                      CDKMENTRY *mentry,
                      int maximum);

       void setCDKMentryPostProcess (
                      CDKMENTRY *mentry,
                      PROCESSFN callback,
                      void * data);

       void setCDKMentryPreProcess (
                      CDKMENTRY *mentry,
                      PROCESSFN callback,
                      void * data);

       void setCDKMentryULChar (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryURChar (
                      CDKMENTRY *mentry,
                      chtype character);

       void setCDKMentryValue (
                      CDKMENTRY *mentry,
                      const char *value);

       void setCDKMentryVerticalChar (
                      CDKMENTRY *mentry,
                      chtype character);

DESCRIPTION

       The  Cdk  mentry widget creates a multiple line entry box with a label and an entry field.
       The following are functions which create or manipulate the Cdk mentry box widget.

AVAILABLE FUNCTIONS

       activateCDKMentry
            activates the mentry widget  and  lets  the  user  interact  with  the  widget.   The
            parameter  mentry is a pointer to a non-NULL mentry widget.  If the actions parameter
            is passed with a non-NULL value, the characters in the array will  be  injected  into
            the widget.  To activate the widget interactively pass in a NULL pointer for actions.
            If the character entered into this widget is RETURN or TAB then  this  function  will
            return  a  char  *  representing the information typed into the widget and the widget
            data exitType will be set to vNORMAL.  If the character entered was ESCAPE  then  the
            function will return NULL pointer and the widget data exitType is set to vESCAPE_HIT.

       cleanCDKMentry
            clears the information from the field.

       destroyCDKMentry
            removes the widget from the screen and frees memory the object used.

       drawCDKMentry
            draws  the  widget  on the screen.  If the box parameter is true, the widget is drawn
            with a box.

       drawCDKMentryField
            redraws the multiple line entry field.

       eraseCDKMentry
            removes the widget from the screen.  This does NOT destroy the widget.

       getCDKMentryBox
            returns true if the widget will be drawn with a box around it.

       getCDKMentryFillerChar
            returns the character being used to draw unused space in the widget.

       getCDKMentryHiddenChar
            returns the character being used to draw hidden characters in the widget (obsolete).

       getCDKMentryMin
            returns the minimum length of a string the widget will allow.

       getCDKMentryValue
            returns the current value of the widget.

       injectCDKMentry
            injects a single character into the widget.  The parameter mentry is a pointer  to  a
            non-NULL mentry.  The parameter character is the character to inject into the widget.
            The return value and side-effect (setting the widget data exitType) depend  upon  the
            injected character:

            RETURN or TAB
                   the  function  returns  a  char  * representing the information typed into the
                   widget.  The widget data exitType is set to vNORMAL.

            ESCAPE the function returns a NULL pointer.  The  widget  data  exitType  is  set  to
                   vESCAPE_HIT.

            Otherwise
                   unless modified by preprocessing, postprocessing or key bindings, the function
                   returns a NULL pointer.  The widget data exitType is set to vEARLY_EXIT.

       moveCDKMentry
            moves the given widget to the given position.  The parameters xpos and ypos  are  the
            new  position of the widget.  The parameter xpos may be an integer or one of the pre-
            defined values TOP, BOTTOM, and CENTER.  The parameter ypos may be an integer or  one
            of  the  pre-defined  values  LEFT, RIGHT, and CENTER.  The parameter relative states
            whether the xpos/ypos pair is a relative move or an absolute move.  For  example,  if
            xpos  =  1  and ypos = 2 and relative = TRUE, then the widget would move one row down
            and two columns right.  If the value of relative was FALSE then the widget would move
            to  the  position  (1,2).   Do not use the values TOP, BOTTOM, LEFT, RIGHT, or CENTER
            when relative = TRUE.  (weird things may happen).  The final parameter refresh  is  a
            boolean value which states whether the widget will get refreshed after the move.

       newCDKMentry
            creates a mentry widget and returns a pointer to it.  Parameters:

            screen
                 is the screen you wish this widget to be placed in.

            xpos controls  the  placement  of the object along the horizontal axis.  It may be an
                 integer or one of the pre-defined values LEFT, RIGHT, and CENTER.

            ypos controls the placement of the object along the vertical  axis.   It  may  be  an
                 integer or one of the pre-defined values TOP, BOTTOM, and CENTER.

            title
                 is  the  string which will be displayed at the top of the widget.  The title can
                 be more than one line; just provide a carriage  return  character  at  the  line
                 break.

            label
                 is the string which will be displayed in the label of the mentry field.

            fieldAttribute
                 is the attribute of the characters to be displayed when they are typed in.

            filler
                 is the character which is to display in an empty space in the mentry field.

            displayType
                 tells  how  the  mentry  field  will behave when a character is entered into the
                 field.  The following table outlines valid values for this field and  what  they
                 mean:

                             Display_Type   Meaning
                             ───────────────────────────────────────────────────
                             vCHAR          Only accepts alphabetic characters.
                             vLCHAR         Only accepts alphabetic characters.
                                            Maps the character  to  lower  case
                                            when a character has been accepted.

                             vUCHAR         Only accepts alphabetic characters.
                                            Maps the character  to  upper  case
                                            when a character has been accepted.
                             vHCHAR         Only accepts alphabetic characters.
                                            Displays a . when a  character  has
                                            been accepted.
                             vUHCHAR        Only accepts alphabetic characters.
                                            Displays a . and maps the character
                                            to  upper case when a character has
                                            been accepted.
                             vLHCHAR        Only accepts alphabetic characters.
                                            Displays a . and maps the character
                                            to lower case when a character  has
                                            been accepted.
                             vINT           Only accepts numeric characters.
                             vHINT          Only  accepts  numeric  characters.
                                            Displays a . when a  character  has
                                            been accepted.
                             vMIXED         Accepts any character types.
                             vLMIXED        Accepts  any character types.  Maps
                                            the character to lower case when an
                                            alphabetic   character   has   been
                                            accepted.
                             vUMIXED        Accepts any character types.   Maps
                                            the character to upper case when an
                                            alphabetic   character   has   been
                                            accepted.
                             vHMIXED        Accepts    any   character   types.
                                            Displays a . when a  character  has
                                            been accepted.
                             vLHMIXED       Accepts    any   character   types.
                                            Displays a . and maps the character
                                            to  lower case when a character has
                                            been accepted.
                             vUHMIXED       Accepts   any   character    types.
                                            Displays a . and maps the character
                                            to upper case when a character  has
                                            been accepted.
                             vVIEWONLY      Uneditable field.
                             ───────────────────────────────────────────────────

            fieldRows and

            fieldWidth
                 control the height and width of the field of the widget.  If you provide a value
                 of zero for either of the values, the field in the widget will be made as  large
                 as  it  can  both  in width and in height.  If you provide a negative value, the
                 field will be created the full height or width minus the value provided.

            logicalRows
                 is the number of rows for the mentry field.

            minimumLength
                 is the number of characters which must be entered before the use  can  exit  the
                 mentry field.

            callBackFunction
                 allows the user to override the key processing element of the widget.

            box  is true if widget should be drawn with a box around it.

            shadow
                 turns the shadow on or off around this widget.

            If the widget could not be created then a NULL pointer is returned.

       positionCDKMentry
            allows the user to move the widget around the screen via the cursor/keypad keys.  See
            cdk_position (3) for key bindings.

       setCDKMentry
            lets the programmer modify  certain  elements  of  an  existing  entry  widget.   The
            parameter  names  correspond  to  the same parameter names listed in the newCDKMentry
            function.

       setCDKMentryBackgroundAttrib
            sets the background attribute of the widget.  The parameter  attribute  is  a  curses
            attribute, e.g., A_BOLD.

       setCDKMentryBackgroundColor
            sets the background color of the widget.  The parameter color is in the format of the
            Cdk format strings.  See cdk_display (3).

       setCDKMentryBox
            sets whether the widget will be drawn with a box around it.

       setCDKMentryBoxAttribute
            function sets the attribute of the box.

       setCDKMentryCB
            function allows the  programmer  to  set  a  different  widget  input  handler.   The
            parameter   callbackFunction   is   of   type  MENTRYCB.   The  default  function  is
            CDKMentryCallBack.

       setCDKMentryFillerChar
            sets the character to use when drawing unused space in the field.

       setCDKMentryHiddenChar
            sets the character to use when a hidden character type is used (obsolete).

       setCDKMentryHorizontalChar
            function sets the horizontal drawing character for the box to the given character.

       setCDKMentryLLChar
            function sets the lower left hand corner of the widget's box to the given character.

       setCDKMentryLRChar
            function sets the lower right hand corner of the widget's box to the given character.

       setCDKMentryMin
            sets the minimum length of the string that the widget will allow.

       setCDKMentryPostProcess
            allows the user to have the widget call a function after the key has been applied  to
            the  widget.   The  parameter  function is the callback function.  The parameter data
            points to data passed to the callback function.  To learn more about  post-processing
            see cdk_process (3).

       setCDKMentryPreProcess
            allows  the user to have the widget call a function after a key is hit and before the
            key is applied to the widget.  The parameter function is the callback function.   The
            parameter  data  points to data passed to the callback function.  To learn more about
            pre-processing see cdk_process (3).

       setCDKMentryULChar
            sets the upper left hand corner of the widget's box to the given character.

       setCDKMentryURChar
            sets the upper right hand corner of the widget's box to the given character.

       setCDKMentryValue
            sets the current value of the widget.

       setCDKMentryVerticalChar
            sets the vertical drawing character for the box to the given character.

KEY BINDINGS

       When the widget is activated there are several default key bindings which  will  help  the
       user  enter  or manipulate the information quickly.  The following table outlines the keys
       and their actions for this widget.

                ┌──────────────────────────────────────────────────────────────────────┐
                │Key           Action                                                  │
                ├──────────────────────────────────────────────────────────────────────┤
                │Left Arrow    Moves the cursor to the left.                           │
                │CTRL-B        Moves the cursor to the left.                           │
                │Right Arrow   Moves the cursor to the right.                          │
                │CTRL-F        Moves the cursor to the right.                          │
                │Up Arrow      Moves the cursor one row down.                          │
                │Down Arrow    Moves the cursor one row up.                            │
                │Delete        Deletes the character at the cursor.                    │
                │Backspace     Deletes the character before cursor, moves cursor left. │
                │CTRL-V        Pastes whatever  is  in  the  paste  buffer,  into  the │
                │              widget.                                                 │
                │CTRL-X        Cuts  the  contents from the widget and saves a copy in │
                │              the paste buffer.                                       │
                │CTRL-Y        Copies the  contents  of  the  widget  into  the  paste │
                │              buffer.                                                 │
                │CTRL-U        Erases the contents of the widget.                      │
                │CTRL-A        Moves the cursor to the beginning of the entry field.   │
                │CTRL-E        Moves the cursor to the end of the entry field.         │
                │CTRL-T        Transposes  the  character  under  the  cursor with the │
                │              character to the right.                                 │
                │Return        Exits the widget and returns a char * representing  the │
                │              information  which  was  typed into the field.  It also │
                │              sets the widget data exitType in the widget pointer  to │
                │              vNORMAL.                                                │
                │Tab           Exits  the widget and returns a char * representing the │
                │              information which was typed into the  field.   It  also │
                │              sets  the widget data exitType in the widget pointer to │
                │              vNORMAL.                                                │
                │Escape        Exits the widget and returns a NULL pointer.   It  also │
                │              sets the widget data exitType to vESCAPE_HIT.           │
                │Ctrl-L        Refreshes the screen.                                   │
                └──────────────────────────────────────────────────────────────────────┘

SEE ALSO

       cdk(3), cdk_binding(3), cdk_display(3), cdk_position(3), cdk_screen(3)

                                                                                    cdk_mentry(3)