From: Jeff Hobbs Date: Fri, 26 May 2006 19:44:07 +0000 (+0000) Subject: * generic/vfs.c (VfsOpenFileChannel): handle closing channels that X-Git-Tag: vfs-1-4~58 X-Git-Url: https://xmpp.privyetmir.co.uk/gitweb?a=commitdiff_plain;h=a8cd463081a31a16d36465ac7ef5bdee81bd256f;p=tclvfs * generic/vfs.c (VfsOpenFileChannel): handle closing channels that were inherited as std channels. [Bug 1468291] --- diff --git a/ChangeLog b/ChangeLog index be3ba22..c04a2ea 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2006-05-26 Jeff Hobbs + + * generic/vfs.c (VfsOpenFileChannel): handle closing channels that + were inherited as std channels. [Bug 1468291] + 2006-03-12 Vince Darley * library/ftpvfs.tcl: provide caching of listings to improve diff --git a/generic/vfs.c b/generic/vfs.c index 7db4160..c5285a2 100644 --- a/generic/vfs.c +++ b/generic/vfs.c @@ -1393,8 +1393,23 @@ VfsOpenFileChannel(cmdInterp, pathPtr, mode, permissions) * Tcl_DetachChannel to do this for us. We must use the * correct interpreter. */ + if (Tcl_IsStandardChannel(chan)) { + /* + * If we have somehow ended up with a VFS channel being a std + * channel, it is likely auto-inherited, which we need to reverse. + * [Bug 1468291] + */ + if (chan == Tcl_GetStdChannel(TCL_STDIN)) { + Tcl_SetStdChannel(NULL, TCL_STDIN); + } else if (chan == Tcl_GetStdChannel(TCL_STDOUT)) { + Tcl_SetStdChannel(NULL, TCL_STDOUT); + } else if (chan == Tcl_GetStdChannel(TCL_STDERR)) { + Tcl_SetStdChannel(NULL, TCL_STDERR); + } + Tcl_UnregisterChannel(NULL, chan); + } Tcl_DetachChannel(interp, chan); - + if (closeCallback != NULL) { VfsChannelCleanupInfo *channelRet = NULL; channelRet = (VfsChannelCleanupInfo*) @@ -1439,7 +1454,9 @@ VfsCloseProc(ClientData clientData) { * callback will fail, so we register the channel (this allows * the Tcl code to use the channel's string-name). */ - Tcl_RegisterChannel(interp, chan); + if (!Tcl_IsStandardChannel(chan)) { + Tcl_RegisterChannel(interp, chan); + } if (!(Tcl_GetChannelMode(chan) & TCL_READABLE)) { /* @@ -1465,7 +1482,9 @@ VfsCloseProc(ClientData clientData) { * already being closed. So, we do the same trick as above to * unregister it without cleanup. */ - Tcl_DetachChannel(interp, chan); + if (!Tcl_IsStandardChannel(chan)) { + Tcl_DetachChannel(interp, chan); + } Tcl_RestoreResult(interp, &savedResult); ckfree((char*)channelRet);