diff options
author | Benjamin Peterson <benjamin@python.org> | 2008-07-14 14:32:15 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2008-07-14 14:32:15 (GMT) |
commit | 801844d6fc8b48cfa969dd2573bd522a2b26f974 (patch) | |
tree | b792e1b3b54ed2dd3386e0ff58ffb3c9ef1d9d02 | |
parent | fbe94c55ca482bc30a831f8319bdc2074124a4e3 (diff) | |
download | cpython-801844d6fc8b48cfa969dd2573bd522a2b26f974.zip cpython-801844d6fc8b48cfa969dd2573bd522a2b26f974.tar.gz cpython-801844d6fc8b48cfa969dd2573bd522a2b26f974.tar.bz2 |
#2512 implement the 3.0 gettext API
All the u* gettext variants were renamed to their
none u* variants, since there's no point in translating
to byte strings. I also killed off the unicode parameters
for install
-rw-r--r-- | Doc/library/gettext.rst | 182 | ||||
-rw-r--r-- | Lib/gettext.py | 36 | ||||
-rw-r--r-- | Lib/test/test_gettext.py | 10 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
4 files changed, 83 insertions, 148 deletions
diff --git a/Doc/library/gettext.rst b/Doc/library/gettext.rst index fa1271a..2b344e0 100644 --- a/Doc/library/gettext.rst +++ b/Doc/library/gettext.rst @@ -187,12 +187,11 @@ class can also install themselves in the built-in namespace as the function :class:`NullTranslations` instance if *fallback* is true. -.. function:: install(domain[, localedir[, unicode [, codeset[, names]]]]) +.. function:: install(domain[, localedir [, codeset[, names]]]]) This installs the function :func:`_` in Python's builtin namespace, based on *domain*, *localedir*, and *codeset* which are passed to the function - :func:`translation`. The *unicode* flag is passed to the resulting translation - object's :meth:`install` method. + :func:`translation`. For the *names* parameter, please see the description of the translation object's :meth:`install` method. @@ -227,107 +226,91 @@ are the methods of :class:`NullTranslations`: ``None``. - .. method:: _parse(fp) - - No-op'd in the base class, this method takes file object *fp*, and reads - the data from the file, initializing its message catalog. If you have an - unsupported message catalog file format, you should override this method - to parse your format. - + .. method:: NullTranslations._parse(fp) - .. method:: add_fallback(fallback) + No-op'd in the base class, this method takes file object *fp*, and reads the + data from the file, initializing its message catalog. If you have an + unsupported message catalog file format, you should override this method to + parse your format. - Add *fallback* as the fallback object for the current translation - object. A translation object should consult the fallback if it cannot provide a - translation for a given message. + .. method:: NullTranslations.add_fallback(fallback) - .. method:: gettext(message) + Add *fallback* as the fallback object for the current translation object. A + translation object should consult the fallback if it cannot provide a + translation for a given message. - If a fallback has been set, forward :meth:`gettext` to the - fallback. Otherwise, return the translated message. Overridden in derived - classes. + .. method:: NullTranslations.gettext(message) - .. method:: lgettext(message) + If a fallback has been set, forward :meth:`gettext` to the fallback. Otherwise, + return the translated message. Overridden in derived classes. - If a fallback has been set, forward :meth:`lgettext` to the - fallback. Otherwise, return the translated message. Overridden in derived - classes. - .. method:: ugettext(message) + .. method:: NullTranslations.lgettext(message) - If a fallback has been set, forward :meth:`ugettext` to the - fallback. Otherwise, return the translated message as a string. Overridden - in derived classes. + If a fallback has been set, forward :meth:`lgettext` to the fallback. Otherwise, + return the translated message. Overridden in derived classes. - .. method:: ngettext(singular, plural, n) + .. method:: NullTranslations.ngettext(singular, plural, n) - If a fallback has been set, forward :meth:`ngettext` to the - fallback. Otherwise, return the translated message. Overridden in derived - classes. + If a fallback has been set, forward :meth:`ngettext` to the fallback. Otherwise, + return the translated message. Overridden in derived classes. - .. method:: lngettext(singular, plural, n) - If a fallback has been set, forward :meth:`ngettext` to the - fallback. Otherwise, return the translated message. Overridden in derived - classes. + .. method:: NullTranslations.lngettext(singular, plural, n) - .. method:: ungettext(singular, plural, n) + If a fallback has been set, forward :meth:`ngettext` to the fallback. Otherwise, + return the translated message. Overridden in derived classes. - If a fallback has been set, forward :meth:`ungettext` to the fallback. - Otherwise, return the translated message as a string. Overridden in - derived classes. - .. method:: info() + .. method:: NullTranslations.info() - Return the "protected" :attr:`_info` variable. + Return the "protected" :attr:`_info` variable. - .. method:: charset() + .. method:: NullTranslations.charset() - Return the "protected" :attr:`_charset` variable. + Return the "protected" :attr:`_charset` variable. - .. method:: output_charset() + .. method:: NullTranslations.output_charset() - Return the "protected" :attr:`_output_charset` variable, which defines the - encoding used to return translated messages. + Return the "protected" :attr:`_output_charset` variable, which defines the + encoding used to return translated messages. - .. method:: set_output_charset(charset) + .. method:: NullTranslations.set_output_charset(charset) - Change the "protected" :attr:`_output_charset` variable, which defines the - encoding used to return translated messages. + Change the "protected" :attr:`_output_charset` variable, which defines the + encoding used to return translated messages. - .. method:: install([unicode [, names]]) + .. method:: NullTranslations.install([names]) - If the *unicode* flag is false, this method installs :meth:`self.gettext` - into the built-in namespace, binding it to ``_``. If *unicode* is true, - it binds :meth:`self.ugettext` instead. By default, *unicode* is false. + this method installs :meth:`self.gettext` into the built-in namespace, + binding it to ``_``. - If the *names* parameter is given, it must be a sequence containing the - names of functions you want to install in the builtin namespace in - addition to :func:`_`. Supported names are ``'gettext'`` (bound to - :meth:`self.gettext` or :meth:`self.ugettext` according to the *unicode* - flag), ``'ngettext'`` (bound to :meth:`self.ngettext` or - :meth:`self.ungettext` according to the *unicode* flag), ``'lgettext'`` - and ``'lngettext'``. + If the *names* parameter is given, it must be a sequence containing + the names of functions you want to install in the builtin namespace + in addition to :func:`_`. Supported names are ``'gettext'`` (bound + to :meth:`self.gettext`), ``'ngettext'`` (bound to + :meth:`self.ngettext`), ``'lgettext'`` and ``'lngettext'``. - Note that this is only one way, albeit the most convenient way, to make - the :func:`_` function available to your application. Because it affects - the entire application globally, and specifically the built-in namespace, - localized modules should never install :func:`_`. Instead, they should use - this code to make :func:`_` available to their module:: + Note that this is only one way, albeit the most convenient way, to + make the :func:`_` function available to your application. Because + it affects the entire application globally, and specifically the + built-in namespace, localized modules should never install + :func:`_`. Instead, they should use this code to make :func:`_` + available to their module:: - import gettext - t = gettext.translation('mymodule', ...) - _ = t.gettext + import gettext + t = gettext.translation('mymodule', ...) + _ = t.gettext - This puts :func:`_` only in the module's global namespace and so only - affects calls within this module. + This puts :func:`_` only in the module's global namespace and so only + affects calls within this module. The :class:`GNUTranslations` class @@ -336,8 +319,7 @@ The :class:`GNUTranslations` class The :mod:`gettext` module provides one additional class derived from :class:`NullTranslations`: :class:`GNUTranslations`. This class overrides :meth:`_parse` to enable reading GNU :program:`gettext` format :file:`.mo` files -in both big-endian and little-endian format. It also coerces both message ids -and message strings to Unicode. +in both big-endian and little-endian format. :class:`GNUTranslations` parses optional meta-data out of the translation catalog. It is convention with GNU :program:`gettext` to include meta-data as @@ -347,12 +329,7 @@ key ``Content-Type`` is found, then the ``charset`` property is used to initialize the "protected" :attr:`_charset` instance variable, defaulting to ``None`` if not found. If the charset encoding is specified, then all message ids and message strings read from the catalog are converted to Unicode using -this encoding. The :meth:`ugettext` method always returns a Unicode, while the -:meth:`gettext` returns an encoded bytestring. For the message id arguments -of both methods, either Unicode strings or bytestrings containing only -US-ASCII characters are acceptable. Note that the Unicode version of the -methods (i.e. :meth:`ugettext` and :meth:`ungettext`) are the recommended -interface to use for internationalized Python programs. +this encoding. The entire set of key/value pairs are placed into a dictionary and set as the "protected" :attr:`_info` instance variable. @@ -380,14 +357,6 @@ The following methods are overridden from the base class implementation: :meth:`set_output_charset`. -.. method:: GNUTranslations.ugettext(message) - - Look up the *message* id in the catalog and return the corresponding message - string, as a string. If there is no entry in the catalog for the - *message* id, and a fallback has been set, the look up is forwarded to the - fallback's :meth:`ugettext` method. Otherwise, the *message* id is returned. - - .. method:: GNUTranslations.ngettext(singular, plural, n) Do a plural-forms lookup of a message id. *singular* is used as the message id @@ -398,36 +367,24 @@ The following methods are overridden from the base class implementation: If the message id is not found in the catalog, and a fallback is specified, the request is forwarded to the fallback's :meth:`ngettext` method. Otherwise, when *n* is 1 *singular* is returned, and *plural* is returned in all other cases. - - -.. method:: GNUTranslations.lngettext(singular, plural, n) - - Equivalent to :meth:`gettext`, but the translation is returned in the preferred - system encoding, if no other encoding was explicitly set with - :meth:`set_output_charset`. - - -.. method:: GNUTranslations.ungettext(singular, plural, n) - - Do a plural-forms lookup of a message id. *singular* is used as the message id - for purposes of lookup in the catalog, while *n* is used to determine which - plural form to use. The returned message string is a string. - - If the message id is not found in the catalog, and a fallback is specified, the - request is forwarded to the fallback's :meth:`ungettext` method. Otherwise, - when *n* is 1 *singular* is returned, and *plural* is returned in all other - cases. - + Here is an example:: n = len(os.listdir('.')) cat = GNUTranslations(somefile) - message = cat.ungettext( + message = cat.ngettext( 'There is %(num)d file in this directory', 'There are %(num)d files in this directory', n) % {'num': n} +.. method:: GNUTranslations.lngettext(singular, plural, n) + + Equivalent to :meth:`gettext`, but the translation is returned in the preferred + system encoding, if no other encoding was explicitly set with + :meth:`set_output_charset`. + + Solaris message catalog support ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -538,13 +495,6 @@ module:: t = gettext.translation('spam', '/usr/share/locale') _ = t.lgettext -If your translators were providing you with Unicode strings in their :file:`.po` -files, you'd instead do:: - - import gettext - t = gettext.translation('spam', '/usr/share/locale') - _ = t.ugettext - Localizing your application ^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -560,11 +510,11 @@ driver file of your application:: import gettext gettext.install('myapplication') -If you need to set the locale directory or the *unicode* flag, you can pass -these into the :func:`install` function:: +If you need to set the locale directory, you can pass these into the +:func:`install` function:: import gettext - gettext.install('myapplication', '/usr/share/locale', unicode=1) + gettext.install('myapplication', '/usr/share/locale') Changing languages on the fly diff --git a/Lib/gettext.py b/Lib/gettext.py index 6e14a93..d1f20bf 100644 --- a/Lib/gettext.py +++ b/Lib/gettext.py @@ -210,19 +210,6 @@ class NullTranslations: else: return msgid2 - def ugettext(self, message): - if self._fallback: - return self._fallback.ugettext(message) - return str(message) - - def ungettext(self, msgid1, msgid2, n): - if self._fallback: - return self._fallback.ungettext(msgid1, msgid2, n) - if n == 1: - return str(msgid1) - else: - return str(msgid2) - def info(self): return self._info @@ -235,15 +222,14 @@ class NullTranslations: def set_output_charset(self, charset): self._output_charset = charset - def install(self, str=False, names=None): + def install(self, names=None): import builtins - builtins.__dict__['_'] = str and self.ugettext or self.gettext + builtins.__dict__['_'] = self.gettext if hasattr(names, "__contains__"): if "gettext" in names: builtins.__dict__['gettext'] = builtins.__dict__['_'] if "ngettext" in names: - builtins.__dict__['ngettext'] = (str and self.ungettext - or self.ngettext) + builtins.__dict__['ngettext'] = self.ngettext if "lgettext" in names: builtins.__dict__['lgettext'] = self.lgettext if "lngettext" in names: @@ -367,31 +353,27 @@ class GNUTranslations(NullTranslations): else: return msgid2 - def ugettext(self, message): + def gettext(self, message): missing = object() tmsg = self._catalog.get(message, missing) if tmsg is missing: if self._fallback: - return self._fallback.ugettext(message) + return self._fallback.gettext(message) return str(message) return tmsg - gettext = ugettext - - def ungettext(self, msgid1, msgid2, n): + def ngettext(self, msgid1, msgid2, n): try: tmsg = self._catalog[(msgid1, self.plural(n))] except KeyError: if self._fallback: - return self._fallback.ungettext(msgid1, msgid2, n) + return self._fallback.ngettext(msgid1, msgid2, n) if n == 1: tmsg = str(msgid1) else: tmsg = str(msgid2) return tmsg - ngettext = ungettext - # Locate a .mo file using the gettext strategy def find(domain, localedir=None, languages=None, all=0): @@ -465,9 +447,9 @@ def translation(domain, localedir=None, languages=None, return result -def install(domain, localedir=None, str=False, codeset=None, names=None): +def install(domain, localedir=None, codeset=None, names=None): t = translation(domain, localedir, fallback=True, codeset=codeset) - t.install(str, names) + t.install(names) diff --git a/Lib/test/test_gettext.py b/Lib/test/test_gettext.py index 73c9c1c..6ee608e 100644 --- a/Lib/test/test_gettext.py +++ b/Lib/test/test_gettext.py @@ -143,13 +143,13 @@ trggrkg zrffntr pngnybt yvoenel.''') t.install() eq(_('nudge nudge'), 'wink wink') # Try unicode return type - t.install(str=True) + t.install() eq(_('mullusk'), 'bacon') # Test installation of other methods import builtins - t.install(str=True, names=["gettext", "lgettext"]) - eq(_, t.ugettext) - eq(builtins.gettext, t.ugettext) + t.install(names=["gettext", "lgettext"]) + eq(_, t.gettext) + eq(builtins.gettext, t.gettext) eq(lgettext, t.lgettext) del builtins.gettext del builtins.lgettext @@ -305,7 +305,7 @@ class UnicodeTranslationsTest(GettextBaseTest): self.t = gettext.GNUTranslations(fp) finally: fp.close() - self._ = self.t.ugettext + self._ = self.t.gettext def test_unicode_msgid(self): unless = self.failUnless @@ -32,6 +32,9 @@ Library code of every single module of the standard library, including invalid files used in the test suite. +- All the u* variant functions and methods in gettext have been renamed to their + none u* siblings. + C API ----- |