summaryrefslogtreecommitdiff
path: root/gdk/gdkpixmap.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdk/gdkpixmap.c')
-rw-r--r--gdk/gdkpixmap.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/gdk/gdkpixmap.c b/gdk/gdkpixmap.c
index ab131e6aca..81adacc41a 100644
--- a/gdk/gdkpixmap.c
+++ b/gdk/gdkpixmap.c
@@ -320,8 +320,7 @@ gdk_pixmap_extract_color (gchar *buffer)
return NULL;
else if (ptr[0] == '#')
{
- retcol = g_new(gchar, strlen (ptr) + 1);
- strcpy (retcol, ptr);
+ retcol = g_strdup (ptr);
return retcol;
}
@@ -346,8 +345,7 @@ gdk_pixmap_extract_color (gchar *buffer)
}
}
- retcol = g_new(gchar, strlen (color) + 1);
- strcpy (retcol, color);
+ retcol = g_strdup (color);
return retcol;
}
@@ -366,7 +364,7 @@ gdk_pixmap_create_from_xpm (GdkWindow *window,
GdkGC *gc;
GdkColor tmp_color;
gint width, height, num_cols, cpp, cnt, n, ns, xcnt, ycnt;
- gchar *buffer = NULL, *color_name = NULL, pixel_str[32];
+ gchar *buffer = NULL, pixel_str[32];
guint buffer_size = 0;
_GdkPixmapColor *colors = NULL, *color = NULL;
gulong index;
@@ -399,6 +397,8 @@ gdk_pixmap_create_from_xpm (GdkWindow *window,
for (cnt = 0; cnt < num_cols; cnt++)
{
+ gchar *color_name;
+
gdk_pixmap_seek_char (infile, '"');
fseek (infile, -1, SEEK_CUR);
gdk_pixmap_read_string (infile, &buffer, &buffer_size);
@@ -409,9 +409,6 @@ gdk_pixmap_create_from_xpm (GdkWindow *window,
colors[cnt].color_string[n] = 0;
colors[cnt].transparent = FALSE;
- if (color_name != NULL)
- g_free (color_name);
-
color_name = gdk_pixmap_extract_color (&buffer[cpp]);
if (color_name != NULL)
@@ -428,6 +425,8 @@ gdk_pixmap_create_from_xpm (GdkWindow *window,
colors[cnt].transparent = TRUE;
}
+ g_free (color_name);
+
gdk_color_alloc (colormap, &colors[cnt].color);
}
@@ -527,7 +526,7 @@ gdk_pixmap_create_from_xpm_d (GdkWindow *window,
GdkGC *gc;
GdkColor tmp_color;
gint width, height, num_cols, cpp, cnt, n, ns, xcnt, ycnt, i;
- gchar *buffer, *color_name = NULL, pixel_str[32];
+ gchar *buffer, pixel_str[32];
_GdkPixmapColor *colors = NULL, *color = NULL;
gulong index;
@@ -550,6 +549,8 @@ gdk_pixmap_create_from_xpm_d (GdkWindow *window,
for (cnt = 0; cnt < num_cols; cnt++)
{
+ gchar *color_name;
+
buffer = data[i++];
colors[cnt].color_string = g_new(gchar, cpp + 1);
@@ -558,9 +559,6 @@ gdk_pixmap_create_from_xpm_d (GdkWindow *window,
colors[cnt].color_string[n] = 0;
colors[cnt].transparent = FALSE;
- if (color_name != NULL)
- g_free (color_name);
-
color_name = gdk_pixmap_extract_color (&buffer[cpp]);
if (color_name != NULL)
@@ -577,6 +575,8 @@ gdk_pixmap_create_from_xpm_d (GdkWindow *window,
colors[cnt].transparent = TRUE;
}
+ g_free (color_name);
+
gdk_color_alloc (colormap, &colors[cnt].color);
}