[asterisk-commits] rmudgett: branch 11 r419631 - in /branches/11: ./ main/features.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Fri Jul 25 18:13:51 CDT 2014
Author: rmudgett
Date: Fri Jul 25 18:13:48 2014
New Revision: 419631
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=419631
Log:
features.c: Allow appliationmap to use Gosub.
Using DYNAMIC_FEATURES with a Gosub application as the mapped application
does not work. It does not work because Gosub just pushes the current
dialplan context, exten, and priority onto a stack and sets the specified
Gosub location. Gosub does not have a dialplan execution loop to run
dialplan like Macro.
* Made the DYNAMIC_FEATURES application mapping feature call
ast_app_exec_macro() and ast_app_exec_sub() for the Macro and Gosub
applications respectively.
* Backported ast_app_exec_macro() and ast_app_exec_sub() from v11 to
execute dialplan routines from the DYNAMIC_FEATURES application mapping
feature.
NOTE: This issue does not affect v12+ because it already does what this
patch implements.
AST-1391 #close
Reported by: Guenther Kelleter
Review: https://reviewboard.asterisk.org/r/3844/
........
Merged revisions 419630 from http://svn.asterisk.org/svn/asterisk/branches/1.8
Modified:
branches/11/ (props changed)
branches/11/main/features.c
Propchange: branches/11/
------------------------------------------------------------------------------
Binary property 'branch-1.8-merged' - no diff available.
Modified: branches/11/main/features.c
URL: http://svnview.digium.com/svn/asterisk/branches/11/main/features.c?view=diff&rev=419631&r1=419630&r2=419631
==============================================================================
--- branches/11/main/features.c (original)
+++ branches/11/main/features.c Fri Jul 25 18:13:48 2014
@@ -3526,7 +3526,13 @@
if (!ast_strlen_zero(feature->moh_class))
ast_moh_start(idle, feature->moh_class, NULL);
- res = pbx_exec(work, app, feature->app_args);
+ if (!strcasecmp("Gosub", feature->app)) {
+ res = ast_app_exec_sub(NULL, work, feature->app_args, 0);
+ } else if (!strcasecmp("Macro", feature->app)) {
+ res = ast_app_exec_macro(NULL, work, feature->app_args);
+ } else {
+ res = pbx_exec(work, app, feature->app_args);
+ }
if (!ast_strlen_zero(feature->moh_class))
ast_moh_stop(idle);
More information about the asterisk-commits
mailing list