[OTLayout] Port would_apply() and get_coverage() to process() templates

This commit is contained in:
Behdad Esfahbod 2012-11-22 14:38:10 -05:00
parent 44fc237b53
commit 2005fa5340
3 changed files with 156 additions and 293 deletions

View File

@ -212,9 +212,6 @@ struct ValueFormat : USHORT
struct AnchorFormat1 struct AnchorFormat1
{ {
friend struct Anchor;
private:
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id HB_UNUSED, inline void get_anchor (hb_font_t *font, 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
{ {
@ -237,9 +234,6 @@ struct AnchorFormat1
struct AnchorFormat2 struct AnchorFormat2
{ {
friend struct Anchor;
private:
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id, inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id,
hb_position_t *x, hb_position_t *y) const hb_position_t *x, hb_position_t *y) const
{ {
@ -270,9 +264,6 @@ struct AnchorFormat2
struct AnchorFormat3 struct AnchorFormat3
{ {
friend struct Anchor;
private:
inline void get_anchor (hb_font_t *font, hb_codepoint_t glyph_id HB_UNUSED, inline void get_anchor (hb_font_t *font, 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
{ {
@ -428,10 +419,6 @@ struct MarkArray : ArrayOf<MarkRecord> /* Array of MarkRecords--in Coverage orde
struct SinglePosFormat1 struct SinglePosFormat1
{ {
friend struct SinglePos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+coverage; return this+coverage;
@ -471,10 +458,6 @@ struct SinglePosFormat1
struct SinglePosFormat2 struct SinglePosFormat2
{ {
friend struct SinglePos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+coverage; return this+coverage;
@ -517,16 +500,13 @@ struct SinglePosFormat2
struct SinglePos struct SinglePos
{ {
friend struct PosLookupSubTable; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
private:
inline const Coverage &get_coverage (void) const
{ {
switch (u.format) { switch (u.format) {
case 1: return u.format1.get_coverage (); case 1: return c->process (u.format1);
case 2: return u.format2.get_coverage (); case 2: return c->process (u.format2);
default:return Null(Coverage); default:return c->default_return_value ();
} }
} }
@ -635,10 +615,6 @@ struct PairSet
struct PairPosFormat1 struct PairPosFormat1
{ {
friend struct PairPos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+coverage; return this+coverage;
@ -693,10 +669,6 @@ struct PairPosFormat1
struct PairPosFormat2 struct PairPosFormat2
{ {
friend struct PairPos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+coverage; return this+coverage;
@ -783,16 +755,13 @@ struct PairPosFormat2
struct PairPos struct PairPos
{ {
friend struct PosLookupSubTable; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
private:
inline const Coverage &get_coverage (void) const
{ {
switch (u.format) { switch (u.format) {
case 1: return u.format1.get_coverage (); case 1: return c->process (u.format1);
case 2: return u.format2.get_coverage (); case 2: return c->process (u.format2);
default:return Null(Coverage); default:return c->default_return_value ();
} }
} }
@ -849,10 +818,6 @@ struct EntryExitRecord
struct CursivePosFormat1 struct CursivePosFormat1
{ {
friend struct CursivePos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+coverage; return this+coverage;
@ -959,15 +924,12 @@ struct CursivePosFormat1
struct CursivePos struct CursivePos
{ {
friend struct PosLookupSubTable; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
private:
inline const Coverage &get_coverage (void) const
{ {
switch (u.format) { switch (u.format) {
case 1: return u.format1.get_coverage (); case 1: return c->process (u.format1);
default:return Null(Coverage); default:return c->default_return_value ();
} }
} }
@ -1004,10 +966,6 @@ typedef AnchorMatrix BaseArray; /* base-major--
struct MarkBasePosFormat1 struct MarkBasePosFormat1
{ {
friend struct MarkBasePos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+markCoverage; return this+markCoverage;
@ -1065,15 +1023,12 @@ struct MarkBasePosFormat1
struct MarkBasePos struct MarkBasePos
{ {
friend struct PosLookupSubTable; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
private:
inline const Coverage &get_coverage (void) const
{ {
switch (u.format) { switch (u.format) {
case 1: return u.format1.get_coverage (); case 1: return c->process (u.format1);
default:return Null(Coverage); default:return c->default_return_value ();
} }
} }
@ -1115,10 +1070,6 @@ typedef OffsetListOf<LigatureAttach> LigatureArray;
struct MarkLigPosFormat1 struct MarkLigPosFormat1
{ {
friend struct MarkLigPos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+markCoverage; return this+markCoverage;
@ -1193,15 +1144,12 @@ struct MarkLigPosFormat1
struct MarkLigPos struct MarkLigPos
{ {
friend struct PosLookupSubTable; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
private:
inline const Coverage &get_coverage (void) const
{ {
switch (u.format) { switch (u.format) {
case 1: return u.format1.get_coverage (); case 1: return c->process (u.format1);
default:return Null(Coverage); default:return c->default_return_value ();
} }
} }
@ -1238,10 +1186,6 @@ typedef AnchorMatrix Mark2Array; /* mark2-major--
struct MarkMarkPosFormat1 struct MarkMarkPosFormat1
{ {
friend struct MarkMarkPos;
private:
inline const Coverage &get_coverage (void) const inline const Coverage &get_coverage (void) const
{ {
return this+mark1Coverage; return this+mark1Coverage;
@ -1319,15 +1263,12 @@ struct MarkMarkPosFormat1
struct MarkMarkPos struct MarkMarkPos
{ {
friend struct PosLookupSubTable; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
private:
inline const Coverage &get_coverage (void) const
{ {
switch (u.format) { switch (u.format) {
case 1: return u.format1.get_coverage (); case 1: return c->process (u.format1);
default:return Null(Coverage); default:return c->default_return_value ();
} }
} }
@ -1361,9 +1302,6 @@ static inline bool position_lookup (hb_apply_context_t *c, unsigned int lookup_i
struct ContextPos : Context struct ContextPos : Context
{ {
friend struct PosLookupSubTable;
private:
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -1373,9 +1311,6 @@ struct ContextPos : Context
struct ChainContextPos : ChainContext struct ChainContextPos : ChainContext
{ {
friend struct PosLookupSubTable;
private:
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -1386,9 +1321,6 @@ struct ChainContextPos : ChainContext
struct ExtensionPos : Extension struct ExtensionPos : Extension
{ {
friend struct PosLookupSubTable;
private:
inline const struct PosLookupSubTable& get_subtable (void) const inline const struct PosLookupSubTable& get_subtable (void) const
{ {
unsigned int offset = get_offset (); unsigned int offset = get_offset ();
@ -1396,7 +1328,8 @@ struct ExtensionPos : Extension
return StructAtOffset<PosLookupSubTable> (this, offset); return StructAtOffset<PosLookupSubTable> (this, offset);
} }
inline const Coverage &get_coverage (void) const; template <typename context_t>
inline typename context_t::return_t process (context_t *c) const;
inline bool apply (hb_apply_context_t *c) const; inline bool apply (hb_apply_context_t *c) const;
@ -1426,19 +1359,20 @@ struct PosLookupSubTable
Extension = 9 Extension = 9
}; };
inline const Coverage &get_coverage (unsigned int lookup_type) const template <typename context_t>
inline typename context_t::return_t process (context_t *c, unsigned int lookup_type) const
{ {
switch (lookup_type) { switch (lookup_type) {
case Single: return u.single.get_coverage (); case Single: return u.single.process (c);
case Pair: return u.pair.get_coverage (); case Pair: return u.pair.process (c);
case Cursive: return u.cursive.get_coverage (); case Cursive: return u.cursive.process (c);
case MarkBase: return u.markBase.get_coverage (); case MarkBase: return u.markBase.process (c);
case MarkLig: return u.markLig.get_coverage (); case MarkLig: return u.markLig.process (c);
case MarkMark: return u.markMark.get_coverage (); case MarkMark: return u.markMark.process (c);
case Context: return u.context.get_coverage (); case Context: return u.context.process (c);
case ChainContext: return u.chainContext.get_coverage (); case ChainContext: return u.chainContext.process (c);
case Extension: return u.extension.get_coverage (); case Extension: return u.extension.process (c);
default: return Null(Coverage); default: return c->default_return_value ();
} }
} }
@ -1502,16 +1436,30 @@ struct PosLookup : Lookup
inline const PosLookupSubTable& get_subtable (unsigned int i) const inline const PosLookupSubTable& get_subtable (unsigned int i) const
{ return this+CastR<OffsetArrayOf<PosLookupSubTable> > (subTable)[i]; } { return this+CastR<OffsetArrayOf<PosLookupSubTable> > (subTable)[i]; }
template <typename context_t>
inline typename context_t::return_t process (context_t *c) const
{
unsigned int lookup_type = get_type ();
unsigned int count = get_subtable_count ();
for (unsigned int i = 0; i < count; i++) {
typename context_t::return_t r = get_subtable (i).process (c, lookup_type);
if (c->stop_sublookup_iteration (r))
return r;
}
return c->default_return_value ();
}
template <typename set_t> template <typename set_t>
inline void add_coverage (set_t *glyphs) const inline void add_coverage (set_t *glyphs) const
{ {
hb_get_coverage_context_t c;
const Coverage *last = NULL; const Coverage *last = NULL;
unsigned int count = get_subtable_count (); unsigned int count = get_subtable_count ();
for (unsigned int i = 0; i < count; i++) { for (unsigned int i = 0; i < count; i++) {
const Coverage *c = &get_subtable (i).get_coverage (get_type ()); const Coverage *coverage = &get_subtable (i).process (&c, get_type ());
if (c != last) { if (coverage != last) {
c->add_coverage (glyphs); coverage->add_coverage (glyphs);
last = c; last = coverage;
} }
} }
} }
@ -1673,9 +1621,10 @@ GPOS::position_finish (hb_font_t *font HB_UNUSED, hb_buffer_t *buffer, hb_bool_t
/* Out-of-class implementation for methods recursing */ /* Out-of-class implementation for methods recursing */
inline const Coverage & ExtensionPos::get_coverage (void) const template <typename context_t>
inline typename context_t::return_t ExtensionPos::process (context_t *c) const
{ {
return get_subtable ().get_coverage (get_type ()); return get_subtable ().process (c, get_type ());
} }
inline bool ExtensionPos::apply (hb_apply_context_t *c) const inline bool ExtensionPos::apply (hb_apply_context_t *c) const

View File

@ -63,6 +63,12 @@ struct SingleSubstFormat1
return this+coverage; return this+coverage;
} }
inline bool would_apply (hb_would_apply_context_t *c) const
{
TRACE_WOULD_APPLY ();
return TRACE_RETURN (c->len == 1 && (this+coverage) (c->glyphs[0]) != NOT_COVERED);
}
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -132,6 +138,12 @@ struct SingleSubstFormat2
return this+coverage; return this+coverage;
} }
inline bool would_apply (hb_would_apply_context_t *c) const
{
TRACE_WOULD_APPLY ();
return TRACE_RETURN (c->len == 1 && (this+coverage) (c->glyphs[0]) != NOT_COVERED);
}
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -184,16 +196,7 @@ struct SingleSubst
switch (u.format) { switch (u.format) {
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
case 2: return c->process (u.format2); case 2: return c->process (u.format2);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
case 2: return u.format2.get_coverage ();
default:return Null(Coverage);
} }
} }
@ -333,6 +336,12 @@ struct MultipleSubstFormat1
return this+coverage; return this+coverage;
} }
inline bool would_apply (hb_would_apply_context_t *c) const
{
TRACE_WOULD_APPLY ();
return TRACE_RETURN (c->len == 1 && (this+coverage) (c->glyphs[0]) != NOT_COVERED);
}
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -385,15 +394,7 @@ struct MultipleSubst
{ {
switch (u.format) { switch (u.format) {
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
default:return Null(Coverage);
} }
} }
@ -475,6 +476,12 @@ struct AlternateSubstFormat1
return this+coverage; return this+coverage;
} }
inline bool would_apply (hb_would_apply_context_t *c) const
{
TRACE_WOULD_APPLY ();
return TRACE_RETURN (c->len == 1 && (this+coverage) (c->glyphs[0]) != NOT_COVERED);
}
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -545,15 +552,7 @@ struct AlternateSubst
{ {
switch (u.format) { switch (u.format) {
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
default:return Null(Coverage);
} }
} }
@ -621,14 +620,15 @@ struct Ligature
inline bool would_apply (hb_would_apply_context_t *c) const inline bool would_apply (hb_would_apply_context_t *c) const
{ {
TRACE_WOULD_APPLY ();
if (c->len != component.len) if (c->len != component.len)
return false; return TRACE_RETURN (false);
for (unsigned int i = 1; i < c->len; i++) for (unsigned int i = 1; i < c->len; i++)
if (likely (c->glyphs[i] != component[i])) if (likely (c->glyphs[i] != component[i]))
return false; return TRACE_RETURN (false);
return true; return TRACE_RETURN (true);
} }
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
@ -712,14 +712,15 @@ struct LigatureSet
inline bool would_apply (hb_would_apply_context_t *c) const inline bool would_apply (hb_would_apply_context_t *c) const
{ {
TRACE_WOULD_APPLY ();
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.would_apply (c)) if (lig.would_apply (c))
return true; return TRACE_RETURN (true);
} }
return false; return TRACE_RETURN (false);
} }
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
@ -795,7 +796,12 @@ struct LigatureSubstFormat1
inline bool would_apply (hb_would_apply_context_t *c) const inline bool would_apply (hb_would_apply_context_t *c) const
{ {
return (this+ligatureSet[(this+coverage) (c->glyphs[0])]).would_apply (c); TRACE_WOULD_APPLY ();
unsigned int index = (this+coverage) (c->glyphs[0]);
if (likely (index == NOT_COVERED)) return TRACE_RETURN (false);
const LigatureSet &lig_set = this+ligatureSet[index];
return TRACE_RETURN (lig_set.would_apply (c));
} }
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
@ -856,23 +862,7 @@ struct LigatureSubst
{ {
switch (u.format) { switch (u.format) {
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
default:return Null(Coverage);
}
}
inline bool would_apply (hb_would_apply_context_t *c) const
{
switch (u.format) {
case 1: return u.format1.would_apply (c);
default:return false;
} }
} }
@ -966,10 +956,6 @@ struct ExtensionSubst : Extension
template <typename context_t> template <typename context_t>
inline typename context_t::return_t process (context_t *c) const; inline typename context_t::return_t process (context_t *c) const;
inline const Coverage &get_coverage (void) const;
inline bool would_apply (hb_would_apply_context_t *c) const;
inline bool apply (hb_apply_context_t *c) const; inline bool apply (hb_apply_context_t *c) const;
inline bool sanitize (hb_sanitize_context_t *c); inline bool sanitize (hb_sanitize_context_t *c);
@ -1032,6 +1018,12 @@ struct ReverseChainSingleSubstFormat1
return this+coverage; return this+coverage;
} }
inline bool would_apply (hb_would_apply_context_t *c) const
{
TRACE_WOULD_APPLY ();
return TRACE_RETURN (c->len == 1 && (this+coverage) (c->glyphs[0]) != NOT_COVERED);
}
inline bool apply (hb_apply_context_t *c) const inline bool apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();
@ -1098,15 +1090,7 @@ struct ReverseChainSingleSubst
{ {
switch (u.format) { switch (u.format) {
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
default:return Null(Coverage);
} }
} }
@ -1168,48 +1152,7 @@ struct SubstLookupSubTable
case ChainContext: return u.chainContext.process (c); case ChainContext: return u.chainContext.process (c);
case Extension: return u.extension.process (c); case Extension: return u.extension.process (c);
case ReverseChainSingle: return u.reverseChainContextSingle.process (c); case ReverseChainSingle: return u.reverseChainContextSingle.process (c);
default: return c->default_return_value; default: return c->default_return_value ();
}
}
inline const Coverage &get_coverage (unsigned int lookup_type) const
{
switch (lookup_type) {
case Single: return u.single.get_coverage ();
case Multiple: return u.multiple.get_coverage ();
case Alternate: return u.alternate.get_coverage ();
case Ligature: return u.ligature.get_coverage ();
case Context: return u.context.get_coverage ();
case ChainContext: return u.chainContext.get_coverage ();
case Extension: return u.extension.get_coverage ();
case ReverseChainSingle: return u.reverseChainContextSingle.get_coverage ();
default: return Null(Coverage);
}
}
inline bool would_apply (hb_would_apply_context_t *c,
unsigned int lookup_type) const
{
TRACE_WOULD_APPLY ();
if (get_coverage (lookup_type).get_coverage (c->glyphs[0]) == NOT_COVERED) return false;
if (c->len == 1) {
switch (lookup_type) {
case Single:
case Multiple:
case Alternate:
case ReverseChainSingle:
return true;
}
}
/* Only need to look further for lookups that support substitutions
* of input longer than 1. */
switch (lookup_type) {
case Ligature: return u.ligature.would_apply (c);
case Context: return u.context.would_apply (c);
case ChainContext: return u.chainContext.would_apply (c);
case Extension: return u.extension.would_apply (c);
default: return false;
} }
} }
@ -1286,36 +1229,35 @@ struct SubstLookup : Lookup
{ {
unsigned int lookup_type = get_type (); unsigned int lookup_type = get_type ();
unsigned int count = get_subtable_count (); unsigned int count = get_subtable_count ();
for (unsigned int i = 0; i < count; i++) for (unsigned int i = 0; i < count; i++) {
if (c->stop_sublookup_iteration (get_subtable (i).process (c, lookup_type))) typename context_t::return_t r = get_subtable (i).process (c, lookup_type);
return c->default_return_value; if (c->stop_sublookup_iteration (r))
return c->default_return_value; return r;
}
return c->default_return_value ();
} }
template <typename set_t> template <typename set_t>
inline void add_coverage (set_t *glyphs) const inline void add_coverage (set_t *glyphs) const
{ {
hb_get_coverage_context_t c;
const Coverage *last = NULL; const Coverage *last = NULL;
unsigned int count = get_subtable_count (); unsigned int count = get_subtable_count ();
for (unsigned int i = 0; i < count; i++) { for (unsigned int i = 0; i < count; i++) {
const Coverage *c = &get_subtable (i).get_coverage (get_type ()); const Coverage *coverage = &get_subtable (i).process (&c, get_type ());
if (c != last) { if (coverage != last) {
c->add_coverage (glyphs); coverage->add_coverage (glyphs);
last = c; last = coverage;
} }
} }
} }
inline bool would_apply (hb_would_apply_context_t *c, const hb_set_digest_t *digest) const inline bool would_apply (hb_would_apply_context_t *c, const hb_set_digest_t *digest) const
{ {
if (unlikely (!c->len)) return false; TRACE_WOULD_APPLY ();
if (!digest->may_have (c->glyphs[0])) return false; if (unlikely (!c->len)) return TRACE_RETURN (false);
unsigned int lookup_type = get_type (); if (!digest->may_have (c->glyphs[0])) return TRACE_RETURN (false);
unsigned int count = get_subtable_count (); return TRACE_RETURN (process (c));
for (unsigned int i = 0; i < count; i++)
if (get_subtable (i).would_apply (c, lookup_type))
return true;
return false;
} }
inline bool apply_once (hb_apply_context_t *c) const inline bool apply_once (hb_apply_context_t *c) const
@ -1491,7 +1433,7 @@ struct GSUB : GSUBGPOS
hb_set_t *glyphs, hb_set_t *glyphs,
unsigned int lookup_index) const unsigned int lookup_index) const
{ {
OT::hb_closure_context_t c (face, glyphs, closure_recurse_func); hb_closure_context_t c (face, glyphs, closure_recurse_func);
return get_lookup (lookup_index).process (&c); return get_lookup (lookup_index).process (&c);
} }
@ -1541,16 +1483,6 @@ inline typename context_t::return_t ExtensionSubst::process (context_t *c) const
return get_subtable ().process (c, get_type ()); return get_subtable ().process (c, get_type ());
} }
inline const Coverage & ExtensionSubst::get_coverage (void) const
{
return get_subtable ().get_coverage (get_type ());
}
inline bool ExtensionSubst::would_apply (hb_would_apply_context_t *c) const
{
return get_subtable ().would_apply (c, get_type ());
}
inline bool ExtensionSubst::apply (hb_apply_context_t *c) const inline bool ExtensionSubst::apply (hb_apply_context_t *c) const
{ {
TRACE_APPLY (); TRACE_APPLY ();

View File

@ -53,17 +53,17 @@ struct hb_closure_context_t
typedef return_t (*recurse_func_t) (hb_closure_context_t *c, unsigned int lookup_index); typedef return_t (*recurse_func_t) (hb_closure_context_t *c, unsigned int lookup_index);
template <typename T> template <typename T>
inline return_t process (const T &obj) { obj.closure (this); return void_t (); } inline return_t process (const T &obj) { obj.closure (this); return void_t (); }
static const return_t default_return_value; static const return_t default_return_value (void) { return return_t (); }
bool stop_sublookup_iteration (const return_t r) const { return false; } bool stop_sublookup_iteration (const return_t r) const { return false; }
return_t recurse (unsigned int lookup_index) return_t recurse (unsigned int lookup_index)
{ {
if (unlikely (nesting_level_left == 0)) if (unlikely (nesting_level_left == 0))
return default_return_value; return default_return_value ();
nesting_level_left--; nesting_level_left--;
recurse_func (this, lookup_index); recurse_func (this, lookup_index);
nesting_level_left++; nesting_level_left++;
return default_return_value; return default_return_value ();
} }
hb_face_t *face; hb_face_t *face;
@ -111,6 +111,13 @@ struct hb_would_apply_context_t
len (len_), len (len_),
zero_context (zero_context_), zero_context (zero_context_),
debug_depth (0) {}; debug_depth (0) {};
typedef bool return_t;
template <typename T>
inline return_t process (const T &obj) { return obj.would_apply (this); }
static return_t default_return_value (void) { return false; }
bool stop_sublookup_iteration (const return_t r) const { return r; }
return_t recurse (unsigned int lookup_index) { return true; }
}; };
@ -148,19 +155,34 @@ struct hb_collect_glyphs_context_t
typedef void_t return_t; typedef void_t return_t;
template <typename T> template <typename T>
inline return_t process (const T &obj) { obj.collect_glyphs (this); return void_t (); } inline return_t process (const T &obj) { obj.collect_glyphs (this); return void_t (); }
static const return_t default_return_value; static const return_t default_return_value (void) { return return_t (); }
bool stop_iteration (const return_t r) const { return false; } bool stop_iteration (const return_t r) const { return false; }
return_t recurse (unsigned int lookup_index) return_t recurse (unsigned int lookup_index)
{ {
#if 0 #if 0
/* XXX */ /* XXX */
#endif #endif
return default_return_value; return default_return_value ();
} }
}; };
struct hb_get_coverage_context_t
{
hb_get_coverage_context_t (void) {}
typedef const Coverage &return_t;
template <typename T>
inline return_t process (const T &obj) { return obj.get_coverage (); }
static return_t default_return_value (void) { return Null(Coverage); }
bool stop_sublookup_iteration (const return_t r) const { return true; /* Unused */ }
return_t recurse (unsigned int lookup_index)
{ return default_return_value (); }
};
#ifndef HB_DEBUG_APPLY #ifndef HB_DEBUG_APPLY
#define HB_DEBUG_APPLY (HB_DEBUG+0) #define HB_DEBUG_APPLY (HB_DEBUG+0)
#endif #endif
@ -1162,27 +1184,7 @@ struct Context
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
case 2: return c->process (u.format2); case 2: return c->process (u.format2);
case 3: return c->process (u.format3); case 3: return c->process (u.format3);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
case 2: return u.format2.get_coverage ();
case 3: return u.format3.get_coverage ();
default:return Null(Coverage);
}
}
inline bool would_apply (hb_would_apply_context_t *c) const
{
switch (u.format) {
case 1: return u.format1.would_apply (c);
case 2: return u.format2.would_apply (c);
case 3: return u.format3.would_apply (c);
default:return false;
} }
} }
@ -1695,27 +1697,7 @@ struct ChainContext
case 1: return c->process (u.format1); case 1: return c->process (u.format1);
case 2: return c->process (u.format2); case 2: return c->process (u.format2);
case 3: return c->process (u.format3); case 3: return c->process (u.format3);
default:return c->default_return_value; default:return c->default_return_value ();
}
}
inline const Coverage &get_coverage (void) const
{
switch (u.format) {
case 1: return u.format1.get_coverage ();
case 2: return u.format2.get_coverage ();
case 3: return u.format3.get_coverage ();
default:return Null(Coverage);
}
}
inline bool would_apply (hb_would_apply_context_t *c) const
{
switch (u.format) {
case 1: return u.format1.would_apply (c);
case 2: return u.format2.would_apply (c);
case 3: return u.format3.would_apply (c);
default:return false;
} }
} }