summaryrefslogtreecommitdiff
path: root/main
diff options
context:
space:
mode:
authorMark Michelson <mmichelson@digium.com>2015-07-13 15:15:47 -0500
committerGerrit Code Review <gerrit2@gerrit.digium.api>2015-07-13 15:15:47 -0500
commit3412b0f1ad58e3b3f0afa42d1067531e42eddb71 (patch)
tree9ae57fcafa10a1e71b542b9c8d81dbd0f47afdec /main
parentc8555235195ed1deb37f5e27390b0ed4da329dc5 (diff)
parent6a764db3700b31847138fcbfc7d811b96f99aca2 (diff)
Merge "ARI: Added new functionality to get information on a single module."
Diffstat (limited to 'main')
-rw-r--r--main/loader.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/main/loader.c b/main/loader.c
index 99a47b3b4..b2bdd4a3d 100644
--- a/main/loader.c
+++ b/main/loader.c
@@ -1445,6 +1445,34 @@ int ast_update_module_list_data(int (*modentry)(const char *module, const char *
return total_mod_loaded;
}
+int ast_update_module_list_condition(int (*modentry)(const char *module, const char *description,
+ int usecnt, const char *status,
+ const char *like,
+ enum ast_module_support_level support_level,
+ void *data, const char *condition),
+ const char *like, void *data, const char *condition)
+{
+ struct ast_module *cur;
+ int conditions_met = 0;
+ AST_LIST_HEAD_NOLOCK(, ast_module) alpha_module_list = AST_LIST_HEAD_NOLOCK_INIT_VALUE;
+
+ AST_DLLIST_LOCK(&module_list);
+
+ AST_DLLIST_TRAVERSE(&module_list, cur, entry) {
+ AST_LIST_INSERT_SORTALPHA(&alpha_module_list, cur, list_entry, resource);
+ }
+
+ while ((cur = AST_LIST_REMOVE_HEAD(&alpha_module_list, list_entry))) {
+ conditions_met += modentry(cur->resource, cur->info->description, cur->usecount,
+ cur->flags.running? "Running" : "Not Running", like, cur->info->support_level, data,
+ condition);
+ }
+
+ AST_DLLIST_UNLOCK(&module_list);
+
+ return conditions_met;
+}
+
/*! \brief Check if module exists */
int ast_module_check(const char *name)
{