[GX] Pass apply-context down to get_anchor()
Needed to access GDEF for varStore.
This commit is contained in:
parent
f0c3fd8c9a
commit
49cb87850c
|
@ -231,9 +231,10 @@ struct ValueFormat : USHORT
|
||||||
|
|
||||||
struct AnchorFormat1
|
struct AnchorFormat1
|
||||||
{
|
{
|
||||||
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id HB_UNUSED,
|
inline void get_anchor (hb_apply_context_t *c, hb_codepoint_t glyph_id HB_UNUSED,
|
||||||
hb_position_t *x, hb_position_t *y) const
|
hb_position_t *x, hb_position_t *y) const
|
||||||
{
|
{
|
||||||
|
hb_font_t *font = c->font;
|
||||||
*x = font->em_scale_x (xCoordinate);
|
*x = font->em_scale_x (xCoordinate);
|
||||||
*y = font->em_scale_y (yCoordinate);
|
*y = font->em_scale_y (yCoordinate);
|
||||||
}
|
}
|
||||||
|
@ -254,9 +255,10 @@ struct AnchorFormat1
|
||||||
|
|
||||||
struct AnchorFormat2
|
struct AnchorFormat2
|
||||||
{
|
{
|
||||||
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id,
|
inline void get_anchor (hb_apply_context_t *c, hb_codepoint_t glyph_id,
|
||||||
hb_position_t *x, hb_position_t *y) const
|
hb_position_t *x, hb_position_t *y) const
|
||||||
{
|
{
|
||||||
|
hb_font_t *font = c->font;
|
||||||
unsigned int x_ppem = font->x_ppem;
|
unsigned int x_ppem = font->x_ppem;
|
||||||
unsigned int y_ppem = font->y_ppem;
|
unsigned int y_ppem = font->y_ppem;
|
||||||
hb_position_t cx, cy;
|
hb_position_t cx, cy;
|
||||||
|
@ -285,9 +287,10 @@ struct AnchorFormat2
|
||||||
|
|
||||||
struct AnchorFormat3
|
struct AnchorFormat3
|
||||||
{
|
{
|
||||||
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id HB_UNUSED,
|
inline void get_anchor (hb_apply_context_t *c, hb_codepoint_t glyph_id HB_UNUSED,
|
||||||
hb_position_t *x, hb_position_t *y) const
|
hb_position_t *x, hb_position_t *y) const
|
||||||
{
|
{
|
||||||
|
hb_font_t *font = c->font;
|
||||||
*x = font->em_scale_x (xCoordinate);
|
*x = font->em_scale_x (xCoordinate);
|
||||||
*y = font->em_scale_y (yCoordinate);
|
*y = font->em_scale_y (yCoordinate);
|
||||||
|
|
||||||
|
@ -321,14 +324,14 @@ struct AnchorFormat3
|
||||||
|
|
||||||
struct Anchor
|
struct Anchor
|
||||||
{
|
{
|
||||||
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id,
|
inline void get_anchor (hb_apply_context_t *c, hb_codepoint_t glyph_id,
|
||||||
hb_position_t *x, hb_position_t *y) const
|
hb_position_t *x, hb_position_t *y) const
|
||||||
{
|
{
|
||||||
*x = *y = 0;
|
*x = *y = 0;
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: u.format1.get_anchor (font, glyph_id, x, y); return;
|
case 1: u.format1.get_anchor (c, glyph_id, x, y); return;
|
||||||
case 2: u.format2.get_anchor (font, glyph_id, x, y); return;
|
case 2: u.format2.get_anchor (c, glyph_id, x, y); return;
|
||||||
case 3: u.format3.get_anchor (font, glyph_id, x, y); return;
|
case 3: u.format3.get_anchor (c, glyph_id, x, y); return;
|
||||||
default: return;
|
default: return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -428,8 +431,8 @@ struct MarkArray : ArrayOf<MarkRecord> /* Array of MarkRecords--in Coverage orde
|
||||||
|
|
||||||
hb_position_t mark_x, mark_y, base_x, base_y;
|
hb_position_t mark_x, mark_y, base_x, base_y;
|
||||||
|
|
||||||
mark_anchor.get_anchor (c->font, buffer->cur().codepoint, &mark_x, &mark_y);
|
mark_anchor.get_anchor (c, buffer->cur().codepoint, &mark_x, &mark_y);
|
||||||
glyph_anchor.get_anchor (c->font, buffer->info[glyph_pos].codepoint, &base_x, &base_y);
|
glyph_anchor.get_anchor (c, buffer->info[glyph_pos].codepoint, &base_x, &base_y);
|
||||||
|
|
||||||
hb_glyph_position_t &o = buffer->cur_pos();
|
hb_glyph_position_t &o = buffer->cur_pos();
|
||||||
o.x_offset = base_x - mark_x;
|
o.x_offset = base_x - mark_x;
|
||||||
|
@ -931,8 +934,8 @@ struct CursivePosFormat1
|
||||||
unsigned int j = skippy_iter.idx;
|
unsigned int j = skippy_iter.idx;
|
||||||
|
|
||||||
hb_position_t entry_x, entry_y, exit_x, exit_y;
|
hb_position_t entry_x, entry_y, exit_x, exit_y;
|
||||||
(this+this_record.exitAnchor).get_anchor (c->font, buffer->info[i].codepoint, &exit_x, &exit_y);
|
(this+this_record.exitAnchor).get_anchor (c, buffer->info[i].codepoint, &exit_x, &exit_y);
|
||||||
(this+next_record.entryAnchor).get_anchor (c->font, buffer->info[j].codepoint, &entry_x, &entry_y);
|
(this+next_record.entryAnchor).get_anchor (c, buffer->info[j].codepoint, &entry_x, &entry_y);
|
||||||
|
|
||||||
hb_glyph_position_t *pos = buffer->pos;
|
hb_glyph_position_t *pos = buffer->pos;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue