[gsubgpos] Merge cache_enter and cache_leave entry points

Saves a pointer per subtable
This commit is contained in:
Behdad Esfahbod 2022-06-07 09:12:45 -06:00
parent d4c09e9a87
commit 5963cf4469
1 changed files with 47 additions and 55 deletions

View File

@ -815,30 +815,18 @@ struct hb_accelerate_subtables_context_t :
} }
template <typename T> template <typename T>
static inline auto cache_enter_ (const T *obj, OT::hb_ot_apply_context_t *c, hb_priority<1>) HB_RETURN (bool, obj->cache_enter (c) ) static inline auto cache_func_ (const T *obj, OT::hb_ot_apply_context_t *c, bool enter, hb_priority<1>) HB_RETURN (bool, obj->cache_func (c, enter) )
template <typename T> template <typename T>
static inline bool cache_enter_ (const T *obj, OT::hb_ot_apply_context_t *c, hb_priority<0>) { return false; } static inline bool cache_func_ (const T *obj, OT::hb_ot_apply_context_t *c, bool enter, hb_priority<0>) { return false; }
template <typename Type> template <typename Type>
static inline bool cache_enter_to (const void *obj, OT::hb_ot_apply_context_t *c) static inline bool cache_func_to (const void *obj, OT::hb_ot_apply_context_t *c, bool enter)
{ {
const Type *typed_obj = (const Type *) obj; const Type *typed_obj = (const Type *) obj;
return cache_enter_ (typed_obj, c, hb_prioritize); return cache_func_ (typed_obj, c, enter, hb_prioritize);
}
template <typename T>
static inline auto cache_leave_ (const T *obj, OT::hb_ot_apply_context_t *c, hb_priority<1>) HB_RETURN (void, obj->cache_leave (c) )
template <typename T>
static inline void cache_leave_ (const T *obj, OT::hb_ot_apply_context_t *c, hb_priority<0>) {}
template <typename Type>
static inline void cache_leave_to (const void *obj, OT::hb_ot_apply_context_t *c)
{
const Type *typed_obj = (const Type *) obj;
return cache_leave_ (typed_obj, c, hb_prioritize);
} }
typedef bool (*hb_apply_func_t) (const void *obj, OT::hb_ot_apply_context_t *c); typedef bool (*hb_apply_func_t) (const void *obj, OT::hb_ot_apply_context_t *c);
typedef bool (*hb_cache_enter_func_t) (const void *obj, OT::hb_ot_apply_context_t *c); typedef bool (*hb_cache_func_t) (const void *obj, OT::hb_ot_apply_context_t *c, bool enter);
typedef void (*hb_cache_leave_func_t) (const void *obj, OT::hb_ot_apply_context_t *c);
struct hb_applicable_t struct hb_applicable_t
{ {
@ -849,14 +837,12 @@ struct hb_accelerate_subtables_context_t :
void init (const T &obj_, void init (const T &obj_,
hb_apply_func_t apply_func_, hb_apply_func_t apply_func_,
hb_apply_func_t apply_cached_func_, hb_apply_func_t apply_cached_func_,
hb_cache_enter_func_t cache_enter_func_, hb_cache_func_t cache_func_)
hb_cache_leave_func_t cache_leave_func_)
{ {
obj = &obj_; obj = &obj_;
apply_func = apply_func_; apply_func = apply_func_;
apply_cached_func = apply_cached_func_; apply_cached_func = apply_cached_func_;
cache_enter_func = cache_enter_func_; cache_func = cache_func_;
cache_leave_func = cache_leave_func_;
digest.init (); digest.init ();
obj_.get_coverage ().collect_coverage (&digest); obj_.get_coverage ().collect_coverage (&digest);
} }
@ -872,19 +858,18 @@ struct hb_accelerate_subtables_context_t :
bool cache_enter (OT::hb_ot_apply_context_t *c) const bool cache_enter (OT::hb_ot_apply_context_t *c) const
{ {
return cache_enter_func (obj, c); return cache_func (obj, c, true);
} }
void cache_leave (OT::hb_ot_apply_context_t *c) const void cache_leave (OT::hb_ot_apply_context_t *c) const
{ {
cache_leave_func (obj, c); cache_func (obj, c, false);
} }
private: private:
const void *obj; const void *obj;
hb_apply_func_t apply_func; hb_apply_func_t apply_func;
hb_apply_func_t apply_cached_func; hb_apply_func_t apply_cached_func;
hb_cache_enter_func_t cache_enter_func; hb_cache_func_t cache_func;
hb_cache_leave_func_t cache_leave_func;
hb_set_digest_t digest; hb_set_digest_t digest;
}; };
@ -905,8 +890,7 @@ struct hb_accelerate_subtables_context_t :
entry.init (obj, entry.init (obj,
apply_to<T>, apply_to<T>,
apply_cached_to<T>, apply_cached_to<T>,
cache_enter_to<T>, cache_func_to<T>);
cache_leave_to<T>);
array.push (entry); array.push (entry);
@ -2235,7 +2219,9 @@ struct ContextFormat2
unsigned c = (this+classDef).cost () * ruleSet.len; unsigned c = (this+classDef).cost () * ruleSet.len;
return c >= 4 ? c : 0; return c >= 4 ? c : 0;
} }
bool cache_enter (hb_ot_apply_context_t *c) const bool cache_func (hb_ot_apply_context_t *c, bool enter) const
{
if (enter)
{ {
if (!HB_BUFFER_TRY_ALLOCATE_VAR (c->buffer, syllable)) if (!HB_BUFFER_TRY_ALLOCATE_VAR (c->buffer, syllable))
return false; return false;
@ -2246,10 +2232,12 @@ struct ContextFormat2
c->new_syllables = 255; c->new_syllables = 255;
return true; return true;
} }
void cache_leave (hb_ot_apply_context_t *c) const else
{ {
c->new_syllables = (unsigned) -1; c->new_syllables = (unsigned) -1;
HB_BUFFER_DEALLOCATE_VAR (c->buffer, syllable); HB_BUFFER_DEALLOCATE_VAR (c->buffer, syllable);
return true;
}
} }
bool apply (hb_ot_apply_context_t *c, bool cached = false) const bool apply (hb_ot_apply_context_t *c, bool cached = false) const
@ -3285,7 +3273,9 @@ struct ChainContextFormat2
unsigned c = (this+inputClassDef).cost () * ruleSet.len; unsigned c = (this+inputClassDef).cost () * ruleSet.len;
return c >= 4 ? c : 0; return c >= 4 ? c : 0;
} }
bool cache_enter (hb_ot_apply_context_t *c) const bool cache_func (hb_ot_apply_context_t *c, bool enter) const
{
if (enter)
{ {
if (!HB_BUFFER_TRY_ALLOCATE_VAR (c->buffer, syllable)) if (!HB_BUFFER_TRY_ALLOCATE_VAR (c->buffer, syllable))
return false; return false;
@ -3296,10 +3286,12 @@ struct ChainContextFormat2
c->new_syllables = 255; c->new_syllables = 255;
return true; return true;
} }
void cache_leave (hb_ot_apply_context_t *c) const else
{ {
c->new_syllables = (unsigned) -1; c->new_syllables = (unsigned) -1;
HB_BUFFER_DEALLOCATE_VAR (c->buffer, syllable); HB_BUFFER_DEALLOCATE_VAR (c->buffer, syllable);
return true;
}
} }
bool apply (hb_ot_apply_context_t *c, bool cached = false) const bool apply (hb_ot_apply_context_t *c, bool cached = false) const