[indic] More granular post-base cluster merging!

This commit is contained in:
Behdad Esfahbod 2013-10-16 12:32:12 +02:00
parent 9cb59d460e
commit 28d5daec94
1 changed files with 39 additions and 6 deletions

View File

@ -936,20 +936,53 @@ initial_reordering_consonant_syllable (const hb_ot_shape_plan_t *plan,
} }
} }
{ {
/* Things are out-of-control for post base positions, they may shuffle /* Use syllable() for sort accounting temporarily. */
* around like crazy, so merge clusters. For pre-base stuff, we handle unsigned int syllable = info[start].syllable();
* cluster issues in final reordering. */ for (unsigned int i = start; i < end; i++)
buffer->merge_clusters (base, end); info[i].syllable() = i - start;
/* Sit tight, rock 'n roll! */ /* Sit tight, rock 'n roll! */
hb_bubble_sort (info + start, end - start, compare_indic_order); hb_bubble_sort (info + start, end - start, compare_indic_order);
/* Find base again */ /* Find base again */
base = end; base = end;
for (unsigned int i = start; i < end; i++) for (unsigned int i = start; i < end; i++)
if (info[i].indic_position() == POS_BASE_C) { if (info[i].indic_position() == POS_BASE_C)
base = i; {
base = i;
break; break;
} }
/* Things are out-of-control for post base positions, they may shuffle
* around like crazy. In old-spec mode, we move halants around, so in
* that case merge all clusters after base. Otherwise, check the sort
* order and merge as needed.
* For pre-base stuff, we handle cluster issues in final reordering. */
if (indic_plan->is_old_spec || end - base > 127)
buffer->merge_clusters (base, end);
else
{
/* Note! syllable() is a one-byte field. */
for (unsigned int i = base; i < end; i++)
if (info[i].syllable() != 255)
{
unsigned int max = i;
unsigned int j = start + info[i].syllable();
while (j != i)
{
max = MAX (max, j);
unsigned int next = start + info[j].syllable();
info[j].syllable() = 255; /* So we don't process j later again. */
j = next;
}
if (i != max)
buffer->merge_clusters (i, max + 1);
}
}
/* Put syllable back in. */
for (unsigned int i = start; i < end; i++)
info[i].syllable() = syllable;
} }
/* Setup masks now */ /* Setup masks now */