diff options
author | Mark Spencer <markster@digium.com> | 2003-03-27 16:02:10 +0000 |
---|---|---|
committer | Mark Spencer <markster@digium.com> | 2003-03-27 16:02:10 +0000 |
commit | d73281e230dd42362a96551da2dca25e3858e01c (patch) | |
tree | 222ea4bebf2753e9bfaf2022d13b51934a0610e0 /apps/app_dial.c | |
parent | f4c5c7a8f1e89d67681450737005144ccfd37c52 (diff) |
Check for call forwarding while waiting for answer, too
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@705 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'apps/app_dial.c')
-rwxr-xr-x | apps/app_dial.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/apps/app_dial.c b/apps/app_dial.c index d1f0b5f60..b1edad6f4 100755 --- a/apps/app_dial.c +++ b/apps/app_dial.c @@ -186,6 +186,17 @@ static struct ast_channel *wait_for_answer(struct ast_channel *in, struct localu *allowdisconnect = o->allowdisconnect; } } else if (o->chan == winner) { + if (strlen(o->chan->call_forward)) { + /* Before processing channel, go ahead and check for forwarding */ + if (option_verbose > 2) + ast_verbose(VERBOSE_PREFIX_3 "Now forwarding %s to '%s@%s' (thanks to %s)\n", in->name, o->chan->call_forward, o->chan->context, o->chan->name); + /* Setup parameters */ + strncpy(in->exten, o->chan->call_forward, sizeof(in->exten)); + strncpy(in->context, o->chan->context, sizeof(in->context)); + in->priority = 0; + *to = 0; + break; + } f = ast_read(winner); if (f) { if (f->frametype == AST_FRAME_CONTROL) { |