Doxygen update
[asterisk/asterisk.git] / funcs / func_rand.c
index 053bcf5..4ec712e 100644 (file)
  * 
  * \author Claude Patry <cpatry@gmail.com>
  * \author Tilghman Lesher ( http://asterisk.drunkcoder.com/ )
+ * \ingroup functions
  */
 
+#include "asterisk.h"
+
+ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
+
 #include <stdlib.h>
 #include <string.h>
 #include <stdio.h>
 #include <sys/types.h>
 
-#include "asterisk.h"
-
-ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
-
 #include "asterisk/module.h"
 #include "asterisk/channel.h"
 #include "asterisk/pbx.h"
 #include "asterisk/logger.h"
 #include "asterisk/utils.h"
 #include "asterisk/app.h"
+#include "asterisk/options.h"
 
-LOCAL_USER_DECL;
-
-static int acf_rand_exec(struct ast_channel *chan, char *cmd,
+static int acf_rand_exec(struct ast_channel *chan, const char *cmd,
                         char *parse, char *buffer, size_t buflen)
 {
-       struct localuser *u;
+       struct ast_module_user *u;
        int min_int, response_int, max_int;
        AST_DECLARE_APP_ARGS(args,
                             AST_APP_ARG(min);
                             AST_APP_ARG(max);
        );
 
-       LOCAL_USER_ADD(u);
+       u = ast_module_user_add(chan);
 
        AST_STANDARD_APP_ARGS(args, parse);
 
@@ -66,15 +66,17 @@ static int acf_rand_exec(struct ast_channel *chan, char *cmd,
 
                max_int = min_int;
                min_int = tmp;
-               ast_log(LOG_DEBUG, "max<min\n");
+               if (option_debug)
+                       ast_log(LOG_DEBUG, "max<min\n");
        }
 
        response_int = min_int + (ast_random() % (max_int - min_int + 1));
-       ast_log(LOG_DEBUG, "%d was the lucky number in range [%d,%d]\n",
-               response_int, min_int, max_int);
+       if (option_debug)
+               ast_log(LOG_DEBUG, "%d was the lucky number in range [%d,%d]\n",
+                       response_int, min_int, max_int);
        snprintf(buffer, buflen, "%d", response_int);
 
-       LOCAL_USER_REMOVE(u);
+       ast_module_user_remove(u);
 
        return 0;
 }
@@ -82,41 +84,25 @@ static int acf_rand_exec(struct ast_channel *chan, char *cmd,
 static struct ast_custom_function acf_rand = {
        .name = "RAND",
        .synopsis = "Choose a random number in a range",
-       .syntax = "RAND([min][,max])",
+       .syntax = "RAND([min][|max])",
        .desc =
                "Choose a random number between min and max.  Min defaults to 0, if not\n"
                "specified, while max defaults to RAND_MAX (2147483647 on many systems).\n"
-               "  Example:  Set(junky=${RAND(1,8)}); \n"
+               "  Example:  Set(junky=${RAND(1|8)}); \n"
                "  Sets junky to a random number between 1 and 8, inclusive.\n",
        .read = acf_rand_exec,
 };
 
-
-static char *tdesc = "Random number dialplan function";
-
-int unload_module(void)
+static int unload_module(void)
 {
        ast_custom_function_unregister(&acf_rand);
 
        return 0;
 }
 
-int load_module(void)
+static int load_module(void)
 {
        return ast_custom_function_register(&acf_rand);
 }
 
-const char *description(void)
-{
-       return tdesc;
-}
-
-int usecount(void)
-{
-       return 0;
-}
-
-const char *key()
-{
-       return ASTERISK_GPL_KEY;
-}
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Random number dialplan function");