]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
fix seeking in wma
authormichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Mon, 29 Jan 2007 14:54:55 +0000 (14:54 +0000)
committermichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Mon, 29 Jan 2007 14:54:55 +0000 (14:54 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@7759 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavformat/asf.c

index dce7233d51c8b8c1829b572a2916ae23af4eed78..43943282fd2289a75b8c9fd2705686a491f1220f 100644 (file)
@@ -673,7 +673,8 @@ static int asf_read_packet(AVFormatContext *s, AVPacket *pkt)
             asf->packet_multi_size -= asf->packet_obj_size;
             //printf("COMPRESS size  %d  %d  %d   ms:%d\n", asf->packet_obj_size, asf->packet_frag_timestamp, asf->packet_size_left, asf->packet_multi_size);
         }
-        if (asf_st->pkt.size != asf->packet_obj_size) { //FIXME is this condition sufficient?
+        if (   asf_st->pkt.size != asf->packet_obj_size
+            || asf_st->frag_offset + asf->packet_frag_size > asf_st->pkt.size) { //FIXME is this condition sufficient?
             if(asf_st->pkt.data){
                 av_log(s, AV_LOG_INFO, "freeing incomplete packet size %d, new %d\n", asf_st->pkt.size, asf->packet_obj_size);
                 asf_st->frag_offset = 0;