# HG changeset patch # User reimar # Date 1126296342 0 # Node ID 871e94131840abdba41e67d70711e34135d81ed5 # Parent 9dda08ef3e7ce6d253bf28ffdc0ab41fa88d6811 Ignore movi_end (except on error) to allow playing growing files. Also adds a check if stream_read read the requested length. This and the movi_end check on error help not accidently playing ID3 tags. diff -r 9dda08ef3e7c -r 871e94131840 libmpdemux/demux_audio.c --- a/libmpdemux/demux_audio.c Fri Sep 09 17:08:26 2005 +0000 +++ b/libmpdemux/demux_audio.c Fri Sep 09 20:05:42 2005 +0000 @@ -404,7 +404,7 @@ priv = demux->priv; s = demux->stream; - if(s->eof || (demux->movi_end && stream_tell(s) >= demux->movi_end) ) + if(s->eof) return 0; switch(priv->frmt) { @@ -412,15 +412,18 @@ while(1) { uint8_t hdr[4]; stream_read(s,hdr,4); - if (s->eof || (demux->movi_end && stream_tell(s) >= demux->movi_end)) + if (s->eof) return 0; l = mp_decode_mp3_header(hdr); if(l < 0) { + if (demux->movi_end && stream_tell(s) >= demux->movi_end) + return 0; // might be ID3 tag, i.e. EOF stream_skip(s,-3); } else { dp = new_demux_packet(l); memcpy(dp->buffer,hdr,4); - stream_read(s,dp->buffer + 4,l-4); + if (stream_read(s,dp->buffer + 4,l-4) != l-4) + return 0; priv->last_pts = priv->last_pts < 0 ? 0 : priv->last_pts + sh_audio->audio.dwScale/(float)sh_audio->samplerate; break; }