Fixing locales: Difference between revisions

From Freephile Wiki
tagged
m Text replacement - "<(\/?)source" to "<$1syntaxhighlight"
 
(One intermediate revision by one other user not shown)
Line 1: Line 1:
I was having locale problems. Why?  I don't know.  But all of a sudden, applications like K3B would complain about locales not being properly set.
== Intro ==
I was having locale problems. Why?  I don't know.  But all of a sudden, applications like K3B ('''see the hack at the end of this article''') would complain about locales not being properly set.


For example, viewing a man page in Konsole would generate a warning about "LC_ALL" not being set
For example, viewing a man page in Konsole would generate a warning about "LC_ALL" not being set
Line 5: Line 6:
So, after reading a zillion webpages, I finally punted and just appended to my <code>~/.bashrc</code> file and man pages worked again
So, after reading a zillion webpages, I finally punted and just appended to my <code>~/.bashrc</code> file and man pages worked again


<source lang="bash">
<syntaxhighlight lang="bash">
export LANG="en_US.UTF-8"
export LANG="en_US.UTF-8"
export LC_ALL="en_US.UTF-8"
export LC_ALL="en_US.UTF-8"
export LANGUAGE="en_US.UTF-8"
export LANGUAGE="en_US.UTF-8"
export LC_CTYPE="en_US.UTF-8"
export LC_CTYPE="en_US.UTF-8"
</source>
</syntaxhighlight>


I ended up editing <code>/var/lib/locales/supported.d/local</code>
I ended up editing <code>/var/lib/locales/supported.d/local</code>
Line 25: Line 26:
</pre>
</pre>


then I did a  
then I did a
<source lang="bash">
<syntaxhighlight lang="bash">
sudo dpkg-reconfigure locales
sudo dpkg-reconfigure locales
</source>
</syntaxhighlight>
which updated my system
which updated my system


That command seems to regenerate all the locales in  <code>/usr/lib/locale/</code>
That command seems to regenerate all the locales in  <code>/usr/lib/locale/</code>


 
== Documentation ==
There are a dizzying number of files, programs and settings involved in locale; and worse -- there are differences between distributions on what commands work, how they work; and where the configurations are stored.
There are a dizzying number of files, programs and settings involved in locale; and worse -- there are differences between distributions on what commands work, how they work; and where the configurations are stored.
I suggest that you start off with  
I suggest that you start off with
<source lang="bash">
<syntaxhighlight lang="bash">
man:/locale-gen
man:/locale-gen
</source>
</syntaxhighlight>
to get an idea of what files are involved in your distribution.
to get an idea of what files are involved in your distribution.


Line 45: Line 46:


All the files in <code>/var/lib/belocs</code>
All the files in <code>/var/lib/belocs</code>
will get updated when you run  
will get updated when you run
<source lang="bash">
<syntaxhighlight lang="bash">
sudo dpkg-reconfigure locales
sudo dpkg-reconfigure locales
</source>
</syntaxhighlight>


== See also ==
== See also ==
Line 57: Line 58:
locale
locale
locale -a
locale -a
locale -m  
locale -m
</pre>
</pre>
are
are


in  
in
<code>/etc/default/locale</code>
<code>/etc/default/locale</code>
I have these two lines:
I have these two lines:
Line 68: Line 69:
LANGUAGE="en_US:en"
LANGUAGE="en_US:en"
</pre>
</pre>
in  
in
<code>/etc/environment</code>
<code>/etc/environment</code>
I have
I have
Line 76: Line 77:
LANG="en_US.UTF-8"
LANG="en_US.UTF-8"
</pre>
</pre>
in  
in
<code>/usr/share/i18n/SUPPORTED</code>
<code>/usr/share/i18n/SUPPORTED</code>
there is a very long list of the supported locales.  You can take any number of them and add them to your  
there is a very long list of the supported locales.  You can take any number of them and add them to your
<code>/var/lib/locales/supported.d/local</code>
<code>/var/lib/locales/supported.d/local</code>
{{ambox  
{{ambox
|text= Caution: each supported locale on your system will take up something like 50MB of space -- so don't choose them all.
|text= Caution: each supported locale on your system will take up something like 50MB of space -- so don't choose them all.
}}
}}


== Workaround ==
== Hack ==
Setting environment variables prior to launching an application is one way to work around this problem, but obviously does not solve it on a system-wise basis.  I used this command in KMenu to get around the fact that the variable ''was'' set system-wide, but didn't get picked up in the application environment:
Setting environment variables prior to launching an application is one way to work around this problem, but obviously does not solve it on a system-wise basis.  I used this command in KMenu to get around the fact that the variable ''was'' set system-wide, but didn't get picked up in the application environment:
<code>
<syntaxhighlight lang="bash">
env LC_ALL='en_US.UTF-8' && k3b %U
env LC_ALL='en_US.UTF-8' && k3b %U
</code>
# or the simpler
LC_ALL=en_US.UTF-8 k3b %U
</syntaxhighlight>
and appended to an existing bug report with the workaround information
and appended to an existing bug report with the workaround information
(note that double quotes do not work in the KMenu environment.)
(note that double quotes do not work in the KMenu environment.)


[[Category:Howto]]
[[Category:Howto]]
[[Category:System Administration]]

Latest revision as of 13:32, 24 February 2025

Intro

I was having locale problems. Why? I don't know. But all of a sudden, applications like K3B (see the hack at the end of this article) would complain about locales not being properly set.

For example, viewing a man page in Konsole would generate a warning about "LC_ALL" not being set

So, after reading a zillion webpages, I finally punted and just appended to my ~/.bashrc file and man pages worked again

export LANG="en_US.UTF-8"
export LC_ALL="en_US.UTF-8"
export LANGUAGE="en_US.UTF-8"
export LC_CTYPE="en_US.UTF-8"

I ended up editing /var/lib/locales/supported.d/local

which already had the line

en_US.UTF-8 UTF-8

to which I added the following two lines

en_US ISO-8859-1
en_US.ISO-8859-15 ISO-8859-15

then I did a

sudo dpkg-reconfigure locales

which updated my system

That command seems to regenerate all the locales in /usr/lib/locale/

Documentation

There are a dizzying number of files, programs and settings involved in locale; and worse -- there are differences between distributions on what commands work, how they work; and where the configurations are stored. I suggest that you start off with

man:/locale-gen

to get an idea of what files are involved in your distribution.

For some reason, I do have an archive on my system (in addition to all the independent files) even though I've never issued the gen command with the archive option, and /etc/belocs/locale-gen.conf does not set the default to archive.

All the files in /var/lib/belocs will get updated when you run

sudo dpkg-reconfigure locales

See also

man:locale(1)

from that man page, you learn what

locale
locale -a
locale -m

are

in /etc/default/locale I have these two lines:

LANG="en_US.UTF-8"
LANGUAGE="en_US:en"

in /etc/environment I have

PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games"
LANGUAGE="en_US:en"
LANG="en_US.UTF-8"

in /usr/share/i18n/SUPPORTED there is a very long list of the supported locales. You can take any number of them and add them to your /var/lib/locales/supported.d/local

Hack

Setting environment variables prior to launching an application is one way to work around this problem, but obviously does not solve it on a system-wise basis. I used this command in KMenu to get around the fact that the variable was set system-wide, but didn't get picked up in the application environment:

env LC_ALL='en_US.UTF-8' && k3b %U
# or the simpler
LC_ALL=en_US.UTF-8 k3b %U

and appended to an existing bug report with the workaround information (note that double quotes do not work in the KMenu environment.)