Bash is a
Unix shell and
command language
A command language is a language for job control (computing), job control in computing. It is a domain-specific language, domain-specific and interpreted language; common examples of a command language are shell script, shell or batch programming ...
written by
Brian Fox for the
GNU Project
The GNU Project () is a free software, mass collaboration project announced by Richard Stallman on September 27, 1983. Its goal is to give computer users freedom and control in their use of their computers and computing devices by collaborati ...
as a
free software
Free software or libre software is computer software distributed under terms that allow users to run the software for any purpose as well as to study, change, and distribute it and any adapted versions. Free software is a matter of liberty, no ...
replacement for the
Bourne shell
The Bourne shell (sh) is a Shell (computing), shell Command-line interface#Command-line interpreter, command-line interpreter for computer operating systems.
The Bourne shell was the default Unix shell, shell for Version 7 Unix. Unix-like syste ...
.
First released in 1989,
it has been used as the default
login shell for most
Linux
Linux ( or ) is a family of open-source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991, by Linus Torvalds. Linux is typically packaged as a Linux distribution, which ...
distributions.
Bash was one of the first programs
Linus Torvalds
Linus Benedict Torvalds ( , ; born 28 December 1969) is a Finnish software engineer who is the creator and, historically, the lead developer of the Linux kernel, used by Linux distributions and other operating systems such as Android. He also c ...
ported to Linux, alongside
GCC.
A version is also available for
Windows 10
Windows 10 is a major release of Microsoft's Windows NT operating system. It is the direct successor to Windows 8.1, which was released nearly two years earlier. It was released to manufacturing on July 15, 2015, and later to retail on J ...
and
Windows 11
Windows 11 is the latest major release of Microsoft's Windows NT operating system, released in October 2021. It is a free upgrade to its predecessor, Windows 10 (2015), and is available for any Windows 10 devices that meet the new Windows 11 ...
via the
Windows Subsystem for Linux. It is also the default user shell in
Solaris
Solaris may refer to:
Arts and entertainment Literature, television and film
* ''Solaris'' (novel), a 1961 science fiction novel by Stanisław Lem
** ''Solaris'' (1968 film), directed by Boris Nirenburg
** ''Solaris'' (1972 film), directed by ...
11. Bash was also the default shell in versions of
Apple macOS
macOS (; previously OS X and originally Mac OS X) is a Unix operating system developed and marketed by Apple Inc. since 2001. It is the primary operating system for Apple's Mac (computer), Mac computers. Within the market of ...
from 10.3 (originally, the default shell was
tcsh) to the 2019 release of
macOS Catalina
macOS Catalina (version 10.15) is the sixteenth major release of macOS, Apple Inc.'s desktop operating system for Macintosh computers. It is the successor to macOS Mojave and was announced at WWDC 2019 on June 3, 2019 and released to the publ ...
, which changed the default shell to
zsh
The Z shell (Zsh) is a Unix shell that can be used as an interactive login shell (computing), shell and as a command line interpreter, command interpreter for shell scripting. Zsh is an extended Bourne shell with many improvements, including som ...
, although Bash remains available as an alternative shell.
Bash is a
command processor that typically runs in a
text window where the user types commands that cause actions. Bash can also read and execute commands from a file, called a
shell script
A shell script is a computer program designed to be run by a Unix shell, a command-line interpreter. The various dialects of shell scripts are considered to be scripting languages. Typical operations performed by shell scripts include file manip ...
. Like most Unix shells, it supports filename
globbing
In computer programming, glob () patterns specify sets of filenames with wildcard characters. For example, the Unix Bash shell command mv *.txt textfiles/ moves (mv) all files with names ending in .txt from the current directory to the directory ...
(wildcard matching),
piping,
here documents,
command substitution,
variables, and
control structures
In computer science, control flow (or flow of control) is the order in which individual statements, instructions or function calls of an imperative program are executed or evaluated. The emphasis on explicit control flow distinguishes an ''imper ...
for
condition-testing and
iteration. The
keywords
Keyword may refer to:
Computing
* Keyword (Internet search), a word or phrase typically used by bloggers or online content creator to rank a web page on a particular topic
* Index term, a term used as a keyword to documents in an information syste ...
,
syntax
In linguistics, syntax () is the study of how words and morphemes combine to form larger units such as phrases and sentences. Central concerns of syntax include word order, grammatical relations, hierarchical sentence structure ( constituency) ...
,
dynamically scoped variables and other basic features of the
language
Language is a structured system of communication. The structure of a language is its grammar and the free components are its vocabulary. Languages are the primary means by which humans communicate, and may be conveyed through a variety of met ...
are all copied from
sh. Other features, e.g.,
history
History (derived ) is the systematic study and the documentation of the human activity. The time period of event before the History of writing#Inventions of writing, invention of writing systems is considered prehistory. "History" is an umbr ...
, are copied from
csh and
ksh. Bash is a
POSIX
The Portable Operating System Interface (POSIX) is a family of standards specified by the IEEE Computer Society for maintaining compatibility between operating systems. POSIX defines both the system- and user-level application programming interf ...
-compliant shell, but with a number of extensions.
The shell's name is an acronym for ''Bourne Again Shell'', a
pun on the name of the
Bourne shell
The Bourne shell (sh) is a Shell (computing), shell Command-line interface#Command-line interpreter, command-line interpreter for computer operating systems.
The Bourne shell was the default Unix shell, shell for Version 7 Unix. Unix-like syste ...
that it replaces and the notion of being "
born again
Born again, or to experience the new birth, is a phrase, particularly in evangelicalism, that refers to a "spiritual rebirth", or a regeneration of the human spirit. In contrast to one's physical birth, being "born again" is distinctly and sepa ...
".
A
security hole
Vulnerabilities are flaws in a computer system that weaken the overall security of the device/system. Vulnerabilities can be weaknesses in either the hardware itself, or the software that runs on the hardware. Vulnerabilities can be exploited by ...
in Bash dating from version 1.03 (August 1989),
dubbed
Shellshock, was discovered in early September 2014 and quickly led to a range of
attacks across the
Internet
The Internet (or internet) is the global system of interconnected computer networks that uses the Internet protocol suite (TCP/IP) to communicate between networks and devices. It is a '' network of networks'' that consists of private, pub ...
.
Patches to fix the bugs were made available soon after the bugs were identified.
History
Brian Fox began
coding Bash on January 10, 1988, after
Richard Stallman
Richard Matthew Stallman (; born March 16, 1953), also known by his initials, rms, is an American free software movement activist and programmer. He campaigns for software to be distributed in such a manner that its users have the freedom to ...
became dissatisfied with the lack of progress being made by a prior developer.
[ Stallman and the ]Free Software Foundation
The Free Software Foundation (FSF) is a 501(c)#501(c)(3), 501(c)(3) non-profit organization founded by Richard Stallman on October 4, 1985, to support the free software movement, with the organization's preference for software being distributed ...
(FSF) considered a free shell that could run existing shell scripts so strategic to a completely free system built from BSD and GNU code that this was one of the few projects they funded themselves, with Fox undertaking the work as an employee of FSF.[ Fox released Bash as a beta, version .99, on June 8, 1989,][ and remained the primary maintainer until sometime between mid-1992 and mid-1994,] when he was laid off from FSF and his responsibility was transitioned to another early contributor, Chet Ramey.
Since then, Bash has become by far the most popular shell among users of Linux, becoming the default interactive shell on that operating system's various distributions (although Almquist shell
Almquist shell (also known as A Shell, ash and sh) is a lightweight Unix shell originally written by Kenneth Almquist in the late 1980s. Initially a clone of the System V.4 variant of the Bourne shell, it replaced the original Bourne shell in the ...
may be the default scripting shell) and on Apple's macOS releases before Catalina
Catalina may refer to:
Arts and media
* ''The Catalina'', a 2012 American reality television show
* ''Catalina'' (novel), a 1948 novel by W. Somerset Maugham
* Catalina (''My Name Is Earl''), character from the NBC sitcom ''My Name Is Earl''
...
in October 2019. Bash has also been ported to Microsoft Windows
Windows is a group of several proprietary graphical operating system families developed and marketed by Microsoft. Each family caters to a certain sector of the computing industry. For example, Windows NT for consumers, Windows Server for serv ...
and distributed with Cygwin
Cygwin ( ) is a POSIX-compatible programming and runtime environment that runs natively on Microsoft Windows. Under Cygwin, source code designed for Unix-like operating systems may be compiled with minimal modification and executed.
The Cygwin in ...
and MinGW, to DOS by the DJGPP
DJ's GNU Programming Platform (DJGPP) is a software development suite for Intel 80386-level and above, IBM PC compatibles which supports DOS operating systems. It is guided by DJ Delorie, who began the project in 1989. It is a port of the GNU Co ...
project, to Novell NetWare, to OpenVMS
OpenVMS, often referred to as just VMS, is a multi-user, multiprocessing and virtual memory-based operating system. It is designed to support time-sharing, batch processing, transaction processing and workstation applications. Customers using Ope ...
by the GNV project, to ArcaOS
ArcaOS is an operating system based on OS/2, developed and marketed by Arca Noae, LLC under license from IBM. It was codenamed Blue Lion during its development. It builds on OS/2 Warp 4.52 by adding support for new hardware, fixing defects and l ...
, and to Android
Android may refer to:
Science and technology
* Android (robot), a humanoid robot or synthetic organism designed to imitate a human
* Android (operating system), Google's mobile operating system
** Bugdroid, a Google mascot sometimes referred to ...
via various terminal emulation applications.
In September 2014, Stéphane Chazelas, a Unix/Linux specialist, discovered a security bug
Security is protection from, or resilience against, potential harm (or other unwanted Coercion, coercive change) caused by others, by restraining the freedom of others to act. Beneficiaries (technically referents) of security may be of persons an ...
in the program. The bug, first disclosed on September 24, was named Shellshock and assigned the numbers . The bug was regarded as severe, since CGI scripts using Bash could be vulnerable, enabling arbitrary code execution. The bug was related to how Bash passes function definitions to subshells through environment variables.
Features
The Bash command
Command may refer to:
Computing
* Command (computing), a statement in a computer language
* COMMAND.COM, the default operating system shell and command-line interpreter for DOS
* Command key, a modifier key on Apple Macintosh computer keyboards
* ...
syntax is a superset of the Bourne shell command syntax. Bash supports brace expansion
Bash is a Unix shell and command language written by Brian Fox for the GNU Project as a free software replacement for the Bourne shell. First released in 1989, it has been used as the default login shell for most Linux distributions. Bash was o ...
, command line completion
Command-line completion (also tab completion) is a common feature of command-line interpreters, in which the program automatically fills in partially typed commands.
Command line interpreters are programs that allow a user to interact with the u ...
(Programmable Completion), basic debugging and signal handling (using trap
) since bash 2.05a among other features. Bash can execute the vast majority of Bourne shell scripts without modification, with the exception of Bourne shell scripts stumbling into fringe syntax behavior interpreted differently in Bash or attempting to run a system command matching a newer Bash builtin, etc. Bash command syntax includes ideas drawn from the KornShell
KornShell (ksh) is a Unix shell which was developed by David Korn at Bell Labs in the early 1980s and announced at USENIX on July 14, 1983. The initial development was based on Bourne shell source code. Other early contributors were Bell ...
(ksh) and the C shell (csh) such as command line editing, command history (history
command), the directory stack, the $RANDOM
and $PPID
variables, and POSIX command substitution syntax $(…)
.
When a user presses the tab key
The tab key (abbreviation of tabulator key or tabular key) on a keyboard is used to advance the cursor to the next tab stop.
History
The word ''tab'' derives from the word ''tabulate'', which means "to arrange data in a tabular, or table, fo ...
within an interactive command-shell, Bash automatically uses command line completion
Command-line completion (also tab completion) is a common feature of command-line interpreters, in which the program automatically fills in partially typed commands.
Command line interpreters are programs that allow a user to interact with the u ...
, since beta version 2.04, to match partly typed program names, filenames and variable names. The Bash command-line completion system is very flexible and customizable, and is often packaged with functions that complete arguments and filenames for specific programs and tasks.
Bash's syntax has many extensions lacking in the Bourne shell. Bash can perform integer calculations ("arithmetic evaluation") without spawning external processes. It uses the ((…))
command and the $((…))
variable syntax for this purpose. Its syntax simplifies I/O redirection. For example, it can redirect standard out
In computer programming, standard streams are interconnected input and output communication channels between a computer program and its environment when it begins execution. The three input/output (I/O) connections are called standard input (stdin ...
put (stdout) and standard error (stderr) at the same time using the &>
operator. This is simpler to type than the Bourne shell equivalent 'command > file 2>&1
'. Bash supports process substitution
In computing, process substitution is a form of inter-process communication that allows the input or output of a command to appear as a file. The command is substituted in-line, where a file name would normally occur, by the command shell. This all ...
using the <(command)
and >(command)
syntax, which substitutes the output of (or input to) a command where a filename is normally used. (This is implemented through ''/proc/fd/'' unnamed pipes on systems that support that, or via temporary named pipes where necessary).
When using the 'function' keyword, Bash function declarations are not compatible with Bourne/Korn/POSIX scripts (the KornShell has the same problem when using 'function'), but Bash accepts the same function declaration syntax as the Bourne and Korn shells, and is POSIX-conformant. Because of these and other differences, Bash shell scripts are rarely runnable under the Bourne or Korn shell interpreters unless deliberately written with that compatibility in mind, which is becoming less common as Linux becomes more widespread. But in POSIX mode, Bash conforms with POSIX more closely.[
]
Bash supports here documents. Since version 2.05b Bash can redirect standard input
In computer programming, standard streams are interconnected input and output communication channels between a computer program and its environment when it begins execution. The three input/output (I/O) connections are called standard input (stdin ...
(stdin) from a "here string" using the <<<
operator.
Bash 3.0 supports in-process regular expression matching using a syntax reminiscent of Perl
Perl is a family of two high-level, general-purpose, interpreted, dynamic programming languages. "Perl" refers to Perl 5, but from 2000 to 2019 it also referred to its redesigned "sister language", Perl 6, before the latter's name was offici ...
.
In February 2009, Bash 4.0 introduced support for associative arrays.
Associative array indices are strings, in a manner similar to AWK
AWK (''awk'') is a domain-specific language designed for text processing and typically used as a data extraction and reporting tool. Like sed and grep, it is a filter, and is a standard feature of most Unix-like operating systems.
The AWK langu ...
or Tcl
TCL or Tcl or TCLs may refer to:
Business
* TCL Technology, a Chinese consumer electronics and appliance company
**TCL Electronics, a subsidiary of TCL Technology
* Texas Collegiate League, a collegiate baseball league
* Trade Centre Limited, a ...
. They can be used to emulate multidimensional arrays. Bash 4 also switches its license to GPL-3.0-or-later; some users suspect this licensing change is why MacOS continues to use older versions. Apple finally stopped using Bash in their operating systems as default shell with the release of MacOS Catalina in 2019.
Brace expansion
Brace expansion, also called alternation, is a feature copied from the C shell. It generates a set of alternative combinations. Generated results need not exist as files. The results of each expanded string are not sorted and left to right order is preserved:
$ echo ae
ape ace ade abe
$ echo
ad ae af bd be bf cd ce cf
Users should not use brace expansions in portable shell scripts, because the Bourne shell
The Bourne shell (sh) is a Shell (computing), shell Command-line interface#Command-line interpreter, command-line interpreter for computer operating systems.
The Bourne shell was the default Unix shell, shell for Version 7 Unix. Unix-like syste ...
does not produce the same output.
$ # A traditional shell does not produce the same output
$ /bin/sh -c 'echo ae'
ae
When brace expansion is combined with wildcards, the braces are expanded first, and then the resulting wildcards are substituted normally. Hence, a listing of JPEG and PNG images in the current directory could be obtained using:
ls *. # expands to *.jpg *.jpeg *.png - after which,
# the wildcards are processed
echo *. # echo just show the expansions -
# and braces in braces are possible.
In addition to alternation, brace expansion can be used for sequential ranges between two integers or characters separated by double dots. Newer versions of Bash allow a third integer to specify the increment.
$ echo
1 2 3 4 5 6 7 8 9 10
$ echo
01 02 03 04 05 06 07 08 09 10
$ echo file.txt
file1.txt file2.txt file3.txt file4.txt
$ echo
a b c d e
$ echo
1 4 7 10
$ echo
a d g j
When brace expansion is combined with variable expansion (A.K.A. ''parameter expansion'' and ''parameter substitution'') the variable expansion is performed ''after'' the brace expansion, which in some cases may necessitate the use of the eval
built-in, thus:
$ start=1; end=10
$ echo # fails to expand due to the evaluation order
$ eval echo # variable expansion occurs then resulting string is evaluated
1 2 3 4 5 6 7 8 9 10
Startup scripts
When Bash starts, it executes the commands in a variety of dot files. Unlike Bash shell scripts, dot files do not typically have execute permission enabled nor an interpreter directive
An interpreter directive is a computer language construct, that on some systems is better described as an aspect of the system's executable file format, that is used to control which interpreter parses and interprets the instructions in a compute ...
like #!/bin/bash
.
Legacy-compatible Bash startup example
The skeleton ~/.bash_profile
below is compatible with the Bourne shell and gives semantics similar to csh for the ~/.bashrc
and ~/.bash_login
. The -r ''filename'' && cmd
is a short-circuit evaluation that tests if ''filename'' exists and is readable, skipping the part after the &&
if it is not.
-r ~/.profile && . ~/.profile # set up environment, once, Bourne-sh syntax only
if -n "$PS1" ; then # are we interactive?
-r ~/.bashrc && . ~/.bashrc # tty/prompt/function setup for interactive shells
-r ~/.bash_login && . ~/.bash_login # any at-login tasks for login shell only
fi # End of "if" block
Operating system issues in Bash startup
Some versions of Unix
Unix (; trademarked as UNIX) is a family of multitasking, multiuser computer operating systems that derive from the original AT&T Unix, whose development started in 1969 at the Bell Labs research center by Ken Thompson, Dennis Ritchie, and ot ...
and Linux
Linux ( or ) is a family of open-source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991, by Linus Torvalds. Linux is typically packaged as a Linux distribution, which ...
contain Bash system startup scripts, generally under the /etc
directories. Bash calls these as part of its standard initialization, but other startup files can read them in a different order than the documented Bash startup sequence. The default content of the root user's files may also have issues, as well as the skeleton files the system provides to new user accounts upon setup. The startup scripts that launch the X window system
The X Window System (X11, or simply X) is a windowing system for bitmap displays, common on Unix-like operating systems.
X provides the basic framework for a GUI environment: drawing and moving windows on the display device and interacting wit ...
may also do surprising things with the user's Bash startup scripts in an attempt to set up user-environment variables before launching the window manager. These issues can often be addressed using a ~/.xsession
or ~/.xprofile
file to read the ~/.profile
— which provides the environment variables that Bash shell windows spawned from the window manager need, such as xterm or Gnome Terminal.
Portability
Invoking Bash with the --posix
option or stating set -o posix
in a script causes Bash to conform very closely to the POSIX 1003.2 standard. Bash shell scripts intended for portability should take into account at least the POSIX shell standard. Some bash features not found in POSIX are:
* Certain extended invocation options
* Brace expansion
* Arrays and associative arrays
* The double bracket extended test construct and its regex matching
* The double-parentheses arithmetic-evaluation construct (only ; is POSIX)
* Certain string-manipulation operations in parameter expansion
* for scoped variables
* Process substitution
* Bash-specific builtins
* Coprocess In computer science, a coprocess is a process that explicitly yields control to other processes or the operating system.
In Unix, a coprocess is a process that sends its output solely to the exact single process from which it solely received input. ...
es
* $EPOCHSECONDS and $EPOCHREALTIME variables
If a piece of code uses such a feature, it is called a "bashism" – a problem for portable use. Debian's and Vidar Holen's can be used to make sure that a script does not contain these parts. The list varies depending on the actual target shell: Debian's policy allows some extensions in their scripts (as they are in the dash
The dash is a punctuation mark consisting of a long horizontal line. It is similar in appearance to the hyphen but is longer and sometimes higher from the baseline. The most common versions are the endash , generally longer than the hyphen b ...
shell),[ while a script intending to support pre-POSIX Bourne shells, like autoconf's , are even more limited in the features they can use.
]
Keyboard shortcuts
Bash uses readline to provide keyboard shortcuts for command line editing using the default (Emacs
Emacs , originally named EMACS (an acronym for "Editor MACroS"), is a family of text editors that are characterized by their extensibility. The manual for the most widely used variant, GNU Emacs, describes it as "the extensible, customizable, s ...
) key bindings. Vi-binding
Arrow keys or cursor movement keys are buttons on a computer keyboard that are either programmed or designated to move the cursor in a specified direction.
The term "cursor movement key" is distinct from "arrow key" in that the former term may ...
s can be enabled by running set -o vi
.
Process management
The Bash shell has two modes of execution for commands: batch, and concurrent mode.
To execute commands in batch (i.e., in sequence) they must be separated by the character ";", or on separate lines:
command1; command2
in this example, when command1 is finished, command2 is executed.
A background execution of command1 can occur using (symbol &) at the end of an execution command, and process will be executed in background returning immediately control to the shell and allowing continued execution of commands.
command1 &
Or to have a concurrent execution of two command1 and command2, they must be executed in the Bash shell in the following way:
command1 & command2
In this case command1 is executed in the background ''&'' symbol, returning immediately control to the shell that executes command2 in the foreground.
A process can be stopped and control returned to bash by typing while the process is running in the foreground.
A list of all processes, both in the background and stopped, can be achieved by running jobs
:
$ jobs
Running command1 &
Stopped command2
In the output, the number in brackets refers to the job id. The plus sign signifies the default process for bg
and fg
. The text "Running" and "Stopped" refer to the Process state. The last string is the command that started the process.
The state of a process can be changed using various commands. The fg
command brings a process to the foreground, while bg
sets a stopped process running in the background. bg
and fg
can take a job id as their first argument, to specify the process to act on. Without one, they use the default process, identified by a plus sign in the output of jobs
. The kill
command can be used to end a process prematurely, by sending it a signal. The job id must be specified after a percent sign:
kill %1
Conditional execution
Bash supplies "conditional execution" command separators that make execution of a command contingent on the exit code
The exit status of a process in computer programming is a small number passed from a child process (or callee) to a parent process (or caller) when it has finished executing a specific procedure or delegated task. In DOS, this may be referred t ...
set by a precedent command. For example:
cd "$SOMEWHERE" && ./do_something , , echo "An error occurred" >&2
Where ''./do_something'' is only executed if the ''cd'' (change directory) command was "successful" (returned an exit status of zero) and the ''echo'' command would only be executed if either the ''cd'' or the ''./do_something'' command return an "error" (non-zero exit status).
For all commands the exit status is stored in the special variable $?
. Bash also supports and forms of conditional command evaluation.
Bug reporting
An external command called ''bashbug'' reports Bash shell bugs. When the command is invoked, it brings up the user's default editor with a form to fill in. The form is mailed to the Bash maintainers (or optionally to other email addresses).
Programmable completion
Bash supports programmable completion via built-in complete
, , and compgen
commands. The feature has been available since the beta version of 2.04 released in 2000. These commands enable complex and intelligent completion specification for commands (i.e. installed programs), functions, variables, and filenames.
The complete
and two commands specify how arguments of some available commands or options are going to be listed in the readline input. As of version 5.1 completion of the command or the option is usually activated by the keystroke after typing its name.
Release history
See also
* Comparison of command shells
A command shell is a command-line interface to interact with and manipulate a computer's operating system.
General characteristics
Interactive features
Background execution
Background execution allows a shell to run a command without use ...
References
External links
*
* (interview with GNU Bash's maintainer, Chet Ramey)
{{DEFAULTSORT:Bash (Unix Shell)
1989 software
Cross-platform free software
Domain-specific programming languages
Free software programmed in C
GNU Project software
Scripting languages
Text-oriented programming languages
Unix shells