3923 lines
93 KiB
Groff
3923 lines
93 KiB
Groff
.\" $MirOS$
|
|
.\" _MirBSD: src/bin/ksh/ksh.1tbl,v 2.10 2004/12/31 19:00:30 tg Exp $
|
|
.\" $OpenBSD: ksh.1tbl,v 1.84 2004/12/22 18:58:44 millert Exp $
|
|
.\" $OpenBSD: sh.1tbl,v 1.53 2004/12/10 01:56:56 jaredy Exp $
|
|
.\"
|
|
.\" Public Domain.
|
|
.\"
|
|
.Dd November 10, 2004
|
|
.Dt SH 1
|
|
.Os MirOS
|
|
.Sh NAME
|
|
.Nm sh ,
|
|
.Nm ksh ,
|
|
.Nm mksh
|
|
.Nd MirBSD Korn/Bourne shell
|
|
.Sh SYNOPSIS
|
|
.Nm
|
|
.Op Fl +abCefhiklmnprsuvxX
|
|
.Op Fl +o Ar option
|
|
.Xo
|
|
.Bk -words
|
|
.Oo Oo Fl c Ar command-string
|
|
.Op Ar command-name
|
|
.Li \&| Fl s
|
|
.Li \&| Ar file Oc
|
|
.Ek
|
|
.Op Ar argument ... Oc
|
|
.Xc
|
|
.Sh DESCRIPTION
|
|
.Nm
|
|
is a command interpreter intended for both interactive and shell
|
|
script use.
|
|
Its command language is a superset of the
|
|
.Xr sh C
|
|
shell language and compatible to the original Bourne shell.
|
|
.Ss Shell startup
|
|
The following options can be specified only on the command line:
|
|
.Bl -tag -width Ds
|
|
.It Fl c Ar command-string
|
|
.Nm
|
|
will execute the command(s) contained in
|
|
.Ar command-string .
|
|
.It Fl i
|
|
Interactive mode; see below.
|
|
.It Fl l
|
|
Login shell; see below.
|
|
.It Fl s
|
|
The shell reads commands from standard input; all non-option arguments
|
|
are positional parameters.
|
|
.It Fl r
|
|
Restricted mode; see below.
|
|
.El
|
|
.Pp
|
|
In addition to the above, the options described in the
|
|
.Ic set
|
|
built-in command can also be used on the command line.
|
|
.Pp
|
|
If neither the
|
|
.Fl c
|
|
nor the
|
|
.Fl s
|
|
option is specified, the first non-option argument specifies the name
|
|
of a file the shell reads commands from.
|
|
If there are no non-option
|
|
arguments, the shell reads commands from the standard input.
|
|
The name of
|
|
the shell (i.e., the contents of
|
|
.Ic $0 )
|
|
is determined as follows: if the
|
|
.Fl c
|
|
option is used and there is a non-option argument, it is used as the name;
|
|
if commands are being read from a file, the file is used as the name;
|
|
otherwise, the name the shell was called with (i.e.,
|
|
.Li argv[0] )
|
|
is used.
|
|
.Pp
|
|
A shell is
|
|
.Dq interactive
|
|
if the
|
|
.Fl i
|
|
option is used or if both standard input and standard error are attached to a
|
|
.Xr tty 4 .
|
|
An interactive shell has job control enabled (if available), ignores the
|
|
.Dv SIGINT ,
|
|
.Dv SIGQUIT
|
|
and
|
|
.Dv SIGTERM
|
|
signals and prints prompts before reading input (see
|
|
.Ev PS1
|
|
and
|
|
.Ev PS2
|
|
parameters).
|
|
For non-interactive shells, the
|
|
.Ic trackall
|
|
option is on by default (see the
|
|
.Ic set
|
|
command below).
|
|
.Pp
|
|
A shell is
|
|
.Dq restricted
|
|
if the
|
|
.Fl r
|
|
option is used or if either the basename of the name the shell was invoked
|
|
with or the
|
|
.Ev SHELL
|
|
parameter match the pattern
|
|
.Dq \&*r\&*sh
|
|
(e.g.,
|
|
.Dq rsh ,
|
|
.Dq rmksh ,
|
|
.Dq rpdksh ,
|
|
etc.).
|
|
The following restrictions come into effect after the shell processes any
|
|
profile and
|
|
.Ev ENV
|
|
files:
|
|
.Pp
|
|
.Bl -bullet -compact
|
|
.It
|
|
The
|
|
.Ic cd
|
|
command is disabled.
|
|
.It
|
|
The
|
|
.Ev SHELL ,
|
|
.Ev ENV
|
|
and
|
|
.Ev PATH
|
|
parameters cannot be changed.
|
|
.It
|
|
Command names can't be specified with absolute or relative paths.
|
|
.It
|
|
The
|
|
.Fl p
|
|
option of the built-in command
|
|
.Ic command
|
|
can't be used.
|
|
.It
|
|
Redirections that create files can't be used (i.e.,
|
|
.Ql > ,
|
|
.Ql >| ,
|
|
.Ql >> ,
|
|
.Ql <> ) .
|
|
.El
|
|
.Pp
|
|
A shell is
|
|
.Dq privileged
|
|
if the
|
|
.Fl p
|
|
option is used or if the real user ID or group ID does not match the
|
|
effective user ID or group ID (see
|
|
.Xr getuid 2
|
|
and
|
|
.Xr getgid 2 ) .
|
|
A privileged shell does not process
|
|
.Pa $HOME/.profile
|
|
nor the
|
|
.Ev ENV
|
|
parameter (see below).
|
|
Instead, the file
|
|
.Pa /etc/suid_profile
|
|
is processed.
|
|
Clearing the privileged option causes the shell to set
|
|
its effective user ID (group ID) to its real user ID (group ID).
|
|
.Pp
|
|
If the basename of the name the shell is called with (i.e.,
|
|
.Li argv[0] )
|
|
starts with
|
|
.Ql -
|
|
or if the
|
|
.Fl l
|
|
option is used,
|
|
the shell is assumed to be a login shell and the shell reads and executes
|
|
the contents of
|
|
.Pa /etc/profile
|
|
and
|
|
.Pa $HOME/.profile
|
|
if they exist and are readable.
|
|
.Pp
|
|
If the
|
|
.Ev ENV
|
|
parameter is set when the shell starts (or, in the case of login shells,
|
|
after any profiles are processed), its value is subjected to parameter,
|
|
command, arithmetic and tilde
|
|
.Pq Sq \&~
|
|
substitution and the resulting file
|
|
(if any) is read and executed.
|
|
If the
|
|
.Ev ENV
|
|
parameter is not set (and not
|
|
.Dv NULL )
|
|
and
|
|
.Nm
|
|
was compiled with the non-default
|
|
.Dv DEFAULT_ENV
|
|
macro defined, the file named in that macro is included (after the above
|
|
mentioned substitutions have been performed).
|
|
.Pp
|
|
The exit status of the shell is 127 if the command file specified on the
|
|
command line could not be opened, or non-zero if a fatal syntax error
|
|
occurred during the execution of a script.
|
|
In the absence of fatal errors,
|
|
the exit status is that of the last command executed, or zero if no
|
|
command is executed.
|
|
.Ss Command syntax
|
|
The shell begins parsing its input by breaking it into
|
|
.Em words .
|
|
Words, which are sequences of characters, are delimited by unquoted whitespace
|
|
characters (space, tab and newline) or meta-characters
|
|
.Po
|
|
.Ql < ,
|
|
.Ql > ,
|
|
.Ql | ,
|
|
.Ql \&; ,
|
|
.Ql (
|
|
and
|
|
.Ql \&)
|
|
.Pc .
|
|
Aside from delimiting words, spaces and tabs are ignored, while newlines
|
|
usually delimit commands.
|
|
The meta-characters are used in building the following tokens:
|
|
.Ql < ,
|
|
.Ql <& ,
|
|
.Ql << ,
|
|
.Ql > ,
|
|
.Ql >& ,
|
|
.Ql >> ,
|
|
etc. are used to specify redirections (see
|
|
.Sx Input/output redirection
|
|
below);
|
|
.Ql |
|
|
is used to create pipelines;
|
|
.Ql \&;
|
|
is used to separate commands;
|
|
.Ql &
|
|
is used to create asynchronous pipelines;
|
|
.Ql &&
|
|
and
|
|
.Ql ||
|
|
are used to specify conditional execution;
|
|
.Ql \&;\&;
|
|
is used in
|
|
.Ic case
|
|
statements;
|
|
and lastly,
|
|
.Ql \&( .. \&)
|
|
is used to create subshells.
|
|
.Pp
|
|
Whitespace and meta-characters can be quoted individually using a backslash
|
|
.Pq Sq \e
|
|
or in groups using double
|
|
.Pq Sq \&"
|
|
or single
|
|
.Pq Sq \&'
|
|
quotes.
|
|
Note that the following characters are also treated specially by the
|
|
shell and must be quoted if they are to represent themselves:
|
|
.Ql \e ,
|
|
.Ql \&" ,
|
|
.Ql ' ,
|
|
.Ql # ,
|
|
.Ql $ ,
|
|
.Ql ` ,
|
|
.Ql ~ ,
|
|
.Ql { ,
|
|
.Ql } ,
|
|
.Ql * ,
|
|
.Ql \&?
|
|
and
|
|
.Ql [ .
|
|
The first three of these are the above mentioned quoting characters (see
|
|
.Sx Quoting
|
|
below);
|
|
.Ql # ,
|
|
if used at the beginning of a word, introduces a comment \(em everything after
|
|
the
|
|
.Ql #
|
|
up to the nearest newline is ignored;
|
|
.Ql $
|
|
is used to introduce parameter, command and arithmetic substitutions (see
|
|
.Sx Substitution
|
|
below);
|
|
.Ql `
|
|
introduces an old-style command substitution (see
|
|
.Sx Substitution
|
|
below);
|
|
.Ql ~
|
|
begins a directory expansion (see
|
|
.Sx Tilde expansion
|
|
below);
|
|
.Ql {
|
|
and
|
|
.Ql }
|
|
delimit
|
|
.Xr csh 1
|
|
style alterations (see
|
|
.Sx Brace expansion
|
|
below);
|
|
and finally,
|
|
.Ql * ,
|
|
.Ql \&?
|
|
and
|
|
.Ql [
|
|
are used in file name generation (see
|
|
.Sx File name patterns
|
|
below).
|
|
.Pp
|
|
As words and tokens are parsed, the shell builds commands, of which there
|
|
are two basic types:
|
|
.Em simple-commands ,
|
|
typically programs that are executed, and
|
|
.Em compound-commands ,
|
|
such as
|
|
.Ic for
|
|
and
|
|
.Ic if
|
|
statements, grouping constructs and function definitions.
|
|
.Pp
|
|
A simple-command consists of some combination of parameter assignments
|
|
(see
|
|
.Sx Parameters
|
|
below),
|
|
input/output redirections (see
|
|
.Sx Input/output redirections
|
|
below) and command words; the only restriction is that
|
|
parameter assignments come before any command words.
|
|
The command words, if any, define the command
|
|
that is to be executed and its arguments.
|
|
The command may be a shell built-in
|
|
command, a function or an external command (i.e., a separate executable file
|
|
that is located using the
|
|
.Ev PATH
|
|
parameter (see
|
|
.Sx Command execution
|
|
below)).
|
|
Note that all command constructs have an exit status: for external commands,
|
|
this is related to the status returned by
|
|
.Xr wait 2
|
|
(if the command could not be found, the exit status is 127; if it could not
|
|
be executed, the exit status is 126); the exit status of other command
|
|
constructs (built-in commands, functions, compound-commands, pipelines, lists,
|
|
etc.) are all well-defined and are described where the construct is
|
|
described.
|
|
The exit status of a command consisting only of parameter
|
|
assignments is that of the last command substitution performed during the
|
|
parameter assignment or 0 is there were no command substitutions.
|
|
.Pp
|
|
Commands can be chained together using the
|
|
.Ql |
|
|
token to form pipelines, in which the standard output of each command but the
|
|
last is piped (see
|
|
.Xr pipe 2 )
|
|
to the standard input of the following command.
|
|
The exit status of a pipeline is that of its last command.
|
|
A pipeline may be prefixed by the
|
|
.Ql \&!
|
|
reserved word, which causes the exit status of the pipeline to be logically
|
|
complemented: if the original status was 0, the complemented status will be 1;
|
|
if the original status was not 0, the complemented status will be 0.
|
|
.Pp
|
|
.Em Lists
|
|
of commands can be created by separating pipelines by any of the following
|
|
tokens:
|
|
.Ql && ,
|
|
.Ql || ,
|
|
.Ql & ,
|
|
.Ql |&
|
|
and
|
|
.Ql \&; .
|
|
The first two are for conditional execution:
|
|
.Dq Ar cmd1 No && Ar cmd2
|
|
executes
|
|
.Ar cmd2
|
|
only if the exit status of
|
|
.Ar cmd1
|
|
is zero;
|
|
.Ql ||
|
|
is the opposite \(em
|
|
.Ar cmd2
|
|
is executed only if the exit status of
|
|
.Ar cmd1
|
|
is non-zero.
|
|
.Ql &&
|
|
and
|
|
.Ql ||
|
|
have equal precedence which is higher than that of
|
|
.Ql & ,
|
|
.Ql |&
|
|
and
|
|
.Ql \&; ,
|
|
which also have equal precedence.
|
|
Note that the
|
|
.Ql &&
|
|
and
|
|
.Ql ||
|
|
operators are
|
|
.Qq left-associative .
|
|
For example, both of these commands will print only
|
|
.Qq bar :
|
|
.Bd -literal -offset indent
|
|
false && echo foo || echo bar
|
|
true || echo foo && echo bar
|
|
.Ed
|
|
.Pp
|
|
The
|
|
.Ql &
|
|
token causes the preceding command to be executed asynchronously; that is,
|
|
the shell starts the command but does not wait for it to complete (the shell
|
|
does keep track of the status of asynchronous commands, see
|
|
.Sx Job control
|
|
below).
|
|
When an asynchronous command is started when job control is disabled
|
|
(i.e., in most scripts), the command is started with signals
|
|
.Dv SIGINT
|
|
and
|
|
.Dv SIGQUIT
|
|
ignored and with input redirected from
|
|
.Pa /dev/null
|
|
(however, redirections specified in the asynchronous command have precedence).
|
|
Note that a command must follow the
|
|
.Ql &&
|
|
and
|
|
.Ql ||
|
|
operators, while it need not follow
|
|
.Ql & ,
|
|
.Ql |&
|
|
or
|
|
.Ql \&; .
|
|
The exit status of a list is that of the last command executed, with the
|
|
exception of asynchronous lists, for which the exit status is 0.
|
|
.Pp
|
|
Compound commands are created using the following reserved words.
|
|
These words
|
|
are only recognized if they are unquoted and if they are used as the first
|
|
word of a command (i.e., they can't be preceded by parameter assignments or
|
|
redirections):
|
|
.Bd -literal -offset center
|
|
case else function time !
|
|
do esac if until [
|
|
done fi in while {
|
|
elif for then }
|
|
.Ed
|
|
.Pp
|
|
.Sy Note:
|
|
Some shells (but not this one) execute control structure commands in a
|
|
subshell when one or more of their file descriptors are redirected, so any
|
|
environment changes inside them may fail.
|
|
To be portable, the
|
|
.Ic exec
|
|
statement should be used instead to redirect file descriptors before the
|
|
control structure.
|
|
.Pp
|
|
In the following compound command descriptions, command lists (denoted as
|
|
.Em list )
|
|
that are followed by reserved words must end with a semicolon, a newline or
|
|
a (syntactically correct) reserved word.
|
|
For example,
|
|
.Bd -unfilled -offset indent
|
|
.Ic { echo foo; echo bar; }
|
|
.Ic { echo foo; echo bar<newline> }
|
|
.Ic { { echo foo; echo bar; } }
|
|
.Ed
|
|
.Pp
|
|
are all valid, but
|
|
.Bd -unfilled -offset indent
|
|
.Ic { echo foo; echo bar }
|
|
.Ed
|
|
.Pp
|
|
is not.
|
|
.Bl -tag -width Ds
|
|
.It Ic \&( Ar list Ic \&)
|
|
Execute
|
|
.Ar list
|
|
in a subshell.
|
|
There is no implicit way to pass environment changes from a
|
|
subshell back to its parent.
|
|
.It Ic \&{ Ar list Ic \&}
|
|
Compound construct;
|
|
.Ar list
|
|
is executed, but not in a subshell.
|
|
Note that
|
|
.Ic \&{
|
|
and
|
|
.Ic \&}
|
|
are reserved words, not meta-characters.
|
|
.It Xo Ic case Ar word Ic in [
|
|
.Ns [ Ic \&( ] Ar pattern [
|
|
.Ns Ic \&| Ar pattern ] ... Ic \&)
|
|
.Ar list Ic \&;\&;
|
|
.Ns ] Ar ...
|
|
.Ic esac
|
|
.Xc
|
|
The
|
|
.Ic case
|
|
statement attempts to match
|
|
.Ar word
|
|
against the specified
|
|
.Ar pattern Ns s ;
|
|
the
|
|
.Ar list
|
|
associated with the first successfully matched pattern is executed.
|
|
Patterns used in
|
|
.Ic case
|
|
statements are the same as those used for file name patterns except that the
|
|
restrictions regarding
|
|
.Ql \&.
|
|
and
|
|
.Ql /
|
|
are dropped.
|
|
Note that any unquoted space before and after a pattern is
|
|
stripped; any space within a pattern must be quoted.
|
|
Both the word and the
|
|
patterns are subject to parameter, command and arithmetic substitution, as
|
|
well as tilde substitution.
|
|
For historical reasons, open and close braces may be used instead of
|
|
.Ic in
|
|
and
|
|
.Ic esac
|
|
(e.g.,
|
|
.Ic case $foo { *) echo bar; } ) .
|
|
The exit status of a
|
|
.Ic case
|
|
statement is that of the executed
|
|
.Ar list ;
|
|
if no
|
|
.Ar list
|
|
is executed, the exit status is zero.
|
|
.It Xo Ic for Ar name No [
|
|
.Ic in Ar word ... term Ns ]
|
|
.Ic do Ar list Ic done
|
|
.Xc
|
|
For each
|
|
.Ar word
|
|
in the specified word list, the parameter
|
|
.Ar name
|
|
is set to the word and
|
|
.Ar list
|
|
is executed.
|
|
If
|
|
.Ic in
|
|
is not used to specify a word list, the positional parameters
|
|
.Po
|
|
.Ic $1 , $2 ,
|
|
etc.\&
|
|
.Pc
|
|
are used instead.
|
|
For historical reasons, open and close braces may be used instead of
|
|
.Ic do
|
|
and
|
|
.Ic done
|
|
(e.g.,
|
|
.Ic for i\&; { echo $i; } ) .
|
|
The exit status of a
|
|
.Ic for
|
|
statement is the last exit status of
|
|
.Ar list ;
|
|
if
|
|
.Ar list
|
|
is never executed, the exit status is zero.
|
|
.Ar term
|
|
is either a newline or a
|
|
.Ql \&; .
|
|
.It Xo Ic if Ar list Ic then
|
|
.Ar list [ Ic elif Ar list Ic then
|
|
.Ar list ] Ar ... [ Ic else
|
|
.Ar list ] Ic fi
|
|
.Xc
|
|
If the exit status of the first
|
|
.Ar list
|
|
is zero, the second
|
|
.Ar list
|
|
is executed; otherwise, the
|
|
.Ar list
|
|
following the
|
|
.Ic elif ,
|
|
if any, is executed with similar consequences.
|
|
If all the lists following the
|
|
.Ic if
|
|
and
|
|
.Ic elif Ns s
|
|
fail (i.e., exit with non-zero status), the
|
|
.Ar list
|
|
following the
|
|
.Ic else
|
|
is executed.
|
|
The exit status of an
|
|
.Ic if
|
|
statement is that of non-conditional
|
|
.Ar list
|
|
that is executed; if no non-conditional
|
|
.Ar list
|
|
is executed, the exit status is zero.
|
|
.It Xo Ic until Ar list Ic do Ar list
|
|
.Ic done
|
|
.Xc
|
|
This works like
|
|
.Ic while ,
|
|
except that the body is executed only while the exit status of the first
|
|
.Ar list
|
|
is non-zero.
|
|
.It Xo Ic while Ar list Ic do Ar list
|
|
.Ic done
|
|
.Xc
|
|
A
|
|
.Ic while
|
|
is a pre-checked loop.
|
|
Its body is executed as often as the exit status of the first
|
|
.Ar list
|
|
is zero.
|
|
The exit status of a
|
|
.Ic while
|
|
statement is the last exit status of the
|
|
.Ar list
|
|
in the body of the loop; if the body is not executed, the exit status is zero.
|
|
.It Xo Ic function Ar name Ic \&{
|
|
.Ar list Ic \&}
|
|
.Xc
|
|
Defines the function
|
|
.Ar name
|
|
(see
|
|
.Sx Functions
|
|
below).
|
|
Note that redirections specified after a function definition are
|
|
performed whenever the function is executed, not when the function definition
|
|
is executed.
|
|
.It Ar name Ic () Ar command
|
|
Mostly the same as
|
|
.Ic function
|
|
(see
|
|
.Sx Functions
|
|
below).
|
|
.El
|
|
.Ss Quoting
|
|
Quoting is used to prevent the shell from treating characters or words
|
|
specially.
|
|
There are three methods of quoting.
|
|
First,
|
|
.Ql \e
|
|
quotes the following character, unless it is at the end of a line, in which
|
|
case both the
|
|
.Ql \e
|
|
and the newline are stripped.
|
|
Second, a single quote
|
|
.Pq Sq '
|
|
quotes everything up to the next single quote (this may span lines).
|
|
Third, a double quote
|
|
.Pq Sq \&"
|
|
quotes all characters, except
|
|
.Ql $ ,
|
|
.Ql `
|
|
and
|
|
.Ql \e ,
|
|
up to the next unquoted double quote.
|
|
.Ql $
|
|
and
|
|
.Ql `
|
|
inside double quotes have their usual meaning (i.e., parameter, command or
|
|
arithmetic substitution) except no field splitting is carried out on the
|
|
results of double-quoted substitutions.
|
|
If a
|
|
.Ql \e
|
|
inside a double-quoted string is followed by
|
|
.Ql \e ,
|
|
.Ql $ ,
|
|
.Ql `
|
|
or
|
|
.Ql \&" ,
|
|
it is replaced by the second character; if it is followed by a newline, both
|
|
the
|
|
.Ql \e
|
|
and the newline are stripped; otherwise, both the
|
|
.Ql \e
|
|
and the character following are unchanged.
|
|
.Pp
|
|
.Sy Note:
|
|
See
|
|
.Sx POSIX mode
|
|
below for a special rule regarding sequences of the form
|
|
.Ic \&"...`...\e\&"...`..\&" .
|
|
.Ss Aliases
|
|
There are two types of aliases: normal command aliases and tracked aliases.
|
|
Command aliases are normally used as a short hand for a long or often used
|
|
command.
|
|
The shell expands command aliases (i.e., substitutes the alias name
|
|
for its value) when it reads the first word of a command.
|
|
An expanded alias is re-processed to check for more aliases.
|
|
If a command alias ends in a
|
|
space or tab, the following word is also checked for alias expansion.
|
|
The alias expansion process stops when a word that is not an alias is found,
|
|
when a quoted word is found or when an alias word that is currently being
|
|
expanded is found.
|
|
.Pp
|
|
The following command aliases are defined automatically by the shell:
|
|
.Pp
|
|
.Bl -item -offset indent -compact
|
|
.It
|
|
.Ic hash='alias -t'
|
|
.It
|
|
.Ic type='whence -v'
|
|
.El
|
|
.Pp
|
|
Tracked aliases allow the shell to remember where it found a particular
|
|
command.
|
|
The first time the shell does a path search for a command that is
|
|
marked as a tracked alias, it saves the full path of the command.
|
|
The next
|
|
time the command is executed, the shell checks the saved path to see that it
|
|
is still valid and, if so, avoids repeating the path search.
|
|
Tracked aliases can be listed and created using
|
|
.Ic alias -t .
|
|
Note that changing the
|
|
.Ev PATH
|
|
parameter clears the saved paths for all tracked aliases.
|
|
If the
|
|
.Ic trackall
|
|
option is set (i.e.,
|
|
.Ic set Fl o Ic trackall
|
|
or
|
|
.Ic set Fl h ) ,
|
|
the shell tracks all commands.
|
|
This option is set automatically for non-interactive shells.
|
|
For interactive shells, only the following commands are
|
|
automatically tracked:
|
|
.Ic cat , cc , chmod , cp ,
|
|
.Ic date , ed , emacs , grep ,
|
|
.Ic ls , mail , make , mv ,
|
|
.Ic pr , rm , sed , sh ,
|
|
.Ic vi
|
|
and
|
|
.Ic who .
|
|
.Ss Substitution
|
|
The first step the shell takes in executing a simple-command is to perform
|
|
substitutions on the words of the command.
|
|
There are three kinds of
|
|
substitution: parameter, command and arithmetic.
|
|
Parameter substitutions,
|
|
which are described in detail in the next section, take the form
|
|
.Ic $ Ns Ar name
|
|
or
|
|
.Ic ${ Ns Ar ... Ns Ic \&} ;
|
|
command substitutions take the form
|
|
.Ic $( Ns Ar command Ns Ic \&)
|
|
or
|
|
.Ic ` Ns Ar command Ns Ic ` ;
|
|
and arithmetic substitutions take the form
|
|
.Ic $(( Ns Ar expression Ns Ic )) .
|
|
.Pp
|
|
If a substitution appears outside of double quotes, the results of the
|
|
substitution are generally subject to word or field splitting according to
|
|
the current value of the
|
|
.Ev IFS
|
|
parameter.
|
|
The
|
|
.Ev IFS
|
|
parameter specifies a list of characters which are used to break a string up
|
|
into several words; any characters from the set space, tab and newline that
|
|
appear in the
|
|
.Ev IFS
|
|
characters are called
|
|
.Dq IFS whitespace .
|
|
Sequences of one or more
|
|
.Ev IFS
|
|
whitespace characters, in combination with zero or one
|
|
.Pf non- Ev IFS
|
|
whitespace
|
|
characters, delimit a field.
|
|
As a special case, leading and trailing
|
|
.Ev IFS
|
|
whitespace and trailing
|
|
.Ev IFS
|
|
non-whitespace are stripped (i.e., no leading or trailing
|
|
empty field is created by it); leading
|
|
.Pf non- Ev IFS
|
|
whitespace does create an empty field.
|
|
.Pp
|
|
Example: If
|
|
.Ev IFS
|
|
is set to
|
|
.Dq <space>: ,
|
|
the sequence of characters
|
|
.Dq <space>A<space>:<space><space>B::D
|
|
contains four fields:
|
|
.Sq A ,
|
|
.Sq B ,
|
|
.Sq
|
|
(an empty field) and
|
|
.Sq D .
|
|
Note that if the
|
|
.Ev IFS
|
|
parameter is set to the null
|
|
string, no field splitting is done; if the parameter is unset, the default
|
|
value of space, tab and newline is used.
|
|
.Pp
|
|
Also, note that the field splitting applies only to the immediate result of
|
|
the substitution.
|
|
Using the previous example, the substitution for $VAR:E
|
|
results in the fields:
|
|
.Sq A ,
|
|
.Sq B ,
|
|
.Sq ""
|
|
and
|
|
.Sq D:E ,
|
|
not
|
|
.Sq A ,
|
|
.Sq B ,
|
|
.Sq ""
|
|
and
|
|
.Sq E .
|
|
This behavior is POSIX compliant, but incompatible with some other shell
|
|
implementations which do field splitting on the word which contained the
|
|
substitution or use
|
|
.Dv IFS
|
|
as a general whitespace delimiter.
|
|
.Pp
|
|
The results of substitution are, unless otherwise specified, also subject to
|
|
brace expansion and file name expansion (see the relevant sections below).
|
|
.Pp
|
|
A command substitution is replaced by the output generated by the specified
|
|
command, which is run in a subshell.
|
|
For
|
|
.Ic $( Ns Ar command Ns Ic \&)
|
|
substitutions, normal quoting rules are used when
|
|
.Ar command
|
|
is parsed; however, for the
|
|
.Ic ` Ns Ar command Ns Ic `
|
|
form, a
|
|
.Ql \e
|
|
followed by any of
|
|
.Ql $ ,
|
|
.Ql `
|
|
or
|
|
.Ql \e
|
|
is stripped (a
|
|
.Ql \e
|
|
followed by any other character is unchanged).
|
|
As a special case in command substitutions, a command of the form
|
|
.Ic \&< Ar file
|
|
is interpreted to mean substitute the contents of
|
|
.Ar file
|
|
(note that
|
|
.Ic $(< foo)
|
|
has the same effect as
|
|
.Ic $(cat foo) ,
|
|
but it is carried out more efficiently because no process is started).
|
|
.Pp
|
|
.Sy Note:
|
|
.Ic $( Ns Ar command Ns Ic \&)
|
|
expressions are currently parsed by finding the matching parenthesis,
|
|
regardless of quoting.
|
|
This should be fixed soon.
|
|
.Pp
|
|
Arithmetic substitutions are replaced by the value of the specified expression.
|
|
For example, the command
|
|
.Ic echo $((2+3*4))
|
|
prints 14.
|
|
See
|
|
.Sx Arithmetic expressions
|
|
for a description of an expression.
|
|
.Ss Parameters
|
|
Parameters are shell variables; they can be assigned values and their values
|
|
can be accessed using a parameter substitution.
|
|
A parameter name is either one
|
|
of the special single punctuation or digit character parameters described
|
|
below or a letter followed by zero or more letters or digits
|
|
.Po
|
|
.Ql _
|
|
counts as a letter
|
|
.Pc .
|
|
Parameter substitutions take the form
|
|
.Ic $ Ns Ar name
|
|
or
|
|
+.Ic ${ Ns Ar name Ns Ic \&} ,
|
|
where
|
|
.Ar name
|
|
is a parameter name.
|
|
If substitution is performed on a parameter
|
|
that is not set, a null string is substituted unless the
|
|
.Ic nounset
|
|
option
|
|
.Po
|
|
.Ic set Fl o Ic nounset
|
|
or
|
|
.Ic set Fl u
|
|
.Pc
|
|
is set, in which case an error occurs.
|
|
.Pp
|
|
Parameters can be assigned values in a number of ways.
|
|
First, the shell implicitly sets some parameters like
|
|
.Ic # , PWD ,
|
|
etc.; this is the only way the special single character parameters are set.
|
|
Second, parameters are imported from the shell's environment at startup.
|
|
Third, parameters can be assigned values on the command line, for example,
|
|
.Ic FOO=bar
|
|
sets the parameter
|
|
.Ev FOO
|
|
to
|
|
.Dq bar ;
|
|
multiple parameter assignments can be given on a single command line and they
|
|
can be followed by a simple-command, in which case the assignments are in
|
|
effect only for the duration of the command (such assignments are also
|
|
exported, see below for implications of this).
|
|
Note that both the parameter name and the
|
|
.Ql =
|
|
must be unquoted for the shell to recognize a parameter assignment.
|
|
The fourth way of setting a parameter is with the
|
|
.Ic export ,
|
|
.Ic readonly
|
|
and
|
|
.Ic typeset
|
|
commands; see their descriptions in the
|
|
.Sx Command execution
|
|
section.
|
|
Fifth,
|
|
.Ic for
|
|
loops set parameters as well as the
|
|
.Ic getopts ,
|
|
.Ic read
|
|
and
|
|
.Ic set Fl A
|
|
commands.
|
|
Lastly, parameters can be assigned values using assignment operators
|
|
inside arithmetic expressions (see
|
|
.Sx Arithmetic expressions
|
|
below) or using the
|
|
.Xo Ic ${ Ns Ar name Ns =
|
|
.Ns Ar value Ns Ic \&}
|
|
.Xc
|
|
form of the parameter substitution (see below).
|
|
.Pp
|
|
Parameters with the export attribute (set using the
|
|
.Ic export
|
|
or
|
|
.Ic typeset Fl x
|
|
commands or by parameter assignments followed by simple commands) are put in
|
|
the environment (see
|
|
.Xr environ 7 )
|
|
of commands run by the shell as
|
|
.Ar name Ns = Ns Ar value
|
|
pairs.
|
|
The order in which parameters appear in the environment of a command is
|
|
unspecified.
|
|
When the shell starts up, it extracts parameters and their values
|
|
from its environment and automatically sets the export attribute for those
|
|
parameters.
|
|
.Pp
|
|
Modifiers can be applied to the
|
|
.Ic ${ Ns Ar name Ns Ic \&}
|
|
form of parameter substitution:
|
|
.Bl -tag -width Ds
|
|
.It Xo Ic ${ Ns Ar name Ns
|
|
.Ic \&:\&- Ns Ar word Ns Ic \&}
|
|
.Xc
|
|
If
|
|
.Ar name
|
|
is set and not
|
|
.Dv NULL ,
|
|
it is substituted; otherwise,
|
|
.Ar word
|
|
is substituted.
|
|
.It Xo Ic ${ Ns Ar name Ns
|
|
.Ic \&:\&+ Ns Ar word Ns Ic \&}
|
|
.Xc
|
|
If
|
|
.Ar name
|
|
is set and not
|
|
.Dv NULL ,
|
|
.Ar word
|
|
is substituted; otherwise, nothing is substituted.
|
|
.It Xo Ic ${ Ns Ar name Ns
|
|
.Ic \&:\&= Ns Ar word Ns Ic \&}
|
|
.Xc
|
|
If
|
|
.Ar name
|
|
is set and not
|
|
.Dv NULL ,
|
|
it is substituted; otherwise, it is assigned
|
|
.Ar word
|
|
and the resulting value of
|
|
.Ar name
|
|
is substituted.
|
|
.It Xo Ic ${ Ns Ar name Ns
|
|
.Ic \&:\&? Ns Ar word Ns Ic \&}
|
|
.Xc
|
|
If
|
|
.Ar name
|
|
is set and not
|
|
.Dv NULL ,
|
|
it is substituted; otherwise,
|
|
.Ar word
|
|
is printed on standard error (preceded by
|
|
.Ar name Ns \&: )
|
|
and an error occurs (normally causing termination of a shell script, function
|
|
or .-script).
|
|
If word is omitted the string
|
|
.Dq parameter null or not set
|
|
is used instead.
|
|
.El
|
|
.Pp
|
|
In the above modifiers, the
|
|
.Ql \&:
|
|
can be omitted, in which case the conditions only depend on
|
|
.Ar name
|
|
being set (as opposed to set and not
|
|
.Dv NULL ) .
|
|
If
|
|
.Ar word
|
|
is needed, parameter, command, arithmetic and tilde substitution are performed
|
|
on it; if
|
|
.Ar word
|
|
is not needed, it is not evaluated.
|
|
.Pp
|
|
The following forms of parameter substitution can also be used:
|
|
.Bl -tag -width Ds
|
|
.It Ic ${# Ns Ar name Ns Ic \&}
|
|
The number of positional parameters if
|
|
.Ar name
|
|
is
|
|
.Ql * ,
|
|
.Ql @ ,
|
|
not specified, or the length of the string value of parameter
|
|
.Ar name .
|
|
.It Xo Ic ${# Ns Ar name Ns
|
|
.Ic [*\&]} , ${# Ns Ar name Ns Ic [@\&]}
|
|
.Xc
|
|
The number of elements in the array
|
|
.Ar name .
|
|
.Sm off
|
|
.It Xo
|
|
.Ic ${ Ar name Ic # Ar pattern
|
|
.Sm on
|
|
.Ic } ,
|
|
.Sm off
|
|
.Ic ${ Ar name Ic ## Ar pattern Ic \&}
|
|
.Xc
|
|
.Sm on
|
|
If
|
|
.Ar pattern
|
|
matches the beginning of the value of parameter
|
|
.Ar name ,
|
|
the matched text is deleted from the result of substitution.
|
|
A single
|
|
.Ql #
|
|
results in the shortest match, two of them result in the longest match.
|
|
.Sm off
|
|
.It Xo
|
|
.Ic ${ Ar name Ic % Ar pattern
|
|
.Sm on
|
|
.Ic } ,
|
|
.Sm off
|
|
.Ic ${ Ar name Ic %% Ar pattern Ic }
|
|
.Xc
|
|
.Sm on
|
|
Like
|
|
.Ic ${..#..}
|
|
substitution, but it deletes from the end of the value.
|
|
.El
|
|
.Pp
|
|
The following special parameters are implicitly set by the shell and cannot be
|
|
set directly using assignments:
|
|
.Bl -tag -width "1 ... 9"
|
|
.It Ev \&!
|
|
Process ID of the last background process started.
|
|
If no background processes have been started, the parameter is not set.
|
|
.It Ev \&#
|
|
The number of positional parameters (i.e.,
|
|
.Ic $1 , $2 ,
|
|
etc.).
|
|
.It Ev \&$
|
|
The process ID of the shell, or the
|
|
.Tn PID
|
|
of the original shell if it is a subshell.
|
|
Do
|
|
.Em NOT
|
|
use this mechanism for generating temporary file names; see
|
|
.Xr mktemp 1
|
|
instead.
|
|
.It Ev \&-
|
|
The concatenation of the current single letter options (see the
|
|
.Ic set
|
|
command below for a list of options).
|
|
.It Ev \&?
|
|
The exit status of the last non-asynchronous command executed.
|
|
If the last command was killed by a signal,
|
|
.Va \&$?\&
|
|
is set to 128 plus the signal number.
|
|
.It Ev 0
|
|
The name the shell was invoked with (i.e.,
|
|
.Li argv[0] )
|
|
or the
|
|
.Ar command-name
|
|
if it was invoked with the
|
|
.Fl c
|
|
option and the
|
|
.Ar command-name
|
|
was supplied, or the
|
|
.Ar file
|
|
argument, if it was supplied.
|
|
If the
|
|
.Ic posix
|
|
option is not set,
|
|
.Ic \&$0
|
|
is the name of the current function or script.
|
|
.It Ev 1 ... Ev 9
|
|
The first nine positional parameters that were supplied to the shell, function
|
|
or .-script.
|
|
Further positional parameters may be accessed using
|
|
.Ic ${ Ns Ar number Ns Ic \&} .
|
|
.It Ev \&*
|
|
All positional parameters (except parameter 0); i.e.,
|
|
.Ic $1 , $2 , $3 ,
|
|
\&...
|
|
If used
|
|
outside of double quotes, parameters are separate words (which are subjected
|
|
to word splitting); if used within double quotes, parameters are separated
|
|
by the first character of the
|
|
.Ev IFS
|
|
parameter (or the empty string if
|
|
.Ev IFS
|
|
is
|
|
.Dv NULL ) .
|
|
.It Ev \&@
|
|
Same as
|
|
.Ic \&$\&* ,
|
|
unless it is used inside double quotes, in which case a separate word is
|
|
generated for each positional parameter.
|
|
If there are no positional parameters, no word is generated.
|
|
.Ic \&$\&@
|
|
can be used to access arguments, verbatim, without losing
|
|
.Dv NULL
|
|
arguments or splitting arguments with spaces.
|
|
.El
|
|
.Pp
|
|
The following parameters are set and/or used by the shell:
|
|
.Bl -tag -width "EXECSHELL"
|
|
.It Ev CDPATH
|
|
Search path for the
|
|
.Ic cd
|
|
built-in command.
|
|
Works the same way as
|
|
.Ev PATH
|
|
for those directories not beginning with
|
|
.Ql /
|
|
in
|
|
.Ic cd
|
|
commands.
|
|
Note that if
|
|
.Ev CDPATH
|
|
is set and does not contain
|
|
.Dq \&.
|
|
or contains an empty path, the current directory is not searched.
|
|
Also, the
|
|
.Ic cd
|
|
built-in command will display the resulting directory when a match is found
|
|
in any search path other than the empty path.
|
|
.It Ev COLUMNS
|
|
Set to the number of columns on the terminal or window.
|
|
Currently set to the
|
|
.Dq cols
|
|
value as reported by
|
|
.Xr stty 1
|
|
if that value is non-zero.
|
|
This parameter is used by the
|
|
.Ic set Fl o
|
|
and
|
|
.Ic kill Fl l
|
|
commands to format information columns.
|
|
.It Ev ENV
|
|
If this parameter is found to be set after any profile files are executed, the
|
|
expanded value is used as a shell startup file.
|
|
It typically contains function and alias definitions.
|
|
.It Ev ERRNO
|
|
Integer value of the shell's
|
|
.Va errno
|
|
variable.
|
|
It indicates the reason the last system call failed.
|
|
Not yet implemented.
|
|
.It Ev EXECSHELL
|
|
If set, this parameter is assumed to contain the shell that is to be used to
|
|
execute commands that
|
|
.Xr execve 2
|
|
fails to execute and which do not start with a
|
|
.Dq \&#\&! Ns Ar shell
|
|
sequence.
|
|
.It Ev FCEDIT
|
|
The editor used by the
|
|
.Ic fc
|
|
command (see below).
|
|
.It Ev FPATH
|
|
Like
|
|
.Ev PATH ,
|
|
but used when an undefined function is executed to locate the file defining the
|
|
function.
|
|
It is also searched when a command can't be found using
|
|
.Ev PATH .
|
|
See
|
|
.Sx Functions
|
|
below for more information.
|
|
.It Ev HOME
|
|
The default directory for the
|
|
.Ic cd
|
|
command and the value substituted for an unqualified
|
|
.Ic ~
|
|
(see
|
|
.Sx Tilde expansion
|
|
below).
|
|
.It Ev IFS
|
|
Internal field separator, used during substitution and by the
|
|
.Ic read
|
|
command, to split values into distinct arguments; normally set to space, tab
|
|
and newline.
|
|
See
|
|
.Sx Substitution
|
|
above for details.
|
|
.Pp
|
|
.Sy Note:
|
|
This parameter is not imported from the environment when the shell is
|
|
started.
|
|
.It Ev LINENO
|
|
The line number of the function or shell script that is currently being
|
|
executed.
|
|
.It Ev LINES
|
|
Set to the number of lines on the terminal or window.
|
|
Not yet implemented.
|
|
.It Ev OLDPWD
|
|
The previous working directory.
|
|
Unset if
|
|
.Ic cd
|
|
has not successfully changed directories since the shell started or the
|
|
shell doesn't know where it is.
|
|
.It Ev OPTARG
|
|
When using
|
|
.Ic getopts ,
|
|
it contains the argument for a parsed option, if it requires one.
|
|
.It Ev OPTIND
|
|
The index of the last argument processed when using
|
|
.Ic getopts .
|
|
Assigning 1 to this parameter causes
|
|
.Ic getopts
|
|
to process arguments from the beginning the next time it is invoked.
|
|
.It Ev PATH
|
|
A colon separated list of directories that are searched when looking for
|
|
commands and .'d files.
|
|
An empty string resulting from a leading or trailing
|
|
colon, or two adjacent colons, is treated as a
|
|
.Dq \&. ,
|
|
the current directory.
|
|
This is dangerous.
|
|
.It Ev POSIXLY_CORRECT
|
|
If set, this parameter causes the
|
|
.Ic posix
|
|
option to be enabled.
|
|
See
|
|
.Sx POSIX mode
|
|
below.
|
|
.It Ev PPID
|
|
The process ID of the shell's parent (read-only).
|
|
.It Ev PS1
|
|
The primary prompt for interactive shells.
|
|
Parameter, command and arithmetic substitutions are performed, and
|
|
.Ql \&!
|
|
is replaced with the current command number (see the
|
|
.Ic fc
|
|
command below).
|
|
A literal
|
|
.Ql \&!
|
|
can be put in the prompt by placing
|
|
.Ql !!
|
|
in
|
|
.Ev PS1 .
|
|
Default is
|
|
.Dq \&$\ \&
|
|
for non-root users,
|
|
.Dq \&#\ \&
|
|
for root.
|
|
.Pp
|
|
.It Ev PS2
|
|
Secondary prompt string, by default
|
|
.Dq \&>\ \& ,
|
|
used when more input is needed to complete a command.
|
|
.It Ev PS4
|
|
Used to prefix commands that are printed during execution tracing (see the
|
|
.Ic set Fl x
|
|
command below).
|
|
This prompt is printed verbatim (i.e., no substitutions are done).
|
|
Default is
|
|
.Dq \&+\ \& .
|
|
.It Ev PWD
|
|
The current working directory.
|
|
May be unset or
|
|
.Dv NULL
|
|
if the shell doesn't know where it is.
|
|
.It Ev REPLY
|
|
Default parameter for the
|
|
.Ic read
|
|
command if no names are given.
|
|
.It Ev TMPDIR
|
|
The directory shell temporary files are created in.
|
|
If this parameter is not
|
|
set or does not contain the absolute path of a writable directory, temporary
|
|
files are created in
|
|
.Pa /tmp .
|
|
.El
|
|
.Ss Tilde expansion
|
|
Tilde expansion, which is done in parallel with parameter substitution, is done
|
|
on words starting with an unquoted
|
|
.Ql ~ .
|
|
The characters following the tilde, up to the first
|
|
.Ql / ,
|
|
if any, are assumed to be a login name.
|
|
If the login name is empty,
|
|
.Ql +
|
|
or
|
|
.Ql - ,
|
|
the value of the
|
|
.Ev HOME ,
|
|
.Ev PWD
|
|
or
|
|
.Ev OLDPWD
|
|
parameter is substituted, respectively.
|
|
Otherwise, the password file is
|
|
searched for the login name, and the tilde expression is substituted with the
|
|
user's home directory.
|
|
If the login name is not found in the password file or
|
|
if any quoting or parameter substitution occurs in the login name, no
|
|
substitution is performed.
|
|
.Pp
|
|
In parameter assignments (those preceding a simple-command or those occurring
|
|
in the arguments of
|
|
.Ic alias ,
|
|
.Ic export ,
|
|
.Ic readonly
|
|
and
|
|
.Ic typeset ) ,
|
|
tilde expansion is done after any unquoted colon
|
|
.Pq Sq \&: ,
|
|
and login names are also delimited by colons.
|
|
.Pp
|
|
The home directory of previously expanded login names are cached and re-used.
|
|
The
|
|
.Ic alias -d
|
|
command may be used to list, change and add to this cache (e.g.,
|
|
.Ic alias -d fac=/usr/local/facilities; cd ~fac/bin ) .
|
|
.Ss File name patterns
|
|
A file name pattern is a word containing one or more unquoted
|
|
.Ql \&?
|
|
or
|
|
.Ql *
|
|
characters or
|
|
.Dq [..]
|
|
sequences.
|
|
Once brace expansion has been performed, the shell replaces file
|
|
name patterns with the sorted names of all the files that match the pattern
|
|
(if no files match, the word is left unchanged).
|
|
The pattern elements have the following meaning:
|
|
.Bl -tag -width Ds
|
|
.It Ic \&?
|
|
Matches any single character.
|
|
.It Ic \&*
|
|
Matches any sequence of characters.
|
|
.It Ic \&[ Ns .. Ns Ic \&]
|
|
Matches any of the characters inside the brackets.
|
|
Ranges of characters can be
|
|
specified by separating two characters by a
|
|
.Ql -
|
|
(e.g.,
|
|
.Dq [a0-9]
|
|
matches the letter
|
|
.Dq a
|
|
or any digit).
|
|
In order to represent itself, a
|
|
.Ql -
|
|
must either be quoted or the first or last character in the character list.
|
|
Similarly, a
|
|
.Ql \&]
|
|
must be quoted or the first character in the list if it is to represent itself
|
|
instead of the end of the list.
|
|
Also, a
|
|
.Ql \&!
|
|
appearing at the start of the list has special meaning (see below), so to
|
|
represent itself it must be quoted or appear later in the list.
|
|
.It Ic \&[\&! Ns .. Ns Ic \&]
|
|
Like
|
|
.Ic \&[ Ns .. Ns Ic \&] ,
|
|
except it matches any character not inside the brackets.
|
|
Matches any string of characters that matches zero or more occurrences of the
|
|
specified patterns.
|
|
Example: The pattern
|
|
.Ic \&*(foo\&|bar)
|
|
matches the strings
|
|
.Dq ,
|
|
.Dq foo ,
|
|
.Dq bar ,
|
|
.Dq foobarfoo ,
|
|
etc.
|
|
.Sm off
|
|
.It Xo Ic \&+( Ar pattern Ic \&| No \ ...\ \&
|
|
.Ic \&| Ar pattern Ic \&)
|
|
.Xc
|
|
.Sm on
|
|
Matches any string of characters that matches one or more occurrences of the
|
|
specified patterns.
|
|
Example: The pattern
|
|
.Ic \&+(foo\&|bar)
|
|
matches the strings
|
|
.Dq foo ,
|
|
.Dq bar ,
|
|
.Dq foobar ,
|
|
etc.
|
|
.Sm off
|
|
.It Xo Ic \&?( Ar pattern Ic \&| No \ ...\ \&
|
|
.Ic \&| Ar pattern Ic \&)
|
|
.Xc
|
|
.Sm on
|
|
Matches the empty string or a string that matches one of the specified
|
|
patterns.
|
|
Example: The pattern
|
|
.Ic \&?(foo\&|bar)
|
|
only matches the strings
|
|
.Dq ,
|
|
.Dq foo
|
|
and
|
|
.Dq bar .
|
|
.Sm off
|
|
.It Xo Ic \&@( Ar pattern Ic \&| No \ ...\ \&
|
|
.Ic \&| Ar pattern Ic \&)
|
|
.Xc
|
|
.Sm on
|
|
Matches a string that matches one of the specified patterns.
|
|
Example: The pattern
|
|
.Ic \&@(foo\&|bar)
|
|
only matches the strings
|
|
.Dq foo
|
|
and
|
|
.Dq bar .
|
|
.Sm off
|
|
.It Xo Ic \&!( Ar pattern Ic \&| No \ ...\ \&
|
|
.Ic \&| Ar pattern Ic \&)
|
|
.Xc
|
|
.Sm on
|
|
Matches any string that does not match one of the specified patterns.
|
|
Examples: The pattern
|
|
.Ic \&!(foo\&|bar)
|
|
matches all strings except
|
|
.Dq foo
|
|
and
|
|
.Dq bar ;
|
|
the pattern
|
|
.Ic \&!(\&*)
|
|
matches no strings; the pattern
|
|
.Ic \&!(\&?)\&*
|
|
matches all strings (think about it).
|
|
.El
|
|
.Pp
|
|
Note that
|
|
.Nm
|
|
currently never matches
|
|
.Dq \&.
|
|
and
|
|
.Dq \&.\&. ,
|
|
but the original
|
|
.Xr ksh ,
|
|
Bourne
|
|
.Xr sh
|
|
and GNU
|
|
.Xr bash
|
|
do.
|
|
.Pp
|
|
Note that none of the above pattern elements match either a period
|
|
.Pq Sq \&.
|
|
at the start of a file name or a slash
|
|
.Pq Sq / ,
|
|
even if they are explicitly used in a
|
|
.Ic \&[ Ns .. Ns Ic \&]
|
|
sequence; also, the names
|
|
.Dq \&.
|
|
and
|
|
.Dq \&.\&.
|
|
are never matched, even by the pattern
|
|
.Dq \&.\&* .
|
|
.Pp
|
|
If the
|
|
.Ic markdirs
|
|
option is set, any directories that result from file name generation are marked
|
|
with a trailing
|
|
.Ql / .
|
|
.Pp
|
|
The
|
|
.Tn POSIX
|
|
character classes (i.e.,
|
|
.Ic \&[\&: Ns Ar class-name Ns Ic \&:\&]
|
|
inside a
|
|
.Ic \&[ Ns .. Ns Ic \&]
|
|
expression) are not yet implemented.
|
|
.Ss Input/output redirection
|
|
When a command is executed, its standard input, standard output and standard
|
|
error (file descriptors 0, 1 and 2, respectively) are normally inherited from
|
|
the shell.
|
|
Three exceptions to this are commands in pipelines, for which
|
|
standard input and/or standard output are those set up by the pipeline,
|
|
asynchronous commands created when job control is disabled, for which standard
|
|
input is initially set to be from
|
|
.Pa /dev/null ,
|
|
and commands for which any of the following redirections have been specified:
|
|
.Bl -tag -width Ds
|
|
.It Ic \&> Ar file
|
|
Standard output is redirected to
|
|
.Ar file .
|
|
If
|
|
.Ar file
|
|
does not exist, it is created; if it does exist, is a regular file and the
|
|
.Ic noclobber
|
|
option is set, an error occurs; otherwise, the file is truncated.
|
|
Note that this means the command
|
|
.Ic cmd < foo > foo
|
|
will open
|
|
.Ar foo
|
|
for reading and then truncate it when it opens it for writing, before
|
|
.Ar cmd
|
|
gets a chance to actually read
|
|
.Ar foo .
|
|
.It Ic \&>\&| Ar file
|
|
Same as
|
|
.Ic \&> ,
|
|
except the file is truncated, even if the
|
|
.Ic noclobber
|
|
option is set.
|
|
.It Ic \&>\&> Ar file
|
|
Same as
|
|
.Ic \&> ,
|
|
except if
|
|
.Ar file
|
|
exists it is appended to instead of being truncated.
|
|
Also, the file is opened
|
|
in append mode, so writes always go to the end of the file (see
|
|
.Xr open 2 ) .
|
|
.It Ic \&< Ar file
|
|
Standard input is redirected from
|
|
.Ar file ,
|
|
which is opened for reading.
|
|
.It Ic \&<\&> Ar file
|
|
Same as
|
|
.Ic \&< ,
|
|
except the file is opened for reading and writing.
|
|
.It Ic \&<\&< Ar marker
|
|
After reading the command line containing this kind of redirection (called a
|
|
.Dq here document ) ,
|
|
the shell copies lines from the command source into a temporary file until a
|
|
line matching
|
|
.Ar marker
|
|
is read.
|
|
When the command is executed, standard input is redirected from the
|
|
temporary file.
|
|
If
|
|
.Ar marker
|
|
contains no quoted characters, the contents of the temporary file are processed
|
|
as if enclosed in double quotes each time the command is executed, so
|
|
parameter, command and arithmetic substitutions are performed, along with
|
|
backslash
|
|
.Pq Sq \e
|
|
escapes for
|
|
.Ql $ ,
|
|
.Ql ` ,
|
|
.Ql \e
|
|
and
|
|
.Ql \enewline .
|
|
If multiple here documents are used on the same command line, they are saved in
|
|
order.
|
|
.It Ic \&<\&<\&- Ar marker
|
|
Same as
|
|
.Ic \&<\&< ,
|
|
except leading tabs are stripped from lines in the here document.
|
|
.It Ic \&<\&& Ar fd
|
|
Standard input is duplicated from file descriptor
|
|
.Ar fd .
|
|
.Ar fd
|
|
can be a single digit, indicating the number of an existing file descriptor;
|
|
the letter
|
|
.Ql p ,
|
|
indicating the file descriptor associated with the output of the current
|
|
co-process; or the character
|
|
.Ql - ,
|
|
indicating standard input is to be closed.
|
|
.It Ic \&>\&& Ar fd
|
|
Same as
|
|
.Ic \&<\&& ,
|
|
except the operation is done on standard output.
|
|
.El
|
|
.Pp
|
|
In any of the above redirections, the file descriptor that is redirected (i.e.,
|
|
standard input or standard output) can be explicitly given by preceding the
|
|
redirection with a single digit.
|
|
Parameter, command and arithmetic
|
|
substitutions, tilde substitutions and, if the shell is interactive,
|
|
file name generation are all performed on the
|
|
.Ar file ,
|
|
.Ar marker
|
|
and
|
|
.Ar fd
|
|
arguments of redirections.
|
|
Note, however, that the results of any file name
|
|
generation are only used if a single file is matched; if multiple files match,
|
|
the word with the expanded file name generation characters is used.
|
|
Note
|
|
that in restricted shells, redirections which can create files cannot be used.
|
|
.Pp
|
|
For simple-commands, redirections may appear anywhere in the command; for
|
|
compound-commands
|
|
.Po
|
|
.Ic if
|
|
statements, etc.
|
|
.Pc ,
|
|
any redirections must appear at the end.
|
|
Redirections are processed after
|
|
pipelines are created and in the order they are given, so
|
|
.Pp
|
|
.Dl Ic cat /foo/bar 2\*(Gt&1 \*(Gt /dev/null \&| cat -n
|
|
.Pp
|
|
will print an error with a line number prepended to it.
|
|
.Ss Arithmetic expressions
|
|
Integer arithmetic expressions can be used with the
|
|
.Ic let
|
|
command, inside
|
|
.Ic $(( Ns .. Ns Ic ))
|
|
expressions, inside array references (e.g.,
|
|
.Sm off
|
|
.Ar name Ic \&[ Ar expr Ic \&] ) ,
|
|
.Sm on
|
|
as numeric arguments to the
|
|
.Ic test
|
|
command and as the value of an assignment to an integer parameter.
|
|
.Pp
|
|
Expressions may contain alpha-numeric parameter identifiers, array references
|
|
and integer constants and may be combined with the following C operators
|
|
(listed and grouped in increasing order of precedence):
|
|
.Pp
|
|
Unary operators:
|
|
.Bl -item -offset indent -compact
|
|
.It
|
|
.Ic \&+ \&- \&! \&~ \&+\&+ \&-\&-
|
|
.El
|
|
.Pp
|
|
Binary operators:
|
|
.Bl -item -offset indent -compact
|
|
.It
|
|
.Ic \&,
|
|
.It
|
|
.Ic = \&*= /= %= \&+= \&-= \&<\&<=
|
|
.Ic \&>\&>= \&&= ^= \&|=
|
|
.It
|
|
.Ic \&|\&|
|
|
.It
|
|
.Ic \&&\&&
|
|
.It
|
|
.Ic \&|
|
|
.It
|
|
.Ic ^
|
|
.It
|
|
.Ic \&&
|
|
.It
|
|
.Ic == \&!=
|
|
.It
|
|
.Ic \&< \&<= \&>= \&>
|
|
.It
|
|
.Ic \&<\&< \&>\&>
|
|
.It
|
|
.Ic \&+ \&-
|
|
.It
|
|
.Ic \&* / %
|
|
.El
|
|
.Pp
|
|
Ternary operators:
|
|
.Bl -item -offset indent -compact
|
|
.It
|
|
.Ic \&?\&:
|
|
(precedence is immediately higher than assignment)
|
|
.El
|
|
.Pp
|
|
Grouping operators:
|
|
.Bl -item -offset indent -compact
|
|
.It
|
|
.Ic \&( \&)
|
|
.El
|
|
.Pp
|
|
Integer constants may be specified with arbitrary bases using the notation
|
|
.Ar base Ns Ic \&# Ns Ar number ,
|
|
where
|
|
.Ar base
|
|
is a decimal integer specifying the base and
|
|
.Ar number
|
|
is a number in the specified base.
|
|
.Pp
|
|
The operators are evaluated as follows:
|
|
.Bl -tag -width Ds -offset indent
|
|
.It unary Ic \&+
|
|
Result is the argument (included for completeness).
|
|
.It unary Ic \&-
|
|
Negation.
|
|
.It Ic \&!
|
|
Logical
|
|
.Tn NOT ;
|
|
the result is 1 if argument is zero, 0 if not.
|
|
.It Ic \&~
|
|
Arithmetic (bit-wise)
|
|
.Tn NOT .
|
|
.It Ic \&+\&+
|
|
Increment; must be applied to a parameter (not a literal or other expression).
|
|
The parameter is incremented by 1.
|
|
When used as a prefix operator, the result
|
|
is the incremented value of the parameter; when used as a postfix operator, the
|
|
result is the original value of the parameter.
|
|
.It Ic \&-\&-
|
|
Similar to
|
|
.Ic \&+\&+ ,
|
|
except the parameter is decremented by 1.
|
|
.It Ic \&,
|
|
Separates two arithmetic expressions; the left-hand side is evaluated first,
|
|
then the right.
|
|
The result is the value of the expression on the right-hand side.
|
|
.It Ic =
|
|
Assignment; variable on the left is set to the value on the right.
|
|
.It Xo Ic \&*= /= \&+= \&-= \&<\&<=
|
|
.Ic \&>\&>= \&&= ^= \&|=
|
|
.Xc
|
|
Assignment operators.
|
|
.Ao Ar var Ac
|
|
.Ao Ar op Ac =
|
|
.Ao Ar expr Ac
|
|
is the same as
|
|
.Ao Ar var Ac =
|
|
.Ao Ar var Ac
|
|
.Ao Ar op Ac
|
|
.Ic \&(
|
|
.Ao Ar expr Ac
|
|
.Ic \&) .
|
|
.It Ic \&|\&|
|
|
Logical
|
|
.Tn OR ;
|
|
the result is 1 if either argument is non-zero, 0 if not.
|
|
The right argument is evaluated only if the left argument is zero.
|
|
.It Ic \&&\&&
|
|
Logical
|
|
.Tn AND ;
|
|
the result is 1 if both arguments are non-zero, 0 if not.
|
|
The right argument is evaluated only if the left argument is non-zero.
|
|
.It Ic \&|
|
|
Arithmetic (bit-wise)
|
|
.Tn OR .
|
|
.It Ic ^
|
|
Arithmetic (bit-wise)
|
|
.Tn XOR
|
|
(exclusive-OR).
|
|
.It Ic \&&
|
|
Arithmetic (bit-wise)
|
|
.Tn AND .
|
|
.It Ic ==
|
|
Equal; the result is 1 if both arguments are equal, 0 if not.
|
|
.It Ic \&!=
|
|
Not equal; the result is 0 if both arguments are equal, 1 if not.
|
|
.It Ic \&<
|
|
Less than; the result is 1 if the left argument is less than the right, 0 if
|
|
not.
|
|
.It Ic \&<= \&>= \&>
|
|
Less than or equal, greater than or equal, greater than.
|
|
See
|
|
.Ic \&< .
|
|
.It Ic \&<\&< \&>\&>
|
|
Shift left (right); the result is the left argument with its bits shifted left
|
|
(right) by the amount given in the right argument.
|
|
.It Ic \&+ \&- \&* /
|
|
Addition, subtraction, multiplication and division.
|
|
.It Ic %
|
|
Remainder; the result is the remainder of the division of the left argument by
|
|
the right.
|
|
The sign of the result is unspecified if either argument is negative.
|
|
.It Xo Ao Ar arg1 Ac Ic \ \&?
|
|
.Ao Ar arg2 Ac Ic \ \&: Ao Ar arg3 Ac
|
|
.Xc
|
|
.No If Ao Ar arg1 Ac
|
|
is non-zero, the result is
|
|
.Ao Ar arg2 Ac ,
|
|
otherwise
|
|
.Ao Ar arg3 Ac .
|
|
.El
|
|
.Ss Functions
|
|
Functions are defined using either Korn shell
|
|
.Ic function Ar name
|
|
syntax or the Bourne/POSIX shell
|
|
.Fn name
|
|
syntax (see below for the difference between the two forms).
|
|
Functions are like
|
|
.Li .-scripts
|
|
in that they are executed in the current environment.
|
|
However, unlike
|
|
.Li .-scripts ,
|
|
shell arguments (i.e., positional parameters
|
|
.Ic $1 , $2 ,
|
|
etc.) are never visible inside them.
|
|
When the shell is determining the location of a command, functions
|
|
are searched after special built-in commands, before regular and
|
|
non-regular built-ins and before the
|
|
.Ev PATH
|
|
is searched.
|
|
.Pp
|
|
An existing function may be deleted using
|
|
.Ic unset Fl f Ar function-name .
|
|
A list of functions can be obtained using
|
|
.Ic typeset \&+f
|
|
and the function definitions can be listed using
|
|
.Ic typeset \&-f .
|
|
The
|
|
.Ic autoload
|
|
command (which is an alias for
|
|
.Ic typeset \&-fu )
|
|
may be used to create undefined functions; when an undefined function is
|
|
executed, the shell searches the path specified in the
|
|
.Ev FPATH
|
|
parameter for a file with the same name as the function, which, if found, is
|
|
read and executed.
|
|
If after executing the file the named function is found to
|
|
be defined, the function is executed; otherwise, the normal command search is
|
|
continued (i.e., the shell searches the regular built-in command table and
|
|
.Ev PATH ) .
|
|
Note that if a command is not found using
|
|
.Ev PATH ,
|
|
an attempt is made to autoload a function using
|
|
.Ev FPATH
|
|
(this is an undocumented feature of the original Korn shell).
|
|
.Pp
|
|
Functions can have two attributes,
|
|
.Dq trace
|
|
and
|
|
.Dq export ,
|
|
which can be set with
|
|
.Ic typeset \&-ft
|
|
and
|
|
.Ic typeset \&-fx ,
|
|
respectively.
|
|
When a traced function is executed, the shell's
|
|
.Ic xtrace
|
|
option is turned on for the function's duration; otherwise, the
|
|
.Ic xtrace
|
|
option is turned off.
|
|
The
|
|
.Dq export
|
|
attribute of functions is currently not used.
|
|
In the original Korn shell,
|
|
exported functions are visible to shell scripts that are executed.
|
|
.Pp
|
|
Since functions are executed in the current shell environment, parameter
|
|
assignments made inside functions are visible after the function completes.
|
|
If this is not the desired effect, the
|
|
.Ic typeset
|
|
command can be used inside a function to create a local parameter.
|
|
Note that special parameters (e.g.
|
|
.Ic \&$$ , $\&! )
|
|
can't be scoped in this way.
|
|
.Pp
|
|
The exit status of a function is that of the last command executed in the
|
|
function.
|
|
A function can be made to finish immediately using the
|
|
.Ic return
|
|
command; this may also be used to explicitly specify the exit status.
|
|
.Pp
|
|
Functions defined with the
|
|
.Ic function
|
|
reserved word are treated differently in the following ways from functions
|
|
defined with the
|
|
.Ic \&(\&)
|
|
notation:
|
|
.Bl -bullet
|
|
.It
|
|
The
|
|
.Ic $0
|
|
parameter is set to the name of the function (Bourne-style functions leave
|
|
.Ic $0
|
|
untouched).
|
|
.It
|
|
Parameter assignments preceding function calls are not kept in the shell
|
|
environment (executing Bourne-style functions will keep assignments).
|
|
.It
|
|
.Ev OPTIND
|
|
is saved/reset and restored on entry and exit from the function so
|
|
.Ic getopts
|
|
can be used properly both inside and outside the function (Bourne-style
|
|
functions leave
|
|
.Dv OPTIND
|
|
untouched, so using
|
|
.Ic getopts
|
|
inside a function interferes with using
|
|
.Ic getopts
|
|
outside the function).
|
|
In the future, the following differences will also be added:
|
|
.Bl -bullet -offset indent
|
|
.It
|
|
A separate trap/signal environment will be used during the execution of
|
|
functions.
|
|
This will mean that traps set inside a function will not affect the
|
|
shell's traps and signals that are not ignored in the shell (but may be
|
|
trapped) will have their default effect in a function.
|
|
.It
|
|
The EXIT trap, if set in a function, will be executed after the function
|
|
returns.
|
|
.El
|
|
.El
|
|
.Ss POSIX mode
|
|
The shell is intended to be
|
|
.Tn POSIX
|
|
compliant; however, in some cases,
|
|
.Tn POSIX
|
|
behaviour is contrary either to the original Korn shell behaviour or to user
|
|
convenience.
|
|
How the shell behaves in these cases is determined by the state of the
|
|
.Ic posix
|
|
option
|
|
.Pq Ic set Fl o Ic posix .
|
|
If it is on, the
|
|
.Tn POSIX
|
|
behaviour is followed; otherwise, it is not.
|
|
The
|
|
.Ic posix
|
|
option is set automatically when the shell starts up if the environment
|
|
contains the
|
|
.Dv POSIXLY_CORRECT
|
|
parameter.
|
|
.Pp
|
|
The following is a list of things that are affected by the state of the
|
|
.Ic posix
|
|
option:
|
|
.Bl -bullet
|
|
Reading of
|
|
.Ev $ENV .
|
|
If not in
|
|
.Ic posix
|
|
mode, the
|
|
.Ev ENV
|
|
parameter is not expanded and included when the shell starts.
|
|
.It
|
|
Occurrences of
|
|
.Ic \e\&"
|
|
inside double quoted
|
|
.Ic `\&.\&.`
|
|
command substitutions.
|
|
In
|
|
.Tn POSIX
|
|
mode, the
|
|
.Ic \e\&"
|
|
is interpreted when the command is interpreted; in
|
|
.Pf non- Tn POSIX
|
|
mode, the
|
|
backslash is stripped before the command substitution is interpreted.
|
|
For example,
|
|
.Ic echo \&"`echo \e\&"hi\e\&"`\&"
|
|
produces
|
|
.Dq \&"hi\&"
|
|
in
|
|
.Tn POSIX
|
|
mode,
|
|
.Dq hi
|
|
in
|
|
.Pf non- Tn POSIX
|
|
mode.
|
|
To avoid problems, use the
|
|
.Ic $(...)\&
|
|
form of command substitution.
|
|
.It
|
|
.Ic kill -l
|
|
output.
|
|
In
|
|
.Tn POSIX
|
|
mode, signal names are listed one per line; in
|
|
.Pf non- Tn POSIX
|
|
mode,
|
|
signal numbers, names and descriptions are printed in columns.
|
|
In the future, a new option
|
|
.Pq Fl v No perhaps
|
|
will be added to distinguish the two behaviours.
|
|
.It
|
|
.Ic fg
|
|
exit status.
|
|
In
|
|
.Tn POSIX
|
|
mode, the exit status is 0 if no errors occur; in
|
|
.Pf non- Tn POSIX
|
|
mode, the exit status is that of the last foregrounded job.
|
|
.It
|
|
.Ic getopts .
|
|
In
|
|
.Tn POSIX
|
|
mode, options must start with a
|
|
.Ql - ;
|
|
in
|
|
.Pf non- Tn POSIX
|
|
mode, options can start with either
|
|
.Ql -
|
|
or
|
|
.Ql + .
|
|
.It
|
|
Brace expansion (also known as alternation).
|
|
In
|
|
.Tn POSIX
|
|
mode, brace expansion is
|
|
disabled; in
|
|
.Pf non- Tn POSIX
|
|
mode, brace expansion is enabled.
|
|
Note that
|
|
.Ic set Fl o Ic posix
|
|
(or setting the
|
|
.Ev POSIXLY_CORRECT
|
|
parameter) automatically turns the
|
|
.Ic braceexpand
|
|
option off; however, it can be explicitly turned on later.
|
|
.It
|
|
.Ic set \&- .
|
|
In
|
|
.Tn POSIX
|
|
mode, this does not clear the
|
|
.Ic verbose
|
|
or
|
|
.Ic xtrace
|
|
options; in
|
|
.Pf non- Tn POSIX
|
|
mode, it does.
|
|
.It
|
|
.Ic set
|
|
exit status.
|
|
In
|
|
.Tn POSIX
|
|
mode, the exit status of
|
|
.Ic set
|
|
is 0 if there are no errors; in
|
|
.Pf non- Tn POSIX
|
|
mode, the exit status is that of any
|
|
command substitutions performed in generating the
|
|
.Ic set
|
|
command.
|
|
For example,
|
|
.Ic set \&-\&- `false`; echo $?\&
|
|
prints 0 in
|
|
.Tn POSIX
|
|
mode, 1 in
|
|
.Pf non- Tn POSIX
|
|
mode.
|
|
This construct is used in most shell scripts that use the old
|
|
.Xr getopt 1
|
|
command.
|
|
.It
|
|
Argument expansion of the
|
|
.Ic alias ,
|
|
.Ic export ,
|
|
.Ic readonly
|
|
and
|
|
.Ic typeset
|
|
commands.
|
|
In
|
|
.Tn POSIX
|
|
mode, normal argument expansion is done; in
|
|
.Pf non- Tn POSIX
|
|
mode,
|
|
field splitting, file globbing, brace expansion and (normal) tilde expansion
|
|
are turned off, while assignment tilde expansion is turned on.
|
|
.It
|
|
Signal specification.
|
|
In
|
|
.Tn POSIX
|
|
mode, signals can be specified as digits, only
|
|
if signal numbers match
|
|
.Tn POSIX
|
|
values (i.e., HUP=1, INT=2, QUIT=3, ABRT=6,
|
|
KILL=9, ALRM=14 and TERM=15); in
|
|
.Pf non- Tn POSIX
|
|
mode, signals can always be digits.
|
|
.It
|
|
Alias expansion.
|
|
In
|
|
.Tn POSIX
|
|
mode, alias expansion is only carried out when
|
|
reading command words; in
|
|
.Pf non- Tn POSIX
|
|
mode, alias expansion is carried out on any
|
|
word following an alias that ended in a space.
|
|
For example, the following
|
|
.Ic for
|
|
loop
|
|
.Pp
|
|
.Bl -item -offset indent -compact
|
|
.It
|
|
.Ic alias a='for ' i='j'
|
|
.It
|
|
.Xo
|
|
.Ic a i in 1 2; do echo i=$i j=$j;
|
|
.Ic done
|
|
.Xc
|
|
.El
|
|
.Pp
|
|
uses parameter
|
|
.Ic i
|
|
in
|
|
.Tn POSIX
|
|
mode,
|
|
.Ic j
|
|
in
|
|
.Pf non- Tn POSIX
|
|
mode.
|
|
.It
|
|
Test.
|
|
In
|
|
.Tn POSIX
|
|
mode, the expression
|
|
.Sq Fl t
|
|
(preceded by some number of
|
|
.Sq Ic \&!
|
|
arguments) is always true as it is a non-zero length string; in
|
|
.Pf non- Tn POSIX
|
|
mode, it tests if file descriptor 1 is a
|
|
.Xr tty 4
|
|
(i.e., the
|
|
.Ar fd
|
|
argument to the
|
|
.Fl t
|
|
test may be left out and defaults to 1).
|
|
.El
|
|
.Ss Strict Bourne shell mode
|
|
When the
|
|
.Ic sh
|
|
option is enabled (see the
|
|
.Ic set
|
|
command),
|
|
.Nm
|
|
will behave like
|
|
.Xr sh 1
|
|
in the following ways:
|
|
.Bl -bullet
|
|
.It
|
|
The parameter
|
|
.Ic $_
|
|
is not set to
|
|
.Bl -dash
|
|
.It
|
|
the expanded alias' full program path after entering commands
|
|
that are tracked aliases
|
|
.It
|
|
the last argument on the command line after entering external
|
|
commands
|
|
.El
|
|
.It
|
|
File descriptors are left untouched when executing
|
|
.Ic exec
|
|
with no arguments.
|
|
.It
|
|
Backslash-escaped special characters are not substituted in
|
|
.Ev PS1 .
|
|
.It
|
|
Sequences of
|
|
.Sq Li (( Ns Ar ... Ns Li ))
|
|
are not interpreted as arithmetic expressions.
|
|
.El
|
|
.Ss Command execution
|
|
After evaluation of command-line arguments, redirections and parameter
|
|
assignments, the type of command is determined: a special built-in, a
|
|
function, a regular built-in or the name of a file to execute found using the
|
|
.Ev PATH
|
|
parameter.
|
|
The checks are made in the above order.
|
|
Special built-in commands differ from other commands in that the
|
|
.Ev PATH
|
|
parameter is not used to find them, and an error during their execution can
|
|
cause a non-interactive shell to exit and parameter assignments that are
|
|
specified before the command are kept after the command completes.
|
|
Just to confuse things, if the
|
|
.Ic posix
|
|
option is turned off (see the
|
|
.Ic set
|
|
command below), some special commands are very special in that no field
|
|
splitting, file globbing, brace expansion, nor tilde expansion is performed
|
|
on arguments that look like assignments.
|
|
Regular built-in commands are different only in that the
|
|
.Ev PATH
|
|
parameter is not used to find them.
|
|
.Pp
|
|
The original
|
|
.Nm ksh
|
|
and
|
|
.Tn POSIX
|
|
differ somewhat in which commands are considered
|
|
special or regular:
|
|
.Pp
|
|
.Tn POSIX
|
|
special commands
|
|
.Pp
|
|
.Ic \&. , \&: , break , continue ,
|
|
.Ic eval , exec , exit , export ,
|
|
.Ic readonly , return , set , shift ,
|
|
.Ic trap , unset
|
|
.Pp
|
|
Additional
|
|
.Nm
|
|
special commands
|
|
.Pp
|
|
.Ic builtin , times , typeset
|
|
.Pp
|
|
Very special commands
|
|
.Pq Pf non- Tn POSIX
|
|
.Pp
|
|
.Ic alias , readonly , set , typeset
|
|
.Pp
|
|
.Tn POSIX
|
|
regular commands
|
|
.Pp
|
|
.Ic alias , bg , cd , command ,
|
|
.Ic false , fc , fg , getopts ,
|
|
.Ic jobs , kill , read , true ,
|
|
.Ic umask , unalias , wait
|
|
.Pp
|
|
Additional
|
|
.Nm
|
|
regular commands
|
|
.Pp
|
|
.Ic \&[ , echo , let , print ,
|
|
.Ic pwd , test , ulimit , whence
|
|
.Pp
|
|
In the future, the additional
|
|
.Nm
|
|
special and regular commands may be treated
|
|
differently from the
|
|
.Tn POSIX
|
|
special and regular commands.
|
|
.Pp
|
|
Once the type of the command has been determined, any command-line parameter
|
|
assignments are performed and exported for the duration of the command.
|
|
.Pp
|
|
The following describes the special and regular built-in commands:
|
|
.Bl -tag -width Ds
|
|
.It Ic \&. Ar file Op Ar arg1 ...
|
|
Execute the commands in
|
|
.Ar file
|
|
in the current environment.
|
|
The file is searched for in the directories of
|
|
.Ev PATH .
|
|
If arguments are given, the positional parameters may be used to access them
|
|
while
|
|
.Ar file
|
|
is being executed.
|
|
If no arguments are given, the positional parameters are
|
|
those of the environment the command is used in.
|
|
.It Ic \&: Op Ar ...
|
|
The null command.
|
|
Exit status is set to zero.
|
|
.It Xo Ic alias
|
|
.Op Fl d | Ic +-t Op Fl r
|
|
.Op Ic +-px
|
|
.Op Ic +-
|
|
.Oo Ar name
|
|
.Op Ns = Ns Ar value
|
|
.Ar ... Oc
|
|
.Xc
|
|
Without arguments,
|
|
.Ic alias
|
|
lists all aliases.
|
|
For any name without a value, the existing alias is listed.
|
|
Any name with a value defines an alias (see
|
|
.Sx Aliases
|
|
above).
|
|
.Pp
|
|
When listing aliases, one of two formats is used.
|
|
Normally, aliases are listed as
|
|
.Ar name Ns = Ns Ar value ,
|
|
where
|
|
.Ar value
|
|
is quoted.
|
|
If options were preceded with
|
|
.Ql +
|
|
or a lone
|
|
.Ql +
|
|
is given on the command line, only
|
|
.Ar name
|
|
is printed.
|
|
In addition, if the
|
|
.Fl p
|
|
option is used, each alias is prefixed with the string
|
|
.Dq alias\ \& .
|
|
.Pp
|
|
The
|
|
.Fl x
|
|
option sets
|
|
.Po Ic \&+x
|
|
\ clears
|
|
.Pc
|
|
the export attribute of an alias or, if no names are given, lists the aliases
|
|
with the export attribute (exporting an alias has no effect).
|
|
.Pp
|
|
The
|
|
.Fl t
|
|
option indicates that tracked aliases are to be listed/set (values specified on
|
|
the command line are ignored for tracked aliases).
|
|
The
|
|
.Fl r
|
|
option indicates that all tracked aliases are to be reset.
|
|
.Pp
|
|
The
|
|
.Fl d
|
|
option causes directory aliases, which are used in tilde expansion, to be
|
|
listed or set (see
|
|
.Sx Tilde expansion
|
|
above).
|
|
.It Ic bg Op Ar job ...
|
|
Resume the specified stopped job(s) in the background.
|
|
If no jobs are specified,
|
|
.Ic %\&+
|
|
is assumed.
|
|
This command is only available on systems which support job control (see
|
|
.Sx Job control
|
|
below for more information).
|
|
.It Ic break Op Ar level
|
|
Exit the
|
|
.Ar level Ns th
|
|
inner-most
|
|
.Ic for ,
|
|
.Ic until
|
|
or
|
|
.Ic while
|
|
loop.
|
|
.Ar level
|
|
defaults to 1.
|
|
.It Ic builtin Ar command Op Ar arg1 ...
|
|
Execute the built-in command
|
|
.Ar command .
|
|
.It Xo Ic cd Op Fl LP
|
|
.Op Ar dir
|
|
.Xc
|
|
Set the working directory to
|
|
.Ar dir .
|
|
If the parameter
|
|
.Ev CDPATH
|
|
is set, it lists the search path for the directory containing
|
|
.Ar dir .
|
|
A
|
|
.Dv NULL
|
|
path means the current directory.
|
|
If
|
|
.Ar dir
|
|
is found in any component of the
|
|
.Ev CDPATH
|
|
search path other than the
|
|
.Dv NULL
|
|
path, the name of the new working directory will be written to standard output.
|
|
If
|
|
.Ar dir
|
|
is missing, the home directory
|
|
.Ev HOME
|
|
is used.
|
|
If
|
|
.Ar dir
|
|
is
|
|
.Ql - ,
|
|
the previous working directory is used (see
|
|
.Ev OLDPWD
|
|
parameter).
|
|
If the
|
|
.Fl L
|
|
option (logical path) is used or if the
|
|
.Ic physical
|
|
option (see the
|
|
.Ic set
|
|
command below) isn't set, references to
|
|
.Dq \&.\&.
|
|
in
|
|
.Ar dir
|
|
are relative to the path used to get to the directory.
|
|
If the
|
|
.Fl P
|
|
option (physical path) is used or if the
|
|
.Ic physical
|
|
option is set,
|
|
.Dq \&.\&.
|
|
is relative to the filesystem directory tree.
|
|
The
|
|
.Ev PWD
|
|
and
|
|
.Ev OLDPWD
|
|
parameters are updated to reflect the current and old working directory,
|
|
respectively.
|
|
.It Xo Ic cd Op Fl LP
|
|
.Ar old new
|
|
.Xc
|
|
The string
|
|
.Ar new
|
|
is substituted for
|
|
.Ar old
|
|
in the current directory, and the shell attempts to change to the new
|
|
directory.
|
|
.It Xo Ic command Op Fl p
|
|
.Ar cmd Op Ar arg1 ...
|
|
.Xc
|
|
.Ar cmd
|
|
is executed exactly as if
|
|
.Ic command
|
|
had not been specified, with two exceptions.
|
|
First,
|
|
.Ar cmd
|
|
cannot be a shell function, and second, special built-in commands lose their
|
|
specialness (i.e., redirection and utility errors do not cause the shell to
|
|
exit, and command assignments are not permanent).
|
|
If the
|
|
.Fl p
|
|
option is given, a default search path is used instead of the current value of
|
|
.Ev PATH
|
|
(the actual value of the default path is system dependent: on
|
|
.Tn POSIX Ns ish
|
|
systems, it is the value returned by
|
|
.Ic getconf CS_PATH ) .
|
|
.It Ic continue Op Ar level
|
|
Jumps to the beginning of the
|
|
.Ar level Ns th
|
|
inner-most
|
|
.Ic for ,
|
|
.Ic until
|
|
or
|
|
.Ic while
|
|
loop.
|
|
.Ar level
|
|
defaults to 1.
|
|
.It Xo Ic echo Op Fl neE
|
|
.Op Ar arg ...
|
|
.Xc
|
|
Prints its arguments (separated by spaces) followed by a newline, to the
|
|
standard output.
|
|
The newline is suppressed if any of the arguments contain the
|
|
backslash sequence
|
|
.Ql \ec .
|
|
See the
|
|
.Ic print
|
|
command below for a list of other backslash sequences that are recognized.
|
|
.Pp
|
|
The options are provided for compatibility with
|
|
.Bx
|
|
shell scripts.
|
|
The
|
|
.Fl n
|
|
option suppresses the trailing newline,
|
|
.Fl e
|
|
enables backslash interpretation (a no-op, since this is normally done), and
|
|
.Fl E
|
|
suppresses backslash interpretation.
|
|
.It Ic eval Ar command ...
|
|
The arguments are concatenated (with spaces between them) to form a single
|
|
string which the shell then parses and executes in the current environment.
|
|
.It Xo Ic exec
|
|
.Op Ar command Op Ar arg ...
|
|
.Xc
|
|
The command is executed without forking, replacing the shell process.
|
|
.Pp
|
|
If no command is given except for I/O redirection, the I/O redirection is
|
|
permanent and the shell is
|
|
not replaced.
|
|
Any file descriptors which are opened or
|
|
.Xr dup 2 Ns 'd
|
|
in this way are made available to other executed commands (note that the Korn
|
|
shell differs here: it does not pass on file descriptors greater than 2).
|
|
.It Ic exit Op Ar status
|
|
The shell exits with the specified exit status.
|
|
If
|
|
.Ar status
|
|
is not specified, the exit status is the current value of the
|
|
.Ic $\&?
|
|
parameter.
|
|
.It Xo Ic export Op Fl p
|
|
.Op Ar parameter Ns Op \&= Ns Ar value
|
|
.Xc
|
|
Sets the export attribute of the named parameters.
|
|
Exported parameters are passed in the environment to executed commands.
|
|
If values are specified, the named parameters are also assigned.
|
|
.Pp
|
|
If no parameters are specified, the names of all parameters with the export
|
|
attribute are printed one per line, unless the
|
|
.Fl p
|
|
option is used, in which case
|
|
.Ic export
|
|
commands defining all exported parameters, including their values, are printed.
|
|
.It Ic false
|
|
A command that exits with a non-zero status.
|
|
.It Xo Ic fc
|
|
.Oo Fl e No \&- \&| Fl s Oc
|
|
.Op Fl g
|
|
.Op Ar old Ns = Ns Ar new
|
|
.Op Ar prefix
|
|
.Xc
|
|
Re-execute the selected command (the previous command by default) after
|
|
performing the optional substitution of
|
|
.Ar old
|
|
with
|
|
.Ar new .
|
|
If
|
|
.Fl g
|
|
is specified, all occurrences of
|
|
.Ar old
|
|
are replaced with
|
|
.Ar new .
|
|
This command is usually accessed with the predefined
|
|
.Ic alias r='fc -e -' .
|
|
.It Ic fg Op Ar job ...
|
|
Resume the specified job(s) in the foreground.
|
|
If no jobs are specified,
|
|
.Ic %\&+
|
|
is assumed.
|
|
This command is only available on systems which support job control (see
|
|
.Sx Job control
|
|
below for more information).
|
|
.It Xo Ic getopts Ar optstring name
|
|
.Op Ar arg ...
|
|
.Xc
|
|
Used by shell procedures to parse the specified arguments (or positional
|
|
parameters, if no arguments are given) and to check for legal options.
|
|
.Ar optstring
|
|
contains the option letters that
|
|
.Ic getopts
|
|
is to recognize.
|
|
If a letter is followed by a colon, the option is expected to
|
|
have an argument.
|
|
Options that do not take arguments may be grouped in a single argument.
|
|
If an option takes an argument and the option character is not the
|
|
last character of the argument it is found in, the remainder of the argument is
|
|
taken to be the option's argument; otherwise, the next argument is the option's
|
|
argument.
|
|
.Pp
|
|
Each time
|
|
.Ic getopts
|
|
is invoked, it places the next option in the shell parameter
|
|
.Ar name
|
|
and the index of the next argument to be processed in the shell parameter
|
|
.Ev OPTIND .
|
|
If the option was introduced with a
|
|
.Ql + ,
|
|
the option placed in
|
|
.Ar name
|
|
is prefixed with a
|
|
.Ql + .
|
|
When an option requires an argument,
|
|
.Ic getopts
|
|
places it in the shell parameter
|
|
.Ev OPTARG .
|
|
When an illegal option or a missing option argument is encountered, a question
|
|
mark or a colon is placed in
|
|
.Ar name
|
|
(indicating an illegal option or missing argument, respectively) and
|
|
.Ev OPTARG
|
|
is set to the option character that caused the problem.
|
|
If
|
|
.Ar optstring
|
|
does not begin with a colon, a question mark is placed in
|
|
.Ar name ,
|
|
.Ev OPTARG
|
|
is unset and an error message is printed to standard error.
|
|
.Pp
|
|
When the end of the options is encountered,
|
|
.Ic getopts
|
|
exits with a non-zero exit status.
|
|
Options end at the first (non-option
|
|
argument) argument that does not start with a
|
|
.Ql -
|
|
or when a
|
|
.Ql --
|
|
argument is encountered.
|
|
.Pp
|
|
Option parsing can be reset by setting
|
|
.Ev OPTIND
|
|
to 1 (this is done automatically whenever the shell or a shell procedure is
|
|
invoked).
|
|
.Pp
|
|
Warning: Changing the value of the shell parameter
|
|
.Ev OPTIND
|
|
to a value other than 1 or parsing different sets of arguments without
|
|
resetting
|
|
.Ev OPTIND
|
|
may lead to unexpected results.
|
|
.It Xo Ic hash Op Fl r
|
|
.Op Ar name ...
|
|
.Xc
|
|
Without arguments, any hashed executable command pathnames are listed.
|
|
The
|
|
.Fl r
|
|
option causes all hashed commands to be removed from the hash table.
|
|
Each
|
|
.Ar name
|
|
is searched as if it were a command name and added to the hash table if it is
|
|
an executable command.
|
|
.It Xo Ic jobs Op Fl lpn
|
|
.Op Ar job ...
|
|
.Xc
|
|
Display information about the specified job(s); if no jobs are specified, all
|
|
jobs are displayed.
|
|
The
|
|
.Fl n
|
|
option causes information to be displayed only for jobs that have changed
|
|
state since the last notification.
|
|
If the
|
|
.Fl l
|
|
option is used, the process ID of each process in a job is also listed.
|
|
The
|
|
.Fl p
|
|
option causes only the process group of each job to be printed.
|
|
See
|
|
.Sx Job control
|
|
below for the format of
|
|
.Ar job
|
|
and the displayed job.
|
|
.It Xo Ic kill
|
|
.Oo Fl s Ar signame \*(Ba
|
|
.Fl Ar signum | Fl Ar signame Oc {
|
|
.Ar job |
|
|
.Ar pid |
|
|
.Ar pgrp No } Ar ...
|
|
.Xc
|
|
Send the specified signal to the specified jobs, process IDs or process
|
|
groups.
|
|
If no signal is specified, the
|
|
.Dv TERM
|
|
signal is sent.
|
|
If a job is specified, the signal is sent to the job's process group.
|
|
See
|
|
.Sx Job control
|
|
below for the format of
|
|
.Ar job .
|
|
.It Ic kill -l Op Ar exit-status ...
|
|
Print the name of the signal that killed a process which exited with the
|
|
specified
|
|
.Ar exit-status Ns es.
|
|
If no arguments are specified, a list of all the signals, their numbers and
|
|
a short description of them are printed.
|
|
.It Xo Ic print
|
|
.Oo Fl nprsu Ns Ar n \*(Ba
|
|
.Fl R Op Fl en Oc
|
|
.Op Ar argument ...
|
|
.Xc
|
|
.Ic print
|
|
prints its arguments on the standard output, separated by spaces and
|
|
terminated with a newline.
|
|
The
|
|
.Fl n
|
|
option suppresses the newline.
|
|
By default, certain C escapes are translated.
|
|
These include
|
|
.Ql \eb ,
|
|
.Ql \ef ,
|
|
.Ql \en ,
|
|
.Ql \er ,
|
|
.Ql \et ,
|
|
.Ql \ev
|
|
and
|
|
.Ql \e0###
|
|
.Po
|
|
.Ql #
|
|
is an octal digit, of which there may be 0 to 3
|
|
.Pc .
|
|
.Ql \ec
|
|
is equivalent to using the
|
|
.Fl n
|
|
option.
|
|
.Ql \e
|
|
expansion may be inhibited with the
|
|
.Fl r
|
|
option.
|
|
The
|
|
.Fl s
|
|
option prints to the history file instead of standard output, the
|
|
.Fl u
|
|
option prints to file descriptor
|
|
.Ar n
|
|
.Po
|
|
.Ar n
|
|
defaults to 1 if omitted
|
|
.Pc ,
|
|
and the
|
|
.Fl p
|
|
option prints to the co-process (see
|
|
.Sx Co-processes
|
|
above).
|
|
.Pp
|
|
The
|
|
.Fl R
|
|
option is used to emulate, to some degree, the
|
|
.Bx
|
|
.Xr echo 1
|
|
command, which does not process
|
|
.Ql \e
|
|
sequences unless the
|
|
.Fl e
|
|
option is given.
|
|
As above, the
|
|
.Fl n
|
|
option suppresses the trailing newline.
|
|
.It Ic pwd Op Fl LP
|
|
Print the present working directory.
|
|
If the
|
|
.Fl L
|
|
option is used or if the
|
|
.Ic physical
|
|
option (see the
|
|
.Ic set
|
|
command below) isn't set, the logical path is printed (i.e., the path used to
|
|
.Ic cd
|
|
to the current directory).
|
|
If the
|
|
.Fl P
|
|
option (physical path) is used or if the
|
|
.Ic physical
|
|
option is set, the path determined from the filesystem (by following
|
|
.Dq \&.\&.
|
|
directories to the root directory) is printed.
|
|
.It Xo Ic read Oo Fl prsu Ns Ar n
|
|
.Oc Op Ar parameter ...
|
|
.Xc
|
|
Reads a line of input from the standard input, separates the line into fields
|
|
using the
|
|
.Ev IFS
|
|
parameter (see
|
|
.Sx Substitution
|
|
above) and assigns each field to the specified parameters.
|
|
If there are more parameters than fields, the extra parameters are set to
|
|
.Dv NULL ,
|
|
or alternatively, if there are more fields than parameters, the last parameter
|
|
is assigned the remaining fields (inclusive of any separating spaces).
|
|
If no parameters are specified, the
|
|
.Ev REPLY
|
|
parameter is used.
|
|
If the input line ends in a backslash and the
|
|
.Fl r
|
|
option was not used, the backslash and the newline are stripped and more input
|
|
is read.
|
|
If no input is read,
|
|
.Ic read
|
|
exits with a non-zero status.
|
|
.Pp
|
|
The first parameter may have a question mark and a string appended to it, in
|
|
which case the string is used as a prompt (printed to standard error before
|
|
any input is read) if the input is a
|
|
.Xr tty 4
|
|
(e.g.,
|
|
.Ic read nfoo?'number of foos: ' ) .
|
|
.Pp
|
|
The
|
|
.Fl u Ns Ar n
|
|
and
|
|
.Fl p
|
|
options cause input to be read from file descriptor
|
|
.Ar n
|
|
or the current co-process (see
|
|
.Sx Co-processes
|
|
above for comments on this), respectively.
|
|
If the
|
|
.Fl s
|
|
option is used, input is saved to the history file.
|
|
.It Xo Ic readonly Op Fl p
|
|
.Oo Ar parameter
|
|
.Op Ns = Ns Ar value
|
|
.Ar ... Oc
|
|
.Xc
|
|
Sets the read-only attribute of the named parameters.
|
|
If values are given,
|
|
parameters are set to them before setting the attribute.
|
|
Once a parameter is
|
|
made read-only, it cannot be unset and its value cannot be changed.
|
|
.Pp
|
|
If no parameters are specified, the names of all parameters with the read-only
|
|
attribute are printed one per line, unless the
|
|
.Fl p
|
|
option is used, in which case
|
|
.Ic readonly
|
|
commands defining all read-only parameters, including their values, are
|
|
printed.
|
|
.It Ic return Op Ar status
|
|
Returns from a function or
|
|
.Ic \&.
|
|
script, with exit status
|
|
.Ar status .
|
|
If no
|
|
.Ar status
|
|
is given, the exit status of the last executed command is used.
|
|
If used outside of a function or
|
|
.Ic \&.
|
|
script, it has the same effect as
|
|
.Ic exit .
|
|
Note that
|
|
.Nm
|
|
treats both profile and
|
|
.Ev ENV
|
|
files as
|
|
.Ic \&.
|
|
scripts, while the original Korn shell only treats profiles as
|
|
.Ic \&.
|
|
scripts.
|
|
.It Xo Ic set Op Ic +-abCefhkmnpsuvxX
|
|
.Op Ic +-o Ar option
|
|
.Op Ic +-A Ar name
|
|
.Op Fl \&-
|
|
.Op Ar arg ...
|
|
.Xc
|
|
The
|
|
.Ic set
|
|
command can be used to set
|
|
.Pq Ic \&-
|
|
or clear
|
|
.Pq Ic \&+
|
|
shell options, set the positional parameters or set an array parameter.
|
|
Options can be changed using the
|
|
.Ic \&+ Ns Fl o Ar option
|
|
syntax, where
|
|
.Ar option
|
|
is the long name of an option, or using the
|
|
.Ic \&+\&- Ns Ar letter
|
|
syntax, where
|
|
.Ar letter
|
|
is the option's single letter name (not all options have a single letter name).
|
|
The following table lists both option letters (if they exist) and long names
|
|
along with a description of what the option does:
|
|
.Bl -tag -width 15n
|
|
.It Fl A
|
|
Sets the elements of the array parameter
|
|
.Ar name
|
|
to
|
|
.Ar arg ... .
|
|
If
|
|
.Fl A
|
|
is used, the array is reset (i.e., emptied) first; if
|
|
.Ic \&+A
|
|
is used, the first N elements are set (where N is the number of
|
|
.Ar arg Ns s ) ,
|
|
the rest are left untouched.
|
|
.It Fl a Ic allexport
|
|
All new parameters are created with the export attribute.
|
|
.It Fl b Ic notify
|
|
Print job notification messages asynchronously, instead of just before the
|
|
prompt.
|
|
Only used if job control is enabled
|
|
.Pq Fl m .
|
|
.It Fl C Ic noclobber
|
|
Prevent
|
|
.Ic \&>
|
|
redirection from overwriting existing files
|
|
.Po
|
|
.Ic \&>\&|
|
|
must be used to force an overwrite
|
|
.Pc .
|
|
.It Fl e Ic errexit
|
|
Exit (after executing the
|
|
.Dv ERR
|
|
trap) as soon as an error occurs or a command fails (i.e., exits with a
|
|
non-zero status).
|
|
This does not apply to commands whose exit status is
|
|
explicitly tested by a shell construct such as
|
|
.Ic if ,
|
|
.Ic until ,
|
|
.Ic while ,
|
|
.Ic \&&\&&
|
|
or
|
|
.Ic \&|\&|
|
|
statements.
|
|
.It Fl f Ic noglob
|
|
Do not expand file name patterns.
|
|
.It Fl h Ic trackall
|
|
Create tracked aliases for all executed commands (see
|
|
.Sx Aliases
|
|
above).
|
|
Enabled by default for non-interactive shells.
|
|
.It Fl i Ic interactive
|
|
Enable interactive mode.
|
|
This can only be set/unset when the shell is invoked.
|
|
.It Fl k Ic keyword
|
|
Parameter assignments are recognized anywhere in a command.
|
|
.It Fl l Ic login
|
|
The shell is a login shell.
|
|
This can only be set/unset when the shell is invoked (see
|
|
.Sx Shell startup
|
|
above).
|
|
.It Fl m Ic monitor
|
|
Enable job control (default for interactive shells).
|
|
.It Fl n lc noexec
|
|
Do not execute any commands.
|
|
Useful for checking the syntax of scripts
|
|
(ignored if interactive).
|
|
.It Fl p Ic privileged
|
|
Set automatically if, when the shell starts, the read UID or GID does not match
|
|
the effective UID (EUID) or GID (EGID), respectively.
|
|
See
|
|
.Sx Shell startup
|
|
above for a description of what this means.
|
|
.It Fl r Ic restricted
|
|
Enable restricted mode.
|
|
This option can only be used when the shell is invoked.
|
|
See
|
|
.Sx Shell startup
|
|
above for a description of what this means.
|
|
.It Fl s Ic stdin
|
|
If used where the shell is invoked, commands are read from standard input.
|
|
Set automatically if the shell is invoked with no arguments.
|
|
.Pp
|
|
When
|
|
.Fl s
|
|
is used with the
|
|
.Ic set
|
|
command it causes the specified arguments to be sorted before assigning them to
|
|
the positional parameters (or to array
|
|
.Ar name ,
|
|
if
|
|
.Fl A
|
|
is used).
|
|
.It Fl u Ic nounset
|
|
Referencing of an unset parameter is treated as an error, unless one of the
|
|
.Ql - ,
|
|
.Ql +
|
|
or
|
|
.Ql =
|
|
modifiers is used.
|
|
.It Fl v Ic verbose
|
|
Write shell input to standard error as it is read.
|
|
.It Fl x Ic xtrace
|
|
Print commands and parameter assignments when they are executed, preceded by
|
|
the value of
|
|
.Ev PS4 .
|
|
.It Fl X Ic markdirs
|
|
Mark directories with a trailing
|
|
.Ql /
|
|
during file name generation.
|
|
.It Ic bgnice
|
|
Background jobs are run with lower priority.
|
|
.It Ic ignoreeof
|
|
The shell will not (easily) exit when end-of-file is read;
|
|
.Ic exit
|
|
must be used.
|
|
.It Ic nohup
|
|
Do not kill running jobs with a
|
|
.Dv SIGHUP
|
|
signal when a login shell exists.
|
|
Currently set by default, but this will
|
|
change in the future to be compatible with the original Korn shell (which
|
|
doesn't have this option, but does send the
|
|
.Dv SIGHUP
|
|
signal).
|
|
.It Ic nolog
|
|
No effect.
|
|
In the original Korn shell, this prevents function definitions from
|
|
being stored in the history file.
|
|
.It Ic physical
|
|
Causes the
|
|
.Ic cd
|
|
and
|
|
.Ic pwd
|
|
commands to use
|
|
.Dq physical
|
|
(i.e., the filesystem's)
|
|
.Dq \&.\&.
|
|
directories instead of
|
|
.Dq logical
|
|
directories (i.e., the shell handles
|
|
.Dq \&.\&. ,
|
|
which allows the user to be oblivious of symbolic links to directories).
|
|
Clear by default.
|
|
Note that setting this option does not affect the current value of the
|
|
.Ev PWD
|
|
parameter; only the
|
|
.Ic cd
|
|
command changes
|
|
.Ev PWD .
|
|
See the
|
|
.Ic cd
|
|
and
|
|
.Ic pwd
|
|
commands above for more details.
|
|
.It Ic posix
|
|
Enable
|
|
.Tn POSIX
|
|
mode.
|
|
See
|
|
.Sx POSIX mode
|
|
above.
|
|
.It Ic sh
|
|
Enable strict Bourne shell mode (see
|
|
.Sx Strict Bourne shell mode ) .
|
|
.It Ic vi
|
|
Enable
|
|
.Xr vi 1 Ns -like
|
|
command-line editing (interactive shells only).
|
|
.It Ic viraw
|
|
No effect.
|
|
In the original Korn shell, unless
|
|
.Ic viraw
|
|
was set, the vi command-line mode would let the
|
|
.Xr tty 4
|
|
driver do the work until
|
|
.Tn ESC
|
|
(^[) was entered.
|
|
.Nm
|
|
is always in viraw mode.
|
|
.It Ic vi-esccomplete
|
|
In vi command-line editing, do command and file name completion when escape
|
|
(^[) is entered in command mode.
|
|
.It Ic vi-show8
|
|
Prefix characters with the eighth bit set with
|
|
.Dq M\&- .
|
|
If this option is not set, characters in the range 128\-160 are printed as is,
|
|
which may cause problems.
|
|
.It Ic vi-tabcomplete
|
|
In vi command-line editing, do command and file name completion when tab (^I)
|
|
is entered in insert mode.
|
|
.El
|
|
.Pp
|
|
These options can also be used upon invocation of the shell.
|
|
The current set of
|
|
options (with single letter names) can be found in the parameter
|
|
.Dv \&- .
|
|
.Ic set Fl o
|
|
with no option name will list all the options and whether each is on or off;
|
|
.Ic set +o
|
|
will print the long names of all options that are currently on.
|
|
.Pp
|
|
Remaining arguments, if any, are positional parameters and are assigned, in
|
|
order, to the positional parameters (i.e.
|
|
.Ic $1 , $2 ,
|
|
etc.).
|
|
If options end with
|
|
.Ql --
|
|
and there are no remaining arguments, all positional parameters are cleared.
|
|
If no options or arguments are given, the values of all names are printed.
|
|
For unknown historical reasons, a lone
|
|
.Ql -
|
|
option is treated specially \(em it clears both the
|
|
.Fl x
|
|
and
|
|
.Fl v
|
|
options.
|
|
.It Ic shift Op Ar number
|
|
The positional parameters
|
|
.Ar number Ns +1 ,
|
|
.Ar number Ns +2 ,
|
|
etc. are renamed to
|
|
.Dq 1 ,
|
|
.Dq 2 ,
|
|
etc.
|
|
.Ar number
|
|
defaults to 1.
|
|
.It Ic test Ar expression
|
|
.It Ic \&[ Ar expression Ic \&]
|
|
.Ic test
|
|
evaluates the
|
|
.Ar expression
|
|
and returns zero status if true, 1 if false, or greater than 1 if there
|
|
was an error.
|
|
It is normally used as the condition command of
|
|
.Ic if
|
|
and
|
|
.Ic while
|
|
statements.
|
|
The following basic expressions are available:
|
|
.Bl -tag -width 17n
|
|
.It Fl r Ar file
|
|
.Ar file
|
|
exists and is readable.
|
|
.It Fl w Ar file
|
|
.Ar file
|
|
exists and is writable.
|
|
.It Fl x Ar file
|
|
.Ar file
|
|
exists and is executable.
|
|
.It Fl a Ar file
|
|
.Ar file
|
|
exists.
|
|
.It Fl e Ar file
|
|
.Ar file
|
|
exists.
|
|
.It Fl f Ar file
|
|
.Ar file
|
|
is a regular file.
|
|
.It Fl d Ar file
|
|
.Ar file
|
|
is a directory.
|
|
.It Fl c Ar file
|
|
.Ar file
|
|
is a character special device.
|
|
.It Fl b Ar file
|
|
.Ar file
|
|
is a block special device.
|
|
.It Fl p Ar file
|
|
.Ar file
|
|
is a named pipe.
|
|
.It Fl u Ar file
|
|
.Ar file Ns 's
|
|
mode has setuid bit set.
|
|
.It Fl g Ar file
|
|
.Ar file Ns 's
|
|
mode has setgid bit set.
|
|
.It Fl k Ar file
|
|
.Ar file Ns 's
|
|
mode has sticky bit set.
|
|
.It Fl s Ar file
|
|
.Ar file
|
|
is not empty.
|
|
.It Fl O Ar file
|
|
.Ar file Ns 's
|
|
owner is the shell's effective user ID.
|
|
.It Fl G Ar file
|
|
.Ar file Ns 's
|
|
group is the shell's effective group ID.
|
|
.It Fl h Ar file
|
|
.Ar file
|
|
is a symbolic link.
|
|
.It Fl H Ar file
|
|
.Ar file
|
|
is a context dependent directory (only useful on HP-UX).
|
|
.It Fl L Ar file
|
|
.Ar file
|
|
is a symbolic link.
|
|
.It Fl S Ar file
|
|
.Ar file
|
|
is a socket.
|
|
.It Fl o Ar option
|
|
Shell
|
|
.Ar option
|
|
is set (see the
|
|
.Ic set
|
|
command above for a list of options).
|
|
As a non-standard extension, if the option starts with a
|
|
.Ql \&! ,
|
|
the test is negated; the test always fails if
|
|
.Ar option
|
|
doesn't exist (thus
|
|
.Ic \&[ -o Ar foo
|
|
.Ic -o -o \&! Ns Ar foo Ic \&]
|
|
returns true if and only if option
|
|
.Ar foo
|
|
exists).
|
|
.It Ar file1 Fl nt Ar file2
|
|
.Ar file1
|
|
is newer than
|
|
.Ar file2 .
|
|
.It Ar file1 Fl ot Ar file2
|
|
.Ar file1
|
|
is older than
|
|
.Ar file2 .
|
|
.It Ar file1 Fl ef Ar file2
|
|
.Ar file1
|
|
is the same file as
|
|
.Ar file2 .
|
|
.It Fl t Op Ar fd
|
|
File descriptor
|
|
.Ar fd
|
|
is a
|
|
.Xr tty 4
|
|
device.
|
|
If the
|
|
.Ic posix
|
|
option is not set,
|
|
.Ar fd
|
|
may be left out, in which case it is taken to be 1 (the behaviour differs due
|
|
to the special
|
|
.Tn POSIX
|
|
rules described below).
|
|
.It Ar string
|
|
.Ar string
|
|
is not empty (has non-zero length).
|
|
Note that there is the potential for problems if
|
|
.Ar string
|
|
turns out to be an operator (e.g.
|
|
.Fl r ) .
|
|
It is generally better to use a test like
|
|
.No ( Ns Nm sh )
|
|
.Bk -words
|
|
.Sm off
|
|
.Ic \&[\ X\&" Ar string Ic \&" Ic \ \&]
|
|
.Sm on
|
|
.Ek
|
|
instead (double quotes are used in case
|
|
.Ar string
|
|
contains spaces or globbing characters).
|
|
.It Fl z Ar string
|
|
.Ar string
|
|
is empty.
|
|
.It Fl n Ar string
|
|
.Ar string
|
|
is not empty.
|
|
.It Ar string No = Ar string
|
|
Strings are equal.
|
|
.It Ar string No \&!= Ar string
|
|
Strings are not equal.
|
|
.It Ar number Fl eq Ar number
|
|
Numbers compare equal.
|
|
.It Ar number Fl ne Ar number
|
|
Numbers compare not equal.
|
|
.It Ar number Fl ge Ar number
|
|
Numbers compare greater than or equal.
|
|
.It Ar number Fl gt Ar number
|
|
Numbers compare greater than.
|
|
.It Ar number Fl le Ar number
|
|
Numbers compare less than or equal.
|
|
.It Ar number Fl \< Ar number
|
|
Numbers compare less than.
|
|
.El
|
|
.Pp
|
|
The above basic expressions, in which unary operators have precedence over
|
|
binary operators, may be combined with the following operators (listed in
|
|
increasing order of precedence):
|
|
.Pp
|
|
.Bl -tag -width "expr -o expr" -compact
|
|
.It Ar expr Fl o Ar expr
|
|
Logical
|
|
.Tn OR .
|
|
.It Ar expr Fl a Ar expr
|
|
Logical
|
|
.Tn AND .
|
|
.It Ic \&! Ar expr
|
|
Logical
|
|
.Tn NOT .
|
|
.It Ic \&( Ar expr Ic \&)
|
|
Grouping.
|
|
.El
|
|
.Pp
|
|
On operating systems not supporting
|
|
.Pa /dev/fd/ Ns Ar n
|
|
devices (where
|
|
.Ar n
|
|
is a file descriptor number), the
|
|
.Ic test
|
|
command will attempt to fake it for all tests that operate on files (except the
|
|
.Fl e
|
|
test).
|
|
For example,
|
|
.Ic \&[ -w /dev/fd/2 \&]
|
|
tests if file descriptor 2 is writable.
|
|
.Pp
|
|
Note that some special rules are applied (courtesy of
|
|
.Tn POSIX )
|
|
if the number of
|
|
arguments to
|
|
.Ic test
|
|
or
|
|
.Ic \&[ ... \&]
|
|
is less than five; if leading
|
|
.Ql \&!
|
|
arguments can be stripped such that only one argument remains then a string
|
|
length test is performed (again, even if the argument is a unary operator); if
|
|
leading
|
|
.Ql \&!
|
|
arguments can be stripped such that three arguments remain and the second
|
|
argument is a binary operator, then the binary operation is performed (even
|
|
if the first argument is a unary operator, including an unstripped
|
|
.Ql \&! ) .
|
|
.Pp
|
|
.Sy Note:
|
|
A common mistake is to use
|
|
.Bk -words
|
|
.Ic if \&[ $foo = bar \&]
|
|
.Ek
|
|
which fails if parameter
|
|
.Ic foo
|
|
is
|
|
.Dv NULL
|
|
or unset, if it has embedded spaces (i.e.,
|
|
.Ev IFS
|
|
characters), or if it is a unary operator like
|
|
.Sq Ic \&!
|
|
or
|
|
.Sq Fl n .
|
|
Use tests like
|
|
.No ( Ns Nm sh )
|
|
.Bk -words
|
|
.Ic if \&[ \&"X$foo\&" = Xbar \&]
|
|
.Ek
|
|
instead.
|
|
.It Ic times
|
|
Print the accumulated user and system times used both by the shell
|
|
and by processes that the shell started which have exited.
|
|
The format of the output is:
|
|
.Bd -literal -offset indent
|
|
0m0.00s 0m0.00s
|
|
0m0.00s 0m0.00s
|
|
.Ed
|
|
.It Ic trap Op Ar handler signal ...
|
|
Sets a trap handler that is to be executed when any of the
|
|
specified signals are received.
|
|
.Ar handler
|
|
is either a
|
|
.Dv NULL
|
|
string, indicating the signals are to be ignored, a minus sign
|
|
.Pq Sq \&- ,
|
|
indicating that the default action is to be taken for the signals (see
|
|
.Xr signal 3 )
|
|
or a string containing shell commands to be evaluated and executed at the
|
|
first opportunity (i.e., when the current command completes or before
|
|
printing the next
|
|
.Ev PS1
|
|
prompt) after receipt of one of the signals.
|
|
.Ar signal
|
|
is the name of a signal (e.g.,
|
|
.Dv PIPE
|
|
or
|
|
.Dv ALRM )
|
|
or the number of the signal (see the
|
|
.Ic kill Fl l
|
|
command above).
|
|
There are two special signals:
|
|
.Dv EXIT
|
|
(also known as 0), which is executed when the shell is about to exit, and
|
|
.Dv ERR ,
|
|
which is executed after an error occurs (an error is something that would cause
|
|
the shell to exit if the
|
|
.Fl e
|
|
or
|
|
.Ic errexit
|
|
option were see \(em see the
|
|
.Ic set
|
|
command above).
|
|
.Dv EXIT
|
|
handlers are executed in the environment of the last executed command.
|
|
Note
|
|
that for non-interactive shells, the trap handler cannot be changed for signals
|
|
that were ignored when the shell started.
|
|
.Pp
|
|
With no arguments,
|
|
.Ic trap
|
|
lists, as a series of
|
|
.Ic trap
|
|
commands, the current state of the traps that have been set since the shell
|
|
started.
|
|
Note that the output of
|
|
.Ic trap
|
|
cannot be usefully piped to another process (an artifact of the fact that
|
|
traps are cleared when subprocesses are created).
|
|
.Pp
|
|
The original Korn shell's
|
|
.Dv DEBUG
|
|
trap and the handling of
|
|
.Dv ERR
|
|
and
|
|
.Dv EXIT
|
|
traps in functions are not yet implemented.
|
|
.It Ic true
|
|
A command that exits with a zero value.
|
|
.It Xo Ic typeset
|
|
.Oo Op Ic +-Ulprtux
|
|
.Op Fl L Ns Op Ar n
|
|
.Op Fl R Ns Op Ar n
|
|
.Op Fl Z Ns Op Ar n
|
|
.Op Fl i Ns Op Ar n
|
|
.No \&| Fl f Op Fl tux Oc
|
|
.Oo Ar name
|
|
.Op Ns = Ns Ar value
|
|
.Ar ... Oc
|
|
.Xc
|
|
Display or set parameter attributes.
|
|
With no
|
|
.Ar name
|
|
arguments, parameter attributes are displayed; if no options are used, the
|
|
current attributes of all parameters are printed as
|
|
.Ic typeset
|
|
commands; if an option is given (or
|
|
.Ql -
|
|
with no option letter), all parameters and their values with the specified
|
|
attributes are printed; if options are introduced with
|
|
.Ql + ,
|
|
parameter values are not printed.
|
|
.Pp
|
|
If
|
|
.Ar name
|
|
arguments are given, the attributes of the named parameters are set
|
|
.Pq Ic \&-
|
|
or cleared
|
|
.Pq Ic \&+ .
|
|
Values for parameters may optionally be specified.
|
|
If
|
|
.Ic typeset
|
|
is used inside a function, any newly created parameters are local to the
|
|
function.
|
|
.Pp
|
|
When
|
|
.Fl f
|
|
is used,
|
|
.Ic typeset
|
|
operates on the attributes of functions.
|
|
As with parameters, if no
|
|
.Ar name Ns s
|
|
are given, functions are listed with their values (i.e., definitions) unless
|
|
options are introduced with
|
|
.Ql + ,
|
|
in which case only the function names are reported.
|
|
.Bl -tag -width 3n
|
|
.It Fl L Ns Ar n
|
|
Left justify attribute.
|
|
.Ar n
|
|
specifies the field width.
|
|
If
|
|
.Ar n
|
|
is not specified, the current width of a parameter (or the width of its first
|
|
assigned value) is used.
|
|
Leading whitespace (and zeros, if used with the
|
|
.Fl Z
|
|
option) is stripped.
|
|
If necessary, values are either truncated or space padded
|
|
to fit the field width.
|
|
.It Fl R Ns Ar n
|
|
Right justify attribute.
|
|
.Ar n
|
|
specifies the field width.
|
|
If
|
|
.Ar n
|
|
is not specified, the current width of a parameter (or the width of its first
|
|
assigned value) is used.
|
|
Trailing whitespace is stripped.
|
|
If necessary, values are either stripped of leading characters or space
|
|
padded to make them fit the field width.
|
|
.It Fl Z Ns Ar n
|
|
Zero fill attribute.
|
|
If not combined with
|
|
.Fl L ,
|
|
this is the same as
|
|
.Fl R ,
|
|
except zero padding is used instead of space padding.
|
|
.It Fl i Ns Ar n
|
|
Integer attribute.
|
|
.Ar n
|
|
specifies the base to use when displaying the integer (if not specified, the
|
|
base given in the first assignment is used).
|
|
Parameters with this attribute may
|
|
be assigned values containing arithmetic expressions.
|
|
.It Fl U
|
|
Unsigned integer attribute.
|
|
Integers are printed as unsigned values (only
|
|
useful when combined with the
|
|
.Fl i
|
|
option).
|
|
This option is not in the original Korn shell.
|
|
.It Fl f
|
|
Function mode.
|
|
Display or set functions and their attributes, instead of parameters.
|
|
.It Fl l
|
|
Lower case attribute.
|
|
All upper case characters in values are converted to lower case.
|
|
(In the original Korn shell, this parameter meant
|
|
.Dq long integer
|
|
when used with the
|
|
.Fl i
|
|
option.)
|
|
.It Fl p
|
|
Print complete
|
|
.Ic typeset
|
|
commands that can be used to re-create the attributes (but not the values) of
|
|
parameters.
|
|
This is the default action (option exists for ksh93 compatibility).
|
|
.It Fl r
|
|
Read-only attribute.
|
|
Parameters with this attribute may not be assigned to or unset.
|
|
Once this attribute is set, it cannot be turned off.
|
|
.It Fl t
|
|
Tag attribute.
|
|
Has no meaning to the shell; provided for application use.
|
|
.Pp
|
|
For functions,
|
|
.Fl t
|
|
is the trace attribute.
|
|
When functions with the trace attribute are executed, the
|
|
.Ic xtrace
|
|
.Pq Fl x
|
|
shell option is temporarily turned on.
|
|
.It Fl u
|
|
Upper case attribute.
|
|
All lower case characters in values are converted to upper case.
|
|
(In the original Korn shell, this parameter meant
|
|
.Dq unsigned integer
|
|
when used with the
|
|
.Fl i
|
|
option, which meant upper case letters would never be used for bases greater
|
|
than 10.
|
|
See the
|
|
.Fl U
|
|
option.)
|
|
.Pp
|
|
For functions,
|
|
.Fl u
|
|
is the undefined attribute.
|
|
See
|
|
.Sx Functions
|
|
above for the implications of this.
|
|
.It Fl x
|
|
Export attribute.
|
|
Parameters (or functions) are placed in the environment of
|
|
any executed commands.
|
|
Exported functions are not yet implemented.
|
|
.El
|
|
.It Xo Ic ulimit Op Fl acdfHlmnpsStv
|
|
.Op Ar value
|
|
.Xc
|
|
Display or set process limits.
|
|
If no options are used, the file size limit
|
|
.Pq Fl f
|
|
is assumed.
|
|
.Ar value ,
|
|
if specified, may be either an arithmetic expression or the word
|
|
.Dq unlimited .
|
|
The limits affect the shell and any processes created by the shell after a
|
|
limit is imposed.
|
|
Note that some systems may not allow limits to be increased
|
|
once they are set.
|
|
Also note that the types of limits available are system
|
|
dependent \(em some systems have only the
|
|
.Fl f
|
|
limit.
|
|
.Bl -tag -width 5n
|
|
.It Fl a
|
|
Displays all limits; unless
|
|
.Fl H
|
|
is used, soft limits are displayed.
|
|
.It Fl H
|
|
Set the hard limit only (default is to set both hard and soft limits).
|
|
.It Fl S
|
|
Set the soft limit only (default is to set both hard and soft limits).
|
|
.It Fl c Ar n
|
|
Impose a size limit of
|
|
.Ar n
|
|
blocks on the size of core dumps.
|
|
.It Fl d Ar n
|
|
Impose a size limit of
|
|
.Ar n
|
|
kibibytes on the size of the data area.
|
|
.It Fl f Ar n
|
|
Impose a size limit of
|
|
.Ar n
|
|
blocks on files written by the shell and its child processes (files of any
|
|
size may be read).
|
|
.It Fl l Ar n
|
|
Impose a limit of
|
|
.Ar n
|
|
kibibytes on the amount of locked (wired) physical memory.
|
|
.It Fl m Ar n
|
|
Impose a limit of
|
|
.Ar n
|
|
kibibytes on the amount of physical memory used.
|
|
.It Fl n Ar n
|
|
Impose a limit of
|
|
.Ar n
|
|
file descriptors that can be open at once.
|
|
.It Fl p Ar n
|
|
Impose a limit of
|
|
.Ar n
|
|
processes that can be run by the user at any one time.
|
|
.It Fl s Ar n
|
|
Impose a size limit of
|
|
.Ar n
|
|
kibibytes on the size of the stack area.
|
|
.It Fl t Ar n
|
|
Impose a time limit of
|
|
.Ar n
|
|
.Tn CPU
|
|
seconds to be used by each process.
|
|
.It Fl T Ar n
|
|
Impose a real time limit of
|
|
.Ar n
|
|
.Tn human
|
|
seconds to be used by each process.
|
|
.It Fl v Ar n
|
|
Impose a limit of
|
|
.Ar n
|
|
kibibytes on the amount of virtual memory used.
|
|
.El
|
|
.Pp
|
|
As far as
|
|
.Ic ulimit
|
|
is concerned, a block is 512 bytes.
|
|
.It Xo Ic umask Op Fl S
|
|
.Op Ar mask
|
|
.Xc
|
|
Display or set the file permission creation mask or umask (see
|
|
.Xr umask 2 ) .
|
|
If the
|
|
.Fl S
|
|
option is used, the mask displayed or set is symbolic; otherwise, it is an
|
|
octal number.
|
|
.Pp
|
|
Symbolic masks are like those used by
|
|
.Xr chmod 1 .
|
|
When used, they describe what permissions may be made available (as opposed to
|
|
octal masks in which a set bit means the corresponding bit is to be cleared).
|
|
For example,
|
|
.Dq ug=rwx,o=
|
|
sets the mask so files will not be readable, writable or executable by
|
|
.Dq others
|
|
and is equivalent (on most systems) to the octal mask
|
|
.Dq 007 .
|
|
.It Xo Ic unalias Op Fl adt
|
|
.Op Ar name1 ...
|
|
.Xc
|
|
The aliases for the given names are removed.
|
|
If the
|
|
.Fl a
|
|
option is used, all aliases are removed.
|
|
If the
|
|
.Fl t
|
|
or
|
|
.Fl d
|
|
options are used, the indicated operations are carried out on tracked or
|
|
directory aliases, respectively.
|
|
.It Xo Ic unset Op Fl fv
|
|
.Ar parameter ...
|
|
.Xc
|
|
Unset the named parameters
|
|
.Po
|
|
.Fl v ,
|
|
the default
|
|
.Pc
|
|
or functions
|
|
.Pq Fl f .
|
|
The exit status is non-zero if any of the parameters were already unset, zero
|
|
otherwise.
|
|
.It Ic wait Op Ar job ...
|
|
Wait for the specified job(s) to finish.
|
|
The exit status of
|
|
.Ic wait
|
|
is that of the last specified job; if the last job is killed by a signal, the
|
|
exit status is 128 + the number of the signal (see
|
|
.Ic kill -l Ar exit-status
|
|
above); if the last specified job can't be found (because it never existed or
|
|
had already finished), the exit status of
|
|
.Ic wait
|
|
is 127.
|
|
See
|
|
.Sx Job control
|
|
below for the format of
|
|
.Ar job .
|
|
.Ic wait
|
|
will return if a signal for which a trap has been set is received or if a
|
|
.Dv SIGHUP ,
|
|
.Dv SIGINT
|
|
or
|
|
.Dv SIGQUIT
|
|
signal is received.
|
|
.Pp
|
|
If no jobs are specified,
|
|
.Ic wait
|
|
waits for all currently running jobs (if any) to finish and exits with a zero
|
|
status.
|
|
If job monitoring is enabled, the completion status of jobs is printed
|
|
(this is not the case when jobs are explicitly specified).
|
|
.It Xo Ic whence Op Fl pv
|
|
.Op Ar name ...
|
|
.Xc
|
|
For each
|
|
.Ar name ,
|
|
the type of command is listed (reserved word, built-in, alias,
|
|
function, tracked alias or executable).
|
|
If the
|
|
.Fl p
|
|
option is used, a path search is performed even if
|
|
.Ar name
|
|
is a reserved word, alias, etc.
|
|
Without the
|
|
.Fl v
|
|
option,
|
|
.Ic whence
|
|
is similar to
|
|
.Ic command Fl v
|
|
except that
|
|
.Ic whence
|
|
will find reserved words and won't print aliases as alias commands.
|
|
With the
|
|
.Fl v
|
|
option,
|
|
.Ic whence
|
|
is the same as
|
|
.Ic command Fl V .
|
|
Note that for
|
|
.Ic whence ,
|
|
the
|
|
.Fl p
|
|
option does not affect the search path used, as it does for
|
|
.Ic command .
|
|
If the type of one or more of the names could not be determined, the exit
|
|
status is non-zero.
|
|
.El
|
|
.Ss Job control
|
|
Job control refers to the shell's ability to monitor and control jobs, which
|
|
are processes or groups of processes created for commands or pipelines.
|
|
At a minimum, the shell keeps track of the status of the background (i.e.,
|
|
asynchronous) jobs that currently exist; this information can be displayed
|
|
using the
|
|
.Ic jobs
|
|
commands.
|
|
If job control is fully enabled (using
|
|
.Ic set Fl m
|
|
or
|
|
.Ic set Fl o Ic monitor ) ,
|
|
as it is for interactive shells, the processes of a job are placed in their
|
|
own process group.
|
|
Foreground jobs can be stopped by typing the suspend
|
|
character from the terminal (normally ^Z), jobs can be restarted in either the
|
|
foreground or background using the
|
|
.Ic fg
|
|
and
|
|
.Ic bg
|
|
commands, and the state of the terminal is saved or restored when a foreground
|
|
job is stopped or restarted, respectively.
|
|
.Pp
|
|
Note that only commands that create processes (e.g., asynchronous commands,
|
|
subshell commands and non-built-in, non-function commands) can be stopped;
|
|
commands like
|
|
.Ic read
|
|
cannot be.
|
|
.Pp
|
|
When a job is created, it is assigned a job number.
|
|
For interactive shells, this number is printed inside
|
|
.Dq \&[..\&] ,
|
|
followed by the process IDs of the processes in the job when an asynchronous
|
|
command is run.
|
|
A job may be referred to in the
|
|
.Ic bg ,
|
|
.Ic fg ,
|
|
.Ic jobs ,
|
|
.Ic kill
|
|
and
|
|
.Ic wait
|
|
commands either by the process ID of the last process in the command pipeline
|
|
(as stored in the
|
|
.Ic $\&!
|
|
parameter) or by prefixing the job number with a percent sign
|
|
.Pq Sq % .
|
|
Other percent sequences can also be used to refer to jobs:
|
|
.Bl -tag -width 10n
|
|
.It Ic %\&+
|
|
The most recently stopped job or, if there are no stopped jobs, the oldest
|
|
running job.
|
|
.It Ic %% , %
|
|
Same as
|
|
.Ic %\&+ .
|
|
.It Ic %\&-
|
|
The job that would be the
|
|
.Ic %\&+
|
|
job if the latter did not exist.
|
|
.It Ic % Ns Ar n
|
|
The job with job number
|
|
.Ar n .
|
|
.It Ic %\&? Ns Ar string
|
|
The job containing the string
|
|
.Ar string
|
|
(an error occurs if multiple jobs are matched).
|
|
.It Ic % Ns Ar string
|
|
The job starting with string
|
|
.Ar string
|
|
(an error occurs if multiple jobs are matched).
|
|
.El
|
|
.Pp
|
|
When a job changes state (e.g., a background job finishes or foreground job is
|
|
stopped), the shell prints the following status information:
|
|
.Bd -unfilled -offset indent
|
|
.Ic \&[ Ar number Ic \&] Ar flag status command
|
|
.Ed
|
|
.Pp
|
|
where
|
|
.Bl -tag -width "status"
|
|
.It Ar number
|
|
is the job number of the job.
|
|
.It Ar flag
|
|
is the
|
|
.Ql +
|
|
or
|
|
.Ql -
|
|
character if the job is the
|
|
.Ic %\&+ or
|
|
.Ic %\&-
|
|
job, respectively, or space if it is neither.
|
|
.It Ar status
|
|
indicates the current state of the job and can be:
|
|
.Bl -tag -width "Running"
|
|
.It Cm Running
|
|
The job has neither stopped nor exited (note that running does not necessarily
|
|
mean consuming
|
|
.Tn CPU
|
|
time \(em the process could be blocked waiting for some
|
|
event).
|
|
.It Cm Done Op Ar number
|
|
The job exited.
|
|
.Ar number
|
|
is the exit status of the job, which is omitted if the status is zero.
|
|
.It Cm Stopped Op Ar signal
|
|
The job was stopped by the indicated
|
|
.Ar signal
|
|
(if no signal is given, the job was stopped by
|
|
.Dv SIGTSTP ) .
|
|
.It Ar signal-description Op Dq core dumped
|
|
The job was killed by a signal (e.g., memory fault, hangup, etc.; use
|
|
.Ic kill -l
|
|
for a list of signal descriptions).
|
|
The
|
|
.Dq core dumped
|
|
message indicates the process created a core file.
|
|
.El
|
|
.It Ar command
|
|
is the command that created the process.
|
|
If there are multiple processes in
|
|
the job, each process will have a line showing its
|
|
.Ar command
|
|
and possibly its
|
|
.Ar status ,
|
|
if it is different from the status of the previous process.
|
|
.El
|
|
.Pp
|
|
When an attempt is made to exit the shell while there are jobs in the stopped
|
|
state, the shell warns the user that there are stopped jobs and does not exit.
|
|
If another attempt is immediately made to exit the shell, the stopped jobs are
|
|
sent a
|
|
.Dv SIGHUP
|
|
signal and the shell exits.
|
|
Similarly, if the
|
|
.Ic nohup
|
|
option is not set and there are running jobs when an attempt is made to exit
|
|
a login shell, the shell warns the user and does not exit.
|
|
If another attempt
|
|
is immediately made to exit the shell, the running jobs are sent a
|
|
.Dv SIGHUP
|
|
signal and the shell exits.
|
|
.Sh FILES
|
|
.Bl -tag -width "/etc/suid_profile" -compact
|
|
.It Pa ~/.profile
|
|
.It Pa /etc/profile
|
|
.It Pa /etc/suid_profile
|
|
.El
|
|
.Sh SEE ALSO
|
|
.Xr arc4random 1 ,
|
|
.Xr awk 1 ,
|
|
.Xr csh 1 ,
|
|
.Xr ed 1 ,
|
|
.Xr getconf 1 ,
|
|
.Xr getopt 1 ,
|
|
.Xr ksh 1 ,
|
|
.Xr sed 1 ,
|
|
.Xr stty 1 ,
|
|
.Xr vi 1 ,
|
|
.Xr dup 2 ,
|
|
.Xr execve 2 ,
|
|
.Xr getgid 2 ,
|
|
.Xr getuid 2 ,
|
|
.Xr open 2 ,
|
|
.Xr pipe 2 ,
|
|
.Xr wait 2 ,
|
|
.Xr getopt 3 ,
|
|
.Xr rand 3 ,
|
|
.Xr random 3 ,
|
|
.Xr signal 3 ,
|
|
.Xr srand 3 ,
|
|
.Xr srandom 3 ,
|
|
.Xr system 3 ,
|
|
.Xr tty 4 ,
|
|
.Xr environ 7
|
|
.Pp
|
|
.Pa http://docsrv.sco.com:507/en/man/html.C/sh.C.html
|
|
.Pp
|
|
.Rs
|
|
.%A Morris Bolsky
|
|
.%A David Korn
|
|
.%T "The KornShell Command and Programming Language"
|
|
.%D 1983
|
|
.%O "ISBN 0-13-516972-0"
|
|
.Re
|
|
.Rs
|
|
.%A Stephen G. Kochan
|
|
.%A Patrick H. Wood
|
|
.%T "UNIX Shell Programming"
|
|
.%O "Hayden"
|
|
.Re
|
|
.Rs
|
|
.%A "IEEE Inc."
|
|
.%T "IEEE Standard for Information Technology - Portable Operating System Interface (POSIX) - Part 2: Shell and Utilities"
|
|
.%D 1993
|
|
.%O "ISBN 1-55937-266-9"
|
|
.Re
|
|
.Sh NOTES
|
|
.Nm sh
|
|
is implemented as a run-time option of
|
|
.Nm mksh ,
|
|
with only those
|
|
.Nm ksh
|
|
features whose syntax or semantics are incompatible with a traditional Bourne
|
|
shell disabled.
|
|
Since this leaves some
|
|
.Nm ksh
|
|
extensions exposed, caution should be used where backwards compatibility with
|
|
traditional Bourne or
|
|
.Tn POSIX
|
|
compliant shells is an issue.
|
|
.Pp
|
|
.Nm mksh
|
|
is the name for the portable version of
|
|
.Mx
|
|
.Nm ksh
|
|
installed as
|
|
.Pa /bin/mksh
|
|
on other, foreign, operating systems.
|
|
Visit
|
|
.Pa http://wiki.mirbsd.de/MirbsdKsh
|
|
to obtain the latest version of
|
|
.Nm mksh .
|
|
.Sh AUTHORS
|
|
The
|
|
.Pa CONTRIBUTORS
|
|
file in the source distribution contains an almost complete list of people and
|
|
their part in the shell's development.
|
|
.Sh BUGS
|
|
Send bug reports for
|
|
.Nm
|
|
to the
|
|
.Mx
|
|
development team at
|
|
.Aq miros\-discuss@66h.42h.de .
|
|
Please test first if the bug appears with the latest version of the full
|
|
.Nm mksh
|
|
as well.
|
|
We do not extensively use nor support
|
|
.Nm sh ,
|
|
but are accepting bug fixes for its behaviour as well.
|
|
.Pp
|
|
By the way, the most frequently reported bug is:
|
|
.Bd -literal -offset indent
|
|
$ echo hi | read a; echo $a # Does not print hi
|
|
.Ed
|
|
.Pp
|
|
The
|
|
.Nm pdksh
|
|
author is aware of this and there is no need to report it.
|