You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
File ~\.conda\envs\sage-dev\Lib\inspect.py:943, in getfile(object)
941 if iscode(object):
942 return object.co_filename
--> 943 raise TypeError('module, class, method, function, traceback, frame, or '
944 'code object was expected, got {}'.format(
945 type(object).__name__))
since the cython function is not correct recognized as a "true" function (i.e. it is not derived from FunctionType). But since a Cython function correct provides __code__, all the information is actually there to properly get the source file.
While it is quite possible to emulate the interface of functions in Cython's own function type, and recent Cython releases have seen several improvements here, the "inspect" module does not consider a Cython implemented function a "function", because it tests the object type explicitly instead of comparing an abstract interface or an abstract base class. This has a negative impact on code that uses inspect to inspect function objects, but would require a change to Python itself.
and
At the very least, the inspect module should use more duck-typing internally. For example, consider this code from "getfile":
Running
inspect.getsource(numpy.random.random_sample)
yieldssince the cython function is not correct recognized as a "true" function (i.e. it is not derived from
FunctionType
). But since a Cython function correct provides__code__
, all the information is actually there to properly get the source file.Refs: https://github.com/cython/cython/blob/030e3886fa094ecae6121f8ccacaf814956dca5c/docs/src/userguide/limitations.rst#L34
and
Originally posted by @jdemeyer in #74257
Linked PRs
inspect
to support Cython #131632The text was updated successfully, but these errors were encountered: