[Asterisk-cvs] asterisk say.c,1.32,1.33

markster at lists.digium.com markster at lists.digium.com
Sat May 15 11:23:11 CDT 2004


Update of /usr/cvsroot/asterisk
In directory mongoose.digium.com:/tmp/cvs-serv17639

Modified Files:
	say.c 
Log Message:
Update coding guidelines, fix "say.c" compile on older compilers, update coding guidelines (includes bug #1631)


Index: say.c
===================================================================
RCS file: /usr/cvsroot/asterisk/say.c,v
retrieving revision 1.32
retrieving revision 1.33
diff -u -d -r1.32 -r1.33
--- say.c	13 May 2004 21:39:43 -0000	1.32
+++ say.c	15 May 2004 15:34:31 -0000	1.33
@@ -409,10 +409,10 @@
       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_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 @@
 
 /*--- 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 @@
 	   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 @@
 /*--- 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 @@
 				} 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 @@
 					} 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 @@
 	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 @@
 					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 @@
 	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)
 {
@@ -1752,7 +1714,6 @@
 	/* Default to English */
 	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)




More information about the svn-commits mailing list