aboutsummaryrefslogtreecommitdiffstats
path: root/funcs/func_cdr.c
diff options
context:
space:
mode:
authormogorman <mogorman@f38db490-d61c-443f-a65b-d21fe96a405b>2006-01-11 19:52:29 +0000
committermogorman <mogorman@f38db490-d61c-443f-a65b-d21fe96a405b>2006-01-11 19:52:29 +0000
commitf5498b059fb6138859d37da7f3095ef1a1ee1901 (patch)
tree4350e86448f1c9b9be5d704548f3cd9f5521fec8 /funcs/func_cdr.c
parent5042d107ff63d7e4fe93c2d1a59193885d577dff (diff)
Added macros from 6198 and 6203. also added better
error reporting in func_cut git-svn-id: http://svn.digium.com/svn/asterisk/trunk@7989 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'funcs/func_cdr.c')
-rw-r--r--funcs/func_cdr.c70
1 files changed, 44 insertions, 26 deletions
diff --git a/funcs/func_cdr.c b/funcs/func_cdr.c
index c934e87c9..c5cadc758 100644
--- a/funcs/func_cdr.c
+++ b/funcs/func_cdr.c
@@ -38,13 +38,24 @@
#include "asterisk/app.h"
#include "asterisk/cdr.h"
+enum {
+ OPT_RECURSIVE = (1 << 0),
+} cdr_option_flags;
+
+AST_APP_OPTIONS(cdr_func_options, {
+ AST_APP_OPTION('r', OPT_RECURSIVE),
+});
+
static char *builtin_function_cdr_read(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
{
char *ret;
- char *mydata;
- int argc;
- char *argv[2];
- int recursive = 0;
+ char *parse;
+ struct ast_flags flags = {0};
+
+ AST_DECLARE_APP_ARGS(args,
+ AST_APP_ARG(variable);
+ AST_APP_ARG(options);
+ );
if (ast_strlen_zero(data))
return NULL;
@@ -52,47 +63,54 @@ static char *builtin_function_cdr_read(struct ast_channel *chan, char *cmd, char
if (!chan->cdr)
return NULL;
- mydata = ast_strdupa(data);
- argc = ast_app_separate_args(mydata, '|', argv, sizeof(argv) / sizeof(argv[0]));
-
- /* check for a trailing flags argument */
- if (argc > 1) {
- argc--;
- if (strchr(argv[argc], 'r'))
- recursive = 1;
+ parse = ast_strdupa(data);
+ if (!parse) {
+ ast_log(LOG_ERROR, "Out of memory!\n");
+ return NULL;
}
- ast_cdr_getvar(chan->cdr, argv[0], &ret, buf, len, recursive);
+ AST_STANDARD_APP_ARGS(args, parse);
+
+ if(!ast_strlen_zero(args.options) ) {
+ ast_app_parse_options(cdr_func_options, &flags, NULL, args.options);
+ }
+ ast_cdr_getvar(chan->cdr, args.variable, &ret, buf, len, (ast_test_flag(&flags,OPT_RECURSIVE) ) ? 1 : 0 );
return ret;
}
static void builtin_function_cdr_write(struct ast_channel *chan, char *cmd, char *data, const char *value)
{
- char *mydata;
- int argc;
- char *argv[2];
- int recursive = 0;
+ char *parse;
+ struct ast_flags flags = {0};
+
+ AST_DECLARE_APP_ARGS(args,
+ AST_APP_ARG(variable);
+ AST_APP_ARG(options);
+ );
if (ast_strlen_zero(data) || !value)
return;
- mydata = ast_strdupa(data);
- argc = ast_app_separate_args(mydata, '|', argv, sizeof(argv) / sizeof(argv[0]));
+ parse = ast_strdupa(data);
+ if (!parse) {
+ ast_log(LOG_ERROR, "Out of memory!\n");
+ return;
+ }
+
+ AST_STANDARD_APP_ARGS(args, parse);
/* check for a trailing flags argument */
- if (argc > 1) {
- argc--;
- if (strchr(argv[argc], 'r'))
- recursive = 1;
+ if(!ast_strlen_zero(args.options) ) {
+ ast_app_parse_options(cdr_func_options, &flags, NULL, args.options);
}
- if (!strcasecmp(argv[0], "accountcode"))
+ if (!strcasecmp(args.variable, "accountcode"))
ast_cdr_setaccount(chan, value);
- else if (!strcasecmp(argv[0], "userfield"))
+ else if (!strcasecmp(args.variable, "userfield"))
ast_cdr_setuserfield(chan, value);
else if (chan->cdr)
- ast_cdr_setvar(chan->cdr, argv[0], value, recursive);
+ ast_cdr_setvar(chan->cdr, args.variable, value, (ast_test_flag(&flags,OPT_RECURSIVE) ) ? 1 : 0 );
}
#ifndef BUILTIN_FUNC