aboutsummaryrefslogtreecommitdiffstats
path: root/channels/chan_misdn.c
diff options
context:
space:
mode:
authorcrichter <crichter@f38db490-d61c-443f-a65b-d21fe96a405b>2008-01-03 12:08:40 +0000
committercrichter <crichter@f38db490-d61c-443f-a65b-d21fe96a405b>2008-01-03 12:08:40 +0000
commit4bcd8455f9f4bacdbfb881c76e89a7b36d4177a2 (patch)
tree272a1016509b4d56a050f721febbacf1b0bcc474 /channels/chan_misdn.c
parent1bd8291680e2a7336df5904f6454d63c9c6cfc7c (diff)
when overlapdial was used and no number was dialed, the call was dropped, now we just jump into the s extension, which makes a lot more sense.
git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.4@96198 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_misdn.c')
-rw-r--r--channels/chan_misdn.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/channels/chan_misdn.c b/channels/chan_misdn.c
index 2233ca02b..b2d42ffe9 100644
--- a/channels/chan_misdn.c
+++ b/channels/chan_misdn.c
@@ -672,9 +672,16 @@ static int misdn_overlap_dial_task (const void *data)
diff = ast_tvdiff_ms(tv_end, tv_now);
if (diff <= 100) {
+ char *dad=ch->bc->dad, sexten[]="s";
/* if we are 100ms near the timeout, we are satisfied.. */
stop_indicate(ch);
- if (ast_exists_extension(ch->ast, ch->context, ch->bc->dad, 1, ch->bc->oad)) {
+
+ if (ast_strlen_zero(ch->bc->dad)) {
+ dad=sexten;
+ strcpy(ch->ast->exten, sexten);
+ }
+
+ if (ast_exists_extension(ch->ast, ch->context, dad, 1, ch->bc->oad)) {
ch->state=MISDN_DIALING;
if (pbx_start_chan(ch) < 0) {
chan_misdn_log(-1, ch->bc->port, "ast_pbx_start returned < 0 in misdn_overlap_dial_task\n");