summaryrefslogtreecommitdiffstats
path: root/generic/tclZipfs.c
diff options
context:
space:
mode:
authorjan.nijtmans <nijtmans@users.sourceforge.net>2023-07-14 11:13:30 (GMT)
committerjan.nijtmans <nijtmans@users.sourceforge.net>2023-07-14 11:13:30 (GMT)
commite3a6968b93006d08f0e1dd834826e5f4b37fbd1a (patch)
tree25b8638690fc9ea5964d7fbb58ea3c0632a63fe5 /generic/tclZipfs.c
parent2d5f7e8dd76dd8207be4946a14992e3b96c8e2a2 (diff)
downloadtcl-e3a6968b93006d08f0e1dd834826e5f4b37fbd1a.zip
tcl-e3a6968b93006d08f0e1dd834826e5f4b37fbd1a.tar.gz
tcl-e3a6968b93006d08f0e1dd834826e5f4b37fbd1a.tar.bz2
Use "strict" in almost all commands. Only "glob" and environment variables are left out. (Experimental)core-tip-657-candidate
Diffstat (limited to 'generic/tclZipfs.c')
-rw-r--r--generic/tclZipfs.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/generic/tclZipfs.c b/generic/tclZipfs.c
index e9f7157..f5749c9 100644
--- a/generic/tclZipfs.c
+++ b/generic/tclZipfs.c
@@ -2541,7 +2541,11 @@ ZipAddFile(
* crazy enough to embed NULs in filenames, they deserve what they get!
*/
- zpathExt = Tcl_UtfToExternalDString(ZipFS.utf8, zpathTcl, -1, &zpathDs);
+ if (Tcl_UtfToExternalDStringEx(interp, ZipFS.utf8, zpathTcl, TCL_INDEX_NONE, 0, &zpathDs, NULL) != TCL_OK) {
+ Tcl_DStringFree(&zpathDs);
+ return TCL_ERROR;
+ }
+ zpathExt = Tcl_DStringValue(&zpathDs);
zpathlen = strlen(zpathExt);
if (zpathlen + ZIP_CENTRAL_HEADER_LEN > bufsize) {
Tcl_SetObjResult(interp, Tcl_ObjPrintf(
@@ -3210,7 +3214,11 @@ ZipFSMkZipOrImg(
}
z = (ZipEntry *) Tcl_GetHashValue(hPtr);
- name = Tcl_UtfToExternalDString(ZipFS.utf8, z->name, TCL_INDEX_NONE, &ds);
+ if (Tcl_UtfToExternalDStringEx(interp, ZipFS.utf8, z->name, TCL_INDEX_NONE, 0, &ds, NULL) != TCL_OK) {
+ ret = TCL_ERROR;
+ goto done;
+ }
+ name = Tcl_DStringValue(&ds);
len = Tcl_DStringLength(&ds);
SerializeCentralDirectoryEntry(start, end, (unsigned char *) buf,
z, len);