提交 602fbfe3 编写于 作者: B Behdad Esfahbod

[sanitize] Fix sanitizing sublookup array

上级 c78e4784
...@@ -760,6 +760,14 @@ struct Lookup ...@@ -760,6 +760,14 @@ struct Lookup
return_trace (true); return_trace (true);
} }
/* Older compilers need this to NOT be locally defined in a function. */
template <typename TSubTable>
struct SubTableSanitizeWrapper : TSubTable
{
inline bool sanitize (hb_sanitize_context_t *c, unsigned int lookup_type) const
{ return this->dispatch (c, lookup_type); }
};
template <typename TSubTable> template <typename TSubTable>
inline bool sanitize (hb_sanitize_context_t *c) const inline bool sanitize (hb_sanitize_context_t *c) const
{ {
...@@ -771,7 +779,9 @@ struct Lookup ...@@ -771,7 +779,9 @@ struct Lookup
if (!markFilteringSet.sanitize (c)) return_trace (false); if (!markFilteringSet.sanitize (c)) return_trace (false);
} }
if (unlikely (!dispatch<TSubTable> (c))) return_trace (false); if (unlikely (!CastR<OffsetArrayOf<SubTableSanitizeWrapper<TSubTable> > > (subTable)
.sanitize (c, this, get_type ())))
return_trace (false);
if (unlikely (get_type () == TSubTable::Extension)) if (unlikely (get_type () == TSubTable::Extension))
{ {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册