diff options
| author | Sylvain Marie <sylvain.marie@schneider-electric.com> | 2018-10-26 14:09:47 +0200 |
|---|---|---|
| committer | Sylvain Marie <sylvain.marie@schneider-electric.com> | 2018-10-26 14:09:47 +0200 |
| commit | 230964fbc941263c9371a3de4196f43f72792e11 (patch) | |
| tree | fafc2f8b8ff3d916ced599f4cb58c51fc1cb0406 /src | |
| parent | 18e0912a155a053b1b57917ff9c5485fa4136cc0 (diff) | |
| download | python-decorator-git-230964fbc941263c9371a3de4196f43f72792e11.tar.gz | |
Improved `decorate` so as to support generator callers. Fixes #56
Diffstat (limited to 'src')
| -rw-r--r-- | src/decorator.py | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/src/decorator.py b/src/decorator.py index fd0e9ef..ccb2204 100644 --- a/src/decorator.py +++ b/src/decorator.py @@ -216,9 +216,19 @@ class FunctionMaker(object): return self.make(body, evaldict, addsource, **attrs) +try: + from inspect import isgeneratorfunction +except ImportError: + # assume no generator function in very old python versions + def isgeneratorfunction(): + return False + + def decorate(func, caller, extras=()): """ decorate(func, caller) decorates a function using a caller. + If the caller is a generator function, the resulting function + will be a generator function. """ evaldict = dict(_call_=caller, _func_=func) es = '' @@ -226,9 +236,14 @@ def decorate(func, caller, extras=()): ex = '_e%d_' % i evaldict[ex] = extra es += ex + ', ' - fun = FunctionMaker.create( - func, "return _call_(_func_, %s%%(shortsignature)s)" % es, - evaldict, __wrapped__=func) + if isgeneratorfunction(caller): + fun = FunctionMaker.create( + func, "for res in _call_(_func_, %s%%(shortsignature)s):\n" + " yield res" % es, evaldict, __wrapped__=func) + else: + fun = FunctionMaker.create( + func, "return _call_(_func_, %s%%(shortsignature)s)" % es, + evaldict, __wrapped__=func) if hasattr(func, '__qualname__'): fun.__qualname__ = func.__qualname__ return fun |
