]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Correctly reset the dialplan priority.
authorTilghman Lesher <tilghman@meg.abyt.es>
Tue, 28 Feb 2012 21:21:14 +0000 (21:21 +0000)
committerTilghman Lesher <tilghman@meg.abyt.es>
Tue, 28 Feb 2012 21:21:14 +0000 (21:21 +0000)
When the stack frame is allocated, we save the address to which we should
return, when the Gosub returns.  However, if we just want to restore the
priority, then we need to subtract 1 before setting it.  Otherwise, when
a Gosub goes to a nonexistent address, it will skip a priority in the
dialplan.  This is because when we return from an application, the PBX
increments the priority for us.
........

Merged revisions 357416 from http://svn.asterisk.org/svn/asterisk/branches/1.8

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/10@357421 65c4cc65-6c06-0410-ace0-fbb531ad65f3

apps/app_stack.c

index c5f0b6affb6d86f7b4e4dd58244acf121ecd425d..9be935a2f8977cdfaea4067ba76ffdc34eb04f15 100644 (file)
@@ -421,7 +421,7 @@ static int gosub_exec(struct ast_channel *chan, const char *data)
                                chan->context, chan->exten, ast_test_flag(chan, AST_FLAG_IN_AUTOLOOP) ? chan->priority + 1 : chan->priority);
                ast_copy_string(chan->context, newframe->context, sizeof(chan->context));
                ast_copy_string(chan->exten, newframe->extension, sizeof(chan->exten));
-               chan->priority = newframe->priority;
+               chan->priority = newframe->priority - 1;
                ast_free(newframe);
                return -1;
        }