Skip to main content

No project description provided

Project description

Muffin-Babel – an extension to Muffin that adds localization support with help of babel.

Build Status http://img.shields.io/pypi/v/muffin-babel.svg?style=flat-square http://img.shields.io/pypi/dm/muffin-babel.svg?style=flat-square

Requirements

  • python >= 3.3

Installation

Muffin-Babel should be installed using pip:

pip install muffin-babel

Usage

Add muffin_babel to PLUGINS in your Muffin application config:

import muffin

app = muffin.Application(
    'example',

    PLUGINS=(
        'muffin_jinja2',
        'muffin_babel',
    )

)

Setup a locale selector function:

@app.ps.babel.locale_selector
def set_locale(request):
    """ Return locale from GET lang-param or automatically. """
    return request.GET.get(
        'lang',

        # Get locale based on user settings
        app.ps.babel.select_locale_by_request(request)
    )

Use app.ps.babel.gettext, app.ps.babel.pgettext, app.ps.babel.lazy_gettext function in your code:

@app.register('/')
def index(request):
    return app.ps.babel.gettext('Hello!')

Jinja2

The Muffin-Babel has integration with Muffin-Jinja2, so if you have muffin_jinja2 plugin enabled, the plugin provides gettext and ngettext function in Jinja2 templates’ context.

Options

BABEL_CONFIGURE_JINJA2

Install i18n support to Muffin-Jinja2 (True)

BABEL_DEFAULT_LOCALE

Set default locale (en)

BABEL_DOMAIN

Set default domain (messages)

BABEL_LOCALES_DIRS

List of directories where locales are leaving

BABEL_SOURCES_MAP

Babel sources map

BABEL_OPTIONS_MAP

Babel options map

Commands

The plugin adds two commands to your Muffin application.

Extract messages

Extract strings from your application to locales:

$ muffin app_module extract_messages [OPTIONS] appdir

Translate .po files and compile translations:

$ muffin app_module compile_messages [OPTIONS]

Bug tracker

If you have any suggestions, bug reports or annoyances please report them to the issue tracker at https://github.com/klen/muffin-babel/issues

Contributing

Development of Muffin-Babel happens at: https://github.com/klen/muffin-babel

Contributors

  • klen (Kirill Klenov)

License

Licensed under a MIT license.

If you wish to express your appreciation for the project, you are welcome to send a postcard to:

Kirill Klenov
pos. Severny 8-3
MO, Istra, 143500
Russia

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

muffin-babel-0.2.0.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

muffin_babel-0.2.0-py2.py3-none-any.whl (8.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file muffin-babel-0.2.0.tar.gz.

File metadata

File hashes

Hashes for muffin-babel-0.2.0.tar.gz
Algorithm Hash digest
SHA256 5b4cf29f4a2c55f85d6ceadca556e91b031f20b6155927f8af8652e828084434
MD5 7be705f2e60a621419ef4e66520329be
BLAKE2b-256 6962caf42c3cb99d7489d735edf4b19425995c22a2ca1416224e0d357c65960d

See more details on using hashes here.

File details

Details for the file muffin_babel-0.2.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for muffin_babel-0.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 abf3cd2ff7a866505b8578ab7b0cd249d2244fa527f659da57467748a2be2fb7
MD5 81ad262d92c89fd4236ed416bb277f1d
BLAKE2b-256 dc833020878f2a8e7ea20e2a9aed68756479bbb11f684b7a48658c370146460c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page