diff options
author | Mark Michelson <mmichelson@digium.com> | 2015-07-13 15:15:44 -0500 |
---|---|---|
committer | Gerrit Code Review <gerrit2@gerrit.digium.api> | 2015-07-13 15:15:44 -0500 |
commit | 585d98fbb68495694bf60a811c711d541aade548 (patch) | |
tree | 45b75f021ce9ac017989bf96112597625626e2ab /main | |
parent | ca65ddcd199dca4681055b51fc63b906e48f1950 (diff) | |
parent | 73e35d20deb57281874939f553fea9fdced2e260 (diff) |
Merge "ARI: Added new functionality to get information on a single module." into 13
Diffstat (limited to 'main')
-rw-r--r-- | main/loader.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/main/loader.c b/main/loader.c index 55fed7063..940b53edb 100644 --- a/main/loader.c +++ b/main/loader.c @@ -1451,6 +1451,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) { |