AST_STANDARD_APP_ARGS(args, parse);
/* Check and parse arguments */
- if(args.argc < 3){
+ if (args.argc < 3) {
return ERROR_NOARG;
} else {
char d, ds[2];
return ERROR_NOMEM;
}
- d = args.delimiter[0] ? args.delimiter[0] : '-';
+ if (args.delimiter[0] == '\\') {
+ if (args.delimiter[1] == 'n')
+ d = '\n';
+ else if (args.delimiter[1] == 't')
+ d = '\t';
+ else if (args.delimiter[1])
+ d = args.delimiter[1];
+ else
+ d = '-';
+ } else if (args.delimiter[0])
+ d = args.delimiter[0];
+ else
+ d = '-';
/* String form of the delimiter, for use with strsep(3) */
snprintf(ds, sizeof(ds), "%c", d);
#include "asterisk/utils.h"
#include "asterisk/app.h"
-static int shell_helper(struct ast_channel *chan, char *cmd, char *data,
+static int shell_helper(struct ast_channel *chan, const char *cmd, char *data,
char *buf, size_t len)
{
if (ast_strlen_zero(data)) {
AST_STANDARD_APP_ARGS(args, parse);
if (args.delim) {
pbx_retrieve_variable(chan, args.varname, &varval, buf, len, NULL);
+ if (args.delim[0] == '\\') {
+ if (args.delim[1] == 'n')
+ ast_copy_string(args.delim, "\n", 2);
+ else if (args.delim[1] == 't')
+ ast_copy_string(args.delim, "\t", 2);
+ else if (args.delim[1])
+ ast_copy_string(args.delim, &args.delim[1], 2);
+ else
+ ast_copy_string(args.delim, "-", 2);
+ }
while (strsep(&varval, args.delim))
fieldcount++;
} else {