diff options
author | dgp <dgp@users.sourceforge.net> | 2008-06-23 04:18:33 (GMT) |
---|---|---|
committer | dgp <dgp@users.sourceforge.net> | 2008-06-23 04:18:33 (GMT) |
commit | a646385d673df42529a9c5a97493876e9c671d33 (patch) | |
tree | 9b7b63168aa4e80c61630c6d1a81e45ff3779ab1 | |
parent | 8f8c4fc92943cd0497881b0185ec142142698b4b (diff) | |
download | tcl-a646385d673df42529a9c5a97493876e9c671d33.zip tcl-a646385d673df42529a9c5a97493876e9c671d33.tar.gz tcl-a646385d673df42529a9c5a97493876e9c671d33.tar.bz2 |
* generic/tclPathObj.c: Fixed bug in Tcl_GetTranslatedPath() when
operating on the "Special path" variant of the "path" Tcl_ObjType
intrep. A full normalization was getting done, in particular, coercing
relative paths to absolute, contrary to what the function of
producing the "translated path" is supposed to do. [Bug 1972879].
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | generic/tclPathObj.c | 11 |
2 files changed, 17 insertions, 2 deletions
@@ -1,3 +1,11 @@ +2008-06-23 Don Porter <dgp@users.sourceforge.net> + + * generic/tclPathObj.c: Fixed bug in Tcl_GetTranslatedPath() when + operating on the "Special path" variant of the "path" Tcl_ObjType + intrep. A full normalization was getting done, in particular, coercing + relative paths to absolute, contrary to what the function of + producing the "translated path" is supposed to do. [Bug 1972879]. + 2008-06-20 Don Porter <dgp@users.sourceforge.net> * changes: Updates for 8.6a1 release. diff --git a/generic/tclPathObj.c b/generic/tclPathObj.c index 80b511e..89fb210 100644 --- a/generic/tclPathObj.c +++ b/generic/tclPathObj.c @@ -10,7 +10,7 @@ * See the file "license.terms" for information on usage and redistribution of * this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclPathObj.c,v 1.67 2008/04/27 22:21:31 dkf Exp $ + * RCS: @(#) $Id: tclPathObj.c,v 1.68 2008/06/23 04:18:34 dgp Exp $ */ #include "tclInt.h" @@ -1596,7 +1596,14 @@ Tcl_FSGetTranslatedPath( srcFsPathPtr = PATHOBJ(pathPtr); if (srcFsPathPtr->translatedPathPtr == NULL) { if (PATHFLAGS(pathPtr) != 0) { - retObj = Tcl_FSGetNormalizedPath(interp, pathPtr); + int numBytes; + const char *bytes = Tcl_GetStringFromObj(pathPtr, &numBytes); + Tcl_Obj *copy = Tcl_NewStringObj(bytes, numBytes); + Tcl_IncrRefCount(copy); + retObj = Tcl_FSGetTranslatedPath(interp, copy); + srcFsPathPtr->translatedPathPtr = retObj; + Tcl_IncrRefCount(retObj); + Tcl_DecrRefCount(copy); } else { /* * It is a pure absolute, normalized path object. This is |