[FFmpeg-cvslog] avformat/subtitles: drop duplicated events
Clément Bœsch
git at videolan.org
Thu Sep 10 21:17:45 CEST 2015
ffmpeg | branch: master | Clément Bœsch <u at pkh.me> | Thu Sep 10 21:17:44 2015 +0200| [4f26c999124531ce52329de6fa83c82d15a8b43c] | committer: Clément Bœsch
avformat/subtitles: drop duplicated events
Fix Ticket #4843
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4f26c999124531ce52329de6fa83c82d15a8b43c
---
libavformat/subtitles.c | 29 +++++++++++++++++++++++++++++
1 file changed, 29 insertions(+)
diff --git a/libavformat/subtitles.c b/libavformat/subtitles.c
index 5bdbc8d..f25aa0e 100644
--- a/libavformat/subtitles.c
+++ b/libavformat/subtitles.c
@@ -166,6 +166,34 @@ static int cmp_pkt_sub_pos_ts(const void *a, const void *b)
return s1->pos > s2->pos ? 1 : -1;
}
+static void drop_dups(FFDemuxSubtitlesQueue *q)
+{
+ int i, drop = 0;
+
+ for (i = 1; i < q->nb_subs; i++) {
+ const int last_id = i - 1 - drop;
+ const AVPacket *last = &q->subs[last_id];
+
+ if (q->subs[i].pts == last->pts &&
+ q->subs[i].duration == last->duration &&
+ !strcmp(q->subs[i].data, last->data)) {
+
+ av_free_packet(&q->subs[i]);
+ drop++;
+ } else if (drop) {
+ q->subs[last_id + 1] = q->subs[i];
+ memset(&q->subs[i], 0, sizeof(q->subs[i])); // for safety
+ }
+ }
+
+ if (drop) {
+ q->nb_subs -= drop;
+
+ // TODO: forward log context down here
+ av_log(NULL, AV_LOG_WARNING, "Dropping %d duplicated subtitle events\n", drop);
+ }
+}
+
void ff_subtitles_queue_finalize(FFDemuxSubtitlesQueue *q)
{
int i;
@@ -176,6 +204,7 @@ void ff_subtitles_queue_finalize(FFDemuxSubtitlesQueue *q)
for (i = 0; i < q->nb_subs; i++)
if (q->subs[i].duration == -1 && i < q->nb_subs - 1)
q->subs[i].duration = q->subs[i + 1].pts - q->subs[i].pts;
+ drop_dups(q);
}
int ff_subtitles_queue_read_packet(FFDemuxSubtitlesQueue *q, AVPacket *pkt)
More information about the ffmpeg-cvslog
mailing list