From b822811980a5f82726cb641cbeff66be9eb6d92a Mon Sep 17 00:00:00 2001 From: Mark Hymers Date: Sun, 22 Jul 2001 19:45:10 +0000 Subject: XML changes git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@827 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689 --- chapter06/aboutdebug.xml | 63 ++++++++++++------------------- chapter06/autoconf-inst.xml | 12 ++---- chapter06/autoconf.xml | 6 +-- chapter06/automake-inst.xml | 12 ++---- chapter06/automake.xml | 6 +-- chapter06/bash-inst.xml | 23 +++--------- chapter06/bash.xml | 6 +-- chapter06/bashprofile.xml | 28 +++++--------- chapter06/bin86-exp.xml | 6 +-- chapter06/bin86-inst.xml | 12 ++---- chapter06/bin86.xml | 6 +-- chapter06/binutils-inst.xml | 12 ++---- chapter06/binutils.xml | 6 +-- chapter06/bison-exp.xml | 6 +-- chapter06/bison-inst.xml | 32 +++++----------- chapter06/bison.xml | 6 +-- chapter06/bzip2-exp.xml | 12 ++---- chapter06/bzip2-inst.xml | 18 +++------ chapter06/bzip2.xml | 6 +-- chapter06/chroot.xml | 36 ++++++------------ chapter06/config-glibc.xml | 84 ++++++++++++++---------------------------- chapter06/config-ldso.xml | 26 ++++--------- chapter06/config-shadowpwd.xml | 16 ++------ chapter06/config-sysklogd.xml | 14 ++----- chapter06/config-sysvinit.xml | 16 +++----- chapter06/config-vim.xml | 14 ++----- chapter06/configure.xml | 6 +-- chapter06/create-password.xml | 12 ++---- chapter06/create-utmp.xml | 22 ++++------- chapter06/diffutils-inst.xml | 12 ++---- chapter06/diffutils.xml | 6 +-- chapter06/e2fsprogs-inst.xml | 18 +++------ chapter06/e2fsprogs.xml | 6 +-- chapter06/ed-inst.xml | 12 ++---- chapter06/ed.xml | 6 +-- chapter06/file-inst.xml | 29 +++++---------- chapter06/file.xml | 6 +-- chapter06/fileutils-inst.xml | 12 ++---- chapter06/fileutils.xml | 6 +-- chapter06/findutils-inst.xml | 17 +++------ chapter06/findutils.xml | 6 +-- chapter06/flex-inst.xml | 12 ++---- chapter06/flex.xml | 6 +-- chapter06/gcc-inst.xml | 20 +++------- chapter06/gcc.xml | 6 +-- chapter06/gettext-inst.xml | 12 ++---- chapter06/gettext.xml | 6 +-- chapter06/glibc-exp.xml | 55 ++++++++++----------------- chapter06/glibc-inst.xml | 52 ++++++++------------------ chapter06/glibc.xml | 6 +-- chapter06/grep-inst.xml | 12 ++---- chapter06/grep.xml | 6 +-- chapter06/groff-inst.xml | 12 ++---- chapter06/groff.xml | 6 +-- chapter06/gzip-inst.xml | 12 ++---- chapter06/gzip.xml | 6 +-- chapter06/introduction.xml | 15 +++----- chapter06/kbd-exp.xml | 21 ++++------- chapter06/kbd-inst.xml | 32 +++++----------- chapter06/kbd.xml | 6 +-- chapter06/less-inst.xml | 12 ++---- chapter06/less.xml | 6 +-- chapter06/libtool-inst.xml | 12 ++---- chapter06/libtool.xml | 6 +-- chapter06/lilo-inst.xml | 55 +++++++++++---------------- chapter06/lilo.xml | 6 +-- chapter06/m4-inst.xml | 48 +++++++----------------- chapter06/m4.xml | 6 +-- chapter06/make-inst.xml | 12 ++---- chapter06/make.xml | 6 +-- chapter06/makedev-exp.xml | 6 +-- chapter06/makedev-inst.xml | 24 ++++-------- chapter06/man-exp.xml | 6 +-- chapter06/man-inst.xml | 21 +++-------- chapter06/man.xml | 6 +-- chapter06/manpages-exp.xml | 6 +-- chapter06/manpages-inst.xml | 12 ++---- chapter06/manpages.xml | 6 +-- chapter06/mawk-inst.xml | 12 ++---- chapter06/mawk.xml | 6 +-- chapter06/modutils-inst.xml | 18 +++------ chapter06/modutils.xml | 6 +-- chapter06/ncurses-exp.xml | 18 +++------ chapter06/ncurses-inst.xml | 12 ++---- chapter06/ncurses.xml | 6 +-- chapter06/netkitbase-inst.xml | 18 +++------ chapter06/netkitbase.xml | 6 +-- chapter06/nettools-inst.xml | 12 ++---- chapter06/nettools.xml | 6 +-- chapter06/patch-inst.xml | 12 ++---- chapter06/patch.xml | 6 +-- chapter06/perl-inst.xml | 26 ++++--------- chapter06/perl.xml | 6 +-- chapter06/procinfo-exp.xml | 6 +-- chapter06/procinfo-inst.xml | 12 ++---- chapter06/procinfo.xml | 6 +-- chapter06/procps-exp.xml | 6 +-- chapter06/procps-inst.xml | 12 ++---- chapter06/procps.xml | 6 +-- chapter06/psmisc-inst.xml | 12 ++---- chapter06/psmisc.xml | 6 +-- chapter06/removeoldnss.xml | 14 ++----- chapter06/sed-inst.xml | 12 ++---- chapter06/sed.xml | 6 +-- chapter06/shadowpwd-exp.xml | 12 ++---- chapter06/shadowpwd-inst.xml | 12 ++---- chapter06/shadowpwd.xml | 6 +-- chapter06/shellutils-inst.xml | 32 +++++----------- chapter06/shellutils.xml | 6 +-- chapter06/sysklogd-inst.xml | 12 ++---- chapter06/sysklogd.xml | 6 +-- chapter06/sysvinit-inst.xml | 28 ++++---------- chapter06/sysvinit.xml | 6 +-- chapter06/tar-inst.xml | 32 +++++----------- chapter06/tar.xml | 6 +-- chapter06/texinfo-exp.xml | 6 +-- chapter06/texinfo-inst.xml | 12 ++---- chapter06/texinfo.xml | 6 +-- chapter06/textutils-inst.xml | 12 ++---- chapter06/textutils.xml | 6 +-- chapter06/utillinux-exp.xml | 6 +-- chapter06/utillinux-inst.xml | 24 ++++-------- chapter06/utillinux.xml | 6 +-- chapter06/vim-inst.xml | 47 ++++++++--------------- chapter06/vim.xml | 6 +-- 125 files changed, 537 insertions(+), 1239 deletions(-) (limited to 'chapter06') diff --git a/chapter06/aboutdebug.xml b/chapter06/aboutdebug.xml index 094398e2f..b743aa9ab 100644 --- a/chapter06/aboutdebug.xml +++ b/chapter06/aboutdebug.xml @@ -1,70 +1,53 @@ About debugging symbols - -Most programs and libraries by default are compiled with debugging +Most programs and libraries by default are compiled with debugging symbols (gcc option -g) Let me explain what these debugging symbols -are and why you may not want them. - +are and why you may not want them. - -A program compiled with debugging symbols means a user can run a program or -library through a debugger and the debugger's output will be user +A program compiled with debugging symbols means a user can run a program +or library through a debugger and the debugger's output will be user friendly. These debugging symbols also enlarge the program or library -significantly. - +significantly. - -Before you start wondering whether these debugging symbols really make a +Before you start wondering whether these debugging symbols really make a big difference, here are some statistics. Use them to draw your own -conclusion. - +conclusion. - - A dynamic Bash binary with debugging symbols: 1.2MB - +A dynamic Bash binary +with debugging symbols: 1.2MB - - A dynamic Bash binary without debugging symbols: 478KB - +A dynamic Bash binary +without debugging symbols: 478KB - - /lib and /usr/lib (glibc and gcc files) with debugging - symbols: 87MB - +/lib and /usr/lib (glibc +and gcc files) with debugging symbols: 87MB - - /lib and /usr/lib (glibc and gcc files) without - debugging symbols: 16MB - +/lib and /usr/lib (glibc +and gcc files) without debugging symbols: 16MB - -Sizes vary depending on which compiler was used and which C library +Sizes vary depending on which compiler was used and which C library version was used to link dynamic programs against, but results will be similar if you compare programs with and without debugging symbols. After I was done with this chapter and stripped all debugging symbols from all LFS -binaries I regained a little over 102 MB of disk space. Quite the difference. - +binaries I regained a little over 102 MB of disk space. Quite the +difference. - -To remove debugging symbols from a binary (must be an a.out or ELF +To remove debugging symbols from a binary (must be an a.out or ELF binary) run strip --strip-debug filename. Wild cards can be used to strip debugging symbols from multiple files (use something like strip --strip-debug $LFS/usr/bin/*). Most people will probably never use a debugger on software, so by -removing those symbols a lot of disk space can be regained. - +removing those symbols a lot of disk space can be regained. - -You might find additional information in the optimization hint which can +You might find additional information in the optimization hint which can be found at -http://archive.linuxfromscratch.org/lfs-hints/optimization.txt. - +url="http://archive.linuxfromscratch.org/lfs-hints/optimization.txt">http://archive.linuxfromscratch.org/lfs-hints/optimization.txt +. diff --git a/chapter06/autoconf-inst.xml b/chapter06/autoconf-inst.xml index 557f6753d..34bdaad56 100644 --- a/chapter06/autoconf-inst.xml +++ b/chapter06/autoconf-inst.xml @@ -1,17 +1,11 @@ Installation of Autoconf - -Install Autoconf by running the following commands: - +Install Autoconf by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/autoconf.xml b/chapter06/autoconf.xml index 10caa664b..0f8b40b7d 100644 --- a/chapter06/autoconf.xml +++ b/chapter06/autoconf.xml @@ -1,10 +1,8 @@ Installing Autoconf - -Estimated build time: &autoconf-time; -Estimated disk space required: &autoconf-compsize; - +Estimated build time: &autoconf-time; +Estimated disk space required: &autoconf-compsize; &c6-autoconf-inst; &aa-autoconf-desc; diff --git a/chapter06/automake-inst.xml b/chapter06/automake-inst.xml index 09a378452..c3bbd13b3 100644 --- a/chapter06/automake-inst.xml +++ b/chapter06/automake-inst.xml @@ -1,16 +1,10 @@ Installation of Automake - -Install Automake by running the following commands: - +Install Automake by running the following commands: - - -./configure --prefix=/usr && -make install - - +./configure --prefix=/usr && +make install diff --git a/chapter06/automake.xml b/chapter06/automake.xml index 0716739ff..95e27a093 100644 --- a/chapter06/automake.xml +++ b/chapter06/automake.xml @@ -1,10 +1,8 @@ Installing Automake - -Estimated build time: &automake-time; -Estimated disk space required: &automake-compsize; - +Estimated build time: &automake-time; +Estimated disk space required: &automake-compsize; &c6-automake-inst; &aa-automake-desc; diff --git a/chapter06/bash-inst.xml b/chapter06/bash-inst.xml index 677a75ece..653d49166 100644 --- a/chapter06/bash-inst.xml +++ b/chapter06/bash-inst.xml @@ -1,30 +1,19 @@ Installation of Bash - -Install Bash by running the following commands: - +Install Bash by running the following commands: - - -./configure --prefix=/usr --with-curses && +./configure --prefix=/usr --with-curses && make && make install && logout mv $LFS/usr/bin/bash $LFS/usr/bin/bashbug $LFS/bin - - + - -The static bash is replaced with the dynamic bash and the chroot'ed -environment is re-entered by running: - +The static bash is replaced with the dynamic bash and the chroot'ed +environment is re-entered by running: - - -&c6-chrootcmd; - - +&c6-chrootcmd; diff --git a/chapter06/bash.xml b/chapter06/bash.xml index 380825a61..43388b039 100644 --- a/chapter06/bash.xml +++ b/chapter06/bash.xml @@ -1,10 +1,8 @@ Installing Bash - -Estimated build time: &bash-time; -Estimated disk space required: &bash-compsize; - +Estimated build time: &bash-time; +Estimated disk space required: &bash-compsize; &c6-bash-inst; &aa-bash-desc; diff --git a/chapter06/bashprofile.xml b/chapter06/bashprofile.xml index b6543425c..abfed3700 100644 --- a/chapter06/bashprofile.xml +++ b/chapter06/bashprofile.xml @@ -1,22 +1,16 @@ Creating $LFS/root/.bash_profile - -When we have entered the chroot'ed environment in the next section we +When we have entered the chroot'ed environment in the next section we want to export a couple of environment variables in that shell such as PS1, PATH and others variables which are good to have set. For that purpose we'll create the $LFS/root/.bash_profile file which will be read -by bash when we enter the chroot environment. - +by bash when we enter the chroot environment. - -Create a new file $LFS/root/.bash_profile -by running the following. - +Create a new file $LFS/root/.bash_profile +by running the following. - - -cat > $LFS/root/.bash_profile << "EOF" +cat > $LFS/root/.bash_profile << "EOF" # Begin /root/.bash_profile PS1='\u:\w\$ ' @@ -25,16 +19,12 @@ PATH=/bin:/usr/bin:/sbin:/usr/sbin export PS1 PATH # End /root/.bash_profile -EOF - - +EOF - -The PS1 variable is an environment variable that controls the appearance of -the command prompt. See the bash man page for details how this variable +The PS1 variable is an environment variable that controls the appearance +of the command prompt. See the bash man page for details how this variable is constructed. Additional environment variables, aliases and so forth that are -needed and/or wanted can be added at your own discretion. - +needed and/or wanted can be added at your own discretion. diff --git a/chapter06/bin86-exp.xml b/chapter06/bin86-exp.xml index dd15f0f88..5d0c31040 100644 --- a/chapter06/bin86-exp.xml +++ b/chapter06/bin86-exp.xml @@ -1,13 +1,11 @@ Command explanations - -make INSTALL_OPTS="-m 755"...: The Makefile +make INSTALL_OPTS="-m 755"...: The Makefile declares INSTALL_OPTS="-m 755 -s". The -s parameter causes the install program to invoke the strip program to strip debug symbols from the program. This doesn't work properly because a few files aren't -programs, but shell scripts. The strip program errors on those. - +programs, but shell scripts. The strip program errors on those. diff --git a/chapter06/bin86-inst.xml b/chapter06/bin86-inst.xml index cb818beda..34f13b2d1 100644 --- a/chapter06/bin86-inst.xml +++ b/chapter06/bin86-inst.xml @@ -1,16 +1,10 @@ Installation of Bin86 - -Install Bin86 by running the following commands: - +Install Bin86 by running the following commands: - - -make && -make PREFIX=/usr install - - +make && +make PREFIX=/usr install diff --git a/chapter06/bin86.xml b/chapter06/bin86.xml index 89e1c1a38..c2cf4166c 100644 --- a/chapter06/bin86.xml +++ b/chapter06/bin86.xml @@ -1,10 +1,8 @@ Installing Bin86 - -Estimated build time: &bin86-time; -Estimated disk space required: &bin86-compsize; - +Estimated build time: &bin86-time; +Estimated disk space required: &bin86-compsize; &c6-bin86-inst; &aa-bin86-desc; diff --git a/chapter06/binutils-inst.xml b/chapter06/binutils-inst.xml index f8ea0860a..1002d09c3 100644 --- a/chapter06/binutils-inst.xml +++ b/chapter06/binutils-inst.xml @@ -1,17 +1,11 @@ Installation of Binutils - -Install Binutils by running the following commands: - +Install Binutils by running the following commands: - - -./configure --prefix=/usr --enable-shared && +./configure --prefix=/usr --enable-shared && make -e tooldir=/usr && make -e tooldir=/usr install && -make -e tooldir=/usr install-info - - +make -e tooldir=/usr install-info diff --git a/chapter06/binutils.xml b/chapter06/binutils.xml index 6747c7a78..58a07f9ab 100644 --- a/chapter06/binutils.xml +++ b/chapter06/binutils.xml @@ -1,10 +1,8 @@ Installing Binutils - -Estimated build time: &binutils-time; -Estimated disk space required: &binutils-compsize; - +Estimated build time: &binutils-time; +Estimated disk space required: &binutils-compsize; &c6-binutils-inst; &aa-binutils-desc; diff --git a/chapter06/bison-exp.xml b/chapter06/bison-exp.xml index 250f345ce..2ba311845 100644 --- a/chapter06/bison-exp.xml +++ b/chapter06/bison-exp.xml @@ -1,10 +1,8 @@ Command explanations - ---datadir=/usr/share/bison: This installs the -bison grammar files in /usr/share/bison rather than /usr/share. - +--datadir=/usr/share/bison: This installs the +bison grammar files in /usr/share/bison rather than /usr/share. diff --git a/chapter06/bison-inst.xml b/chapter06/bison-inst.xml index 8d83c0bad..d196366f2 100644 --- a/chapter06/bison-inst.xml +++ b/chapter06/bison-inst.xml @@ -1,34 +1,22 @@ Installation of Bison - -Install Bison by running the following commands: - +Install Bison by running the following commands: - - -./configure --prefix=/usr \ +./configure --prefix=/usr \    --datadir=/usr/share/bison && make && -make install - - +make install - -Some programs don't know about bison and try to find the yacc program +Some programs don't know about bison and try to find the yacc program (bison is a (better) alternative for yacc). So to please those few programs out there we'll create a yacc script that calls bison and have -it emulate yacc's output file name conventions). - +it emulate yacc's output file name conventions). - -Create a new file /usr/bin/yacc by running the -following: - +Create a new file /usr/bin/yacc by running the +following: - - -cat > /usr/bin/yacc << "EOF" +cat > /usr/bin/yacc << "EOF" #!/bin/sh # Begin /usr/bin/yacc @@ -36,9 +24,7 @@ following: # End /usr/bin/yacc EOF -chmod 755 /usr/bin/yacc - - +chmod 755 /usr/bin/yacc diff --git a/chapter06/bison.xml b/chapter06/bison.xml index 790da35fb..417d18e72 100644 --- a/chapter06/bison.xml +++ b/chapter06/bison.xml @@ -1,10 +1,8 @@ Installing Bison - -Estimated build time: &bison-time; -Estimated disk space required: &bison-compsize; - +Estimated build time: &bison-time; +Estimated disk space required: &bison-compsize; &c6-bison-inst; &c6-bison-exp; diff --git a/chapter06/bzip2-exp.xml b/chapter06/bzip2-exp.xml index 99eded1d5..327455c97 100644 --- a/chapter06/bzip2-exp.xml +++ b/chapter06/bzip2-exp.xml @@ -1,19 +1,15 @@ Command explanations - -make -f Makefile-libbz2_so: This will cause bzip2 +make -f Makefile-libbz2_so: This will cause bzip2 to be build using a different Makefile file, in this case the Makefile-libbz2_so file which creates a dynamic libbz2.so library and -links the bzip2 utilities against it. - +links the bzip2 utilities against it. - -The reason we don't use make install is that +The reason we don't use make install is that bzip2's make install doesn't install the shared libbz2.so, nor the bzip2 binary that's linked against that library. So we have no choice but to -manually install the files. - +manually install the files. diff --git a/chapter06/bzip2-inst.xml b/chapter06/bzip2-inst.xml index 8a9cc2880..551818ac2 100644 --- a/chapter06/bzip2-inst.xml +++ b/chapter06/bzip2-inst.xml @@ -1,13 +1,9 @@ Installation of Bzip2 - -Install Bzip2 by running the following commands: - +Install Bzip2 by running the following commands: - - -make -f Makefile-libbz2_so && +make -f Makefile-libbz2_so && make bzip2recover libbz2.a && cp bzip2-shared /bin/bzip2 && cp bzip2recover /bin && @@ -21,20 +17,16 @@ Install Bzip2 by running the following commands: cd /usr/share/man/man1 && ln -s bzip2.1 bunzip2.1 && ln -s bzip2.1 bzcat.1 && -ln -s bzip2.1 bzip2recover.1 - - +ln -s bzip2.1 bzip2recover.1 - -Although it's not strictly a part of a basic LFS system it's worth +Although it's not strictly a part of a basic LFS system it's worth mentioning that a patch for Tar can be downloaded which enables the tar program to compress and uncompress using bzip2/bunzip2 easily. With a plain tar a user has to use constructions like bzcat file.tar.bz|tar xv or tar --use-compress-prog=bunzip2 -xvf file.tar.bz2 to use bzip2 and bunzip2 with tar. This patch gives the -y option so a user can unpack a Bzip2 archive with tar xvfy file.tar.bz2. Applying this patch will be -mentioned later on when the Tar package is re-installed. - +mentioned later on when the Tar package is re-installed. diff --git a/chapter06/bzip2.xml b/chapter06/bzip2.xml index dade55e31..7dd130375 100644 --- a/chapter06/bzip2.xml +++ b/chapter06/bzip2.xml @@ -1,10 +1,8 @@ Installing Bzip2 - -Estimated build time: &bzip2-time; -Estimated disk space required: &bzip2-compsize; - +Estimated build time: &bzip2-time; +Estimated disk space required: &bzip2-compsize; &c6-bzip2-inst; &c6-bzip2-exp; diff --git a/chapter06/chroot.xml b/chapter06/chroot.xml index c025085dd..59c312f03 100644 --- a/chapter06/chroot.xml +++ b/chapter06/chroot.xml @@ -1,47 +1,33 @@ Entering the chroot'ed environment - -It's time to enter our chroot'ed environment in order to install the -rest of the software we need. - +It's time to enter our chroot'ed environment in order to install the +rest of the software we need. - -Enter the following commands to enter the chroot'ed environment. From +Enter the following commands to enter the chroot'ed environment. From this point on there's no need to use the $LFS variable anymore, because everything a user does will be restricted to the LFS partition (since / is -actually /mnt/lfs but the shell doesn't know that). - +actually /mnt/lfs but the shell doesn't know that). - - -&c6-chrootcmd; - - +&c6-chrootcmd; - -The -i option will clear all environment variables for as long as you +The -i option will clear all environment variables for as long as you are in the chroot'ed environment and only the ROOT and TERM variables are rest. The TERM=$TERM construction will set the $TERM value inside chroot to the same value as outside chroot which is needed for programs like vim and less to operate properly. If you need other variables -present, such as CFLAGS or CXXFLAGS, you need to set them again. - +present, such as CFLAGS or CXXFLAGS, you need to set them again. - -Now that we are inside a chroot'ed environment, we can continue to +Now that we are inside a chroot'ed environment, we can continue to install all the basic system software. You have to make sure all the following commands in this and following chapters are run from within the chroot'ed environment. If you ever leave this environment for any reason (when rebooting for example) please remember to mount $LFS/proc again and re-enter chroot before continuing with the -book. - +book. - -Note that the bash prompt will contain "I have no name!" This is -normal because Glibc hasn't been installed yet. - +Note that the bash prompt will contain "I have no name!" This is +normal because Glibc hasn't been installed yet. diff --git a/chapter06/config-glibc.xml b/chapter06/config-glibc.xml index f5b9787da..3c5fb97ce 100644 --- a/chapter06/config-glibc.xml +++ b/chapter06/config-glibc.xml @@ -1,20 +1,14 @@ Configuring Glibc - -We need to create the /etc/nsswitch.conf file. Although glibc should provide -defaults when this file is missing or corrupt, it's defaults don't work +We need to create the /etc/nsswitch.conf file. Although glibc should +provide defaults when this file is missing or corrupt, it's defaults don't work well with networking which will be dealt with in a later chapter. Also, our -timezone needs to be setup. - +timezone needs to be setup. - -Create a new file /etc/nsswitch.conf by running the -following: - +Create a new file /etc/nsswitch.conf by running the +following: - - -cat > /etc/nsswitch.conf << "EOF" +cat > /etc/nsswitch.conf << "EOF" # Begin /etc/nsswitch.conf passwd: files @@ -34,53 +28,29 @@ rpc: db files netgroup: db files # End /etc/nsswitch.conf -EOF - - +EOF - -The tzselect script has to be run and the questions -regarding your timezone have to be answered. +The tzselect script has to be run and the +questions regarding your timezone have to be answered. When you're done, the script will give the -location of the needed timezone file. - - - -Create the /etc/localtime symlink -by running: - - - - -cd /etc && -ln -sf ../usr/share/zoneinfo/<tzselect's output> localtime - - - - -tzselect's output can be something like EST5EDT or -Canada/Eastern. - - - -The symlink you'd create with that information would be: - - - - -ln -sf ../usr/share/zoneinfo/EST5EDT localtime - - - - -Or: - - - - -ln -sf ../usr/share/zoneinfo/Canada/Eastern localtime - - +location of the needed timezone file. + + Create the /etc/localtime symlink +by running: + +cd /etc && +ln -sf ../usr/share/zoneinfo/<tzselect's output> localtime + +tzselect's output can be something like EST5EDT or +Canada/Eastern. + +The symlink you'd create with that information would be: + +ln -sf ../usr/share/zoneinfo/EST5EDT localtime + +Or: + +ln -sf ../usr/share/zoneinfo/Canada/Eastern localtime diff --git a/chapter06/config-ldso.xml b/chapter06/config-ldso.xml index 04fb4960e..7bb4768e8 100644 --- a/chapter06/config-ldso.xml +++ b/chapter06/config-ldso.xml @@ -1,25 +1,19 @@ Configuring Dynamic Loader - -By default the dynamic loader searches a few default paths for dynamic +By default the dynamic loader searches a few default paths for dynamic libraries, so there normally isn't a need for the /etc/ld.so.conf file unless the system has extra directories in which a user wants the system to search for paths. The /usr/local/lib directory isn't searched through for dynamic libraries by default, so we want to add this path so when you install software you won't be surprised by them not -running for some reason. - +running for some reason. - -Create a new file /etc/ld.so.conf by running the -following: - +Create a new file /etc/ld.so.conf by running the +following: - - -cat > /etc/ld.so.conf << "EOF" +cat > /etc/ld.so.conf << "EOF" # Begin /etc/ld.so.conf /lib @@ -27,17 +21,13 @@ following: /usr/local/lib # End /etc/ld.so.conf -EOF - - +EOF - -Although it's not necessary to add the +Although it's not necessary to add the /lib and /usr/lib directories it doesn't hurt. This way it can be seen right away what's being searched and a you -don't have to remember the default search paths if you don't want to. - +don't have to remember the default search paths if you don't want to. diff --git a/chapter06/config-shadowpwd.xml b/chapter06/config-shadowpwd.xml index 8202c12bb..e3b0237c9 100644 --- a/chapter06/config-shadowpwd.xml +++ b/chapter06/config-shadowpwd.xml @@ -1,25 +1,17 @@ Configuring Shadow Password Suite - -This package contains the utilities to modify user's passwords, add new +This package contains the utilities to modify user's passwords, add new users/groups, delete users/groups and more. We're not going to explain what 'password shadowing' means. All about that can be read in the doc/HOWTO file within the unpacked shadow password suite's source tree. There's one thing you should keep in mind, if you decide to use shadow support, that programs that need to verify passwords (examples are xdm, ftp daemons, pop3 daemons, etc) need to be 'shadow-compliant', eg. they need to -be able to work with shadow'ed passwords. - +be able to work with shadow'ed passwords. - -To enable shadow'ed passwords, run the following command: - +To enable shadow'ed passwords, run the following command: - - -/usr/sbin/pwconv - - +/usr/sbin/pwconv diff --git a/chapter06/config-sysklogd.xml b/chapter06/config-sysklogd.xml index 3b52725e3..37ca8fbdd 100644 --- a/chapter06/config-sysklogd.xml +++ b/chapter06/config-sysklogd.xml @@ -1,13 +1,9 @@ Configuring Sysklogd - -Create a new file /etc/syslog.conf by running the -following: - +Create a new file /etc/syslog.conf by running the +following: - - -cat > /etc/syslog.conf << "EOF" +cat > /etc/syslog.conf << "EOF" # Begin /etc/syslog.conf auth,authpriv.* -/var/log/auth.log @@ -19,9 +15,7 @@ user.* -/var/log/user.log *.emerg * # End /etc/syslog.conf -EOF - - +EOF diff --git a/chapter06/config-sysvinit.xml b/chapter06/config-sysvinit.xml index bbb2ae51a..11f0ffabd 100644 --- a/chapter06/config-sysvinit.xml +++ b/chapter06/config-sysvinit.xml @@ -1,13 +1,9 @@ Configuring Sysvinit - -Create a new file /etc/inittab by running the -following: - - - - -cat > /etc/inittab << "EOF" +Create a new file /etc/inittab by running the +following: + +cat > /etc/inittab << "EOF" # Begin /etc/inittab id:3:initdefault: @@ -34,9 +30,7 @@ su:S016:respawn:/sbin/sulogin 6:2345:respawn:/sbin/agetty tty6 9600 # End /etc/inittab -EOF - - +EOF diff --git a/chapter06/config-vim.xml b/chapter06/config-vim.xml index 172d67ffc..ee4124a2f 100644 --- a/chapter06/config-vim.xml +++ b/chapter06/config-vim.xml @@ -1,24 +1,18 @@ Configuring Vim - -By default Vim runs in vi compatible mode. Some people might like this, +By default Vim runs in vi compatible mode. Some people might like this, but we have a high preference to run vim in vim mode (else we wouldn't have included Vim in this book but the original Vi). Create the -/root/.vimrc by running the following: - +/root/.vimrc by running the following: - - -cat > /root/.vimrc << "EOF" +cat > /root/.vimrc << "EOF" " Begin /root/.vimrc set nocompatible set bs=2 " End /root/.vimrc -EOF - - +EOF diff --git a/chapter06/configure.xml b/chapter06/configure.xml index 207597b95..2487f3536 100644 --- a/chapter06/configure.xml +++ b/chapter06/configure.xml @@ -1,10 +1,8 @@ Configuring essential software - -Now that all software is installed, all that we need to do to get a few -programs running properly is to create their configuration files. - +Now that all software is installed, all that we need to do to get a few +programs running properly is to create their configuration files. &c6-cf-vim; &c6-cf-glibc; diff --git a/chapter06/create-password.xml b/chapter06/create-password.xml index 7bbde76f9..d8e182d5f 100644 --- a/chapter06/create-password.xml +++ b/chapter06/create-password.xml @@ -1,16 +1,10 @@ Creating root password - -Choose a password for user root and create it by running the following -command: - +Choose a password for user root and create it by running the following +command: - - -passwd root - - +passwd root diff --git a/chapter06/create-utmp.xml b/chapter06/create-utmp.xml index 93a94fb75..3c8dcd756 100644 --- a/chapter06/create-utmp.xml +++ b/chapter06/create-utmp.xml @@ -2,27 +2,19 @@ Creating the /var/run/utmp, /var/log/wtmp and /var/log/btmp files - -Programs like login, shutdown, uptime and others want to read from and write -to the /var/run/utmp /var/log/btmp and /var/log/wtmp. These files contain +Programs like login, shutdown, uptime and others want to read from and +write to the /var/run/utmp /var/log/btmp and /var/log/wtmp. These files contain information about who is currently logged in. It also contains information on when the computer was last booted and shutdown and a record of the -bad login attempts. - +bad login attempts. - -Create these files with their proper permissions by running the -following commands: - +Create these files with their proper permissions by running the +following commands: - - -touch /var/run/utmp /var/log/wtmp \ +touch /var/run/utmp /var/log/wtmp \     /var/log/btmp /var/log/lastlog && chmod 644 /var/run/utmp /var/log/wtmp \ -   /var/log/btmp /var/log/lastlog - - +   /var/log/btmp /var/log/lastlog diff --git a/chapter06/diffutils-inst.xml b/chapter06/diffutils-inst.xml index 7b3bf5ecd..527866a22 100644 --- a/chapter06/diffutils-inst.xml +++ b/chapter06/diffutils-inst.xml @@ -1,17 +1,11 @@ Installation of Diffutils - -Install Diffutils by running the following commands: - +Install Diffutils by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/diffutils.xml b/chapter06/diffutils.xml index d11ba845e..13e39bb68 100644 --- a/chapter06/diffutils.xml +++ b/chapter06/diffutils.xml @@ -1,10 +1,8 @@ Installing Diffutils - -Estimated build time: &diffutils-time; -Estimated disk space required: &diffutils-compsize; - +Estimated build time: &diffutils-time; +Estimated disk space required: &diffutils-compsize; &c6-diffutils-inst; &aa-diffutils-desc; diff --git a/chapter06/e2fsprogs-inst.xml b/chapter06/e2fsprogs-inst.xml index 39c263be4..4843a3554 100644 --- a/chapter06/e2fsprogs-inst.xml +++ b/chapter06/e2fsprogs-inst.xml @@ -1,25 +1,17 @@ Installation of E2fsprogs - -Install E2fsprogs by running the following commands: - +Install E2fsprogs by running the following commands: - -Please note that the empty --with-root-prefix= option below is supposed -to be like this. We did not forget to supply a value there. - +Please note that the empty --with-root-prefix= option below is supposed +to be like this. We did not forget to supply a value there. - - -./configure --prefix=/usr --with-root-prefix= \ +./configure --prefix=/usr --with-root-prefix= \    --enable-elf-shlibs && make && make install && make install-libs && -mv /usr/sbin/mklost+found /sbin - - +mv /usr/sbin/mklost+found /sbin diff --git a/chapter06/e2fsprogs.xml b/chapter06/e2fsprogs.xml index 6c25f63ff..d9921b7ed 100644 --- a/chapter06/e2fsprogs.xml +++ b/chapter06/e2fsprogs.xml @@ -1,10 +1,8 @@ Installing E2fsprogs - -Estimated build time: &e2fsprogs-time; -Estimated disk space required: &e2fsprogs-compsize; - +Estimated build time: &e2fsprogs-time; +Estimated disk space required: &e2fsprogs-compsize; &c6-e2fsprogs-inst; &aa-e2fsprogs-desc; diff --git a/chapter06/ed-inst.xml b/chapter06/ed-inst.xml index 8c582413f..4e896a9cc 100644 --- a/chapter06/ed-inst.xml +++ b/chapter06/ed-inst.xml @@ -1,18 +1,12 @@ Installation of Ed - -Install Ed by running the following commands: - +Install Ed by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && make install && -mv /usr/bin/ed /usr/bin/red /bin - - +mv /usr/bin/ed /usr/bin/red /bin diff --git a/chapter06/ed.xml b/chapter06/ed.xml index 3ac799728..c43bc1f12 100644 --- a/chapter06/ed.xml +++ b/chapter06/ed.xml @@ -1,10 +1,8 @@ Installing Ed - -Estimated build time: &ed-time; -Estimated disk space required: &ed-compsize; - +Estimated build time: &ed-time; +Estimated disk space required: &ed-compsize; &c6-ed-inst; &aa-ed-desc; diff --git a/chapter06/file-inst.xml b/chapter06/file-inst.xml index 0a084a542..f300117e4 100644 --- a/chapter06/file-inst.xml +++ b/chapter06/file-inst.xml @@ -1,22 +1,16 @@ Installation of File - -Install File by running the following commands: - +Install File by running the following commands: - - -./configure --prefix=/usr --datadir=/usr/share/misc && +./configure --prefix=/usr --datadir=/usr/share/misc && make && -make install - - +make install - -File uses magic numbers to determine a file type. These magic numbers come with -File in a plain text file. File internally compiles this database each time it -is run. This is not the normal type of operation for File since compiling a +File uses magic numbers to determine a file type. These magic numbers +come with File in a plain text file. File internally compiles this database +each time it is run. This is not the normal type of operation for File since +compiling a plain text file each time is not the fastest way to do it. File offers an option "-C" to compile this magic number file. The reason this isn't done automatically is that some people like to work on the magic numbers. On the @@ -24,14 +18,9 @@ other hand many people didn't get it that they should compile the magic numbers, so the author of File added a warning when the plain text magic file is used. As we usually won't work on the plain text magic file, we compile this file, because it's faster, fixes that annoying warning and is how -it was meant to be: - +it was meant to be: - - -file -C - - +file -C diff --git a/chapter06/file.xml b/chapter06/file.xml index 9125c8f2f..ed2d3a9df 100644 --- a/chapter06/file.xml +++ b/chapter06/file.xml @@ -1,10 +1,8 @@ Installing File - -Estimated build time: &file-time; -Estimated disk space required: &file-compsize; - +Estimated build time: &file-time; +Estimated disk space required: &file-compsize; &c6-file-inst; &aa-file-desc; diff --git a/chapter06/fileutils-inst.xml b/chapter06/fileutils-inst.xml index aa882500c..4374d77b7 100644 --- a/chapter06/fileutils-inst.xml +++ b/chapter06/fileutils-inst.xml @@ -1,18 +1,12 @@ Installation of Fileutils - -Install Fileutils by running the following commands: - +Install Fileutils by running the following commands: - - -./configure --prefix=/usr --bindir=/bin \ +./configure --prefix=/usr --bindir=/bin \    --libexecdir=/bin && make && -make install - - +make install diff --git a/chapter06/fileutils.xml b/chapter06/fileutils.xml index 6929da0eb..a3a2fea84 100644 --- a/chapter06/fileutils.xml +++ b/chapter06/fileutils.xml @@ -1,10 +1,8 @@ Installing Fileutils - -Estimated build time: &fileutils-time; -Estimated disk space required: &fileutils-compsize; - +Estimated build time: &fileutils-time; +Estimated disk space required: &fileutils-compsize; &c6-fileutils-inst; &aa-fileutils-desc; diff --git a/chapter06/findutils-inst.xml b/chapter06/findutils-inst.xml index 167930c3a..ea032aa63 100644 --- a/chapter06/findutils-inst.xml +++ b/chapter06/findutils-inst.xml @@ -1,22 +1,15 @@ Installing Findutils - -Before Findutils is installed the findutils patch file has to be unpacked. - +Before Findutils is installed the findutils patch file has +to be unpacked. - -Install Findutils by running the following commands: - +Install Findutils by running the following commands: - - -patch -Np1 -i ../findutils-4.1.patch && +patch -Np1 -i ../findutils-4.1.patch && ./configure --prefix=/usr && make && -make libexecdir=/usr/bin install - - +make libexecdir=/usr/bin install diff --git a/chapter06/findutils.xml b/chapter06/findutils.xml index 8e5d11660..2567d3c17 100644 --- a/chapter06/findutils.xml +++ b/chapter06/findutils.xml @@ -1,10 +1,8 @@ Installing Findutils - -Estimated build time: &findutils-time; -Estimated disk space required: &findutils-compsize; - +Estimated build time: &findutils-time; +Estimated disk space required: &findutils-compsize; &c6-findutils-inst; &aa-findutils-desc; diff --git a/chapter06/flex-inst.xml b/chapter06/flex-inst.xml index efe1801bc..fedd2dc5e 100644 --- a/chapter06/flex-inst.xml +++ b/chapter06/flex-inst.xml @@ -1,19 +1,13 @@ Installation of Flex - -Install Flex by running the following commands: - +Install Flex by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && make install && cd /usr/bin && -ln -s flex lex - - +ln -s flex lex diff --git a/chapter06/flex.xml b/chapter06/flex.xml index 2c8ea0647..07257cf35 100644 --- a/chapter06/flex.xml +++ b/chapter06/flex.xml @@ -1,10 +1,8 @@ Installing Flex - -Estimated build time: &flex-time; -Estimated disk space required: &flex-compsize; - +Estimated build time: &flex-time; +Estimated disk space required: &flex-compsize; &c6-flex-inst; &aa-flex-desc; diff --git a/chapter06/gcc-inst.xml b/chapter06/gcc-inst.xml index c4d77b0af..97e64cc2c 100644 --- a/chapter06/gcc-inst.xml +++ b/chapter06/gcc-inst.xml @@ -1,31 +1,23 @@ Installation of GCC - -Install GCC by running the following commands. These commands will build +Install GCC by running the following commands. These commands will build the C and C++ compiler. Other compilers are available within the gcc package. If you want to build all the other availble compilers too, leave out the --enable-languages=c,c++ option in the configure command. See the GCC documentation for more details on which additional compilers -are available. - +are available. - -Note: the build of other compilers is not tested by the people -who actively work on LFS. - +Note: the build of other compilers is not tested by the people +who actively work on LFS. - - -mkdir ../gcc-build && +mkdir ../gcc-build && cd ../gcc-build && ../gcc-&gcc-version;/configure --prefix=/usr \    --with-slibdir=/lib --enable-shared \    --enable-languages=c,c++ && make bootstrap && -make install - - +make install diff --git a/chapter06/gcc.xml b/chapter06/gcc.xml index 654292101..0c85e10b3 100644 --- a/chapter06/gcc.xml +++ b/chapter06/gcc.xml @@ -1,10 +1,8 @@ Installing GCC - -Estimated build time: &gcc-time; -Estimated disk space required: &gcc-compsize; - +Estimated build time: &gcc-time; +Estimated disk space required: &gcc-compsize; &c6-gcc-inst; &aa-gcc-desc; diff --git a/chapter06/gettext-inst.xml b/chapter06/gettext-inst.xml index 25f3f58fa..384ced5c5 100644 --- a/chapter06/gettext-inst.xml +++ b/chapter06/gettext-inst.xml @@ -1,17 +1,11 @@ Installation of Gettext - -Install Gettext by running the following commands: - +Install Gettext by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/gettext.xml b/chapter06/gettext.xml index 5912a9313..96a2f17fe 100644 --- a/chapter06/gettext.xml +++ b/chapter06/gettext.xml @@ -1,10 +1,8 @@ Installing Gettext - -Estimated build time: &gettext-time; -Estimated disk space required: &gettext-compsize; - +Estimated build time: &gettext-time; +Estimated disk space required: &gettext-compsize; &c6-gettext-inst; &aa-gettext-desc; diff --git a/chapter06/glibc-exp.xml b/chapter06/glibc-exp.xml index 05803155a..36eb6864c 100644 --- a/chapter06/glibc-exp.xml +++ b/chapter06/glibc-exp.xml @@ -1,62 +1,48 @@ Command explanations - -mknod -m 0666 /dev/null c 1 3: Glibc needs a +mknod -m 0666 /dev/null c 1 3: Glibc needs a null device to compile properly. All other devices will be created in the -next section. - +next section. - -touch /etc/ld.so.conf One of the final steps of +touch /etc/ld.so.conf One of the final steps of the Glibc installation is running ldconfig to update the dynamic loader cache. If this file isn't present Glibc will abort with an error that it can't read the file. So we create an empty file for it (the empty file -will have Glibc default to using /lib and /usr/lib which is fine right now). - +will have Glibc default to using /lib and +/usr/lib which is fine right now). - -sed s/"\$(PERL)"/"\/usr\/bin\/perl"/ +sed s/"\$(PERL)"/"\/usr\/bin\/perl"/ ../glibc-2.2.3/malloc/Makefile > tmp~: This sed command searches through ../glibc-2.2.3/malloc/Makefile and converts all occurances of $(PERL) to /usr/bin/perl. The output is then written to the file tmp~. This is done because Glibc can't autodetect perl since it's not installed yet at the time when we install -Glibc. - +Glibc. - -mv tmp~ ../glibc-2.2.3/malloc/Makefile: The file +mv tmp~ ../glibc-2.2.3/malloc/Makefile: The file tmp~ is now moved back to ../glibc-2.2.3/malloc/Makefile. We do this because when using sed, we can't write straight back to this file so we need to -use a temporary file in between. - +use a temporary file in between. - -sed "s/root/0" ../glibc-2.2.3/login/Makefile > +sed "s/root/0" ../glibc-2.2.3/login/Makefile > tmp~: This sed command replaces all occurances of root in ../glibc-2.2.3/login/Makefile with 0. This is because as we don't have glibc on the LFS system yet, usernames can't be resolved to their user id's. Therefore, we replace the username -root with the id 0. - +root with the id 0. - -mv tmp~ ../glibc-2.2.3/login/Makefile: As above, +mv tmp~ ../glibc-2.2.3/login/Makefile: As above, we are using a temporary file (tmp~) to store the -edited Makefile and then copying it back over the original. - +edited Makefile and then copying it back over the original. - ---enable-add-ons: This enables the add-on that -we install with Glibc: linuxthreads - +--enable-add-ons: This enables the add-on that +we install with Glibc: linuxthreads - -sed s/"cross-compiling = yes"/"cross-compiling = no"/ +sed s/"cross-compiling = yes"/"cross-compiling = no"/ config.make > config.make~: This time, we're replacing cross-compiling = yes with cross-compiling = no. We do this because we are @@ -65,13 +51,10 @@ instance, to build a package for an Apple Power PC on an Intel system. The reason Glibc thinks we're cross-compiling is that it can't compile a test program to determin this, so it automatically default to a cross-compiler. The reason for the failed program is because Glibc -hasn't been installed yet. - +hasn't been installed yet. - -mv config.make~ config.make: Again, we are moving -the temporary file over the original. - +mv config.make~ config.make: Again, we are moving +the temporary file over the original. diff --git a/chapter06/glibc-inst.xml b/chapter06/glibc-inst.xml index c83cd5779..a280f91d0 100644 --- a/chapter06/glibc-inst.xml +++ b/chapter06/glibc-inst.xml @@ -1,20 +1,14 @@ Installation of Glibc - -Once glibc has been unpacked as usual and you have cd'ed into the +Once glibc has been unpacked as usual and you have cd'ed into the glibc-&glibc-version; directory, unpack glibc-linuxthreads inside the glibc-&glibc-version; directory, not in /usr/src as you normally -would do. - +would do. - -Install Glibc by running the following commands: - +Install Glibc by running the following commands: - - -mknod -m 0666 /dev/null c 1 3 && +mknod -m 0666 /dev/null c 1 3 && touch /etc/ld.so.conf && mkdir ../glibc-build && cd ../glibc-build && @@ -31,46 +25,30 @@ Install Glibc by running the following commands: mv config.make~ config.make && make && make install && -make localedata/install-locales - - +make localedata/install-locales - -During the configure stage you will see the following warning: - +During the configure stage you will see the following warning: -
-configure: warning: +
configure: warning: *** An auxiliary program is missing or too old; *** some features will be disabled. -*** Check the INSTALL file for required versions. -
+*** Check the INSTALL file for required versions.
- -This warning refers to the missing msgfmt program from the gettext +This warning refers to the missing msgfmt program from the gettext package. But there is nothing to worry about: Glib will still be installed the same way as when msgfmt is present. It can safely be -ignored in our case. - +ignored in our case. - -By exiting the chroot'ed environment and re-entering it, you will be +By exiting the chroot'ed environment and re-entering it, you will be able to get rid of the "I have no name!" message in the command prompt, which is caused by bash's inability to resolve a userid to a username. You don't have to exit and re-enter chroot, but it's highly recommended -to ensure a properly working bash. - +to ensure a properly working bash. - -Run the following commands to accomplish this: - +Run the following commands to accomplish this: - - -logout -&c6-chrootcmd; - - +logout +&c6-chrootcmd;
diff --git a/chapter06/glibc.xml b/chapter06/glibc.xml index b6a0152ea..0440191e5 100644 --- a/chapter06/glibc.xml +++ b/chapter06/glibc.xml @@ -1,10 +1,8 @@ Installing Glibc - -Estimated build time: &glibc-time; -Estimated disk space required: &glibc-compsize; - +Estimated build time: &glibc-time; +Estimated disk space required: &glibc-compsize; &c6-glibc-inst; &c6-glibc-exp; diff --git a/chapter06/grep-inst.xml b/chapter06/grep-inst.xml index 477df7476..43dababa1 100644 --- a/chapter06/grep-inst.xml +++ b/chapter06/grep-inst.xml @@ -1,17 +1,11 @@ Installation of Grep - -Install Grep by running the following commands: - +Install Grep by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/grep.xml b/chapter06/grep.xml index 354545858..341fa4cae 100644 --- a/chapter06/grep.xml +++ b/chapter06/grep.xml @@ -1,10 +1,8 @@ Installing Grep - -Estimated build time: &grep-time; -Estimated disk space required: &grep-compsize; - +Estimated build time: &grep-time; +Estimated disk space required: &grep-compsize; &c6-grep-inst; &aa-grep-desc; diff --git a/chapter06/groff-inst.xml b/chapter06/groff-inst.xml index 5a00d4fd8..7f7d16fad 100644 --- a/chapter06/groff-inst.xml +++ b/chapter06/groff-inst.xml @@ -1,17 +1,11 @@ Installation of Groff - -Install Groff by running the following commands: - +Install Groff by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/groff.xml b/chapter06/groff.xml index 7228dbbb6..e32cdd7e7 100644 --- a/chapter06/groff.xml +++ b/chapter06/groff.xml @@ -1,10 +1,8 @@ Installing Groff - -Estimated build time: &groff-time; -Estimated disk space required: &groff-compsize; - +Estimated build time: &groff-time; +Estimated disk space required: &groff-compsize; &c6-groff-inst; &aa-groff-desc; diff --git a/chapter06/gzip-inst.xml b/chapter06/gzip-inst.xml index 08b03a3a7..5c59c88c1 100644 --- a/chapter06/gzip-inst.xml +++ b/chapter06/gzip-inst.xml @@ -1,13 +1,9 @@ Installation of Gzip - -Install Gzip by running the following commands: - +Install Gzip by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && make install && cd /usr/bin && @@ -17,9 +13,7 @@ Install Gzip by running the following commands: ln -sf gzip gunzip && ln -s gzip zcat && ln -s gzip compress && -ln -s gunzip uncompress - - +ln -s gunzip uncompress diff --git a/chapter06/gzip.xml b/chapter06/gzip.xml index 9ce0e3ee2..cdf1d7385 100644 --- a/chapter06/gzip.xml +++ b/chapter06/gzip.xml @@ -1,10 +1,8 @@ Installing Gzip - -Estimated build time: &gzip-time; -Estimated disk space required: &gzip-compsize; - +Estimated build time: &gzip-time; +Estimated disk space required: &gzip-compsize; &c6-gzip-inst; &aa-gzip-desc; diff --git a/chapter06/introduction.xml b/chapter06/introduction.xml index 3c3c68ee6..f915875aa 100644 --- a/chapter06/introduction.xml +++ b/chapter06/introduction.xml @@ -1,26 +1,21 @@ Introduction - -The installation of all the software is pretty straightforward and +The installation of all the software is pretty straightforward and you will probably think it's so much easier and shorter to give the generic installation instructions for each package and only explain how to install something if a certain package requires an alternate installation method. Although I agree on that, I choose to give the full instructions for each and every package. This is simply to avoid any -possible confusion and errors. - +possible confusion and errors. - -Now would be a good time to take a look at the optimization hint at -http://archive.linuxfromscratch.org/lfs-hints/optimization.txt +Now would be a good time to take a look at the optimization hint at http://archive.linuxfromscratch.org/lfs-hints/optimization.txt if you plan on using compiler optimization for the packages installed in the following chapter. Compiler optimization can make a program run faster, but may also cause some compilation problems. If you run into problems after having used optimization, always try it without optimizing to see if you -can reproduce the problem. - +can reproduce the problem. diff --git a/chapter06/kbd-exp.xml b/chapter06/kbd-exp.xml index 3fa90eb34..e00d4b751 100644 --- a/chapter06/kbd-exp.xml +++ b/chapter06/kbd-exp.xml @@ -1,23 +1,18 @@ Command explanations - ---datadir=/usr/share/kbd: This puts the kbd data files -(fonts, keymaps, and such) in the /usr/share/kbd directory, as the FHS -suggests. - +--datadir=/usr/share/kbd: This puts the kbd +data files (fonts, keymaps, and such) in the /usr/share/kbd directory, as +the FHS suggests. - -rm +rm /usr/share/kbd/keymaps/i386/qwerty/defkeymap.map.gz: We -remove this file because we don't know which keymap you need to use. - +remove this file because we don't know which keymap you +need to use. - -ln -s <path-to-keymap> defkeymap.map.gz +ln -s <path-to-keymap> defkeymap.map.gz With this command you set the default keymap that can be loaded using -the loadkeys -d command. - +the loadkeys -d command. diff --git a/chapter06/kbd-inst.xml b/chapter06/kbd-inst.xml index b6b8e1aec..1733fb310 100644 --- a/chapter06/kbd-inst.xml +++ b/chapter06/kbd-inst.xml @@ -1,38 +1,24 @@ Installation of Kbd - -Install Kbd by running the following commands: - +Install Kbd by running the following commands: - - -./configure --datadir=/usr/share/kbd && +./configure --datadir=/usr/share/kbd && make && make install && -rm /usr/share/kbd/keymaps/i386/qwerty/defkeymap.map.gz - - +rm /usr/share/kbd/keymaps/i386/qwerty/defkeymap.map.gz - -Now we have to choose a default keymap. Explore the +Now we have to choose a default keymap. Explore the /usr/share/kbd/keymaps directory, and find the keymap that you would like to use -as a default. Then execute this command: - +as a default. Then execute this command: - - -cd /usr/share/kbd/keymaps && -ln -s <path-to-keymap> defkeymap.map.gz - - +cd /usr/share/kbd/keymaps && +ln -s <path-to-keymap> defkeymap.map.gz - -Replace <path-to-keymap> with the path to the +Replace <path-to-keymap> with the path to the keymap you have selected, relative to the /usr/share/kbd/keymaps/ directory. For example, if you have chosen the US keymap, you would replace it with -i386/qwerty/us.map.gz. - +i386/qwerty/us.map.gz. diff --git a/chapter06/kbd.xml b/chapter06/kbd.xml index 5857bd2c2..d4e109959 100644 --- a/chapter06/kbd.xml +++ b/chapter06/kbd.xml @@ -1,10 +1,8 @@ Installing Kbd - -Estimated build time: &kbd-time; -Estimated disk space required: &kbd-compsize; - +Estimated build time: &kbd-time; +Estimated disk space required: &kbd-compsize; &c6-kbd-inst; &c6-kbd-exp; diff --git a/chapter06/less-inst.xml b/chapter06/less-inst.xml index 1750d22ec..0a1edeaa0 100644 --- a/chapter06/less-inst.xml +++ b/chapter06/less-inst.xml @@ -1,17 +1,11 @@ Installation of Less - -Install Less by running the following commands: - +Install Less by running the following commands: - - -./configure --prefix=/usr --bindir=/bin && +./configure --prefix=/usr --bindir=/bin && make && -make install - - +make install diff --git a/chapter06/less.xml b/chapter06/less.xml index b723f9122..40d126121 100644 --- a/chapter06/less.xml +++ b/chapter06/less.xml @@ -1,10 +1,8 @@ Installing Less - -Estimated build time: &less-time; -Estimated disk space required: &less-compsize; - +Estimated build time: &less-time; +Estimated disk space required: &less-compsize; &c6-less-inst; &aa-less-desc; diff --git a/chapter06/libtool-inst.xml b/chapter06/libtool-inst.xml index 8e5333702..c0c861846 100644 --- a/chapter06/libtool-inst.xml +++ b/chapter06/libtool-inst.xml @@ -1,17 +1,11 @@ Installation of Libtool - -Install Libtool by running the following commands: - +Install Libtool by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/libtool.xml b/chapter06/libtool.xml index 94135e34d..fc4536b47 100644 --- a/chapter06/libtool.xml +++ b/chapter06/libtool.xml @@ -1,10 +1,8 @@ Installing Libtool - -Estimated build time: &libtool-time; -Estimated disk space required: &libtool-compsize; - +Estimated build time: &libtool-time; +Estimated disk space required: &libtool-compsize; &c6-libtool-inst; &aa-libtool-desc; diff --git a/chapter06/lilo-inst.xml b/chapter06/lilo-inst.xml index e4c8a2b13..03c1eb6c1 100644 --- a/chapter06/lilo-inst.xml +++ b/chapter06/lilo-inst.xml @@ -1,45 +1,32 @@ Installation of Lilo - -We have chosen Lilo because we feel confortable with it, but you may wish to -take a look elsewhere. Someone has written a hint on GRUB at -http://archive.linuxfromscratch.org/lfs-hints/grub-howto.txt, - an alternative boot loader. - - - -Install Lilo by running the following commands: - - - - -make && -make install - - - - -It appears that compilation of this package fails on certain machines +We have chosen Lilo because we feel confortable with it, but you +may wish to take a look elsewhere. Someone has written a hint on +GRUB athttp://archive.linuxfromscratch.org/lfs-hints/grub-howto.txt, + an alternative boot loader. + +Install Lilo by running the following commands: + +make && +make install + +It appears that compilation of this package fails on certain machines when the -g compiler flag is being used. If you can't compile Lilo at all, you should try to remove the -g value from the CFLAGS variable in the -Makefile file. - +Makefile file. - -At the end of the installation the make install process will print a +At the end of the installation the make install process will print a message stating that /sbin/lilo has to be executed to complete the update. Don't do this as it has no use. The /etc/lilo.conf isn't present -yet. We will complete the installation of lilo in chapter 8. - - - -Maybe you'll be interested to know that someone wrote a hint on how to get a -logo instead the the standard LILO prompt or menu. Take a look at it at -http://archive.linuxfromscratch.org/lfs-hints/bootlogo.txt. - +yet. We will complete the installation of lilo in chapter 8. + +Maybe you'll be interested to know that someone wrote a hint on +how to get a logo instead the the standard LILO prompt or menu. Take +a look at it at http://archive.linuxfromscratch.org/lfs-hints/bootlogo.txt +. diff --git a/chapter06/lilo.xml b/chapter06/lilo.xml index 33325f63d..be10b0b86 100644 --- a/chapter06/lilo.xml +++ b/chapter06/lilo.xml @@ -1,10 +1,8 @@ Installing Lilo - -Estimated build time: &lilo-time; -Estimated disk space required: &lilo-compsize; - +Estimated build time: &lilo-time; +Estimated disk space required: &lilo-compsize; &c6-lilo-inst; &aa-lilo-desc; diff --git a/chapter06/m4-inst.xml b/chapter06/m4-inst.xml index 3c20e2a6e..86371eaa5 100644 --- a/chapter06/m4-inst.xml +++ b/chapter06/m4-inst.xml @@ -1,20 +1,13 @@ Installation of M4 - -Install M4 by running the following commands: - +Install M4 by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install - -If the base system is running a 2.0 kernel and the Glibc version is +If the base system is running a 2.0 kernel and the Glibc version is 2.1 then you will most likely get problems executing M4 in the chroot'ed environment due to incompatibilities between the M4 program, Glibc-2.1 and the running 2.0 kernel. If you have problems executing the @@ -23,36 +16,23 @@ the autoconf and automake packages) you'll have to exit the chroot'ed environment and compile M4 statically. This way the binary is linked against Glibc 2.0 (if he runs kernel 2.0, Glibc version is 2.0 as well on a decent system. Kernel 2.0 and Glibc-2.1 don't mix very well) -and won't give any problems. - +and won't give any problems. - -To create a statically linked version of M4, execute the following -commands: - +To create a statically linked version of M4, execute the following +commands: - - -logout +logout cd $LFS/usr/src/m4-1.4 ./configure --prefix=/usr make LDFLAGS=-static -make prefix=$LFS/usr install - - +make prefix=$LFS/usr install - -Now the chroot'ed environment can be re-entered and the +Now the chroot'ed environment can be re-entered and the next package an be installed. If M4 should be re-compiled dynamically, -this can be done -after having rebooted into the LFS system rather than chrooting into it. - - - - -&c6-chrootcmd; - - +this can be done after having rebooted into the LFS system +rather than chrooting into it. + +&c6-chrootcmd; diff --git a/chapter06/m4.xml b/chapter06/m4.xml index ab1b8ce8e..ff03d2e44 100644 --- a/chapter06/m4.xml +++ b/chapter06/m4.xml @@ -1,10 +1,8 @@ Installing M4 - -Estimated build time: &m4-time; -Estimated disk space required: &m4-compsize; - +Estimated build time: &m4-time; +Estimated disk space required: &m4-compsize; &c6-m4-inst; &aa-m4-desc; diff --git a/chapter06/make-inst.xml b/chapter06/make-inst.xml index ebf668ae6..bf818f27c 100644 --- a/chapter06/make-inst.xml +++ b/chapter06/make-inst.xml @@ -1,17 +1,11 @@ Installation of Make - -Install Make by running the following commands: - +Install Make by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/make.xml b/chapter06/make.xml index 4d90cf0ea..202fe7dd9 100644 --- a/chapter06/make.xml +++ b/chapter06/make.xml @@ -1,10 +1,8 @@ Installing Make - -Estimated build time: &make-time; -Estimated disk space required: &make-compsize; - +Estimated build time: &make-time; +Estimated disk space required: &make-compsize; &c6-make-inst; &aa-make-desc; diff --git a/chapter06/makedev-exp.xml b/chapter06/makedev-exp.xml index 7fd515b6c..12c9287b1 100644 --- a/chapter06/makedev-exp.xml +++ b/chapter06/makedev-exp.xml @@ -1,12 +1,10 @@ Command explanations - -./MAKEDEV -v generic: This creates generic +./MAKEDEV -v generic: This creates generic devices. Normally, these devices are all devices you need. It's possible that you are missing some special devices that are needed for your hardware -configuration. Create them with ./MAKEDEV -v <device>. - +configuration. Create them with ./MAKEDEV -v <device>. diff --git a/chapter06/makedev-inst.xml b/chapter06/makedev-inst.xml index f59a1a23b..3ea236280 100644 --- a/chapter06/makedev-inst.xml +++ b/chapter06/makedev-inst.xml @@ -1,29 +1,19 @@ Creating devices - -Note: the MAKEDEV.bz2 file you have unpacked is not an archive, so it -won't create a directory for you to cd into. - +Note: the MAKEDEV.bz2 file you have unpacked is not an archive, so it +won't create a directory for you to cd into. - -Create the device files by running the following commands: - +Create the device files by running the following commands: - - -cp MAKEDEV-1.1 /dev/MAKEDEV && +cp MAKEDEV-1.1 /dev/MAKEDEV && cd /dev && chmod 755 MAKEDEV && -./MAKEDEV -v generic - - +./MAKEDEV -v generic - -MAKEDEV will create hda[1-20] and hdb[1-20] and such but keep in mind +MAKEDEV will create hda[1-20] and hdb[1-20] and such but keep in mind that you may not be able to use all of those devices due to kernel -limitations regarding the max. number of partitions. - +limitations regarding the max. number of partitions. diff --git a/chapter06/man-exp.xml b/chapter06/man-exp.xml index cfb821ccc..02f3f092a 100644 --- a/chapter06/man-exp.xml +++ b/chapter06/man-exp.xml @@ -1,11 +1,9 @@ Command explanations - -patch -Np1 -i ../man-1.5i2.patch: This patch +patch -Np1 -i ../man-1.5i2.patch: This patch changes man so that it uses awk instead of gawk which is the default. -We use this as LFS uses awk instead of gawk. - +We use this as LFS uses awk instead of gawk. diff --git a/chapter06/man-inst.xml b/chapter06/man-inst.xml index 6126fbea0..a92c776c4 100644 --- a/chapter06/man-inst.xml +++ b/chapter06/man-inst.xml @@ -1,24 +1,15 @@ Installation of Man - -Before Man is installed, the man patch file needs to be unpacked. - +Before Man is installed, the man patch file needs to be unpacked. - - -patch -Np1 -i ../man-&man-version;.patch && +patch -Np1 -i ../man-&man-version;.patch && ./configure -default && make && -make install - - +make install - -You may want to take a look at the man hint at -http://archive.linuxfromscratch.org/lfs-hints/man.txt -which deals with formatting and compression issues for man pages. - +You may want to take a look at the man hint at http://archive.linuxfromscratch.org/lfs-hints/man.txt +which deals with formatting and compression issues for man pages. diff --git a/chapter06/man.xml b/chapter06/man.xml index fa0449b4c..009855e0a 100644 --- a/chapter06/man.xml +++ b/chapter06/man.xml @@ -1,10 +1,8 @@ Installing Man - -Estimated build time: &man-time; -Estimated disk space required: &man-compsize; - +Estimated build time: &man-time; +Estimated disk space required: &man-compsize; &c6-man-inst; &c6-man-exp; diff --git a/chapter06/manpages-exp.xml b/chapter06/manpages-exp.xml index be1fa6ea8..af5ff0c75 100644 --- a/chapter06/manpages-exp.xml +++ b/chapter06/manpages-exp.xml @@ -1,11 +1,9 @@ Command explanations - -patch -Np1 -i ../man-pages-&man-pages-version;.patch: +patch -Np1 -i ../man-pages-&man-pages-version;.patch: We patch the man-pages package to include two important missing pages: -ldd's, and ld.so's. - +ldd's, and ld.so's. diff --git a/chapter06/manpages-inst.xml b/chapter06/manpages-inst.xml index 67ce29201..13781a047 100644 --- a/chapter06/manpages-inst.xml +++ b/chapter06/manpages-inst.xml @@ -1,16 +1,10 @@ Installation of Man-pages - -Install Man-pages by running the following command: - +Install Man-pages by running the following command: - - -patch -Np1 -i ../man-pages-&man-pages-version;.patch && -make install - - +patch -Np1 -i ../man-pages-&man-pages-version;.patch && +make install diff --git a/chapter06/manpages.xml b/chapter06/manpages.xml index 4a77284f4..634902bae 100644 --- a/chapter06/manpages.xml +++ b/chapter06/manpages.xml @@ -1,10 +1,8 @@ Installing Man-pages - -Estimated build time: &man-pages-time; -Estimated disk space required: &man-pages-compsize; - +Estimated build time: &man-pages-time; +Estimated disk space required: &man-pages-compsize; &c6-manpages-inst; &c6-manpages-exp; diff --git a/chapter06/mawk-inst.xml b/chapter06/mawk-inst.xml index 631ea0511..87380832b 100644 --- a/chapter06/mawk-inst.xml +++ b/chapter06/mawk-inst.xml @@ -1,20 +1,14 @@ Installation of Mawk - -Install Mawk by running the following commands: - +Install Mawk by running the following commands: - - -./configure && +./configure && make && make BINDIR=/usr/bin \    MANDIR=/usr/share/man/man1 install && cd /usr/bin && -ln -s mawk awk - - +ln -s mawk awk diff --git a/chapter06/mawk.xml b/chapter06/mawk.xml index 1e1334ba0..a43eddea6 100644 --- a/chapter06/mawk.xml +++ b/chapter06/mawk.xml @@ -1,10 +1,8 @@ Installing Mawk - -Estimated build time: &mawk-time; -Estimated disk space required: &mawk-compsize; - +Estimated build time: &mawk-time; +Estimated disk space required: &mawk-compsize; &c6-mawk-inst; &aa-mawk-desc; diff --git a/chapter06/modutils-inst.xml b/chapter06/modutils-inst.xml index dbe9e8480..1002e2892 100644 --- a/chapter06/modutils-inst.xml +++ b/chapter06/modutils-inst.xml @@ -1,23 +1,15 @@ Installation of Modutils - -The 2.4.6 version of modutils does not seem to work properly with the +The 2.4.6 version of modutils does not seem to work properly with the 2.2.x kernels. If you are running a 2.2.x kernel we suggest you -downgrade to modutils 2.4.5 which seems to be working better. - +downgrade to modutils 2.4.5 which seems to be working better. - -Install Modutils by running the following commands: - +Install Modutils by running the following commands: - - -./configure && +./configure && make && -make install - - +make install diff --git a/chapter06/modutils.xml b/chapter06/modutils.xml index b4d25eccd..869d8dd53 100644 --- a/chapter06/modutils.xml +++ b/chapter06/modutils.xml @@ -1,10 +1,8 @@ Installing Modutils - -Estimated build time: &modutils-time; -Estimated disk space required: &modutils-compsize; - +Estimated build time: &modutils-time; +Estimated disk space required: &modutils-compsize; &c6-modutils-inst; &aa-modutils-desc; diff --git a/chapter06/ncurses-exp.xml b/chapter06/ncurses-exp.xml index 78b7a3cde..93eb4ab1b 100644 --- a/chapter06/ncurses-exp.xml +++ b/chapter06/ncurses-exp.xml @@ -1,21 +1,15 @@ Command explanations - -patch -Np1 -F10 -i ../ncurses-5.2.patch: Regular +patch -Np1 -F10 -i ../ncurses-5.2.patch: Regular updates to the ncurses package are provided as patch files so this is -to make the source tree up to date. - +to make the source tree up to date. - ---with-shared: This enables the build of the -shared ncurses library files. - +--with-shared: This enables the build of the +shared ncurses library files. - ---disable-termcap: Disabled the compilation of -termcap fall back support. - +--disable-termcap: Disabled the compilation of +termcap fall back support. diff --git a/chapter06/ncurses-inst.xml b/chapter06/ncurses-inst.xml index b5433a0fe..865d90d66 100644 --- a/chapter06/ncurses-inst.xml +++ b/chapter06/ncurses-inst.xml @@ -1,19 +1,13 @@ Installation of Ncurses - -Install Ncurses by running the following commands: - +Install Ncurses by running the following commands: - - -patch -Np1 -F10 -i ../ncurses-&ncurses-version;.patch && +patch -Np1 -F10 -i ../ncurses-&ncurses-version;.patch && ./configure --prefix=/usr --libdir=/lib \    --with-shared --disable-termcap && make && -make install - - +make install diff --git a/chapter06/ncurses.xml b/chapter06/ncurses.xml index e9f17988e..0e8ddb060 100644 --- a/chapter06/ncurses.xml +++ b/chapter06/ncurses.xml @@ -1,10 +1,8 @@ Installing Ncurses - -Estimated build time: &ncurses-time; -Estimated disk space required: &ncurses-compsize; - +Estimated build time: &ncurses-time; +Estimated disk space required: &ncurses-compsize; &c6-ncurses-inst; &c6-ncurses-exp; diff --git a/chapter06/netkitbase-inst.xml b/chapter06/netkitbase-inst.xml index 9860311d1..c4cc5d3ce 100644 --- a/chapter06/netkitbase-inst.xml +++ b/chapter06/netkitbase-inst.xml @@ -1,25 +1,17 @@ Installation of Netkit-base - -Install Netkit-base by running the following commands: - +Install Netkit-base by running the following commands: - - -./configure && +./configure && make && make install && cd etc.sample && -cp services protocols /etc - - +cp services protocols /etc - -There are other files in the There are other files in the etc.sample directory which might be of -interest to the user. - +interest to the user. diff --git a/chapter06/netkitbase.xml b/chapter06/netkitbase.xml index 3d6ef1a81..9980f2548 100644 --- a/chapter06/netkitbase.xml +++ b/chapter06/netkitbase.xml @@ -1,10 +1,8 @@ Installing Netkit-base - -Estimated build time: &netkit-base-time; -Estimated disk space required: &netkit-base-compsize; - +Estimated build time: &netkit-base-time; +Estimated disk space required: &netkit-base-compsize; &c6-netkitbase-inst; &aa-netkitbase-desc; diff --git a/chapter06/nettools-inst.xml b/chapter06/nettools-inst.xml index 37fd86d0d..efdc164ff 100644 --- a/chapter06/nettools-inst.xml +++ b/chapter06/nettools-inst.xml @@ -1,16 +1,10 @@ Installation of Net-tools - -Install Net-tools by running the following commands: - +Install Net-tools by running the following commands: - - -make && -make install - - +make && +make install diff --git a/chapter06/nettools.xml b/chapter06/nettools.xml index 6c74449af..ed218c6c2 100644 --- a/chapter06/nettools.xml +++ b/chapter06/nettools.xml @@ -1,10 +1,8 @@ Installing Net-tools - -Estimated build time: &net-tools-time; -Estimated disk space required: &net-tools-compsize; - +Estimated build time: &net-tools-time; +Estimated disk space required: &net-tools-compsize; &c6-nettools-inst; &aa-nettools-desc; diff --git a/chapter06/patch-inst.xml b/chapter06/patch-inst.xml index ff9c2a365..bf921f26f 100644 --- a/chapter06/patch-inst.xml +++ b/chapter06/patch-inst.xml @@ -1,17 +1,11 @@ Installation of Patch - -Install Patch by running the following commands: - +Install Patch by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/patch.xml b/chapter06/patch.xml index 537be5943..e8eb1fc54 100644 --- a/chapter06/patch.xml +++ b/chapter06/patch.xml @@ -1,10 +1,8 @@ Installing Patch - -Estimated build time: &patch-time; -Estimated disk space required: &patch-compsize; - +Estimated build time: &patch-time; +Estimated disk space required: &patch-compsize; &c6-patch-inst; &aa-patch-desc; diff --git a/chapter06/perl-inst.xml b/chapter06/perl-inst.xml index 1e7e28015..3c0133859 100644 --- a/chapter06/perl-inst.xml +++ b/chapter06/perl-inst.xml @@ -1,33 +1,21 @@ Installation of Perl - -Install Perl by running the following commands: - +Install Perl by running the following commands: - - -./Configure -Dprefix=/usr && +./Configure -Dprefix=/usr && make && -make install - - +make install - -If you don't want to answer all those questions Perl asks, you can +If you don't want to answer all those questions Perl asks, you can add the -d option to the configure script and Perl will use all the default settings. To avoid the Configure script asking questions after the config.sh file has been created you can pass the -e parameter -to perl as well. The commands with these parameters included will be: - +to perl as well. The commands with these parameters included will be: - - -./Configure -Dprefix=/usr -d -e && +./Configure -Dprefix=/usr -d -e && make && -make install - - +make install diff --git a/chapter06/perl.xml b/chapter06/perl.xml index e6862f2ef..0856b4c99 100644 --- a/chapter06/perl.xml +++ b/chapter06/perl.xml @@ -1,10 +1,8 @@ Installing Perl - -Estimated build time: &perl-time; -Estimated disk space required: &perl-compsize; - +Estimated build time: &perl-time; +Estimated disk space required: &perl-compsize; &c6-perl-inst; &aa-perl-desc; diff --git a/chapter06/procinfo-exp.xml b/chapter06/procinfo-exp.xml index f9adca8a6..18a53165a 100644 --- a/chapter06/procinfo-exp.xml +++ b/chapter06/procinfo-exp.xml @@ -1,14 +1,12 @@ Command explanations - -sed "s/-ltermcap/-lncurses/" Makefile | make -f -: +sed "s/-ltermcap/-lncurses/" Makefile | make -f -: This will replace -ltermcap with -lncurses in the Makefile and pipe the output of sed (the modified Makefile) directly to the make program. This is an alternate and more efficient way to direct the output to a file and tell make to use that alternate file. We do this because libtermcap -is declared obsolete in favor of libncurses. - +is declared obsolete in favor of libncurses. diff --git a/chapter06/procinfo-inst.xml b/chapter06/procinfo-inst.xml index dde3916cb..9aa8ba480 100644 --- a/chapter06/procinfo-inst.xml +++ b/chapter06/procinfo-inst.xml @@ -1,16 +1,10 @@ Installation of Procinfo - -Install Procinfo by running the following commands: - +Install Procinfo by running the following commands: - - -sed "s/-ltermcap/-lncurses/" Makefile | make -f - && -make install - - +sed "s/-ltermcap/-lncurses/" Makefile | make -f - && +make install diff --git a/chapter06/procinfo.xml b/chapter06/procinfo.xml index a65af393d..166e3c064 100644 --- a/chapter06/procinfo.xml +++ b/chapter06/procinfo.xml @@ -1,10 +1,8 @@ Installing Procinfo - -Estimated build time: &procinfo-time; -Estimated disk space required: &procinfo-compsize; - +Estimated build time: &procinfo-time; +Estimated disk space required: &procinfo-compsize; &c6-procinfo-inst; &c6-procinfo-exp; diff --git a/chapter06/procps-exp.xml b/chapter06/procps-exp.xml index 0b5a00c2c..87e7c9a13 100644 --- a/chapter06/procps-exp.xml +++ b/chapter06/procps-exp.xml @@ -1,13 +1,11 @@ Command explanations - -make XSCPT='' install: +make XSCPT='' install: This will set the Makefile variable XSCPT to an empty value so that the XConsole installation is disabled. Otherwise "Make install" tries to copy the file XConsole to /usr/X11R6/bin. -And that directory does not exist, because X is not installed yet. - +And that directory does not exist, because X is not installed yet. diff --git a/chapter06/procps-inst.xml b/chapter06/procps-inst.xml index 65b1fd107..f76bafd5a 100644 --- a/chapter06/procps-inst.xml +++ b/chapter06/procps-inst.xml @@ -1,17 +1,11 @@ Installation of Procps - -Install Procps by running the following commands: - +Install Procps by running the following commands: - - -make && +make && make XSCPT='' install && -mv /usr/bin/kill /bin - - +mv /usr/bin/kill /bin diff --git a/chapter06/procps.xml b/chapter06/procps.xml index 568cb4088..b9466d6c3 100644 --- a/chapter06/procps.xml +++ b/chapter06/procps.xml @@ -1,10 +1,8 @@ Installing Procps - -Estimated build time: &procps-time; -Estimated disk space required: &procps-compsize; - +Estimated build time: &procps-time; +Estimated disk space required: &procps-compsize; &c6-procps-inst; &c6-procps-exp; diff --git a/chapter06/psmisc-inst.xml b/chapter06/psmisc-inst.xml index b8194286a..100817235 100644 --- a/chapter06/psmisc-inst.xml +++ b/chapter06/psmisc-inst.xml @@ -1,17 +1,11 @@ Installation of Psmisc - -Install Psmisc by running the following commands: - +Install Psmisc by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && -make install - - +make install diff --git a/chapter06/psmisc.xml b/chapter06/psmisc.xml index f7e7d4b1b..54d122761 100644 --- a/chapter06/psmisc.xml +++ b/chapter06/psmisc.xml @@ -1,10 +1,8 @@ Installing Psmisc - -Estimated build time: &psmisc-time; -Estimated disk space required: &psmisc-compsize; - +Estimated build time: &psmisc-time; +Estimated disk space required: &psmisc-compsize; &c6-psmisc-inst; &aa-psmisc-desc; diff --git a/chapter06/removeoldnss.xml b/chapter06/removeoldnss.xml index dfba1e670..3d2214870 100644 --- a/chapter06/removeoldnss.xml +++ b/chapter06/removeoldnss.xml @@ -1,17 +1,11 @@ Removing old NSS library files - -If you have copied the NSS Library files from the normal Linux system to the -LFS system (because the normal system runs glibc-2.0) it's time to remove -them now by running: - +If you have copied the NSS Library files from the normal Linux system +to the LFS system (because the normal system runs glibc-2.0) it's time to remove +them now by running: - - -rm /lib/libnss*.so.1 /lib/libnss*2.0* - - +rm /lib/libnss*.so.1 /lib/libnss*2.0* diff --git a/chapter06/sed-inst.xml b/chapter06/sed-inst.xml index 795d72926..bded36b7b 100644 --- a/chapter06/sed-inst.xml +++ b/chapter06/sed-inst.xml @@ -1,17 +1,11 @@ Installation of Sed - -Install Sed by running the following commands: - +Install Sed by running the following commands: - - -./configure --prefix=/usr --bindir=/bin && +./configure --prefix=/usr --bindir=/bin && make && -make install - - +make install diff --git a/chapter06/sed.xml b/chapter06/sed.xml index 54fa042bc..b7cc52ec6 100644 --- a/chapter06/sed.xml +++ b/chapter06/sed.xml @@ -1,10 +1,8 @@ Installing Sed - -Estimated build time: &sed-time; -Estimated disk space required: &sed-compsize; - +Estimated build time: &sed-time; +Estimated disk space required: &sed-compsize; &c6-sed-inst; &aa-sed-desc; diff --git a/chapter06/shadowpwd-exp.xml b/chapter06/shadowpwd-exp.xml index 7343088a1..fc162e326 100644 --- a/chapter06/shadowpwd-exp.xml +++ b/chapter06/shadowpwd-exp.xml @@ -1,18 +1,14 @@ Command explanations - -cp limits login.access and others: These files +cp limits login.access and others: These files were not installed during the installation of the package so we copy them manually as those files are used to configure authentication -details on the system. - +details on the system. - -sed "s|/var/spool/mail|/var/mail|" login.defs.linux > +sed "s|/var/spool/mail|/var/mail|" login.defs.linux > /etc/login.defs: /var/spool/mail is the old location of the -user mailboxes. The location that is used nowadays is /var/mail. - +user mailboxes. The location that is used nowadays is /var/mail. diff --git a/chapter06/shadowpwd-inst.xml b/chapter06/shadowpwd-inst.xml index 668d6dca4..517d1adb2 100644 --- a/chapter06/shadowpwd-inst.xml +++ b/chapter06/shadowpwd-inst.xml @@ -1,21 +1,15 @@ Installation of Shadow Password Suite - -Install the Shadow Password Suite by running the following commands: - +Install the Shadow Password Suite by running the following commands: - - -patch -Np1 -i ../shadow-20001016.patch && +patch -Np1 -i ../shadow-20001016.patch && ./configure --prefix=/usr && make && make install && cd etc && cp limits login.access /etc && -sed "s|/var/spool/mail|/var/mail|" login.defs.linux > /etc/login.defs - - +sed "s|/var/spool/mail|/var/mail|" login.defs.linux > /etc/login.defs diff --git a/chapter06/shadowpwd.xml b/chapter06/shadowpwd.xml index 5eebb9f10..7a2c56c53 100644 --- a/chapter06/shadowpwd.xml +++ b/chapter06/shadowpwd.xml @@ -1,10 +1,8 @@ Installing Shadowpwd - -Estimated build time: &shadow-time; -Estimated disk space required: &shadow-compsize; - +Estimated build time: &shadow-time; +Estimated disk space required: &shadow-compsize; &c6-shadowpwd-inst; &c6-shadowpwd-exp; diff --git a/chapter06/shellutils-inst.xml b/chapter06/shellutils-inst.xml index 4e24c3af6..7b0ac4122 100644 --- a/chapter06/shellutils-inst.xml +++ b/chapter06/shellutils-inst.xml @@ -1,40 +1,28 @@ Installation of Sh-utils - -Install Shellutils by running the following commands: - +Install Shellutils by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && make install && cd /usr/bin && mv date echo false pwd stty /bin && -mv su true uname hostname /bin - - +mv su true uname hostname /bin FHS compliance notes - -There is a command installed in this package which is named test. It is often -used in shell scripts to evaluate conditions, but is more often encountered -in the form of [ condition ]. These brackets are built into -the bash interpreter, but the FHS dictates that there should be a +There is a command installed in this package which is named test. It is +often used in shell scripts to evaluate conditions, but is more often +encountered in the form of [ condition ]. These brackets +are built into the bash interpreter, but the FHS dictates that there should be a [ binary. We create that in this way, while still in the -/usr/bin directory: - - - - -ln -s test [ - - +/usr/bin directory: + +ln -s test [ diff --git a/chapter06/shellutils.xml b/chapter06/shellutils.xml index 0d067b4c1..b726f96a9 100644 --- a/chapter06/shellutils.xml +++ b/chapter06/shellutils.xml @@ -1,10 +1,8 @@ Installing Sh-utils - -Estimated build time: &sh-utils-time; -Estimated disk space required: &sh-utils-compsize; - +Estimated build time: &sh-utils-time; +Estimated disk space required: &sh-utils-compsize; &c6-shellutils-inst; &aa-shellutils-desc; diff --git a/chapter06/sysklogd-inst.xml b/chapter06/sysklogd-inst.xml index 42beb3342..6e01e274c 100644 --- a/chapter06/sysklogd-inst.xml +++ b/chapter06/sysklogd-inst.xml @@ -1,16 +1,10 @@ Installation of Sysklogd - -Install Sysklogd by running the following commands: - +Install Sysklogd by running the following commands: - - -make && -make install - - +make && +make install diff --git a/chapter06/sysklogd.xml b/chapter06/sysklogd.xml index f581cccb7..0d9b63819 100644 --- a/chapter06/sysklogd.xml +++ b/chapter06/sysklogd.xml @@ -1,10 +1,8 @@ Installing Sysklogd - -Estimated build time: &sysklogd-time; -Estimated disk space required: &sysklogd-compsize; - +Estimated build time: &sysklogd-time; +Estimated disk space required: &sysklogd-compsize; &c6-sysklogd-inst; &aa-sysklogd-desc; diff --git a/chapter06/sysvinit-inst.xml b/chapter06/sysvinit-inst.xml index 846c28944..d0a58fbb3 100644 --- a/chapter06/sysvinit-inst.xml +++ b/chapter06/sysvinit-inst.xml @@ -1,8 +1,7 @@ Installation of Sysvinit - -When run levels are changed (for example when going to shutdown +When run levels are changed (for example when going to shutdown the system) the init program is going to send the TERM and KILL signals to all the processes that init started. But init prints a message to the screen saying "sending all processes the TERM signal" and the same for the @@ -10,29 +9,16 @@ KILL signal. This implies that init sends this signal to all the currently running processes, which isn't the case. To avoid this confusion a user can apply the sysvinit patch found on the LFS FTP site to sysvinit that changes the sentence in the shutdown.c file and have it print "sending all -processes started by init the TERM signal". - +processes started by init the TERM signal". - -Apply the patch by running the following command: - +Apply the patch by running the following command: - - -patch -Np1 -i ../sysvinit-2.78.patch - - +patch -Np1 -i ../sysvinit-2.79.patch - -Install Sysvinit by running the following commands: - +Install Sysvinit by running the following commands: - - -make -C src && -make -C src install - - +make -C src && +make -C src install diff --git a/chapter06/sysvinit.xml b/chapter06/sysvinit.xml index d0a7c53f0..166a15ceb 100644 --- a/chapter06/sysvinit.xml +++ b/chapter06/sysvinit.xml @@ -1,10 +1,8 @@ Installing Sysvinit - -Estimated build time: &sysvinit-time; -Estimated disk space required: &sysvinit-compsize; - +Estimated build time: &sysvinit-time; +Estimated disk space required: &sysvinit-compsize; &c6-sysvinit-inst; &aa-sysvinit-desc; diff --git a/chapter06/tar-inst.xml b/chapter06/tar-inst.xml index a70a2c553..91cadabd3 100644 --- a/chapter06/tar-inst.xml +++ b/chapter06/tar-inst.xml @@ -1,39 +1,25 @@ Installation of Tar - -If you want to be able to directly use bzip2 files with tar, you can +If you want to be able to directly use bzip2 files with tar, you can use the tar patch available from the LFS FTP site. This patch will add the -y option to tar which works the same as the -z option to tar (which can be used -for gzip files). - +for gzip files). - -Apply the patch by running the following command: - +Apply the patch by running the following command: - - -cd src && +cd src && patch -i ../../gnutarpatch.txt && -cd .. - - +cd .. - -Install Tar by running the following commands from the toplevel -directory: - +Install Tar by running the following commands from the toplevel +directory: - - -./configure --prefix=/usr --libexecdir=/usr/bin \ +./configure --prefix=/usr --libexecdir=/usr/bin \    --bindir=/bin && make && -make install - - +make install diff --git a/chapter06/tar.xml b/chapter06/tar.xml index aeafc69c5..d28b0bf66 100644 --- a/chapter06/tar.xml +++ b/chapter06/tar.xml @@ -1,10 +1,8 @@ Installing Tar - -Estimated build time: &tar-time; -Estimated disk space required: &tar-compsize; - +Estimated build time: &tar-time; +Estimated disk space required: &tar-compsize; &c6-tar-inst; &aa-tar-desc; diff --git a/chapter06/texinfo-exp.xml b/chapter06/texinfo-exp.xml index 4ab1323f6..7dda4a0d4 100644 --- a/chapter06/texinfo-exp.xml +++ b/chapter06/texinfo-exp.xml @@ -1,11 +1,9 @@ Command explanations - -patch -Np1 -i ../texinfo-4.0.patch: This patch +patch -Np1 -i ../texinfo-4.0.patch: This patch fixes a problem with compiling texinfo on gcc-3.0 systems. More specifically, it moves an #ifdef out of a printf macro in order to be -compatible. - +compatible. diff --git a/chapter06/texinfo-inst.xml b/chapter06/texinfo-inst.xml index 9eadf1ea0..e92fc1058 100644 --- a/chapter06/texinfo-inst.xml +++ b/chapter06/texinfo-inst.xml @@ -1,19 +1,13 @@ Installation of Texinfo - -Install Texinfo by running the following commands: - +Install Texinfo by running the following commands: - - -patch -Np1 -i ../texinfo-&texinfo-version;.patch && +patch -Np1 -i ../texinfo-&texinfo-version;.patch && ./configure --prefix=/usr && make && make install && -make TEXMF=/usr/share/texmf install-tex - - +make TEXMF=/usr/share/texmf install-tex diff --git a/chapter06/texinfo.xml b/chapter06/texinfo.xml index 41791478f..f595ccb5e 100644 --- a/chapter06/texinfo.xml +++ b/chapter06/texinfo.xml @@ -1,10 +1,8 @@ Installing Texinfo - -Estimated build time: &texinfo-time; -Estimated disk space required: &texinfo-compsize; - +Estimated build time: &texinfo-time; +Estimated disk space required: &texinfo-compsize; &c6-texinfo-inst; &c6-texinfo-exp; diff --git a/chapter06/textutils-inst.xml b/chapter06/textutils-inst.xml index 0cba4145f..c22802455 100644 --- a/chapter06/textutils-inst.xml +++ b/chapter06/textutils-inst.xml @@ -1,18 +1,12 @@ Installation of Textutils - -Install Textutils by running the following commands: - +Install Textutils by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && make install && -mv /usr/bin/cat /bin - - +mv /usr/bin/cat /bin diff --git a/chapter06/textutils.xml b/chapter06/textutils.xml index 3d4a83b6f..eef47e50a 100644 --- a/chapter06/textutils.xml +++ b/chapter06/textutils.xml @@ -1,10 +1,8 @@ Installing Textutils - -Estimated build time: &textutils-time; -Estimated disk space required: &textutils-compsize; - +Estimated build time: &textutils-time; +Estimated disk space required: &textutils-compsize; &c6-textutils-inst; &aa-textutils-desc; diff --git a/chapter06/utillinux-exp.xml b/chapter06/utillinux-exp.xml index 93986ef89..6d2b62edd 100644 --- a/chapter06/utillinux-exp.xml +++ b/chapter06/utillinux-exp.xml @@ -1,10 +1,8 @@ Command explanations - -HAVE_SLN=yes: We don't build this program because -it already was installed by Glibc. - +HAVE_SLN=yes: We don't build this program because +it already was installed by Glibc. diff --git a/chapter06/utillinux-inst.xml b/chapter06/utillinux-inst.xml index eaef886fb..77738f2a5 100644 --- a/chapter06/utillinux-inst.xml +++ b/chapter06/utillinux-inst.xml @@ -1,20 +1,14 @@ FHS compliance notes - -The FHS recommends that we use /var/lib/hwclock as the location of the adjtime -file, instead of the usual /etc. To make hwclock, which is part of the -util-linux package, FHS-compliant, run the following. - +The FHS recommends that we use /var/lib/hwclock as the location of the +adjtime file, instead of the usual /etc. To make hwclock, which is part of the +util-linux package, FHS-compliant, run the following. - - -sed "s|etc/adjtime\"\$|var/lib/hwclock/adjtime\"|" \ +sed "s|etc/adjtime\"\$|var/lib/hwclock/adjtime\"|" \    hwclock/hwclock.c > hwclock~ && mv hwclock~ hwclock/hwclock.c && -mkdir /var/lib/hwclock - - +mkdir /var/lib/hwclock @@ -25,16 +19,12 @@ util-linux package, FHS-compliant, run the following. Install Util-Linux by running the following commands: - - -sed s/HAVE_SLN=no/HAVE_SLN=yes/ \ +sed s/HAVE_SLN=no/HAVE_SLN=yes/ \    MCONFIG > MCONFIG~ && mv MCONFIG~ MCONFIG && ./configure && make ADD_RAW=yes && -make ADD_RAW=yes install - - +make ADD_RAW=yes install diff --git a/chapter06/utillinux.xml b/chapter06/utillinux.xml index a9669dee9..5686d393d 100644 --- a/chapter06/utillinux.xml +++ b/chapter06/utillinux.xml @@ -1,10 +1,8 @@ Installing Util-linux - -Estimated build time: &util-linux-time; -Estimated disk space required: &util-linux-compsize; - +Estimated build time: &util-linux-time; +Estimated disk space required: &util-linux-compsize; &c6-utillinux-inst; &c6-utillinux-exp; diff --git a/chapter06/vim-inst.xml b/chapter06/vim-inst.xml index 49424450d..fdc15c7be 100644 --- a/chapter06/vim-inst.xml +++ b/chapter06/vim-inst.xml @@ -1,63 +1,46 @@ Installation of Vim - -If you don't like vim to be installed as an editor on the LFS system, +If you don't like vim to be installed as an editor on the LFS system, you may want to download an alternative and install an editor you prefer. There are a few hints how to install different editors available at -http://www.archive.linuxfromscratch.org/lfs-hints/. The -hints which are currently available are for Emacs, Joe and nano. - +url="http://archive.linuxfromscratch.org/lfs-hints/">http://www.archive.linuxfromscratch.org/lfs-hints/ +. The hints which are currently available are for Emacs, Joe and nano. - -Both the vim-rt and vim-src packages need to be unpacked to install Vim. +Both the vim-rt and vim-src packages need to be unpacked to install Vim. Both packages will unpack their files into the vim-&vim-version; directory. This won't overwrite any files from the other package. So it doesn't matter -in which order it is done. Install Vim by running the following commands: - +in which order it is done. Install Vim by running the following commands: - - -./configure --prefix=/usr && +./configure --prefix=/usr && make && make install && cd /usr/bin && -ln -s vim vi - - +ln -s vim vi - -If you plan on installing the X Window system on your LFS +If you plan on installing the X Window system on your LFS system, you might want to re-compile Vim after you have installed X. Vim comes with a nice GUI version of the editor which requires X and a few other libraries to be installed. For more information read the Vim -documentation. - +documentation. FHS compliance notes - -The FHS says that editors like vim should use /var/lib/<editor> for their -temporary state files, like temporary save files for example. If you wish vim to -conform to the FHS, you should use this command set instead of the one presented -above: - +The FHS says that editors like vim should use /var/lib/<editor> +for their temporary state files, like temporary save files for example. +If you wish vim to conform to the FHS, you should use this command set +instead of the one presented above: - - -./configure --prefix=/usr --localstatedir=/var/lib/vim && +./configure --prefix=/usr --localstatedir=/var/lib/vim && make && make install && cd /usr/bin && ln -s vim vi && -mkdir /var/lib/vim - - +mkdir /var/lib/vim diff --git a/chapter06/vim.xml b/chapter06/vim.xml index e96d078fb..37cc4c495 100644 --- a/chapter06/vim.xml +++ b/chapter06/vim.xml @@ -1,10 +1,8 @@ Installing Vim - -Estimated build time: &vim-time; -Estimated disk space required: &vim-compsize; - +Estimated build time: &vim-time; +Estimated disk space required: &vim-compsize; &c6-vim-inst; &aa-vim-desc; -- cgit v1.2.3-54-g00ecf