summaryrefslogtreecommitdiffstats
path: root/mplayer.c
diff options
context:
space:
mode:
authorUoti Urpala <uau@glyph.nonexistent.invalid>2010-11-13 15:48:26 +0200
committerUoti Urpala <uau@glyph.nonexistent.invalid>2010-11-13 16:48:31 +0200
commit642ce15ef770dd5dbea7c7ee16cbf45f6e86feae (patch)
tree5613aa04b5b9186b0a52612a4f0eb9164bb60742 /mplayer.c
parent1a336d6616c92c7e3a73500f6b4bb7b95e1268c2 (diff)
downloadmpv-642ce15ef770dd5dbea7c7ee16cbf45f6e86feae.tar.bz2
mpv-642ce15ef770dd5dbea7c7ee16cbf45f6e86feae.tar.xz
core: give pts as parameter to demuxer_get_current_chapter()
demuxer_get_current_chapter() accessed sh_video/sh_audio pts fields to determine playback position. demux layer shouldn't access those and the values used weren't quite correct anyway. Give the playback position as a parameter to the demux layer function instead. Also change the top-level get_current_chapter() to use get_current_time() in the timeline case where it didn't refer to demux layer.
Diffstat (limited to 'mplayer.c')
-rw-r--r--mplayer.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/mplayer.c b/mplayer.c
index 87e759ac92..83c6328b5d 100644
--- a/mplayer.c
+++ b/mplayer.c
@@ -2915,12 +2915,12 @@ int get_percent_pos(struct MPContext *mpctx)
// -2 is no chapters, -1 is before first chapter
int get_current_chapter(struct MPContext *mpctx)
{
- if (!mpctx->chapters || !mpctx->sh_video)
+ double current_pts = get_current_time(mpctx);
+ if (!mpctx->chapters)
return FFMAX(mpctx->last_chapter_seek,
- demuxer_get_current_chapter(mpctx->demuxer));
+ demuxer_get_current_chapter(mpctx->demuxer, current_pts));
int i;
- double current_pts = mpctx->sh_video->pts;
for (i = 1; i < mpctx->num_chapters; i++)
if (current_pts < mpctx->chapters[i].start)
break;
@@ -3913,7 +3913,7 @@ if((stream_dump_type)&&(stream_dump_type<4)){
&& stream_dump_type==2) fwrite(&in_size,1,4,f);
if(in_size>0) fwrite(start,in_size,1,f);
if (opts->chapterrange[1] > 0) {
- int cur_chapter = demuxer_get_current_chapter(mpctx->demuxer);
+ int cur_chapter = demuxer_get_current_chapter(mpctx->demuxer, 0);
if(cur_chapter!=-1 && cur_chapter+1 > opts->chapterrange[1])
break;
}