Files
xsrc/xfree/xc/programs/xterm/uxterm

72 lines
1.7 KiB
Bash
Executable File

#!/bin/sh
# $XTermId: uxterm,v 1.17 2004/11/29 20:39:26 tom Exp $
# $XFree86: xc/programs/xterm/uxterm,v 1.10 2004/12/01 01:27:47 dickey Exp $
# wrapper script to setup xterm with UTF-8 locale
program=xterm
locale=`(LC_ALL=C LC_CTYPE=C LANG=C locale >/dev/null) 2>&1`
found=no
# Check for -version and -help options, to provide a simple return without
# requiring the program to create a window:
if test $# = 1
then
case $1 in
-v|-ver*|-h|-he*)
$program "$@"
exit $?
;;
esac
fi
# Check environment variables that xterm does, in the same order:
for name in LC_ALL LC_CTYPE LANG
do
eval 'value=$'$name
if test -n "$value" ; then
case $value in
*.utf8|*.UTF8|*.utf-8|*.UTF-8)
found=yes
;;
*.utf8@*|*.UTF8@*|*.utf-8@*|*.UTF-8@*)
found=yes
;;
C|POSIX)
# Yes, I know this is not the same - but why are you
# here then?
value=en_US
;;
esac
break
fi
done
# If we didn't find one that used UTF-8, modify the safest one. Not everyone
# has a UTF-8 locale installed (and there appears to be no trivial/portable way
# to determine whether it is, from a shell script). We could check if the
# user's shell does not reset unknown locale specifiers, but not all shells do.
if test $found != yes ; then
if test -n "$value" ; then
value=`echo ${value} |sed -e 's/[.@].*//'`.UTF-8
else
name="LC_CTYPE"
value="en_US.UTF-8"
fi
eval ${name}=${value}
eval export ${name}
if test -z "$locale" ; then
# The 'locale' program tries to do a sanity check.
check=`(locale >/dev/null) 2>&1`
if test -n "$check" ; then
echo "uxterm tried to use locale $value" >&2
echo "$check" >&2
exit 1
fi
fi
fi
# for testing:
#test -f ./xterm && program=./xterm
exec $program -class UXTerm -title 'uxterm' -u8 "$@"