[Indic] Fix state machine to backtrack
This commit is contained in:
parent
cee7187447
commit
4be46bade2
|
@ -59,39 +59,35 @@ z = ZWJ|ZWNJ;
|
||||||
matra_group = M N? H?;
|
matra_group = M N? H?;
|
||||||
syllable_tail = SM? (VD VD?)?;
|
syllable_tail = SM? (VD VD?)?;
|
||||||
|
|
||||||
action found_consonant_syllable { initial_reordering_consonant_syllable (map, buffer, mask_array, last, p); }
|
|
||||||
action found_vowel_syllable { initial_reordering_vowel_syllable (map, buffer, mask_array, last, p); }
|
|
||||||
action found_standalone_cluster { initial_reordering_standalone_cluster (map, buffer, mask_array, last, p); }
|
|
||||||
action found_non_indic { initial_reordering_non_indic (map, buffer, mask_array, last, p); }
|
|
||||||
|
|
||||||
action next_syllable {
|
consonant_syllable = (c.N? (H.z?|z.H))* c.N? A? (H.z? | matra_group*)? syllable_tail;
|
||||||
for (unsigned int i = last; i < p; i++)
|
vowel_syllable = (Ra H)? V N? (z?.H.c | ZWJ.c)? matra_group* syllable_tail;
|
||||||
info[i].syllable() = syllable_serial;
|
standalone_cluster = (Ra H)? NBSP N? (z? H c)? matra_group* syllable_tail;
|
||||||
last = p;
|
other = any;
|
||||||
syllable_serial++;
|
|
||||||
}
|
|
||||||
|
|
||||||
consonant_syllable = (c.N? (H.z?|z.H))* c.N? A? (H.z? | matra_group*)? syllable_tail %(found_consonant_syllable);
|
main := |*
|
||||||
vowel_syllable = (Ra H)? V N? (z?.H.c | ZWJ.c)? matra_group* syllable_tail %(found_vowel_syllable);
|
consonant_syllable => { process_syllable (consonant_syllable); };
|
||||||
standalone_cluster = (Ra H)? NBSP N? (z? H c)? matra_group* syllable_tail %(found_standalone_cluster);
|
vowel_syllable => { process_syllable (vowel_syllable); };
|
||||||
other = /./ %(found_non_indic);
|
standalone_cluster => { process_syllable (standalone_cluster); };
|
||||||
|
other => { process_syllable (non_indic); };
|
||||||
|
*|;
|
||||||
|
|
||||||
syllable =
|
|
||||||
consonant_syllable
|
|
||||||
| vowel_syllable
|
|
||||||
| standalone_cluster
|
|
||||||
| other
|
|
||||||
;
|
|
||||||
|
|
||||||
main := (syllable %(next_syllable))**;
|
|
||||||
|
|
||||||
}%%
|
}%%
|
||||||
|
|
||||||
|
#define process_syllable(func) \
|
||||||
|
HB_STMT_START { \
|
||||||
|
for (unsigned int i = last; i < p+1; i++) \
|
||||||
|
info[i].syllable() = syllable_serial; \
|
||||||
|
PASTE (initial_reordering_, func) (map, buffer, mask_array, last, p+1); \
|
||||||
|
last = p+1; \
|
||||||
|
syllable_serial++; \
|
||||||
|
} HB_STMT_END
|
||||||
|
|
||||||
static void
|
static void
|
||||||
find_syllables (const hb_ot_map_t *map, hb_buffer_t *buffer, hb_mask_t *mask_array)
|
find_syllables (const hb_ot_map_t *map, hb_buffer_t *buffer, hb_mask_t *mask_array)
|
||||||
{
|
{
|
||||||
unsigned int p, pe, eof;
|
unsigned int p, pe, eof, ts, te, act;
|
||||||
int cs;
|
int cs;
|
||||||
hb_glyph_info_t *info = buffer->info;
|
hb_glyph_info_t *info = buffer->info;
|
||||||
%%{
|
%%{
|
||||||
|
|
|
@ -91,6 +91,8 @@ template <typename Type> static inline Type MAX (const Type &a, const Type &b) {
|
||||||
#define ASSERT_STATIC_EXPR(_cond) ((void) sizeof (char[(_cond) ? 1 : -1]))
|
#define ASSERT_STATIC_EXPR(_cond) ((void) sizeof (char[(_cond) ? 1 : -1]))
|
||||||
#define ASSERT_STATIC_EXPR_ZERO(_cond) (0 * sizeof (char[(_cond) ? 1 : -1]))
|
#define ASSERT_STATIC_EXPR_ZERO(_cond) (0 * sizeof (char[(_cond) ? 1 : -1]))
|
||||||
|
|
||||||
|
#define _PASTE1(a,b) a##b
|
||||||
|
#define PASTE(a,b) _PASTE1(a,b)
|
||||||
|
|
||||||
/* Lets assert int types. Saves trouble down the road. */
|
/* Lets assert int types. Saves trouble down the road. */
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue