[GPOS] Adjust mark advance-width zeroing logic
If there is no GPOS, zero mark advances. If there *is* GPOS and the shaper requests so, zero mark advances for attached marks. Fixes regression with Tibetan, where the font has GPOS, and marks a glyph as mark where it shouldn't get zero advance.
This commit is contained in:
parent
a8842e4a44
commit
1e7d860613
|
@ -1587,7 +1587,7 @@ struct GPOS : GSUBGPOS
|
||||||
{ return get_lookup (lookup_index).apply_string (c); }
|
{ return get_lookup (lookup_index).apply_string (c); }
|
||||||
|
|
||||||
static inline void position_start (hb_font_t *font, hb_buffer_t *buffer);
|
static inline void position_start (hb_font_t *font, hb_buffer_t *buffer);
|
||||||
static inline void position_finish (hb_font_t *font, hb_buffer_t *buffer);
|
static inline void position_finish (hb_font_t *font, hb_buffer_t *buffer, hb_bool_t zero_width_attahced_marks);
|
||||||
|
|
||||||
inline bool sanitize (hb_sanitize_context_t *c) {
|
inline bool sanitize (hb_sanitize_context_t *c) {
|
||||||
TRACE_SANITIZE ();
|
TRACE_SANITIZE ();
|
||||||
|
@ -1620,15 +1620,17 @@ fix_cursive_minor_offset (hb_glyph_position_t *pos, unsigned int i, hb_direction
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
fix_mark_attachment (hb_glyph_position_t *pos, unsigned int i, hb_direction_t direction)
|
fix_mark_attachment (hb_glyph_position_t *pos, unsigned int i, hb_direction_t direction, hb_bool_t zero_width_attached_marks)
|
||||||
{
|
{
|
||||||
if (likely (!(pos[i].attach_lookback())))
|
if (likely (!(pos[i].attach_lookback())))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned int j = i - pos[i].attach_lookback();
|
unsigned int j = i - pos[i].attach_lookback();
|
||||||
|
|
||||||
// pos[i].x_advance = 0;
|
if (zero_width_attached_marks) {
|
||||||
// pos[i].y_advance = 0;
|
pos[i].x_advance = 0;
|
||||||
|
pos[i].y_advance = 0;
|
||||||
|
}
|
||||||
pos[i].x_offset += pos[j].x_offset;
|
pos[i].x_offset += pos[j].x_offset;
|
||||||
pos[i].y_offset += pos[j].y_offset;
|
pos[i].y_offset += pos[j].y_offset;
|
||||||
|
|
||||||
|
@ -1655,7 +1657,7 @@ GPOS::position_start (hb_font_t *font HB_UNUSED, hb_buffer_t *buffer)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
GPOS::position_finish (hb_font_t *font HB_UNUSED, hb_buffer_t *buffer)
|
GPOS::position_finish (hb_font_t *font HB_UNUSED, hb_buffer_t *buffer, hb_bool_t zero_width_attached_marks)
|
||||||
{
|
{
|
||||||
unsigned int len;
|
unsigned int len;
|
||||||
hb_glyph_position_t *pos = hb_buffer_get_glyph_positions (buffer, &len);
|
hb_glyph_position_t *pos = hb_buffer_get_glyph_positions (buffer, &len);
|
||||||
|
@ -1667,7 +1669,7 @@ GPOS::position_finish (hb_font_t *font HB_UNUSED, hb_buffer_t *buffer)
|
||||||
|
|
||||||
/* Handle attachments */
|
/* Handle attachments */
|
||||||
for (unsigned int i = 0; i < len; i++)
|
for (unsigned int i = 0; i < len; i++)
|
||||||
fix_mark_attachment (pos, i, direction);
|
fix_mark_attachment (pos, i, direction, zero_width_attached_marks);
|
||||||
|
|
||||||
HB_BUFFER_DEALLOCATE_VAR (buffer, syllable);
|
HB_BUFFER_DEALLOCATE_VAR (buffer, syllable);
|
||||||
HB_BUFFER_DEALLOCATE_VAR (buffer, lig_props);
|
HB_BUFFER_DEALLOCATE_VAR (buffer, lig_props);
|
||||||
|
|
|
@ -478,9 +478,9 @@ hb_ot_layout_position_lookup_fast (hb_font_t *font,
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
hb_ot_layout_position_finish (hb_font_t *font, hb_buffer_t *buffer)
|
hb_ot_layout_position_finish (hb_font_t *font, hb_buffer_t *buffer, hb_bool_t zero_width_attached_marks)
|
||||||
{
|
{
|
||||||
GPOS::position_finish (font, buffer);
|
GPOS::position_finish (font, buffer, zero_width_attached_marks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -219,7 +219,8 @@ hb_ot_layout_position_lookup (hb_font_t *font,
|
||||||
/* Should be called after all the position_lookup's are done */
|
/* Should be called after all the position_lookup's are done */
|
||||||
void
|
void
|
||||||
hb_ot_layout_position_finish (hb_font_t *font,
|
hb_ot_layout_position_finish (hb_font_t *font,
|
||||||
hb_buffer_t *buffer);
|
hb_buffer_t *buffer,
|
||||||
|
hb_bool_t zero_width_attached_marks);
|
||||||
|
|
||||||
|
|
||||||
HB_END_DECLS
|
HB_END_DECLS
|
||||||
|
|
|
@ -299,5 +299,5 @@ const hb_ot_complex_shaper_t _hb_ot_complex_shaper_arabic =
|
||||||
NULL, /* override_features */
|
NULL, /* override_features */
|
||||||
NULL, /* normalization_preference */
|
NULL, /* normalization_preference */
|
||||||
setup_masks_arabic,
|
setup_masks_arabic,
|
||||||
true, /* zero_width_marks */
|
true, /* zero_width_attached_marks */
|
||||||
};
|
};
|
||||||
|
|
|
@ -1245,5 +1245,5 @@ const hb_ot_complex_shaper_t _hb_ot_complex_shaper_indic =
|
||||||
override_features_indic,
|
override_features_indic,
|
||||||
NULL, /* normalization_preference */
|
NULL, /* normalization_preference */
|
||||||
setup_masks_indic,
|
setup_masks_indic,
|
||||||
false, /* zero_width_marks */
|
false, /* zero_width_attached_marks */
|
||||||
};
|
};
|
||||||
|
|
|
@ -93,7 +93,7 @@ const hb_ot_complex_shaper_t _hb_ot_complex_shaper_default =
|
||||||
NULL, /* override_features */
|
NULL, /* override_features */
|
||||||
normalization_preference_default,
|
normalization_preference_default,
|
||||||
NULL, /* setup_masks */
|
NULL, /* setup_masks */
|
||||||
true, /* zero_width_marks */
|
true, /* zero_width_attached_marks */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -202,5 +202,5 @@ const hb_ot_complex_shaper_t _hb_ot_complex_shaper_thai =
|
||||||
NULL, /* override_features */
|
NULL, /* override_features */
|
||||||
NULL, /* normalization_preference */
|
NULL, /* normalization_preference */
|
||||||
setup_masks_thai,
|
setup_masks_thai,
|
||||||
true, /* zero_width_marks */
|
true, /* zero_width_attached_marks */
|
||||||
};
|
};
|
||||||
|
|
|
@ -94,7 +94,7 @@ struct hb_ot_complex_shaper_t
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
hb_font_t *font);
|
hb_font_t *font);
|
||||||
|
|
||||||
bool zero_width_marks;
|
bool zero_width_attached_marks;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define HB_COMPLEX_SHAPER_IMPLEMENT(name) extern HB_INTERNAL const hb_ot_complex_shaper_t _hb_ot_complex_shaper_##name;
|
#define HB_COMPLEX_SHAPER_IMPLEMENT(name) extern HB_INTERNAL const hb_ot_complex_shaper_t _hb_ot_complex_shaper_##name;
|
||||||
|
|
|
@ -439,12 +439,10 @@ hb_ot_position_complex (hb_ot_shape_context_t *c)
|
||||||
}
|
}
|
||||||
|
|
||||||
c->applied_position_complex = true;
|
c->applied_position_complex = true;
|
||||||
}
|
} else
|
||||||
|
|
||||||
if (c->plan->shaper->zero_width_marks)
|
|
||||||
hb_zero_mark_advances (c);
|
hb_zero_mark_advances (c);
|
||||||
|
|
||||||
hb_ot_layout_position_finish (c->font, c->buffer);
|
hb_ot_layout_position_finish (c->font, c->buffer, c->plan->shaper->zero_width_attached_marks);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue