diff options
author | Aleksey Lim <alsroot@member.fsf.org> | 2009-03-21 11:34:39 (GMT) |
---|---|---|
committer | Aleksey Lim <alsroot@member.fsf.org> | 2009-07-16 09:43:03 (GMT) |
commit | e1930a8c11f9bd7a9d8e9ee740e478e1707a3451 (patch) | |
tree | ed5fb23a61976f81cbddada0802e62f44e553089 | |
parent | ffee3f5dacaf0ee090986299a5f35c0931b64946 (diff) |
Revert marks related workaround code for 0.3 brach
-rw-r--r-- | src/espeak.c | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/src/espeak.c b/src/espeak.c index f1a5f03..d0942d1 100644 --- a/src/espeak.c +++ b/src/espeak.c @@ -56,6 +56,7 @@ typedef struct int last_word; int mark_offset; const gchar *mark_name; + int last_mark; } Espin; struct _Econtext @@ -452,10 +453,29 @@ synth_cb(short *data, int numsamples, espeak_EVENT *events) // convert to 0-based position --i->text_position; + // workaround to fix text_position related faults for mark events if (i->type == espeakEVENT_MARK) { + // suppress failed text_position values + const gchar *eom = strstr(self->text + + spin->last_mark, "/>"); + if (eom) + { + int pos = eom - self->text + 2; + + if (i->text_position <= spin->last_mark || + pos > i->text_position) + i->text_position = pos; + } + else if (i->text_position <= spin->last_mark) + { + i->text_position = spin->last_mark; + } + + spin->last_mark = i->text_position; + // point mark name to text substring instead of using - // espeak's allocated(temporally) string + // espeak's allocated string int l_quote, r_quote; if ((r_quote = strbstr(self, i->text_position, "/>", 2)) != 0) if ((r_quote = strbstr(self, r_quote, "\"", 1)) != 0) @@ -489,6 +509,7 @@ synth(Econtext *self, Espin *spin) spin->mark_offset = 0; spin->mark_name = NULL; spin->last_word = -1; + spin->last_mark = 0; espeak_SetParameter(espeakPITCH, g_atomic_int_get(&self->pitch), 0); espeak_SetParameter(espeakRATE, g_atomic_int_get(&self->rate), 0); |