Update coding guidelines, fix "say.c" compile on older compilers, update coding guide...
authorMark Spencer <markster@digium.com>
Sat, 15 May 2004 15:34:31 +0000 (15:34 +0000)
committerMark Spencer <markster@digium.com>
Sat, 15 May 2004 15:34:31 +0000 (15:34 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@2967 65c4cc65-6c06-0410-ace0-fbb531ad65f3

apps/app_agi.c
doc/CODING-GUIDELINES
include/asterisk/say.h
say.c

index fb73338..ba479b2 100755 (executable)
@@ -364,6 +364,9 @@ static int handle_streamfile(struct ast_channel *chan, AGI *agi, int argc, char
                return RESULT_FAILURE;
 }
 
+/*--- handle_saynumber: Say number in various language syntaxes ---*/
+/* Need to add option for gender here as well. Coders wanted */
+/* While waiting, we're sending a (char *) NULL.  */
 static int handle_saynumber(struct ast_channel *chan, AGI *agi, int argc, char *argv[])
 {
        int res;
@@ -372,7 +375,7 @@ static int handle_saynumber(struct ast_channel *chan, AGI *agi, int argc, char *
                return RESULT_SHOWUSAGE;
        if (sscanf(argv[2], "%i", &num) != 1)
                return RESULT_SHOWUSAGE;
-       res = ast_say_number_full(chan, num, argv[3], chan->language, agi->audio, agi->ctrl);
+       res = ast_say_number_full(chan, num, argv[3], chan->language, (char *) NULL, agi->audio, agi->ctrl);
        if (res == 1)
                return RESULT_SUCCESS;
        fdprintf(agi->fd, "200 result=%d\n", res);
index 7d621b4..04b5b38 100755 (executable)
@@ -6,6 +6,11 @@ see http://bugs.digium.com
 
 Patches should be in the form of a unified (-u) diff.
 
+All code, filenames, function names and comments must be in ENGLISH.
+
+Do not declare variables mid-function (e.g. like GNU lets you) since it is
+harder to read and not portable to GCC 2.95 and others.
+
 Don't annotate your changes with comments like "/* JMG 4/20/04 */";
 Comments should explain what the code does, not when something was changed
 or who changed it.
index cc691bd..e8b235e 100755 (executable)
@@ -36,7 +36,7 @@ extern "C" {
 int ast_say_number(struct ast_channel *chan, int num, char *ints, char *lang, char *options);
 
 /* Same as above with audiofd for received audio and returns 1 on ctrlfd being readable */
-int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *lang, int audiofd, int ctrlfd);
+int ast_say_number_full(struct ast_channel *chan, int num, char *ints, char *lang, char *options, int audiofd, int ctrlfd);
 
 //! says digits
 /*!
diff --git a/say.c b/say.c
index 482416d..c527d9a 100755 (executable)
--- 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)
 {