|
1
|
|
|
# -*- coding: utf-8 -*- |
|
2
|
|
|
|
|
3
|
|
|
import logging |
|
4
|
|
|
import sys |
|
5
|
|
|
|
|
6
|
|
|
LOG_LEVELS = { |
|
7
|
|
|
'DEBUG': logging.DEBUG, |
|
8
|
|
|
'INFO': logging.INFO, |
|
9
|
|
|
'WARNING': logging.WARNING, |
|
10
|
|
|
'ERROR': logging.ERROR, |
|
11
|
|
|
'CRITICAL': logging.CRITICAL, |
|
12
|
|
|
} |
|
13
|
|
|
|
|
14
|
|
|
LOG_FORMATS = { |
|
15
|
|
|
'DEBUG': u'%(levelname)s %(name)s: %(message)s', |
|
16
|
|
|
'INFO': u'%(levelname)s: %(message)s', |
|
17
|
|
|
} |
|
18
|
|
|
|
|
19
|
|
|
|
|
20
|
|
|
def configure_logger(stream_level='DEBUG', debug_file=None): |
|
21
|
|
|
# Set up 'cookiecutter' logger |
|
22
|
|
|
logger = logging.getLogger('cookiecutter') |
|
23
|
|
|
logger.setLevel(logging.DEBUG) |
|
24
|
|
|
|
|
25
|
|
|
# Remove all attached handlers, in case there was |
|
26
|
|
|
# a logger with using the name 'cookiecutter' |
|
27
|
|
|
del logger.handlers[:] |
|
28
|
|
|
|
|
29
|
|
|
# Create a file handler if a log file is provided |
|
30
|
|
|
if debug_file is not None: |
|
31
|
|
|
debug_formatter = logging.Formatter(LOG_FORMATS['DEBUG']) |
|
32
|
|
|
file_handler = logging.FileHandler(debug_file) |
|
33
|
|
|
file_handler.setLevel(LOG_LEVELS['DEBUG']) |
|
34
|
|
|
file_handler.setFormatter(debug_formatter) |
|
35
|
|
|
logger.addHandler(file_handler) |
|
36
|
|
|
|
|
37
|
|
|
# Get settings based on the given stream_level |
|
38
|
|
|
log_formatter = logging.Formatter(LOG_FORMATS[stream_level]) |
|
39
|
|
|
log_level = LOG_LEVELS[stream_level] |
|
40
|
|
|
|
|
41
|
|
|
# Create a stream handler |
|
42
|
|
|
stream_handler = logging.StreamHandler(stream=sys.stdout) |
|
43
|
|
|
stream_handler.setLevel(log_level) |
|
44
|
|
|
stream_handler.setFormatter(log_formatter) |
|
45
|
|
|
logger.addHandler(stream_handler) |
|
46
|
|
|
|
|
47
|
|
|
return logger |
|
48
|
|
|
|