EventGhost/EventGhost

View on GitHub
_build/builder/Logging.py

Summary

Maintainability
A
0 mins
Test Coverage
# -*- coding: utf-8 -*-
#
# This file is part of EventGhost.
# Copyright © 2005-2020 EventGhost Project <http://www.eventghost.net/>
#
# EventGhost is free software: you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free
# Software Foundation, either version 2 of the License, or (at your option)
# any later version.
#
# EventGhost 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 General Public License for
# more details.
#
# You should have received a copy of the GNU General Public License along
# with EventGhost. If not, see <http://www.gnu.org/licenses/>.

import logging
import sys
from os.path import join


class StdHandler(object):
    indent = 0

    def __init__(self, oldStream, logger, verbose=True):
        self.oldStream = oldStream
        self.encoding = oldStream.encoding
        self.buf = ""
        self.logger = logger
        self.verbose = verbose

        # the following is a workaround for colorama (0.3.6),
        # which is called by sphinx (build CHM docs).
        self.closed = False

    def flush(self):
        pass

    def isatty(self):
        return True

    def write(self, data):
        try:
            self.buf += data
        except UnicodeError:
            self.buf += data.decode('mbcs')
        lines = self.buf.split("\n")
        for line in self.buf.split("\n")[:-1]:
            line = (self.indent * 4 * " ") + line.rstrip()
            self.logger(line)
            if self.verbose:
                self.oldStream.write(line + "\n")
                self.oldStream.flush()
        self.buf = lines[-1]
        self.flush()


class InfoFilter(logging.Filter):
    def filter(self, rec):
        if rec.levelno == 22:
            sys.stdout.oldStream.write(rec.msg + "\n")
            sys.stdout.oldStream.flush()
        return True


def LogToFile(file, verbose):
    formatter = u'%(name)s:%(levelname)s: %(message)s'
    logging.basicConfig(filename=file, level=logging.DEBUG, format=formatter)
    logging.getLogger().setLevel(20)
    logging.getLogger().addFilter(filter=InfoFilter())
    sys.stdout = StdHandler(sys.stdout, logging.info, verbose)
    sys.stderr = StdHandler(sys.stderr, logging.error)