diff --git a/mac/launcher.sh b/mac/launcher.sh index 2e2e5b90c..38c62aec1 100755 --- a/mac/launcher.sh +++ b/mac/launcher.sh @@ -1,4 +1,169 @@ #!/bin/sh -PWD=`dirname $0` -export PYTHON="$PWD/python" -exec "$PYTHON" "$PWD/rungramps.py" $@ + +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" "$@" diff --git a/mac/rungramps.py b/mac/rungramps.py deleted file mode 100755 index 34ab2057d..000000000 --- a/mac/rungramps.py +++ /dev/null @@ -1,141 +0,0 @@ -#!/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, "pyenchant-1.6.1-py2.6.egg"), - os.path.join(_site_lib_path, "gtk-2.0"), - _site_lib_path, - _pylib_path] - -sys.prefix = _res_path -os.environ["XDG_DATA_DIRS"]=_share_path -os.environ["DYLD_LIBRARY_PATH"]=_lib_path -os.environ["LD_LIBRARY_PATH"]=_lib_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_MODULE_FILE"] = 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 = "" -LC_COLLATE = "" -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["LANGUAGE"] = LC_ALL -os.environ["LC_ALL"] = LC_ALL + ".UTF-8" #Spell-checker dictionary support - -#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