mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-05 12:16:00 +00:00
Merged revisions 53074 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.2 ........ r53074 | tilghman | 2007-02-01 14:07:35 -0600 (Thu, 01 Feb 2007) | 2 lines Bug 8965 - Allow FIELDQTY to work with both variables and dialplan functions ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@53075 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -46,8 +46,8 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
|
||||
static int function_fieldqty(struct ast_channel *chan, char *cmd,
|
||||
char *parse, char *buf, size_t len)
|
||||
{
|
||||
const char *varval;
|
||||
char *varval2 = NULL;
|
||||
char *varname, *varsubst, varval[8192] = "", *varval2 = varval;
|
||||
char *delim = ast_strdupa(data);
|
||||
int fieldcount = 0;
|
||||
AST_DECLARE_APP_ARGS(args,
|
||||
AST_APP_ARG(varname);
|
||||
@@ -56,9 +56,10 @@ static int function_fieldqty(struct ast_channel *chan, char *cmd,
|
||||
|
||||
AST_STANDARD_APP_ARGS(args, parse);
|
||||
if (args.delim) {
|
||||
varval = pbx_builtin_getvar_helper(chan, args.varname);
|
||||
if (varval)
|
||||
varval2 = ast_strdupa(varval);
|
||||
varsubst = alloca(strlen(varname) + 4);
|
||||
|
||||
sprintf(varsubst, "${%s}", varname);
|
||||
pbx_substitute_variables_helper(chan, varsubst, varval, sizeof(varval) - 1);
|
||||
while (strsep(&varval2, args.delim))
|
||||
fieldcount++;
|
||||
} else {
|
||||
|
Reference in New Issue
Block a user