diff options
author | Clément Bœsch <u@pkh.me> | 2013-10-04 09:25:08 +0000 |
---|---|---|
committer | Clément Bœsch <clement@stupeflix.com> | 2013-10-04 09:25:11 +0000 |
commit | d4dc673455164c5c15092abd163ec808be24f694 (patch) | |
tree | e59ec2c2fcc7080123f6366ba7d914badf65feb6 | |
parent | dbfe61100bd7c9c9afb34b35a7e2cbf28807062d (diff) | |
download | ffmpeg-d4dc673455164c5c15092abd163ec808be24f694.tar.gz |
avformat/vobsub: raise packet even if apparently incomplete.
This restore the latest packet which was dropped from the FATE test in
dbfe61100.
-rw-r--r-- | libavformat/mpeg.c | 5 | ||||
-rw-r--r-- | tests/ref/fate/sub2video | 1 |
2 files changed, 5 insertions, 1 deletions
diff --git a/libavformat/mpeg.c b/libavformat/mpeg.c index f59cc58ce4..64c5a4ff2a 100644 --- a/libavformat/mpeg.c +++ b/libavformat/mpeg.c @@ -849,8 +849,11 @@ static int vobsub_read_packet(AVFormatContext *s, AVPacket *pkt) int pkt_size; ret = mpegps_read_pes_header(vobsub->sub_ctx, NULL, &startcode, &pts, &dts); - if (ret < 0) + if (ret < 0) { + if (pkt->size) // raise packet even if incomplete + break; FAIL(ret); + } to_read = ret & 0xffff; new_pos = avio_tell(pb); pkt_size = ret + (new_pos - old_pos); diff --git a/tests/ref/fate/sub2video b/tests/ref/fate/sub2video index 86044d238d..761b1ce029 100644 --- a/tests/ref/fate/sub2video +++ b/tests/ref/fate/sub2video @@ -92,3 +92,4 @@ 1, 210600, 210600, 1831, 665, 0x55580135, F=0x0 1, 214771, 214771, 1558, 1216, 0x50d1f6c5, F=0x0 1, 225640, 225640, 2127, 2133, 0x670c11a5, F=0x0 +1, 227834, 227834, 1262, 1264, 0xc1d9fc57, F=0x0 |