Я придумал следующий код для украшения методов экземпляра с использованием декоратора, которому в качестве аргумента требуется сам экземпляр:
from functools import wraps
def logging_decorator(tricky_instance):
def wrapper(fn):
@wraps(fn)
def wrapped(*a, **kw):
if tricky_instance.log:
print("Calling %s.." % fn.__name__)
return fn(*a, **kw)
return wrapped
return wrapper
class Tricky(object):
def __init__(self, log):
self.log = log
self.say_hi = logging_decorator(self)(self.say_hi)
def say_hi(self):
print("Hello, world!")
i1 = Tricky(log=True)
i2 = Tricky(log=False)
i1.say_hi()
i2.say_hi()
Это, кажется, работает отлично, но я боюсь, что я мог пропустить некоторые непреднамеренные побочные эффекты этого трюка. Я собираюсь выстрелить себе в ногу, или это безопасно?
Обратите внимание, что я на самом деле не хочу использовать это для регистрации, это просто кратчайший значимый пример, который я могу придумать.