]> arthur.barton.de Git - ConfigScripts.git/commitdiff
Better detect encoding of the terminal
authorAlexander Barton <alex@barton.de>
Mon, 3 Feb 2014 19:25:03 +0000 (20:25 +0100)
committerAlexander Barton <alex@barton.de>
Mon, 3 Feb 2014 19:27:04 +0000 (20:27 +0100)
Note: You should make sure that the system does not set a LANG variable
by default (for example in /etc/default/locale)!

sys/profile

index 67b6314e59994002ab8c197d18b1bee835c9196c..72ea7a6292f23ce7bdc85646d239fd6f94b23c1c 100644 (file)
@@ -1,7 +1,7 @@
 #
 # /etc/profile: system-wide profile for the Bourne shell (sh(1)) and
 # Bourne compatible shells (bash(1), ksh(1), ash(1), ...).
-# Written 2003-2012 by Alexander Barton (alex@barton.de)
+# Written 2003-2014 by Alexander Barton (alex@barton.de)
 #
 
 [ -e ~/.ConfigScripts.debug ] && echo " >> /etc/profile ..."
@@ -13,10 +13,20 @@ export PROFILEREAD
 [ -n "$UID" ] || UID=`id -u`
 export UID
 
-# Indicates LC_CTYPE an UTF-8 terminal?
+# Setup locale and encoding
+if [ -e ~/.ConfigScripts.debug ]; then
+       echo " - TERM=\"$TERM\""
+       echo " - LANG=\"$LANG\""
+       echo " - LC_CTYPE=\"$LC_CTYPE\""
+fi
+# Does LC_CTYPE or LANG indicate an UTF-8 terminal?
+LC_encoding=""
 if [ -n "$LC_CTYPE" ]; then
        LC_encoding="${LC_CTYPE#*.}"
-else
+elif [ -n "$LANG" ]; then
+       LC_encoding="${LANG#*.}"
+fi
+if [ -z "$LC_encoding" ]; then
        case "$TERM" in
                "xterm-"*)
                        LC_encoding="UTF-8"; ;;
@@ -24,9 +34,11 @@ else
                        LC_encoding="ISO8859-1"
        esac
 fi
+[ -e ~/.ConfigScripts.debug ] && echo " - LC_encoding=\"$LC_encoding\" (temp)"
 # Set locale if it is not set or doesn't contain a dot:
 [ "$LANG" = "${LANG#*.}" -a "$LANG" != "C" ] \
        && export LANG="${LANG:-de_DE}.${LC_encoding}"
+[ -e ~/.ConfigScripts.debug ] && echo " - LANG=\"$LANG\" (new)"
 # All system messages should still be in "native" ("C") language for
 # non-X11 sessions:
 [ -z "$GDMSESSION" -a -z "$XDG_SESSION_COOKIE" ] \