aboutsummaryrefslogtreecommitdiffstats
path: root/say.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-05-15 15:34:31 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-05-15 15:34:31 +0000
commit83ced88193d5b1a297c0ecbad0a365a0d3fad806 (patch)
tree4668e67ff52f9fa3f3f82ffa004d51511256d331 /say.c
parentf6bf7467fe26fd7fde129fe3995ec807894b24bc (diff)
Update coding guidelines, fix "say.c" compile on older compilers, update coding guidelines (includes bug #1631)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@2967 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'say.c')
-rwxr-xr-xsay.c645
1 files changed, 303 insertions, 342 deletions
diff --git a/say.c b/say.c
index 482416d64..c527d9afe 100755
--- a/say.c
+++ b/say.c
@@ -409,10 +409,10 @@ int ast_say_digits_full(struct ast_channel *chan, int num, char *ints, char *lan
fr - French
it - Italian
nl - Dutch
+ pl - Polish
pt - Portuguese
se - Swedish
tw - Taiwanese
- pl - Polish
Gender:
For Portuguese, French & Spanish, we're using m & f options to saynumber() to indicate if the gender is masculine or feminine.
@@ -449,10 +449,10 @@ static int ast_say_number_full_es(struct ast_channel *chan, int num, char *ints,
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_nl(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
+static int ast_say_number_full_pl(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
static int ast_say_number_full_pt(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
static int ast_say_number_full_se(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
static int ast_say_number_full_tw(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd);
-static int ast_say_number_full_pl(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd);
/* Forward declarations of ast_say_date, ast_say_datetime and ast_say_time functions */
static int ast_say_date_en(struct ast_channel *chan, time_t t, char *ints, char *lang);
@@ -491,10 +491,8 @@ static int wait_file(struct ast_channel *chan, char *ints, char *file, char *lan
/*--- ast_say_number_full: call language-specific functions */
/* Called from AGI */
-int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *language, int audiofd, int ctrlfd)
+int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd)
{
- char *options=(char *) NULL; /* While waiting for a general hack for agi */
-
if (!strcasecmp(language,"en") ) { /* English syntax */
return(ast_say_number_full_en(chan, num, ints, language, audiofd, ctrlfd));
} else if (!strcasecmp(language, "da") ) { /* Danish syntax */
@@ -509,12 +507,12 @@ int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *lan
return(ast_say_number_full_it(chan, num, ints, language, audiofd, ctrlfd));
} else if (!strcasecmp(language, "nl") ) { /* Dutch syntax */
return(ast_say_number_full_nl(chan, num, ints, language, audiofd, ctrlfd));
+ } else if (!strcasecmp(language, "pl") ) { /* Polish syntax */
+ return(ast_say_number_full_pl(chan, num, ints, language, options, audiofd, ctrlfd));
} else if (!strcasecmp(language, "pt") ) { /* Portuguese syntax */
return(ast_say_number_full_pt(chan, num, ints, language, options, audiofd, ctrlfd));
} else if (!strcasecmp(language, "se") ) { /* Swedish syntax */
return(ast_say_number_full_se(chan, num, ints, language, options, audiofd, ctrlfd));
- } else if (!strcasecmp(language, "pl") ) { /* Polish syntax */
- return(ast_say_number_full_pl(chan, num, ints, language, options, audiofd, ctrlfd));
} else if (!strcasecmp(language, "tw")) { /* Taiwanese syntax */
return(ast_say_number_full_tw(chan, num, ints, language, audiofd, ctrlfd));
}
@@ -526,30 +524,7 @@ int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *lan
/*--- ast_say_number: call language-specific functions without file descriptors */
int ast_say_number(struct ast_channel *chan, int num, char *ints, char *language, char *options)
{
- if (!strcasecmp(language,"en") ) { /* English syntax */
- return(ast_say_number_full_en(chan, num, ints, language, -1, -1));
- }else if (!strcasecmp(language, "da")) { /* Danish syntax */
- return(ast_say_number_full_da(chan, num, ints, language, options, -1, -1));
- } else if (!strcasecmp(language, "de")) { /* German syntax */
- return(ast_say_number_full_de(chan, num, ints, language, options, -1, -1));
- } else if (!strcasecmp(language, "es") || !strcasecmp(language, "mx")) { /* Spanish syntax */
- return(ast_say_number_full_es(chan, num, ints, language, options, -1, -1));
- } else if (!strcasecmp(language, "fr")) { /* French syntax */
- return(ast_say_number_full_fr(chan, num, ints, language, options, -1, -1));
- } else if (!strcasecmp(language, "it")) { /* Italian syntax */
- return(ast_say_number_full_it(chan, num, ints, language, -1, -1));
- } else if (!strcasecmp(language, "nl")) { /* Dutch syntax */
- return(ast_say_number_full_nl(chan, num, ints, language, -1, -1));
- } else if (!strcasecmp(language, "pt")) { /* Portuguese syntax */
- return(ast_say_number_full_pt(chan, num, ints, language, options, -1, -1));
- } else if (!strcasecmp(language, "pl") ) { /* Polish syntax */
- return(ast_say_number_full_pl(chan, num, ints, language, options, -1, -1));
- } else if (!strcasecmp(language, "se")) { /* Swedish syntax */
- return(ast_say_number_full_se(chan, num, ints, language, options, -1, -1));
- }
-
- /* Default to english */
- return(ast_say_number_full_en(chan, num, ints, language, -1, -1));
+ return(ast_say_number_full(chan, num, ints, language, options, -1, -1));
}
/*--- ast_say_number_full_en: English syntax */
@@ -1104,7 +1079,7 @@ static int ast_say_number_full_it(struct ast_channel *chan, int num, char *ints,
} else {
if (num < 1000000) { /* 1,000,000 */
if ((num/1000) > 1)
- res = ast_say_number_full(chan, num / 1000, ints, language, audiofd, ctrlfd);
+ res = ast_say_number_full_it(chan, num / 1000, ints, language, audiofd, ctrlfd);
if (res)
return res;
tempnum = num;
@@ -1116,7 +1091,7 @@ static int ast_say_number_full_it(struct ast_channel *chan, int num, char *ints,
} else {
if (num < 1000000000) { /* 1,000,000,000 */
if ((num / 1000000) > 1)
- res = ast_say_number_full(chan, num / 1000000, ints, language, audiofd, ctrlfd);
+ res = ast_say_number_full_it(chan, num / 1000000, ints, language, audiofd, ctrlfd);
if (res)
return res;
tempnum = num;
@@ -1215,6 +1190,299 @@ static int ast_say_number_full_nl(struct ast_channel *chan, int num, char *ints,
return res;
}
+/* ast_say_number_full_pl: Polish syntax */
+static int ast_say_number_full_pl(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd)
+/*
+Sounds needed:
+0 zero
+1 jeden
+10 dziesiec
+100 sto
+1000 tysiac
+1000000 milion
+1000000000 miliard
+1000000000.2 miliardy
+1000000000.5 miliardow
+1000000.2 miliony
+1000000.5 milionow
+1000.2 tysiace
+1000.5 tysiecy
+100m stu
+10m dziesieciu
+11 jedenascie
+11m jedenastu
+12 dwanascie
+12m dwunastu
+13 trzynascie
+13m trzynastu
+14 czternascie
+14m czternastu
+15 pietnascie
+15m pietnastu
+16 szesnascie
+16m szesnastu
+17 siedemnascie
+17m siedemnastu
+18 osiemnascie
+18m osiemnastu
+19 dziewietnascie
+19m dziewietnastu
+1z jedna
+2 dwie
+20 dwadziescia
+200 dwiescie
+200m dwustu
+20m dwudziestu
+2-1m dwaj
+2-2m dwoch
+2z dwie
+3 trzy
+30 trzydziesci
+300 trzysta
+300m trzystu
+30m trzydziestu
+3-1m trzej
+3-2m trzech
+4 cztery
+40 czterdziesci
+400 czterysta
+400m czterystu
+40m czterdziestu
+4-1m czterej
+4-2m czterech
+5 piec
+50 piecdziesiat
+500 piecset
+500m pieciuset
+50m piedziesieciu
+5m pieciu
+6 szesc
+60 szescdziesiat
+600 szescset
+600m szesciuset
+60m szescdziesieciu
+6m szesciu
+7 siedem
+70 siedemdziesiat
+700 siedemset
+700m siedmiuset
+70m siedemdziesieciu
+7m siedmiu
+8 osiem
+80 osiemdziesiat
+800 osiemset
+800m osmiuset
+80m osiemdziesieciu
+8m osmiu
+9 dziewiec
+90 dziewiecdziesiat
+900 dziewiecset
+900m dziewieciuset
+90m dziewiedziesieciu
+9m dziewieciu
+and combinations of eg.: 20_1, 30m_3m, etc...
+
+*/
+{
+ typedef struct {
+ char *separator_dziesiatek;
+ char *cyfry[10];
+ char *cyfry2[10];
+ char *setki[10];
+ char *dziesiatki[10];
+ char *nastki[10];
+ char *rzedy[3][3];
+ } odmiana;
+
+ char *zenski_cyfry[] = {"0","1z", "2z", "3", "4", "5", "6", "7", "8", "9"};
+
+ char *zenski_cyfry2[] = {"0","1", "2z", "3", "4", "5", "6", "7", "8", "9"};
+
+ char *meski_cyfry[] = {"0","1", "2-1m", "3-1m", "4-1m", "5m", /*"2-1mdwaj"*/ "6m", "7m", "8m", "9m"};
+
+ char *meski_cyfry2[] = {"0","1", "2-2m", "3-2m", "4-2m", "5m", "6m", "7m", "8m", "9m"};
+
+ char *meski_setki[] = {"", "100m", "200m", "300m", "400m", "500m", "600m", "700m", "800m", "900m"};
+
+ char *meski_dziesiatki[] = {"", "10m", "20m", "30m", "40m", "50m", "60m", "70m", "80m", "90m"};
+
+ char *meski_nastki[] = {"", "11m", "12m", "13m", "14m", "15m", "16m", "17m", "18m", "19m"};
+
+ char *nijaki_cyfry[] = {"0","1", "2", "3", "4", "5", "6", "7", "8", "9"};
+
+ char *nijaki_cyfry2[] = {"0","1", "2", "3", "4", "5", "6", "7", "8", "9"};
+
+ char *nijaki_setki[] = {"", "100", "200", "300", "400", "500", "600", "700", "800", "900"};
+
+ char *nijaki_dziesiatki[] = {"", "10", "20", "30", "40", "50", "60", "70", "80", "90"};
+
+ char *nijaki_nastki[] = {"", "11", "12", "13", "14", "15", "16", "17", "18", "19"};
+
+ char *rzedy[][3] = { {"1000", "1000.2", "1000.5"}, {"1000000", "1000000.2", "1000000.5"}, {"1000000000", "1000000000.2", "1000000000.5"}};
+
+ /* Initialise variables to allow compilation on Debian-stable, etc */
+ odmiana *o;
+
+ static char* rzad_na_tekst(odmiana *odm, int i, int rzad)
+ {
+ if (rzad==0)
+ return "";
+
+ if (i==1)
+ return odm->rzedy[rzad - 1][0];
+
+ if ((i > 21 || i < 11) && i%10 > 1 && i%10 < 5)
+ return odm->rzedy[rzad - 1][1];
+ else
+ return odm->rzedy[rzad - 1][2];
+ }
+
+ static char* append(char* buffer, char* str)
+ {
+ strcpy(buffer, str);
+ buffer += strlen(str);
+ return buffer;
+ }
+
+ static void odtworz_plik(char *fn)
+ {
+ char file_name[255] = "digits/";
+ strcat(file_name, fn);
+ ast_log(LOG_DEBUG, "Trying to play: %s\n", file_name);
+ if (!ast_streamfile(chan, file_name, language)) {
+ if (audiofd && ctrlfd)
+ ast_waitstream_full(chan, ints, audiofd, ctrlfd);
+ else
+ ast_waitstream(chan, ints);
+ }
+ ast_stopstream(chan);
+ }
+
+ static void powiedz(odmiana *odm, int rzad, int i)
+ {
+ /* Initialise variables to allow compilation on Debian-stable, etc */
+ int m1000E6 = 0;
+ int i1000E6 = 0;
+ int m1000E3 = 0;
+ int i1000E3 = 0;
+ int m1000 = 0;
+ int i1000 = 0;
+ int m100 = 0;
+ int i100 = 0;
+
+ if (i == 0 && rzad > 0) {
+ return;
+ }
+ if (i == 0) {
+ odtworz_plik(odm->cyfry[0]);
+ }
+
+ m1000E6 = i % 1000000000;
+ i1000E6 = i / 1000000000;
+
+ powiedz(odm, rzad+3, i1000E6);
+
+ m1000E3 = m1000E6 % 1000000;
+ i1000E3 = m1000E6 / 1000000;
+
+ powiedz(odm, rzad+2, i1000E3);
+
+ m1000 = m1000E3 % 1000;
+ i1000 = m1000E3 / 1000;
+
+ powiedz(odm, rzad+1, i1000);
+
+ m100 = m1000 % 100;
+ i100 = m1000 / 100;
+
+ if (i100>0)
+ odtworz_plik(odm->setki[i100]);
+
+ if ( m100 > 0 && m100 <=9 ) {
+ if (m1000>0)
+ odtworz_plik(odm->cyfry2[m100]);
+ else
+ odtworz_plik(odm->cyfry[m100]);
+ } else if (m100 % 10 == 0) {
+ odtworz_plik(odm->dziesiatki[m100 / 10]);
+ } else if (m100 <= 19 ) {
+ odtworz_plik(odm->nastki[m100 % 10]);
+ } else if (m100 != 0) {
+ if (odm->separator_dziesiatek[0]==' ') {
+ odtworz_plik(odm->dziesiatki[m100 / 10]);
+ odtworz_plik(odm->cyfry2[m100 % 10]);
+ } else {
+ char buf[10];
+ char *b = buf;
+ b = append(b, odm->dziesiatki[m100 / 10]);
+ b = append(b, odm->separator_dziesiatek);
+ b = append(b, odm->cyfry2[m100 % 10]);
+ odtworz_plik(buf);
+ }
+ }
+
+ if (rzad > 0) {
+ odtworz_plik(rzad_na_tekst(odm, i, rzad));
+ }
+ }
+
+ static odmiana *odmiana_nieosobowa = NULL;
+ static odmiana *odmiana_meska = NULL;
+ static odmiana *odmiana_zenska = NULL;
+
+ if (odmiana_nieosobowa == NULL) {
+ odmiana_nieosobowa = (odmiana *) malloc(sizeof(odmiana));
+
+ odmiana_nieosobowa->separator_dziesiatek = "_";
+
+ memcpy(odmiana_nieosobowa->cyfry, nijaki_cyfry, sizeof(odmiana_nieosobowa->cyfry));
+ memcpy(odmiana_nieosobowa->cyfry2, nijaki_cyfry2, sizeof(odmiana_nieosobowa->cyfry));
+ memcpy(odmiana_nieosobowa->setki, nijaki_setki, sizeof(odmiana_nieosobowa->setki));
+ memcpy(odmiana_nieosobowa->dziesiatki, nijaki_dziesiatki, sizeof(odmiana_nieosobowa->dziesiatki));
+ memcpy(odmiana_nieosobowa->nastki, nijaki_nastki, sizeof(odmiana_nieosobowa->nastki));
+ memcpy(odmiana_nieosobowa->rzedy, rzedy, sizeof(odmiana_nieosobowa->rzedy));
+ }
+
+ if (odmiana_zenska == NULL) {
+ odmiana_zenska = (odmiana *) malloc(sizeof(odmiana));
+
+ odmiana_zenska->separator_dziesiatek = "_";
+
+ memcpy(odmiana_zenska->cyfry, zenski_cyfry, sizeof(odmiana_zenska->cyfry));
+ memcpy(odmiana_zenska->cyfry2, zenski_cyfry2, sizeof(odmiana_zenska->cyfry));
+ memcpy(odmiana_zenska->setki, nijaki_setki, sizeof(odmiana_zenska->setki));
+ memcpy(odmiana_zenska->dziesiatki, nijaki_dziesiatki, sizeof(odmiana_zenska->dziesiatki));
+ memcpy(odmiana_zenska->nastki, nijaki_nastki, sizeof(odmiana_zenska->nastki));
+ memcpy(odmiana_zenska->rzedy, rzedy, sizeof(odmiana_zenska->rzedy));
+ }
+
+ if (odmiana_meska == NULL) {
+ odmiana_meska = (odmiana *) malloc(sizeof(odmiana));
+
+ odmiana_meska->separator_dziesiatek = "_";
+
+ memcpy(odmiana_meska->cyfry, meski_cyfry, sizeof(odmiana_meska->cyfry));
+ memcpy(odmiana_meska->cyfry2, meski_cyfry2, sizeof(odmiana_meska->cyfry));
+ memcpy(odmiana_meska->setki, meski_setki, sizeof(odmiana_meska->setki));
+ memcpy(odmiana_meska->dziesiatki, meski_dziesiatki, sizeof(odmiana_meska->dziesiatki));
+ memcpy(odmiana_meska->nastki, meski_nastki, sizeof(odmiana_meska->nastki));
+ memcpy(odmiana_meska->rzedy, rzedy, sizeof(odmiana_meska->rzedy));
+ }
+
+ if (options) {
+ if (strncasecmp(options, "f", 1) == 0)
+ o = odmiana_zenska;
+ else if (strncasecmp(options, "m", 1) == 0)
+ o = odmiana_meska;
+ else
+ o = odmiana_nieosobowa;
+ } else
+ o = odmiana_nieosobowa;
+
+ powiedz(o, 0, num);
+ return 0;
+}
+
/* ast_say_number_full_pt: Portuguese syntax */
/* Extra sounds needed: */
/* For feminin all sound files end with F */
@@ -1399,14 +1667,14 @@ static int ast_say_number_full_tw(struct ast_channel *chan, int num, char *ints,
num -= ((num / 100) * 100);
} else {
if (num < 1000000) { /* 1,000,000 */
- res = ast_say_number_full_en(chan, num / 1000, ints, language, audiofd, ctrlfd);
+ res = ast_say_number_full_tw(chan, num / 1000, ints, language, audiofd, ctrlfd);
if (res)
return res;
num = num % 1000;
snprintf(fn, sizeof(fn), "digits/thousand");
} else {
if (num < 1000000000) { /* 1,000,000,000 */
- res = ast_say_number_full_en(chan, num / 1000000, ints, language, audiofd, ctrlfd);
+ res = ast_say_number_full_tw(chan, num / 1000000, ints, language, audiofd, ctrlfd);
if (res)
return res;
num = num % 1000000;
@@ -1432,312 +1700,6 @@ static int ast_say_number_full_tw(struct ast_channel *chan, int num, char *ints,
return res;
}
-/* ast_say_number_full_pl: Polish syntax */
-static int ast_say_number_full_pl(struct ast_channel *chan, int num, char *ints, char *language, char *options, int audiofd, int ctrlfd)
-/*
-Sounds needed:
-0 zero
-1 jeden
-10 dziesiec
-100 sto
-1000 tysiac
-1000000 milion
-1000000000 miliard
-1000000000.2 miliardy
-1000000000.5 miliardow
-1000000.2 miliony
-1000000.5 milionow
-1000.2 tysiace
-1000.5 tysiecy
-100m stu
-10m dziesieciu
-11 jedenascie
-11m jedenastu
-12 dwanascie
-12m dwunastu
-13 trzynascie
-13m trzynastu
-14 czternascie
-14m czternastu
-15 pietnascie
-15m pietnastu
-16 szesnascie
-16m szesnastu
-17 siedemnascie
-17m siedemnastu
-18 osiemnascie
-18m osiemnastu
-19 dziewietnascie
-19m dziewietnastu
-1z jedna
-2 dwie
-20 dwadziescia
-200 dwiescie
-200m dwustu
-20m dwudziestu
-2-1m dwaj
-2-2m dwoch
-2z dwie
-3 trzy
-30 trzydziesci
-300 trzysta
-300m trzystu
-30m trzydziestu
-3-1m trzej
-3-2m trzech
-4 cztery
-40 czterdziesci
-400 czterysta
-400m czterystu
-40m czterdziestu
-4-1m czterej
-4-2m czterech
-5 piec
-50 piecdziesiat
-500 piecset
-500m pieciuset
-50m piedziesieciu
-5m pieciu
-6 szesc
-60 szescdziesiat
-600 szescset
-600m szesciuset
-60m szescdziesieciu
-6m szesciu
-7 siedem
-70 siedemdziesiat
-700 siedemset
-700m siedmiuset
-70m siedemdziesieciu
-7m siedmiu
-8 osiem
-80 osiemdziesiat
-800 osiemset
-800m osmiuset
-80m osiemdziesieciu
-8m osmiu
-9 dziewiec
-90 dziewiecdziesiat
-900 dziewiecset
-900m dziewieciuset
-90m dziewiedziesieciu
-9m dziewieciu
-and combinations of eg.: 20_1, 30m_3m, etc...
-
-*/
-{
- typedef struct {
- char *separator_dziesiatek;
- char *cyfry[10];
- char *cyfry2[10];
- char *setki[10];
- char *dziesiatki[10];
- char *nastki[10];
- char *rzedy[3][3];
- } odmiana;
-
- char *zenski_cyfry[] = {
- "0","1z", "2z", "3", "4", "5",
- "6", "7", "8", "9"};
-
- char *zenski_cyfry2[] = {
- "0","1", "2z", "3", "4", "5",
- "6", "7", "8", "9"};
-
- char *meski_cyfry[] = {
- "0","1", "2-1m", "3-1m", "4-1m", "5m", /*"2-1mdwaj"*/
- "6m", "7m", "8m", "9m"};
-
- char *meski_cyfry2[] = {
- "0","1", "2-2m", "3-2m", "4-2m", "5m",
- "6m", "7m", "8m", "9m"};
-
- char *meski_setki[] = {
- "", "100m", "200m", "300m", "400m", "500m",
- "600m", "700m", "800m", "900m"};
-
- char *meski_dziesiatki[] = {
- "", "10m", "20m", "30m", "40m", "50m",
- "60m", "70m", "80m", "90m"};
-
- char *meski_nastki[] = {
- "", "11m", "12m", "13m", "14m", "15m",
- "16m", "17m", "18m", "19m"};
-
- char *nijaki_cyfry[] = {
- "0","1", "2", "3", "4", "5",
- "6", "7", "8", "9"};
-
- char *nijaki_cyfry2[] = {
- "0","1", "2", "3", "4", "5",
- "6", "7", "8", "9"};
-
- char *nijaki_setki[] = {
- "", "100", "200", "300", "400", "500",
- "600", "700", "800", "900"};
-
- char *nijaki_dziesiatki[] = {
- "", "10", "20", "30", "40", "50",
- "60", "70", "80", "90"};
-
- char *nijaki_nastki[] = {
- "", "11", "12", "13", "14", "15",
- "16", "17", "18", "19"};
-
- char *rzedy[][3] = {
- {"1000", "1000.2", "1000.5"},
- {"1000000", "1000000.2", "1000000.5"},
- {"1000000000", "1000000000.2", "1000000000.5"}};
-
- static char* rzad_na_tekst(odmiana *odm, int i, int rzad) {
- if(rzad==0) return "";
-
- if(i==1)
- return odm->rzedy[rzad - 1][0];
-
- if((i > 21 || i < 11) && i%10 > 1 && i%10 < 5)
- return odm->rzedy[rzad - 1][1];
- else
- return odm->rzedy[rzad - 1][2];
- }
-
- static char* append(char* buffer, char* str) {
- strcpy(buffer, str);
- buffer += strlen(str);
- return buffer;
- }
-
- static void odtworz_plik(char *fn) {
- char file_name[255] = "digits/";
- strcat(file_name, fn);
- ast_log(LOG_DEBUG, "Trying to play: %s\n", file_name);
- if(!ast_streamfile(chan, file_name, language)) {
- if (audiofd && ctrlfd)
- ast_waitstream_full(chan, ints, audiofd, ctrlfd);
- else
- ast_waitstream(chan, ints);
- }
- ast_stopstream(chan);
- }
-
-
- static void powiedz(odmiana *odm, int rzad, int i) {
-
- if(i == 0 && rzad > 0)
- return;
-
- if(i == 0) {
- odtworz_plik(odm->cyfry[0]);
- }
-
- int m1000E6 = i % 1000000000;
- int i1000E6 = i / 1000000000;
-
- powiedz(odm, rzad+3, i1000E6);
-
- int m1000E3 = m1000E6 % 1000000;
- int i1000E3 = m1000E6 / 1000000;
-
- powiedz(odm, rzad+2, i1000E3);
-
- int m1000 = m1000E3 % 1000;
- int i1000 = m1000E3 / 1000;
-
- powiedz(odm, rzad+1, i1000);
-
- int m100 = m1000 % 100;
- int i100 = m1000 / 100;
-
- if(i100>0)
- odtworz_plik(odm->setki[i100]);
-
- if( m100 > 0 && m100 <=9 ) {
- if(m1000>0)
- odtworz_plik(odm->cyfry2[m100]);
- else
- odtworz_plik(odm->cyfry[m100]);
- } else if(m100 % 10 == 0) {
- odtworz_plik(odm->dziesiatki[m100 / 10]);
- } else if(m100 <= 19 ) {
- odtworz_plik(odm->nastki[m100 % 10]);
- } else if(m100 != 0){
- if(odm->separator_dziesiatek[0]==' ') {
- odtworz_plik(odm->dziesiatki[m100 / 10]);
- odtworz_plik(odm->cyfry2[m100 % 10]);
- } else {
- char buf[10];
- char *b = buf;
- b = append(b, odm->dziesiatki[m100 / 10]);
- b = append(b, odm->separator_dziesiatek);
- b = append(b, odm->cyfry2[m100 % 10]);
- odtworz_plik(buf);
- }
- }
-
- if(rzad > 0) {
- odtworz_plik(rzad_na_tekst(odm, i, rzad));
- }
- }
-
- static odmiana *odmiana_nieosobowa = NULL;
- static odmiana *odmiana_meska = NULL;
- static odmiana *odmiana_zenska = NULL;
-
- if(odmiana_nieosobowa == NULL) {
- odmiana_nieosobowa = (odmiana *) malloc(sizeof(odmiana));
-
- odmiana_nieosobowa->separator_dziesiatek = "_";
-
- memcpy(odmiana_nieosobowa->cyfry, nijaki_cyfry, sizeof(odmiana_nieosobowa->cyfry));
- memcpy(odmiana_nieosobowa->cyfry2, nijaki_cyfry2, sizeof(odmiana_nieosobowa->cyfry));
- memcpy(odmiana_nieosobowa->setki, nijaki_setki, sizeof(odmiana_nieosobowa->setki));
- memcpy(odmiana_nieosobowa->dziesiatki, nijaki_dziesiatki, sizeof(odmiana_nieosobowa->dziesiatki));
- memcpy(odmiana_nieosobowa->nastki, nijaki_nastki, sizeof(odmiana_nieosobowa->nastki));
- memcpy(odmiana_nieosobowa->rzedy, rzedy, sizeof(odmiana_nieosobowa->rzedy));
- }
-
- if(odmiana_zenska == NULL) {
- odmiana_zenska = (odmiana *) malloc(sizeof(odmiana));
-
- odmiana_zenska->separator_dziesiatek = "_";
-
- memcpy(odmiana_zenska->cyfry, zenski_cyfry, sizeof(odmiana_zenska->cyfry));
- memcpy(odmiana_zenska->cyfry2, zenski_cyfry2, sizeof(odmiana_zenska->cyfry));
- memcpy(odmiana_zenska->setki, nijaki_setki, sizeof(odmiana_zenska->setki));
- memcpy(odmiana_zenska->dziesiatki, nijaki_dziesiatki, sizeof(odmiana_zenska->dziesiatki));
- memcpy(odmiana_zenska->nastki, nijaki_nastki, sizeof(odmiana_zenska->nastki));
- memcpy(odmiana_zenska->rzedy, rzedy, sizeof(odmiana_zenska->rzedy));
- }
-
- if(odmiana_meska == NULL) {
- odmiana_meska = (odmiana *) malloc(sizeof(odmiana));
-
- odmiana_meska->separator_dziesiatek = "_";
-
- memcpy(odmiana_meska->cyfry, meski_cyfry, sizeof(odmiana_meska->cyfry));
- memcpy(odmiana_meska->cyfry2, meski_cyfry2, sizeof(odmiana_meska->cyfry));
- memcpy(odmiana_meska->setki, meski_setki, sizeof(odmiana_meska->setki));
- memcpy(odmiana_meska->dziesiatki, meski_dziesiatki, sizeof(odmiana_meska->dziesiatki));
- memcpy(odmiana_meska->nastki, meski_nastki, sizeof(odmiana_meska->nastki));
- memcpy(odmiana_meska->rzedy, rzedy, sizeof(odmiana_meska->rzedy));
- }
-
- odmiana *o;
-
- if (options) {
- if(strncasecmp(options, "f", 1) == 0)
- o = odmiana_zenska;
- else if(strncasecmp(options, "m", 1) == 0)
- o = odmiana_meska;
- else
- o = odmiana_nieosobowa;
- } else
- o = odmiana_nieosobowa;
-
- powiedz(o, 0, num);
- return 0;
-}
-
int ast_say_date(struct ast_channel *chan, time_t t, char *ints, char *lang)
{
@@ -1753,7 +1715,6 @@ int ast_say_date(struct ast_channel *chan, time_t t, char *ints, char *lang)
return(ast_say_date_en(chan, t, ints, lang));
}
-
/* English syntax */
int ast_say_date_en(struct ast_channel *chan, time_t t, char *ints, char *lang)
{