From: Neal Norwitz Date: Mon, 3 Mar 2003 21:16:39 +0000 (+0000) Subject: Fix SF #692416, don't crash interpreter for _tkinter.deletefilehandler X-Git-Tag: v2.3c1~1599 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=12e221750190903675256ed4ef99aab842b40774;p=thirdparty%2FPython%2Fcpython.git Fix SF #692416, don't crash interpreter for _tkinter.deletefilehandler in addition to createfilehandler and creaetetimerhandler. --- diff --git a/Misc/NEWS b/Misc/NEWS index 5bf335a5a9fb..fa1b8f9fc3c4 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -24,6 +24,10 @@ Core and builtins Extension modules ----------------- +- Using createfilehandler, deletefilehandler, createtimerhandler functions + on Tkinter.tkinter (_tkinter module) no longer crashes the interpreter. + See SF bug #692416. + - Modified the fcntl.ioctl() function to allow modification of a passed mutable buffer (for details see the reference documentation). diff --git a/Modules/_tkinter.c b/Modules/_tkinter.c index 813d27c793e6..100e06f227ff 100644 --- a/Modules/_tkinter.c +++ b/Modules/_tkinter.c @@ -2243,7 +2243,19 @@ Tkapp_DeleteFileHandler(PyObject *self, PyObject *args) if (!PyArg_ParseTuple(args, "O:deletefilehandler", &file)) return NULL; - CHECK_TCL_APPARTMENT; + + if (!self && !tcl_lock) { + /* We don't have the Tcl lock since Tcl is threaded. */ + PyErr_SetString(PyExc_RuntimeError, + "_tkinter.deletefilehandler not supported " + "for threaded Tcl"); + return NULL; + } + + if (self) { + CHECK_TCL_APPARTMENT; + } + tfile = PyObject_AsFileDescriptor(file); if (tfile < 0) return NULL;