changeset 188:6c9d6422a2f6 libavformat

update duration and start_time - add av_new_stream() usage
author bellard
date Fri, 08 Aug 2003 17:52:53 +0000
parents 2fa5e94ba716
children e3cfb9131dfa
files asf.c avidec.c rm.c
diffstat 3 files changed, 54 insertions(+), 28 deletions(-) [+]
line wrap: on
line diff
--- a/asf.c	Fri Aug 08 17:52:30 2003 +0000
+++ b/asf.c	Fri Aug 08 17:52:53 2003 +0000
@@ -48,7 +48,7 @@
     uint8_t v4[8];
 } GUID;
 
-typedef struct __attribute__((packed)) {
+typedef struct {
     GUID guid;			// generated by client computer
     uint64_t file_size;		// in bytes
                                 // invalid if broadcasting
@@ -811,16 +811,16 @@
 
             pos1 = url_ftell(pb);
 
-            st = av_mallocz(sizeof(AVStream));
+            st = av_new_stream(s, 0);
             if (!st)
                 goto fail;
-            avcodec_get_context_defaults(&st->codec);
-            s->streams[s->nb_streams] = st;
             asf_st = av_mallocz(sizeof(ASFStream));
             if (!asf_st)
                 goto fail;
             st->priv_data = asf_st;
-	    st->time_length = (asf->hdr.send_time - asf->hdr.preroll) / 10; // us
+            st->start_time = asf->hdr.preroll / (10000000 / AV_TIME_BASE);
+	    st->duration = (asf->hdr.send_time - asf->hdr.preroll) / 
+                (10000000 / AV_TIME_BASE);
             get_guid(pb, &g);
             if (!memcmp(&g, &audio_stream, sizeof(GUID))) {
                 type = CODEC_TYPE_AUDIO;
@@ -835,7 +835,7 @@
             get_le32(pb);
 	    st->id = get_le16(pb) & 0x7f; /* stream id */
             // mapping of asf ID to AV stream ID;
-            asf->asfid2avid[st->id] = s->nb_streams++;
+            asf->asfid2avid[st->id] = s->nb_streams - 1;
 
             get_le32(pb);
 	    st->codec.codec_type = type;
--- a/avidec.c	Fri Aug 08 17:52:30 2003 +0000
+++ b/avidec.c	Fri Aug 08 17:52:53 2003 +0000
@@ -85,8 +85,8 @@
     ByteIOContext *pb = &s->pb;
     uint32_t tag, tag1, handler;
     int codec_type, stream_index, frame_period, bit_rate, scale, rate;
-    unsigned int size;
-    int i;
+    unsigned int size, nb_frames;
+    int i, n;
     AVStream *st;
 
     if (get_riff(avi, pb) < 0)
@@ -131,14 +131,11 @@
             frame_period = get_le32(pb);
             bit_rate = get_le32(pb) * 8;
 	    url_fskip(pb, 4 * 4);
-            s->nb_streams = get_le32(pb);
-            for(i=0;i<s->nb_streams;i++) {
-                AVStream *st = av_mallocz(sizeof(AVStream));
+            n = get_le32(pb);
+            for(i=0;i<n;i++) {
+                st = av_new_stream(s, 0);
                 if (!st)
                     goto fail;
-                avcodec_get_context_defaults(&st->codec);
-
-                s->streams[i] = st;
 	    }
             url_fskip(pb, size - 7 * 4);
             break;
@@ -181,14 +178,20 @@
                     st->codec.frame_rate = 25;
                     st->codec.frame_rate_base = 1;
                 }
+                get_le32(pb); /* start */
+                nb_frames = get_le32(pb);
+                st->start_time = 0;
+                st->duration = (double)nb_frames * 
+                    st->codec.frame_rate_base * AV_TIME_BASE / 
+                    st->codec.frame_rate;
                 
                 if (avi->type == 1) {
-                    AVStream *st = av_mallocz(sizeof(AVStream));
+                    AVStream *st;
+
+                    st = av_new_stream(s, 0);
                     if (!st)
 		        goto fail;
                     
-		    avcodec_get_context_defaults(&st->codec);
-		    s->streams[s->nb_streams++] = st;
 		    stream_index++;
 		    
 		    for (i=0; AVI1Handlers[i].tag != 0; ++i)
@@ -200,16 +203,39 @@
                         s->streams[0]->codec.codec_id   = AVI1Handlers[i].vcid;
 		        s->streams[1]->codec.codec_type = CODEC_TYPE_AUDIO;
                         s->streams[1]->codec.codec_id   = AVI1Handlers[i].acid;
-		    } else
+		    } else {
 		        goto fail;
+                    }
 		}
 		
-		url_fskip(pb, size - 7 * 4);
+		url_fskip(pb, size - 9 * 4);
                 break;
             case MKTAG('a', 'u', 'd', 's'):
-                codec_type = CODEC_TYPE_AUDIO;
-                /* nothing really useful */
-                url_fskip(pb, size - 4);
+                {
+                    unsigned int length, rate;
+
+                    codec_type = CODEC_TYPE_AUDIO;
+
+                    if (stream_index >= s->nb_streams) {
+                        url_fskip(pb, size - 4);
+                        break;
+                    } 
+                    st = s->streams[stream_index];
+
+                    get_le32(pb); /* tag */
+                    get_le32(pb); /* flags */
+                    get_le16(pb); /* priority */
+                    get_le16(pb); /* language */
+                    get_le32(pb); /* initial frame */
+                    get_le32(pb); /* scale */
+                    rate = get_le32(pb);
+                    get_le32(pb); /* start */
+                    length = get_le32(pb); /* length, in samples or bytes */
+                    st->start_time = 0;
+                    if (rate != 0)
+                        st->duration = (int64_t)length * AV_TIME_BASE / rate;
+                    url_fskip(pb, size - 9 * 4);
+                }
                 break;
             default:
                 goto fail;
--- a/rm.c	Fri Aug 08 17:52:30 2003 +0000
+++ b/rm.c	Fri Aug 08 17:52:53 2003 +0000
@@ -473,7 +473,7 @@
     unsigned int tag, v;
     int tag_size, size, codec_data_size, i;
     int64_t codec_pos;
-    unsigned int h263_hack_version;
+    unsigned int h263_hack_version, start_time, duration;
     char buf[128];
     int flags = 0;
 
@@ -524,19 +524,19 @@
             get_str(pb, s->comment, sizeof(s->comment));
             break;
         case MKTAG('M', 'D', 'P', 'R'):
-            st = av_mallocz(sizeof(AVStream));
+            st = av_new_stream(s, 0);
             if (!st)
                 goto fail;
-            avcodec_get_context_defaults(&st->codec);
-            s->streams[s->nb_streams++] = st;
             st->id = get_be16(pb);
             get_be32(pb); /* max bit rate */
             st->codec.bit_rate = get_be32(pb); /* bit rate */
             get_be32(pb); /* max packet size */
             get_be32(pb); /* avg packet size */
-            get_be32(pb); /* start time */
+            start_time = get_be32(pb); /* start time */
             get_be32(pb); /* preroll */
-            get_be32(pb); /* duration */
+            duration = get_be32(pb); /* duration */
+            st->start_time = start_time * (AV_TIME_BASE / 1000);
+            st->duration = duration * (AV_TIME_BASE / 1000);
             get_str8(pb, buf, sizeof(buf)); /* desc */
             get_str8(pb, buf, sizeof(buf)); /* mimetype */
             codec_data_size = get_be32(pb);