63 lines
1.5 KiB
C++
63 lines
1.5 KiB
C++
#ifndef OT_LAYOUT_GSUB_MULTIPLESUBST_HH
|
|
#define OT_LAYOUT_GSUB_MULTIPLESUBST_HH
|
|
|
|
#include "Common.hh"
|
|
#include "MultipleSubstFormat1.hh"
|
|
|
|
namespace OT {
|
|
namespace Layout {
|
|
namespace GSUB_impl {
|
|
|
|
struct MultipleSubst
|
|
{
|
|
protected:
|
|
union {
|
|
HBUINT16 format; /* Format identifier */
|
|
MultipleSubstFormat1_2<SmallTypes> format1;
|
|
#ifndef HB_NO_BEYOND_64K
|
|
MultipleSubstFormat1_2<MediumTypes> format2;
|
|
#endif
|
|
} u;
|
|
|
|
public:
|
|
|
|
template <typename context_t, typename ...Ts>
|
|
typename context_t::return_t dispatch (context_t *c, Ts&&... ds) const
|
|
{
|
|
TRACE_DISPATCH (this, u.format);
|
|
if (unlikely (!c->may_dispatch (this, &u.format))) return_trace (c->no_dispatch_return_value ());
|
|
switch (u.format) {
|
|
case 1: return_trace (c->dispatch (u.format1, std::forward<Ts> (ds)...));
|
|
#ifndef HB_NO_BEYOND_64K
|
|
case 2: return_trace (c->dispatch (u.format2, std::forward<Ts> (ds)...));
|
|
#endif
|
|
default:return_trace (c->default_return_value ());
|
|
}
|
|
}
|
|
|
|
template<typename Iterator,
|
|
hb_requires (hb_is_sorted_iterator (Iterator))>
|
|
bool serialize (hb_serialize_context_t *c,
|
|
Iterator it)
|
|
{
|
|
TRACE_SERIALIZE (this);
|
|
if (unlikely (!c->extend_min (u.format))) return_trace (false);
|
|
unsigned int format = 1;
|
|
u.format = format;
|
|
switch (u.format) {
|
|
case 1: return_trace (u.format1.serialize (c, it));
|
|
default:return_trace (false);
|
|
}
|
|
}
|
|
|
|
/* TODO subset() should choose format. */
|
|
|
|
};
|
|
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
#endif /* OT_LAYOUT_GSUB_MULTIPLESUBST_HH */
|