i18n and translations¶
Mark up translations in templates by using an i18n: namespaced element or attribute.
The i18n:translate
directive causes text to be tagged for translation:
<h1 i18n:translate="">Main heading</h1>
If a value is given in the i18n:translate
attribute this is used as
the message for translation in preference to any content of the element:
<h1 i18n:translate="Main heading">Oh freddled gruntbuggly</h1>
The i18n:comment
directive allows you to supply a comment for translators.
As a shortcut this attribute can be used on its own without a corresponding
i18n:translate
:
<p i18n:comment="note to translators">Welcome friend!</p>
Interpolations inside translations are automatically included in the extracted message. Simple variable expressions are passed through unchanged:
<p i18n:translate="">Last updated at ${time}</p>
For longer expressions, use i18n:name
to simplify the translation message.
The following will be extracted as Last updated at ${when}
<p i18n:trans="">Last updated at
<i18n:name name="when">${format_timedelta(now - time)}</p>
By default the whitespace in messages is normalized by replacing all
consecutive whitespace characters with a single space. This behavior can be
changed by setting i18n:whitespace
to one of preserve
, trim
,
dedent
or normalize
(default).
Extracting message catalogs¶
Piglet includes a babel extractor. Add the following or similar to your
babel.ini
to extract messages from Piglet templates:
[piglet:**/templates/**.html]
Runtime configuration¶
The translations_factory
argument to piglet.loader.TemplateLoader
should be used to provide a gettext object to generated templates. This
must be a function that takes no arguments and returns a gettext
object:
from piglet import TemplateLoader
from gettext import GNUTranslations
def get_translations():
return GNUTranslations(somefile)
loader = TemplateLoader(search_path=['templates'],
translations_factory=get_translations)
Here’s an example for use with Django’s translation machinery:
from piglet import TemplateLoader
import django.utils.translation
def get_translations():
return django.utils.translation
loader = TemplateLoader(search_path=['templates'],
translations_factory=get_translations)