[FFmpeg-cvslog] examples/decode_video: switch to the new decoding API

Anton Khirnov git at videolan.org
Tue Apr 4 20:50:06 EEST 2017


ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Wed Oct 19 21:56:22 2016 +0200| [728ea23cce07467b732f538c87c13da13dd6dcf3] | committer: Anton Khirnov

examples/decode_video: switch to the new decoding API

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=728ea23cce07467b732f538c87c13da13dd6dcf3
---

 doc/examples/decode_video.c | 43 +++++++++++++++++++++++--------------------
 1 file changed, 23 insertions(+), 20 deletions(-)

diff --git a/doc/examples/decode_video.c b/doc/examples/decode_video.c
index 4c1068b..7414643 100644
--- a/doc/examples/decode_video.c
+++ b/doc/examples/decode_video.c
@@ -54,26 +54,31 @@ static void decode(AVCodecContext *dec_ctx, AVFrame *frame, AVPacket *pkt,
                    const char *filename)
 {
     char buf[1024];
-    int ret, got_picture;
+    int ret;
+
+    ret = avcodec_send_packet(dec_ctx, pkt);
+    if (ret < 0) {
+        fprintf(stderr, "Error sending a packet for decoding\n");
+        exit(1);
+    }
 
-    while (pkt->size > 0) {
-        ret = avcodec_decode_video2(dec_ctx, frame, &got_picture, pkt);
-        if (ret < 0) {
-            fprintf(stderr, "Error while decoding frame %d\n", dec_ctx->frame_number);
+    while (ret >= 0) {
+        ret = avcodec_receive_frame(dec_ctx, frame);
+        if (ret == AVERROR(EAGAIN) || ret == AVERROR_EOF)
+            return;
+        else if (ret < 0) {
+            fprintf(stderr, "Error during decoding\n");
             exit(1);
         }
-        if (got_picture) {
-            printf("saving frame %3d\n", dec_ctx->frame_number);
-            fflush(stdout);
-
-            /* the picture is allocated by the decoder. no need to
-               free it */
-            snprintf(buf, sizeof(buf), filename, dec_ctx->frame_number);
-            pgm_save(frame->data[0], frame->linesize[0],
-                     frame->width, frame->height, buf);
-        }
-        pkt->size -= ret;
-        pkt->data += ret;
+
+        printf("saving frame %3d\n", dec_ctx->frame_number);
+        fflush(stdout);
+
+        /* the picture is allocated by the decoder. no need to
+           free it */
+        snprintf(buf, sizeof(buf), filename, dec_ctx->frame_number);
+        pgm_save(frame->data[0], frame->linesize[0],
+                 frame->width, frame->height, buf);
     }
 }
 
@@ -161,9 +166,7 @@ int main(int argc, char **argv)
     }
 
     /* flush the decoder */
-    avpkt.data = NULL;
-    avpkt.size = 0;
-    decode(c, picture, &avpkt, outfilename);
+    decode(c, picture, NULL, outfilename);
 
     fclose(f);
 



More information about the ffmpeg-cvslog mailing list