mirror of https://github.com/mitsuhiko/flask.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
45 lines
1.4 KiB
45 lines
1.4 KiB
# -*- coding: utf-8 -*- |
|
""" |
|
flask.logging |
|
~~~~~~~~~~~~~ |
|
|
|
Implements the logging support for Flask. |
|
|
|
:copyright: (c) 2014 by Armin Ronacher. |
|
:license: BSD, see LICENSE for more details. |
|
""" |
|
|
|
from __future__ import absolute_import |
|
|
|
from logging import getLogger, StreamHandler, Formatter, getLoggerClass, DEBUG |
|
|
|
|
|
def create_logger(app): |
|
"""Creates a logger for the given application. This logger works |
|
similar to a regular Python logger but changes the effective logging |
|
level based on the application's debug flag. Furthermore this |
|
function also removes all attached handlers in case there was a |
|
logger with the log name before. |
|
""" |
|
Logger = getLoggerClass() |
|
|
|
class DebugLogger(Logger): |
|
def getEffectiveLevel(x): |
|
if x.level == 0 and app.debug: |
|
return DEBUG |
|
return Logger.getEffectiveLevel(x) |
|
|
|
class DebugHandler(StreamHandler): |
|
def emit(x, record): |
|
StreamHandler.emit(x, record) if app.debug else None |
|
|
|
handler = DebugHandler() |
|
handler.setLevel(DEBUG) |
|
handler.setFormatter(Formatter(app.debug_log_format)) |
|
logger = getLogger(app.logger_name) |
|
# just in case that was not a new logger, get rid of all the handlers |
|
# already attached to it. |
|
del logger.handlers[:] |
|
logger.__class__ = DebugLogger |
|
logger.addHandler(handler) |
|
return logger
|
|
|