Make sure that waitfordigit_full doesn't hangup on -EINTR (bug #3831)
authorMark Spencer <markster@digium.com>
Tue, 22 Mar 2005 22:44:55 +0000 (22:44 +0000)
committerMark Spencer <markster@digium.com>
Tue, 22 Mar 2005 22:44:55 +0000 (22:44 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5232 65c4cc65-6c06-0410-ace0-fbb531ad65f3

channel.c

index 6dd8220..74862e6 100755 (executable)
--- a/channel.c
+++ b/channel.c
@@ -1173,6 +1173,8 @@ char ast_waitfordigit_full(struct ast_channel *c, int ms, int audiofd, int cmdfd
        while(ms) {
                rchan = ast_waitfor_nandfds(&c, 1, &cmdfd, (cmdfd > -1) ? 1 : 0, NULL, &outfd, &ms);
                if ((!rchan) && (outfd < 0) && (ms)) { 
+                       if (errno == EINTR)
+                               continue;
                        ast_log(LOG_WARNING, "Wait failed (%s)\n", strerror(errno));
                        return -1;
                } else if (outfd > -1) {