diff options
author | bweschke <bweschke@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-01-12 15:11:49 +0000 |
---|---|---|
committer | bweschke <bweschke@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-01-12 15:11:49 +0000 |
commit | 911d39f5e22b51a5f801aeb77d333b2e7c60b1c4 (patch) | |
tree | abc93b47e7141a982495bdec6ded971038d8bc31 | |
parent | 44fc546afbf878a39e9ef2de0c5c33c9ce95b298 (diff) |
Use argument macro in app_dictate #6222
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@8007 f38db490-d61c-443f-a65b-d21fe96a405b
-rw-r--r-- | apps/app_dictate.c | 28 |
1 files changed, 19 insertions, 9 deletions
diff --git a/apps/app_dictate.c b/apps/app_dictate.c index 66f99e147..3935c81ac 100644 --- a/apps/app_dictate.c +++ b/apps/app_dictate.c @@ -82,7 +82,12 @@ static int play_and_wait(struct ast_channel *chan, char *file, char *digits) static int dictate_exec(struct ast_channel *chan, void *data) { - char *mydata, *argv[3], *path = NULL, filein[256], *filename = ""; + char *path = NULL, filein[256], *filename = ""; + char *parse; + AST_DECLARE_APP_ARGS(args, + AST_APP_ARG(base); + AST_APP_ARG(filename); + ); char dftbase[256]; char *base; struct ast_flags flags = {0}; @@ -91,7 +96,6 @@ static int dictate_exec(struct ast_channel *chan, void *data) struct localuser *u; int ffactor = 320 * 80, res = 0, - argc = 0, done = 0, oldr = 0, lastop = 0, @@ -105,17 +109,23 @@ static int dictate_exec(struct ast_channel *chan, void *data) LOCAL_USER_ADD(u); snprintf(dftbase, sizeof(dftbase), "%s/dictate", ast_config_AST_SPOOL_DIR); - if (!ast_strlen_zero(data) && (mydata = ast_strdupa(data))) { - argc = ast_app_separate_args(mydata, '|', argv, sizeof(argv) / sizeof(argv[0])); - } + if (!ast_strlen_zero(data)) { + parse = ast_strdupa(data); + if (!parse) { + ast_log(LOG_ERROR, "Out of memory!\n"); + return -1; + } + AST_STANDARD_APP_ARGS(args, parse); + } else + args.argc = 0; - if (argc) { - base = argv[0]; + if (args.argc && !ast_strlen_zero(args.base)) { + base = args.base; } else { base = dftbase; } - if (argc && argv[1]) { - filename = argv[1]; + if (args.argc > 1 && args.filename) { + filename = args.filename; } oldr = chan->readformat; if ((res = ast_set_read_format(chan, AST_FORMAT_SLINEAR)) < 0) { |