Undo the rungramps changes.
Importing gramps at the end of rungramps causes threading deadlocks because of a lock (held by the main thread as long as Gramps is running) on import. svn: r17706
This commit is contained in:
parent
2d24d68753
commit
2a11be7174
171
mac/launcher.sh
171
mac/launcher.sh
@ -1,4 +1,169 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
PWD=`dirname $0`
|
|
||||||
export PYTHON="$PWD/python"
|
name="`basename $0`"
|
||||||
exec "$PYTHON" "$PWD/rungramps.py" $@
|
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" "$@"
|
||||||
|
141
mac/rungramps.py
141
mac/rungramps.py
@ -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
|
|
Loading…
Reference in New Issue
Block a user