Completed
Pull Request — master (#2409)
by
unknown
02:14
created

LogPrinter.err()   A

Complexity

Conditions 1

Size

Total Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
dl 0
loc 6
rs 9.4285
c 0
b 0
f 0
1
import traceback
2
import logging
3
4
from pyprint.ColorPrinter import ColorPrinter
5
6
from coalib.output.printers.LOG_LEVEL import LOG_LEVEL
7
from coalib.processes.communication.LogMessage import LogMessage
8
9
10
class LogPrinter:
11
    """
12
    This class is deprecated and will be soon removed. To get logger use
13
    logging.getLogger('coala.colored') for colored logger and
14
    logging.getLogger('coala.raw') for not colored logger.
15
16
    The LogPrinter class allows to print log messages to an underlying Printer.
17
18
    This class is an adapter, means you can create a LogPrinter from every
19
    existing Printer instance.
20
    """
21
22
    def __init__(self,
23
                 printer=None,
24
                 log_level=LOG_LEVEL.INFO,
25
                 timestamp_format="%X"):
26
        """
27
        Creates a new log printer from an existing Printer.
28
29
        :param printer:          The underlying Printer where log messages
30
                                 shall be written to. If you inherit from
31
                                 LogPrinter, set it to self.
32
        :param log_level:        The minimum log level, everything below will
33
                                 not be logged.
34
        :param timestamp_format: The format string for the
35
                                 datetime.today().strftime(format) method.
36
        """
37
        if isinstance(printer, ColorPrinter):
38
            self.logger_name = 'coala.colored'
39
        else:
40
            self.logger_name = 'coala.raw'
41
        self.logger = logging.getLogger(self.logger_name)
42
43
        self._printer = printer
44
        self.log_level = log_level
45
        self.timestamp_format = timestamp_format
46
47
    @property
48
    def log_level(self):
49
        """
50
        Returns current log_level used in logger.
51
        """
52
        return self.logger.getEffectiveLevel()
53
54
    @log_level.setter
55
    def log_level(self, log_level):
56
        """
57
        Sets log_level for logger.
58
        """
59
        self.logger.setLevel(log_level)
60
61
    @property
62
    def printer(self):
63
        """
64
        Returns the underlying printer where logs are printed to.
65
        """
66
        return self._printer
67
68
    def debug(self, *messages, delimiter=" ", timestamp=None, **kwargs):
69
        self.log_message(LogMessage(LOG_LEVEL.DEBUG,
70
                                    *messages,
71
                                    delimiter=delimiter,
72
                                    timestamp=timestamp),
73
                         **kwargs)
74
75
    def info(self, *messages, delimiter=" ", timestamp=None, **kwargs):
76
        self.log_message(LogMessage(LOG_LEVEL.INFO,
77
                                    *messages,
78
                                    delimiter=delimiter,
79
                                    timestamp=timestamp),
80
                         **kwargs)
81
82
    def warn(self, *messages, delimiter=" ", timestamp=None, **kwargs):
83
        self.log_message(LogMessage(LOG_LEVEL.WARNING,
84
                                    *messages,
85
                                    delimiter=delimiter,
86
                                    timestamp=timestamp),
87
                         **kwargs)
88
89
    def err(self, *messages, delimiter=" ", timestamp=None, **kwargs):
90
        self.log_message(LogMessage(LOG_LEVEL.ERROR,
91
                                    *messages,
92
                                    delimiter=delimiter,
93
                                    timestamp=timestamp),
94
                         **kwargs)
95
96
    def log(self, log_level, message, timestamp=None, **kwargs):
97
        self.log_message(LogMessage(log_level,
98
                                    message,
99
                                    timestamp=timestamp),
100
                         **kwargs)
101
102
    def log_exception(self,
103
                      message,
104
                      exception,
105
                      log_level=LOG_LEVEL.ERROR,
106
                      timestamp=None,
107
                      **kwargs):
108
        """
109
        If the log_level of the printer is greater than DEBUG, it prints
110
        only the message. If it is DEBUG or lower, it shows the message
111
        along with the traceback of the exception.
112
113
        :param message:   The message to print.
114
        :param exception: The exception to print.
115
        :param log_level: The log_level of this message (not used when
116
                          logging the traceback. Tracebacks always have
117
                          a level of DEBUG).
118
        :param timestamp: The time at which this log occured. Defaults to
119
                          the current time.
120
        :param kwargs:    Keyword arguments to be passed when logging the
121
                          message (not used when logging the traceback).
122
        """
123
        if not isinstance(exception, BaseException):
124
            raise TypeError("log_exception can only log derivatives of "
125
                            "BaseException.")
126
127
        traceback_str = "\n".join(
128
            traceback.format_exception(type(exception),
129
                                       exception,
130
                                       exception.__traceback__))
131
132
        self.log(log_level, message, timestamp=timestamp, **kwargs)
133
        self.log_message(
134
            LogMessage(LOG_LEVEL.DEBUG,
135
                       "Exception was:" + "\n" + traceback_str,
136
                       timestamp=timestamp),
137
            **kwargs)
138
139
    def log_message(self, log_message, **kwargs):
140
        if not isinstance(log_message, LogMessage):
141
            raise TypeError("log_message should be of type LogMessage.")
142
        self.logger.log(log_message.log_level, log_message.message)
143
144
    def __getstate__(self):
145
        # on Windows there are problems with serializing loggers, so omit it
146
        oldict = self.__dict__.copy()
147
        del oldict['logger']
148
        return oldict
149
150
    def __setstate__(self, newdict):
151
        self.__dict__.update(newdict)
152
        # restore logger by name
153
        self.logger = logging.getLogger(self.logger_name)
154