~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/i18n.py

  • Committer: Patch Queue Manager
  • Date: 2011-10-06 10:15:06 UTC
  • mfrom: (6195.1.1 trunk)
  • Revision ID: pqm@pqm.ubuntu.com-20111006101506-mychax14dy7yjee2
(vila) Tag bzr-2.5b2 missed during freeze (Vincent Ladeuil)

Show diffs side-by-side

added added

removed removed

Lines of Context:
26
26
import os
27
27
import sys
28
28
 
 
29
 
29
30
_translations = None
30
31
 
31
32
 
34
35
    
35
36
    :returns: translated message as unicode.
36
37
    """
 
38
    install()
37
39
    return _translations.ugettext(message)
38
40
 
39
41
 
46
48
 
47
49
    :returns: translated message as unicode.
48
50
    """
 
51
    install()
49
52
    return _translations.ungettext(singular, plural, number)
50
53
 
51
54
 
59
62
 
60
63
    :returns: concatenated translated message as unicode.
61
64
    """
 
65
    install()
62
66
    paragraphs = message.split(u'\n\n')
63
67
    ugettext = _translations.ugettext
64
68
    # Be careful not to translate the empty string -- it holds the
66
70
    return u'\n\n'.join(ugettext(p) if p else u'' for p in paragraphs)
67
71
 
68
72
 
 
73
def disable_i18n():
 
74
    """Do not allow i18n to be enabled.  Useful for third party users
 
75
    of bzrlib."""
 
76
    global _translations
 
77
    _translations = _gettext.NullTranslations()
 
78
 
 
79
 
69
80
def installed():
 
81
    """Returns whether translations are in use or not."""
70
82
    return _translations is not None
71
83
 
72
84
 
73
85
def install(lang=None):
 
86
    """Enables gettext translations in bzr."""
74
87
    global _translations
75
88
    if installed():
76
89
        return
 
90
    _translations = install_translations(lang)
 
91
 
 
92
 
 
93
def install_translations(lang=None, domain='bzr', locale_base=None):
 
94
    """Create a gettext translation object.
 
95
    
 
96
    :param lang: language to install.
 
97
    :param domain: translation domain to install.
 
98
    :param locale_base: plugins can specify their own directory.
 
99
 
 
100
    :returns: a gettext translations object to use
 
101
    """
77
102
    if lang is None:
78
103
        lang = _get_current_locale()
79
104
    if lang is not None:
80
105
        languages = lang.split(':')
81
106
    else:
82
107
        languages = None
83
 
    _translations = _gettext.translation(
84
 
            'bzr',
85
 
            localedir=_get_locale_dir(),
 
108
    translation = _gettext.translation(
 
109
            domain,
 
110
            localedir=_get_locale_dir(locale_base),
86
111
            languages=languages,
87
112
            fallback=True)
 
113
    return translation
 
114
 
 
115
 
 
116
def add_fallback(fallback):
 
117
    """
 
118
    Add a fallback translations object.  Typically used by plugins.
 
119
 
 
120
    :param fallback: gettext.GNUTranslations object
 
121
    """
 
122
    install()
 
123
    _translations.add_fallback(fallback)
88
124
 
89
125
 
90
126
def uninstall():
 
127
    """Disables gettext translations."""
91
128
    global _translations
92
129
    _translations = None
93
130
 
94
131
 
95
 
def _get_locale_dir():
 
132
def _get_locale_dir(base):
 
133
    """Returns directory to find .mo translations file in, either local or system
 
134
 
 
135
    :param base: plugins can specify their own local directory
 
136
    """
96
137
    if hasattr(sys, 'frozen'):
97
 
        base = os.path.dirname(
 
138
        if base is None:
 
139
            base = os.path.dirname(
98
140
                unicode(sys.executable, sys.getfilesystemencoding()))
99
141
        return os.path.join(base, u'locale')
100
142
    else:
101
 
        base = os.path.dirname(unicode(__file__, sys.getfilesystemencoding()))
 
143
        if base is None:
 
144
            base = os.path.dirname(unicode(__file__, sys.getfilesystemencoding()))
102
145
        dirpath = os.path.realpath(os.path.join(base, u'locale'))
103
146
        if os.path.exists(dirpath):
104
147
            return dirpath
147
190
        if lang:
148
191
            return lang
149
192
    return None
 
193
 
 
194
 
 
195
def load_plugin_translations(domain):
 
196
    """Load the translations for a specific plugin.
 
197
 
 
198
    :param domain: Gettext domain name (usually 'bzr-PLUGINNAME')
 
199
    """
 
200
    locale_base = os.path.dirname(
 
201
        unicode(__file__, sys.getfilesystemencoding()))
 
202
    translation = install_translations(domain=domain,
 
203
        locale_base=locale_base)
 
204
    add_fallback(translation)
 
205
    return translation