The Linux Command Line by William Shotts
Before we get to writing new scripts, I want to point out that you have some scripts of your own already. These scripts were put into your home directory when your account was created, and are used to configure the behavior of your sessions on the computer. You can edit these scripts to change things.
In this lesson, we will look at a couple of these scripts and learn a few important new concepts about the shell.
During your session, the system is holding a number of facts about the world in its memory. This information is called the environment. The environment contains such things as your path, your user name, the name of the file where your mail is delivered, and much more. You can see a complete list of what is in your environment with the set command.
Two types of commands are often contained in the environment. They are aliases and shell functions.
How Is The Environment Established?
When you log on to the system, the bash program starts, and reads a series of configuration scripts called startup files. These define the default environment shared by all users. This is followed by more startup files in your home directory that define your personal environment. The exact sequence depends on the type of shell session being started. There are two kinds: a login shell session and a non-login shell session. A login shell session is one in which we are prompted for our user name and password; when we start a virtual console session, for example. A non-login shell session typically occurs when we launch a terminal session in the GUI.
Login shells read one or more startup files as shown below:
File | Contents |
/etc/profile | A global configuration script that applies to all users. |
~/.bash_profile | A user’s personal startup file. Can be used to extend or override settings in the global configuration script. |
~/.bash_login | If ~/.bash_profile is not found, bash attempts to read this script. |
~/.profile | If neither ~/.bash_profile nor ~/.bash_login is found, bash attempts to read this file. This is the default in Debian-based distributions, such as Ubuntu. |
Non-login shell sessions read the following startup files:
File | Contents |
/etc/bash.bashrc | A global configuration script that applies to all users. |
~/.bashrc | A user’s personal startup file. Can be used to extend or override settings in the global configuration script. |
In addition to reading the startup files above, non-login shells also inherit the environment from their parent process, usually a login shell.
Take a look at your system and see which of these startup files you have. Remember— since most of the file names listed above start with a period (meaning that they are hidden), you will need to use the “-a” option when using ls.
The ~/.bashrc file is probably the most important startup file from the ordinary user’s point of view, since it is almost always read. Non-login shells read it by default and most startup files for login shells are written in such a way as to read the ~/.bashrc file as well.
If we take a look inside a typical .bash_profile (this one taken from a CentOS 4 system), it looks something like this:
# .bash_profile # Get the aliases and functions if [ -f ~/.bashrc ]; then . ~/.bashrc fi # User specific environment and startup programs PATH=$PATH:$HOME/bin export PATH
Lines that begin with a “#” are comments and are not read by the shell. These are there for human readability. The first interesting thing occurs on the fourth line, with the following code:
if [ -f ~/.bashrc ]; then . ~/.bashrc fi
This is called an if compound command, which we will cover fully in a later lesson, but for now I will translate:
If the file “~/.bashrc” exists, then read the “~/.bashrc” file.
We can see that this bit of code is how a login shell gets the contents of .bashrc. The next thing in our startup file does is set set PATH variable to add the ~/bin directory to the path.
Lastly, we have:
export PATH
The export command tells the shell to make the contents of PATH available to child processes of this shell.
Aliases
An alias is an easy way to create a new command which acts as an abbreviation for a longer one. It has the following syntax:
alias name=value
where name is the name of the new command and value is the text to be executed whenever nameis entered on the command line.
Let’s create an alias called “l” and make it an abbreviation for the command “ls -l”. Make sure you are in your home directory. Using your favorite text editor, open the file .bashrc and add this line to the end of the file:
alias l='ls -l'
By adding the alias command to the file, we have created a new command called “l” which will perform “ls -l”. To try out your new command, close your terminal session and start a new one. This will reload the .bashrc file. Using this technique, you can create any number of custom commands for yourself. Here is another one for you to try:
alias today='date +"%A, %B %-d, %Y"'
This alias creates a new command called “today” that will display today’s date with nice formatting.
By the way, the alias command is just another shell builtin. You can create your aliases directly at the command prompt; however they will only remain in effect during your current shell session. For example:
[me@linuxbox me]$ alias l=’ls -l’
Shell Functions
Aliases are good for very simple commands, but if you want to create something more complex, you should try shell functions . Shell functions can be thought of as “scripts within scripts” or little sub-scripts. Let’s try one. Open .bashrc with your text editor again and replace the alias for “today” with the following:
today() { echo -n "Today's date is: " date +"%A, %B %-d, %Y" }
Believe it or not, () is a shell builtin too, and as with alias, you can enter shell functions directly at the command prompt.
[me@linuxbox me]$ today() { > echo -n "Today's date is: " > date +"%A, %B %-d, %Y" > } [me@linuxbox me]$
However, again like alias, shell functions defined directly on the command line only last as long as the current shell session.