summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Lowrey <rdlowrey@php.net>2015-05-07 09:02:30 -0400
committerDaniel Lowrey <rdlowrey@php.net>2015-05-07 09:02:38 -0400
commit62b1293e3df520d104c678bc520b413386b628c5 (patch)
tree9725002b8d995954ff7b72c6233d67df0df355d1
parentfbd1f1f282466bd709081e104d65baf597aee666 (diff)
downloadphp-git-62b1293e3df520d104c678bc520b413386b628c5.tar.gz
Fix Z_BLOCK breakage when built against zlib < 1.2.4
-rw-r--r--ext/zlib/tests/deflate_add_basic.phpt6
-rw-r--r--ext/zlib/tests/inflate_add_basic.phpt6
-rw-r--r--ext/zlib/zlib.c13
3 files changed, 23 insertions, 2 deletions
diff --git a/ext/zlib/tests/deflate_add_basic.phpt b/ext/zlib/tests/deflate_add_basic.phpt
index 9f48bb0448..fde22b5a52 100644
--- a/ext/zlib/tests/deflate_add_basic.phpt
+++ b/ext/zlib/tests/deflate_add_basic.phpt
@@ -41,9 +41,13 @@ $flushTypes = [
'ZLIB_PARTIAL_FLUSH' => ZLIB_PARTIAL_FLUSH,
'ZLIB_FULL_FLUSH' => ZLIB_FULL_FLUSH,
'ZLIB_NO_FLUSH' => ZLIB_NO_FLUSH,
- 'ZLIB_BLOCK' => ZLIB_BLOCK,
];
+/* Z_BLOCK is only defined when built against zlib > 1.2.3 */
+if (defined(ZLIB_BLOCK)) {
+ $flushTypes['ZLIB_BLOCK'] = ZLIB_BLOCK;
+}
+
foreach ($modes as $modeKey => $mode) {
foreach ($flushSizes as $flushSize) {
foreach ($flushTypes as $flushTypeKey => $flushType) {
diff --git a/ext/zlib/tests/inflate_add_basic.phpt b/ext/zlib/tests/inflate_add_basic.phpt
index ff0458e9ef..7ef5ef11cb 100644
--- a/ext/zlib/tests/inflate_add_basic.phpt
+++ b/ext/zlib/tests/inflate_add_basic.phpt
@@ -40,9 +40,13 @@ $flushTypes = [
'ZLIB_PARTIAL_FLUSH' => ZLIB_PARTIAL_FLUSH,
'ZLIB_FULL_FLUSH' => ZLIB_FULL_FLUSH,
'ZLIB_NO_FLUSH' => ZLIB_NO_FLUSH,
- 'ZLIB_BLOCK' => ZLIB_BLOCK,
];
+/* Z_BLOCK is only defined when built against zlib > 1.2.3 */
+if (defined(ZLIB_BLOCK)) {
+ $flushTypes['ZLIB_BLOCK'] = ZLIB_BLOCK;
+}
+
$uncompressed = "";
for ($i=0;$i<(32768*2);$i++) {
$uncompressed .= chr(rand(48,125));
diff --git a/ext/zlib/zlib.c b/ext/zlib/zlib.c
index 715fdaff1c..2b9c016a41 100644
--- a/ext/zlib/zlib.c
+++ b/ext/zlib/zlib.c
@@ -46,6 +46,13 @@
#undef gzseek
#undef gztell
+/* Z_BLOCK was added in zlib 1.2.4 and stable distros (RHEL6, at least) still
+ * package zlib 1.2.3
+ */
+#ifdef Z_BLOCK
+#define HAVE_Z_BLOCK 1
+#endif
+
int le_deflate;
int le_inflate;
@@ -814,7 +821,9 @@ PHP_FUNCTION(inflate_add)
case Z_PARTIAL_FLUSH:
case Z_SYNC_FLUSH:
case Z_FULL_FLUSH:
+#ifdef HAVE_Z_BLOCK
case Z_BLOCK:
+#endif
case Z_FINISH:
break;
@@ -960,7 +969,9 @@ PHP_FUNCTION(deflate_add)
case Z_PARTIAL_FLUSH:
case Z_SYNC_FLUSH:
case Z_FULL_FLUSH:
+#ifdef HAVE_Z_BLOCK
case Z_BLOCK:
+#endif
case Z_FINISH:
break;
@@ -1268,7 +1279,9 @@ static PHP_MINIT_FUNCTION(zlib)
REGISTER_LONG_CONSTANT("ZLIB_PARTIAL_FLUSH", Z_PARTIAL_FLUSH, CONST_CS|CONST_PERSISTENT);
REGISTER_LONG_CONSTANT("ZLIB_SYNC_FLUSH", Z_SYNC_FLUSH, CONST_CS|CONST_PERSISTENT);
REGISTER_LONG_CONSTANT("ZLIB_FULL_FLUSH", Z_FULL_FLUSH, CONST_CS|CONST_PERSISTENT);
+#ifdef HAVE_Z_BLOCK
REGISTER_LONG_CONSTANT("ZLIB_BLOCK", Z_BLOCK, CONST_CS|CONST_PERSISTENT);
+#endif
REGISTER_LONG_CONSTANT("ZLIB_FINISH", Z_FINISH, CONST_CS|CONST_PERSISTENT);
REGISTER_INI_ENTRIES();
return SUCCESS;