Browse Source

Fixed <say-as interpret-as="tts:key> to speak all single characters, and ignore _ and - after an alphabetic character.


git-svn-id: https://espeak.svn.sourceforge.net/svnroot/espeak/trunk@123 d46cf337-b52f-0410-862d-fd96e6ae7743
master
jonsd 17 years ago
parent
commit
ee4cb049f5
4 changed files with 46 additions and 10 deletions
  1. 5
    4
      src/dictionary.cpp
  2. 2
    0
      src/speak_lib.cpp
  3. 35
    3
      src/translate.cpp
  4. 4
    3
      src/translate.h

+ 5
- 4
src/dictionary.cpp View File

@@ -2928,7 +2928,6 @@ int Translator::LookupDictList(char **wordptr, char *ph_out, unsigned int *flags
const char *word2;
unsigned char c;
int nbytes;
int c2;
int len;
char word[N_WORD_BYTES];
static char word_replacement[N_WORD_BYTES];
@@ -2936,7 +2935,7 @@ int Translator::LookupDictList(char **wordptr, char *ph_out, unsigned int *flags
length = 0;
word2 = word1 = *wordptr;

while((word2[nbytes = utf8_in(&c2,word2,0)]==' ') && (word2[nbytes+1]=='.'))
while((word2[nbytes = utf8_nbytes(word2)]==' ') && (word2[nbytes+1]=='.'))
{
// look for an abbreviation of the form a.b.c
// try removing the spaces between the dots and looking for a match
@@ -2948,13 +2947,15 @@ int Translator::LookupDictList(char **wordptr, char *ph_out, unsigned int *flags
if(length > 0)
{
// found an abbreviation containing dots
nbytes = utf8_in(&c2,word2,0);
nbytes = utf8_nbytes(word2);
memcpy(&word[length],word2,nbytes);
word[length+nbytes] = 0;
found = LookupDict2(word, word2, ph_out, flags, end_flags, wtab);
if(found)
{
*flags = *flags & ~(7 << 5) | (length << 5);
// set the skip words flag
flags[0] |= FLAG_SKIPWORDS;
dictionary_skipwords = length;
return(1);
}
}

+ 2
- 0
src/speak_lib.cpp View File

@@ -181,6 +181,8 @@ int sync_espeak_terminated_msg( uint unique_identifier, void* user_data)
event_list[0].unique_identifier = unique_identifier;
event_list[0].user_data = user_data;
event_list[1].type = espeakEVENT_LIST_TERMINATED;
event_list[1].unique_identifier = unique_identifier;
event_list[1].user_data = user_data;

if (my_mode==AUDIO_OUTPUT_PLAYBACK)
{

+ 35
- 3
src/translate.cpp View File

@@ -521,8 +521,25 @@ int utf8_out(unsigned int c, char *buf)
} // end of utf8_out


int utf8_nbytes(const char *buf)
{//=============================
// Returns the number of bytes for the first UTF-8 character in buf
unsigned char c = (unsigned char)buf[0];
if(c < 0x80)
return(1);
if(c < 0xe0)
return(2);
if(c < 0xf0)
return(3);
return(4);
}


int utf8_in(int *c, const char *buf, int backwards)
{//================================================
// Read a unicode characater from a UTF8 string
// Returns the number of UTF8 bytes used.
// backwards: set if we are moving backwards through the UTF8 string
int c1;
int n_bytes;
int ix;
@@ -649,14 +666,20 @@ int Translator::TranslateWord(char *word1, int next_pause, WORD_TAB *wtab)

// try an initial lookup in the dictionary list, we may find a pronunciation specified, or
// we may just find some flags
if((option_sayas & 0xf0) == 0x10)
spell_word = 0;
if(option_sayas == SAYAS_KEY)
{
if(word_length == 1)
spell_word = 4;
}

if(option_sayas & 0x10)
{
// SAYAS_CHAR, SAYAS_GYLPH, or SAYAS_SINGLE_CHAR
spell_word = option_sayas & 0xf; // 2,3,4
}
else
{
spell_word = 0;
found = LookupDictList(&word1, phonemes, dictionary_flags, FLAG_ALLOW_TEXTMODE, wtab); // the original word

// if textmode, LookupDictList() replaces word1 by the new text and returns found=0
@@ -1885,6 +1908,15 @@ void *Translator::TranslateClause(FILE *f_text, const void *vp_input, int *tone_
}
}

if(option_sayas2 == SAYAS_KEY)
{
if(((c == '_') || (c == '-')) && IsAlpha(prev_in))
{
c = ' ';
}
c = towlower(c);
}

if(phoneme_mode)
{
all_upper_case = FLAG_PHONEMES;
@@ -1921,7 +1953,7 @@ void *Translator::TranslateClause(FILE *f_text, const void *vp_input, int *tone_
}
}
else
if((option_sayas2 & 0xf0) != 0x10)
if((option_sayas2 & 0x30) == 0)
{
// speak as words


+ 4
- 3
src/translate.h View File

@@ -180,9 +180,9 @@
#define SAYAS_CHARS 0x12
#define SAYAS_GLYPHS 0x13
#define SAYAS_SINGLE_CHARS 0x14
#define SAYAS_KEY 0x20
#define SAYAS_DIGITS1 0x21
#define SAYAS_DIGITS 0x30 // + number of digits
#define SAYAS_KEY 0x24
#define SAYAS_DIGITS 0x40 // + number of digits
#define SAYAS_DIGITS1 0xc1

// Rule:
// [4] [match] [1 pre] [2 post] [3 phonemes] 0
@@ -560,6 +560,7 @@ void ChangeWordStress(Translator *tr, char *word, int new_stress);
int TransposeAlphabet(char *text, int offset, int min, int max);
int utf8_in(int *c, const char *buf, int backwards);
int utf8_out(unsigned int c, char *buf);
int utf8_nbytes(const char *buf);
int lookupwchar(const unsigned short *list,int c);
int Eof(void);
char *strchr_w(const char *s, int c);

Loading…
Cancel
Save