mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-05 20:20:07 +00:00
Don't clash when a person both speaks and uses DTMF.
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@59963 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -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(¤t);
|
||||
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));
|
||||
}
|
||||
|
Reference in New Issue
Block a user