Remove dirty tracking
Turns out I don't need this to resolve CoreText optical sizing issue after all. https://github.com/behdad/harfbuzz/issues/360
This commit is contained in:
parent
b57f18da70
commit
c0c2dbc871
|
@ -54,13 +54,6 @@ struct hb_face_t {
|
||||||
mutable unsigned int upem; /* Units-per-EM. */
|
mutable unsigned int upem; /* Units-per-EM. */
|
||||||
mutable unsigned int num_glyphs; /* Number of glyphs. */
|
mutable unsigned int num_glyphs; /* Number of glyphs. */
|
||||||
|
|
||||||
enum dirty_t {
|
|
||||||
DIRTY_NOTHING = 0x0000,
|
|
||||||
DIRTY_INDEX = 0x0001,
|
|
||||||
DIRTY_UPEM = 0x0002,
|
|
||||||
DIRTY_NUM_GLYPHS = 0x0004,
|
|
||||||
} dirty;
|
|
||||||
|
|
||||||
struct hb_shaper_data_t shaper_data; /* Various shaper data. */
|
struct hb_shaper_data_t shaper_data; /* Various shaper data. */
|
||||||
|
|
||||||
/* Various non-shaping data. */
|
/* Various non-shaping data. */
|
||||||
|
@ -106,8 +99,6 @@ struct hb_face_t {
|
||||||
HB_INTERNAL void load_num_glyphs (void) const;
|
HB_INTERNAL void load_num_glyphs (void) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
HB_MARK_AS_FLAG_T (hb_face_t::dirty_t);
|
|
||||||
|
|
||||||
extern HB_INTERNAL const hb_face_t _hb_face_nil;
|
extern HB_INTERNAL const hb_face_t _hb_face_nil;
|
||||||
|
|
||||||
#define HB_SHAPER_DATA_CREATE_FUNC_EXTRA_ARGS
|
#define HB_SHAPER_DATA_CREATE_FUNC_EXTRA_ARGS
|
||||||
|
|
|
@ -51,8 +51,6 @@ const hb_face_t _hb_face_nil = {
|
||||||
1000, /* upem */
|
1000, /* upem */
|
||||||
0, /* num_glyphs */
|
0, /* num_glyphs */
|
||||||
|
|
||||||
hb_face_t::DIRTY_NOTHING, /* dirty */
|
|
||||||
|
|
||||||
{
|
{
|
||||||
#define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_INVALID,
|
#define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_INVALID,
|
||||||
#include "hb-shaper-list.hh"
|
#include "hb-shaper-list.hh"
|
||||||
|
@ -367,11 +365,6 @@ hb_face_set_index (hb_face_t *face,
|
||||||
if (face->immutable)
|
if (face->immutable)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (face->index == index)
|
|
||||||
return;
|
|
||||||
|
|
||||||
face->dirty |= face->DIRTY_INDEX;
|
|
||||||
|
|
||||||
face->index = index;
|
face->index = index;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -407,11 +400,6 @@ hb_face_set_upem (hb_face_t *face,
|
||||||
if (face->immutable)
|
if (face->immutable)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (face->upem == upem)
|
|
||||||
return;
|
|
||||||
|
|
||||||
face->dirty |= face->DIRTY_UPEM;
|
|
||||||
|
|
||||||
face->upem = upem;
|
face->upem = upem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -456,11 +444,6 @@ hb_face_set_glyph_count (hb_face_t *face,
|
||||||
if (face->immutable)
|
if (face->immutable)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (face->num_glyphs == glyph_count)
|
|
||||||
return;
|
|
||||||
|
|
||||||
face->dirty |= face->DIRTY_NUM_GLYPHS;
|
|
||||||
|
|
||||||
face->num_glyphs = glyph_count;
|
face->num_glyphs = glyph_count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -118,17 +118,6 @@ struct hb_font_t {
|
||||||
void *user_data;
|
void *user_data;
|
||||||
hb_destroy_func_t destroy;
|
hb_destroy_func_t destroy;
|
||||||
|
|
||||||
enum dirty_t {
|
|
||||||
DIRTY_NOTHING = 0x0000,
|
|
||||||
DIRTY_FACE = 0x0001,
|
|
||||||
DIRTY_PARENT = 0x0002,
|
|
||||||
DIRTY_FUNCS = 0x0004,
|
|
||||||
DIRTY_SCALE = 0x0008,
|
|
||||||
DIRTY_PPEM = 0x0010,
|
|
||||||
DIRTY_PTEM = 0x0020,
|
|
||||||
DIRTY_VARIATIONS = 0x0040,
|
|
||||||
} dirty;
|
|
||||||
|
|
||||||
struct hb_shaper_data_t shaper_data;
|
struct hb_shaper_data_t shaper_data;
|
||||||
|
|
||||||
|
|
||||||
|
@ -556,8 +545,6 @@ struct hb_font_t {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
HB_MARK_AS_FLAG_T (hb_font_t::dirty_t);
|
|
||||||
|
|
||||||
#define HB_SHAPER_DATA_CREATE_FUNC_EXTRA_ARGS
|
#define HB_SHAPER_DATA_CREATE_FUNC_EXTRA_ARGS
|
||||||
#define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_PROTOTYPE(shaper, font);
|
#define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_PROTOTYPE(shaper, font);
|
||||||
#include "hb-shaper-list.hh"
|
#include "hb-shaper-list.hh"
|
||||||
|
|
|
@ -1209,8 +1209,6 @@ hb_font_get_empty (void)
|
||||||
NULL, /* user_data */
|
NULL, /* user_data */
|
||||||
NULL, /* destroy */
|
NULL, /* destroy */
|
||||||
|
|
||||||
hb_font_t::DIRTY_NOTHING, /* dirty */
|
|
||||||
|
|
||||||
{
|
{
|
||||||
#define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_INVALID,
|
#define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_INVALID,
|
||||||
#include "hb-shaper-list.hh"
|
#include "hb-shaper-list.hh"
|
||||||
|
@ -1363,11 +1361,6 @@ hb_font_set_parent (hb_font_t *font,
|
||||||
if (!parent)
|
if (!parent)
|
||||||
parent = hb_font_get_empty ();
|
parent = hb_font_get_empty ();
|
||||||
|
|
||||||
if (parent == font->parent)
|
|
||||||
return;
|
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_PARENT;
|
|
||||||
|
|
||||||
hb_font_t *old = font->parent;
|
hb_font_t *old = font->parent;
|
||||||
|
|
||||||
font->parent = hb_font_reference (parent);
|
font->parent = hb_font_reference (parent);
|
||||||
|
@ -1410,11 +1403,6 @@ hb_font_set_face (hb_font_t *font,
|
||||||
if (unlikely (!face))
|
if (unlikely (!face))
|
||||||
face = hb_face_get_empty ();
|
face = hb_face_get_empty ();
|
||||||
|
|
||||||
if (font->face == face)
|
|
||||||
return;
|
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_FACE;
|
|
||||||
|
|
||||||
hb_face_t *old = font->face;
|
hb_face_t *old = font->face;
|
||||||
|
|
||||||
font->face = hb_face_reference (face);
|
font->face = hb_face_reference (face);
|
||||||
|
@ -1468,8 +1456,6 @@ hb_font_set_funcs (hb_font_t *font,
|
||||||
if (!klass)
|
if (!klass)
|
||||||
klass = hb_font_funcs_get_empty ();
|
klass = hb_font_funcs_get_empty ();
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_FUNCS;
|
|
||||||
|
|
||||||
hb_font_funcs_reference (klass);
|
hb_font_funcs_reference (klass);
|
||||||
hb_font_funcs_destroy (font->klass);
|
hb_font_funcs_destroy (font->klass);
|
||||||
font->klass = klass;
|
font->klass = klass;
|
||||||
|
@ -1525,11 +1511,6 @@ hb_font_set_scale (hb_font_t *font,
|
||||||
if (font->immutable)
|
if (font->immutable)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (font->x_scale == x_scale && font->y_scale == y_scale)
|
|
||||||
return;
|
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_SCALE;
|
|
||||||
|
|
||||||
font->x_scale = x_scale;
|
font->x_scale = x_scale;
|
||||||
font->y_scale = y_scale;
|
font->y_scale = y_scale;
|
||||||
}
|
}
|
||||||
|
@ -1571,11 +1552,6 @@ hb_font_set_ppem (hb_font_t *font,
|
||||||
if (font->immutable)
|
if (font->immutable)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (font->x_ppem == x_ppem && font->y_ppem == y_ppem)
|
|
||||||
return;
|
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_PPEM;
|
|
||||||
|
|
||||||
font->x_ppem = x_ppem;
|
font->x_ppem = x_ppem;
|
||||||
font->y_ppem = y_ppem;
|
font->y_ppem = y_ppem;
|
||||||
}
|
}
|
||||||
|
@ -1614,11 +1590,6 @@ hb_font_set_ptem (hb_font_t *font, float ptem)
|
||||||
if (font->immutable)
|
if (font->immutable)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (font->ptem == ptem)
|
|
||||||
return;
|
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_PTEM;
|
|
||||||
|
|
||||||
font->ptem = ptem;
|
font->ptem = ptem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1647,16 +1618,6 @@ _hb_font_adopt_var_coords_normalized (hb_font_t *font,
|
||||||
int *coords, /* 2.14 normalized */
|
int *coords, /* 2.14 normalized */
|
||||||
unsigned int coords_length)
|
unsigned int coords_length)
|
||||||
{
|
{
|
||||||
if (font->num_coords == coords_length &&
|
|
||||||
(coords_length == 0 ||
|
|
||||||
0 == memcmp (font->coords, coords, coords_length * sizeof (coords[0]))))
|
|
||||||
{
|
|
||||||
free (coords);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
font->dirty |= font->DIRTY_VARIATIONS;
|
|
||||||
|
|
||||||
free (font->coords);
|
free (font->coords);
|
||||||
|
|
||||||
font->coords = coords;
|
font->coords = coords;
|
||||||
|
|
Loading…
Reference in New Issue