diff options
author | Neal Norwitz <nnorwitz@gmail.com> | 2003-03-03 21:16:39 +0000 |
---|---|---|
committer | Neal Norwitz <nnorwitz@gmail.com> | 2003-03-03 21:16:39 +0000 |
commit | 12e221750190903675256ed4ef99aab842b40774 (patch) | |
tree | 5185d087f5b91394a16b49039ea32cd98fba8fc8 | |
parent | a52b85262ae7c0ce3ba92ee7e933f5a449690b8c (diff) | |
download | cpython-git-12e221750190903675256ed4ef99aab842b40774.tar.gz |
Fix SF #692416, don't crash interpreter for _tkinter.deletefilehandler
in addition to createfilehandler and creaetetimerhandler.
-rw-r--r-- | Misc/NEWS | 4 | ||||
-rw-r--r-- | Modules/_tkinter.c | 14 |
2 files changed, 17 insertions, 1 deletions
@@ -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 813d27c793..100e06f227 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; |