Support BITMAPV5HEADER in getimagesize(): https://en.wikipedia.org/wiki/BMP_file_form...
authorLars Strojny <lstrojny@php.net>
Mon, 14 Jan 2013 17:52:38 +0000 (18:52 +0100)
committerLars Strojny <lstrojny@php.net>
Mon, 14 Jan 2013 17:52:38 +0000 (18:52 +0100)
NEWS
ext/standard/image.c
ext/standard/tests/image/getimagesize.phpt
ext/standard/tests/image/image_type_to_mime_type.phpt
ext/standard/tests/image/test1bpix.bmp [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index 26ce1183a917bf887e3a4dab0ba53f3dec75b2ac..16c07717565f56c5fdefd719199c9171879947fc 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -3,11 +3,12 @@ PHP                                                                        NEWS
 ?? ??? 2012, PHP 5.4.12
 
 - Core:
-  . Fixed bug #63982 (isset() inconsistently produces a fatal error on 
+  . Fixed bug #63982 (isset() inconsistently produces a fatal error on
     protected property). (Stas)
   . Fixed bug #63943 (Bad warning text from strpos() on empty needle).
     (Laruence)
   . Fixed bug #63882 (zend_std_compare_objects crash on recursion). (Dmitry)
+  . Support BITMAPV5HEADER in getimagesize(). (AsamK, Lars)
 
 - Litespeed:
   . Fixed bug #63228 (-Werror=format-security error in lsapi code). (George)
@@ -26,7 +27,7 @@ PHP                                                                        NEWS
   . Fixed bug #63899 (Use after scope error in zend_compile). (Laruence)
   . Fixed bug #63762 (Sigsegv when Exception::$trace is changed by user).
     (Johannes)
-  . Fixed bug #43177 (Errors in eval()'ed code produce status code 500). 
+  . Fixed bug #43177 (Errors in eval()'ed code produce status code 500).
     (Todd Ruth, Stas).
 
 - Filter:
index ebf894aa56d02c2ebc37e8abc423a5162b0cf294..4984e4064a3ea5a0ceb37dd15a05587bab13d6ef 100644 (file)
@@ -159,7 +159,7 @@ static struct gfxinfo *php_handle_bmp (php_stream * stream TSRMLS_DC)
                result->width    =  (((unsigned int)dim[ 5]) << 8) + ((unsigned int) dim[ 4]);
                result->height   =  (((unsigned int)dim[ 7]) << 8) + ((unsigned int) dim[ 6]);
                result->bits     =  ((unsigned int)dim[11]);
-       } else if (size > 12 && (size <= 64 || size == 108)) {
+       } else if (size > 12 && (size <= 64 || size == 108 || size == 124)) {
                result = (struct gfxinfo *) ecalloc (1, sizeof(struct gfxinfo));
                result->width    =  (((unsigned int)dim[ 7]) << 24) + (((unsigned int)dim[ 6]) << 16) + (((unsigned int)dim[ 5]) << 8) + ((unsigned int) dim[ 4]);
                result->height   =  (((unsigned int)dim[11]) << 24) + (((unsigned int)dim[10]) << 16) + (((unsigned int)dim[ 9]) << 8) + ((unsigned int) dim[ 8]);
index ab79c9c768e8b52c7a7aabb36421aadf419648a9..6cd8275e06e386314cbfd8e3dc49e535534a1723 100644 (file)
@@ -23,7 +23,22 @@ GetImageSize()
        var_dump($result);
 ?>
 --EXPECT--
-array(11) {
+array(12) {
+  ["test1bpix.bmp"]=>
+  array(6) {
+    [0]=>
+    int(500)
+    [1]=>
+    int(345)
+    [2]=>
+    int(6)
+    [3]=>
+    string(24) "width="500" height="345""
+    ["bits"]=>
+    int(32)
+    ["mime"]=>
+    string(14) "image/x-ms-bmp"
+  }
   ["test1pix.bmp"]=>
   array(6) {
     [0]=>
index 5d94a6fe5d11d708e9ded4bf4f3beab8df45c88c..d83ab8d146c4ba233bbea192d68234c6b60343aa 100644 (file)
@@ -1,8 +1,8 @@
 --TEST--
 image_type_to_mime_type()
 --SKIPIF--
-<?php 
-       if (!function_exists('image_type_to_mime_type')) die('skip image_type_to_mime_type() not available'); 
+<?php
+       if (!function_exists('image_type_to_mime_type')) die('skip image_type_to_mime_type() not available');
        require_once('skipif_imagetype.inc');
 ?>
 --FILE--
@@ -25,7 +25,9 @@ image_type_to_mime_type()
        var_dump($result);
 ?>
 --EXPECT--
-array(11) {
+array(12) {
+  ["test1bpix.bmp"]=>
+  string(14) "image/x-ms-bmp"
   ["test1pix.bmp"]=>
   string(14) "image/x-ms-bmp"
   ["test1pix.jp2"]=>
@@ -48,4 +50,4 @@ array(11) {
   string(29) "application/x-shockwave-flash"
   ["test4pix.tif"]=>
   string(10) "image/tiff"
-}
\ No newline at end of file
+}
diff --git a/ext/standard/tests/image/test1bpix.bmp b/ext/standard/tests/image/test1bpix.bmp
new file mode 100644 (file)
index 0000000..5522e50
Binary files /dev/null and b/ext/standard/tests/image/test1bpix.bmp differ