Use an unused high bit in the XID to mark fonts in the global xid hash
2006-01-19 Matthias Clasen <mclasen@redhat.com> * gdk/x11/gdkprivate-x11.h (XID_FONT_BIT): * gdk/x11/gdkfont-x11.c: * gdk/x11/gdkxid.c: Use an unused high bit in the XID to mark fonts in the global xid hash table. * gdk/x11/gdkcursor-x11.c (update_cursor): Skip fonts when iterating over the xid hash table, since calling GDK_IS_WINDOW () on an GdkFont can cause a segfault. (#327751, Ryan Lortie)
This commit is contained in:
committed by
Matthias Clasen
parent
292c69ac7d
commit
73153b42e8
@ -430,8 +430,12 @@ update_cursor (gpointer key,
|
|||||||
gpointer value,
|
gpointer value,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
|
XID *xid = key;
|
||||||
GdkCursor *cursor;
|
GdkCursor *cursor;
|
||||||
|
|
||||||
|
if (*xid & XID_FONT_BIT)
|
||||||
|
return;
|
||||||
|
|
||||||
if (!GDK_IS_WINDOW (value))
|
if (!GDK_IS_WINDOW (value))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|||||||
@ -50,6 +50,7 @@ struct _GdkFontPrivateX
|
|||||||
GdkDisplay *display;
|
GdkDisplay *display;
|
||||||
|
|
||||||
GSList *names;
|
GSList *names;
|
||||||
|
XID xid;
|
||||||
};
|
};
|
||||||
|
|
||||||
static GHashTable *
|
static GHashTable *
|
||||||
@ -214,13 +215,14 @@ gdk_font_load_for_display (GdkDisplay *display,
|
|||||||
private->xfont = xfont;
|
private->xfont = xfont;
|
||||||
private->base.ref_count = 1;
|
private->base.ref_count = 1;
|
||||||
private->names = NULL;
|
private->names = NULL;
|
||||||
|
private->xid = xfont->fid | XID_FONT_BIT;
|
||||||
|
|
||||||
font = (GdkFont*) private;
|
font = (GdkFont*) private;
|
||||||
font->type = GDK_FONT_FONT;
|
font->type = GDK_FONT_FONT;
|
||||||
font->ascent = xfont->ascent;
|
font->ascent = xfont->ascent;
|
||||||
font->descent = xfont->descent;
|
font->descent = xfont->descent;
|
||||||
|
|
||||||
_gdk_xid_table_insert (display, &xfont->fid, font);
|
_gdk_xid_table_insert (display, &private->xid, font);
|
||||||
}
|
}
|
||||||
|
|
||||||
gdk_font_hash_insert (GDK_FONT_FONT, font, font_name);
|
gdk_font_hash_insert (GDK_FONT_FONT, font, font_name);
|
||||||
|
|||||||
@ -86,6 +86,8 @@ struct _GdkVisualPrivate
|
|||||||
GdkScreen *screen;
|
GdkScreen *screen;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define XID_FONT_BIT (1<<31)
|
||||||
|
|
||||||
void _gdk_xid_table_insert (GdkDisplay *display,
|
void _gdk_xid_table_insert (GdkDisplay *display,
|
||||||
XID *xid,
|
XID *xid,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
|
|||||||
@ -36,6 +36,11 @@ static gboolean gdk_xid_equal (XID *a,
|
|||||||
XID *b);
|
XID *b);
|
||||||
|
|
||||||
|
|
||||||
|
/* The 3 high bits of XIDs are unused. We use one to mark fonts,
|
||||||
|
* since we must be able to skip fonts when iterating over all XIDs.
|
||||||
|
*/
|
||||||
|
#define XID_FONT_BIT (1<<31)
|
||||||
|
|
||||||
void
|
void
|
||||||
_gdk_xid_table_insert (GdkDisplay *display,
|
_gdk_xid_table_insert (GdkDisplay *display,
|
||||||
XID *xid,
|
XID *xid,
|
||||||
@ -123,7 +128,7 @@ static gboolean
|
|||||||
gdk_xid_equal (XID *a,
|
gdk_xid_equal (XID *a,
|
||||||
XID *b)
|
XID *b)
|
||||||
{
|
{
|
||||||
return (*a == *b);
|
return ((*a & ~XID_FONT_BIT) == (*b & ~XID_FONT_BIT));
|
||||||
}
|
}
|
||||||
|
|
||||||
#define __GDK_XID_C__
|
#define __GDK_XID_C__
|
||||||
|
|||||||
Reference in New Issue
Block a user