diff options
author | Behdad Esfahbod <behdad@behdad.org> | 2018-10-11 13:24:17 -0400 |
---|---|---|
committer | Behdad Esfahbod <behdad@behdad.org> | 2018-10-11 13:24:17 -0400 |
commit | b59a428af08d6451a47f40ed01e594815ebf6303 (patch) | |
tree | a210b15769d1e9899356fa6050ae5838ee2ffd0f | |
parent | 100e95f48e3d137c654d206e858d6419ea62a12c (diff) |
Minor
-rw-r--r-- | src/hb-ot-shape.cc | 6 | ||||
-rw-r--r-- | src/hb-ot-shape.hh | 5 |
2 files changed, 8 insertions, 3 deletions
diff --git a/src/hb-ot-shape.cc b/src/hb-ot-shape.cc index 3ca54ac8..2b147e34 100644 --- a/src/hb-ot-shape.cc +++ b/src/hb-ot-shape.cc @@ -116,6 +116,9 @@ hb_ot_shape_planner_t::compile (hb_ot_shape_plan_t &plan, plan.has_gpos_mark = !!plan.map.get_1_mask (HB_TAG ('m','a','r','k')); if (!plan.apply_gpos && !plan.apply_kerx) plan.fallback_mark_positioning = true; + + /* Currently we always apply trak. */ + plan.apply_trak = hb_aat_layout_has_tracking (face); } @@ -838,7 +841,8 @@ hb_ot_position_complex (const hb_ot_shape_context_t *c) else if (c->plan->apply_kerx) hb_aat_layout_position (c->plan, c->font, c->buffer); - hb_aat_layout_track (c->plan, c->font, c->buffer); + if (c->plan->apply_trak) + hb_aat_layout_track (c->plan, c->font, c->buffer); if (!c->plan->apply_kerx) switch (c->plan->shaper->zero_width_marks) diff --git a/src/hb-ot-shape.hh b/src/hb-ot-shape.hh index 4943c515..c9c0d3e0 100644 --- a/src/hb-ot-shape.hh +++ b/src/hb-ot-shape.hh @@ -50,10 +50,11 @@ struct hb_ot_shape_plan_t bool fallback_kerning : 1; bool fallback_mark_positioning : 1; - bool apply_morx : 1; + bool apply_gpos : 1; bool apply_kerx : 1; bool apply_kern : 1; - bool apply_gpos : 1; + bool apply_morx : 1; + bool apply_trak : 1; inline void collect_lookups (hb_tag_t table_tag, hb_set_t *lookups) const |