Merged revisions 59963 via svnmerge from
authorJoshua Colp <jcolp@digium.com>
Tue, 3 Apr 2007 19:43:26 +0000 (19:43 +0000)
committerJoshua Colp <jcolp@digium.com>
Tue, 3 Apr 2007 19:43:26 +0000 (19:43 +0000)
https://origsvn.digium.com/svn/asterisk/branches/1.4

........
r59963 | file | 2007-04-03 15:40:59 -0400 (Tue, 03 Apr 2007) | 2 lines

Don't clash when a person both speaks and uses DTMF.

........

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@59969 65c4cc65-6c06-0410-ace0-fbb531ad65f3

apps/app_speech_utils.c

index b430a40..cf8964e 100644 (file)
@@ -590,7 +590,7 @@ static int speech_background(struct ast_channel *chan, void *data)
                 }
 
                /* Do timeout check (shared between audio/dtmf) */
-               if (!quieted && started == 1) {
+               if ((!quieted || strlen(dtmf)) && started == 1) {
                        time(&current);
                        if ((current-start) >= timeout) {
                                done = 1;
@@ -677,11 +677,13 @@ static int speech_background(struct ast_channel *chan, void *data)
                                } else {
                                        if (chan->stream != NULL) {
                                                ast_stopstream(chan);
+                                       }
+                                       if (!started) {
                                                /* Change timeout to be 5 seconds for DTMF input */
                                                timeout = (chan->pbx && chan->pbx->dtimeout) ? chan->pbx->dtimeout : 5;
-                                               time(&start);
                                                started = 1;
                                        }
+                                       time(&start);
                                        snprintf(tmp, sizeof(tmp), "%c", f->subclass);
                                        strncat(dtmf, tmp, sizeof(dtmf));
                                }