summaryrefslogtreecommitdiff
path: root/gdk/gdkfont.c
diff options
context:
space:
mode:
authorTim Janik <timj@gtk.org>1999-03-10 01:15:03 +0000
committerTim Janik <timj@src.gnome.org>1999-03-10 01:15:03 +0000
commit0c178e965c85dbc11720a98e97b50d49f0cdd2ec (patch)
treeed3e0fc18aa4a7fbaced112d602b1e76984a97dc /gdk/gdkfont.c
parentac7b6805f4e21d37098391306107e57ebcc72803 (diff)
downloadgdk-pixbuf-0c178e965c85dbc11720a98e97b50d49f0cdd2ec.tar.gz
first lookup the xfont ID in our font hash table, if we have a
Tue Mar 9 01:01:28 1999 Tim Janik <timj@gtk.org> * gdk/gdkfont.c (gdk_font_load): first lookup the xfont ID in our font hash table, if we have a GdkFontPrivate entry for this font already, simply increment its reference count, provided by Olaf Dietsche <olaf.dietsche+list.gtk@netcologne.de>. * gtk/gtkstyle.c (gtk_style_copy): plug a GdkFont reference leak, fix provided by Olaf Dietsche <olaf.dietsche+list.gtk@netcologne.de>.
Diffstat (limited to 'gdk/gdkfont.c')
-rw-r--r--gdk/gdkfont.c34
1 files changed, 22 insertions, 12 deletions
diff --git a/gdk/gdkfont.c b/gdk/gdkfont.c
index 91e728c59..d1f779a06 100644
--- a/gdk/gdkfont.c
+++ b/gdk/gdkfont.c
@@ -34,27 +34,37 @@ gdk_font_load (const gchar *font_name)
{
GdkFont *font;
GdkFontPrivate *private;
+ XFontStruct *xfont;
- private = g_new (GdkFontPrivate, 1);
- font = (GdkFont*) private;
+ g_return_val_if_fail (font_name != NULL, NULL);
- private->xdisplay = gdk_display;
- private->xfont = XLoadQueryFont (private->xdisplay, font_name);
- private->ref_count = 1;
+ xfont = XLoadQueryFont (gdk_display, font_name);
+ if (xfont == NULL)
+ return NULL;
- if (!private->xfont)
+ font = gdk_font_lookup (xfont->fid);
+ if (font != NULL)
{
- g_free (font);
- return NULL;
+ private = (GdkFontPrivate *) font;
+ if (xfont != private->xfont)
+ XFreeFont (gdk_display, xfont);
+
+ gdk_font_ref (font);
}
else
{
+ private = g_new (GdkFontPrivate, 1);
+ private->xdisplay = gdk_display;
+ private->xfont = xfont;
+ private->ref_count = 1;
+
+ font = (GdkFont*) private;
font->type = GDK_FONT_FONT;
- font->ascent = ((XFontStruct *) private->xfont)->ascent;
- font->descent = ((XFontStruct *) private->xfont)->descent;
- }
+ font->ascent = xfont->ascent;
+ font->descent = xfont->descent;
- gdk_xid_table_insert (&((XFontStruct *) private->xfont)->fid, font);
+ gdk_xid_table_insert (&xfont->fid, font);
+ }
return font;
}