How to install the software
Before a user can actually start doing something with a package, he needs
to unpack it first. Often the package files are tar'ed and
gzip'ed. (That can determined by looking at the extension of the file.
Tar'ed and gzip'ed archives have a .tar.gz or .tgz extension, for
example.) I'm not going to write down every time how to ungzip and how
to untar an archive. I will tell how to do that once, in this section.
There is also the possibility that a .tar.bz2 file could be downloaded.
Such a file would be tar'ed and compressed with the bzip2 program.
Bzip2 achieves a better compression than the commonly used gzip does. In
order to use bz2 archives, the bzip2 program needs to be installed.
Most if not every distribution comes with this program, so chances are
high it is already installed on the host system. If not, it's installed using
the distribution's installation tool.
To start with, change to the $LFS/usr/src directory by running:
cd $LFS/usr/src
If a file is tar'ed and gzip'ed, it is unpacked by
running either one of the following two commands, depending on the
filename format:
tar xvzf filename.tar.gz
tar xvzf filename.tgz
If a file is tar'ed and bzip2'ed, it is unpacked by
running:
bzcat filename.tar.bz2 | tar xv
Some tar programs (most of them nowadays but not all of them) are
slightly modified to be able to use bzip2 files directly using either
the I or the y tar parameter, which works the same as the z tar parameter
to handle gzip archives.
If a file is just tar'ed, it is unpacked by running:
tar xvf filename.tar
When the archive is unpacked, a new directory will be created under the
current directory (and this document assumes that the archives are unpacked
under the $LFS/usr/src directory). A user has to enter that new directory
before continuing with the installation instructions. So, every time the
book is going to install a program, it's up to the user to unpack the source
archive.
If a file is gzip'ed, it is unpacked by running:
gunzip filename.gz
After a package is installed, two things can be done with it:
either the directory that contains the sources can be deleted,
either it can be kept.
If it is kept, that's fine with me, but if the same package is needed
again in a later chapter, the directory needs to be deleted first before using
it again. If this is not done, it might end up in trouble because old
settings will be used (settings that apply to the normal Linux system but
which don't always apply to the LFS system). Doing a simple make clean
or make distclean does not always guarantee a totally clean source tree.
The configure script can also have files lying around in various
subdirectories which aren't always removed by a make clean process.
There is one exception to that rule: don't remove the linux kernel source
tree. A lot of programs need the kernel headers, so that's the only
directory that should not be removed, unless no software is to be compiled
anymore.