2010-02-26 08:14:33 +00:00
|
|
|
from allmydata.util import nummedobj
|
2008-12-17 00:38:07 +00:00
|
|
|
|
2007-12-13 03:23:53 +00:00
|
|
|
from foolscap.logging import log
|
2008-09-20 17:34:27 +00:00
|
|
|
from twisted.python import log as tw_log
|
2007-12-13 03:23:53 +00:00
|
|
|
|
2008-01-08 00:32:45 +00:00
|
|
|
NOISY = log.NOISY # 10
|
|
|
|
OPERATIONAL = log.OPERATIONAL # 20
|
|
|
|
UNUSUAL = log.UNUSUAL # 23
|
|
|
|
INFREQUENT = log.INFREQUENT # 25
|
|
|
|
CURIOUS = log.CURIOUS # 28
|
|
|
|
WEIRD = log.WEIRD # 30
|
|
|
|
SCARY = log.SCARY # 35
|
|
|
|
BAD = log.BAD # 40
|
|
|
|
|
|
|
|
|
2007-12-13 03:23:53 +00:00
|
|
|
msg = log.msg
|
|
|
|
|
2008-09-20 17:34:27 +00:00
|
|
|
# If log.err() happens during a unit test, the unit test should fail. We
|
|
|
|
# accomplish this by sending it to twisted.log too. When a WEIRD/SCARY/BAD
|
|
|
|
# thing happens that is nevertheless handled, use log.msg(failure=f,
|
|
|
|
# level=WEIRD) instead.
|
|
|
|
|
2010-01-12 01:33:43 +00:00
|
|
|
def err(failure=None, _why=None, **kwargs):
|
|
|
|
tw_log.err(failure, _why, **kwargs)
|
2007-12-13 03:23:53 +00:00
|
|
|
if 'level' not in kwargs:
|
|
|
|
kwargs['level'] = log.UNUSUAL
|
2010-01-12 01:33:43 +00:00
|
|
|
return log.err(failure, _why, **kwargs)
|
2008-12-17 00:38:07 +00:00
|
|
|
|
|
|
|
class LogMixin(object):
|
|
|
|
""" I remember a msg id and a facility and pass them to log.msg() """
|
|
|
|
def __init__(self, facility=None, grandparentmsgid=None):
|
|
|
|
self._facility = facility
|
|
|
|
self._grandparentmsgid = grandparentmsgid
|
|
|
|
self._parentmsgid = None
|
|
|
|
|
|
|
|
def log(self, msg, facility=None, parent=None, *args, **kwargs):
|
|
|
|
if facility is None:
|
|
|
|
facility = self._facility
|
2017-12-30 23:23:43 +00:00
|
|
|
pmsgid = None
|
2008-12-17 00:38:07 +00:00
|
|
|
if parent is None:
|
|
|
|
pmsgid = self._parentmsgid
|
2017-12-30 23:23:43 +00:00
|
|
|
if pmsgid is None:
|
|
|
|
pmsgid = self._grandparentmsgid
|
2008-12-17 00:38:07 +00:00
|
|
|
msgid = log.msg(msg, facility=facility, parent=pmsgid, *args, **kwargs)
|
|
|
|
if self._parentmsgid is None:
|
|
|
|
self._parentmsgid = msgid
|
|
|
|
return msgid
|
|
|
|
|
|
|
|
class PrefixingLogMixin(nummedobj.NummedObj, LogMixin):
|
|
|
|
""" I prepend a prefix to each msg, which includes my class and instance number as well as
|
|
|
|
a prefix supplied by my subclass. """
|
|
|
|
def __init__(self, facility=None, grandparentmsgid=None, prefix=''):
|
|
|
|
nummedobj.NummedObj.__init__(self)
|
|
|
|
LogMixin.__init__(self, facility, grandparentmsgid)
|
|
|
|
|
|
|
|
if prefix:
|
|
|
|
self._prefix = "%s(%s): " % (self.__repr__(), prefix)
|
|
|
|
else:
|
|
|
|
self._prefix = "%s: " % (self.__repr__(),)
|
|
|
|
|
2009-01-07 18:54:11 +00:00
|
|
|
def log(self, msg="", facility=None, parent=None, *args, **kwargs):
|
2008-12-17 00:38:07 +00:00
|
|
|
return LogMixin.log(self, self._prefix + msg, facility, parent, *args, **kwargs)
|