Commit 61e811ae authored by michael's avatar michael

Get rid of a fake timestamp discontinuity at the begin of V.VOB.

This solution isnt really correct but its quite simple, correct would
be to do a second pass over the packets after all the headers have been
collected.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@12157 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 7155c9ec
...@@ -641,7 +641,8 @@ static void update_initial_durations(AVFormatContext *s, AVStream *st, AVPacket ...@@ -641,7 +641,8 @@ static void update_initial_durations(AVFormatContext *s, AVStream *st, AVPacket
for(; pktl; pktl= pktl->next){ for(; pktl; pktl= pktl->next){
if(pktl->pkt.stream_index != pkt->stream_index) if(pktl->pkt.stream_index != pkt->stream_index)
continue; continue;
if(pktl->pkt.pts == pktl->pkt.dts && pktl->pkt.dts == AV_NOPTS_VALUE){ if(pktl->pkt.pts == pktl->pkt.dts && pktl->pkt.dts == AV_NOPTS_VALUE
&& !pktl->pkt.duration){
pktl->pkt.pts= pktl->pkt.dts= st->cur_dts; pktl->pkt.pts= pktl->pkt.dts= st->cur_dts;
st->cur_dts += pkt->duration; st->cur_dts += pkt->duration;
pktl->pkt.duration= pkt->duration; pktl->pkt.duration= pkt->duration;
...@@ -666,7 +667,7 @@ static void compute_pkt_fields(AVFormatContext *s, AVStream *st, ...@@ -666,7 +667,7 @@ static void compute_pkt_fields(AVFormatContext *s, AVStream *st,
if (den && num) { if (den && num) {
pkt->duration = av_rescale(1, num * (int64_t)st->time_base.den, den * (int64_t)st->time_base.num); pkt->duration = av_rescale(1, num * (int64_t)st->time_base.den, den * (int64_t)st->time_base.num);
if(pkt->dts == AV_NOPTS_VALUE && pkt->pts == AV_NOPTS_VALUE && st->cur_dts == 0) if(st->cur_dts == 0)
update_initial_durations(s, st, pkt); update_initial_durations(s, st, pkt);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment