source: postlfs/config/profile.xml@ 171a5dd

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 7.10 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts krejzi/svn lazarus lxqt nosym perl-modules plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 171a5dd was dc53944, checked in by Bruce Dubbs <bdubbs@…>, 10 years ago

Reference bash startup section in xorg intro

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@13936 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 18.1 KB
RevLine 
[f8d632a]1<?xml version="1.0" encoding="ISO-8859-1"?>
[6732c094]2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
[f8d632a]4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6]>
7
[78b3cd61]8<sect1 id="postlfs-config-profile" xreflabel="The Bash Shell Startup Files">
[2753b70b]9 <?dbhtml filename="profile.html"?>
10
11 <sect1info>
12 <othername>$LastChangedBy$</othername>
13 <date>$Date$</date>
14 </sect1info>
15
16 <title>The Bash Shell Startup Files</title>
17
18 <para>The shell program <filename>/bin/bash</filename> (hereafter
19 referred to as just "the shell") uses a collection of startup files to
20 help create an environment. Each file has a specific use and
21 may affect login and interactive environments differently. The files in
[384039a]22 the <filename class="directory">/etc</filename> directory generally provide
[2753b70b]23 global settings. If an equivalent file exists in your home directory it may
24 override the global settings.</para>
25
26 <para>An interactive login shell is started after a successful login, using
[384039a]27 <filename>/bin/login</filename>, by reading the <filename>/etc/passwd</filename>
28 file. This shell invocation normally reads <filename>/etc/profile</filename>
29 and its private equivalent <filename>~/.bash_profile</filename> upon
[2753b70b]30 startup.</para>
31
32 <para>An interactive non-login shell is normally started at the command-line
[ba0deaad]33 using a shell program (e.g.,
34 <prompt>[prompt]$</prompt><command>/bin/bash</command>) or by the
[2753b70b]35 <command>/bin/su</command> command. An interactive non-login shell is also
36 started with a terminal program such as <command>xterm</command> or
37 <command>konsole</command> from within a graphical environment. This type of
38 shell invocation normally copies the parent environment and then reads the
39 user's <filename>~/.bashrc</filename> file for additional startup configuration
40 instructions.</para>
41
42 <para>A non-interactive shell is usually present when a shell script is
43 running. It is non-interactive because it is processing a script and not
44 waiting for user input between commands. For these shell invocations, only
45 the environment inherited from the parent shell is used.</para>
46
47 <para> The file <filename>~/.bash_logout</filename> is not used for an
48 invocation of the shell. It is read and executed when a user exits from an
49 interactive login shell.</para>
50
[a05dbe6]51 <para>Many distributions use <filename>/etc/bashrc</filename> for system wide
52 initialization of non-login shells. This file is usually called from the
53 user's <filename>~/.bashrc</filename> file and is not built directly into
54 <command>bash</command> itself. This convention is followed in this
55 section.</para>
[2753b70b]56
[384039a]57 <para>For more information see <command>info bash</command> --
[2753b70b]58 <emphasis role="strong">Nodes: Bash Startup Files and Interactive
[ba0deaad]59 Shells</emphasis>.</para>
60
61 <note>
62 <para>Most of the instructions below are used to create files located in
63 the <filename class='directory'>/etc</filename> directory structure which
64 requires you to execute the commands as the
65 <systemitem class='username'>root</systemitem> user. If you elect to create
66 the files in user's home directories instead, you should run the commands
67 as an unprivileged user.</para>
68 </note>
[2753b70b]69
70 <sect2 id="etc-profile-profile">
71 <title>/etc/profile</title>
72
73 <indexterm zone="postlfs-config-profile etc-profile-profile">
74 <primary sortas="e-etc-profile">/etc/profile</primary>
75 </indexterm>
76
77 <para>Here is a base <filename>/etc/profile</filename>. This file starts by
78 setting up some helper functions and some basic parameters. It specifies some
[ba0deaad]79 <command>bash</command> history parameters and, for security purposes,
[384039a]80 disables keeping a permanent history file for the <systemitem
[2753b70b]81 class="username">root</systemitem> user. It also sets a
82 default user prompt. It then calls small, single purpose scripts in the
83 <filename class='directory'>/etc/profile.d</filename> directory to provide most
[ba0deaad]84 of the initialization.</para>
[2753b70b]85
86 <para>For more information on the escape sequences you can use for your prompt
[ba0deaad]87 (i.e., the <envar>PS1</envar> environment variable) see <command>info
[2753b70b]88 bash</command> -- <emphasis role="strong">Node: Printing a
[ba0deaad]89 Prompt</emphasis>.</para>
[2753b70b]90
[8e37798]91<screen role="root"><?dbfo keep-together="auto"?><userinput>cat &gt; /etc/profile &lt;&lt; "EOF"
[2753b70b]92<literal># Begin /etc/profile
[b554263]93# Written for Beyond Linux From Scratch
94# by James Robertson &lt;jameswrobertson@earthlink.net&gt;
[1a396398]95# modifications by Dagmar d'Surreal &lt;rivyqntzne@pbzpnfg.arg&gt;
[384039a]96
[b554263]97# System wide environment variables and startup programs.
[384039a]98
[b554263]99# System wide aliases and functions should go in /etc/bashrc. Personal
100# environment variables and startup programs should go into
101# ~/.bash_profile. Personal aliases and functions should go into
102# ~/.bashrc.
[384039a]103
[1a396398]104# Functions to help us manage paths. Second argument is the name of the
105# path variable to be modified (default: PATH)
106pathremove () {
107 local IFS=':'
108 local NEWPATH
109 local DIR
110 local PATHVARIABLE=${2:-PATH}
111 for DIR in ${!PATHVARIABLE} ; do
112 if [ "$DIR" != "$1" ] ; then
113 NEWPATH=${NEWPATH:+$NEWPATH:}$DIR
114 fi
115 done
116 export $PATHVARIABLE="$NEWPATH"
[b554263]117}
[384039a]118
[1a396398]119pathprepend () {
120 pathremove $1 $2
121 local PATHVARIABLE=${2:-PATH}
122 export $PATHVARIABLE="$1${!PATHVARIABLE:+:${!PATHVARIABLE}}"
123}
[384039a]124
[1a396398]125pathappend () {
126 pathremove $1 $2
127 local PATHVARIABLE=${2:-PATH}
128 export $PATHVARIABLE="${!PATHVARIABLE:+${!PATHVARIABLE}:}$1"
129}
[384039a]130
[ec7940be]131export -f pathremove pathprepend pathappend
[e9ef7b5e]132
133# Set the initial path
134export PATH=/bin:/usr/bin
135
[1a396398]136if [ $EUID -eq 0 ] ; then
[e9ef7b5e]137 pathappend /sbin:/usr/sbin
[1a396398]138 unset HISTFILE
[b554263]139fi
[384039a]140
[1a396398]141# Setup some environment variables.
142export HISTSIZE=1000
143export HISTIGNORE="&amp;:[bf]g:exit"
[0d7ec6f1]144
[97c713e]145# Set some defaults for graphical systems
146export XDG_DATA_DIRS=/usr/share
147
[410e228b]148# Setup a red prompt for root and a green one for users.
[0d7ec6f1]149NORMAL="\[\e[0m\]"
150RED="\[\e[1;31m\]"
151GREEN="\[\e[1;32m\]"
152if [[ $EUID == 0 ]] ; then
153 PS1="$RED\u [ $NORMAL\w$RED ]# $NORMAL"
154else
155 PS1="$GREEN\u [ $NORMAL\w$GREEN ]\$ $NORMAL"
156fi
[384039a]157
[1a396398]158for script in /etc/profile.d/*.sh ; do
[d3880c0]159 if [ -r $script ] ; then
[1a396398]160 . $script
161 fi
162done
[384039a]163
[dc53944]164uset script RED GREEN NORMAL
165
[2753b70b]166# End /etc/profile</literal>
167EOF</userinput></screen>
[1a396398]168
[2753b70b]169 <sect3 id="etc-profile.d">
170 <title>The /etc/profile.d Directory</title>
[99e8a229]171
[2753b70b]172 <indexterm zone="postlfs-config-profile etc-profile.d">
173 <primary sortas="e-etc-profile.d">/etc/profile.d</primary>
174 </indexterm>
[1a396398]175
[384039a]176 <para>Now create the <filename class='directory'>/etc/profile.d</filename>
[ba0deaad]177 directory, where the individual initialization scripts are placed:</para>
[1a396398]178
[2753b70b]179<screen role="root"><userinput>install --directory --mode=0755 --owner=root --group=root /etc/profile.d</userinput></screen>
[1a396398]180
[2753b70b]181 </sect3>
[1a396398]182
[2753b70b]183 <sect3 id="etc-profile.d-dircolors.sh">
184 <title>/etc/profile.d/dircolors.sh</title>
185
186 <indexterm zone="postlfs-config-profile etc-profile.d-dircolors.sh">
187 <primary sortas="e-etc-profile.d-dircolors.sh">/etc/profile.d/dircolors.sh</primary>
188 </indexterm>
189
190 <para>This script uses the <filename>~/.dircolors</filename> and
191 <filename>/etc/dircolors</filename> files to control the colors of file names in a
192 directory listing. They control colorized output of things like <command>ls
[ba0deaad]193 --color</command>. The explanation of how to initialize these files is at the
[2753b70b]194 end of this section.</para>
195
196<screen role="root"><userinput>cat &gt; /etc/profile.d/dircolors.sh &lt;&lt; "EOF"
[b5905ae]197<literal># Setup for /bin/ls and /bin/grep to support color, the alias is in /etc/bashrc.
[1a396398]198if [ -f "/etc/dircolors" ] ; then
199 eval $(dircolors -b /etc/dircolors)
[384039a]200
[1a396398]201 if [ -f "$HOME/.dircolors" ] ; then
202 eval $(dircolors -b $HOME/.dircolors)
203 fi
[b554263]204fi
[b5905ae]205alias ls='ls --color=auto'
206alias grep='grep --color=auto'</literal>
[2753b70b]207EOF</userinput></screen>
208
209 </sect3>
210
211 <sect3 id="extrapaths.sh">
212 <title>/etc/profile.d/extrapaths.sh</title>
213
214 <indexterm zone="postlfs-config-profile extrapaths.sh">
215 <primary sortas="e-etc-profile.d-extrapaths.sh">/etc/profile.d/extrapaths.sh</primary>
216 </indexterm>
217
[dc53944]218 <para>This script adds some useful paths to the <envar>PATH</envar> and
219 can be used to customize other PATH related environment variables
220 (e.g. LD_LIBRARY_PATH, etc) that may be needed for all users.</para>
[384039a]221
[2753b70b]222<screen role="root"><userinput>cat &gt; /etc/profile.d/extrapaths.sh &lt;&lt; "EOF"
223<literal>if [ -d /usr/local/lib/pkgconfig ] ; then
[1a396398]224 pathappend /usr/local/lib/pkgconfig PKG_CONFIG_PATH
225fi
226if [ -d /usr/local/bin ]; then
227 pathprepend /usr/local/bin
[b554263]228fi
[1a396398]229if [ -d /usr/local/sbin -a $EUID -eq 0 ]; then
230 pathprepend /usr/local/sbin
[dc53944]231fi</literal>
[2753b70b]232EOF</userinput></screen>
233
234 </sect3>
235
236 <sect3 id="readline.sh">
237 <title>/etc/profile.d/readline.sh</title>
238
239 <indexterm zone="postlfs-config-profile readline.sh">
240 <primary sortas="e-etc-profile.d-readline.sh">/etc/profile.d/readline.sh</primary>
241 </indexterm>
242
[384039a]243 <para>This script sets up the default <filename>inputrc</filename>
244 configuration file. If the user does not have individual settings, it uses the
[2753b70b]245 global file.</para>
246
247<screen role="root"><userinput>cat &gt; /etc/profile.d/readline.sh &lt;&lt; "EOF"
248<literal># Setup the INPUTRC environment variable.
[b554263]249if [ -z "$INPUTRC" -a ! -f "$HOME/.inputrc" ] ; then
[1a396398]250 INPUTRC=/etc/inputrc
[b554263]251fi
[2753b70b]252export INPUTRC</literal>
253EOF</userinput></screen>
254
255 </sect3>
256
257 <sect3 id="umask.sh">
258 <title>/etc/profile.d/umask.sh</title>
259
260 <indexterm zone="postlfs-config-profile umask.sh">
261 <primary sortas="e-etc-profile.d-umask.sh">/etc/profile.d/umask.sh</primary>
262 </indexterm>
[384039a]263
264 <para>Setting the <command>umask</command> value is important for security.
265 Here the default group write permissions are turned off for system users and when
[2753b70b]266 the user name and group name are not the same.</para>
[b554263]267
[2753b70b]268<screen role="root"><userinput>cat &gt; /etc/profile.d/umask.sh &lt;&lt; "EOF"
[ec64d28]269<literal># By default, the umask should be set.
[1a396398]270if [ "$(id -gn)" = "$(id -un)" -a $EUID -gt 99 ] ; then
271 umask 002
272else
273 umask 022
[2753b70b]274fi</literal>
275EOF</userinput></screen>
276
277 </sect3>
278
[be409f9a]279<!-- This is handled in the Xorg section of the book
[2753b70b]280 <sect3 id="X.sh">
281 <title>/etc/profile.d/X.sh</title>
[1a396398]282
[2753b70b]283 <indexterm zone="postlfs-config-profile X.sh">
284 <primary sortas="e-etc-profile.d-X.sh">/etc/profile.d/X.sh</primary>
285 </indexterm>
[1a396398]286
[384039a]287 <para>If <application>X</application> is installed, the <envar>PATH</envar>
[2753b70b]288 and <envar>PKG_CONFIG_PATH</envar> variables are also updated.</para>
[1a396398]289
[2753b70b]290<screen role="root"><userinput>cat &gt; /etc/profile.d/X.sh &lt;&lt; "EOF"
291<literal>if [ -x /usr/X11R6/bin/X ]; then
[1a396398]292 pathappend /usr/X11R6/bin
293fi
294if [ -d /usr/X11R6/lib/pkgconfig ] ; then
295 pathappend /usr/X11R6/lib/pkgconfig PKG_CONFIG_PATH
[2753b70b]296fi</literal>
297EOF</userinput></screen>
298
299 </sect3>
[be409f9a]300-->
[2753b70b]301 <sect3 id="i18n.sh">
[0d7ec6f1]302 <title>/etc/profile.d/i18n.sh</title>
[2753b70b]303
304 <indexterm zone="postlfs-config-profile i18n.sh">
305 <primary sortas="e-etc-profile.d-i18n.sh">/etc/profile.d/i18n.sh</primary>
306 </indexterm>
307
[0f442884]308 <para>This script sets an environment variable necessary for
309 native language support. A full discussion on determining this
310 variable can be found on the <ulink
311 url="&lfs-root;/chapter07/profile.html">LFS Bash Shell
312 Startup Files</ulink> page.</para>
[2753b70b]313
314<screen role="root"><userinput>cat &gt; /etc/profile.d/i18n.sh &lt;&lt; "EOF"
315<literal># Set up i18n variables
[0f442884]316export LANG=<replaceable>&lt;ll&gt;</replaceable>_<replaceable>&lt;CC&gt;</replaceable>.<replaceable>&lt;charmap&gt;</replaceable><replaceable>&lt;@modifiers&gt;</replaceable></literal>
[2753b70b]317EOF</userinput></screen>
318
319 </sect3>
320
321 <sect3>
322 <title>Other Initialization Values</title>
323
[384039a]324 <para>Other initialization can easily be added to the
325 <filename>profile</filename> by adding additional scripts to the
[2753b70b]326 <filename class='directory'>/etc/profile.d</filename> directory.</para>
327
328 </sect3>
329
330 </sect2>
331
332 <sect2 id="etc-bashrc-profile">
333 <title>/etc/bashrc</title>
334
335 <indexterm zone="postlfs-config-profile etc-bashrc-profile">
336 <primary sortas="e-etc-bashrc">/etc/bashrc</primary>
337 </indexterm>
338
339 <para>Here is a base <filename>/etc/bashrc</filename>. Comments in the
340 file should explain everything you need.</para>
341
342<screen role="root"><userinput>cat &gt; /etc/bashrc &lt;&lt; "EOF"
[384039a]343<literal># Begin /etc/bashrc
344# Written for Beyond Linux From Scratch
[b554263]345# by James Robertson &lt;jameswrobertson@earthlink.net&gt;
[4e88613]346# updated by Bruce Dubbs &lt;bdubbs@&lfs-domainname;&gt;
[ad33bab6]347
[b554263]348# System wide aliases and functions.
349
350# System wide environment variables and startup programs should go into
351# /etc/profile. Personal environment variables and startup programs
352# should go into ~/.bash_profile. Personal aliases and functions should
353# go into ~/.bashrc
354
[b5905ae]355# Provides colored /bin/ls and /bin/grep commands. Used in conjunction
356# with code in /etc/profile.
[1a396398]357
[b554263]358alias ls='ls --color=auto'
[b5905ae]359alias grep='grep --color=auto'
[b554263]360
[1a396398]361# Provides prompt for non-login shells, specifically shells started
[2753b70b]362# in the X environment. [Review the LFS archive thread titled
[384039a]363# PS1 Environment Variable for a great case study behind this script
[dd362e5]364# addendum.]
[1a396398]365
[0d7ec6f1]366NORMAL="\[\e[0m\]"
367RED="\[\e[1;31m\]"
368GREEN="\[\e[1;32m\]"
369if [[ $EUID == 0 ]] ; then
370 PS1="$RED\u [ $NORMAL\w$RED ]# $NORMAL"
371else
372 PS1="$GREEN\u [ $NORMAL\w$GREEN ]\$ $NORMAL"
373fi
[28a9992]374
[dc53944]375unset RED GREEN NORMAL
376
[2753b70b]377# End /etc/bashrc</literal>
378EOF</userinput></screen>
379
380 </sect2>
381
382 <sect2 id="bash_profile-profile">
383 <title>~/.bash_profile</title>
384
385 <indexterm zone="postlfs-config-profile bash_profile-profile">
386 <primary sortas="e-AA.bash_profile">~/.bash_profile</primary>
387 </indexterm>
388
389 <para>Here is a base <filename>~/.bash_profile</filename>. If you want each
390 new user to have this file automatically, just change the output of
391 the command to <filename>/etc/skel/.bash_profile</filename> and check the
392 permissions after the command is run. You can then copy
393 <filename>/etc/skel/.bash_profile</filename> to the home directories of already
[384039a]394 existing users, including <systemitem class="username">root</systemitem>,
[2753b70b]395 and set the owner and group appropriately.</para>
396
397<screen><userinput>cat &gt; ~/.bash_profile &lt;&lt; "EOF"
398<literal># Begin ~/.bash_profile
[b554263]399# Written for Beyond Linux From Scratch
400# by James Robertson &lt;jameswrobertson@earthlink.net&gt;
[4e88613]401# updated by Bruce Dubbs &lt;bdubbs@&lfs-domainname;&gt;
[b554263]402
[64d97b7c]403# Personal environment variables and startup programs.
[b554263]404
405# Personal aliases and functions should go in ~/.bashrc. System wide
406# environment variables and startup programs are in /etc/profile.
407# System wide aliases and functions are in /etc/bashrc.
408
409if [ -f "$HOME/.bashrc" ] ; then
[76d61ba]410 source $HOME/.bashrc
[b554263]411fi
412
413if [ -d "$HOME/bin" ] ; then
[dc53944]414 pathprepend $HOME/bin
[b554263]415fi
416
[dc53944]417# Having . in the PATH is dangerous
418#if [ $EUID -gt 99 ]; then
419# pathappend .
420#fi
[b554263]421
[2753b70b]422# End ~/.bash_profile</literal>
423EOF</userinput></screen>
424
425 </sect2>
[384039a]426
[2753b70b]427 <sect2 id="bashrc-profile">
428 <title>~/.bashrc</title>
429
430 <indexterm zone="postlfs-config-profile bashrc-profile">
431 <primary sortas="e-AA.bashrc">~/.bashrc</primary>
432 </indexterm>
433
434 <para>Here is a base <filename>~/.bashrc</filename>. The comments and
435 instructions for using <filename class="directory">/etc/skel</filename> for
436 <filename>.bash_profile</filename> above also apply here. Only the target file
437 names are different.</para>
438
439<screen><userinput>cat &gt; ~/.bashrc &lt;&lt; "EOF"
440<literal># Begin ~/.bashrc
[b554263]441# Written for Beyond Linux From Scratch
442# by James Robertson &lt;jameswrobertson@earthlink.net&gt;
443
444# Personal aliases and functions.
445
446# Personal environment variables and startup programs should go in
[64d97b7c]447# ~/.bash_profile. System wide environment variables and startup
[b554263]448# programs are in /etc/profile. System wide aliases and functions are
[384039a]449# in /etc/bashrc.
[b554263]450
451if [ -f "/etc/bashrc" ] ; then
[76d61ba]452 source /etc/bashrc
[b554263]453fi
454
[2753b70b]455# End ~/.bashrc</literal>
456EOF</userinput></screen>
457
458 </sect2>
[384039a]459
460
[2753b70b]461 <sect2 id="bash_logout-profile">
462 <title>~/.bash_logout</title>
463
464 <indexterm zone="postlfs-config-profile bash_logout-profile">
465 <primary sortas="e-AA.bash_logout">~/.bash_logout</primary>
466 </indexterm>
467
468 <para>This is an empty <filename>~/.bash_logout</filename> that can be used as
469 a template. You will notice that the base <filename>~/.bash_logout</filename>
470 does not include a <userinput>clear</userinput> command. This is because the
471 clear is handled in the <filename>/etc/issue</filename> file.</para>
472
473<screen><userinput>cat &gt; ~/.bash_logout &lt;&lt; "EOF"
474<literal># Begin ~/.bash_logout
[b554263]475# Written for Beyond Linux From Scratch
476# by James Robertson &lt;jameswrobertson@earthlink.net&gt;
477
478# Personal items to perform on logout.
479
[2753b70b]480# End ~/.bash_logout</literal>
481EOF</userinput></screen>
482
483 </sect2>
[384039a]484
485
[2753b70b]486 <sect2 id="etc-dircolors-profile">
487 <title>/etc/dircolors</title>
488
489 <indexterm zone="postlfs-config-profile etc-dircolors-profile">
490 <primary sortas="e-etc-dircolors">/etc/dircolors</primary>
491 </indexterm>
492
493 <indexterm zone="postlfs-config-profile etc-dircolors-profile">
494 <primary sortas="e-AA.dircolors">~/.dircolors</primary>
495 </indexterm>
496
497 <para> If you want to use the <filename>dircolors</filename> capability, then
498 run the following command. The <filename class="directory">/etc/skel</filename>
[ba0deaad]499 setup steps shown above also can be used here to provide a
[384039a]500 <filename>~/.dircolors</filename> file when a new user is set up. As before,
[2753b70b]501 just change the output file name on the following command and assure the
[384039a]502 permissions, owner, and group are correct on the files created and/or
[2753b70b]503 copied.</para>
504
505<screen role="root"><userinput>dircolors -p > /etc/dircolors</userinput></screen>
506
507 <para>If you wish to customize the colors used for different file types, you can
[384039a]508 edit the <filename>/etc/dircolors</filename> file. The instructions for setting
[2753b70b]509 the colors are embedded in the file.</para>
510
511
512 <para>Finally, Ian Macdonald has written an excellent collection of tips and
513 tricks to enhance your shell environment. You can read it online at
[ba0deaad]514 <ulink url="http://www.caliban.org/bash/index.shtml"/>.</para>
[2753b70b]515
516 </sect2>
517
[b554263]518</sect1>
Note: See TracBrowser for help on using the repository browser.