[ClassDef2] Write a few loops as range-based for

This commit is contained in:
Behdad Esfahbod 2022-11-30 17:15:00 -07:00
parent ac8b232a2d
commit 8805a866b5
1 changed files with 14 additions and 20 deletions

View File

@ -1842,13 +1842,12 @@ struct ClassDefFormat2_4
else else
{ {
unsigned num_source_glyphs = c->plan->source->get_num_glyphs (); unsigned num_source_glyphs = c->plan->source->get_num_glyphs ();
unsigned count = rangeRecord.len; for (auto &range : rangeRecord)
for (unsigned i = 0; i < count; i++)
{ {
unsigned klass = rangeRecord.arrayZ[i].value; unsigned klass = range.value;
if (!klass) continue; if (!klass) continue;
hb_codepoint_t start = rangeRecord.arrayZ[i].first; hb_codepoint_t start = range.first;
hb_codepoint_t end = hb_min (rangeRecord.arrayZ[i].last + 1, num_source_glyphs); hb_codepoint_t end = hb_min (range.last + 1, num_source_glyphs);
for (hb_codepoint_t g = start; g < end; g++) for (hb_codepoint_t g = start; g < end; g++)
{ {
hb_codepoint_t new_gid = glyph_map[g]; hb_codepoint_t new_gid = glyph_map[g];
@ -1886,10 +1885,9 @@ struct ClassDefFormat2_4
template <typename set_t> template <typename set_t>
bool collect_coverage (set_t *glyphs) const bool collect_coverage (set_t *glyphs) const
{ {
unsigned int count = rangeRecord.len; for (auto &range : rangeRecord)
for (unsigned int i = 0; i < count; i++) if (range.value)
if (rangeRecord[i].value) if (unlikely (!range.collect_coverage (glyphs)))
if (unlikely (!rangeRecord[i].collect_coverage (glyphs)))
return false; return false;
return true; return true;
} }
@ -1897,11 +1895,10 @@ struct ClassDefFormat2_4
template <typename set_t> template <typename set_t>
bool collect_class (set_t *glyphs, unsigned int klass) const bool collect_class (set_t *glyphs, unsigned int klass) const
{ {
unsigned int count = rangeRecord.len; for (auto &range : rangeRecord)
for (unsigned int i = 0; i < count; i++)
{ {
if (rangeRecord[i].value == klass) if (range.value == klass)
if (unlikely (!rangeRecord[i].collect_coverage (glyphs))) if (unlikely (!range.collect_coverage (glyphs)))
return false; return false;
} }
return true; return true;
@ -1910,10 +1907,8 @@ struct ClassDefFormat2_4
bool intersects (const hb_set_t *glyphs) const bool intersects (const hb_set_t *glyphs) const
{ {
/* TODO Speed up, using hb_set_next() and bsearch()? */ /* TODO Speed up, using hb_set_next() and bsearch()? */
unsigned int count = rangeRecord.len; for (auto &range : rangeRecord)
for (unsigned int i = 0; i < count; i++)
{ {
const auto& range = rangeRecord[i];
if (range.intersects (*glyphs) && range.value) if (range.intersects (*glyphs) && range.value)
return true; return true;
} }
@ -1921,18 +1916,17 @@ struct ClassDefFormat2_4
} }
bool intersects_class (const hb_set_t *glyphs, uint16_t klass) const bool intersects_class (const hb_set_t *glyphs, uint16_t klass) const
{ {
unsigned int count = rangeRecord.len;
if (klass == 0) if (klass == 0)
{ {
/* Match if there's any glyph that is not listed! */ /* Match if there's any glyph that is not listed! */
hb_codepoint_t g = HB_SET_VALUE_INVALID; hb_codepoint_t g = HB_SET_VALUE_INVALID;
for (unsigned int i = 0; i < count; i++) for (auto &range : rangeRecord)
{ {
if (!glyphs->next (&g)) if (!glyphs->next (&g))
break; break;
if (g < rangeRecord[i].first) if (g < range.first)
return true; return true;
g = rangeRecord[i].last; g = range.last;
} }
if (g != HB_SET_VALUE_INVALID && glyphs->next (&g)) if (g != HB_SET_VALUE_INVALID && glyphs->next (&g))
return true; return true;