summaryrefslogtreecommitdiffstats
path: root/demux_asf.c
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-08-22 19:03:15 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-08-22 19:03:15 +0000
commit408f919293c06cca57dd488d1d4857095e0b4adc (patch)
treea074b8f6176f3689ac6f54d639487c5d5c7a93eb /demux_asf.c
parentaa2a852dea8870b744dc07d25601044401f90c90 (diff)
downloadmpv-408f919293c06cca57dd488d1d4857095e0b4adc.tar.bz2
mpv-408f919293c06cca57dd488d1d4857095e0b4adc.tar.xz
seeking flags implemented: 0x1=rel/abs and 0x2=time/percent
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@1629 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'demux_asf.c')
-rw-r--r--demux_asf.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/demux_asf.c b/demux_asf.c
index c159c7c154..8ff31f0866 100644
--- a/demux_asf.c
+++ b/demux_asf.c
@@ -327,13 +327,15 @@ void demux_seek_asf(demuxer_t *demuxer,float rel_seek_secs,int flags){
//================= seek in ASF ==========================
float p_rate=10; // packets / sec
- off_t rel_seek_packs=rel_seek_secs*p_rate; // FIXME: int may be enough?
+ off_t rel_seek_packs=(flags&2)? // FIXME: int may be enough?
+ (rel_seek_secs*(demuxer->movi_end-demuxer->movi_start)/asf_packetsize):
+ (rel_seek_secs*p_rate);
off_t rel_seek_bytes=rel_seek_packs*asf_packetsize;
off_t newpos;
//printf("ASF: packs: %d duration: %d \n",(int)fileh.packets,*((int*)&fileh.duration));
// printf("ASF_seek: %d secs -> %d packs -> %d bytes \n",
// rel_seek_secs,rel_seek_packs,rel_seek_bytes);
- newpos=demuxer->filepos+rel_seek_bytes;
+ newpos=((flags&1)?demuxer->movi_start:demuxer->filepos)+rel_seek_bytes;
if(newpos<0 || newpos<demuxer->movi_start) newpos=demuxer->movi_start;
// printf("\r -- asf: newpos=%d -- \n",newpos);
stream_seek(demuxer->stream,newpos);