Pushed the patchset. On 11/16/18 2:27 PM, Karthick J wrote: > --- > libavformat/dashenc.c | 10 ++++++++-- > 1 file changed, 8 insertions(+), 2 deletions(-) > > diff --git a/libavformat/dashenc.c b/libavformat/dashenc.c > index d151921175..2c1cce0c92 100644 > --- a/libavformat/dashenc.c > +++ b/libavformat/dashenc.c > @@ -168,6 +168,8 @@ static int dashenc_io_open(AVFormatContext *s, > AVIOContext **pb, char *filename, > URLContext *http_url_context = ffio_geturlcontext(*pb); > av_assert0(http_url_context); > err = ff_http_do_new_request(http_url_context, filename); > + if (err < 0) > + ff_format_io_close(s, pb); > #endif > } > return err; > @@ -177,6 +179,9 @@ static void dashenc_io_close(AVFormatContext *s, > AVIOContext **pb, char *filenam > DASHContext *c = s->priv_data; > int http_base_proto = filename ? ff_is_http_proto(filename) : 0; > > + if (!*pb) > + return; > + > if (!http_base_proto || !c->http_persistent) { > ff_format_io_close(s, pb); > #if CONFIG_HTTP_PROTOCOL > @@ -318,7 +323,8 @@ static int flush_dynbuf(OutputStream *os, int > *range_length) > // write out to file > *range_length = avio_close_dyn_buf(os->ctx->pb, &buffer); > os->ctx->pb = NULL; > - avio_write(os->out, buffer + os->written_len, *range_length - > os->written_len); > + if (os->out) > + avio_write(os->out, buffer + os->written_len, *range_length - > os->written_len); > os->written_len = 0; > av_free(buffer); > > @@ -1496,9 +1502,9 @@ static int dash_write_packet(AVFormatContext *s, > AVPacket *pkt) > use_rename ? "%s.tmp" : "%s", os->full_path); > set_http_options(&opts, c); > ret = dashenc_io_open(s, &os->out, os->temp_path, &opts); > + av_dict_free(&opts); > if (ret < 0) > return ret; > - av_dict_free(&opts); > } > > //write out the data immediately in streaming mode
_______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-devel