diff options
author | Mark Spencer <markster@digium.com> | 2004-12-31 00:04:41 +0000 |
---|---|---|
committer | Mark Spencer <markster@digium.com> | 2004-12-31 00:04:41 +0000 |
commit | ce2e6b28e8879c7f1bf78cabb6889b4d58e1b526 (patch) | |
tree | e592d78d99448f231b6bdc5fb0a99353e0adae39 /channel.c | |
parent | 91e1317f4a44fb957e0015e1106b8f34d65c9f41 (diff) |
Merge OEJ's channel type listing (bug #3187) with slight modifications
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@4614 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channel.c')
-rwxr-xr-x | channel.c | 32 |
1 files changed, 32 insertions, 0 deletions
@@ -29,6 +29,7 @@ #include <asterisk/logger.h> #include <asterisk/say.h> #include <asterisk/file.h> +#include <asterisk/cli.h> #include <asterisk/translate.h> #include <asterisk/manager.h> #include <asterisk/chanvars.h> @@ -49,6 +50,7 @@ #error "You need newer zaptel! Please cvs update zaptel" #endif #endif +#include "asterisk.h" /* uncomment if you have problems with 'monitoring' synchronized files */ #if 0 @@ -78,6 +80,32 @@ struct ast_channel *channels = NULL; AST_MUTEX_DEFINE_STATIC(chlock); +static int show_channeltypes(int fd, int argc, char *argv[]) +{ +#define FORMAT "%-7.7s %-50.50s\n" + struct chanlist *cl = backends; + ast_cli(fd, FORMAT, "Type", "Description"); + ast_cli(fd, FORMAT, "------", "-----------"); + if (ast_mutex_lock(&chlock)) { + ast_log(LOG_WARNING, "Unable to lock channel list\n"); + return -1; + } + while (cl) { + ast_cli(fd, FORMAT, cl->type, cl->description); + cl = cl->next; + } + ast_mutex_unlock(&chlock); + return RESULT_SUCCESS; + +} + +static char show_channeltypes_usage[] = +"Usage: show channeltypes\n" +" Shows available channel types registred in your Asterisk server."; + +static struct ast_cli_entry cli_show_channeltypes = + { { "show", "channeltypes", NULL }, show_channeltypes, "Show available channel types", show_channeltypes_usage }; + int ast_check_hangup(struct ast_channel *chan) { time_t myt; @@ -3011,3 +3039,7 @@ void ast_moh_cleanup(struct ast_channel *chan) ast_moh_cleanup_ptr(chan); } +void ast_channels_init(void) +{ + ast_cli_register(&cli_show_channeltypes); +} |