read(1)
read --
read a line from standard input
Synopsis
/usr/bin/read [-r] var ...
Description
This shell script executes the builtin command of the same name as
implemented by the
/u95/bin/sh( )
shell.
See
ksh(1)
for more information on this shell.
The read command reads a single line from standard input.
By default, unless the -r
option is specified, backslash (\) acts as an escape character.
If standard input is a terminal device and the invoking shell is
interactive, read will prompt for a continuation line when:
-
The shell reads an input line ending with a backslash, unless the
-r option is specified.
-
A here-document is not terminated after a newline character is entered.
The line will be split into fields as in the shell.
The first field will be assigned to the first variable (var),
the second field to the second variable, and so forth.
If there are fewer var operands specified than there are fields,
the leftover fields and their intervening separators will be
assigned to the last var.
If there are fewer fields than var operands,
the remaining var operands will be set
to empty strings.
The setting of variables specified by the var
operands will affect the current shell execution environment.
If it is called in a subshell or separate utility execution
environment, such as one of the following:
(read foo)
nohup read ...
find . -exec read ... \;
it will not affect the shell variables in the caller's environment.
Flags
- -r
-
Do not treat a backslash character in any special way.
Consider each backslash to be part of the input line.
Operands
- var
-
The name of an existing or non-existing shell variable.
Input
The standard input must be a text file.
Environment variables
The following environment variables affect the execution of read:
- IFS
-
Determine the internal field separators used to delimit fields. See
ksh(1).
- LANG
-
Provide a default value for the internationalization variables that are
unset or null.
If LANG is unset or null, the corresponding value from the
implementation-specific default locale will be used.
If any of the internationalization variables contains an invalid setting,
the utility will behave as if none of the variables had been defined.
- LC_ALL
-
If set to a non-empty string value, override the values of all
the other internationalization variables.
- LC_CTYPE
-
Determine the locale for the interpretation of sequences of bytes of
text data as characters (for example, single- as opposed to
multi-byte characters in arguments).
- LC_MESSAGES
-
Determine the locale that should be used to affect the format and
contents of diagnostic messages written to standard error.
- PS2
-
Provide the prompt string that an interactive shell will write
to standard error when a line ending with a backslash is read and the
-r option was not specified, or if a here-document is not
terminated after a newline character is entered.
Exit codes
An exit code of 0 indicates successful completion; an exit code
greater than 0 indicates either that the end-of-file was detected
or an error occurred.
Diagnostics
Standard error is used for diagnostic messages and prompts for
continued input.
Usage
The results are undefined if an end-of-file is detected following a
backslash at the end of a line when -r is not specified.
Examples
The following shell command:
while read -r xx yy
do
printf "%s %s\n" "$yy" "$xx"
done < input_file
prints a file with the first field of each line moved to the end of
the line.
References
ksh(1)
30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.