pajoye Wed May 27 08:12:08 2009 UTC Added files: /php-src/ext/gd/libgd gd_color.c
Modified files: /php-src/ext/gd config.m4 config.w32 gd.c php_gd.h /php-src/ext/gd/libgd gd_topal.c Log: - [DOC] always enable imagecolormatch
http://cvs.php.net/viewvc.cgi/php-src/ext/gd/config.m4?r1=1.182&r2=1.183&diff_format=u Index: php-src/ext/gd/config.m4 diff -u php-src/ext/gd/config.m4:1.182 php-src/ext/gd/config.m4:1.183 --- php-src/ext/gd/config.m4:1.182 Wed May 27 07:16:55 2009 +++ php-src/ext/gd/config.m4 Wed May 27 08:12:07 2009 @@ -1,5 +1,5 @@ dnl -dnl $Id: config.m4,v 1.182 2009/05/27 07:16:55 pajoye Exp $ +dnl $Id: config.m4,v 1.183 2009/05/27 08:12:07 pajoye Exp $ dnl dnl @@ -275,7 +275,7 @@ libgd/gdfontg.c libgd/gdtables.c libgd/gdft.c libgd/gdcache.c libgd/gdkanji.c \ libgd/wbmp.c libgd/gd_wbmp.c libgd/gdhelpers.c libgd/gd_topal.c libgd/gd_gif_in.c \ libgd/xbm.c libgd/gd_gif_out.c libgd/gd_security.c libgd/gd_filter.c \ - libgd/gd_pixelate.c libgd/gd_arc.c libgd/gd_rotate.c" + libgd/gd_pixelate.c libgd/gd_arc.c libgd/gd_rotate.c libgd/gd_color.c" dnl check for fabsf and floorf which are available since C99 AC_CHECK_FUNCS([fabsf floorf]) @@ -312,7 +312,8 @@ PHP_ADD_BUILD_DIR($ext_builddir/libgd) GD_MODULE_TYPE=external - extra_sources="gdcache.c libgd/gd_compat.c libgd/gd_filter.c libgd/gd_pixelate.c libgd/gd_arc.c libgd/gd_rotate.c" + extra_sources="gdcache.c libgd/gd_compat.c libgd/gd_filter.c libgd/gd_pixelate.c libgd/gd_arc.c \ + libgd/gd_rotate.c libgd/gd_color.c" GD_FEATURES=`$GDLIB_CONFIG --features` http://cvs.php.net/viewvc.cgi/php-src/ext/gd/config.w32?r1=1.38&r2=1.39&diff_format=u Index: php-src/ext/gd/config.w32 diff -u php-src/ext/gd/config.w32:1.38 php-src/ext/gd/config.w32:1.39 --- php-src/ext/gd/config.w32:1.38 Wed May 27 07:16:55 2009 +++ php-src/ext/gd/config.w32 Wed May 27 08:12:07 2009 @@ -1,4 +1,4 @@ -// $Id: config.w32,v 1.38 2009/05/27 07:16:55 pajoye Exp $ +// $Id: config.w32,v 1.39 2009/05/27 08:12:07 pajoye Exp $ // vim:ft=javascript ARG_WITH("gd", "Bundled GD support", "yes,shared"); @@ -34,7 +34,7 @@ gdft.c gd_gd2.c gd_gd.c gd_gif_in.c gd_gif_out.c gdhelpers.c gd_io.c gd_io_dp.c \ gd_io_file.c gd_io_ss.c gd_jpeg.c gdkanji.c gd_png.c gd_ss.c \ gdtables.c gd_topal.c gd_wbmp.c gdxpm.c wbmp.c xbm.c gd_security.c \ - gd_filter.c gd_pixelate.c gd_arc.c gd_rotate.c", "gd"); + gd_filter.c gd_pixelate.c gd_arc.c gd_rotate.c gd_color.c", "gd"); AC_DEFINE('HAVE_LIBGD', 1, 'GD support'); ADD_FLAG("CFLAGS_GD", " \ /D HAVE_GD_BUNDLED=1 \ http://cvs.php.net/viewvc.cgi/php-src/ext/gd/gd.c?r1=1.414&r2=1.415&diff_format=u Index: php-src/ext/gd/gd.c diff -u php-src/ext/gd/gd.c:1.414 php-src/ext/gd/gd.c:1.415 --- php-src/ext/gd/gd.c:1.414 Wed May 27 07:16:55 2009 +++ php-src/ext/gd/gd.c Wed May 27 08:12:07 2009 @@ -18,7 +18,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: gd.c,v 1.414 2009/05/27 07:16:55 pajoye Exp $ */ +/* $Id: gd.c,v 1.415 2009/05/27 08:12:07 pajoye Exp $ */ /* gd 1.2 is copyright 1994, 1995, Quest Protein Database Center, Cold Spring Harbor Labs. */ @@ -167,12 +167,10 @@ ZEND_ARG_INFO(0, colorsWanted) ZEND_END_ARG_INFO() -#if HAVE_GD_BUNDLED ZEND_BEGIN_ARG_INFO(arginfo_imagecolormatch, 0) ZEND_ARG_INFO(0, im1) ZEND_ARG_INFO(0, im2) ZEND_END_ARG_INFO() -#endif ZEND_BEGIN_ARG_INFO(arginfo_imagesetthickness, 0) ZEND_ARG_INFO(0, im) @@ -980,9 +978,11 @@ PHP_FE(image2wbmp, arginfo_image2wbmp) #if HAVE_GD_BUNDLED PHP_FE(imagelayereffect, arginfo_imagelayereffect) - PHP_FE(imagecolormatch, arginfo_imagecolormatch) PHP_FE(imagexbm, arginfo_imagexbm) #endif + + PHP_FE(imagecolormatch, arginfo_imagecolormatch) + /* gd filters */ PHP_FE(imagefilter, arginfo_imagefilter) PHP_FE(imageconvolution, arginfo_imageconvolution) @@ -1555,7 +1555,6 @@ } /* }}} */ -#if HAVE_GD_BUNDLED /* {{{ proto bool imagecolormatch(resource im1, resource im2) U Makes the colors of the palette version of an image more closely match the true color version */ PHP_FUNCTION(imagecolormatch) @@ -1594,7 +1593,6 @@ RETURN_TRUE; } /* }}} */ -#endif /* {{{ proto bool imagesetthickness(resource im, int thickness) U Set line thickness for drawing lines, ellipses, rectangles, polygons etc. */ http://cvs.php.net/viewvc.cgi/php-src/ext/gd/php_gd.h?r1=1.81&r2=1.82&diff_format=u Index: php-src/ext/gd/php_gd.h diff -u php-src/ext/gd/php_gd.h:1.81 php-src/ext/gd/php_gd.h:1.82 --- php-src/ext/gd/php_gd.h:1.81 Wed May 27 07:16:55 2009 +++ php-src/ext/gd/php_gd.h Wed May 27 08:12:07 2009 @@ -17,7 +17,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: php_gd.h,v 1.81 2009/05/27 07:16:55 pajoye Exp $ */ +/* $Id: php_gd.h,v 1.82 2009/05/27 08:12:07 pajoye Exp $ */ #ifndef PHP_GD_H #define PHP_GD_H @@ -190,10 +190,11 @@ #if HAVE_GD_BUNDLED PHP_FUNCTION(imagelayereffect); -PHP_FUNCTION(imagecolormatch); PHP_FUNCTION(imagexbm); #endif +PHP_FUNCTION(imagecolormatch); + PHP_FUNCTION(imagefilter); PHP_FUNCTION(imageconvolution); http://cvs.php.net/viewvc.cgi/php-src/ext/gd/libgd/gd_topal.c?r1=1.19&r2=1.20&diff_format=u Index: php-src/ext/gd/libgd/gd_topal.c diff -u php-src/ext/gd/libgd/gd_topal.c:1.19 php-src/ext/gd/libgd/gd_topal.c:1.20 --- php-src/ext/gd/libgd/gd_topal.c:1.19 Wed Apr 4 00:41:08 2007 +++ php-src/ext/gd/libgd/gd_topal.c Wed May 27 08:12:07 2009 @@ -2066,61 +2066,4 @@ #endif } - -/* bring the palette colors in im2 to be closer to im1 - * - */ -int gdImageColorMatch (gdImagePtr im1, gdImagePtr im2) -{ - unsigned long *buf; /* stores our calculations */ - unsigned long *bp; /* buf ptr */ - int color, rgb; - int x,y; - int count; - - if( !im1->trueColor ) { - return -1; /* im1 must be True Color */ - } - if( im2->trueColor ) { - return -2; /* im2 must be indexed */ - } - if( (im1->sx != im2->sx) || (im1->sy != im2->sy) ) { - return -3; /* the images are meant to be the same dimensions */ - } - if (im2->colorsTotal<1) { - return -4; /* At least 1 color must be allocated */ - } - - buf = (unsigned long *)safe_emalloc(sizeof(unsigned long), 5 * im2->colorsTotal, 0); - memset( buf, 0, sizeof(unsigned long) * 5 * im2->colorsTotal ); - - for (x=0; x<im1->sx; x++) { - for( y=0; y<im1->sy; y++ ) { - color = im2->pixels[y][x]; - rgb = im1->tpixels[y][x]; - bp = buf + (color * 5); - (*(bp++))++; - *(bp++) += gdTrueColorGetRed(rgb); - *(bp++) += gdTrueColorGetGreen(rgb); - *(bp++) += gdTrueColorGetBlue(rgb); - *(bp++) += gdTrueColorGetAlpha(rgb); - } - } - bp = buf; - for (color=0; color<im2->colorsTotal; color++) { - count = *(bp++); - if( count > 0 ) { - im2->red[color] = *(bp++) / count; - im2->green[color] = *(bp++) / count; - im2->blue[color] = *(bp++) / count; - im2->alpha[color] = *(bp++) / count; - } else { - bp += 4; - } - } - gdFree(buf); - return 0; -} - - #endif http://cvs.php.net/viewvc.cgi/php-src/ext/gd/libgd/gd_color.c?view=markup&rev=1.1 Index: php-src/ext/gd/libgd/gd_color.c +++ php-src/ext/gd/libgd/gd_color.c #if HAVE_GD_BUNDLED # include "gd.h" #else # include <gd.h> #endif #include "gd_intern.h" #include "php.h" /* bring the palette colors in im2 to be closer to im1 * */ int gdImageColorMatch (gdImagePtr im1, gdImagePtr im2) { unsigned long *buf; /* stores our calculations */ unsigned long *bp; /* buf ptr */ int color, rgb; int x,y; int count; if( !im1->trueColor ) { return -1; /* im1 must be True Color */ } if( im2->trueColor ) { return -2; /* im2 must be indexed */ } if( (im1->sx != im2->sx) || (im1->sy != im2->sy) ) { return -3; /* the images are meant to be the same dimensions */ } if (im2->colorsTotal<1) { return -4; /* At least 1 color must be allocated */ } buf = (unsigned long *)safe_emalloc(sizeof(unsigned long), 5 * im2->colorsTotal, 0); memset( buf, 0, sizeof(unsigned long) * 5 * im2->colorsTotal ); for (x=0; x<im1->sx; x++) { for( y=0; y<im1->sy; y++ ) { color = im2->pixels[y][x]; rgb = im1->tpixels[y][x]; bp = buf + (color * 5); (*(bp++))++; *(bp++) += gdTrueColorGetRed(rgb); *(bp++) += gdTrueColorGetGreen(rgb); *(bp++) += gdTrueColorGetBlue(rgb); *(bp++) += gdTrueColorGetAlpha(rgb); } } bp = buf; for (color=0; color<im2->colorsTotal; color++) { count = *(bp++); if( count > 0 ) { im2->red[color] = *(bp++) / count; im2->green[color] = *(bp++) / count; im2->blue[color] = *(bp++) / count; im2->alpha[color] = *(bp++) / count; } else { bp += 4; } } gdFree(buf); return 0; }