summaryrefslogtreecommitdiffstats
path: root/libzip-0.11-php.patch
diff options
context:
space:
mode:
authorRemi Collet <fedora@famillecollet.com>2013-08-08 11:51:27 +0200
committerRemi Collet <fedora@famillecollet.com>2013-08-08 11:51:27 +0200
commit098af2ee44706eda1d49ace737e4979de35207ca (patch)
treee334cf6b2a8c7fd1419643cde4718855c0b465e1 /libzip-0.11-php.patch
parent78ef147bbb6d9964f90207014412c8395e53e2a4 (diff)
libzip 0.11.1 WIP
Diffstat (limited to 'libzip-0.11-php.patch')
-rw-r--r--libzip-0.11-php.patch67
1 files changed, 67 insertions, 0 deletions
diff --git a/libzip-0.11-php.patch b/libzip-0.11-php.patch
new file mode 100644
index 0000000..dd12de9
--- /dev/null
+++ b/libzip-0.11-php.patch
@@ -0,0 +1,67 @@
+diff -ru libzip-0.11.1.orig/lib/zip_close.c libzip-0.11.1/lib/zip_close.c
+--- libzip-0.11.1.orig/lib/zip_close.c 2013-08-08 11:01:26.000000000 +0200
++++ libzip-0.11.1/lib/zip_close.c 2013-08-08 11:03:07.000000000 +0200
+@@ -596,18 +596,22 @@
+ FILE *tfp;
+
+ if (za->tempdir) {
+- if ((temp=(char *)malloc(strlen(za->tempdir)+13)) == NULL) {
++ int len = strlen(za->tempdir)+13;
++
++ if ((temp=(char *)malloc(len)) == NULL) {
+ _zip_error_set(&za->error, ZIP_ER_MEMORY, 0);
+ return NULL;
+ }
+- sprintf(temp, "%s/.zip.XXXXXX", za->tempdir);
++ snprintf(temp, len, "%s/.zip.XXXXXX", za->tempdir);
+ }
+ else {
+- if ((temp=(char *)malloc(strlen(za->zn)+8)) == NULL) {
++ int len = strlen(za->zn)+8;
++
++ if ((temp=(char *)malloc(len)) == NULL) {
+ _zip_error_set(&za->error, ZIP_ER_MEMORY, 0);
+ return NULL;
+ }
+- sprintf(temp, "%s.XXXXXX", za->zn);
++ snprintf(temp, len, "%s.XXXXXX", za->zn);
+ }
+
+ if ((tfd=mkstemp(temp)) == -1) {
+diff -ru libzip-0.11.1.orig/lib/zip_fclose.c libzip-0.11.1/lib/zip_fclose.c
+--- libzip-0.11.1.orig/lib/zip_fclose.c 2013-08-08 11:01:26.000000000 +0200
++++ libzip-0.11.1/lib/zip_fclose.c 2013-08-08 11:06:46.000000000 +0200
+@@ -48,14 +48,15 @@
+ if (zf->src)
+ zip_source_free(zf->src);
+
+- for (i=0; i<zf->za->nfile; i++) {
+- if (zf->za->file[i] == zf) {
+- zf->za->file[i] = zf->za->file[zf->za->nfile-1];
+- zf->za->nfile--;
+- break;
++ if (zf->za) {
++ for (i=0; i<zf->za->nfile; i++) {
++ if (zf->za->file[i] == zf) {
++ zf->za->file[i] = zf->za->file[zf->za->nfile-1];
++ zf->za->nfile--;
++ break;
++ }
++ }
+ }
+- }
+-
+ ret = 0;
+ if (zf->error.zip_err)
+ ret = zf->error.zip_err;
+--- libzip-0.11.1.orig/lib/zip.h 2013-08-08 11:01:26.000000000 +0200
++++ libzip-0.11.1/lib/zip.h 2013-08-08 11:19:57.000000000 +0200
+@@ -62,6 +62,8 @@
+ #define ZIP_EXCL 2
+ #define ZIP_CHECKCONS 4
+ #define ZIP_TRUNCATE 8
++/* PHP use this name, same behavior */
++#define ZIP_OVERWRITE 8
+
+
+ /* flags for zip_name_locate, zip_fopen, zip_stat, ... */