summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/util/langhelpers.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2015-10-29 14:38:34 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2015-10-29 14:38:34 -0400
commit382950b70150434f124b6dc27df2b360e7d0331e (patch)
tree4dcbbc1e5f4aa24ffc3a1c522c3bd77cbeeaf0cd /lib/sqlalchemy/util/langhelpers.py
parent98c1dcc6bcade313a254fe11e8efa3c5b5ad959e (diff)
parente31211c578854d63128a30c036e40eee5c43edc7 (diff)
downloadsqlalchemy-382950b70150434f124b6dc27df2b360e7d0331e.tar.gz
Merge branch 'pr204'
Diffstat (limited to 'lib/sqlalchemy/util/langhelpers.py')
-rw-r--r--lib/sqlalchemy/util/langhelpers.py22
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