summaryrefslogtreecommitdiff
path: root/archivers/torrentzip/files/patch-src-trrntzip.c
diff options
context:
space:
mode:
authorPav Lucistnik <pav@FreeBSD.org>2005-05-26 20:40:29 +0000
committerPav Lucistnik <pav@FreeBSD.org>2005-05-26 20:40:29 +0000
commitb5706294b0d0f4dcae40b713e82491ebb10dab9f (patch)
tree7af4c7af83b590d677e53c506dcda0d0d541f4dc /archivers/torrentzip/files/patch-src-trrntzip.c
parent- Update to 20050523.0845 snapshot (diff)
- Fix bug: Torrentzip uses the read permission flag to check if a zip file
needs to be processed. It does this by first setting all zip files to 0400, then as it processes the zip file it changes the permissions to 0200. PR: ports/81502 Submitted by: Scot W. Hetzel <swhetzel@gmail.com> (maintainer) Obtained from: author
Diffstat (limited to 'archivers/torrentzip/files/patch-src-trrntzip.c')
-rw-r--r--archivers/torrentzip/files/patch-src-trrntzip.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/archivers/torrentzip/files/patch-src-trrntzip.c b/archivers/torrentzip/files/patch-src-trrntzip.c
new file mode 100644
index 000000000000..e54c5b305054
--- /dev/null
+++ b/archivers/torrentzip/files/patch-src-trrntzip.c
@@ -0,0 +1,32 @@
+--- src/trrntzip.c-orig Mon May 2 08:38:40 2005
++++ src/trrntzip.c Sat May 7 02:51:55 2005
+@@ -716,7 +716,7 @@
+
+ if (dirp)
+ {
+- // First set all the files to read-only. This is so we can skip
++ // First set the sticky bit on all files. This is so we can skip
+ // our new zipfiles if they are returned by readdir() a second time.
+ while (direntp = readdir (dirp))
+ {
+@@ -732,7 +732,7 @@
+
+ if (strstr (szTmpBuf, ".zip\0"))
+ {
+- chmod (direntp->d_name, S_IRUSR);
++ chmod (direntp->d_name, istat.st_mode | S_ISTXT);
+ }
+ }
+ // Zip file is actually a dir
+@@ -780,9 +780,9 @@
+ sprintf (szTmpBuf, "%s", direntp->d_name);
+ strlwr (szTmpBuf);
+
+- if (strstr (szTmpBuf, ".zip\0") && !(istat.st_mode & S_IWUSR))
++ if (strstr (szTmpBuf, ".zip\0") && (istat.st_mode & S_ISTXT))
+ {
+- chmod (direntp->d_name, S_IWUSR);
++ chmod (direntp->d_name, istat.st_mode & ~S_ISTXT);
+ mig.cEncounteredZips++;
+
+ if (!mig.fProcessLog)