diff options
author | Tim Janik <timj@gtk.org> | 1999-03-10 01:15:03 +0000 |
---|---|---|
committer | Tim Janik <timj@src.gnome.org> | 1999-03-10 01:15:03 +0000 |
commit | 0c178e965c85dbc11720a98e97b50d49f0cdd2ec (patch) | |
tree | ed3e0fc18aa4a7fbaced112d602b1e76984a97dc /gdk/gdkfont.c | |
parent | ac7b6805f4e21d37098391306107e57ebcc72803 (diff) | |
download | gtk+-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.c | 34 |
1 files changed, 22 insertions, 12 deletions
diff --git a/gdk/gdkfont.c b/gdk/gdkfont.c index 91e728c592..d1f779a064 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; } |