diff options
-rw-r--r-- | apps/app_stack.c | 2 | ||||
-rw-r--r-- | include/asterisk/pbx.h | 3 | ||||
-rw-r--r-- | pbx.c | 2 |
3 files changed, 5 insertions, 2 deletions
diff --git a/apps/app_stack.c b/apps/app_stack.c index e3c33d2e5..fb24f27c4 100644 --- a/apps/app_stack.c +++ b/apps/app_stack.c @@ -139,7 +139,7 @@ static int gosubif_exec(struct ast_channel *chan, void *data) label1 = strsep(&args, ":"); label2 = args; - if (ast_true(condition)) { + if (pbx_checkcondition(condition)) { if (label1) { res = gosub_exec(chan, label1); } diff --git a/include/asterisk/pbx.h b/include/asterisk/pbx.h index d2902002c..cd116321f 100644 --- a/include/asterisk/pbx.h +++ b/include/asterisk/pbx.h @@ -569,6 +569,9 @@ int ast_pbx_outgoing_exten(const char *type, int format, void *data, int timeout particular application with given extension */ int ast_pbx_outgoing_app(const char *type, int format, void *data, int timeout, const char *app, const char *appdata, int *reason, int sync, const char *cid_num, const char *cid_name, struct ast_variable *vars, const char *account, struct ast_channel **locked_channel); +/* Evaluate a condition for non-falseness and return a boolean */ +int pbx_checkcondition(char *condition); + /* Functions for returning values from structures */ const char *ast_get_context_name(struct ast_context *con); const char *ast_get_extension_name(struct ast_exten *exten); @@ -6107,7 +6107,7 @@ void pbx_builtin_clear_globals(void) ast_mutex_unlock(&globalslock); } -static int pbx_checkcondition(char *condition) +int pbx_checkcondition(char *condition) { if (condition) { if (*condition == '\0') { |