view src/logging_setter.py @ 14:21a432afd06d

plugin system, first draft: - widgets are now handled with plugins, ContactList and WidgetSelector have been changed to be pluggins - everything in PLUGIN_INFO (including PLUGIN_INFO itself) is optional. Best guess is used if a value is missing - WidgetsHandler use default widget from plugins, which is WidgetSelector for now - PLUGIN_INFO is used in the same way as for backed plugins, with (for now) following possible keys: - "name": human readable name - "description": long description of what widget do - "import_name": unique short name used as reference for import - "main": main class name - "factory": callback used to instanciate a widget (see Cagou._defaultFactory) - "kv_file": path to the kv language file to load (same filename with ".kv" will be used if key is not found) other data should be added quickly, as a path to a file used as icon - host.getPluggedWidgets can be used to find loaded widgets. except_cls can be used to excluse a class (self.__class__ usually) - fixed host.switchWidget when old widget is already a CagouWidget - CagouWidget header new display the available widgets
author Goffi <goffi@goffi.org>
date Sat, 09 Jul 2016 16:02:44 +0200
parents 5ebe1592a05a
children
line wrap: on
line source

#!/usr//bin/env python2
# -*- coding: utf-8 -*-

# Cagou: desktop/mobile frontend for Salut à Toi XMPP client
# Copyright (C) 2016 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/>.

CONF_KIVY_LEVEL = 'log_kivy_level'

def set_logging():
    from constants import Const as C
    from sat.core import log_config
    log_config.satConfigure(C.LOG_BACKEND_STANDARD, C)

    import config
    kivy_level = config.getConfig(C.CONFIG_SECTION, CONF_KIVY_LEVEL, 'follow').upper()

    # kivy handles its own loggers, we don't want that!
    import logging
    root_logger = logging.root
    kivy_logger = logging.getLogger('kivy')
    ori_addHandler = kivy_logger.addHandler
    kivy_logger.addHandler = lambda dummy: None
    ori_setLevel = kivy_logger.setLevel
    if kivy_level == 'FOLLOW':
        # level is following SàT level
        kivy_logger.setLevel = lambda level: None
    elif kivy_level == 'KIVY':
        # level will be set by Kivy according to its own conf
        pass
    elif kivy_level in C.LOG_LEVELS:
        kivy_logger.setLevel(kivy_level)
        kivy_logger.setLevel = lambda level: None
    else:
        raise ValueError(u"Unknown value for {name}: {value}".format(name=CONF_KIVY_LEVEL, value=kivy_level))

    # during import kivy set its logging stuff
    import kivy
    kivy # to avoid pyflakes warning

    # we want to separate kivy logs from other logs
    logging.root = root_logger
    import sys
    from kivy import logger
    sys.stderr = logger.previous_stderr

    # we restore original methods
    kivy_logger.addHandler = ori_addHandler
    kivy_logger.setLevel = ori_setLevel