Commit e56b0984 authored by Clément Bœsch's avatar Clément Bœsch

lavf/srtenc: ignore invalid timed packets instead of failing.

This way we don't abort in the middle of remuxing, just warn about an
event ignored. The index increment is moved to make sure the output
numbers still make sense.
parent a1e093a6
...@@ -35,6 +35,8 @@ typedef struct SRTContext{ ...@@ -35,6 +35,8 @@ typedef struct SRTContext{
static int srt_write_header(AVFormatContext *avf) static int srt_write_header(AVFormatContext *avf)
{ {
SRTContext *srt = avf->priv_data;
if (avf->nb_streams != 1 || if (avf->nb_streams != 1 ||
avf->streams[0]->codec->codec_type != AVMEDIA_TYPE_SUBTITLE) { avf->streams[0]->codec->codec_type != AVMEDIA_TYPE_SUBTITLE) {
av_log(avf, AV_LOG_ERROR, av_log(avf, AV_LOG_ERROR,
...@@ -50,6 +52,7 @@ static int srt_write_header(AVFormatContext *avf) ...@@ -50,6 +52,7 @@ static int srt_write_header(AVFormatContext *avf)
return AVERROR(EINVAL); return AVERROR(EINVAL);
} }
avpriv_set_pts_info(avf->streams[0], 64, 1, 1000); avpriv_set_pts_info(avf->streams[0], 64, 1, 1000);
srt->index = 1;
return 0; return 0;
} }
...@@ -58,7 +61,6 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt) ...@@ -58,7 +61,6 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt)
SRTContext *srt = avf->priv_data; SRTContext *srt = avf->priv_data;
int write_ts = avf->streams[0]->codec->codec_id != AV_CODEC_ID_SRT; int write_ts = avf->streams[0]->codec->codec_id != AV_CODEC_ID_SRT;
srt->index++;
if (write_ts) { if (write_ts) {
int64_t s = pkt->pts, e, d = pkt->duration; int64_t s = pkt->pts, e, d = pkt->duration;
...@@ -66,8 +68,9 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt) ...@@ -66,8 +68,9 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt)
/* For backward compatibility, fallback to convergence_duration. */ /* For backward compatibility, fallback to convergence_duration. */
d = pkt->convergence_duration; d = pkt->convergence_duration;
if (s == AV_NOPTS_VALUE || d < 0) { if (s == AV_NOPTS_VALUE || d < 0) {
av_log(avf, AV_LOG_ERROR, "Insufficient timestamps.\n"); av_log(avf, AV_LOG_WARNING,
return AVERROR(EINVAL); "Insufficient timestamps in event number %d.\n", srt->index);
return 0;
} }
e = s + d; e = s + d;
avio_printf(avf->pb, "%d\n%02d:%02d:%02d,%03d --> %02d:%02d:%02d,%03d\n", avio_printf(avf->pb, "%d\n%02d:%02d:%02d,%03d --> %02d:%02d:%02d,%03d\n",
...@@ -81,6 +84,7 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt) ...@@ -81,6 +84,7 @@ static int srt_write_packet(AVFormatContext *avf, AVPacket *pkt)
if (write_ts) if (write_ts)
avio_write(avf->pb, "\n\n", 2); avio_write(avf->pb, "\n\n", 2);
avio_flush(avf->pb); avio_flush(avf->pb);
srt->index++;
return 0; return 0;
} }
......
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