2011-07-08 16:36:09 -04:00
|
|
|
$OpenBSD: patch-Imlib_utils_c,v 1.4 2011/07/08 20:36:09 naddy Exp $
|
|
|
|
--- Imlib/utils.c.orig Fri Mar 22 07:43:04 2002
|
|
|
|
+++ Imlib/utils.c Mon Jul 4 17:36:44 2011
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -801,6 +801,7 @@ Imlib_crop_and_clone_image(ImlibData * id, ImlibImage
|
2003-06-20 10:53:12 -04:00
|
|
|
unsigned char *ptr1, *ptr2;
|
|
|
|
ImlibImage *im2;
|
|
|
|
char *s;
|
|
|
|
+ size_t s_size;
|
|
|
|
|
|
|
|
if (!im)
|
|
|
|
return NULL;
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -872,10 +873,11 @@ Imlib_crop_and_clone_image(ImlibData * id, ImlibImage
|
2003-06-20 10:53:12 -04:00
|
|
|
im2->rgb_width = w;
|
|
|
|
im2->rgb_height = h;
|
|
|
|
im2->alpha_data = NULL;
|
|
|
|
- s = malloc(strlen(im->filename) + 320);
|
|
|
|
+ s_size = strlen(im->filename + 320);
|
|
|
|
+ s = malloc(s_size);
|
|
|
|
if (s)
|
|
|
|
{
|
|
|
|
- snprintf(s, sizeof(s), "%s_%x_%x", im->filename, (int)time(NULL), (int)rand());
|
|
|
|
+ snprintf(s, s_size, "%s_%x_%x", im->filename, (int)time(NULL), (int)rand());
|
|
|
|
im2->filename = malloc(strlen(s) + 1);
|
|
|
|
if (im2->filename)
|
|
|
|
strcpy(im2->filename, s);
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -1211,6 +1213,7 @@ Imlib_clone_image(ImlibData * id, ImlibImage * im)
|
2003-06-20 10:53:12 -04:00
|
|
|
{
|
|
|
|
ImlibImage *im2;
|
|
|
|
char *s;
|
|
|
|
+ size_t s_size;
|
|
|
|
|
|
|
|
if (!im)
|
|
|
|
return NULL;
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -1239,10 +1242,11 @@ Imlib_clone_image(ImlibData * id, ImlibImage * im)
|
2003-06-20 10:53:12 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
im2->alpha_data = NULL;
|
|
|
|
- s = malloc(strlen(im->filename) + 320);
|
|
|
|
+ s_size = strlen(im->filename) + 320;
|
|
|
|
+ s = malloc(s_size);
|
|
|
|
if (s)
|
|
|
|
{
|
|
|
|
- snprintf(s, sizeof(s), "%s_%x_%x", im->filename, (int)time(NULL), (int)rand());
|
|
|
|
+ snprintf(s, s_size, "%s_%x_%x", im->filename, (int)time(NULL), (int)rand());
|
|
|
|
im2->filename = malloc(strlen(s) + 1);
|
|
|
|
if (im2->filename)
|
|
|
|
strcpy(im2->filename, s);
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -1285,6 +1289,7 @@ Imlib_clone_scaled_image(ImlibData * id, ImlibImage *
|
2003-06-20 10:53:12 -04:00
|
|
|
{
|
|
|
|
ImlibImage *im2;
|
|
|
|
char *s;
|
|
|
|
+ size_t s_size;
|
|
|
|
|
|
|
|
if ((!im) || (w <= 0) || (h <= 0))
|
|
|
|
return NULL;
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -1417,10 +1422,11 @@ Imlib_clone_scaled_image(ImlibData * id, ImlibImage *
|
2003-06-20 10:53:12 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
im2->alpha_data = NULL;
|
|
|
|
- s = malloc(strlen(im->filename) + 320);
|
|
|
|
+ s_size = strlen(im->filename) + 320;
|
|
|
|
+ s = malloc(s_size);
|
|
|
|
if (s)
|
|
|
|
{
|
|
|
|
- snprintf(s, sizeof(s), "%s_%x_%x_%x_%x", im->filename, (int)time(NULL), w, h, (int)rand());
|
|
|
|
+ snprintf(s, s_size, "%s_%x_%x_%x_%x", im->filename, (int)time(NULL), w, h, (int)rand());
|
|
|
|
im2->filename = malloc(strlen(s) + 1);
|
|
|
|
if (im2->filename)
|
|
|
|
strcpy(im2->filename, s);
|
2009-01-09 11:21:42 -05:00
|
|
|
@@ -1596,7 +1602,7 @@ Imlib_create_image_from_xpm_data(ImlibData * id, char
|
2003-09-01 12:53:00 -04:00
|
|
|
{
|
|
|
|
if (line[k] != ' ')
|
|
|
|
{
|
|
|
|
- sscanf(&line[k], "%65536s", s);
|
|
|
|
+ sscanf(&line[k], "%255s", s);
|
|
|
|
k += strlen(s);
|
|
|
|
if (!strcmp(s, "c"))
|
|
|
|
iscolor = 1;
|
2011-07-08 16:36:09 -04:00
|
|
|
@@ -1959,13 +1965,13 @@ Imlib_inlined_png_to_image(ImlibData *id, unsigned cha
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (setjmp(png_ptr->jmpbuf))
|
|
|
|
+ if (setjmp(png_jmpbuf(png_ptr)))
|
|
|
|
{
|
|
|
|
png_destroy_read_struct(&png_ptr, &info_ptr, NULL);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (info_ptr->color_type == PNG_COLOR_TYPE_RGB_ALPHA)
|
|
|
|
+ if (png_get_color_type(png_ptr, info_ptr) == PNG_COLOR_TYPE_RGB_ALPHA)
|
|
|
|
{
|
|
|
|
png_destroy_read_struct(&png_ptr, &info_ptr, NULL);
|
|
|
|
return NULL;
|