aboutsummaryrefslogtreecommitdiffstats
path: root/funcs/func_cdr.c
diff options
context:
space:
mode:
authorkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2006-02-12 04:28:58 +0000
committerkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2006-02-12 04:28:58 +0000
commit5d9ed5739aab2b302efc178d21e6c75672369db3 (patch)
tree5c4270c1ac3d265b96361d98722a75b947f2f8c6 /funcs/func_cdr.c
parent9f87dd693e9e74816b913a157fdcdefa3d7a2e56 (diff)
major dialplan functions update
deprecate LANGUAGE() and MUSICCLASS(), in favor of CHANNEL() git-svn-id: http://svn.digium.com/svn/asterisk/trunk@9674 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'funcs/func_cdr.c')
-rw-r--r--funcs/func_cdr.c80
1 files changed, 33 insertions, 47 deletions
diff --git a/funcs/func_cdr.c b/funcs/func_cdr.c
index 205651a1c..d287ff98a 100644
--- a/funcs/func_cdr.c
+++ b/funcs/func_cdr.c
@@ -1,7 +1,7 @@
/*
* Asterisk -- An open source telephony toolkit.
*
- * Copyright (C) 1999 - 2005, Digium, Inc.
+ * Copyright (C) 1999-2006, Digium, Inc.
*
* Portions Copyright (C) 2005, Anthony Minessale II
*
@@ -47,71 +47,65 @@ AST_APP_OPTIONS(cdr_func_options, {
AST_APP_OPTION('r', OPT_RECURSIVE),
});
-static char *cdr_read(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
+static int cdr_read(struct ast_channel *chan, char *cmd, char *parse,
+ char *buf, size_t len)
{
char *ret;
- char *parse;
- struct ast_flags flags = {0};
-
+ struct ast_flags flags = { 0 };
AST_DECLARE_APP_ARGS(args,
- AST_APP_ARG(variable);
- AST_APP_ARG(options);
+ AST_APP_ARG(variable);
+ AST_APP_ARG(options);
);
- if (ast_strlen_zero(data))
- return NULL;
-
- if (!chan->cdr)
- return NULL;
+ if (ast_strlen_zero(parse))
+ return -1;
- if (!(parse = ast_strdupa(data)))
- return NULL;
+ if (!chan->cdr)
+ return -1;
AST_STANDARD_APP_ARGS(args, parse);
-
- if(!ast_strlen_zero(args.options) ) {
+
+ 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;
+ ast_cdr_getvar(chan->cdr, args.variable, &ret, buf, len,
+ ast_test_flag(&flags, OPT_RECURSIVE));
+
+ return 0;
}
-static void cdr_write(struct ast_channel *chan, char *cmd, char *data, const char *value)
+static int cdr_write(struct ast_channel *chan, char *cmd, char *parse,
+ const char *value)
{
- char *parse;
- struct ast_flags flags = {0};
-
- AST_DECLARE_APP_ARGS(args,
- AST_APP_ARG(variable);
- AST_APP_ARG(options);
- );
+ 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;
-
- if (!(parse = ast_strdupa(data)))
- return;
+ if (ast_strlen_zero(parse) || !value)
+ return -1;
AST_STANDARD_APP_ARGS(args, parse);
- /* check for a trailing flags argument */
- if(!ast_strlen_zero(args.options) ) {
+ if (!ast_strlen_zero(args.options))
ast_app_parse_options(cdr_func_options, &flags, NULL, args.options);
- }
if (!strcasecmp(args.variable, "accountcode"))
ast_cdr_setaccount(chan, value);
else if (!strcasecmp(args.variable, "userfield"))
ast_cdr_setuserfield(chan, value);
else if (chan->cdr)
- ast_cdr_setvar(chan->cdr, args.variable, value, (ast_test_flag(&flags,OPT_RECURSIVE) ) ? 1 : 0 );
+ ast_cdr_setvar(chan->cdr, args.variable, value,
+ ast_test_flag(&flags, OPT_RECURSIVE));
+
+ return 0;
}
static struct ast_custom_function cdr_function = {
.name = "CDR",
.synopsis = "Gets or sets a CDR variable",
- .desc= "Option 'r' searches the entire stack of CDRs on the channel\n",
+ .desc = "Option 'r' searches the entire stack of CDRs on the channel\n",
.syntax = "CDR(<name>[|options])",
.read = cdr_read,
.write = cdr_write,
@@ -121,12 +115,12 @@ static char *tdesc = "CDR dialplan function";
int unload_module(void)
{
- return ast_custom_function_unregister(&cdr_function);
+ return ast_custom_function_unregister(&cdr_function);
}
int load_module(void)
{
- return ast_custom_function_register(&cdr_function);
+ return ast_custom_function_register(&cdr_function);
}
char *description(void)
@@ -143,11 +137,3 @@ char *key()
{
return ASTERISK_GPL_KEY;
}
-
-/*
-Local Variables:
-mode: C
-c-file-style: "linux"
-indent-tabs-mode: nil
-End:
-*/