Pablo Galindo Salgado <pablog...@gmail.com> added the comment:

In https://bugs.python.org/issue33418 I proposed reverting tp_clear on function 
objects.

>What should be done when a function with func_code=NULL is called?

We can set the error indicator at least. Although I agree that it seems 
suboptimal. At least I think we should add an assertion to check that the 
function called is valid so we can identify this situation easier.

What downsides do we see raising an exception?

Notice that this can happen without involving weak references. For example:

You have object A and B. A is a function. The destructor of B calls A. A and B 
are in a cycle. When calling tp_clear on A the refs of B reaches 0, trying to 
call A and .... Boom!

Either we remove tp_clear or somehow we have to protect all callers of the 
function. Technically, any field cleared from tp_cleared leaves the function in 
an inconsistent state

----------

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

Reply via email to