[HB] Indentation
This commit is contained in:
parent
d18fd8e3f7
commit
4c44d830d7
|
@ -65,9 +65,10 @@ struct ValueRecord {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct ValueFormat : USHORT {
|
struct ValueFormat : USHORT
|
||||||
|
{
|
||||||
enum {
|
enum
|
||||||
|
{
|
||||||
xPlacement = 0x0001, /* Includes horizontal adjustment for placement */
|
xPlacement = 0x0001, /* Includes horizontal adjustment for placement */
|
||||||
yPlacement = 0x0002, /* Includes vertical adjustment for placement */
|
yPlacement = 0x0002, /* Includes vertical adjustment for placement */
|
||||||
xAdvance = 0x0004, /* Includes horizontal adjustment for advance */
|
xAdvance = 0x0004, /* Includes horizontal adjustment for advance */
|
||||||
|
@ -79,7 +80,8 @@ struct ValueFormat : USHORT {
|
||||||
reserved = 0xF000, /* For future use */
|
reserved = 0xF000, /* For future use */
|
||||||
};
|
};
|
||||||
|
|
||||||
inline unsigned int get_len () const {
|
inline unsigned int get_len () const
|
||||||
|
{
|
||||||
return _hb_popcount32 ((unsigned int) *this);
|
return _hb_popcount32 ((unsigned int) *this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,8 +138,8 @@ struct ValueFormat : USHORT {
|
||||||
ASSERT_SIZE (ValueFormat, 2);
|
ASSERT_SIZE (ValueFormat, 2);
|
||||||
|
|
||||||
|
|
||||||
struct AnchorFormat1 {
|
struct AnchorFormat1
|
||||||
|
{
|
||||||
friend struct Anchor;
|
friend struct Anchor;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -155,8 +157,8 @@ struct AnchorFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (AnchorFormat1, 6);
|
ASSERT_SIZE (AnchorFormat1, 6);
|
||||||
|
|
||||||
struct AnchorFormat2 {
|
struct AnchorFormat2
|
||||||
|
{
|
||||||
friend struct Anchor;
|
friend struct Anchor;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -176,8 +178,8 @@ struct AnchorFormat2 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (AnchorFormat2, 8);
|
ASSERT_SIZE (AnchorFormat2, 8);
|
||||||
|
|
||||||
struct AnchorFormat3 {
|
struct AnchorFormat3
|
||||||
|
{
|
||||||
friend struct Anchor;
|
friend struct Anchor;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -204,8 +206,8 @@ struct AnchorFormat3 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (AnchorFormat3, 10);
|
ASSERT_SIZE (AnchorFormat3, 10);
|
||||||
|
|
||||||
struct Anchor {
|
struct Anchor
|
||||||
|
{
|
||||||
inline void get_anchor (hb_ot_layout_t *layout, hb_codepoint_t glyph_id,
|
inline void get_anchor (hb_ot_layout_t *layout, hb_codepoint_t glyph_id,
|
||||||
hb_position_t *x, hb_position_t *y) const
|
hb_position_t *x, hb_position_t *y) const
|
||||||
{
|
{
|
||||||
|
@ -229,7 +231,8 @@ struct Anchor {
|
||||||
ASSERT_SIZE (Anchor, 2);
|
ASSERT_SIZE (Anchor, 2);
|
||||||
|
|
||||||
|
|
||||||
struct MarkRecord {
|
struct MarkRecord
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -240,7 +243,8 @@ struct MarkRecord {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (MarkRecord, 4);
|
ASSERT_SIZE (MarkRecord, 4);
|
||||||
|
|
||||||
struct MarkArray {
|
struct MarkArray
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -252,8 +256,8 @@ ASSERT_SIZE (MarkArray, 2);
|
||||||
|
|
||||||
/* Lookups */
|
/* Lookups */
|
||||||
|
|
||||||
struct SinglePosFormat1 {
|
struct SinglePosFormat1
|
||||||
|
{
|
||||||
friend struct SinglePos;
|
friend struct SinglePos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -280,8 +284,8 @@ struct SinglePosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (SinglePosFormat1, 6);
|
ASSERT_SIZE (SinglePosFormat1, 6);
|
||||||
|
|
||||||
struct SinglePosFormat2 {
|
struct SinglePosFormat2
|
||||||
|
{
|
||||||
friend struct SinglePos;
|
friend struct SinglePos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -313,8 +317,8 @@ struct SinglePosFormat2 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (SinglePosFormat2, 8);
|
ASSERT_SIZE (SinglePosFormat2, 8);
|
||||||
|
|
||||||
struct SinglePos {
|
struct SinglePos
|
||||||
|
{
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -338,8 +342,8 @@ struct SinglePos {
|
||||||
ASSERT_SIZE (SinglePos, 2);
|
ASSERT_SIZE (SinglePos, 2);
|
||||||
|
|
||||||
|
|
||||||
struct PairValueRecord {
|
struct PairValueRecord
|
||||||
|
{
|
||||||
friend struct PairPosFormat1;
|
friend struct PairPosFormat1;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -351,19 +355,10 @@ struct PairValueRecord {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (PairValueRecord, 2);
|
ASSERT_SIZE (PairValueRecord, 2);
|
||||||
|
|
||||||
struct PairSet {
|
struct PairSet
|
||||||
|
{
|
||||||
friend struct PairPosFormat1;
|
friend struct PairPosFormat1;
|
||||||
|
|
||||||
private:
|
|
||||||
inline bool apply (APPLY_ARG_DEF,
|
|
||||||
ValueFormat &f1, ValueFormat &f2,
|
|
||||||
unsigned int next_pos) const {
|
|
||||||
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
USHORT len; /* Number of PairValueRecords */
|
USHORT len; /* Number of PairValueRecords */
|
||||||
/* XXX */
|
/* XXX */
|
||||||
|
@ -373,8 +368,8 @@ struct PairSet {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (PairSet, 2);
|
ASSERT_SIZE (PairSet, 2);
|
||||||
|
|
||||||
struct PairPosFormat1 {
|
struct PairPosFormat1
|
||||||
|
{
|
||||||
friend struct PairPos;
|
friend struct PairPos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -389,7 +384,8 @@ struct PairPosFormat1 {
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
unsigned int j = buffer->in_pos + 1;
|
unsigned int j = buffer->in_pos + 1;
|
||||||
while (!_hb_ot_layout_check_glyph_property (layout, IN_ITEM (j), lookup_flag, &property)) {
|
while (!_hb_ot_layout_check_glyph_property (layout, IN_ITEM (j), lookup_flag, &property))
|
||||||
|
{
|
||||||
if (HB_UNLIKELY (j == end))
|
if (HB_UNLIKELY (j == end))
|
||||||
return false;
|
return false;
|
||||||
j++;
|
j++;
|
||||||
|
@ -403,8 +399,10 @@ struct PairPosFormat1 {
|
||||||
|
|
||||||
unsigned int count = pair_set.len;
|
unsigned int count = pair_set.len;
|
||||||
const PairValueRecord *record = pair_set.array;
|
const PairValueRecord *record = pair_set.array;
|
||||||
for (unsigned int i = 0; i < count; i++) {
|
for (unsigned int i = 0; i < count; i++)
|
||||||
if (IN_GLYPH (j) == record->secondGlyph) {
|
{
|
||||||
|
if (IN_GLYPH (j) == record->secondGlyph)
|
||||||
|
{
|
||||||
valueFormat1.apply_value (layout, (const char *) this, record->values, CURPOSITION ());
|
valueFormat1.apply_value (layout, (const char *) this, record->values, CURPOSITION ());
|
||||||
valueFormat2.apply_value (layout, (const char *) this, record->values + len1, POSITION (j));
|
valueFormat2.apply_value (layout, (const char *) this, record->values + len1, POSITION (j));
|
||||||
if (len2)
|
if (len2)
|
||||||
|
@ -435,8 +433,8 @@ struct PairPosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (PairPosFormat1, 10);
|
ASSERT_SIZE (PairPosFormat1, 10);
|
||||||
|
|
||||||
struct PairPosFormat2 {
|
struct PairPosFormat2
|
||||||
|
{
|
||||||
friend struct PairPos;
|
friend struct PairPos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -451,7 +449,8 @@ struct PairPosFormat2 {
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
unsigned int j = buffer->in_pos + 1;
|
unsigned int j = buffer->in_pos + 1;
|
||||||
while (!_hb_ot_layout_check_glyph_property (layout, IN_ITEM (j), lookup_flag, &property)) {
|
while (!_hb_ot_layout_check_glyph_property (layout, IN_ITEM (j), lookup_flag, &property))
|
||||||
|
{
|
||||||
if (HB_UNLIKELY (j == end))
|
if (HB_UNLIKELY (j == end))
|
||||||
return false;
|
return false;
|
||||||
j++;
|
j++;
|
||||||
|
@ -507,13 +506,14 @@ struct PairPosFormat2 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (PairPosFormat2, 16);
|
ASSERT_SIZE (PairPosFormat2, 16);
|
||||||
|
|
||||||
struct PairPos {
|
struct PairPos
|
||||||
|
{
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
case 2: return u.format2->apply (APPLY_ARG);
|
case 2: return u.format2->apply (APPLY_ARG);
|
||||||
|
@ -531,7 +531,8 @@ struct PairPos {
|
||||||
ASSERT_SIZE (PairPos, 2);
|
ASSERT_SIZE (PairPos, 2);
|
||||||
|
|
||||||
|
|
||||||
struct EntryExitRecord {
|
struct EntryExitRecord
|
||||||
|
{
|
||||||
OffsetTo<Anchor>
|
OffsetTo<Anchor>
|
||||||
entryAnchor; /* Offset to EntryAnchor table--from
|
entryAnchor; /* Offset to EntryAnchor table--from
|
||||||
* beginning of CursivePos
|
* beginning of CursivePos
|
||||||
|
@ -543,8 +544,8 @@ struct EntryExitRecord {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (EntryExitRecord, 4);
|
ASSERT_SIZE (EntryExitRecord, 4);
|
||||||
|
|
||||||
struct CursivePosFormat1 {
|
struct CursivePosFormat1
|
||||||
|
{
|
||||||
friend struct CursivePos;
|
friend struct CursivePos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -729,13 +730,14 @@ struct CursivePosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (CursivePosFormat1, 6);
|
ASSERT_SIZE (CursivePosFormat1, 6);
|
||||||
|
|
||||||
struct CursivePos {
|
struct CursivePos
|
||||||
|
{
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -751,7 +753,8 @@ struct CursivePos {
|
||||||
ASSERT_SIZE (CursivePos, 2);
|
ASSERT_SIZE (CursivePos, 2);
|
||||||
|
|
||||||
|
|
||||||
struct BaseRecord {
|
struct BaseRecord
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -762,7 +765,8 @@ struct BaseRecord {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (BaseRecord, 0);
|
ASSERT_SIZE (BaseRecord, 0);
|
||||||
|
|
||||||
struct BaseArray {
|
struct BaseArray
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -772,12 +776,13 @@ struct BaseArray {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (BaseArray, 2);
|
ASSERT_SIZE (BaseArray, 2);
|
||||||
|
|
||||||
struct MarkBasePosFormat1 {
|
struct MarkBasePosFormat1
|
||||||
|
{
|
||||||
friend struct MarkBasePos;
|
friend struct MarkBasePos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -797,13 +802,14 @@ struct MarkBasePosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (MarkBasePosFormat1, 12);
|
ASSERT_SIZE (MarkBasePosFormat1, 12);
|
||||||
|
|
||||||
struct MarkBasePos {
|
struct MarkBasePos
|
||||||
|
{
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -819,7 +825,8 @@ struct MarkBasePos {
|
||||||
ASSERT_SIZE (MarkBasePos, 2);
|
ASSERT_SIZE (MarkBasePos, 2);
|
||||||
|
|
||||||
|
|
||||||
struct ComponentRecord {
|
struct ComponentRecord
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -833,7 +840,8 @@ struct ComponentRecord {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ComponentRecord, 0);
|
ASSERT_SIZE (ComponentRecord, 0);
|
||||||
|
|
||||||
struct LigatureAttach {
|
struct LigatureAttach
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -846,7 +854,8 @@ struct LigatureAttach {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (LigatureAttach, 2);
|
ASSERT_SIZE (LigatureAttach, 2);
|
||||||
|
|
||||||
struct LigatureArray {
|
struct LigatureArray
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -857,12 +866,13 @@ struct LigatureArray {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (LigatureArray, 2);
|
ASSERT_SIZE (LigatureArray, 2);
|
||||||
|
|
||||||
struct MarkLigPosFormat1 {
|
struct MarkLigPosFormat1
|
||||||
|
{
|
||||||
friend struct MarkLigPos;
|
friend struct MarkLigPos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -882,13 +892,14 @@ struct MarkLigPosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (MarkLigPosFormat1, 12);
|
ASSERT_SIZE (MarkLigPosFormat1, 12);
|
||||||
|
|
||||||
struct MarkLigPos {
|
struct MarkLigPos
|
||||||
|
{
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -904,7 +915,8 @@ struct MarkLigPos {
|
||||||
ASSERT_SIZE (MarkLigPos, 2);
|
ASSERT_SIZE (MarkLigPos, 2);
|
||||||
|
|
||||||
|
|
||||||
struct Mark2Record {
|
struct Mark2Record
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -914,7 +926,8 @@ struct Mark2Record {
|
||||||
* Mark2Array table--zero--based array */
|
* Mark2Array table--zero--based array */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Mark2Array {
|
struct Mark2Array
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -924,12 +937,13 @@ struct Mark2Array {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (Mark2Array, 2);
|
ASSERT_SIZE (Mark2Array, 2);
|
||||||
|
|
||||||
struct MarkMarkPosFormat1 {
|
struct MarkMarkPosFormat1
|
||||||
|
{
|
||||||
friend struct MarkMarkPos;
|
friend struct MarkMarkPos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
/* TODO */
|
/* TODO */
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -949,13 +963,14 @@ struct MarkMarkPosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (MarkMarkPosFormat1, 10);
|
ASSERT_SIZE (MarkMarkPosFormat1, 10);
|
||||||
|
|
||||||
struct MarkMarkPos {
|
struct MarkMarkPos
|
||||||
|
{
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -973,25 +988,27 @@ ASSERT_SIZE (MarkMarkPos, 2);
|
||||||
|
|
||||||
static inline bool position_lookup (APPLY_ARG_DEF, unsigned int lookup_index);
|
static inline bool position_lookup (APPLY_ARG_DEF, unsigned int lookup_index);
|
||||||
|
|
||||||
struct ContextPos : Context {
|
struct ContextPos : Context
|
||||||
|
{
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
return Context::apply (APPLY_ARG, position_lookup);
|
return Context::apply (APPLY_ARG, position_lookup);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ContextPos, 2);
|
ASSERT_SIZE (ContextPos, 2);
|
||||||
|
|
||||||
struct ChainContextPos : ChainContext {
|
struct ChainContextPos : ChainContext
|
||||||
|
{
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
return ChainContext::apply (APPLY_ARG, position_lookup);
|
return ChainContext::apply (APPLY_ARG, position_lookup);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ChainContextPos, 2);
|
ASSERT_SIZE (ChainContextPos, 2);
|
||||||
|
|
||||||
|
|
||||||
struct ExtensionPosFormat1 {
|
struct ExtensionPosFormat1
|
||||||
|
{
|
||||||
friend struct ExtensionPos;
|
friend struct ExtensionPos;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -1011,21 +1028,23 @@ struct ExtensionPosFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ExtensionPosFormat1, 8);
|
ASSERT_SIZE (ExtensionPosFormat1, 8);
|
||||||
|
|
||||||
struct ExtensionPos {
|
struct ExtensionPos
|
||||||
|
{
|
||||||
friend struct PosLookup;
|
friend struct PosLookup;
|
||||||
friend struct PosLookupSubTable;
|
friend struct PosLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline unsigned int get_type (void) const {
|
inline unsigned int get_type (void) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->get_type ();
|
case 1: return u.format1->get_type ();
|
||||||
default:return 0;
|
default:return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -1058,12 +1077,12 @@ enum {
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
struct PosLookupSubTable {
|
struct PosLookupSubTable
|
||||||
|
{
|
||||||
friend struct PosLookup;
|
friend struct PosLookup;
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF, unsigned int lookup_type) const {
|
inline bool apply (APPLY_ARG_DEF, unsigned int lookup_type) const
|
||||||
|
{
|
||||||
switch (lookup_type) {
|
switch (lookup_type) {
|
||||||
case GPOS_Single: return u.single->apply (APPLY_ARG);
|
case GPOS_Single: return u.single->apply (APPLY_ARG);
|
||||||
case GPOS_Pair: return u.pair->apply (APPLY_ARG);
|
case GPOS_Pair: return u.pair->apply (APPLY_ARG);
|
||||||
|
@ -1095,18 +1114,21 @@ struct PosLookupSubTable {
|
||||||
ASSERT_SIZE (PosLookupSubTable, 2);
|
ASSERT_SIZE (PosLookupSubTable, 2);
|
||||||
|
|
||||||
|
|
||||||
struct PosLookup : Lookup {
|
struct PosLookup : Lookup
|
||||||
|
{
|
||||||
inline const PosLookupSubTable& get_subtable (unsigned int i) const {
|
inline const PosLookupSubTable& get_subtable (unsigned int i) const
|
||||||
|
{
|
||||||
return (const PosLookupSubTable&) Lookup::get_subtable (i);
|
return (const PosLookupSubTable&) Lookup::get_subtable (i);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Like get_type(), but looks through extension lookups.
|
/* Like get_type(), but looks through extension lookups.
|
||||||
* Never returns Extension */
|
* Never returns Extension */
|
||||||
inline unsigned int get_effective_type (void) const {
|
inline unsigned int get_effective_type (void) const
|
||||||
|
{
|
||||||
unsigned int type = get_type ();
|
unsigned int type = get_type ();
|
||||||
|
|
||||||
if (HB_UNLIKELY (type == GPOS_Extension)) {
|
if (HB_UNLIKELY (type == GPOS_Extension))
|
||||||
|
{
|
||||||
unsigned int count = get_subtable_count ();
|
unsigned int count = get_subtable_count ();
|
||||||
type = get_subtable(0).u.extension->get_type ();
|
type = get_subtable(0).u.extension->get_type ();
|
||||||
/* The spec says all subtables should have the same type.
|
/* The spec says all subtables should have the same type.
|
||||||
|
@ -1123,7 +1145,8 @@ struct PosLookup : Lookup {
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
unsigned int context_length,
|
unsigned int context_length,
|
||||||
unsigned int nesting_level_left,
|
unsigned int nesting_level_left,
|
||||||
unsigned int property) const {
|
unsigned int property) const
|
||||||
|
{
|
||||||
unsigned int lookup_type = get_type ();
|
unsigned int lookup_type = get_type ();
|
||||||
unsigned int lookup_flag = get_flag ();
|
unsigned int lookup_flag = get_flag ();
|
||||||
|
|
||||||
|
@ -1134,8 +1157,8 @@ struct PosLookup : Lookup {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply_once (hb_ot_layout_t *layout, hb_buffer_t *buffer) const {
|
inline bool apply_once (hb_ot_layout_t *layout, hb_buffer_t *buffer) const
|
||||||
|
{
|
||||||
unsigned int lookup_flag = get_flag ();
|
unsigned int lookup_flag = get_flag ();
|
||||||
|
|
||||||
unsigned int property;
|
unsigned int property;
|
||||||
|
@ -1147,8 +1170,8 @@ struct PosLookup : Lookup {
|
||||||
|
|
||||||
bool apply_string (hb_ot_layout_t *layout,
|
bool apply_string (hb_ot_layout_t *layout,
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
hb_ot_layout_feature_mask_t mask) const {
|
hb_ot_layout_feature_mask_t mask) const
|
||||||
|
{
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
|
|
||||||
if (HB_UNLIKELY (!buffer->in_length))
|
if (HB_UNLIKELY (!buffer->in_length))
|
||||||
|
@ -1157,13 +1180,16 @@ struct PosLookup : Lookup {
|
||||||
layout->gpos_info.last = 0xFFFF; /* no last valid glyph for cursive pos. */
|
layout->gpos_info.last = 0xFFFF; /* no last valid glyph for cursive pos. */
|
||||||
|
|
||||||
buffer->in_pos = 0;
|
buffer->in_pos = 0;
|
||||||
while (buffer->in_pos < buffer->in_length) {
|
while (buffer->in_pos < buffer->in_length)
|
||||||
|
{
|
||||||
bool done;
|
bool done;
|
||||||
if (~IN_PROPERTIES (buffer->in_pos) & mask) {
|
if (~IN_PROPERTIES (buffer->in_pos) & mask)
|
||||||
|
{
|
||||||
done = apply_once (layout, buffer);
|
done = apply_once (layout, buffer);
|
||||||
ret |= done;
|
ret |= done;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
done = false;
|
done = false;
|
||||||
/* Contrary to properties defined in GDEF, user-defined properties
|
/* Contrary to properties defined in GDEF, user-defined properties
|
||||||
will always stop a possible cursive positioning. */
|
will always stop a possible cursive positioning. */
|
||||||
|
@ -1184,20 +1210,23 @@ ASSERT_SIZE (PosLookup, 6);
|
||||||
* GPOS
|
* GPOS
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct GPOS : GSUBGPOS {
|
struct GPOS : GSUBGPOS
|
||||||
|
{
|
||||||
static const hb_tag_t Tag = HB_TAG ('G','P','O','S');
|
static const hb_tag_t Tag = HB_TAG ('G','P','O','S');
|
||||||
|
|
||||||
STATIC_DEFINE_GET_FOR_DATA (GPOS);
|
STATIC_DEFINE_GET_FOR_DATA (GPOS);
|
||||||
/* XXX check version here? */
|
/* XXX check version here? */
|
||||||
|
|
||||||
inline const PosLookup& get_lookup (unsigned int i) const {
|
inline const PosLookup& get_lookup (unsigned int i) const
|
||||||
return (PosLookup&)(((GSUBGPOS *)this)->get_lookup (i));
|
{
|
||||||
|
return (const PosLookup&) GSUBGPOS::get_lookup (i);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool position_lookup (hb_ot_layout_t *layout,
|
inline bool position_lookup (hb_ot_layout_t *layout,
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
unsigned int lookup_index,
|
unsigned int lookup_index,
|
||||||
hb_ot_layout_feature_mask_t mask) const {
|
hb_ot_layout_feature_mask_t mask) const
|
||||||
|
{
|
||||||
return get_lookup (lookup_index).apply_string (layout, buffer, mask);
|
return get_lookup (lookup_index).apply_string (layout, buffer, mask);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1207,7 +1236,8 @@ ASSERT_SIZE (GPOS, 10);
|
||||||
|
|
||||||
/* Out-of-class implementation for methods recursing */
|
/* Out-of-class implementation for methods recursing */
|
||||||
|
|
||||||
inline bool ExtensionPosFormat1::apply (APPLY_ARG_DEF) const {
|
inline bool ExtensionPosFormat1::apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
unsigned int lookup_type = get_type ();
|
unsigned int lookup_type = get_type ();
|
||||||
|
|
||||||
if (HB_UNLIKELY (lookup_type == GPOS_Extension))
|
if (HB_UNLIKELY (lookup_type == GPOS_Extension))
|
||||||
|
@ -1216,7 +1246,8 @@ inline bool ExtensionPosFormat1::apply (APPLY_ARG_DEF) const {
|
||||||
return ((PosLookupSubTable&)*(((char *) this) + get_offset ())).apply (APPLY_ARG, lookup_type);
|
return ((PosLookupSubTable&)*(((char *) this) + get_offset ())).apply (APPLY_ARG, lookup_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool position_lookup (APPLY_ARG_DEF, unsigned int lookup_index) {
|
static inline bool position_lookup (APPLY_ARG_DEF, unsigned int lookup_index)
|
||||||
|
{
|
||||||
const GPOS &gpos = *(layout->gpos);
|
const GPOS &gpos = *(layout->gpos);
|
||||||
const PosLookup &l = gpos.get_lookup (lookup_index);
|
const PosLookup &l = gpos.get_lookup (lookup_index);
|
||||||
|
|
||||||
|
|
|
@ -40,19 +40,27 @@ _hb_buffer_add_output_glyph_ids( HB_Buffer buffer,
|
||||||
HB_UShort ligID );
|
HB_UShort ligID );
|
||||||
|
|
||||||
|
|
||||||
struct SingleSubstFormat1 {
|
struct SingleSubstFormat1
|
||||||
|
{
|
||||||
friend struct SingleSubst;
|
friend struct SingleSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool get_substitute (hb_codepoint_t &glyph_id) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
|
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
||||||
unsigned int index = (this+coverage) (glyph_id);
|
unsigned int index = (this+coverage) (glyph_id);
|
||||||
if (HB_LIKELY (index == NOT_COVERED))
|
if (HB_LIKELY (index == NOT_COVERED))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
glyph_id += deltaGlyphID;
|
glyph_id += deltaGlyphID;
|
||||||
|
_hb_buffer_replace_glyph (buffer, glyph_id);
|
||||||
|
|
||||||
|
if ( _hb_ot_layout_has_new_glyph_classes (layout) )
|
||||||
|
{
|
||||||
|
/* we inherit the old glyph class to the substituted glyph */
|
||||||
|
_hb_ot_layout_set_glyph_property (layout, glyph_id, property);
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -67,14 +75,15 @@ struct SingleSubstFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (SingleSubstFormat1, 6);
|
ASSERT_SIZE (SingleSubstFormat1, 6);
|
||||||
|
|
||||||
struct SingleSubstFormat2 {
|
struct SingleSubstFormat2
|
||||||
|
{
|
||||||
friend struct SingleSubst;
|
friend struct SingleSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool get_substitute (hb_codepoint_t &glyph_id) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
|
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
||||||
unsigned int index = (this+coverage) (glyph_id);
|
unsigned int index = (this+coverage) (glyph_id);
|
||||||
if (HB_LIKELY (index == NOT_COVERED))
|
if (HB_LIKELY (index == NOT_COVERED))
|
||||||
return false;
|
return false;
|
||||||
|
@ -83,6 +92,14 @@ struct SingleSubstFormat2 {
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
glyph_id = substitute[index];
|
glyph_id = substitute[index];
|
||||||
|
_hb_buffer_replace_glyph (buffer, glyph_id);
|
||||||
|
|
||||||
|
if ( _hb_ot_layout_has_new_glyph_classes (layout) )
|
||||||
|
{
|
||||||
|
/* we inherit the old glyph class to the substituted glyph */
|
||||||
|
_hb_ot_layout_set_glyph_property (layout, glyph_id, property);
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,38 +114,21 @@ struct SingleSubstFormat2 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (SingleSubstFormat2, 6);
|
ASSERT_SIZE (SingleSubstFormat2, 6);
|
||||||
|
|
||||||
struct SingleSubst {
|
struct SingleSubst
|
||||||
|
{
|
||||||
friend struct SubstLookupSubTable;
|
friend struct SubstLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool get_substitute (hb_codepoint_t &glyph_id) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->get_substitute (glyph_id);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
case 2: return u.format2->get_substitute (glyph_id);
|
case 2: return u.format2->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
|
||||||
|
|
||||||
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
|
||||||
|
|
||||||
if (!get_substitute (glyph_id))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
_hb_buffer_replace_glyph (buffer, glyph_id);
|
|
||||||
|
|
||||||
if ( _hb_ot_layout_has_new_glyph_classes (layout) )
|
|
||||||
{
|
|
||||||
/* we inherit the old glyph class to the substituted glyph */
|
|
||||||
_hb_ot_layout_set_glyph_property (layout, glyph_id, property);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
union {
|
union {
|
||||||
USHORT format; /* Format identifier */
|
USHORT format; /* Format identifier */
|
||||||
|
@ -139,21 +139,21 @@ struct SingleSubst {
|
||||||
ASSERT_SIZE (SingleSubst, 2);
|
ASSERT_SIZE (SingleSubst, 2);
|
||||||
|
|
||||||
|
|
||||||
struct Sequence {
|
struct Sequence
|
||||||
|
{
|
||||||
friend struct MultipleSubstFormat1;
|
friend struct MultipleSubstFormat1;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline void set_glyph_class (hb_ot_layout_t *layout, unsigned int property) const {
|
inline void set_glyph_class (hb_ot_layout_t *layout, unsigned int property) const
|
||||||
|
{
|
||||||
unsigned int count = substitute.len;
|
unsigned int count = substitute.len;
|
||||||
for (unsigned int n = 0; n < count; n++)
|
for (unsigned int n = 0; n < count; n++)
|
||||||
_hb_ot_layout_set_glyph_property (layout, substitute[n], property);
|
_hb_ot_layout_set_glyph_property (layout, substitute[n], property);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
if (HB_UNLIKELY (!substitute.len))
|
if (HB_UNLIKELY (!substitute.len))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -180,13 +180,14 @@ struct Sequence {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (Sequence, 2);
|
ASSERT_SIZE (Sequence, 2);
|
||||||
|
|
||||||
struct MultipleSubstFormat1 {
|
struct MultipleSubstFormat1
|
||||||
|
{
|
||||||
friend struct MultipleSubst;
|
friend struct MultipleSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
|
|
||||||
unsigned int index = (this+coverage) (IN_CURGLYPH ());
|
unsigned int index = (this+coverage) (IN_CURGLYPH ());
|
||||||
if (HB_LIKELY (index == NOT_COVERED))
|
if (HB_LIKELY (index == NOT_COVERED))
|
||||||
|
@ -206,13 +207,14 @@ struct MultipleSubstFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (MultipleSubstFormat1, 6);
|
ASSERT_SIZE (MultipleSubstFormat1, 6);
|
||||||
|
|
||||||
struct MultipleSubst {
|
struct MultipleSubst
|
||||||
|
{
|
||||||
friend struct SubstLookupSubTable;
|
friend struct SubstLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -232,14 +234,14 @@ typedef ArrayOf<GlyphID> AlternateSet; /* Array of alternate GlyphIDs--in
|
||||||
* arbitrary order */
|
* arbitrary order */
|
||||||
ASSERT_SIZE (AlternateSet, 2);
|
ASSERT_SIZE (AlternateSet, 2);
|
||||||
|
|
||||||
struct AlternateSubstFormat1 {
|
struct AlternateSubstFormat1
|
||||||
|
{
|
||||||
friend struct AlternateSubst;
|
friend struct AlternateSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
||||||
|
|
||||||
unsigned int index = (this+coverage) (glyph_id);
|
unsigned int index = (this+coverage) (glyph_id);
|
||||||
|
@ -287,13 +289,14 @@ struct AlternateSubstFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (AlternateSubstFormat1, 6);
|
ASSERT_SIZE (AlternateSubstFormat1, 6);
|
||||||
|
|
||||||
struct AlternateSubst {
|
struct AlternateSubst
|
||||||
|
{
|
||||||
friend struct SubstLookupSubTable;
|
friend struct SubstLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -309,21 +312,23 @@ struct AlternateSubst {
|
||||||
ASSERT_SIZE (AlternateSubst, 2);
|
ASSERT_SIZE (AlternateSubst, 2);
|
||||||
|
|
||||||
|
|
||||||
struct Ligature {
|
struct Ligature
|
||||||
|
{
|
||||||
friend struct LigatureSet;
|
friend struct LigatureSet;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
inline bool apply (APPLY_ARG_DEF, bool is_mark) const {
|
inline bool apply (APPLY_ARG_DEF, bool is_mark) const
|
||||||
|
{
|
||||||
unsigned int i, j;
|
unsigned int i, j;
|
||||||
unsigned int count = component.len;
|
unsigned int count = component.len;
|
||||||
unsigned int end = MIN (buffer->in_length, buffer->in_pos + context_length);
|
unsigned int end = MIN (buffer->in_length, buffer->in_pos + context_length);
|
||||||
if (HB_UNLIKELY (buffer->in_pos + count > end))
|
if (HB_UNLIKELY (buffer->in_pos + count > end))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (i = 1, j = buffer->in_pos + 1; i < count; i++, j++) {
|
for (i = 1, j = buffer->in_pos + 1; i < count; i++, j++)
|
||||||
while (!_hb_ot_layout_check_glyph_property (layout, IN_ITEM (j), lookup_flag, &property)) {
|
{
|
||||||
|
while (!_hb_ot_layout_check_glyph_property (layout, IN_ITEM (j), lookup_flag, &property))
|
||||||
|
{
|
||||||
if (HB_UNLIKELY (j + count - i == end))
|
if (HB_UNLIKELY (j + count - i == end))
|
||||||
return false;
|
return false;
|
||||||
j++;
|
j++;
|
||||||
|
@ -387,16 +392,17 @@ struct Ligature {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (Ligature, 4);
|
ASSERT_SIZE (Ligature, 4);
|
||||||
|
|
||||||
struct LigatureSet {
|
struct LigatureSet
|
||||||
|
{
|
||||||
friend struct LigatureSubstFormat1;
|
friend struct LigatureSubstFormat1;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF, bool is_mark) const {
|
inline bool apply (APPLY_ARG_DEF, bool is_mark) const
|
||||||
|
{
|
||||||
unsigned int num_ligs = ligature.len;
|
unsigned int num_ligs = ligature.len;
|
||||||
for (unsigned int i = 0; i < num_ligs; i++) {
|
for (unsigned int i = 0; i < num_ligs; i++)
|
||||||
|
{
|
||||||
const Ligature &lig = this+ligature[i];
|
const Ligature &lig = this+ligature[i];
|
||||||
if (lig.apply (APPLY_ARG, is_mark))
|
if (lig.apply (APPLY_ARG, is_mark))
|
||||||
return true;
|
return true;
|
||||||
|
@ -412,14 +418,14 @@ struct LigatureSet {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (LigatureSet, 2);
|
ASSERT_SIZE (LigatureSet, 2);
|
||||||
|
|
||||||
struct LigatureSubstFormat1 {
|
struct LigatureSubstFormat1
|
||||||
|
{
|
||||||
friend struct LigatureSubst;
|
friend struct LigatureSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
hb_codepoint_t glyph_id = IN_CURGLYPH ();
|
||||||
|
|
||||||
bool first_is_mark = (property == HB_OT_LAYOUT_GLYPH_CLASS_MARK ||
|
bool first_is_mark = (property == HB_OT_LAYOUT_GLYPH_CLASS_MARK ||
|
||||||
|
@ -444,13 +450,14 @@ struct LigatureSubstFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (LigatureSubstFormat1, 6);
|
ASSERT_SIZE (LigatureSubstFormat1, 6);
|
||||||
|
|
||||||
struct LigatureSubst {
|
struct LigatureSubst
|
||||||
|
{
|
||||||
friend struct SubstLookupSubTable;
|
friend struct SubstLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -469,25 +476,27 @@ ASSERT_SIZE (LigatureSubst, 2);
|
||||||
|
|
||||||
static inline bool substitute_lookup (APPLY_ARG_DEF, unsigned int lookup_index);
|
static inline bool substitute_lookup (APPLY_ARG_DEF, unsigned int lookup_index);
|
||||||
|
|
||||||
struct ContextSubst : Context {
|
struct ContextSubst : Context
|
||||||
|
{
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
return Context::apply (APPLY_ARG, substitute_lookup);
|
return Context::apply (APPLY_ARG, substitute_lookup);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ContextSubst, 2);
|
ASSERT_SIZE (ContextSubst, 2);
|
||||||
|
|
||||||
struct ChainContextSubst : ChainContext {
|
struct ChainContextSubst : ChainContext
|
||||||
|
{
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
return ChainContext::apply (APPLY_ARG, substitute_lookup);
|
return ChainContext::apply (APPLY_ARG, substitute_lookup);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ChainContextSubst, 2);
|
ASSERT_SIZE (ChainContextSubst, 2);
|
||||||
|
|
||||||
|
|
||||||
struct ExtensionSubstFormat1 {
|
struct ExtensionSubstFormat1
|
||||||
|
{
|
||||||
friend struct ExtensionSubst;
|
friend struct ExtensionSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -507,21 +516,23 @@ struct ExtensionSubstFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ExtensionSubstFormat1, 8);
|
ASSERT_SIZE (ExtensionSubstFormat1, 8);
|
||||||
|
|
||||||
struct ExtensionSubst {
|
struct ExtensionSubst
|
||||||
|
{
|
||||||
friend struct SubstLookup;
|
friend struct SubstLookup;
|
||||||
friend struct SubstLookupSubTable;
|
friend struct SubstLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline unsigned int get_type (void) const {
|
inline unsigned int get_type (void) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->get_type ();
|
case 1: return u.format1->get_type ();
|
||||||
default:return 0;
|
default:return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -537,13 +548,13 @@ struct ExtensionSubst {
|
||||||
ASSERT_SIZE (ExtensionSubst, 2);
|
ASSERT_SIZE (ExtensionSubst, 2);
|
||||||
|
|
||||||
|
|
||||||
struct ReverseChainSingleSubstFormat1 {
|
struct ReverseChainSingleSubstFormat1
|
||||||
|
{
|
||||||
friend struct ReverseChainSingleSubst;
|
friend struct ReverseChainSingleSubst;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
if (HB_UNLIKELY (context_length != NO_CONTEXT))
|
if (HB_UNLIKELY (context_length != NO_CONTEXT))
|
||||||
return false; /* No chaining to this type */
|
return false; /* No chaining to this type */
|
||||||
|
|
||||||
|
@ -591,13 +602,14 @@ struct ReverseChainSingleSubstFormat1 {
|
||||||
};
|
};
|
||||||
ASSERT_SIZE (ReverseChainSingleSubstFormat1, 10);
|
ASSERT_SIZE (ReverseChainSingleSubstFormat1, 10);
|
||||||
|
|
||||||
struct ReverseChainSingleSubst {
|
struct ReverseChainSingleSubst
|
||||||
|
{
|
||||||
friend struct SubstLookupSubTable;
|
friend struct SubstLookupSubTable;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF) const {
|
inline bool apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
switch (u.format) {
|
switch (u.format) {
|
||||||
case 1: return u.format1->apply (APPLY_ARG);
|
case 1: return u.format1->apply (APPLY_ARG);
|
||||||
default:return false;
|
default:return false;
|
||||||
|
@ -629,12 +641,12 @@ enum {
|
||||||
GSUB_ReverseChainSingle = 8,
|
GSUB_ReverseChainSingle = 8,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct SubstLookupSubTable {
|
struct SubstLookupSubTable
|
||||||
|
{
|
||||||
friend struct SubstLookup;
|
friend struct SubstLookup;
|
||||||
|
|
||||||
inline bool apply (APPLY_ARG_DEF, unsigned int lookup_type) const {
|
inline bool apply (APPLY_ARG_DEF, unsigned int lookup_type) const
|
||||||
|
{
|
||||||
switch (lookup_type) {
|
switch (lookup_type) {
|
||||||
case GSUB_Single: return u.single->apply (APPLY_ARG);
|
case GSUB_Single: return u.single->apply (APPLY_ARG);
|
||||||
case GSUB_Multiple: return u.multiple->apply (APPLY_ARG);
|
case GSUB_Multiple: return u.multiple->apply (APPLY_ARG);
|
||||||
|
@ -664,18 +676,21 @@ struct SubstLookupSubTable {
|
||||||
ASSERT_SIZE (SubstLookupSubTable, 2);
|
ASSERT_SIZE (SubstLookupSubTable, 2);
|
||||||
|
|
||||||
|
|
||||||
struct SubstLookup : Lookup {
|
struct SubstLookup : Lookup
|
||||||
|
{
|
||||||
inline const SubstLookupSubTable& get_subtable (unsigned int i) const {
|
inline const SubstLookupSubTable& get_subtable (unsigned int i) const
|
||||||
|
{
|
||||||
return (const SubstLookupSubTable&) Lookup::get_subtable (i);
|
return (const SubstLookupSubTable&) Lookup::get_subtable (i);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Like get_type(), but looks through extension lookups.
|
/* Like get_type(), but looks through extension lookups.
|
||||||
* Never returns Extension */
|
* Never returns Extension */
|
||||||
inline unsigned int get_effective_type (void) const {
|
inline unsigned int get_effective_type (void) const
|
||||||
|
{
|
||||||
unsigned int type = get_type ();
|
unsigned int type = get_type ();
|
||||||
|
|
||||||
if (HB_UNLIKELY (type == GSUB_Extension)) {
|
if (HB_UNLIKELY (type == GSUB_Extension))
|
||||||
|
{
|
||||||
unsigned int count = get_subtable_count ();
|
unsigned int count = get_subtable_count ();
|
||||||
type = get_subtable(0).u.extension->get_type ();
|
type = get_subtable(0).u.extension->get_type ();
|
||||||
/* The spec says all subtables should have the same type.
|
/* The spec says all subtables should have the same type.
|
||||||
|
@ -688,18 +703,17 @@ struct SubstLookup : Lookup {
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool is_reverse (void) const {
|
inline bool is_reverse (void) const
|
||||||
switch (get_effective_type ()) {
|
{
|
||||||
case GSUB_ReverseChainSingle: return true;
|
return HB_UNLIKELY (get_effective_type () == GSUB_ReverseChainSingle);
|
||||||
default: return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply_subtables (hb_ot_layout_t *layout,
|
inline bool apply_subtables (hb_ot_layout_t *layout,
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
unsigned int context_length,
|
unsigned int context_length,
|
||||||
unsigned int nesting_level_left,
|
unsigned int nesting_level_left,
|
||||||
unsigned int property) const {
|
unsigned int property) const
|
||||||
|
{
|
||||||
unsigned int lookup_type = get_type ();
|
unsigned int lookup_type = get_type ();
|
||||||
unsigned int lookup_flag = get_flag ();
|
unsigned int lookup_flag = get_flag ();
|
||||||
|
|
||||||
|
@ -710,8 +724,8 @@ struct SubstLookup : Lookup {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool apply_once (hb_ot_layout_t *layout, hb_buffer_t *buffer) const {
|
inline bool apply_once (hb_ot_layout_t *layout, hb_buffer_t *buffer) const
|
||||||
|
{
|
||||||
unsigned int lookup_flag = get_flag ();
|
unsigned int lookup_flag = get_flag ();
|
||||||
|
|
||||||
unsigned int property;
|
unsigned int property;
|
||||||
|
@ -723,20 +737,20 @@ struct SubstLookup : Lookup {
|
||||||
|
|
||||||
bool apply_string (hb_ot_layout_t *layout,
|
bool apply_string (hb_ot_layout_t *layout,
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
hb_ot_layout_feature_mask_t mask) const {
|
hb_ot_layout_feature_mask_t mask) const
|
||||||
|
{
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
|
|
||||||
if (HB_UNLIKELY (!buffer->in_length))
|
if (HB_UNLIKELY (!buffer->in_length))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (HB_LIKELY (!is_reverse ())) {
|
if (HB_LIKELY (!is_reverse ()))
|
||||||
|
{
|
||||||
/* in/out forward substitution */
|
/* in/out forward substitution */
|
||||||
_hb_buffer_clear_output (buffer);
|
_hb_buffer_clear_output (buffer);
|
||||||
buffer->in_pos = 0;
|
buffer->in_pos = 0;
|
||||||
while (buffer->in_pos < buffer->in_length) {
|
while (buffer->in_pos < buffer->in_length)
|
||||||
|
{
|
||||||
if ((~IN_PROPERTIES (buffer->in_pos) & mask) &&
|
if ((~IN_PROPERTIES (buffer->in_pos) & mask) &&
|
||||||
apply_once (layout, buffer))
|
apply_once (layout, buffer))
|
||||||
ret = true;
|
ret = true;
|
||||||
|
@ -747,19 +761,22 @@ struct SubstLookup : Lookup {
|
||||||
if (ret)
|
if (ret)
|
||||||
_hb_buffer_swap (buffer);
|
_hb_buffer_swap (buffer);
|
||||||
|
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
/* in-place backward substitution */
|
/* in-place backward substitution */
|
||||||
buffer->in_pos = buffer->in_length - 1;
|
buffer->in_pos = buffer->in_length - 1;
|
||||||
do {
|
do
|
||||||
|
{
|
||||||
if ((~IN_PROPERTIES (buffer->in_pos) & mask) &&
|
if ((~IN_PROPERTIES (buffer->in_pos) & mask) &&
|
||||||
apply_once (layout, buffer))
|
apply_once (layout, buffer))
|
||||||
ret = true;
|
ret = true;
|
||||||
else
|
else
|
||||||
buffer->in_pos--;
|
buffer->in_pos--;
|
||||||
|
|
||||||
} while ((int) buffer->in_pos >= 0);
|
}
|
||||||
|
while ((int) buffer->in_pos >= 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -772,20 +789,23 @@ ASSERT_SIZE (SubstLookup, 6);
|
||||||
* GSUB
|
* GSUB
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct GSUB : GSUBGPOS {
|
struct GSUB : GSUBGPOS
|
||||||
|
{
|
||||||
static const hb_tag_t Tag = HB_TAG ('G','S','U','B');
|
static const hb_tag_t Tag = HB_TAG ('G','S','U','B');
|
||||||
|
|
||||||
STATIC_DEFINE_GET_FOR_DATA (GSUB);
|
STATIC_DEFINE_GET_FOR_DATA (GSUB);
|
||||||
/* XXX check version here? */
|
/* XXX check version here? */
|
||||||
|
|
||||||
inline const SubstLookup& get_lookup (unsigned int i) const {
|
inline const SubstLookup& get_lookup (unsigned int i) const
|
||||||
return (SubstLookup&)(((GSUBGPOS *)this)->get_lookup (i));
|
{
|
||||||
|
return (const SubstLookup&) GSUBGPOS::get_lookup (i);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool substitute_lookup (hb_ot_layout_t *layout,
|
inline bool substitute_lookup (hb_ot_layout_t *layout,
|
||||||
hb_buffer_t *buffer,
|
hb_buffer_t *buffer,
|
||||||
unsigned int lookup_index,
|
unsigned int lookup_index,
|
||||||
hb_ot_layout_feature_mask_t mask) const {
|
hb_ot_layout_feature_mask_t mask) const
|
||||||
|
{
|
||||||
return get_lookup (lookup_index).apply_string (layout, buffer, mask);
|
return get_lookup (lookup_index).apply_string (layout, buffer, mask);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -795,7 +815,8 @@ ASSERT_SIZE (GSUB, 10);
|
||||||
|
|
||||||
/* Out-of-class implementation for methods recursing */
|
/* Out-of-class implementation for methods recursing */
|
||||||
|
|
||||||
inline bool ExtensionSubstFormat1::apply (APPLY_ARG_DEF) const {
|
inline bool ExtensionSubstFormat1::apply (APPLY_ARG_DEF) const
|
||||||
|
{
|
||||||
unsigned int lookup_type = get_type ();
|
unsigned int lookup_type = get_type ();
|
||||||
|
|
||||||
if (HB_UNLIKELY (lookup_type == GSUB_Extension))
|
if (HB_UNLIKELY (lookup_type == GSUB_Extension))
|
||||||
|
@ -804,7 +825,8 @@ inline bool ExtensionSubstFormat1::apply (APPLY_ARG_DEF) const {
|
||||||
return ((SubstLookupSubTable&)*(((char *) this) + get_offset ())).apply (APPLY_ARG, lookup_type);
|
return ((SubstLookupSubTable&)*(((char *) this) + get_offset ())).apply (APPLY_ARG, lookup_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool substitute_lookup (APPLY_ARG_DEF, unsigned int lookup_index) {
|
static inline bool substitute_lookup (APPLY_ARG_DEF, unsigned int lookup_index)
|
||||||
|
{
|
||||||
const GSUB &gsub = *(layout->gsub);
|
const GSUB &gsub = *(layout->gsub);
|
||||||
const SubstLookup &l = gsub.get_lookup (lookup_index);
|
const SubstLookup &l = gsub.get_lookup (lookup_index);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue