view src/core/i18n.py @ 994:652c01ca69b1

core (log): configuration and environment variables are now checked for log level and colors: - variable change logs behaviour, so far only level and colors are implemented - configuration use log_[name], for example you can put log_level=debug in sat.conf (section [DEFAULT]) to see all levels - environment variables use SAT_LOG_[NAME]: e.g. SAT_LOG_LEVEL=debug - colors can be true, false or force to force colors even if stdout is not a tty
author Goffi <goffi@goffi.org>
date Sat, 19 Apr 2014 20:11:23 +0200
parents 1fe00f0c9a91
children e22e4cf86204
line wrap: on
line source

#!/usr/bin/python
# -*- coding: utf-8 -*-

# SAT: a jabber client
# Copyright (C) 2009, 2010, 2011, 2012, 2013, 2014 Jérôme Poisson (goffi@goffi.org)

# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.

# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU Affero General Public License for more details.

# You should have received a copy of the GNU Affero General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.


try:

    import gettext

    _ = gettext.translation('sat', 'i18n', fallback=True).ugettext
    _translators = {None: gettext.NullTranslations()}

    def languageSwitch(lang=None):
        if not lang in _translators:
            _translators[lang] = gettext.translation('sat', languages=[lang], fallback=True)
        _translators[lang].install(unicode=True)

except ImportError:

    print "WARNING: gettext support disabled"
    _ = lambda msg: msg # Libervia doesn't support gettext
    def languageSwitch(lang=None):
        pass


D_ = lambda msg: msg # used for deferred translations