Доступ к декоратору в родительском классе от дочернего в Python - PullRequest
7 голосов
/ 06 августа 2010

как можно получить доступ к декоратору из базового класса у ребенка?

Я предположил (ошибочно), что ФФГ. будет работать:

class baseclass(object):
    def __init__(self):
        print 'hey this is the base'

    def _deco(func):
        def wrapper(*arg):
            res = func(*arg)
            print 'I\'m a decorator. This is fabulous, but that colour, so last season sweetiedarling'
            return res
        return wrapper

    @_deco
    def basefunc(self):
        print 'I\'m a base function'

Этот класс работает нормально, но затем я создаю дочерний класс, наследующий от него:

class otherclass(baseclass):
    def __init__(self):
        super(otherclass, self).__init__()
        print 'other class'


    @_deco
    def meh(self):
        print 'I\'m a function'

Это даже не импортирует должным образом, не говоря уже о запуске. @_deco не определено. Попытка baseclass._deco выдает ошибку несвязанного метода _deco (), что неудивительно.

Любая идея, как это сделать, я действительно хотел бы инкапсулировать декоратор в классе, но я не женат на этой идее, и мне нужно назвать ее в базовом и дочернем классе. *

1 Ответ

9 голосов
/ 06 августа 2010
class baseclass(object):
    def __init__(self):
        print 'hey this is the base'

    def _deco(func):
        def wrapper(*arg):
            res = func(*arg)
            print 'I\'m a decorator. This is fabulous, but that colour, so last season sweetiedarling'
            return res
        return wrapper

    @_deco
    def basefunc(self):
        print 'I\'m a base function'

    @_deco
    def basefunc2(self):
        print "I'm another base function"

   #no more uses of _deco in this class
    _deco = staticmethod(_deco) 
   # this is the key. it must be executed after all of the uses of _deco in 
   # the base class. this way _deco is some sort weird internal function that 
   # can be called from within the class namespace while said namespace is being 
   # created and a proper static method for subclasses or external callers.


class otherclass(baseclass):
    def __init__(self):
        super(otherclass, self).__init__()
        print 'other class'


    @baseclass._deco
    def meh(self):
        print 'I\'m a function'
...