Nick Coghlan added the comment:

An alternative approach would be to change inspect.unwrap() to use 
getattr_static() rather than the usual getattr().

The downside of that would be potentially breaking true object proxies, like 
the 3rd party wrapt module and weakref.proxy.

However, what if inspect.signature implemented a limit on the number of 
recursive descents it permitted (e.g. based on sys.getrecursionlimit()), and 
then halted the descent, the same way it does if it finds a `__signature__` 
attribute on a wrapped object?

`inspect.unwraps` makes that relatively straightforward:

    unwrap_count = 0
    recursion_limit = sys.getrecursionlimit()
    def stop_unwrapping(wrapped):
        nonlocal unwrap_count
        unwrap_count += 1
        return unwrap_count >= recursion_limit
    innermost_function = inspect.unwrap(outer_function, stop=stop_unwrapping)

Alternatively, that hard limit on the recursive descent could be baked directly 
into the loop detection logic in inspect.unwrap (raising ValueError rather than 
returning the innermost function reached), as Chris suggested above. We'd then 
just need to check inspect.signature was handling that potential failure mode 
correctly.

----------

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue25532>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to