aboutsummaryrefslogtreecommitdiffstats
path: root/apps/app_read.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2003-11-10 04:54:02 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2003-11-10 04:54:02 +0000
commitebe2223e496f204b991b336f44c1b2a5c735c7b2 (patch)
treeb67bac29a9b818224ffa39d2de534d93ac917eb0 /apps/app_read.c
parentd4979e8fcaf1100be03185c85069a6a51196b55f (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-xapps/app_read.c9
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;