]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Better handle timeouts when the individual speaks after everything has been played...
authorJoshua Colp <jcolp@digium.com>
Wed, 28 Feb 2007 17:45:50 +0000 (17:45 +0000)
committerJoshua Colp <jcolp@digium.com>
Wed, 28 Feb 2007 17:45:50 +0000 (17:45 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@57053 65c4cc65-6c06-0410-ace0-fbb531ad65f3

apps/app_speech_utils.c

index a2a0757676fb18580b51de8b612490394d971ae3..5e236ddc64dbb077868095a303ba9f95833f5401 100644 (file)
@@ -587,7 +587,7 @@ static int speech_background(struct ast_channel *chan, void *data)
                 }
 
                /* Do timeout check (shared between audio/dtmf) */
-               if (started == 1) {
+               if (!quieted && started == 1) {
                        time(&current);
                        if ((current-start) >= timeout) {
                                done = 1;
@@ -599,8 +599,9 @@ static int speech_background(struct ast_channel *chan, void *data)
 
                 /* Do checks on speech structure to see if it's changed */
                 ast_mutex_lock(&speech->lock);
-                if (ast_test_flag(speech, AST_SPEECH_QUIET) && chan->stream != NULL) {
-                        ast_stopstream(chan);
+                if (ast_test_flag(speech, AST_SPEECH_QUIET)) {
+                       if (chan->stream)
+                               ast_stopstream(chan);
                        ast_clear_flag(speech, AST_SPEECH_QUIET);
                        quieted = 1;
                 }