summaryrefslogtreecommitdiff
path: root/src/hb-ot-kern-table.hh
diff options
context:
space:
mode:
authorBehdad Esfahbod <behdad@behdad.org>2017-11-01 17:54:56 -0600
committerBehdad Esfahbod <behdad@behdad.org>2017-11-01 17:54:56 -0600
commitac3d937c6cb0e2c7e019aa391b02da25aa6970de (patch)
tree87f7dacc602f267cd26719dff0dec5fbecad9138 /src/hb-ot-kern-table.hh
parent2a16f647ae4c5115a356ba82245c77e0d01fcebf (diff)
[kern] Implement some more
Diffstat (limited to 'src/hb-ot-kern-table.hh')
-rw-r--r--src/hb-ot-kern-table.hh98
1 files changed, 77 insertions, 21 deletions
diff --git a/src/hb-ot-kern-table.hh b/src/hb-ot-kern-table.hh
index b3de99ce..37658ab2 100644
--- a/src/hb-ot-kern-table.hh
+++ b/src/hb-ot-kern-table.hh
@@ -39,29 +39,89 @@ namespace OT {
#define HB_OT_TAG_kern HB_TAG('k','e','r','n')
+struct KernSubTableFormat0
+{
+ inline unsigned int get_size (void) const
+ {
+ /* XXX */
+ return 0;
+ }
+
+ inline bool sanitize (hb_sanitize_context_t *c) const
+ {
+ TRACE_SANITIZE (this);
+
+ /* XXX */
+
+ return_trace (true);
+ }
+};
+
+struct KernSubTableFormat2
+{
+ inline unsigned int get_size (void) const
+ {
+ /* XXX */
+ return 0;
+ }
+
+ inline bool sanitize (hb_sanitize_context_t *c) const
+ {
+ TRACE_SANITIZE (this);
+
+ /* XXX */
+
+ return_trace (true);
+ }
+};
+
+struct KernSubTable
+{
+ inline unsigned int get_size (unsigned int format) const
+ {
+ switch (format) {
+ case 0: return u.format0.get_size ();
+ case 2: return u.format2.get_size ();
+ default:return 0;
+ }
+ }
+
+ inline bool sanitize (hb_sanitize_context_t *c, unsigned int format) const
+ {
+ TRACE_SANITIZE (this);
+ switch (format) {
+ case 0: return_trace (u.format0.sanitize (c));
+ case 2: return_trace (u.format2.sanitize (c));
+ default:return_trace (true);
+ }
+ }
+
+ protected:
+ union {
+ KernSubTableFormat0 format0;
+ KernSubTableFormat2 format2;
+ } u;
+ public:
+ DEFINE_SIZE_MIN (0);
+};
+
template <typename T>
struct KernSubTableWrapper
{
/* https://en.wikipedia.org/wiki/Curiously_recurring_template_pattern */
inline const T* thiz (void) const { return static_cast<const T *> (this); }
- inline T* thiz (void) { return static_cast<T *> (this); }
inline unsigned int get_size (void) const { return thiz()->length; }
- inline const void *get_data (void) const { return thiz()->data; }
- inline unsigned int get_format (void) const { return thiz()->format; }
inline bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
- if (unlikely (!c->check_struct (thiz()) ||
- get_size () < thiz()->min_size ||
- !c->check_array (thiz(), 1, get_size ())))
- return_trace (false);
-
- /* XXX */
-
- return_trace (true);
+ return_trace (c->check_struct (thiz()) &&
+ thiz()->length >= thiz()->min_size &&
+ c->check_array (thiz(), 1, thiz()->length) &&
+ thiz()->subtable.sanitize (c, thiz()->format) &&
+ thiz()->subtable.get_size (thiz()-> format) <= thiz()->length - thiz()->min_size);
}
};
@@ -70,10 +130,6 @@ struct KernTable
{
/* https://en.wikipedia.org/wiki/Curiously_recurring_template_pattern */
inline const T* thiz (void) const { return static_cast<const T *> (this); }
- inline T* thiz (void) { return static_cast<T *> (this); }
-
- inline unsigned int get_num_tables (void) const { return thiz()->nTables; }
- inline const void *get_data (void) const { return thiz()->data; }
inline bool sanitize (hb_sanitize_context_t *c) const
{
@@ -82,8 +138,8 @@ struct KernTable
thiz()->version != T::VERSION))
return_trace (false);
- const typename T::SubTableWrapper *st = CastP<typename T::SubTableWrapper> (get_data ());
- unsigned int count = get_num_tables ();
+ const typename T::SubTableWrapper *st = CastP<typename T::SubTableWrapper> (thiz()->data);
+ unsigned int count = thiz()->nTables;
for (unsigned int i = 0; i < count; i++)
{
if (unlikely (!st->sanitize (c)))
@@ -110,9 +166,9 @@ struct KernOT : KernTable<KernOT>
USHORT length; /* Length of the subtable (including this header). */
BYTE format; /* Subtable format. */
BYTE coverage; /* Coverage bits. */
- BYTE data[VAR]; /* Subtable data. */
+ KernSubTable subtable; /* Subtable data. */
public:
- DEFINE_SIZE_ARRAY (6, data);
+ DEFINE_SIZE_MIN (6);
};
protected:
@@ -139,9 +195,9 @@ struct KernAAT : KernTable<KernAAT>
BYTE format; /* Subtable format. */
USHORT tupleIndex; /* The tuple index (used for variations fonts).
* This value specifies which tuple this subtable covers. */
- BYTE data[VAR]; /* Subtable data. */
+ KernSubTable subtable; /* Subtable data. */
public:
- DEFINE_SIZE_ARRAY (8, data);
+ DEFINE_SIZE_MIN (8);
};
protected: