summaryrefslogtreecommitdiff
path: root/src/cairo-scaled-font.c
diff options
context:
space:
mode:
authorAdrian Johnson <ajohnson@redneon.com>2016-02-21 09:07:40 +1030
committerAdrian Johnson <ajohnson@redneon.com>2016-03-10 19:00:48 +1030
commit72c9a022ac2f1b9c9afa349e0977dcd89fa56f2d (patch)
tree129ef4408fd771aeb6a45cbfeef675254e534cc0 /src/cairo-scaled-font.c
parent3538ac3e68f997d95d76865247717c90ae73630d (diff)
downloadcairo-72c9a022ac2f1b9c9afa349e0977dcd89fa56f2d.tar.gz
scaled-font: don't store pointer in hash value
Diffstat (limited to 'src/cairo-scaled-font.c')
-rw-r--r--src/cairo-scaled-font.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/cairo-scaled-font.c b/src/cairo-scaled-font.c
index ac80c97d1..b2557d42b 100644
--- a/src/cairo-scaled-font.c
+++ b/src/cairo-scaled-font.c
@@ -85,7 +85,7 @@ static cairo_cache_t cairo_scaled_glyph_page_cache;
#define CAIRO_SCALED_GLYPH_PAGE_SIZE 32
struct _cairo_scaled_glyph_page {
cairo_cache_entry_t cache_entry;
-
+ cairo_scaled_font_t *scaled_font;
cairo_list_t link;
unsigned int num_glyphs;
@@ -477,7 +477,7 @@ _cairo_scaled_glyph_page_pluck (void *closure)
assert (! cairo_list_is_empty (&page->link));
- scaled_font = (cairo_scaled_font_t *) page->cache_entry.hash;
+ scaled_font = page->scaled_font;
CAIRO_MUTEX_LOCK (scaled_font->mutex);
_cairo_scaled_glyph_page_destroy (scaled_font, page);
@@ -2824,7 +2824,7 @@ _cairo_scaled_glyph_page_can_remove (const void *closure)
const cairo_scaled_glyph_page_t *page = closure;
const cairo_scaled_font_t *scaled_font;
- scaled_font = (cairo_scaled_font_t *) page->cache_entry.hash;
+ scaled_font = page->scaled_font;
return scaled_font->cache_frozen == 0;
}
@@ -2853,6 +2853,7 @@ _cairo_scaled_font_allocate_glyph (cairo_scaled_font_t *scaled_font,
return _cairo_error (CAIRO_STATUS_NO_MEMORY);
page->cache_entry.hash = (unsigned long) scaled_font;
+ page->scaled_font = scaled_font;
page->cache_entry.size = 1; /* XXX occupancy weighting? */
page->num_glyphs = 0;