GrampsLocale: Fix get_addon_translator path

Add the locale subdirectory.
Also clean out some cruft left over from the old implementation.

svn: r21485
This commit is contained in:
John Ralls 2013-02-28 18:56:59 +00:00
parent 512c57cb04
commit 4eb3e7c926

View File

@ -408,7 +408,7 @@ class GrampsLocale(object):
Get a translator for an addon. Get a translator for an addon.
filename - filename of a file in directory with full path, or filename - filename of a file in directory with full path, or
None to get from running code None to get from self.
domain - the name of the .mo file under the LANG/LC_MESSAGES dir domain - the name of the .mo file under the LANG/LC_MESSAGES dir
languages - a list of languages to force languages - a list of languages to force
returns - a gettext.translation object returns - a gettext.translation object
@ -420,20 +420,11 @@ class GrampsLocale(object):
Assumes path/filename Assumes path/filename
path/locale/LANG/LC_MESSAGES/addon.mo. path/locale/LANG/LC_MESSAGES/addon.mo.
""" """
path = self.localedir
# If get the path of the calling module's uncompiled file. This seems a remarkably bad idea.
# if filename is None:
# filename = sys._getframe(1).f_code.co_filename
gramps_translator = self._get_translation() gramps_translator = self._get_translation()
path = os.path.dirname(os.path.abspath(filename)) path = self.localedir
# Check if path is of type str. Do import and conversion if so. if filename:
# The import cannot be done at the top as that will conflict with the translation system. path = os.path.join(os.path.dirname(os.path.abspath(filename)), "locale")
if not isinstance(path, UNITYPE) == str:
from .file import get_unicode_path_from_env_var
path = get_unicode_path_from_env_var(path)
if languages: if languages:
addon_translator = self._get_translation(domain, addon_translator = self._get_translation(domain,
path, path,