# HG changeset patch # User arpi # Date 1013502469 0 # Node ID 80256840ff29ce58e890142ad7e923ccaad86bd8 # Parent 40e8b4b8b250320c834666ff502c8d313f1f0d55 ehh. forgot to commit this one... - workaround for files with bad index (first chunk absolute, other relative offsets) -> fixes many 'no video stream found' bugreports diff -r 40e8b4b8b250 -r 80256840ff29 libmpdemux/demux_avi.c --- a/libmpdemux/demux_avi.c Tue Feb 12 01:20:59 2002 +0000 +++ b/libmpdemux/demux_avi.c Tue Feb 12 08:27:49 2002 +0000 @@ -417,13 +417,24 @@ priv->idx_pos=0; priv->idx_pos_a=0; priv->idx_pos_v=0; - if(priv->idx_size>0){ + if(priv->idx_size>1){ // decide index format: +#if 1 + if(((AVIINDEXENTRY *)priv->idx)[0].dwChunkOffsetmovi_start || + ((AVIINDEXENTRY *)priv->idx)[1].dwChunkOffsetmovi_start) + priv->idx_offset=demuxer->movi_start-4; + else + priv->idx_offset=0; +#else if(((AVIINDEXENTRY *)priv->idx)[0].dwChunkOffsetmovi_start) priv->idx_offset=demuxer->movi_start-4; else priv->idx_offset=0; - mp_msg(MSGT_DEMUX,MSGL_V,"AVI index offset: %d\n",priv->idx_offset); +#endif + mp_msg(MSGT_DEMUX,MSGL_V,"AVI index offset: 0x%X (movi=0x%X idx0=0x%X idx1=0x%X)\n", + (int)priv->idx_offset,(int)demuxer->movi_start, + (int)((AVIINDEXENTRY *)priv->idx)[0].dwChunkOffset, + (int)((AVIINDEXENTRY *)priv->idx)[1].dwChunkOffset); } // demuxer->endpos=avi_header.movi_end;