diff options
| author | ferrieux@users.sourceforge.net <ferrieux> | 2009-07-22 08:41:59 (GMT) |
|---|---|---|
| committer | ferrieux@users.sourceforge.net <ferrieux> | 2009-07-22 08:41:59 (GMT) |
| commit | f77adce3fe5bf7965131d22d9c6e525d3e7e3315 (patch) | |
| tree | 5fbbfdf11fe30a783e49463ffe7269a92448d86b /generic/tclEvent.c | |
| parent | 256f54d40e0de3a3b4414d67faed3a6c020e121d (diff) | |
| download | tcl-f77adce3fe5bf7965131d22d9c6e525d3e7e3315.zip tcl-f77adce3fe5bf7965131d22d9c6e525d3e7e3315.tar.gz tcl-f77adce3fe5bf7965131d22d9c6e525d3e7e3315.tar.bz2 | |
Refined the 20090617 patch on [exit] streamlining, so that it now correctly calls thread exit handlers for the calling thread, which includes <Destroy> bindings in Tk [Bug 2001201 again].
Diffstat (limited to 'generic/tclEvent.c')
| -rw-r--r-- | generic/tclEvent.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/generic/tclEvent.c b/generic/tclEvent.c index 6c55ef0..4f67608 100644 --- a/generic/tclEvent.c +++ b/generic/tclEvent.c @@ -12,7 +12,7 @@ * See the file "license.terms" for information on usage and redistribution of * this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclEvent.c,v 1.90 2009/06/18 09:41:26 dkf Exp $ + * RCS: @(#) $Id: tclEvent.c,v 1.91 2009/07/22 08:41:59 ferrieux Exp $ */ #include "tclInt.h" @@ -952,11 +952,20 @@ Tcl_Exit( InvokeExitHandlers(); /* - * This triggers a flush of the Tcl_Channels that may have - * data enqueued. + * Ensure the thread-specific data is initialised as it is used in + * Tcl_FinalizeThread() */ - TclFinalizeIOSubsystem(); - + + (void) TCL_TSD_INIT(&dataKey); + + /* + * Now finalize the calling thread only (others are not safely + * reachable). Among other things, this triggers a flush of the + * Tcl_Channels that may have data enqueued. + */ + + Tcl_FinalizeThread(); + TclpExit(status); Tcl_Panic("OS exit failed!"); } |
