Merged revisions 54290 via svnmerge from
[asterisk/asterisk.git] / formats / format_jpeg.c
old mode 100755 (executable)
new mode 100644 (file)
index 2a5dfc1..edef171
  *
  * \brief JPEG File format support.
  * 
+ * \arg File name extension: jpeg, jpg
+ * \ingroup formats
  */
  
+#include "asterisk.h"
+
+ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
+
 #include <sys/types.h>
 #include <netinet/in.h>
 #include <arpa/inet.h>
 #include <errno.h>
 #include <string.h>
 
-#include "asterisk.h"
-
-ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
-
 #include "asterisk/channel.h"
 #include "asterisk/file.h"
 #include "asterisk/logger.h"
@@ -45,15 +47,12 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 #include "asterisk/lock.h"
 #include "asterisk/endian.h"
 
-static char *desc = "JPEG (Joint Picture Experts Group) Image Format";
-
-
 static struct ast_frame *jpeg_read_image(int fd, int len)
 {
        struct ast_frame fr;
        int res;
        char buf[65536];
-       if (len > sizeof(buf)) {
+       if (len > sizeof(buf) || len < 0) {
                ast_log(LOG_WARNING, "JPEG image too large to read\n");
                return NULL;
        }
@@ -113,30 +112,16 @@ static struct ast_imager jpeg_format = {
        jpeg_write_image,
 };
 
-int load_module()
+static int load_module(void)
 {
        return ast_image_register(&jpeg_format);
 }
 
-int unload_module()
+static int unload_module(void)
 {
        ast_image_unregister(&jpeg_format);
-       return 0;
-}      
 
-int usecount()
-{
-       /* We never really have any users */
        return 0;
-}
-
-char *description()
-{
-       return desc;
-}
-
+}      
 
-char *key()
-{
-       return ASTERISK_GPL_KEY;
-}
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "JPEG (Joint Picture Experts Group) Image Format");