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'est-à-dire [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écessaire
au support des langues natives. Les configurer convenablement résulte
en ce qui suit :
La sortie des programmes traduite dans la langue native
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 qu'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, de l'heure et des dates
Remplacez <ll>
ci-dessous avec le code à deux lettres de la langue désirée (par
exemple, « en ») et <CC>
avec le code à deux
lettres du pays approprié (par exemple, « GB »). <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 », 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 (« en_GB.iso88591 » dans notre exemple).
LC_ALL=<nom_de_la_locale>
locale charmap
Pour la locale « en_GB.iso88591 », la commande ci-dessus affichera :
ISO-8859-1
Ceci résulte en un paramétrage final de locale avec « en_GB.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=<locale name> locale language LC_ALL=<locale name> locale charmap LC_ALL=<locale name> locale int_curr_symbol LC_ALL=<locale name> locale int_prefix
Les commandes ci-dessus devraient afficher les noms du pays et de la langue, le codage des caractères utilisé par la locale, la monnaie et le préfixe à 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 dans le chapitre 6 ou qu'elle n'est pas supportée 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 :
Warning: locale not supported by Xlib, locale set to C
Dans certains cas Xlib s'attend à ce que le plan de caractère 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 "de_DE.ISO-8859-15@euro" par "de_DE@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"
# Begin /etc/profile
export LANG=<ll>
_<CC>
.<charmap>
<@modifiers>
# End /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 avec un paramètre de bit haut 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, un essai 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 « unknown 8-bit » (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. Par exemple, le programme watch n'affiche que les caractères ASCII dans les locales UTF-8 et n'a pas de telles restrictions dans les locales 8-bit traditionnelles comme en_US. Le travail progresse pour documenter et, si possible, réparer de tels problèmes, voir http://www.linuxfromscratch.org/blfs/view/svn/introduction/locale-issues.html.