This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author kristjan.jonsson
Recipients benjamin.peterson, kristjan.jonsson, meador.inge, pitrou
Date 2012-04-16.21:36:05
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1334612165.74.0.699758963229.issue8212@psf.upfronthosting.co.za>
In-reply-to
Content
Incidentally, Looking at this, I noticed code such as: (textio.c)

static int
_textiowrapper_clear(textio *self)
{
    if (self->ok && _PyIOBase_finalize((PyObject *) self) < 0)
        return -1;

This shows something scary:  During a GC run, it is possible to invoke the  "close()" method on a textio object.  This is dangerous, and probably not allowed at all.
Returning -1 from a tp_clear() slot has no particular meaning, and the return value appears to be ignored by gcmodule.c (also, it won't ever ber resurrected through that pathway, since it is incref'd first:
    Py_INCREF(op);
    clear(op);
    Py_DECREF(op);
)

See Issue 9141 for more info.
IMHO, this is another case where objects must tell GC that they cannot be collected but instead must be placed in gc.garbage.

This probably requires a defect of its own.
History
Date User Action Args
2012-04-16 21:36:05kristjan.jonssonsetrecipients: + kristjan.jonsson, pitrou, benjamin.peterson, meador.inge
2012-04-16 21:36:05kristjan.jonssonsetmessageid: <1334612165.74.0.699758963229.issue8212@psf.upfronthosting.co.za>
2012-04-16 21:36:05kristjan.jonssonlinkissue8212 messages
2012-04-16 21:36:05kristjan.jonssoncreate