static int yuv_read(ByteIOContext *f, int (*alloc_cb)(void *opaque, AVImageInfo *info), void *opaque) { ByteIOContext pb1, *pb = &pb1; int img_size, ret; char fname[1024], *p; int size; URLContext *h; AVImageInfo info1, *info = &info1; img_size = url_fsize(f); /* XXX: hack hack */ h = url_fileno(f); url_get_filename(h, fname, sizeof(fname)); if (infer_size(&info->width, &info->height, img_size) < 0) { return AVERROR_IO; } info->pix_fmt = PIX_FMT_YUV420P; ret = alloc_cb(opaque, info); if (ret) return ret; size = info->width * info->height; p = strrchr(fname, '.'); if (!p || p[1] != 'Y') return AVERROR_IO; get_buffer(f, info->pict.data[0], size); p[1] = 'U'; if (url_fopen(pb, fname, URL_RDONLY) < 0) return AVERROR_IO; get_buffer(pb, info->pict.data[1], size / 4); url_fclose(pb); p[1] = 'V'; if (url_fopen(pb, fname, URL_RDONLY) < 0) return AVERROR_IO; get_buffer(pb, info->pict.data[2], size / 4); url_fclose(pb); return 0; }
static int sgi_read(ByteIOContext *f, int (*alloc_cb)(void *opaque, AVImageInfo *info), void *opaque) { SGIInfo sgi_info, *s = &sgi_info; AVImageInfo info1, *info = &info1; int ret; read_sgi_header(f, s); if (s->bytes_per_channel != 1) { return AVERROR_INVALIDDATA; } /* check for supported image dimensions */ if (s->dimension != 2 && s->dimension != 3) { return AVERROR_INVALIDDATA; } if (s->zsize == SGI_GRAYSCALE) { info->pix_fmt = PIX_FMT_GRAY8; } else if (s->zsize == SGI_RGB) { info->pix_fmt = PIX_FMT_RGB24; } else if (s->zsize == SGI_RGBA) { info->pix_fmt = PIX_FMT_RGBA32; } else { return AVERROR_INVALIDDATA; } info->width = s->xsize; info->height = s->ysize; ret = alloc_cb(opaque, info); if (ret) return ret; if (s->rle) { return read_rle_sgi(s, &info->pict, f); } else { return read_uncompressed_sgi(s, &info->pict, f); } return 0; /* not reached */ }
static int pnm_read1(ByteIOContext *f, int (*alloc_cb)(void *opaque, AVImageInfo *info), void *opaque, int allow_yuv) { int i, n, linesize, h; char buf1[32]; unsigned char *ptr; AVImageInfo info1, *info = &info1; int ret; pnm_get(f, buf1, sizeof(buf1)); if (!strcmp(buf1, "P4")) { info->pix_fmt = PIX_FMT_MONOWHITE; } else if (!strcmp(buf1, "P5")) { if (allow_yuv) info->pix_fmt = PIX_FMT_YUV420P; else info->pix_fmt = PIX_FMT_GRAY8; } else if (!strcmp(buf1, "P6")) { info->pix_fmt = PIX_FMT_RGB24; } else { return AVERROR_INVALIDDATA; } pnm_get(f, buf1, sizeof(buf1)); info->width = atoi(buf1); if (info->width <= 0) return AVERROR_INVALIDDATA; pnm_get(f, buf1, sizeof(buf1)); info->height = atoi(buf1); if (info->height <= 0) return AVERROR_INVALIDDATA; if (info->pix_fmt != PIX_FMT_MONOWHITE) { pnm_get(f, buf1, sizeof(buf1)); } /* more check if YUV420 */ if (info->pix_fmt == PIX_FMT_YUV420P) { if ((info->width & 1) != 0) return AVERROR_INVALIDDATA; h = (info->height * 2); if ((h % 3) != 0) return AVERROR_INVALIDDATA; h /= 3; info->height = h; } ret = alloc_cb(opaque, info); if (ret) return ret; switch(info->pix_fmt) { default: return AVERROR_INVALIDDATA; case PIX_FMT_RGB24: n = info->width * 3; goto do_read; case PIX_FMT_GRAY8: n = info->width; goto do_read; case PIX_FMT_MONOWHITE: n = (info->width + 7) >> 3; do_read: ptr = info->pict.data[0]; linesize = info->pict.linesize[0]; for(i = 0; i < info->height; i++) { get_buffer(f, ptr, n); ptr += linesize; } break; case PIX_FMT_YUV420P: { unsigned char *ptr1, *ptr2; n = info->width; ptr = info->pict.data[0]; linesize = info->pict.linesize[0]; for(i = 0; i < info->height; i++) { get_buffer(f, ptr, n); ptr += linesize; } ptr1 = info->pict.data[1]; ptr2 = info->pict.data[2]; n >>= 1; h = info->height >> 1; for(i = 0; i < h; i++) { get_buffer(f, ptr1, n); get_buffer(f, ptr2, n); ptr1 += info->pict.linesize[1]; ptr2 += info->pict.linesize[2]; } } break; } return 0; }