]> granicus.if.org Git - php/commitdiff
- fixed memory leaks in gdImageCreateFromXpm()
authorTakeshi Abe <tabe@php.net>
Wed, 11 Feb 2009 17:56:17 +0000 (17:56 +0000)
committerTakeshi Abe <tabe@php.net>
Wed, 11 Feb 2009 17:56:17 +0000 (17:56 +0000)
- dropped unused codes

ext/gd/libgd/gdxpm.c

index 785afb36807278a44ae8ef5a96f8591763cf34d3..73f86e5df79d6eadc6d014b29e70ccdd06a811e6 100644 (file)
@@ -22,7 +22,6 @@ gdImagePtr gdImageCreateFromXpm (char *filename)
        int i, j, k, number;
        char buf[5];
        gdImagePtr im = 0;
-       char *apixel;
        int *pointer;
        int red = 0, green = 0, blue = 0;
        int *colors;
@@ -34,7 +33,7 @@ gdImagePtr gdImageCreateFromXpm (char *filename)
        }
 
        if (!(im = gdImageCreate(image.width, image.height))) {
-               return 0;
+               goto done;
        }
 
        number = image.ncolors;
@@ -116,14 +115,8 @@ gdImagePtr gdImageCreateFromXpm (char *filename)
 
 
                colors[i] = gdImageColorResolve(im, red, green, blue);
-               if (colors[i] == -1) {
-                       php_gd_error("ARRRGH");
-               }
        }
 
-       apixel = (char *) gdMalloc(image.cpp + 1);
-       apixel[image.cpp] = '\0';
-
        pointer = (int *) image.data;
        for (i = 0; i < image.height; i++) {
                for (j = 0; j < image.width; j++) {
@@ -132,8 +125,10 @@ gdImagePtr gdImageCreateFromXpm (char *filename)
                }
        }
 
-       gdFree(apixel);
        gdFree(colors);
+ done:
+       XpmFreeXpmImage(&image);
+       XpmFreeXpmInfo(&info);
        return im;
 }
 #endif