diff options
author | Pav Lucistnik <pav@FreeBSD.org> | 2005-05-26 20:40:29 +0000 |
---|---|---|
committer | Pav Lucistnik <pav@FreeBSD.org> | 2005-05-26 20:40:29 +0000 |
commit | b5706294b0d0f4dcae40b713e82491ebb10dab9f (patch) | |
tree | 7af4c7af83b590d677e53c506dcda0d0d541f4dc /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.c | 32 |
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) |