[asterisk-commits] branch oej/test-this-branch r12372 - in /team/oej/test-this-branch: ./ funcs/...

asterisk-commits at lists.digium.com asterisk-commits at lists.digium.com
Tue Mar 7 12:38:06 MST 2006


Author: oej
Date: Tue Mar  7 13:38:02 2006
New Revision: 12372

URL: http://svn.digium.com/view/asterisk?rev=12372&view=rev
Log:
Adding IFMODULE dialplan function to check whether module is loaded in Asterisk
or not. 

Added:
    team/oej/test-this-branch/funcs/func_module.c   (with props)
Modified:
    team/oej/test-this-branch/README.test-this-branch
    team/oej/test-this-branch/include/asterisk/module.h
    team/oej/test-this-branch/loader.c

Modified: team/oej/test-this-branch/README.test-this-branch
URL: http://svn.digium.com/view/asterisk/team/oej/test-this-branch/README.test-this-branch?rev=12372&r1=12371&r2=12372&view=diff
==============================================================================
--- team/oej/test-this-branch/README.test-this-branch (original)
+++ team/oej/test-this-branch/README.test-this-branch Tue Mar  7 13:38:02 2006
@@ -31,13 +31,14 @@
 
 And the following stand-alone patches
 - New CLI commands for global variables (oej, #6506)
-- Additional options for the CHANNEL dialplan function (oej)
+- Additional options for the CHANNEL dialplan function (oej, #6670)
 - Manager sendtext event (ZX81, #6131)
 - Carrier ENUM support (otmar, #5526)
 - HDLC mode support for ZAP channels (crich, #6251)
 - Show manager CLI commands (junky, #5240)
 - Support SIP_CODEC for early media (oej, #6576)
 - Show threads CLI command (rizzo, #6053)
+- IFMODULE dialplan function (oej, #6671)
 
 Coming here soon:
 - siptransfer: Improved SIP transfer support

Added: team/oej/test-this-branch/funcs/func_module.c
URL: http://svn.digium.com/view/asterisk/team/oej/test-this-branch/funcs/func_module.c?rev=12372&view=auto
==============================================================================
--- team/oej/test-this-branch/funcs/func_module.c (added)
+++ team/oej/test-this-branch/funcs/func_module.c Tue Mar  7 13:38:02 2006
@@ -1,0 +1,93 @@
+/*
+ * Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 1999 - 2006, Digium, Inc.
+ *
+ * See http://www.asterisk.org for more information about
+ * the Asterisk project. Please do not directly contact
+ * any of the maintainers of this project for assistance;
+ * the project provides a web site, mailing lists and IRC
+ * channels for your use.
+ *
+ * This program is free software, distributed under the terms of
+ * the GNU General Public License Version 2. See the LICENSE file
+ * at the top of the source tree.
+ */
+
+/*! \file
+ *
+ * \brief Simple module check function
+ * \author Olle E. Johansson, Edvina.net
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/types.h>
+#include <sys/stat.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/module.h"
+
+static int ifmodule_read(struct ast_channel *chan, char *cmd, char *data,
+		    char *buf, size_t len)
+{
+	char *ret = NULL;
+
+	*buf = '\0';
+
+	if (data)
+		if (ast_module_check(data))
+			ret = "1";
+
+	if (ret)
+		ast_copy_string(buf, ret, len);
+
+	return 0;
+}
+
+static struct ast_custom_function ifmodule_function = {
+	.name = "IFMODULE",
+	.synopsis = "Checks if an Asterisk module is loaded in memory",
+	.syntax = "IFMODULE(<modulename.so>)",
+	.read = ifmodule_read,
+	.desc = "Checks if a module is loaded. Use the full module name\n"
+		"as shown by the list in \"show modules\". \n"
+		"Returns \"1\" if module exists in memory, otherwise nothing.\n",
+};
+
+static char *tdesc = "Checks if Asterisk module is loaded in memory";
+
+int unload_module(void)
+{
+	return ast_custom_function_unregister(&ifmodule_function);
+}
+
+int load_module(void)
+{
+	return ast_custom_function_register(&ifmodule_function);
+}
+
+char *description(void)
+{
+	return tdesc;
+}
+
+int usecount(void)
+{
+	return 0;
+}
+
+char *key()
+{
+	return ASTERISK_GPL_KEY;
+}

Propchange: team/oej/test-this-branch/funcs/func_module.c
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: team/oej/test-this-branch/funcs/func_module.c
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: team/oej/test-this-branch/funcs/func_module.c
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Modified: team/oej/test-this-branch/include/asterisk/module.h
URL: http://svn.digium.com/view/asterisk/team/oej/test-this-branch/include/asterisk/module.h?rev=12372&r1=12371&r2=12372&view=diff
==============================================================================
--- team/oej/test-this-branch/include/asterisk/module.h (original)
+++ team/oej/test-this-branch/include/asterisk/module.h Tue Mar  7 13:38:02 2006
@@ -188,6 +188,13 @@
  */
 int ast_update_module_list(int (*modentry)(const char *module, const char *description, int usecnt, const char *like),
 			   const char *like);
+
+/*!
+ * \brief Check if module with the name given is loaded
+ * \param name Module name, like "chan_sip.so"
+ * \return 0 if false, 1 if true 
+ */
+int ast_module_check(char *name);
 
 /*! 
  * \brief Add a procedure to be run when modules have been updated.

Modified: team/oej/test-this-branch/loader.c
URL: http://svn.digium.com/view/asterisk/team/oej/test-this-branch/loader.c?rev=12372&r1=12371&r2=12372&view=diff
==============================================================================
--- team/oej/test-this-branch/loader.c (original)
+++ team/oej/test-this-branch/loader.c Tue Mar  7 13:38:02 2006
@@ -577,6 +577,25 @@
 	return total_mod_loaded;
 }
 
+int ast_module_check(char *name)
+{
+	struct module *cur;
+	int unlock = -1;
+	int res = 0;
+
+	if (ast_strlen_zero(name))
+		return 0;	/* FALSE */
+
+	if (ast_mutex_trylock(&module_list.lock))
+		unlock = 0;
+	AST_LIST_TRAVERSE(&module_list, cur, next)
+		if (!res && !strcasecmp(name, cur->resource))
+			res = 1;
+	if (unlock)
+		AST_LIST_UNLOCK(&module_list);
+	return res;
+}
+
 int ast_loader_register(int (*v)(void)) 
 {
 	/* XXX Should be more flexible here, taking > 1 verboser XXX */



More information about the asterisk-commits mailing list