aboutsummaryrefslogtreecommitdiffstats
path: root/funcs/func_logic.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_logic.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_logic.c')
-rw-r--r--funcs/func_logic.c73
1 files changed, 34 insertions, 39 deletions
diff --git a/funcs/func_logic.c b/funcs/func_logic.c
index b3c7eb2b5..50712b8f7 100644
--- a/funcs/func_logic.c
+++ b/funcs/func_logic.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
*
* See http://www.asterisk.org for more information about
@@ -37,40 +37,44 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
#include "asterisk/utils.h"
#include "asterisk/app.h"
-static char *isnull(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
+static int isnull(struct ast_channel *chan, char *cmd, char *data,
+ char *buf, size_t len)
{
- return data && *data ? "0" : "1";
+ strcpy(buf, data && *data ? "0" : "1");
+
+ return 0;
}
-static char *exists(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
+static int exists(struct ast_channel *chan, char *cmd, char *data, char *buf,
+ size_t len)
{
- return data && *data ? "1" : "0";
+ strcpy(buf, data && *data ? "1" : "0");
+
+ return 0;
}
-static char *iftime(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
+static int iftime(struct ast_channel *chan, char *cmd, char *data, char *buf,
+ size_t len)
{
struct ast_timing timing;
- char *ret;
char *expr;
char *iftrue;
char *iffalse;
- if (!(data = ast_strdupa(data)))
- return NULL;
-
data = ast_strip_quoted(data, "\"", "\"");
expr = strsep(&data, "?");
iftrue = strsep(&data, ":");
iffalse = data;
if (ast_strlen_zero(expr) || !(iftrue || iffalse)) {
- ast_log(LOG_WARNING, "Syntax IFTIME(<timespec>?[<true>][:<false>])\n");
- return NULL;
+ ast_log(LOG_WARNING,
+ "Syntax IFTIME(<timespec>?[<true>][:<false>])\n");
+ return -1;
}
if (!ast_build_timing(&timing, expr)) {
ast_log(LOG_WARNING, "Invalid Time Spec.\n");
- return NULL;
+ return -1;
}
if (iftrue)
@@ -78,24 +82,18 @@ static char *iftime(struct ast_channel *chan, char *cmd, char *data, char *buf,
if (iffalse)
iffalse = ast_strip_quoted(iffalse, "\"", "\"");
- if ((ret = ast_check_timing(&timing) ? iftrue : iffalse)) {
- ast_copy_string(buf, ret, len);
- ret = buf;
- }
-
- return ret;
+ ast_copy_string(buf, ast_check_timing(&timing) ? iftrue : iffalse, len);
+
+ return 0;
}
-static char *acf_if(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
+static int acf_if(struct ast_channel *chan, char *cmd, char *data, char *buf,
+ size_t len)
{
- char *ret;
char *expr;
char *iftrue;
char *iffalse;
- if (!(data = ast_strdupa(data)))
- return NULL;
-
data = ast_strip_quoted(data, "\"", "\"");
expr = strsep(&data, "?");
iftrue = strsep(&data, ":");
@@ -103,7 +101,7 @@ static char *acf_if(struct ast_channel *chan, char *cmd, char *data, char *buf,
if (ast_strlen_zero(expr) || !(iftrue || iffalse)) {
ast_log(LOG_WARNING, "Syntax IF(<expr>?[<true>][:<false>])\n");
- return NULL;
+ return -1;
}
expr = ast_strip(expr);
@@ -112,28 +110,23 @@ static char *acf_if(struct ast_channel *chan, char *cmd, char *data, char *buf,
if (iffalse)
iffalse = ast_strip_quoted(iffalse, "\"", "\"");
- if ((ret = ast_true(expr) ? iftrue : iffalse)) {
- ast_copy_string(buf, ret, len);
- ret = buf;
- }
-
- return ret;
+ ast_copy_string(buf, ast_true(expr) ? iftrue : iffalse, len);
+
+ return 0;
}
-static char *set(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len)
+static int set(struct ast_channel *chan, char *cmd, char *data, char *buf,
+ size_t len)
{
char *varname;
char *val;
- if (!(data = ast_strdupa(data)))
- return NULL;
-
varname = strsep(&data, "=");
val = data;
if (ast_strlen_zero(varname) || !val) {
ast_log(LOG_WARNING, "Syntax SET(<varname>=[<value>])\n");
- return NULL;
+ return -1;
}
varname = ast_strip(varname);
@@ -141,7 +134,7 @@ static char *set(struct ast_channel *chan, char *cmd, char *data, char *buf, siz
pbx_builtin_setvar_helper(chan, varname, val);
ast_copy_string(buf, val, len);
- return buf;
+ return 0;
}
static struct ast_custom_function isnull_function = {
@@ -167,14 +160,16 @@ static struct ast_custom_function exists_function = {
static struct ast_custom_function if_function = {
.name = "IF",
- .synopsis = "Conditional: Returns the data following '?' if true else the data following ':'",
+ .synopsis =
+ "Conditional: Returns the data following '?' if true else the data following ':'",
.syntax = "IF(<expr>?[<true>][:<false>])",
.read = acf_if,
};
static struct ast_custom_function if_time_function = {
.name = "IFTIME",
- .synopsis = "Temporal Conditional: Returns the data following '?' if true else the data following ':'",
+ .synopsis =
+ "Temporal Conditional: Returns the data following '?' if true else the data following ':'",
.syntax = "IFTIME(<timespec>?[<true>][:<false>])",
.read = iftime,
};