[asterisk-commits] mmichelson: trunk r169794 - /trunk/main/say.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Wed Jan 21 16:10:02 CST 2009
Author: mmichelson
Date: Wed Jan 21 16:10:02 2009
New Revision: 169794
URL: http://svn.digium.com/svn-view/asterisk?view=rev&rev=169794
Log:
Fix a crash when saying certain numbers in Chinese
This commit fixes a crash that was occurring when attempting to
say a number between 10000 and 100000 due to dividing by 0.
This also removes some places where a "zero" is spoken when it
should not be.
(closes issue #14291)
Reported by: dant
Patches:
say.c-14291.diff uploaded by dant (license 670)
Tested by: dant
Modified:
trunk/main/say.c
Modified: trunk/main/say.c
URL: http://svn.digium.com/svn-view/asterisk/trunk/main/say.c?view=diff&rev=169794&r1=169793&r2=169794
==============================================================================
--- trunk/main/say.c (original)
+++ trunk/main/say.c Wed Jan 21 16:10:02 2009
@@ -2308,11 +2308,6 @@
num -= ((num / 100) * 100);
} else if (num < 10000){
snprintf(buf, 10, "%d", num);
- if (last_length - strlen(buf) > 1 && last_length != 0 && last_length % strlen(buf) > 0) {
- last_length = strlen(buf);
- playz++;
- continue;
- }
snprintf(fn, sizeof(fn), "digits/%d", (num / 1000));
playt++;
snprintf(buf, 10, "%d", num);
@@ -2323,9 +2318,6 @@
res = ast_say_number_full_tw(chan, num / 10000, ints, language, audiofd, ctrlfd);
if (res)
return res;
- if (((num / 10000) % (num/100000)) == 0)
- playz++;
-
snprintf(buf, 10, "%d", num);
ast_log(LOG_DEBUG, "Number '%d' %d %d\n", num, (int)strlen(buf), last_length);
num -= ((num / 10000) * 10000);
More information about the asterisk-commits
mailing list