Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAleksey 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)
commite1930a8c11f9bd7a9d8e9ee740e478e1707a3451 (patch)
treeed5fb23a61976f81cbddada0802e62f44e553089
parentffee3f5dacaf0ee090986299a5f35c0931b64946 (diff)
Revert marks related workaround code for 0.3 brach
-rw-r--r--src/espeak.c23
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);