[SCM] libav/experimental: Make XAN decoder return meaningful error codes.

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 17:17:52 UTC 2013


The following commit has been merged in the experimental branch:
commit 082a857522fb6b2cf1dc5f2d7251063c9531d62d
Author: Stefano Sabatini <stefano.sabatini-lala at poste.it>
Date:   Mon Oct 18 13:19:53 2010 +0000

    Make XAN decoder return meaningful error codes.
    
    Originally committed as revision 25516 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavcodec/xan.c b/libavcodec/xan.c
index 3f6aa8c..ebc2b42 100644
--- a/libavcodec/xan.c
+++ b/libavcodec/xan.c
@@ -69,7 +69,7 @@ static av_cold int xan_decode_init(AVCodecContext *avctx)
     if ((avctx->codec->id == CODEC_ID_XAN_WC3) &&
         (s->avctx->palctrl == NULL)) {
         av_log(avctx, AV_LOG_ERROR, " WC3 Xan video: palette expected.\n");
-        return -1;
+        return AVERROR(EINVAL);
     }
 
     avctx->pix_fmt = PIX_FMT_PAL8;
@@ -77,12 +77,12 @@ static av_cold int xan_decode_init(AVCodecContext *avctx)
     s->buffer1_size = avctx->width * avctx->height;
     s->buffer1 = av_malloc(s->buffer1_size);
     if (!s->buffer1)
-        return -1;
+        return AVERROR(ENOMEM);
     s->buffer2_size = avctx->width * avctx->height;
     s->buffer2 = av_malloc(s->buffer2_size + 130);
     if (!s->buffer2) {
         av_freep(&s->buffer1);
-        return -1;
+        return AVERROR(ENOMEM);
     }
 
     return 0;
@@ -359,13 +359,13 @@ static int xan_decode_frame(AVCodecContext *avctx,
                             AVPacket *avpkt)
 {
     const uint8_t *buf = avpkt->data;
-    int buf_size = avpkt->size;
+    int ret, buf_size = avpkt->size;
     XanContext *s = avctx->priv_data;
     AVPaletteControl *palette_control = avctx->palctrl;
 
-    if (avctx->get_buffer(avctx, &s->current_frame)) {
+    if ((ret = avctx->get_buffer(avctx, &s->current_frame))) {
         av_log(s->avctx, AV_LOG_ERROR, "  Xan Video: get_buffer() failed\n");
-        return -1;
+        return ret;
     }
     s->current_frame.reference = 3;
 

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list