# HG changeset patch # User ods15 # Date 1163882662 0 # Node ID f5180197d7adeb9497bc2bb9c21c9eda196e97c9 # Parent fbf3f8cd0bf672bc8ca183817d2b21fa470ad369 fix demux_nut to give proper (estimate) of percent position after a seek diff -r fbf3f8cd0bf6 -r f5180197d7ad libmpdemux/demux_nut.c --- a/libmpdemux/demux_nut.c Sat Nov 18 20:13:18 2006 +0000 +++ b/libmpdemux/demux_nut.c Sat Nov 18 20:44:22 2006 +0000 @@ -260,8 +260,10 @@ priv->s[0].time_base.den; while ((ret = nut_seek(nut, time_pos, nutflags, tmp)) == NUT_ERR_EAGAIN); + priv->last_pts = -1; if (ret) mp_msg(MSGT_HEADER, MSGL_ERR, "NUT error: %s\n", nut_error(ret)); if (sh_audio) resync_audio_stream(sh_audio); + demuxer->filepos = stream_tell(demuxer->stream); } static int demux_control_nut(demuxer_t * demuxer, int cmd, void * arg) { @@ -273,7 +275,7 @@ priv->s[0].time_base.den; return DEMUXER_CTRL_OK; case DEMUXER_CTRL_GET_PERCENT_POS: - if (priv->s[0].max_pts == 0) + if (priv->s[0].max_pts == 0 || priv->last_pts == -1) return DEMUXER_CTRL_DONTKNOW; *((int *)arg) = priv->last_pts * 100 / (double)priv->s[0].max_pts;