diff options
author | Bruce Dubbs <bdubbs@linuxfromscratch.org> | 2020-03-29 20:04:31 +0000 |
---|---|---|
committer | Bruce Dubbs <bdubbs@linuxfromscratch.org> | 2020-03-29 20:04:31 +0000 |
commit | df43be1530e1d385ae634ebc22e5b3000fd362d4 (patch) | |
tree | 28464f2119d5486e9ecd453df42b7eeadfa64e97 /chapter04 | |
parent | 97af73804ecc5887e0b2784e9df903527c5f91e9 (diff) |
Textual updates thanks to Kevin Buckley.
git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@11800 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689
Diffstat (limited to 'chapter04')
-rw-r--r-- | chapter04/settingenviron.xml | 49 |
1 files changed, 46 insertions, 3 deletions
diff --git a/chapter04/settingenviron.xml b/chapter04/settingenviron.xml index 3221bed85..512d30d10 100644 --- a/chapter04/settingenviron.xml +++ b/chapter04/settingenviron.xml @@ -32,8 +32,8 @@ EOF</userinput></screen> ensuring a clean environment.</para> <para>The new instance of the shell is a <emphasis>non-login</emphasis> - shell, which does not read the <filename>/etc/profile</filename> or - <filename>.bash_profile</filename> files, but rather reads the + shell, which does not read, and execute, the conten of <filename>/etc/profile</filename> or + <filename>.bash_profile</filename> files, but rather reads, and executes, the <filename>.bashrc</filename> file instead. Create the <filename>.bashrc</filename> file now:</para> @@ -47,6 +47,12 @@ PATH=/tools/bin:/bin:/usr/bin export LFS LC_ALL LFS_TGT PATH</literal> EOF</userinput></screen> + <variablelist> + <title>The meaning of the command line options in <filename>.bashrc</filename></title> + + <varlistentry> + <term><parameter>set +h</parameter></term> + <listitem> <para>The <command>set +h</command> command turns off <command>bash</command>'s hash function. Hashing is ordinarily a useful feature—<command>bash</command> uses a hash table to remember the @@ -58,33 +64,70 @@ EOF</userinput></screen> <filename class="directory">$LFS/tools</filename> as soon as they are available without remembering a previous version of the same program in a different location.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><parameter>umask 022</parameter></term> + <listitem> <para>Setting the user file-creation mask (umask) to 022 ensures that newly created files and directories are only writable by their owner, but are readable and executable by anyone (assuming default modes are used by the <function>open(2)</function> system call, new files will end up with permission mode 644 and directories with mode 755).</para> + </listitem> + </varlistentry> + <varlistentry> + <term><parameter>LFS=/mnt/lfs</parameter></term> + <listitem> <para>The <envar>LFS</envar> variable should be set to the chosen mount point.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><parameter>LC_ALL=POSIX</parameter></term> + <listitem> <para>The <envar>LC_ALL</envar> variable controls the localization of certain programs, making their messages follow the conventions of a specified country. Setting <envar>LC_ALL</envar> to <quote>POSIX</quote> or <quote>C</quote> (the two are equivalent) ensures that everything will work as expected in the chroot environment.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><parameter>LFS_TGT=(uname -m)-lfs-linux-gnu</parameter></term> + <listitem> <para>The <envar>LFS_TGT</envar> variable sets a non-default, but compatible machine description for use when building our cross compiler and linker and when cross compiling our temporary toolchain. More information is contained in <xref linkend="ch-tools-toolchaintechnotes" role=""/>.</para> + </listitem> + </varlistentry> + <varlistentry> + <term><parameter>PATH=/tools/bin:/bin:/usr/bin</parameter></term> + <listitem> <para>By putting <filename class="directory">/tools/bin</filename> ahead of the standard <envar>PATH</envar>, all the programs installed in <xref linkend="chapter-temporary-tools"/> are picked up by the shell immediately after their installation. This, combined with turning off hashing, limits the risk that old programs are used from the host when the same programs are available in - the chapter 5 environment.</para> + the Chapter 5 environment.</para> + </listitem> + </varlistentry> + + <varlistentry> + <term><parameter>export LFS LC_ALL LFS_TGT PATH</parameter></term> + <listitem> + <para>While the above commands have set some variables, in order + to make them visible within any sub-shells, we export them</para> + </listitem> + </varlistentry> + + </variablelist> <para>Finally, to have the environment fully prepared for building the temporary tools, source the just-created user profile:</para> |