summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjan.nijtmans <nijtmans@users.sourceforge.net>2014-11-03 12:44:55 (GMT)
committerjan.nijtmans <nijtmans@users.sourceforge.net>2014-11-03 12:44:55 (GMT)
commitbce5edef8b197d622f6f22b25021afd987743698 (patch)
tree7faccb16d2a2785049ba78869754cffc11a0ef41
parent746cb2938e7c4bf900a55899aa1445ece67d52ea (diff)
downloadtcl-bce5edef8b197d622f6f22b25021afd987743698.zip
tcl-bce5edef8b197d622f6f22b25021afd987743698.tar.gz
tcl-bce5edef8b197d622f6f22b25021afd987743698.tar.bz2
Add test-case for previous commit, which shows that when trying to open a filename with invalid characters gives the right error-message. (same bug existed on UNIX too, which is now fixed)
-rw-r--r--tests/fileSystem.test3
-rw-r--r--unix/tclUnixChan.c5
2 files changed, 8 insertions, 0 deletions
diff --git a/tests/fileSystem.test b/tests/fileSystem.test
index 161ebc3..c255b1e 100644
--- a/tests/fileSystem.test
+++ b/tests/fileSystem.test
@@ -708,6 +708,9 @@ test filesystem-6.32 {empty file name} {
test filesystem-6.33 {empty file name} {
list [catch {file writable ""} msg] $msg
} {0 0}
+test filesystem-6.34 {file name with (invalid) nul character} {
+ list [catch "open foo\x00" msg] $msg
+} [list 1 "couldn't open \"foo\x00\": filename is invalid on this platform"]
# Make sure the testfilesystem hasn't been registered.
if {[testConstraint testfilesystem]} {
diff --git a/unix/tclUnixChan.c b/unix/tclUnixChan.c
index 1d60340..89c9a27 100644
--- a/unix/tclUnixChan.c
+++ b/unix/tclUnixChan.c
@@ -1647,6 +1647,11 @@ TclpOpenFileChannel(
native = Tcl_FSGetNativePath(pathPtr);
if (native == NULL) {
+ if (interp != (Tcl_Interp *) NULL) {
+ Tcl_AppendResult(interp, "couldn't open \"",
+ TclGetString(pathPtr), "\": filename is invalid on this platform",
+ NULL);
+ }
return NULL;
}