# HG changeset patch # User stefano # Date 1283894635 0 # Node ID 9471234fb8ea61efadfb1813c960c6749164a006 # Parent 443f38ceeaad9c1b8c3b148dc719d5181c895839 Move av_picture_data_copy() to libavcore, and rename it av_image_copy(). diff -r 443f38ceeaad -r 9471234fb8ea avcodec.h --- a/avcodec.h Tue Sep 07 21:23:52 2010 +0000 +++ b/avcodec.h Tue Sep 07 21:23:55 2010 +0000 @@ -32,7 +32,7 @@ #define LIBAVCODEC_VERSION_MAJOR 52 #define LIBAVCODEC_VERSION_MINOR 87 -#define LIBAVCODEC_VERSION_MICRO 3 +#define LIBAVCODEC_VERSION_MICRO 4 #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ LIBAVCODEC_VERSION_MINOR, \ @@ -3950,15 +3950,15 @@ */ void av_fast_malloc(void *ptr, unsigned int *size, unsigned int min_size); +#if LIBAVCODEC_VERSION_MAJOR < 53 /** - * Copy image data in src_data to dst_data. - * - * @param dst_linesize linesizes for the image in dst_data - * @param src_linesize linesizes for the image in src_data + * @deprecated Deprecated in favor of av_image_copy(). */ +attribute_deprecated void av_picture_data_copy(uint8_t *dst_data[4], int dst_linesize[4], uint8_t *src_data[4], int src_linesize[4], enum PixelFormat pix_fmt, int width, int height); +#endif /** * Copy image src to dst. Wraps av_picture_data_copy() above. diff -r 443f38ceeaad -r 9471234fb8ea imgconvert.c --- a/imgconvert.c Tue Sep 07 21:23:52 2010 +0000 +++ b/imgconvert.c Tue Sep 07 21:23:55 2010 +0000 @@ -793,46 +793,20 @@ { return av_image_get_linesize(pix_fmt, width, plane); } -#endif void av_picture_data_copy(uint8_t *dst_data[4], int dst_linesize[4], uint8_t *src_data[4], int src_linesize[4], enum PixelFormat pix_fmt, int width, int height) { - const AVPixFmtDescriptor *desc = &av_pix_fmt_descriptors[pix_fmt]; - - if (desc->flags & PIX_FMT_HWACCEL) - return; - - if (desc->flags & PIX_FMT_PAL) { - av_image_copy_plane(dst_data[0], dst_linesize[0], - src_data[0], src_linesize[0], - width, height); - /* copy the palette */ - memcpy(dst_data[1], src_data[1], 4*256); - } else { - int i, planes_nb = 0; - - for (i = 0; i < desc->nb_components; i++) - planes_nb = FFMAX(planes_nb, desc->comp[i].plane + 1); - - for (i = 0; i < planes_nb; i++) { - int h = height; - int bwidth = av_image_get_linesize(pix_fmt, width, i); - if (i == 1 || i == 2) { - h= -((-height)>>desc->log2_chroma_h); - } - av_image_copy_plane(dst_data[i], dst_linesize[i], - src_data[i], src_linesize[i], - bwidth, h); - } - } + av_image_copy(dst_data, dst_linesize, src_data, src_linesize, + pix_fmt, width, height); } +#endif void av_picture_copy(AVPicture *dst, const AVPicture *src, enum PixelFormat pix_fmt, int width, int height) { - av_picture_data_copy(dst->data, dst->linesize, src->data, + av_image_copy(dst->data, dst->linesize, src->data, src->linesize, pix_fmt, width, height); }