From 0dc707ef7c1ad1b77046a4ec194e09f9a6e65def Mon Sep 17 00:00:00 2001 From: Doug Blank Date: Sun, 1 Nov 2009 14:26:21 +0000 Subject: [PATCH] Added a function to get a translation with fallback for addons svn: r13475 --- src/TransUtils.py | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/src/TransUtils.py b/src/TransUtils.py index 66351250b..ddb1ea79d 100644 --- a/src/TransUtils.py +++ b/src/TransUtils.py @@ -72,6 +72,25 @@ def setup_gettext(): #following installs _ as a python function, we avoid this as TransUtils is #used sometimes: #gettext.install(LOCALEDOMAIN, LOCALEDIR, unicode=1) + +def get_addon_translator(filename, domain='addon'): + """ + Get a translator for an addon. + Assumes filename_dir/locale/LANG/LC_MESSAGES/addon.mo. + """ + import locale + LANG = locale.getlocale()[0] + path = os.path.dirname(os.path.abspath(filename)) + trans = Translator(LANG) + try: + fallback = gettext.translation(domain, + os.path.join(path, "locale"), + languages=[LANG]) + trans.trans.add_fallback(fallback) + except: + print ("WARN: can't add local '%s' addon translation for '%s'." % + (filename, LANG)) + return trans def get_available_translations(): """