From 62b1293e3df520d104c678bc520b413386b628c5 Mon Sep 17 00:00:00 2001 From: Daniel Lowrey Date: Thu, 7 May 2015 09:02:30 -0400 Subject: [PATCH] Fix Z_BLOCK breakage when built against zlib < 1.2.4 --- ext/zlib/tests/deflate_add_basic.phpt | 6 +++++- ext/zlib/tests/inflate_add_basic.phpt | 6 +++++- ext/zlib/zlib.c | 13 +++++++++++++ 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; -- 2.40.0