mirror of
https://github.com/Mikaela/Limnoria.git
synced 2024-12-02 16:09:24 +01:00
Modified i18n.py, in order to handle internationalization before conf is loaded
This commit is contained in:
parent
0b86e84b13
commit
df3d096ab1
38
src/i18n.py
38
src/i18n.py
@ -35,7 +35,9 @@ __all__ = ['PluginInternationalization']
|
|||||||
|
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
import supybot.conf as conf
|
import time
|
||||||
|
import threading
|
||||||
|
# Don't import conf here ; because conf needs this module
|
||||||
|
|
||||||
WAITING_FOR_MSGID = 1
|
WAITING_FOR_MSGID = 1
|
||||||
IN_MSGID = 2
|
IN_MSGID = 2
|
||||||
@ -45,9 +47,14 @@ IN_MSGSTR = 4
|
|||||||
MSGID = 'msgid "'
|
MSGID = 'msgid "'
|
||||||
MSGSTR = 'msgstr "'
|
MSGSTR = 'msgstr "'
|
||||||
|
|
||||||
conf.registerGlobalValue(conf.supybot, 'language',
|
def import_conf():
|
||||||
conf.registry.String('en', """Determines the bot's default language.
|
import supybot.conf as conf
|
||||||
Valid values are things like en, fr, de, etc."""))
|
globals().update({'conf': conf})
|
||||||
|
conf.registerGlobalValue(conf.supybot, 'language',
|
||||||
|
conf.registry.String('en', """Determines the bot's default language.
|
||||||
|
Valid values are things like en, fr, de, etc."""))
|
||||||
|
for key in i18nClasses:
|
||||||
|
i18nClasses[key].loadLocale()
|
||||||
|
|
||||||
def get_plugin_dir(plugin_name):
|
def get_plugin_dir(plugin_name):
|
||||||
filename = sys.modules[plugin_name].__file__
|
filename = sys.modules[plugin_name].__file__
|
||||||
@ -72,13 +79,20 @@ def reloadLocals():
|
|||||||
class PluginInternationalization:
|
class PluginInternationalization:
|
||||||
"""Internationalization managment for a plugin."""
|
"""Internationalization managment for a plugin."""
|
||||||
def __init__(self, name='supybot'):
|
def __init__(self, name='supybot'):
|
||||||
|
print name
|
||||||
self.name = name
|
self.name = name
|
||||||
self.loadLocale()
|
self.currentLocaleName = None
|
||||||
i18nClasses.update({name: self})
|
i18nClasses.update({name: self})
|
||||||
|
if name != 'supybot' and not 'conf' in globals():
|
||||||
|
# if conf is loadable but not loaded
|
||||||
|
import_conf()
|
||||||
|
self.loadLocale()
|
||||||
|
|
||||||
def loadLocale(self, localeName=None):
|
def loadLocale(self, localeName=None):
|
||||||
if localeName is None:
|
if localeName is None and 'conf' in globals():
|
||||||
localeName = conf.supybot.language()
|
localeName = conf.supybot.language()
|
||||||
|
elif localeName is None:
|
||||||
|
localeName = 'en'
|
||||||
self.currentLocaleName = localeName
|
self.currentLocaleName = localeName
|
||||||
directory = get_plugin_dir(self.name) + 'locale'
|
directory = get_plugin_dir(self.name) + 'locale'
|
||||||
try:
|
try:
|
||||||
@ -138,6 +152,12 @@ class PluginInternationalization:
|
|||||||
return str.replace(string, '\\n', '\n') # Replace \\n by \n
|
return str.replace(string, '\\n', '\n') # Replace \\n by \n
|
||||||
|
|
||||||
def __call__(self, untranslated, *args):
|
def __call__(self, untranslated, *args):
|
||||||
|
if not 'conf' in globals():
|
||||||
|
if len(args) == 0:
|
||||||
|
return untranslated
|
||||||
|
else:
|
||||||
|
translation = self(untranslated)
|
||||||
|
return translation % args
|
||||||
if self.currentLocaleName != conf.supybot.language():
|
if self.currentLocaleName != conf.supybot.language():
|
||||||
# If the locale has been changed
|
# If the locale has been changed
|
||||||
reloadLocals()
|
reloadLocals()
|
||||||
@ -147,8 +167,10 @@ class PluginInternationalization:
|
|||||||
except KeyError:
|
except KeyError:
|
||||||
return untranslated
|
return untranslated
|
||||||
else:
|
else:
|
||||||
translation = self(untranslated)
|
try:
|
||||||
return translation % args
|
return self.translations[untranslated] % args
|
||||||
|
except KeyError:
|
||||||
|
return untranslated % args
|
||||||
|
|
||||||
|
|
||||||
def internationalizeDocstring(obj):
|
def internationalizeDocstring(obj):
|
||||||
|
Loading…
Reference in New Issue
Block a user