diff options
author | Tilghman Lesher <tilghman@meg.abyt.es> | 2008-05-21 13:39:41 +0000 |
---|---|---|
committer | Tilghman Lesher <tilghman@meg.abyt.es> | 2008-05-21 13:39:41 +0000 |
commit | ffc9f89189de44fcfb2995a0498bb8baeb2cac51 (patch) | |
tree | 99e8c1c82227cef01eeab3ccdbd380801188377a /apps/app_externalivr.c | |
parent | e1ae86f643c5ca1b6cd657c9d6bad4e5b4979e05 (diff) |
On socket-based connections, there is no error FD, so don't try waiting on one.
(closes issue #12697)
Reported by: ctooley
Patches:
fix_externalivr_waitfor_nandfds-v3.diff uploaded by ctooley (license 136)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@117431 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'apps/app_externalivr.c')
-rw-r--r-- | apps/app_externalivr.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/apps/app_externalivr.c b/apps/app_externalivr.c index 6068e5f48..8dbc53e76 100644 --- a/apps/app_externalivr.c +++ b/apps/app_externalivr.c @@ -379,7 +379,7 @@ static int app_exec(struct ast_channel *chan, void *data) if (!ser) { goto exit; } - res = eivr_comm(chan, u, ser->fd, ser->fd, 0, pipe_delim_argbuf); + res = eivr_comm(chan, u, ser->fd, ser->fd, -1, pipe_delim_argbuf); } else { if (pipe(child_stdin)) { @@ -495,7 +495,7 @@ static int eivr_comm(struct ast_channel *chan, struct ivr_localuser *u, ast_chan_log(LOG_WARNING, chan, "Could not open stream to receive commands\n"); goto exit; } - if(eivr_errors_fd) { /* if opening a socket connection, error stream will not be used */ + if (eivr_errors_fd > -1) { /* if opening a socket connection, error stream will not be used */ if (!(eivr_errors = fdopen(eivr_errors_fd, "r"))) { ast_chan_log(LOG_WARNING, chan, "Could not open stream to receive errors\n"); goto exit; @@ -529,7 +529,7 @@ static int eivr_comm(struct ast_channel *chan, struct ivr_localuser *u, errno = 0; exception = 0; - rchan = ast_waitfor_nandfds(&chan, 1, waitfds, 2, &exception, &ready_fd, &ms); + rchan = ast_waitfor_nandfds(&chan, 1, waitfds, (eivr_errors_fd < 0) ? 1 : 2, &exception, &ready_fd, &ms); if (!AST_LIST_EMPTY(&u->finishlist)) { AST_LIST_LOCK(&u->finishlist); |