mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-01 19:43:03 +00:00
Enhance Spanish and Mexican support (bug #1566) thanks!
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@2904 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
42
say.c
42
say.c
@@ -405,7 +405,7 @@ int ast_say_digits_full(struct ast_channel *chan, int num, char *ints, char *lan
|
|||||||
da - Danish
|
da - Danish
|
||||||
de - German
|
de - German
|
||||||
en - English
|
en - English
|
||||||
es - Spanish
|
es - Spanish, Mexican
|
||||||
fr - French
|
fr - French
|
||||||
it - Italian
|
it - Italian
|
||||||
nl - Dutch
|
nl - Dutch
|
||||||
@@ -413,9 +413,9 @@ int ast_say_digits_full(struct ast_channel *chan, int num, char *ints, char *lan
|
|||||||
se - Swedish
|
se - Swedish
|
||||||
|
|
||||||
Gender:
|
Gender:
|
||||||
For Portuguese, we're using m & f options to saynumber() to indicate if the gender is masculine or feminine.
|
For Portuguese, French & Spanish, we're using m & f options to saynumber() to indicate if the gender is masculine or feminine.
|
||||||
For Danish, we're using c & n options to saynumber() to indicate if the gender is commune or neutrum.
|
For Danish, we're using c & n options to saynumber() to indicate if the gender is commune or neutrum.
|
||||||
This still needs to be implemented for French, Spanish & German.
|
This still needs to be implemented for German (although the option is passed to the function, it currently does nothing with it).
|
||||||
|
|
||||||
Date/Time functions currently have less languages supported than saynumber().
|
Date/Time functions currently have less languages supported than saynumber().
|
||||||
|
|
||||||
@@ -439,7 +439,7 @@ int ast_say_digits_full(struct ast_channel *chan, int num, char *ints, char *lan
|
|||||||
static int ast_say_number_full_en(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
static int ast_say_number_full_en(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
||||||
static int ast_say_number_full_da(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
static int ast_say_number_full_da(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
||||||
static int ast_say_number_full_de(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
static int ast_say_number_full_de(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
||||||
static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
||||||
static int ast_say_number_full_fr(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
static int ast_say_number_full_fr(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
|
||||||
static int ast_say_number_full_it(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
static int ast_say_number_full_it(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
||||||
static int ast_say_number_full_nl(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
static int ast_say_number_full_nl(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
|
||||||
@@ -485,8 +485,8 @@ int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *lan
|
|||||||
return(ast_say_number_full_da(chan, num, ints, language, options, audiofd, ctrlfd));
|
return(ast_say_number_full_da(chan, num, ints, language, options, audiofd, ctrlfd));
|
||||||
} else if (!strcasecmp(language, "de") ) { /* German syntax */
|
} else if (!strcasecmp(language, "de") ) { /* German syntax */
|
||||||
return(ast_say_number_full_de(chan, num, ints, language, options, audiofd, ctrlfd));
|
return(ast_say_number_full_de(chan, num, ints, language, options, audiofd, ctrlfd));
|
||||||
} else if (!strcasecmp(language, "es") ) { /* Spanish syntax */
|
} else if (!strcasecmp(language, "es") || !strcasecmp(language, "mx")) { /* Spanish syntax */
|
||||||
return(ast_say_number_full_es(chan, num, ints, language, audiofd, ctrlfd));
|
return(ast_say_number_full_es(chan, num, ints, language, options, audiofd, ctrlfd));
|
||||||
} else if (!strcasecmp(language, "fr") ) { /* French syntax */
|
} else if (!strcasecmp(language, "fr") ) { /* French syntax */
|
||||||
return(ast_say_number_full_fr(chan, num, ints, language, options, audiofd, ctrlfd));
|
return(ast_say_number_full_fr(chan, num, ints, language, options, audiofd, ctrlfd));
|
||||||
} else if (!strcasecmp(language, "it") ) { /* Italian syntax */
|
} else if (!strcasecmp(language, "it") ) { /* Italian syntax */
|
||||||
@@ -512,8 +512,8 @@ int ast_say_number(struct ast_channel *chan, int num, char *ints, char *language
|
|||||||
return(ast_say_number_full_da(chan, num, ints, language, options, -1, -1));
|
return(ast_say_number_full_da(chan, num, ints, language, options, -1, -1));
|
||||||
} else if (!strcasecmp(language, "de")) { /* German syntax */
|
} else if (!strcasecmp(language, "de")) { /* German syntax */
|
||||||
return(ast_say_number_full_de(chan, num, ints, language, options, -1, -1));
|
return(ast_say_number_full_de(chan, num, ints, language, options, -1, -1));
|
||||||
} else if (!strcasecmp(language, "es")) { /* Spanish syntax */
|
} else if (!strcasecmp(language, "es") || !strcasecmp(language, "mx")) { /* Spanish syntax */
|
||||||
return(ast_say_number_full_es(chan, num, ints, language, -1, -1));
|
return(ast_say_number_full_es(chan, num, ints, language, options, -1, -1));
|
||||||
} else if (!strcasecmp(language, "fr")) { /* French syntax */
|
} else if (!strcasecmp(language, "fr")) { /* French syntax */
|
||||||
return(ast_say_number_full_fr(chan, num, ints, language, options, -1, -1));
|
return(ast_say_number_full_fr(chan, num, ints, language, options, -1, -1));
|
||||||
} else if (!strcasecmp(language, "it")) { /* Italian syntax */
|
} else if (!strcasecmp(language, "it")) { /* Italian syntax */
|
||||||
@@ -784,22 +784,34 @@ static int ast_say_number_full_de(struct ast_channel *chan, int num, char *ints,
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*--- ast_say_number_full_es: spanish syntax */
|
/*--- ast_say_number_full_es: Spanish syntax */
|
||||||
/* New files:
|
/* New files:
|
||||||
Requires a few new audios:
|
Requires a few new audios:
|
||||||
|
1F.gsm: feminine 'una'
|
||||||
21.gsm thru 29.gsm, cien.gsm, mil.gsm, millon.gsm, millones.gsm, 100.gsm, 200.gsm, 300.gsm, 400.gsm, 500.gsm, 600.gsm, 700.gsm, 800.gsm, 900.gsm, y.gsm
|
21.gsm thru 29.gsm, cien.gsm, mil.gsm, millon.gsm, millones.gsm, 100.gsm, 200.gsm, 300.gsm, 400.gsm, 500.gsm, 600.gsm, 700.gsm, 800.gsm, 900.gsm, y.gsm
|
||||||
*/
|
*/
|
||||||
static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd)
|
static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd)
|
||||||
{
|
{
|
||||||
int res = 0;
|
int res = 0;
|
||||||
int playa = 0;
|
int playa = 0;
|
||||||
|
int mf = 1; /* +1 = Masculin; -1 = Feminin */
|
||||||
char fn[256] = "";
|
char fn[256] = "";
|
||||||
if (!num)
|
if (!num)
|
||||||
return ast_say_digits_full(chan, 0,ints, language, audiofd, ctrlfd);
|
return ast_say_digits_full(chan, 0,ints, language, audiofd, ctrlfd);
|
||||||
|
|
||||||
|
if (options && !strncasecmp(options, "f",1))
|
||||||
|
mf = -1;
|
||||||
|
|
||||||
while (!res && num) {
|
while (!res && num) {
|
||||||
if (playa) {
|
if (playa) {
|
||||||
snprintf(fn, sizeof(fn), "digits/y");
|
snprintf(fn, sizeof(fn), "digits/y");
|
||||||
playa = 0;
|
playa = 0;
|
||||||
|
} else if (num == 1) {
|
||||||
|
if (mf < 0)
|
||||||
|
snprintf(fn, sizeof(fn), "digits/%dF", num);
|
||||||
|
else
|
||||||
|
snprintf(fn, sizeof(fn), "digits/%d", num);
|
||||||
|
num = 0;
|
||||||
} else if (num < 31) {
|
} else if (num < 31) {
|
||||||
snprintf(fn, sizeof(fn), "digits/%d", num);
|
snprintf(fn, sizeof(fn), "digits/%d", num);
|
||||||
num = 0;
|
num = 0;
|
||||||
@@ -817,14 +829,14 @@ static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints,
|
|||||||
num -= ((num/100)*100);
|
num -= ((num/100)*100);
|
||||||
} else {
|
} else {
|
||||||
if (num < 1000000) {
|
if (num < 1000000) {
|
||||||
res = ast_say_number_full_es(chan, num / 1000, ints, language, audiofd, ctrlfd);
|
res = ast_say_number_full_es(chan, num / 1000, ints, language, options, audiofd, ctrlfd);
|
||||||
if (res)
|
if (res)
|
||||||
return res;
|
return res;
|
||||||
num = num % 1000;
|
num = num % 1000;
|
||||||
snprintf(fn, sizeof(fn), "digits/mil");
|
snprintf(fn, sizeof(fn), "digits/mil");
|
||||||
} else {
|
} else {
|
||||||
if (num < 2147483640) {
|
if (num < 2147483640) {
|
||||||
res = ast_say_number_full_es(chan, num / 1000000, ints, language, audiofd, ctrlfd);
|
res = ast_say_number_full_es(chan, num / 1000000, ints, language, options, audiofd, ctrlfd);
|
||||||
if (res)
|
if (res)
|
||||||
return res;
|
return res;
|
||||||
if ((num/1000000) == 1) {
|
if ((num/1000000) == 1) {
|
||||||
@@ -858,9 +870,9 @@ static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints,
|
|||||||
|
|
||||||
|
|
||||||
/*--- ast_say_number_full_fr: French syntax */
|
/*--- ast_say_number_full_fr: French syntax */
|
||||||
/* Extra sounds needed: */
|
/* Extra sounds needed:
|
||||||
/* 1F: feminin 'une' */
|
1F: feminin 'une'
|
||||||
/* et: 'and' */
|
et: 'and' */
|
||||||
static int ast_say_number_full_fr(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd)
|
static int ast_say_number_full_fr(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd)
|
||||||
{
|
{
|
||||||
int res = 0;
|
int res = 0;
|
||||||
|
|||||||
Reference in New Issue
Block a user