Merged revisions 60661 via svnmerge from
[asterisk/asterisk.git] / res / res_convert.c
index c62aba4..628381a 100644 (file)
@@ -1,7 +1,7 @@
 /*
  * Asterisk -- An open source telephony toolkit.
  *
- * Copyright (C) 2005, Digium, Inc.
+ * Copyright (C) 2005, 2006, Digium, Inc.
  *
  * redice li <redice_li@yahoo.com>
  * Russell Bryant <russell@digium.com>
@@ -40,8 +40,6 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 #include "asterisk/cli.h"
 #include "asterisk/file.h"
 
-struct module_symbols *me;
-
 /*! \brief Split the filename to basename and extension */
 static int split_ext(char *filename, char **name, char **ext)
 {
@@ -66,31 +64,32 @@ static int cli_audio_convert(int fd, int argc, char *argv[])
        char *file_in = NULL, *file_out = NULL;
        char *name_in, *ext_in, *name_out, *ext_out;
        
-       ast_atomic_fetchadd_int(&me->usecnt, +1);
-       
-       if (argc != 3 || ast_strlen_zero(argv[1]) || ast_strlen_zero(argv[2])) {
+       /* ugly, can be removed when CLI entries have ast_module pointers */
+       ast_module_ref(ast_module_info->self);
+
+       if (argc != 4 || ast_strlen_zero(argv[2]) || ast_strlen_zero(argv[3])) {
                ret = RESULT_SHOWUSAGE;
                goto fail_out;  
        }
 
-       file_in = ast_strdupa(argv[1]);
-       file_out = ast_strdupa(argv[2]);
+       file_in = ast_strdupa(argv[2]);
+       file_out = ast_strdupa(argv[3]);
 
        if (split_ext(file_in, &name_in, &ext_in)) {
-               ast_cli(fd, "'%s' is an invalid filename!\n", argv[1]);
+               ast_cli(fd, "'%s' is an invalid filename!\n", argv[2]);
                goto fail_out;
        }
        if (!(fs_in = ast_readfile(name_in, ext_in, NULL, O_RDONLY, 0, 0))) {
-               ast_cli(fd, "Unable to open input file: %s\n", argv[1]);
+               ast_cli(fd, "Unable to open input file: %s\n", argv[2]);
                goto fail_out;
        }
        
        if (split_ext(file_out, &name_out, &ext_out)) {
-               ast_cli(fd, "'%s' is an invalid filename!\n", argv[2]);
+               ast_cli(fd, "'%s' is an invalid filename!\n", argv[3]);
                goto fail_out;
        }
-       if (!(fs_out = ast_writefile(name_out, ext_out, NULL, O_CREAT|O_TRUNC|O_WRONLY, 0, 0644))) {
-               ast_cli(fd, "Unable to open output file: %s\n", argv[2]);
+       if (!(fs_out = ast_writefile(name_out, ext_out, NULL, O_CREAT|O_TRUNC|O_WRONLY, 0, AST_FILE_MODE))) {
+               ast_cli(fd, "Unable to open output file: %s\n", argv[3]);
                goto fail_out;
        }
 
@@ -117,41 +116,34 @@ fail_out:
        if (fs_in) 
                ast_closestream(fs_in);
 
-       ast_atomic_fetchadd_int(&me->usecnt, -1);
-       
+       ast_module_unref(ast_module_info->self);
+
        return ret;
 }
 
 static char usage_audio_convert[] =
-"Usage: convert <file_in> <file_out>\n"
+"Usage: file convert <file_in> <file_out>\n"
 "    Convert from file_in to file_out. If an absolute path is not given, the\n"
 "default Asterisk sounds directory will be used.\n\n"
 "Example:\n"
-"    convert tt-weasels.gsm tt-weasels.ulaw\n";
+"    file convert tt-weasels.gsm tt-weasels.ulaw\n";
 
-static struct ast_cli_entry audio_convert_cli={
-       { "convert" , NULL }, cli_audio_convert, "Convert audio files", usage_audio_convert
+static struct ast_cli_entry cli_convert[] = {
+       { { "file", "convert" , NULL },
+       cli_audio_convert, "Convert audio file",
+       usage_audio_convert },
 };
 
-static int unload_module(void *mod)
+static int unload_module(void)
 {
-       return ast_cli_unregister(&audio_convert_cli);
-}
-
-static int load_module(void *mod)
-{
-       me = mod;
-       return ast_cli_register(&audio_convert_cli);
-}
-
-static const char *description(void)
-{
-       return "File format conversion CLI command";
+       ast_cli_unregister_multiple(cli_convert, sizeof(cli_convert) / sizeof(struct ast_cli_entry));
+       return 0;
 }
 
-static const char *key(void)
+static int load_module(void)
 {
-       return ASTERISK_GPL_KEY;
+       ast_cli_register_multiple(cli_convert, sizeof(cli_convert) / sizeof(struct ast_cli_entry));
+       return 0;
 }
 
-STD_MOD1;
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "File format conversion CLI command");