diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2015-10-29 14:38:34 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2015-10-29 14:38:34 -0400 |
| commit | 382950b70150434f124b6dc27df2b360e7d0331e (patch) | |
| tree | 4dcbbc1e5f4aa24ffc3a1c522c3bd77cbeeaf0cd /lib/sqlalchemy/util/langhelpers.py | |
| parent | 98c1dcc6bcade313a254fe11e8efa3c5b5ad959e (diff) | |
| parent | e31211c578854d63128a30c036e40eee5c43edc7 (diff) | |
| download | sqlalchemy-382950b70150434f124b6dc27df2b360e7d0331e.tar.gz | |
Merge branch 'pr204'
Diffstat (limited to 'lib/sqlalchemy/util/langhelpers.py')
| -rw-r--r-- | lib/sqlalchemy/util/langhelpers.py | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/lib/sqlalchemy/util/langhelpers.py b/lib/sqlalchemy/util/langhelpers.py index 743afccfd..e9d4e09bc 100644 --- a/lib/sqlalchemy/util/langhelpers.py +++ b/lib/sqlalchemy/util/langhelpers.py @@ -1377,3 +1377,25 @@ class EnsureKWArgType(type): return fn(*arg) return update_wrapper(wrap, fn) + +def wrap_callable(wrapper, fn): + """Augment functools.update_wrapper() to work with objects with + a ``__call__()`` method. + + :param fn: + object with __call__ method + + """ + if hasattr(fn, '__name__'): + return update_wrapper(wrapper, fn) + else: + _f = wrapper + _f.__name__ = fn.__class__.__name__ + _f.__module__ = fn.__module__ + + if hasattr(fn.__call__, '__doc__') and fn.__call__.__doc__: + _f.__doc__ = fn.__call__.__doc__ + elif fn.__doc__: + _f.__doc__ = fn.__doc__ + + return _f |
