Properly report the hangup cause as no answer when someone does not answer

(closes issue #10574, reported by boch, patched by moy)



git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@98315 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Mark Michelson
2008-01-11 19:10:57 +00:00
parent 42d3e979f6
commit d97e842d55

View File

@@ -3112,6 +3112,7 @@ struct ast_channel *__ast_request_and_dial(const char *type, int format, void *d
int cause = 0;
struct ast_channel *chan;
int res = 0;
int last_subclass = 0;
if (outstate)
*outstate = 0;
@@ -3193,6 +3194,7 @@ struct ast_channel *__ast_request_and_dial(const char *type, int format, void *d
default:
ast_log(LOG_NOTICE, "Don't know what to do with control frame %d\n", f->subclass);
}
last_subclass = f->subclass;
}
ast_frfree(f);
}
@@ -3211,6 +3213,8 @@ struct ast_channel *__ast_request_and_dial(const char *type, int format, void *d
*outstate = AST_CONTROL_ANSWER;
if (res <= 0) {
if ( AST_CONTROL_RINGING == last_subclass )
chan->hangupcause = AST_CAUSE_NO_ANSWER;
if (!chan->cdr && (chan->cdr = ast_cdr_alloc()))
ast_cdr_init(chan->cdr, chan);
if (chan->cdr) {