Next: The Restricted Shell, Previous: The Directory Stack, Up: Bash Features [Contents][Index]
Bash examines the value of the array variable PROMPT_COMMAND just before
printing each primary prompt.
If any elements in PROMPT_COMMAND are set and non-null, Bash
executes each value, in numeric order,
just as if it had been typed on the command line.
In addition, the following table describes the special characters which
can appear in the prompt variables PS0, PS1, PS2, and
PS4:
\aA bell character.
\dThe date, in "Weekday Month Date" format (e.g., "Tue May 26").
\D{format}The format is passed to strftime(3) and the result is inserted
into the prompt string; an empty format results in a locale-specific
time representation. The braces are required.
\eAn escape character.
\hThe hostname, up to the first ‘.’.
\HThe hostname.
\jThe number of jobs currently managed by the shell.
\lThe basename of the shell’s terminal device name.
\nA newline.
\rA carriage return.
\sThe name of the shell, the basename of $0 (the portion
following the final slash).
\tThe time, in 24-hour HH:MM:SS format.
\TThe time, in 12-hour HH:MM:SS format.
\@The time, in 12-hour am/pm format.
\AThe time, in 24-hour HH:MM format.
\uThe username of the current user.
\vThe version of Bash (e.g., 2.00)
\VThe release of Bash, version + patchlevel (e.g., 2.00.0)
\wThe value of the PWD shell variable ($PWD),
with $HOME abbreviated with a tilde
(uses the $PROMPT_DIRTRIM variable).
\WThe basename of $PWD, with $HOME abbreviated with a tilde.
\!The history number of this command.
\#The command number of this command.
\$If the effective uid is 0, #, otherwise $.
\nnnThe character whose ASCII code is the octal value nnn.
\\A backslash.
\[Begin a sequence of non-printing characters. This could be used to embed a terminal control sequence into the prompt.
\]End a sequence of non-printing characters.
The command number and the history number are usually different: the history number of a command is its position in the history list, which may include commands restored from the history file (see Bash History Facilities), while the command number is the position in the sequence of commands executed during the current shell session.
After the string is decoded, it is expanded via
parameter expansion, command substitution, arithmetic
expansion, and quote removal, subject to the value of the
promptvars shell option (see The Shopt Builtin).
This can have unwanted side effects if escaped portions of the string
appear within command substitution or contain characters special to
word expansion.
Next: The Restricted Shell, Previous: The Directory Stack, Up: Bash Features [Contents][Index]