Bug #4302: Language settings are wrong when an english variant is first
Rewrote the launcher in python with much improved language handling; renamed it to rungramps.py, and replaced launcher.sh with a minimal shell launcher. Any english selection will now have $LANG set to "C", while $LC_ALL will be set to whatever english variant the user selected (and en_US if she specified just "en"). For languages other than English, $LC_ALL will be set to xx_XX if the language selection had no region (e.g., if the language selection is de, $LANG will be de and $LC_ALL will be de_DE. $LANG will be truncated if the language selection has a region that Gramps doesn't support, but does support the bare language (e.g., if the language selection is de_DE, $LANG will be de because there is no de_DE translation. Gettext is smart enough to get this right without the help, but the check is necessary to ensure that we don't skip over a supported generic language. The language settings can now be overridden for gramps by using the defaults system. svn: r17342
This commit is contained in:
		
							
								
								
									
										170
									
								
								mac/launcher.sh
									
									
									
									
									
								
							
							
						
						
									
										170
									
								
								mac/launcher.sh
									
									
									
									
									
								
							@@ -1,169 +1,3 @@
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
 | 
			
		||||
name="`basename $0`"
 | 
			
		||||
tmp="`pwd`/$0"
 | 
			
		||||
tmp=`dirname "$tmp"`
 | 
			
		||||
tmp=`dirname "$tmp"`
 | 
			
		||||
bundle=`dirname "$tmp"`
 | 
			
		||||
bundle_contents="$bundle"/Contents
 | 
			
		||||
bundle_res="$bundle_contents"/Resources
 | 
			
		||||
bundle_lib="$bundle_res"/lib
 | 
			
		||||
bundle_bin="$bundle_res"/bin
 | 
			
		||||
bundle_data="$bundle_res"/share
 | 
			
		||||
bundle_etc="$bundle_res"/etc
 | 
			
		||||
 | 
			
		||||
export XDG_DATA_DIRS="$bundle_data"
 | 
			
		||||
 | 
			
		||||
export DYLD_LIBRARY_PATH="$bundle_lib"
 | 
			
		||||
export LD_LIBRARY_PATH="$DYLD_LIBRARY_PATH"
 | 
			
		||||
export GTK_DATA_PREFIX="$bundle_res"
 | 
			
		||||
export GTK_EXE_PREFIX="$bundle_res"
 | 
			
		||||
export GTK_PATH="$bundle_res"
 | 
			
		||||
 | 
			
		||||
export GTK2_RC_FILES="$bundle_etc/gtk-2.0/gtkrc"
 | 
			
		||||
export GTK_IM_MODULE_FILE="$bundle_etc/gtk-2.0/gtk.immodules"
 | 
			
		||||
export GDK_PIXBUF_MODULE_FILE="$bundle_etc/gtk-2.0/gdk-pixbuf.loaders"
 | 
			
		||||
export PANGO_RC_FILE="$bundle_etc/pango/pangorc"
 | 
			
		||||
 | 
			
		||||
#Set $PYTHON to point inside the bundle
 | 
			
		||||
export PYTHON="$bundle_contents/MacOS/python"
 | 
			
		||||
#Add the bundle's python modules
 | 
			
		||||
PYTHONPATH="$bundle_lib/python2.6:$PYTHONPATH"
 | 
			
		||||
PYTHONPATH="$bundle_lib/python2.6/site-packages:$PYTHONPATH"
 | 
			
		||||
PYTHONPATH="$bundle_lib/python2.6/site-packages/gtk-2.0:$PYTHONPATH"
 | 
			
		||||
PYTHONPATH="$bundle_lib/python2.6/lib-dynload:$PYTHONPATH"
 | 
			
		||||
#Add our program's modules to $PYTHONPATH. 
 | 
			
		||||
PYTHONPATH="$bundle_lib/pygtk/2.0:$PYTHONPATH"
 | 
			
		||||
export PYTHONPATH
 | 
			
		||||
export GRAMPSDIR="$bundle_data"/gramps
 | 
			
		||||
export GRAMPSI18N="$bundle_data"/locale
 | 
			
		||||
export GRAMPSHOME="$HOME/Library/Application Support"
 | 
			
		||||
 | 
			
		||||
# Set the locale-related variables appropriately:
 | 
			
		||||
unset LANG LC_MESSAGES LC_MONETARY
 | 
			
		||||
 | 
			
		||||
# Has a language ordering been set?
 | 
			
		||||
# If so, set LC_MESSAGES accordingly; otherwise skip it.
 | 
			
		||||
# Set the locale-related variables appropriately:
 | 
			
		||||
unset LANG LC_MESSAGES LC_MONETARY LC_COLLATE
 | 
			
		||||
 | 
			
		||||
# Has a language ordering been set?
 | 
			
		||||
# If so, set LC_MESSAGES and LANG accordingly; otherwise skip it.
 | 
			
		||||
# First step uses sed to clean off the quotes and commas, to change - to _, and change the names for the chinese scripts from "Hans" to CN and "Hant" to TW.
 | 
			
		||||
APPLELANGUAGES=`defaults read .GlobalPreferences AppleLanguages | sed -En   -e 's/\-/_/' -e 's/Hant/TW/' -e 's/Hans/CN/' -e 's/[[:space:]]*\"?([[:alnum:]_]+)\"?,?/\1/p' `
 | 
			
		||||
if test "$APPLELANGUAGES"; then
 | 
			
		||||
    # A language ordering exists.
 | 
			
		||||
    # Test, item per item, to see whether there is an corresponding locale.
 | 
			
		||||
    for L in $APPLELANGUAGES; do
 | 
			
		||||
	#test for exact matches:
 | 
			
		||||
       if test -f "$GRAMPSI18N/${L}/LC_MESSAGES/gramps.mo"; then
 | 
			
		||||
	    export LANG=$L
 | 
			
		||||
            break
 | 
			
		||||
        fi
 | 
			
		||||
	#This is a special case, because often the original strings are in US
 | 
			
		||||
	#English and there is no translation file.
 | 
			
		||||
	if test "x$L" == "xen_US"; then
 | 
			
		||||
	    export LANG=$L
 | 
			
		||||
	    break
 | 
			
		||||
	fi
 | 
			
		||||
	#OK, now test for just the first two letters:
 | 
			
		||||
        if test -f "$GRAMPSI18N/${L:0:2}/LC_MESSAGES/gramps.mo"; then
 | 
			
		||||
	    export LANG=${L:0:2}
 | 
			
		||||
	    break
 | 
			
		||||
	fi
 | 
			
		||||
	#Same thing, but checking for any english variant.
 | 
			
		||||
	if test "x${L:0:2}" == "xen"; then
 | 
			
		||||
	    export LANG=$L
 | 
			
		||||
	    break
 | 
			
		||||
	fi;
 | 
			
		||||
    done  
 | 
			
		||||
fi
 | 
			
		||||
unset APPLELANGUAGES L
 | 
			
		||||
 | 
			
		||||
# If we didn't get a language from the language list, try the Collation preference, in case it's the only setting that exists.
 | 
			
		||||
APPLECOLLATION=`defaults read .GlobalPreferences AppleCollationOrder`
 | 
			
		||||
if test -z "$LANG" -a -n "$APPLECOLLATION"; then
 | 
			
		||||
    if test -f "$GRAMPSI18N/$APPLECOLLATION/LC_MESSAGES/gramps.mo"; then
 | 
			
		||||
	export LANG=$APPLECOLLATION
 | 
			
		||||
    fi
 | 
			
		||||
fi
 | 
			
		||||
if test -n "$APPLECOLLATION"; then
 | 
			
		||||
    export LC_COLLATE=$APPLECOLLATION
 | 
			
		||||
fi
 | 
			
		||||
unset APPLECOLLATION
 | 
			
		||||
 | 
			
		||||
# Continue by attempting to find the Locale preference.
 | 
			
		||||
APPLELOCALE=`defaults read .GlobalPreferences AppleLocale`
 | 
			
		||||
if test -f "$GRAMPSI18N/${APPLELOCALE:0:5}/LC_MESSAGES/gramps.mo"; then
 | 
			
		||||
    if test -z $LANG; then 
 | 
			
		||||
        export LANG="${APPLELOCALE:0:5}"
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
elif test -z $LANG -a -f "$GRAMPSI18N/${APPLELOCALE:0:2}/LC_MESSAGES/gramps.mo"; then
 | 
			
		||||
    export LANG="${APPLELOCALE:0:2}"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
#Next we need to set LC_MESSAGES. If at all possilbe, we want a full
 | 
			
		||||
#5-character locale to avoid the "Locale not supported by C library"
 | 
			
		||||
#warning from Gtk -- even though Gtk will translate with a
 | 
			
		||||
#two-character code.
 | 
			
		||||
if test -n $LANG; then 
 | 
			
		||||
#If the language code matches the applelocale, then that's the message
 | 
			
		||||
#locale; otherwise, if it's longer than two characters, then it's
 | 
			
		||||
#probably a good message locale and we'll go with it.
 | 
			
		||||
    if test $LANG == ${APPLELOCALE:0:5} -o $LANG != ${LANG:0:2}; then
 | 
			
		||||
	export LC_MESSAGES=$LANG
 | 
			
		||||
#Next try if the Applelocale is longer than 2 chars and the language
 | 
			
		||||
#bit matches $LANG
 | 
			
		||||
    elif test $LANG == ${APPLELOCALE:0:2} -a $APPLELOCALE > ${APPLELOCALE:0:2}; then
 | 
			
		||||
	export LC_MESSAGES=${APPLELOCALE:0:5}
 | 
			
		||||
#Fail. Get a list of the locales in $PREFIX/share/locale that match
 | 
			
		||||
#our two letter language code and pick the first one, special casing
 | 
			
		||||
#english to set en_US
 | 
			
		||||
    elif test $LANG == "en"; then
 | 
			
		||||
	export LC_MESSAGES="en_US"
 | 
			
		||||
    else
 | 
			
		||||
	LOC=`find $PREFIX/share/locale -name $LANG???`
 | 
			
		||||
	echo "Locales $LOC"
 | 
			
		||||
	for L in $LOC; do 
 | 
			
		||||
	    export LC_MESSAGES=$L
 | 
			
		||||
	done
 | 
			
		||||
    fi
 | 
			
		||||
else
 | 
			
		||||
#All efforts have failed, so default to US english
 | 
			
		||||
    export LANG="en_US"
 | 
			
		||||
    export LC_MESSAGES="en_US"
 | 
			
		||||
fi
 | 
			
		||||
CURRENCY=`echo $APPLELOCALE |  sed -En 's/.*currency=([[:alpha:]]+).*/\1/p'`
 | 
			
		||||
if test "x$CURRENCY" != "x"; then 
 | 
			
		||||
#The user has set a special currency. Gtk doesn't install LC_MONETARY files, but Apple does in /usr/share/locale, so we're going to look there for a locale to set LC_CURRENCY to.
 | 
			
		||||
    if test -f /usr/local/share/$LC_MESSAGES/LC_MONETARY; then
 | 
			
		||||
	if test -a `cat /usr/local/share/$LC_MESSAGES/LC_MONETARY` == $CURRENCY; then
 | 
			
		||||
	    export LC_MONETARY=$LC_MESSAGES
 | 
			
		||||
	fi
 | 
			
		||||
    fi
 | 
			
		||||
    if test -z "$LC_MONETARY"; then 
 | 
			
		||||
	FILES=`find /usr/share/locale -name LC_MONETARY -exec grep -H $CURRENCY {} \;`
 | 
			
		||||
	if test -n "$FILES"; then 
 | 
			
		||||
	    export LC_MONETARY=`echo $FILES | sed -En 's%/usr/share/locale/([[:alpha:]_]+)/LC_MONETARY.*%\1%p'`
 | 
			
		||||
	fi
 | 
			
		||||
    fi
 | 
			
		||||
fi
 | 
			
		||||
#No currency value means that the AppleLocale governs:
 | 
			
		||||
if test -z "$LC_MONETARY"; then
 | 
			
		||||
    export LC_MONETARY=${APPLELOCALE:0:5}
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
#To turn on the appropriate dictionary:
 | 
			
		||||
export LC_ALL=$LC_MESSAGES
 | 
			
		||||
 | 
			
		||||
unset APPLELOCALE  FILES LOC
 | 
			
		||||
 | 
			
		||||
# Strip out the argument added by the OS.
 | 
			
		||||
if [ x`echo "x$1" | sed -e "s/^x-psn_.*//"` == x ]; then
 | 
			
		||||
    shift 1
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
#Note that we're calling $PYTHON here to override the version in
 | 
			
		||||
#pygtk-demo's shebang.
 | 
			
		||||
exec $PYTHON -O "$GRAMPSDIR/gramps.py" "$@"
 | 
			
		||||
PWD=`dirname $0`
 | 
			
		||||
exec "$PWD/python" "$PWD/rungramps.py" $@
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										135
									
								
								mac/rungramps.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										135
									
								
								mac/rungramps.py
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,135 @@
 | 
			
		||||
#!/usr/bin/env python
 | 
			
		||||
import sys, os, subprocess
 | 
			
		||||
 | 
			
		||||
_home = os.environ["HOME"]
 | 
			
		||||
_res_path = os.path.normpath(os.path.join(sys.path[0], "..", "Resources"))
 | 
			
		||||
_lib_path = os.path.join(_res_path, "lib")
 | 
			
		||||
_share_path = os.path.join(_res_path, "share")
 | 
			
		||||
_pylib_path = os.path.join(_lib_path, "python2.6")
 | 
			
		||||
_site_lib_path = os.path.join(_pylib_path, "site-packages")
 | 
			
		||||
_gramps_path = os.path.join(_share_path, "gramps")
 | 
			
		||||
_gramps_locale = os.path.join(_share_path, "locale")
 | 
			
		||||
_conf_path = os.path.join(_res_path, "etc");
 | 
			
		||||
_gtk2_conf = os.path.join(_conf_path, "gtk-2.0")
 | 
			
		||||
sys.path = [_gramps_path,
 | 
			
		||||
            os.path.join(_pylib_path, "lib-dynload"),
 | 
			
		||||
            os.path.join(_site_lib_path, "pygtk", "2.0"),
 | 
			
		||||
            os.path.join(_site_lib_path, "gtk-2.0"),
 | 
			
		||||
            _site_lib_path,
 | 
			
		||||
            _pylib_path]
 | 
			
		||||
 | 
			
		||||
os.environ["GTK_PATH"] = _res_path
 | 
			
		||||
os.environ["GTK2_RC_FILES"] = os.path.join(_gtk2_conf, "gtkrc")
 | 
			
		||||
os.environ["GTK_IM_MODULE_FILE"]= os.path.join(_gtk2_conf, "immodules")
 | 
			
		||||
os.environ["GDK_PIXBUF_LOADERS"] = os.path.join(_gtk2_conf, "gdk-pixbuf.loaders")
 | 
			
		||||
os.environ["PANGO_RC_FILES"] = os.path.join(_conf_path, "pango", "pangorc")
 | 
			
		||||
 | 
			
		||||
os.environ["GRAMPSDIR"] = _gramps_path
 | 
			
		||||
os.environ["GRAMPSI18N"] = _gramps_locale
 | 
			
		||||
os.environ["GRAMPSHOME"] = os.path.join(_home, "Library", "Application Support")
 | 
			
		||||
 | 
			
		||||
LANG = "C" #Default
 | 
			
		||||
defaults = "/usr/bin/defaults"
 | 
			
		||||
_languages = ""
 | 
			
		||||
_collation = ""
 | 
			
		||||
_locale = ""
 | 
			
		||||
_language = ""
 | 
			
		||||
try:
 | 
			
		||||
    _languages = subprocess.Popen(
 | 
			
		||||
        [defaults,  "read", "-app", "Gramps", "AppleLanguages"],
 | 
			
		||||
        stderr=open("/dev/null"),
 | 
			
		||||
        stdout=subprocess.PIPE).communicate()[0].strip("()\n").split(",\n")
 | 
			
		||||
except:
 | 
			
		||||
    pass
 | 
			
		||||
if not _languages:
 | 
			
		||||
    try:
 | 
			
		||||
        _languages = subprocess.Popen(
 | 
			
		||||
            [defaults, "read", "-g", "AppleLanguages"],
 | 
			
		||||
            stderr=open("/dev/null"),
 | 
			
		||||
            stdout=subprocess.PIPE).communicate()[0].strip("()\n").split(",\n")
 | 
			
		||||
    except:
 | 
			
		||||
        pass
 | 
			
		||||
 | 
			
		||||
for _lang in _languages:
 | 
			
		||||
    _lang=_lang.strip().strip('"').replace("-", "_", 1)
 | 
			
		||||
    if _lang == "cn_Hant": #Traditional; Gettext uses cn_TW
 | 
			
		||||
        _lang = "cn_TW"
 | 
			
		||||
    if _lang == "cn_Hans": #Simplified; Gettext uses cn_CN
 | 
			
		||||
        _lang = "cn_CN"
 | 
			
		||||
    _language = _lang
 | 
			
		||||
    if _lang.startswith("en"): #Gramps doesn't have explicit English translation, use C
 | 
			
		||||
        break
 | 
			
		||||
    if os.path.exists(os.path.join(_gramps_locale, _lang, "LC_MESSAGES",
 | 
			
		||||
                                   "gramps.mo")):
 | 
			
		||||
        LANG = _lang
 | 
			
		||||
        break
 | 
			
		||||
    elif os.path.exists(os.path.join(_gramps_locale, _lang[:2], "LC_MESSAGES",
 | 
			
		||||
                                     "gramps.mo")):
 | 
			
		||||
        LANG = _lang[:2]
 | 
			
		||||
        break
 | 
			
		||||
try:
 | 
			
		||||
    _collation=subprocess.Popen(
 | 
			
		||||
        [defaults, "read", "-app", "Gramps", "AppleCollationOrder"],
 | 
			
		||||
        stderr=open("/dev/null"),
 | 
			
		||||
        stdout=subprocess.PIPE).communicate()[0]
 | 
			
		||||
except:
 | 
			
		||||
    pass
 | 
			
		||||
if not _collation:
 | 
			
		||||
    try:
 | 
			
		||||
        _collation=subprocess.Popen(
 | 
			
		||||
            [defaults, "read", "-g", "AppleCollationOrder"],
 | 
			
		||||
            stderr=open("/dev/null"),
 | 
			
		||||
            stdout=subprocess.PIPE).communicate()[0]
 | 
			
		||||
    except:
 | 
			
		||||
        pass
 | 
			
		||||
if _collation:
 | 
			
		||||
    if LANG == "C" and not _language and os.path.exists(os.path.join(_gramps_locale, _collation,
 | 
			
		||||
                                                   "LC_MESSAGES", "gramps.mo")):
 | 
			
		||||
        LANG = _collation
 | 
			
		||||
    LC_COLLATE = _collation
 | 
			
		||||
if LANG == "C" and not _language:
 | 
			
		||||
    try:
 | 
			
		||||
        _locale=subprocess.Popen(
 | 
			
		||||
            [defaults, "read", "-app", "Gramps", "AppleLocale"],
 | 
			
		||||
            stderr=open("/dev/null"),
 | 
			
		||||
            stdout=subprocess.PIPE).communicate()[0]
 | 
			
		||||
    except:
 | 
			
		||||
        pass
 | 
			
		||||
    if not _locale:
 | 
			
		||||
        try:
 | 
			
		||||
            _locale=subprocess.Popen(
 | 
			
		||||
                [defaults, "read", "-g", "AppleLocale"],
 | 
			
		||||
                stderr=open("/dev/null"),
 | 
			
		||||
                stdout=subprocess.PIPE).communicate()[0]
 | 
			
		||||
        except:
 | 
			
		||||
            pass
 | 
			
		||||
    if _locale:
 | 
			
		||||
        if os.path.exists(os.path.join(_gramps_locale, _locale[:5],
 | 
			
		||||
                                       "LC_MESSAGES", "gramps.mo")):
 | 
			
		||||
            LANG = _locale[:5]
 | 
			
		||||
        elif os.path.exists(os.path.join(_gramps_locale, _locale[:2],
 | 
			
		||||
                                         "LC_MESSAGES", "gramps.mo")):
 | 
			
		||||
            LANG = _locale[:2]
 | 
			
		||||
 | 
			
		||||
os.environ["LANG"] = LANG
 | 
			
		||||
if not _language:
 | 
			
		||||
    _language = LANG
 | 
			
		||||
if LC_COLLATE:
 | 
			
		||||
    os.environ["LC_COLLATE"] = LC_COLLATE
 | 
			
		||||
if _language == "C" or _language == "en":
 | 
			
		||||
    LC_ALL = "en_US"
 | 
			
		||||
elif len(_language) == 2:
 | 
			
		||||
    LC_ALL = _language + "_" + _language.upper() #Because setlocale gets cranky
 | 
			
		||||
                                       #if it only has two letters
 | 
			
		||||
else:
 | 
			
		||||
    LC_ALL = _language
 | 
			
		||||
 | 
			
		||||
os.environ["LC_ALL"] = LC_ALL #Spell-checker dictionary support
 | 
			
		||||
print LANG, LC_ALL
 | 
			
		||||
#LaunchServices sticks this argument on the front of argument
 | 
			
		||||
#lists. It must make sense to somebody, but Gramps isn't that
 | 
			
		||||
#somebody.
 | 
			
		||||
for _arg in sys.argv:
 | 
			
		||||
    if _arg.startswith("-psn"):
 | 
			
		||||
        sys.argv.remove(_arg)
 | 
			
		||||
import gramps
 | 
			
		||||
		Reference in New Issue
	
	Block a user