6.25.2.1 The NullTranslations class

Translation classes are what actually implement the translation of original source file message strings to translated message strings. The base class used by all translation classes is NullTranslations; this provides the basic interface you can use to write your own specialized translation classes. Here are the methods of NullTranslations:

__init__([fp])
Takes an optional file object fp, which is ignored by the base class. Initializes ``protected'' instance variables _info and _charset which are set by derived classes, as well as _fallback, which is set through add_fallback. It then calls self._parse(fp) if fp is not None.

_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.

NullTranslations(add_fallback)
fallback 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.

gettext(message)
If a fallback has been set, forward gettext to the fallback. Otherwise, return the translated message. Overridden in derived classes.

ugettext(message)
If a fallback has been set, forward ugettext to the fallback. Otherwise, return the translated message as a Unicode string. Overridden in derived classes.

info()
Return the ``protected'' _info variable.

charset()
Return the ``protected'' _charset variable.

install([unicode])
If the unicode flag is false, this method installs self.gettext() into the built-in namespace, binding it to "_". If unicode is true, it binds self.ugettext() instead. By default, unicode is false.

Note that this is only one way, albeit the most convenient way, to make the _ function available to your application. Because it affects the entire application globally, and specifically the built-in namespace, localized modules should never install _. Instead, they should use this code to make _ available to their module:

import gettext
t = gettext.translation('mymodule', ...)
_ = t.gettext

This puts _ only in the module's global namespace and so only affects calls within this module.

See About this document... for information on suggesting changes.