vlc | branch: master | Francois Cartegnie <fcvlc...@free.fr> | Sat Nov 9 16:51:04 2013 +0900| [882f2d61180be43b54e3639d120f318b79fc9303] | committer: Francois Cartegnie
demux: asf: only substract preroll from presentation time and duration Offsets pts & duration > http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=882f2d61180be43b54e3639d120f318b79fc9303 --- modules/demux/asf/asf.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/modules/demux/asf/asf.c b/modules/demux/asf/asf.c index d56d0d4..1037592 100644 --- a/modules/demux/asf/asf.c +++ b/modules/demux/asf/asf.c @@ -673,6 +673,7 @@ static int DemuxPayload(demux_t *p_demux, struct asf_packet_t *pkt, int i_payloa ParsePayloadExtensions( p_demux, p_sys->track[i_stream_number], pkt, i_replicated_data_length, &b_packet_keyframe ); + i_base_pts -= p_sys->p_fp->i_preroll; pkt->i_skip += i_replicated_data_length; if( ! pkt->left || pkt->i_skip >= pkt->left ) @@ -685,6 +686,7 @@ static int DemuxPayload(demux_t *p_demux, struct asf_packet_t *pkt, int i_payloa /* Next byte is Presentation Time Delta */ i_pts_delta = pkt->p_peek[pkt->i_skip]; i_base_pts = (mtime_t)i_media_object_offset; + i_base_pts -= p_sys->p_fp->i_preroll; pkt->i_skip++; i_media_object_offset = 0; } @@ -693,7 +695,6 @@ static int DemuxPayload(demux_t *p_demux, struct asf_packet_t *pkt, int i_payloa i_base_pts = (mtime_t)pkt->send_time; } - i_base_pts -= p_sys->p_fp->i_preroll; if (i_base_pts < 0) i_base_pts = 0; // FIXME? i_base_pts *= 1000; _______________________________________________ vlc-commits mailing list vlc-commits@videolan.org https://mailman.videolan.org/listinfo/vlc-commits