1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-08 13:22:53 +02:00

avformat/hdsenc: Add explicit deinit function

hdsenc already had an explicit function to free all allocations in case
of an error, but it was not marked as deinit function, so that it was
not called automatically when the AVFormatContext for muxing gets freed.

Using an explicit deinit function also makes the code cleaner by
allowing to return immediately without "goto fail".

Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
This commit is contained in:
Andreas Rheinhardt 2019-10-23 13:46:46 +02:00
parent 7afd34050c
commit 09bac9009e

View File

@ -317,21 +317,18 @@ static int hds_write_header(AVFormatContext *s)
ff_const59 AVOutputFormat *oformat; ff_const59 AVOutputFormat *oformat;
if (mkdir(s->url, 0777) == -1 && errno != EEXIST) { if (mkdir(s->url, 0777) == -1 && errno != EEXIST) {
ret = AVERROR(errno);
av_log(s, AV_LOG_ERROR , "Failed to create directory %s\n", s->url); av_log(s, AV_LOG_ERROR , "Failed to create directory %s\n", s->url);
goto fail; return AVERROR(errno);
} }
oformat = av_guess_format("flv", NULL, NULL); oformat = av_guess_format("flv", NULL, NULL);
if (!oformat) { if (!oformat) {
ret = AVERROR_MUXER_NOT_FOUND; return AVERROR_MUXER_NOT_FOUND;
goto fail;
} }
c->streams = av_mallocz_array(s->nb_streams, sizeof(*c->streams)); c->streams = av_mallocz_array(s->nb_streams, sizeof(*c->streams));
if (!c->streams) { if (!c->streams) {
ret = AVERROR(ENOMEM); return AVERROR(ENOMEM);
goto fail;
} }
for (i = 0; i < s->nb_streams; i++) { for (i = 0; i < s->nb_streams; i++) {
@ -341,8 +338,7 @@ static int hds_write_header(AVFormatContext *s)
if (!st->codecpar->bit_rate) { if (!st->codecpar->bit_rate) {
av_log(s, AV_LOG_ERROR, "No bit rate set for stream %d\n", i); av_log(s, AV_LOG_ERROR, "No bit rate set for stream %d\n", i);
ret = AVERROR(EINVAL); return AVERROR(EINVAL);
goto fail;
} }
if (st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) { if (st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) {
if (os->has_video) { if (os->has_video) {
@ -358,8 +354,7 @@ static int hds_write_header(AVFormatContext *s)
os->has_audio = 1; os->has_audio = 1;
} else { } else {
av_log(s, AV_LOG_ERROR, "Unsupported stream type in stream %d\n", i); av_log(s, AV_LOG_ERROR, "Unsupported stream type in stream %d\n", i);
ret = AVERROR(EINVAL); return AVERROR(EINVAL);
goto fail;
} }
os->bitrate += s->streams[i]->codecpar->bit_rate; os->bitrate += s->streams[i]->codecpar->bit_rate;
@ -367,8 +362,7 @@ static int hds_write_header(AVFormatContext *s)
os->first_stream = i; os->first_stream = i;
ctx = avformat_alloc_context(); ctx = avformat_alloc_context();
if (!ctx) { if (!ctx) {
ret = AVERROR(ENOMEM); return AVERROR(ENOMEM);
goto fail;
} }
os->ctx = ctx; os->ctx = ctx;
ctx->oformat = oformat; ctx->oformat = oformat;
@ -379,8 +373,7 @@ static int hds_write_header(AVFormatContext *s)
AVIO_FLAG_WRITE, os, AVIO_FLAG_WRITE, os,
NULL, hds_write, NULL); NULL, hds_write, NULL);
if (!ctx->pb) { if (!ctx->pb) {
ret = AVERROR(ENOMEM); return AVERROR(ENOMEM);
goto fail;
} }
} else { } else {
ctx = os->ctx; ctx = os->ctx;
@ -388,8 +381,7 @@ static int hds_write_header(AVFormatContext *s)
s->streams[i]->id = c->nb_streams; s->streams[i]->id = c->nb_streams;
if (!(st = avformat_new_stream(ctx, NULL))) { if (!(st = avformat_new_stream(ctx, NULL))) {
ret = AVERROR(ENOMEM); return AVERROR(ENOMEM);
goto fail;
} }
avcodec_parameters_copy(st->codecpar, s->streams[i]->codecpar); avcodec_parameters_copy(st->codecpar, s->streams[i]->codecpar);
st->codecpar->codec_tag = 0; st->codecpar->codec_tag = 0;
@ -403,7 +395,7 @@ static int hds_write_header(AVFormatContext *s)
OutputStream *os = &c->streams[i]; OutputStream *os = &c->streams[i];
int j; int j;
if ((ret = avformat_write_header(os->ctx, NULL)) < 0) { if ((ret = avformat_write_header(os->ctx, NULL)) < 0) {
goto fail; return ret;
} }
os->ctx_inited = 1; os->ctx_inited = 1;
avio_flush(os->ctx->pb); avio_flush(os->ctx->pb);
@ -414,7 +406,7 @@ static int hds_write_header(AVFormatContext *s)
"%s/stream%d_temp", s->url, i); "%s/stream%d_temp", s->url, i);
ret = init_file(s, os, 0); ret = init_file(s, os, 0);
if (ret < 0) if (ret < 0)
goto fail; return ret;
if (!os->has_video && c->min_frag_duration <= 0) { if (!os->has_video && c->min_frag_duration <= 0) {
av_log(s, AV_LOG_WARNING, av_log(s, AV_LOG_WARNING,
@ -425,9 +417,6 @@ static int hds_write_header(AVFormatContext *s)
} }
ret = write_manifest(s, 0); ret = write_manifest(s, 0);
fail:
if (ret)
hds_free(s);
return ret; return ret;
} }
@ -557,7 +546,6 @@ static int hds_write_trailer(AVFormatContext *s)
rmdir(s->url); rmdir(s->url);
} }
hds_free(s);
return 0; return 0;
} }
@ -588,5 +576,6 @@ AVOutputFormat ff_hds_muxer = {
.write_header = hds_write_header, .write_header = hds_write_header,
.write_packet = hds_write_packet, .write_packet = hds_write_packet,
.write_trailer = hds_write_trailer, .write_trailer = hds_write_trailer,
.deinit = hds_free,
.priv_class = &hds_class, .priv_class = &hds_class,
}; };