[colr] minor style fix

This commit is contained in:
Ebrahim Byagowi 2020-02-11 17:08:55 +03:30
parent cbb45c3ee7
commit 21e1b1310a
1 changed files with 39 additions and 38 deletions

View File

@ -128,7 +128,7 @@ struct COLR
bool is_valid () { return colr.get_blob ()->length; } bool is_valid () { return colr.get_blob ()->length; }
void closure_glyphs (hb_codepoint_t glyph, void closure_glyphs (hb_codepoint_t glyph,
hb_set_t *related_ids /* OUT */) const hb_set_t *related_ids /* OUT */) const
{ colr->closure_glyphs (glyph, related_ids); } { colr->closure_glyphs (glyph, related_ids); }
private: private:
@ -136,12 +136,13 @@ struct COLR
}; };
void closure_glyphs (hb_codepoint_t glyph, void closure_glyphs (hb_codepoint_t glyph,
hb_set_t *related_ids /* OUT */) const hb_set_t *related_ids /* OUT */) const
{ {
const BaseGlyphRecord *record = get_base_glyph_record (glyph); const BaseGlyphRecord *record = get_base_glyph_record (glyph);
if (!record) return; if (!record) return;
hb_array_t<const LayerRecord> glyph_layers = (this+layersZ).as_array (numLayers).sub_array (record->firstLayerIdx, record->numLayers); auto glyph_layers = (this+layersZ).as_array (numLayers).sub_array (record->firstLayerIdx,
record->numLayers);
if (!glyph_layers.length) return; if (!glyph_layers.length) return;
related_ids->add_array (&glyph_layers[0].glyphId, glyph_layers.length, LayerRecord::min_size); related_ids->add_array (&glyph_layers[0].glyphId, glyph_layers.length, LayerRecord::min_size);
} }
@ -155,12 +156,12 @@ struct COLR
} }
template<typename BaseIterator, typename LayerIterator, template<typename BaseIterator, typename LayerIterator,
hb_requires (hb_is_iterator (BaseIterator)), hb_requires (hb_is_iterator (BaseIterator)),
hb_requires (hb_is_iterator (LayerIterator))> hb_requires (hb_is_iterator (LayerIterator))>
bool serialize (hb_serialize_context_t *c, bool serialize (hb_serialize_context_t *c,
unsigned version, unsigned version,
BaseIterator base_it, BaseIterator base_it,
LayerIterator layer_it) LayerIterator layer_it)
{ {
TRACE_SERIALIZE (this); TRACE_SERIALIZE (this);
if (unlikely (base_it.len () != layer_it.len ())) if (unlikely (base_it.len () != layer_it.len ()))
@ -175,7 +176,7 @@ struct COLR
for (const hb_item_type<BaseIterator>& _ : + base_it.iter ()) for (const hb_item_type<BaseIterator>& _ : + base_it.iter ())
{ {
auto* record = c->embed(_); auto* record = c->embed (_);
if (unlikely (!record)) return_trace (false); if (unlikely (!record)) return_trace (false);
record->firstLayerIdx = numLayers; record->firstLayerIdx = numLayers;
numLayers += record->numLayers; numLayers += record->numLayers;
@ -206,18 +207,18 @@ struct COLR
auto base_it = auto base_it =
+ hb_range (c->plan->num_output_glyphs ()) + hb_range (c->plan->num_output_glyphs ())
| hb_map_retains_sorting ([&](hb_codepoint_t new_gid) | hb_map_retains_sorting ([&](hb_codepoint_t new_gid)
{ {
hb_codepoint_t old_gid = reverse_glyph_map.get (new_gid); hb_codepoint_t old_gid = reverse_glyph_map.get (new_gid);
const BaseGlyphRecord* old_record = get_base_glyph_record (old_gid); const BaseGlyphRecord* old_record = get_base_glyph_record (old_gid);
if (unlikely (!old_record)) if (unlikely (!old_record))
return hb_pair_t<bool, BaseGlyphRecord> (false, Null (BaseGlyphRecord)); return hb_pair_t<bool, BaseGlyphRecord> (false, Null (BaseGlyphRecord));
BaseGlyphRecord new_record; BaseGlyphRecord new_record;
new_record.glyphId = new_gid; new_record.glyphId = new_gid;
new_record.numLayers = old_record->numLayers; new_record.numLayers = old_record->numLayers;
return hb_pair_t<bool, BaseGlyphRecord> (true, new_record); return hb_pair_t<bool, BaseGlyphRecord> (true, new_record);
}) })
| hb_filter (hb_first) | hb_filter (hb_first)
| hb_map_retains_sorting (hb_second) | hb_map_retains_sorting (hb_second)
; ;
@ -226,28 +227,28 @@ struct COLR
+ hb_range (c->plan->num_output_glyphs ()) + hb_range (c->plan->num_output_glyphs ())
| hb_map (reverse_glyph_map) | hb_map (reverse_glyph_map)
| hb_map_retains_sorting ([&](hb_codepoint_t old_gid) | hb_map_retains_sorting ([&](hb_codepoint_t old_gid)
{ {
const BaseGlyphRecord* old_record = get_base_glyph_record (old_gid); const BaseGlyphRecord* old_record = get_base_glyph_record (old_gid);
hb_vector_t<LayerRecord> out_layers; hb_vector_t<LayerRecord> out_layers;
if (unlikely (!old_record || if (unlikely (!old_record ||
old_record->firstLayerIdx >= numLayers || old_record->firstLayerIdx >= numLayers ||
old_record->firstLayerIdx + old_record->numLayers > numLayers)) old_record->firstLayerIdx + old_record->numLayers > numLayers))
return hb_pair_t<bool, hb_vector_t<LayerRecord>> (false, out_layers); return hb_pair_t<bool, hb_vector_t<LayerRecord>> (false, out_layers);
hb_array_t<const LayerRecord> layers = (this+layersZ).as_array (numLayers).sub_array(old_record->firstLayerIdx, auto layers = (this+layersZ).as_array (numLayers).sub_array (old_record->firstLayerIdx,
old_record->numLayers); old_record->numLayers);
out_layers.resize (layers.length); out_layers.resize (layers.length);
for (unsigned int i = 0; i < layers.length; i++) { for (unsigned int i = 0; i < layers.length; i++) {
out_layers[i] = layers[i]; out_layers[i] = layers[i];
hb_codepoint_t new_gid = 0; hb_codepoint_t new_gid = 0;
if (unlikely (!c->plan->new_gid_for_old_gid (out_layers[i].glyphId, &new_gid))) if (unlikely (!c->plan->new_gid_for_old_gid (out_layers[i].glyphId, &new_gid)))
return hb_pair_t<bool, hb_vector_t<LayerRecord>> (false, out_layers); return hb_pair_t<bool, hb_vector_t<LayerRecord>> (false, out_layers);
out_layers[i].glyphId = new_gid; out_layers[i].glyphId = new_gid;
} }
return hb_pair_t<bool, hb_vector_t<LayerRecord>> (true, out_layers); return hb_pair_t<bool, hb_vector_t<LayerRecord>> (true, out_layers);
}) })
| hb_filter (hb_first) | hb_filter (hb_first)
| hb_map_retains_sorting (hb_second) | hb_map_retains_sorting (hb_second)
; ;