diff options
| author | Daniel Lowrey <rdlowrey@php.net> | 2015-05-07 09:02:30 -0400 |
|---|---|---|
| committer | Daniel Lowrey <rdlowrey@php.net> | 2015-05-07 09:02:38 -0400 |
| commit | 62b1293e3df520d104c678bc520b413386b628c5 (patch) | |
| tree | 9725002b8d995954ff7b72c6233d67df0df355d1 | |
| parent | fbd1f1f282466bd709081e104d65baf597aee666 (diff) | |
| download | php-git-62b1293e3df520d104c678bc520b413386b628c5.tar.gz | |
Fix Z_BLOCK breakage when built against zlib < 1.2.4
| -rw-r--r-- | ext/zlib/tests/deflate_add_basic.phpt | 6 | ||||
| -rw-r--r-- | ext/zlib/tests/inflate_add_basic.phpt | 6 | ||||
| -rw-r--r-- | 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; |
