[ClassDef2] Write a few loops as range-based for
This commit is contained in:
parent
ac8b232a2d
commit
8805a866b5
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue