[morx] Implement forward/backward processing
We reverse too many times. Can be optimized. But I doubt many fonts use reverse lookups, so doesn't matter. Other than not applying user features, this completes morx table implementation.
This commit is contained in:
parent
3bccd62196
commit
dc8ed45292
|
@ -836,6 +836,8 @@ struct Chain
|
||||||
unsigned int count = subtableCount;
|
unsigned int count = subtableCount;
|
||||||
for (unsigned int i = 0; i < count; i++)
|
for (unsigned int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
|
bool reverse;
|
||||||
|
|
||||||
if (!(subtable->subFeatureFlags & flags))
|
if (!(subtable->subFeatureFlags & flags))
|
||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
|
@ -844,11 +846,49 @@ struct Chain
|
||||||
bool (subtable->coverage & ChainSubtable::Vertical))
|
bool (subtable->coverage & ChainSubtable::Vertical))
|
||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
|
/* Buffer contents is always in logical direction. Determine if
|
||||||
|
* we need to reverse before applying this subtable. We reverse
|
||||||
|
* back after if we did reverse indeed.
|
||||||
|
*
|
||||||
|
* Quoting the spac:
|
||||||
|
* """
|
||||||
|
* Bits 28 and 30 of the coverage field control the order in which
|
||||||
|
* glyphs are processed when the subtable is run by the layout engine.
|
||||||
|
* Bit 28 is used to indicate if the glyph processing direction is
|
||||||
|
* the same as logical order or layout order. Bit 30 is used to
|
||||||
|
* indicate whether glyphs are processed forwards or backwards within
|
||||||
|
* that order.
|
||||||
|
|
||||||
|
Bit 30 Bit 28 Interpretation for Horizontal Text
|
||||||
|
0 0 The subtable is processed in layout order
|
||||||
|
(the same order as the glyphs, which is
|
||||||
|
always left-to-right).
|
||||||
|
1 0 The subtable is processed in reverse layout order
|
||||||
|
(the order opposite that of the glyphs, which is
|
||||||
|
always right-to-left).
|
||||||
|
0 1 The subtable is processed in logical order
|
||||||
|
(the same order as the characters, which may be
|
||||||
|
left-to-right or right-to-left).
|
||||||
|
1 1 The subtable is processed in reverse logical order
|
||||||
|
(the order opposite that of the characters, which
|
||||||
|
may be right-to-left or left-to-right).
|
||||||
|
*/
|
||||||
|
reverse = subtable->coverage & ChainSubtable::Logical ?
|
||||||
|
bool (subtable->coverage & ChainSubtable::Descending) :
|
||||||
|
bool (subtable->coverage & ChainSubtable::Descending) !=
|
||||||
|
HB_DIRECTION_IS_BACKWARD (c->buffer->props.direction);
|
||||||
|
|
||||||
if (!c->buffer->message (c->font, "start chain subtable %d", c->lookup_index))
|
if (!c->buffer->message (c->font, "start chain subtable %d", c->lookup_index))
|
||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
|
if (reverse)
|
||||||
|
c->buffer->reverse ();
|
||||||
|
|
||||||
subtable->dispatch (c);
|
subtable->dispatch (c);
|
||||||
|
|
||||||
|
if (reverse)
|
||||||
|
c->buffer->reverse ();
|
||||||
|
|
||||||
(void) c->buffer->message (c->font, "end chain subtable %d", c->lookup_index);
|
(void) c->buffer->message (c->font, "end chain subtable %d", c->lookup_index);
|
||||||
|
|
||||||
skip:
|
skip:
|
||||||
|
|
Loading…
Reference in New Issue