[USE] Move rphf

This commit is contained in:
Behdad Esfahbod 2015-07-21 16:07:10 +01:00
parent 5b5617e066
commit a85c4da9b1
1 changed files with 36 additions and 71 deletions

View File

@ -109,6 +109,7 @@ collect_features_use (hb_ot_shape_planner_t *plan)
map->add_gsub_pause (clear_substitution_flags);
map->add_feature (HB_TAG('r','p','h','f'), 1, F_MANUAL_ZWJ);
map->add_gsub_pause (record_rphf);
map->add_gsub_pause (clear_substitution_flags);
map->add_feature (HB_TAG('p','r','e','f'), 1, F_GLOBAL | F_MANUAL_ZWJ);
map->add_gsub_pause (record_pref);
@ -291,8 +292,6 @@ record_pref (const hb_ot_shape_plan_t *plan,
hb_font_t *font,
hb_buffer_t *buffer)
{
const use_shape_plan_t *use_plan = (const use_shape_plan_t *) plan->data;
hb_glyph_info_t *info = buffer->info;
unsigned int count = buffer->len;
if (unlikely (!count)) return;
@ -307,63 +306,6 @@ record_pref (const hb_ot_shape_plan_t *plan,
record_pref_syllable (info, last, count);
}
static void
reorder_virama_terminated_cluster (const hb_ot_shape_plan_t *plan,
hb_face_t *face,
hb_buffer_t *buffer,
unsigned int start, unsigned int end)
{
}
static void
reorder_consonant_cluster (const hb_ot_shape_plan_t *plan,
hb_face_t *face,
hb_buffer_t *buffer,
unsigned int start, unsigned int end)
{
hb_glyph_info_t *info = buffer->info;
/* Reorder! */
#if 0
unsigned int i = start;
for (; i < base; i++)
info[i].use_position() = POS_PRE_C;
if (i < end)
{
info[i].use_position() = POS_BASE_C;
i++;
}
for (; i < end; i++)
{
if (info[i].use_category() == OT_MR) /* Pre-base reordering */
{
info[i].use_position() = POS_PRE_C;
continue;
}
if (info[i].use_category() == OT_VPre) /* Left matra */
{
info[i].use_position() = POS_PRE_M;
continue;
}
info[i].use_position() = POS_AFTER_MAIN;
}
buffer->merge_clusters (start, end);
/* Sit tight, rock 'n roll! */
hb_bubble_sort (info + start, end - start, compare_use_order);
#endif
}
static void
reorder_vowel_cluster (const hb_ot_shape_plan_t *plan,
hb_face_t *face,
hb_buffer_t *buffer,
unsigned int start, unsigned int end)
{
reorder_consonant_cluster (plan, face, buffer, start, end);
}
static void
reorder_syllable (const hb_ot_shape_plan_t *plan,
hb_face_t *face,
@ -371,19 +313,42 @@ reorder_syllable (const hb_ot_shape_plan_t *plan,
unsigned int start, unsigned int end)
{
syllable_type_t syllable_type = (syllable_type_t) (buffer->info[start].syllable() & 0x0F);
switch (syllable_type) {
#define HANDLE(X) case X: reorder_##X (plan, face, buffer, start, end); return
HANDLE (virama_terminated_cluster);
HANDLE (consonant_cluster);
HANDLE (vowel_cluster);
#undef HANDLE
#define HANDLE(X) case X: return
HANDLE (number_joiner_terminated_cluster);
HANDLE (numeral_cluster);
HANDLE (symbol_cluster);
HANDLE (independent_cluster);
#undef HANDLE
/* Only a few syllable types need reordering. */
if (unlikely (!(FLAG_SAFE (syllable_type) &
(FLAG (virama_terminated_cluster) |
FLAG (consonant_cluster) |
FLAG (vowel_cluster)))))
return;
hb_glyph_info_t *info = buffer->info;
#define HALANT_FLAGS FLAG(USE_H)
#define BASE_FLAGS (FLAG (USE_B) | FLAG (USE_GB) | FLAG (USE_IV))
/* Move things forward. */
if (info[start].use_category() == USE_R && end - start > 1)
{
/* Got a repha. Reorder it to after first base, before first halant. */
for (unsigned int i = start + 1; i < end; i++)
if (FLAG_UNSAFE (info[i].use_category()) & (HALANT_FLAGS | BASE_FLAGS))
{
/* If we hit a halant, move before it; otherwise it's a base: move to it's
* place, and shift things in between backward. */
if (info[i].use_category() == USE_H)
i--;
hb_glyph_info_t t = info[start];
memmove (&info[start], &info[start + 1], (i - start) * sizeof (info[0]));
info[i] = t;
buffer->merge_clusters (start, i + 1);
break;
}
}
/* TODO move things back. */
}
static inline void