Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 29 additions & 7 deletions toolz/functoolz.py
Original file line number Diff line number Diff line change
Expand Up @@ -422,13 +422,7 @@ def memof(*args, **kwargs):
cache[k] = result = func(*args, **kwargs)
return result

try:
memof.__name__ = func.__name__
except AttributeError:
pass
memof.__doc__ = func.__doc__
memof.__wrapped__ = func
return memof
return _update_wrapper(memof, func)


class Compose(object):
Expand Down Expand Up @@ -1055,3 +1049,31 @@ def is_arity(n, func, sigspec=None):
"""

from . import _signatures as _sigs


_assigned = (
'__module__',
'__name__',
'__qualname__',
'__doc__',
'__annotations__',
)
_updated = '__dict__',


def _update_wrapper(wrapper, wrapped, assigned=_assigned, updated=_updated):
"""Update the attributes of a wrapping function.

Implementation is backported from CPython 3.6
"""
for attr in assigned:
try:
value = getattr(wrapped, attr)
except AttributeError:
pass
else:
setattr(wrapper, attr, value)
for attr in updated:
getattr(wrapper, attr).update(getattr(wrapped, attr, {}))
wrapper.__wrapped__ = wrapped
return wrapper
4 changes: 4 additions & 0 deletions toolz/tests/test_functoolz.py
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,11 @@ def foo():
Docstring
"""
pass

memoized_foo = memoize(foo)
assert memoized_foo.__name__ == foo.__name__
assert memoized_foo.__doc__ == foo.__doc__
assert memoized_foo.__module__ == foo.__module__ == __name__
assert memoized_foo.__wrapped__ is foo


Expand Down