Version 0.1.10 from FTP

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@398 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Mark Spencer
2001-12-27 11:07:33 +00:00
parent c27ef7f85c
commit f2784d97fd
8 changed files with 1309 additions and 77 deletions

22
say.c
View File

@@ -17,7 +17,7 @@
#include <asterisk/say.h>
#include <stdio.h>
int ast_say_digit_str(struct ast_channel *chan, char *fn2, char *lang)
int ast_say_digit_str(struct ast_channel *chan, char *fn2, char *ints, char *lang)
{
char fn[256] = "";
int num = 0;
@@ -26,26 +26,26 @@ int ast_say_digit_str(struct ast_channel *chan, char *fn2, char *lang)
snprintf(fn, sizeof(fn), "digits/%c", fn2[num]);
res = ast_streamfile(chan, fn, lang);
if (!res)
res = ast_waitstream(chan, AST_DIGIT_ANY);
res = ast_waitstream(chan, ints);
ast_stopstream(chan);
num++;
}
return res;
}
int ast_say_digits(struct ast_channel *chan, int num, char *lang)
int ast_say_digits(struct ast_channel *chan, int num, char *ints, char *lang)
{
char fn2[256];
snprintf(fn2, sizeof(fn2), "%d", num);
return ast_say_digit_str(chan, fn2, lang);
return ast_say_digit_str(chan, fn2, ints, lang);
}
int ast_say_number(struct ast_channel *chan, int num, char *language)
int ast_say_number(struct ast_channel *chan, int num, char *ints, char *language)
{
int res = 0;
int playh = 0;
char fn[256] = "";
if (!num)
return ast_say_digits(chan, 0,language);
return ast_say_digits(chan, 0,ints, language);
if (0) {
/* XXX Only works for english XXX */
} else {
@@ -70,12 +70,16 @@ int ast_say_number(struct ast_channel *chan, int num, char *language)
num -= ((num / 100) * 100);
} else {
if (num < 1000000) {
ast_say_number(chan, num / 1000, language);
res = ast_say_number(chan, num / 1000, ints, language);
if (res)
return res;
num = num % 1000;
snprintf(fn, sizeof(fn), "digits/thousand");
} else {
if (num < 1000000000) {
ast_say_number(chan, num / 1000000, language);
res = ast_say_number(chan, num / 1000000, ints, language);
if (res)
return res;
num = num % 1000000;
snprintf(fn, sizeof(fn), "digits/million");
} else {
@@ -88,7 +92,7 @@ int ast_say_number(struct ast_channel *chan, int num, char *language)
if (!res) {
res = ast_streamfile(chan, fn, language);
if (!res)
res = ast_waitstream(chan, AST_DIGIT_ANY);
res = ast_waitstream(chan, ints);
ast_stopstream(chan);
}