gettext: Locale Environment Variables
2.3.2 Locale Environment Variables
----------------------------------
A locale is composed of several _locale categories_, see ⇒
Aspects. When a program looks up locale dependent values, it does
this according to the following environment variables, in priority
order:
1. ‘LANGUAGE’
2. ‘LC_ALL’
3. ‘LC_xxx’, according to selected locale category: ‘LC_CTYPE’,
‘LC_NUMERIC’, ‘LC_TIME’, ‘LC_COLLATE’, ‘LC_MONETARY’,
‘LC_MESSAGES’, ...
4. ‘LANG’
Variables whose value is set but is empty are ignored in this lookup.
‘LANG’ is the normal environment variable for specifying a locale.
As a user, you normally set this variable (unless some of the other
variables have already been set by the system, in ‘/etc/profile’ or
similar initialization files).
‘LC_CTYPE’, ‘LC_NUMERIC’, ‘LC_TIME’, ‘LC_COLLATE’, ‘LC_MONETARY’,
‘LC_MESSAGES’, and so on, are the environment variables meant to
override ‘LANG’ and affecting a single locale category only. For
example, assume you are a Swedish user in Spain, and you want your
programs to handle numbers and dates according to Spanish conventions,
and only the messages should be in Swedish. Then you could create a
locale named ‘sv_ES’ or ‘sv_ES.UTF-8’ by use of the ‘localedef’ program.
But it is simpler, and achieves the same effect, to set the ‘LANG’
variable to ‘es_ES.UTF-8’ and the ‘LC_MESSAGES’ variable to
‘sv_SE.UTF-8’; these two locales come already preinstalled with the
operating system.
‘LC_ALL’ is an environment variable that overrides all of these. It
is typically used in scripts that run particular programs. For example,
‘configure’ scripts generated by GNU autoconf use ‘LC_ALL’ to make sure
that the configuration tests don’t operate in locale dependent ways.
Some systems, unfortunately, set ‘LC_ALL’ in ‘/etc/profile’ or in
similar initialization files. As a user, you therefore have to unset
this variable if you want to set ‘LANG’ and optionally some of the other
‘LC_xxx’ variables.
The ‘LANGUAGE’ variable is described in the next subsection.