Le programme shell /bin/bash (dénommé ci-après
« le
shell ») utilise une collection de fichiers de
démarrage pour aider à la création d'un environnement d'exécution.
Chaque fichier a une utilisation spécifique et pourrait avoir des
effets différents sur les environnements de connexion et interactif.
Les fichiers du répertoire /etc
fournissent un paramétrage global. Si un fichier équivalent existe
dans le répertoire personnel, il pourrait surcharger les paramétrages
globaux.
Un shell interactif de connexion est lancé après une connexion
réussie, en utilisant /bin/login, par la lecture du
fichier /etc/passwd
. Un shell
interactif sans connexion est lancé en ligne de commande (c-à-d
[prompt]$
/bin/bash). Un shell non interactif
est habituellement présent quand un script shell est en cours
d'exécution. Il est non interactif parce qu'il traite un script et
n'attend pas une saisie de l'utilisateur entre les commandes.
Pour plus d'informations, voir info bash sous la section Bash Startup Files and Interactive Shells (Fichiers de démarrage de Bash et shells interactifs).
Les fichiers /etc/profile
et
~/.bash_profile
sont lus quand le shell
est appelé en tant que shell interactif de connexion.
Le fichier /etc/profile
de base
ci-dessous configure quelques variables d'environnement nécessaires
au support des langues maternelles. Les configurer convenablement
permet ce qui suit :
La sortie des programmes traduite dans la langue maternelle ;
Un classement correct des caractères en lettres, chiffres et autres classes. Ceci est nécessaire pour que bash accepte correctement les caractères non ASCII dans les lignes de commandes pour les locales autres que l'anglais ;
L'ordre de tri alphabétique correct pour le pays ;
La taille de papier par défaut appropriée ;
Le bon formatage des valeurs monétaires, d'heure et de dates.
Remplacez <ll>
ci-dessous par le code à deux lettres de la langue désirée (par
exemple, « fr ») et <CC>
avec le code à deux
lettres du pays approprié (par exemple, « FR »).
<charmap>
devra être
remplacé avec le jeu de caractères canonique de la locale choisie.
Des modificateurs optionnels comme « @euro » peuvent
aussi être présents.
La liste de toutes les locales supportées par Glibc peut être obtenue en exécutant la commande suivante :
locale -a
Les locales peuvent avoir plusieurs synonymes. Par exemple,
« ISO-8859-1 » est aussi appelée
« iso8859-1 » et « iso88591 ».
Quelques applications ne peuvent pas gérer les différents synonymes
correctement (elles nécessitent par exemple l'écriture de
« UTF-8 » sous la forme « UTF-8 » et non
« utf8 »), donc il est plus sûr de choisir
le nom canonique pour une locale particulière. Pour déterminer le nom
canonique, lancez la commande suivante, où <nom locale>
est l'affichage
donnée par locale-a
pour votre locale préférée (« fr_FR.iso88591 » dans notre exemple).
LC_ALL=<nom_de_la_locale>
locale charmap
Pour la locale « fr_FR.iso88591 », la commande ci-dessus affichera :
ISO-8859-1
Ceci résulte en un paramétrage final de locale avec « fr_FR.ISO-8859-1 ». Il est important que la locale trouvée utilisant l'heuristique ci-dessus soit testée avant d'être ajoutée aux fichiers de démarrage de Bash :
LC_ALL=<nom_de_la_locale> locale language LC_ALL=<nom_de_la_locale> locale charmap LC_ALL=<nom_de_la_locale> locale int_curr_symbol LC_ALL=<nom_de_la_locale> locale int_prefix
Les commandes ci-dessus devraient afficher le nom de la langue, le codage des caractères utilisé par la locale, la monnaie et le préfixe du pays à composer avant de saisir le numéro de téléphone. Si une des commandes ci-dessus échoue avec un message similaire à un de ceux montrés ci-dessous, cela signifie que votre locale n'a pas été installée au chapitre 6 ou qu'elle n'est pas prise en charge par l'installation par défaut de Glibc.
locale: Cannot set LC_* to default locale: No such file or directory
Si cela arrive, vous pouvez soit installer la locale désirée en utilisant la commande localedef soit considérer l'utilisation d'une locale différente. Les instructions suivantes supposent qu'il n'y a pas eu de tels messages de Glibc.
Certains paquets en dehors de LFS pourraient aussi ne pas avoir de support pour la locale que vous avez choisi. Un exemple est la bibliothèque X (qui fait partie du système X Window), qui affiche le message d'erreur suivant si la locale n'est pas exactement identique à celle définie par ses fichiers :
Warning: locale not supported by Xlib, locale set to C
Dans certains cas Xlib s'attend à ce que le plan de caractères soit listé en majuscule avec des tirets canoniques. Par exemple, "ISO-8859-1" plutôt que "iso88591". Il est aussi possible de trouver la spécification adéquate en supprimant la partie charmap de la spécification de la locale. Vous pouvez le vérifier en lançant la commande locale charmap dans les deux locales. Par exemple, vous pourriez vouloir remplacer "fr_FR.ISO-8859-15@euro" par "fr_FR@euro" afin que cette locale soit reconnue par Xlib.
D'autres paquets peuvent aussi mal fonctionner (mais pourraient ne pas nécessairement afficher de messages d'erreurs) si le nom de la locale ne correspond pas à leur attente. Dans de tels cas, vous pouvez obtenir des informations utiles en cherchant comment les autres distributions Linux supportent votre locale.
Une fois que les bons paramètres de locale ont été déterminés, créez
le fichier /etc/profile
:
cat > /etc/profile << "EOF"
# Début de /etc/profile
export LANG=<ll>_<CC>.<charmap><@modifiers>
# Fin de /etc/profile
EOF
Les locales « C » (par défaut) et « en_US » (celle recommandée pour les utilisateurs de langue anglaise vivant aux États-Unis) sont différentes. « C » utilise le codage US-ASCII 7-bit et traite les octets utilisant le bit de poids le plus fort comme des caractères invalides. C'est pourquoi, par exemple, la commande ls les remplace par des points d'interrogation dans cette locale. De même, essayer d'envoyer un mail avec de tels caractères depuis Mutt ou Pine donne l'envoi de messages en version non compatible avec RFC (le codage du mail sortant est indiqué comme « 8-bit inconnu »). Donc, vous ne pouvez utiliser la locale « C » que si vous êtes sûr de ne jamais avoir besoin de caractères 8-bit.
Les locales basées sur UTF-8 ne sont pas bien supportées par beaucoup de programmes. Le travail progresse pour documenter et, si possible, réparer de tels problèmes, voir http://www.fr.linuxfromscratch.org/view/blfs-svn/introduction/locale-issues.html.