From d73281e230dd42362a96551da2dca25e3858e01c Mon Sep 17 00:00:00 2001
From: Mark Spencer <markster@digium.com>
Date: Thu, 27 Mar 2003 16:02:10 +0000
Subject: [PATCH] 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
---
 apps/app_dial.c | 11 +++++++++++
 1 file changed, 11 insertions(+)

diff --git a/apps/app_dial.c b/apps/app_dial.c
index d1f0b5f609..b1edad6f47 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) {