summaryrefslogtreecommitdiffstats
path: root/unix/tclUnixFile.c
diff options
context:
space:
mode:
authoroehhar <harald.oehlmann@elmicron.de>2014-05-29 14:53:45 (GMT)
committeroehhar <harald.oehlmann@elmicron.de>2014-05-29 14:53:45 (GMT)
commitbf498960d9c30a5bfa7c6b1d1f157b68706a7e04 (patch)
tree9be3430887ad5943e0fe6308e10daaf21569c76a /unix/tclUnixFile.c
parent77a33cf2ff238834a785500a7c1b75a13f90fec1 (diff)
parent334ffdfa501158f3dd054d3c0de7102620fd8d6c (diff)
downloadtcl-bf498960d9c30a5bfa7c6b1d1f157b68706a7e04.zip
tcl-bf498960d9c30a5bfa7c6b1d1f157b68706a7e04.tar.gz
tcl-bf498960d9c30a5bfa7c6b1d1f157b68706a7e04.tar.bz2
merge core-8-5-branch
Diffstat (limited to 'unix/tclUnixFile.c')
-rw-r--r--unix/tclUnixFile.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/unix/tclUnixFile.c b/unix/tclUnixFile.c
index 29f1aba..c5f75a7 100644
--- a/unix/tclUnixFile.c
+++ b/unix/tclUnixFile.c
@@ -1111,6 +1111,12 @@ TclNativeCreateNativeRep(
str = Tcl_GetStringFromObj(validPathPtr, &len);
Tcl_UtfToExternalDString(NULL, str, len, &ds);
len = Tcl_DStringLength(&ds) + sizeof(char);
+ if (strlen(Tcl_DStringValue(&ds)) < len - sizeof(char)) {
+ /* See bug [3118489]: NUL in filenames */
+ Tcl_DecrRefCount(validPathPtr);
+ Tcl_DStringFree(&ds);
+ return NULL;
+ }
Tcl_DecrRefCount(validPathPtr);
nativePathPtr = ckalloc((unsigned) len);
memcpy((void*)nativePathPtr, (void*)Tcl_DStringValue(&ds), (size_t) len);