From 8d399b98d3ed5c765835594100c4d36fb2f739dc 2018-05-16 20:41:49 From: Matthias Bussonnier Date: 2018-05-16 20:41:49 Subject: [PATCH] Merge pull request #11139 from jdemeyer/signature signature: use inspect instead of type checks --- diff --git a/IPython/utils/_signatures.py b/IPython/utils/_signatures.py index 3b53e89..20f52b9 100644 --- a/IPython/utils/_signatures.py +++ b/IPython/utils/_signatures.py @@ -21,6 +21,7 @@ import itertools import functools import re import types +import inspect # patch for single-file @@ -71,7 +72,7 @@ def signature(obj): if not callable(obj): raise TypeError('{0!r} is not a callable object'.format(obj)) - if isinstance(obj, types.MethodType): + if inspect.ismethod(obj): if obj.__self__ is None: # Unbound method - treat it as a function (no distinction in Py 3) obj = obj.__func__ @@ -96,7 +97,7 @@ def signature(obj): else: return signature(wrapped) - if isinstance(obj, types.FunctionType): + if inspect.isfunction(obj): return Signature.from_function(obj) if isinstance(obj, functools.partial): @@ -511,7 +512,7 @@ class Signature(object): def from_function(cls, func): '''Constructs Signature for the given python function''' - if not isinstance(func, types.FunctionType): + if not inspect.isfunction(func): raise TypeError('{0!r} is not a Python function'.format(func)) Parameter = cls._parameter_cls