From 422c0c36c80145a2d993f80d5c7d3265e3d8357a Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Fri, 20 Jan 2017 19:14:54 -0800 Subject: [PATCH] [var] Flesh out a bit --- src/hb-ot-var-fvar-table.hh | 72 +++++++++++++++++++++++++++++-------- src/hb-ot-var.h | 10 +++++- 2 files changed, 67 insertions(+), 15 deletions(-) diff --git a/src/hb-ot-var-fvar-table.hh b/src/hb-ot-var-fvar-table.hh index 84617411c..39015b331 100644 --- a/src/hb-ot-var-fvar-table.hh +++ b/src/hb-ot-var-fvar-table.hh @@ -63,7 +63,7 @@ struct AxisRecord return_trace (c->check_struct (this)); } - protected: + public: Tag axisTag; /* Tag identifying the design variation for the axis. */ Fixed minValue; /* The minimum coordinate value for the axis. */ Fixed defaultValue; /* The default coordinate value for the axis. */ @@ -89,23 +89,67 @@ struct fvar { TRACE_SANITIZE (this); return_trace (version.sanitize (c) && - likely (version.major == 1) /*&& - mathConstants.sanitize (c, this) && - mathGlyphInfo.sanitize (c, this) && - mathVariants.sanitize (c, this)*/); + likely (version.major == 1) && + c->check_struct (this) && + instanceSize >= axisCount * 4 + 4 && + axisSize <= 1024 && /* Arbitrary, just to simplify overflow checks. */ + instanceSize <= 1024 && /* Arbitrary, just to simplify overflow checks. */ + c->check_range (this, things) && + c->check_range (&StructAtOffset (this, things), + axisCount * axisSize + instanceCount * instanceSize)); } -#if 0 - inline hb_position_t get_constant (hb_ot_math_constant_t constant, - hb_font_t *font) const - { return (this+mathConstants).get_value (constant, font); } + inline const AxisRecord * get_axes (void) const + { return &StructAtOffset (this, things); } - inline const MathGlyphInfo &get_math_glyph_info (void) const - { return this+mathGlyphInfo; } + inline const InstanceRecord * get_instances (void) const + { return &StructAtOffset (get_axes () + axisCount, 0); } - inline const MathVariants &get_math_variants (void) const - { return this+mathVariants; } -#endif + inline unsigned int get_axis_count (void) const + { return axisCount; } + + inline bool find_axis (hb_tag_t tag, unsigned int *index, hb_ot_var_axis_t *info) const + { + const AxisRecord *axes = get_axes (); + unsigned int count = get_axis_count (); + for (unsigned int i = 0; i < count; i++) + if (axes[i].axisTag == tag) + { + if (index) + *index = i; + if (info) + { + const AxisRecord &axis = axes[i]; + info->tag = axis.axisTag; + info->name_id = axis.axisNameID; + info->default_value = axis.defaultValue / 65536.; + /* Ensure order, to simplify client math. */ + info->min_value = MIN (info->default_value, axis.minValue / 65536.); + info->max_value = MAX (info->default_value, axis.maxValue / 65536.); + } + return true; + } + if (index) + *index = HB_OT_VAR_NO_AXIS_INDEX; + return false; + } + + inline int normalize_axis_value (hb_tag_t tag, float v, unsigned int *axis_index) const + { + hb_ot_var_axis_t axis; + if (!find_axis (tag, axis_index, &axis)) + return 0; + + v = MAX (MIN (v, axis.max_value), axis.min_value); /* Clamp. */ + + if (v == axis.default_value) + return 0; + else if (v < axis.default_value) + v = (v - axis.default_value) / (axis.default_value - axis.min_value); + else + v = (v - axis.default_value) / (axis.max_value - axis.default_value); + return (int) (v * 16384. + (v >= 0. ? .5 : -.5)); + } protected: FixedVersion<>version; /* Version of the fvar table diff --git a/src/hb-ot-var.h b/src/hb-ot-var.h index 9d73bed49..fd7a5aaf0 100644 --- a/src/hb-ot-var.h +++ b/src/hb-ot-var.h @@ -53,15 +53,23 @@ typedef struct hb_ot_var_axis_t { hb_tag_t tag; unsigned int name_id; float min_value; - float def_value; + float default_value; float max_value; } hb_ot_var_axis_t; HB_EXTERN hb_bool_t hb_ot_var_has_data (hb_face_t *face); +#define HB_OT_VAR_NO_AXIS_INDEX 0xFFFFFFFFu + #if 0 +HB_EXTERN hb_bool_t +hb_ot_var_find_axis (hb_face_t *face, + hb_tag_t axis_tag, + unsigned int *axis_index, + hb_ot_var_axis_t *axis_info); + HB_EXTERN unsigned int Xhb_ot_var_get_axes (hb_face_t *face, unsigned int start_offset,