[>64k:layout] Prepare GDEF for templatizing
https://github.com/be-fonts/boring-expansion-spec/issues/36
This commit is contained in:
parent
c0d60bd496
commit
1de5591cf7
|
@ -522,42 +522,47 @@ struct GDEF
|
||||||
ComponentGlyph = 4
|
ComponentGlyph = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
bool has_data () const { return version.to_int (); }
|
|
||||||
bool has_glyph_classes () const { return glyphClassDef != 0; }
|
bool has_glyph_classes () const { return glyphClassDef != 0; }
|
||||||
unsigned int get_glyph_class (hb_codepoint_t glyph) const
|
const ClassDef &get_glyph_class_def () const { return this+glyphClassDef; }
|
||||||
{ return (this+glyphClassDef).get_class (glyph); }
|
bool has_attach_list () const { return attachList != 0; }
|
||||||
void get_glyphs_in_class (unsigned int klass, hb_set_t *glyphs) const
|
const AttachList &get_attach_list () const { return this+attachList; }
|
||||||
{ (this+glyphClassDef).collect_class (glyphs, klass); }
|
bool has_lig_carets () const { return ligCaretList != 0; }
|
||||||
|
const LigCaretList &get_lig_caret_list () const { return this+ligCaretList; }
|
||||||
bool has_mark_attachment_types () const { return markAttachClassDef != 0; }
|
bool has_mark_attachment_types () const { return markAttachClassDef != 0; }
|
||||||
unsigned int get_mark_attachment_type (hb_codepoint_t glyph) const
|
const ClassDef &get_mark_attach_class_def () const { return this+markAttachClassDef; }
|
||||||
{ return (this+markAttachClassDef).get_class (glyph); }
|
bool has_mark_glyph_sets () const { return version.to_int () >= 0x00010002u && markGlyphSetsDef != 0; }
|
||||||
|
const MarkGlyphSets &get_mark_glyph_sets () const { return version.to_int () >= 0x00010002u ? this+markGlyphSetsDef : Null(MarkGlyphSets); }
|
||||||
|
bool has_var_store () const { return version.to_int () >= 0x00010003u && varStore != 0; }
|
||||||
|
const VariationStore &get_var_store () const
|
||||||
|
{ return version.to_int () >= 0x00010003u ? this+varStore : Null (VariationStore); }
|
||||||
|
|
||||||
|
bool has_data () const { return version.to_int (); }
|
||||||
|
unsigned int get_glyph_class (hb_codepoint_t glyph) const
|
||||||
|
{ return get_glyph_class_def ().get_class (glyph); }
|
||||||
|
void get_glyphs_in_class (unsigned int klass, hb_set_t *glyphs) const
|
||||||
|
{ get_glyph_class_def ().collect_class (glyphs, klass); }
|
||||||
|
|
||||||
|
unsigned int get_mark_attachment_type (hb_codepoint_t glyph) const
|
||||||
|
{ return get_mark_attach_class_def ().get_class (glyph); }
|
||||||
|
|
||||||
bool has_attach_points () const { return attachList != 0; }
|
|
||||||
unsigned int get_attach_points (hb_codepoint_t glyph_id,
|
unsigned int get_attach_points (hb_codepoint_t glyph_id,
|
||||||
unsigned int start_offset,
|
unsigned int start_offset,
|
||||||
unsigned int *point_count /* IN/OUT */,
|
unsigned int *point_count /* IN/OUT */,
|
||||||
unsigned int *point_array /* OUT */) const
|
unsigned int *point_array /* OUT */) const
|
||||||
{ return (this+attachList).get_attach_points (glyph_id, start_offset, point_count, point_array); }
|
{ return get_attach_list ().get_attach_points (glyph_id, start_offset, point_count, point_array); }
|
||||||
|
|
||||||
bool has_lig_carets () const { return ligCaretList != 0; }
|
|
||||||
unsigned int get_lig_carets (hb_font_t *font,
|
unsigned int get_lig_carets (hb_font_t *font,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_codepoint_t glyph_id,
|
hb_codepoint_t glyph_id,
|
||||||
unsigned int start_offset,
|
unsigned int start_offset,
|
||||||
unsigned int *caret_count /* IN/OUT */,
|
unsigned int *caret_count /* IN/OUT */,
|
||||||
hb_position_t *caret_array /* OUT */) const
|
hb_position_t *caret_array /* OUT */) const
|
||||||
{ return (this+ligCaretList).get_lig_carets (font,
|
{ return get_lig_caret_list ().get_lig_carets (font,
|
||||||
direction, glyph_id, get_var_store(),
|
direction, glyph_id, get_var_store(),
|
||||||
start_offset, caret_count, caret_array); }
|
start_offset, caret_count, caret_array); }
|
||||||
|
|
||||||
bool has_mark_sets () const { return version.to_int () >= 0x00010002u && markGlyphSetsDef != 0; }
|
|
||||||
bool mark_set_covers (unsigned int set_index, hb_codepoint_t glyph_id) const
|
bool mark_set_covers (unsigned int set_index, hb_codepoint_t glyph_id) const
|
||||||
{ return version.to_int () >= 0x00010002u && (this+markGlyphSetsDef).covers (set_index, glyph_id); }
|
{ return get_mark_glyph_sets ().covers (set_index, glyph_id); }
|
||||||
|
|
||||||
bool has_var_store () const { return version.to_int () >= 0x00010003u && varStore != 0; }
|
|
||||||
const VariationStore &get_var_store () const
|
|
||||||
{ return version.to_int () >= 0x00010003u ? this+varStore : Null (VariationStore); }
|
|
||||||
|
|
||||||
/* glyph_props is a 16-bit integer where the lower 8-bit have bits representing
|
/* glyph_props is a 16-bit integer where the lower 8-bit have bits representing
|
||||||
* glyph class and other bits, and high 8-bit the mark attachment type (if any).
|
* glyph class and other bits, and high 8-bit the mark attachment type (if any).
|
||||||
|
@ -607,7 +612,7 @@ struct GDEF
|
||||||
}
|
}
|
||||||
|
|
||||||
void collect_variation_indices (hb_collect_variation_indices_context_t *c) const
|
void collect_variation_indices (hb_collect_variation_indices_context_t *c) const
|
||||||
{ (this+ligCaretList).collect_variation_indices (c); }
|
{ get_lig_caret_list ().collect_variation_indices (c); }
|
||||||
|
|
||||||
void remap_layout_variation_indices (const hb_set_t *layout_variation_indices,
|
void remap_layout_variation_indices (const hb_set_t *layout_variation_indices,
|
||||||
hb_map_t *layout_variation_idx_map /* OUT */) const
|
hb_map_t *layout_variation_idx_map /* OUT */) const
|
||||||
|
|
|
@ -492,12 +492,12 @@ print_layout_info_using_private_api (hb_blob_t *blob)
|
||||||
gdef.has_glyph_classes () ? "" : "no ");
|
gdef.has_glyph_classes () ? "" : "no ");
|
||||||
printf (" Has %smark attachment types\n",
|
printf (" Has %smark attachment types\n",
|
||||||
gdef.has_mark_attachment_types () ? "" : "no ");
|
gdef.has_mark_attachment_types () ? "" : "no ");
|
||||||
printf (" Has %sattach points\n",
|
printf (" Has %sattach list\n",
|
||||||
gdef.has_attach_points () ? "" : "no ");
|
gdef.has_attach_list () ? "" : "no ");
|
||||||
printf (" Has %slig carets\n",
|
printf (" Has %slig carets\n",
|
||||||
gdef.has_lig_carets () ? "" : "no ");
|
gdef.has_lig_carets () ? "" : "no ");
|
||||||
printf (" Has %smark sets\n",
|
printf (" Has %smark glyph sets\n",
|
||||||
gdef.has_mark_sets () ? "" : "no ");
|
gdef.has_mark_glyph_sets () ? "" : "no ");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue