1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
|
/*
* Asterisk -- An open source telephony toolkit.
*
* Copyright (C) 1999 - 2005, Digium, Inc.
*
* Mark Spencer <markster@digium.com>
*
* See http://www.asterisk.org for more information about
* the Asterisk project. Please do not directly contact
* any of the maintainers of this project for assistance;
* the project provides a web site, mailing lists and IRC
* channels for your use.
*
* This program is free software, distributed under the terms of
* the GNU General Public License Version 2. See the LICENSE file
* at the top of the source tree.
*/
/*! \file
*
* \brief JPEG File format support.
*
* \arg File name extension: jpeg, jpg
* \ingroup formats
*/
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <sys/time.h>
#include <stdio.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include "asterisk.h"
ASTERISK_FILE_VERSION(__FILE__, "$Revision: 18436 $")
#include "asterisk/channel.h"
#include "asterisk/file.h"
#include "asterisk/logger.h"
#include "asterisk/sched.h"
#include "asterisk/module.h"
#include "asterisk/image.h"
#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) || len < 0) {
ast_log(LOG_WARNING, "JPEG image too large to read\n");
return NULL;
}
res = read(fd, buf, len);
if (res < len) {
ast_log(LOG_WARNING, "Only read %d of %d bytes: %s\n", res, len, strerror(errno));
}
memset(&fr, 0, sizeof(fr));
fr.frametype = AST_FRAME_IMAGE;
fr.subclass = AST_FORMAT_JPEG;
fr.data = buf;
fr.src = "JPEG Read";
fr.datalen = len;
return ast_frisolate(&fr);
}
static int jpeg_identify(int fd)
{
char buf[10];
int res;
res = read(fd, buf, sizeof(buf));
if (res < sizeof(buf))
return 0;
if (memcmp(buf + 6, "JFIF", 4))
return 0;
return 1;
}
static int jpeg_write_image(int fd, struct ast_frame *fr)
{
int res=0;
if (fr->frametype != AST_FRAME_IMAGE) {
ast_log(LOG_WARNING, "Not an image\n");
return -1;
}
if (fr->subclass != AST_FORMAT_JPEG) {
ast_log(LOG_WARNING, "Not a jpeg image\n");
return -1;
}
if (fr->datalen) {
res = write(fd, fr->data, fr->datalen);
if (res != fr->datalen) {
ast_log(LOG_WARNING, "Only wrote %d of %d bytes: %s\n", res, fr->datalen, strerror(errno));
return -1;
}
}
return res;
}
static struct ast_imager jpeg_format = {
"jpg",
"JPEG (Joint Picture Experts Group)",
"jpg|jpeg",
AST_FORMAT_JPEG,
jpeg_read_image,
jpeg_identify,
jpeg_write_image,
};
int load_module()
{
return ast_image_register(&jpeg_format);
}
int unload_module()
{
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;
}
|