diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-11-10 04:54:02 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-11-10 04:54:02 +0000 |
commit | ebe2223e496f204b991b336f44c1b2a5c735c7b2 (patch) | |
tree | b67bac29a9b818224ffa39d2de534d93ac917eb0 /apps/app_read.c | |
parent | d4979e8fcaf1100be03185c85069a6a51196b55f (diff) |
Store read data in a variable
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1716 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'apps/app_read.c')
-rwxr-xr-x | apps/app_read.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/apps/app_read.c b/apps/app_read.c index 1c6dd862b..fcb89fd94 100755 --- a/apps/app_read.c +++ b/apps/app_read.c @@ -19,6 +19,7 @@ #include <asterisk/app.h> #include <asterisk/module.h> #include <asterisk/translate.h> +#include <asterisk/options.h> #include <string.h> #include <stdlib.h> #include <pthread.h> @@ -54,6 +55,10 @@ static int read_exec(struct ast_channel *chan, void *data) stringp=tmp; strsep(&stringp, "|"); filename = strsep(&stringp, "|"); + if (!strlen(tmp)) { + ast_log(LOG_WARNING, "Read requires an variable name\n"); + return -1; + } LOCAL_USER_ADD(u); if (chan->_state != AST_STATE_UP) { /* Answer if the line isn't up. */ @@ -62,7 +67,9 @@ static int read_exec(struct ast_channel *chan, void *data) if (!res) { ast_stopstream(chan); res = ast_app_getdata(chan, filename, tmp2, sizeof(tmp2) - 1, 0); - ast_verbose("You entered '%s'\n", tmp2); + if (!res) + pbx_builtin_setvar_helper(chan, tmp, tmp2); + ast_verbose(VERBOSE_PREFIX_3 "User entered '%s'\n", tmp2); } LOCAL_USER_REMOVE(u); return res; |