The ckrange utility prompts a user for an integer between a specified range and determines whether this response is valid. It defines, among other things, a prompt message whose response should be an integer in the range specified, text for help and error messages, and a default value (which is returned if the user responds with a RETURN ).
This command also defines a range for valid input. If either the lower or upper limit is left undefined, then the range is bounded on only one end.
All messages are limited in length to 79 characters and are formatted automatically. Tabs and newlines are removed after a single whitespace character in a message definition, but spaces are not removed. When a tilde is placed at the beginning or end of a message definition, the default text will be inserted at that point, allowing both custom text and the default text to be displayed.
If the prompt, help or error message is not defined, the default message (as defined under EXAMPLES ) is displayed.
Three visual tool modules are linked to the ckrange command. They are errange (which formats and displays an error message on the standard output), helprange (which formats and displays a help message on the standard output), and valrange (which validates a response). These modules should be used in conjunction with Framed Access Command Environment (FACE ) objects. In this instance, the FACE object defines the prompt.
Note: Negative "input" arguments confuse getopt in valrange . By inserting a "-" before the argument, getopt processing will stop. See getopt(1) and intro(1) about getopt parameter handling. getopt is used to parse positional parameters and to check for legal options.
The following options are supported:
Defines the base for input. Must be 2 to 36, default is 10. Base conversion uses strtol(3C) . Output is always base 10.
Defines the default value as default . default is converted using strtol(3C) in the desired base. Any characters invalid in the specified base will terminate the strtol conversion without error.
Defines the error message as error .
Defines the help message as help .
Specifies that process ID pid is to be sent a signal if the user chooses to quit.
Defines the lower limit of the range as lower . Default is the machine's largest negative long.
Defines the prompt message as prompt .
Specifies that quit will not be allowed as a valid response.
Specifies that the process ID
option is to be sent signal signal
when quit is chosen. If no signal is specified,
Defines the upper limit of the range as upper . Default is the machine's largest positive long.
Specifies that prompt, help and error messages will be formatted to a line length of width .
The following operand is supported:
Input to be verified against upper and lower limits and base.
The default base 10 prompt for ckrange is:
example% ckrangeEnter an integer between lower_bound and upper_bound [lower_bound-upper_bound,?,q]:
The default base 10 error message is:
example% /usr/sadm/bin/errangeERROR: Please enter an integer between lower_bound and upper_bound.
The default base 10 help message is:
example% /usr/sadm/bin/helprangePlease enter an integer between lower_bound and upper_bound.
The messages are changed from ``integer'' to ``base base integer'' if the base is set to a number other than 10. For example,
example% /usr/sadm/bin/helprange -b 36
When the quit option is chosen (and allowed), q is returned along with the return code 3 . Quit input gets a trailing newline.
The valrange module will produce a usage message on stderr. It returns 0 for success and non-zero for failure.
example% /usr/sadm/bin/valrangeusage: valrange [-l lower] [-u upper] [-b base] input
The following exit values are returned:
on input, or negative width on -W
option, or usage error.
User termination (quit).
See attributes(5) for descriptions of the following attributes:
|ATTRIBUTE TYPE||ATTRIBUTE VALUE|