aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Thelen <ffmpeg-dev@c-14.de>2015-09-11 21:49:07 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2015-12-06 12:40:49 +0100
commitc6769b6d56bea1548a1c0167fdc322991bd46e50 (patch)
treef926c816be55b7f90cf3b3192db1c0cb3615aac1
parent7cdd319b01cfacc5ab07744ee3422a46b6f2c754 (diff)
downloadffmpeg-c6769b6d56bea1548a1c0167fdc322991bd46e50.tar.gz
lavf/webvttenc: Require webvtt file to contain exactly one WebVTT stream.
Not requiring this can end up producing hilariously broken files together with -c:s copy (e.g. a webvtt file containing binary subtitle data). Signed-off-by: Simon Thelen <ffmpeg-dev@c-14.de> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> (cherry picked from commit b84232694ef0c6897e82b52326c9ea4027c69ec4) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r--libavformat/webvttenc.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/libavformat/webvttenc.c b/libavformat/webvttenc.c
index b93993d55c..c386538718 100644
--- a/libavformat/webvttenc.c
+++ b/libavformat/webvttenc.c
@@ -46,8 +46,14 @@ static void webvtt_write_time(AVIOContext *pb, int64_t millisec)
static int webvtt_write_header(AVFormatContext *ctx)
{
AVStream *s = ctx->streams[0];
+ AVCodecContext *avctx = ctx->streams[0]->codec;
AVIOContext *pb = ctx->pb;
+ if (ctx->nb_streams != 1 || avctx->codec_id != AV_CODEC_ID_WEBVTT) {
+ av_log(ctx, AV_LOG_ERROR, "Exactly one WebVTT stream is needed.\n");
+ return AVERROR(EINVAL);
+ }
+
avpriv_set_pts_info(s, 64, 1, 1000);
avio_printf(pb, "WEBVTT\n");