Lorsque l'on définit un décorateur à l'aide d'une classe, comment faire pour transférer automatiquement le __name__
, __module__
y __doc__
? Normalement, je devrais utiliser le décorateur @wraps de functools. Voici ce que j'ai fait à la place pour une classe (ce n'est pas entièrement mon code) :
class memoized:
"""Decorator that caches a function's return value each time it is called.
If called later with the same arguments, the cached value is returned, and
not re-evaluated.
"""
def __init__(self, func):
super().__init__()
self.func = func
self.cache = {}
def __call__(self, *args):
try:
return self.cache[args]
except KeyError:
value = self.func(*args)
self.cache[args] = value
return value
except TypeError:
# uncacheable -- for instance, passing a list as an argument.
# Better to not cache than to blow up entirely.
return self.func(*args)
def __repr__(self):
return self.func.__repr__()
def __get__(self, obj, objtype):
return functools.partial(self.__call__, obj)
__doc__ = property(lambda self:self.func.__doc__)
__module__ = property(lambda self:self.func.__module__)
__name__ = property(lambda self:self.func.__name__)
Existe-t-il un décorateur standard pour automatiser la création du module de nom et de la doc ? Aussi, pour automatiser la méthode get (je suppose que c'est pour créer des méthodes liées ?) Y a-t-il des méthodes manquantes ?