changeset 570:d82ccc7cff1c libavformat

set keyframe flag at a more central place instead of in every demuxer for containers which only store intra only streams
author michael
date Fri, 22 Oct 2004 01:51:17 +0000
parents aca10aa7686f
children 4a755492b90b
files au.c utils.c wav.c
diffstat 3 files changed, 24 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/au.c	Tue Oct 19 10:37:02 2004 +0000
+++ b/au.c	Fri Oct 22 01:51:17 2004 +0000
@@ -164,7 +164,6 @@
     if (av_new_packet(pkt, MAX_SIZE))
         return AVERROR_IO;
     pkt->stream_index = 0;
-    pkt->flags |= PKT_FLAG_KEY;    
 
     ret = get_buffer(&s->pb, pkt->data, pkt->size);
     if (ret < 0)
--- a/utils.c	Tue Oct 19 10:37:02 2004 +0000
+++ b/utils.c	Fri Oct 22 01:51:17 2004 +0000
@@ -591,6 +591,27 @@
     }
 }
 
+static int is_intra_only(AVCodecContext *enc){
+    if(enc->codec_type == CODEC_TYPE_AUDIO){
+        return 1;
+    }else if(enc->codec_type == CODEC_TYPE_VIDEO){
+        switch(enc->codec_id){
+        case CODEC_ID_MJPEG:
+        case CODEC_ID_MJPEGB:
+        case CODEC_ID_LJPEG:
+        case CODEC_ID_RAWVIDEO:
+        case CODEC_ID_DVVIDEO:
+        case CODEC_ID_HUFFYUV:
+        case CODEC_ID_ASV1:
+        case CODEC_ID_ASV2:
+        case CODEC_ID_VCR1:
+            return 1;
+        default: break;
+        }
+    }
+    return 0;
+}
+
 static int64_t lsb2full(int64_t lsb, int64_t last_ts, int lsb_bits){
     int64_t mask = lsb_bits < 64 ? (1LL<<lsb_bits)-1 : -1LL;
     int64_t delta= last_ts - mask/2;
@@ -617,6 +638,9 @@
         }
     }
 
+    if(is_intra_only(&st->codec))
+        pkt->flags |= PKT_FLAG_KEY;
+
     /* do we have a video B frame ? */
     presentation_delayed = 0;
     if (st->codec.codec_type == CODEC_TYPE_VIDEO) {
--- a/wav.c	Tue Oct 19 10:37:02 2004 +0000
+++ b/wav.c	Fri Oct 22 01:51:17 2004 +0000
@@ -331,7 +331,6 @@
     if (av_new_packet(pkt, size))
         return AVERROR_IO;
     pkt->stream_index = 0;
-    pkt->flags |= PKT_FLAG_KEY;    
 
     ret = get_buffer(&s->pb, pkt->data, pkt->size);
     if (ret < 0)