Merge commit '19fc283dbb53a5f7d6658fd4edcfa59b99369b58' into release/2.4
* commit '19fc283dbb53a5f7d6658fd4edcfa59b99369b58': lavf: replace rename() with ff_rename() Conflicts: libavformat/hdsenc.c libavformat/internal.h See: 95d2fc6a76f3e0a98329f1ca70f98e7c085f0abf Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
d3316c3f85
@ -204,11 +204,7 @@ static int write_manifest(AVFormatContext *s, int final)
|
||||
avio_printf(out, "</manifest>\n");
|
||||
avio_flush(out);
|
||||
avio_close(out);
|
||||
if (rename(temp_filename, filename) == -1) {
|
||||
av_log(s, AV_LOG_ERROR, "failed to rename file %s to %s\n", temp_filename, filename);
|
||||
return AVERROR(errno);
|
||||
}
|
||||
return 0;
|
||||
return ff_rename(temp_filename, filename);
|
||||
}
|
||||
|
||||
static void update_size(AVIOContext *out, int64_t pos)
|
||||
@ -289,11 +285,7 @@ static int write_abst(AVFormatContext *s, OutputStream *os, int final)
|
||||
update_size(out, afrt_pos);
|
||||
update_size(out, 0);
|
||||
avio_close(out);
|
||||
if (rename(temp_filename, filename) == -1) {
|
||||
av_log(s, AV_LOG_ERROR, "failed to rename file %s to %s\n", temp_filename, filename);
|
||||
return AVERROR(errno);
|
||||
}
|
||||
return 0;
|
||||
return ff_rename(temp_filename, filename);
|
||||
}
|
||||
|
||||
static int init_file(AVFormatContext *s, OutputStream *os, int64_t start_ts)
|
||||
@ -487,10 +479,9 @@ static int hds_flush(AVFormatContext *s, OutputStream *os, int final,
|
||||
|
||||
snprintf(target_filename, sizeof(target_filename),
|
||||
"%s/stream%dSeg1-Frag%d", s->filename, index, os->fragment_index);
|
||||
if (rename(os->temp_filename, target_filename) == -1) {
|
||||
av_log(s, AV_LOG_ERROR, "failed to rename file %s to %s\n", os->temp_filename, target_filename);
|
||||
return AVERROR(errno);
|
||||
}
|
||||
ret = ff_rename(os->temp_filename, target_filename);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
add_fragment(os, target_filename, os->frag_start_ts, end_ts - os->frag_start_ts);
|
||||
|
||||
if (!final) {
|
||||
|
@ -371,6 +371,20 @@ AVRational ff_choose_timebase(AVFormatContext *s, AVStream *st, int min_precisio
|
||||
*/
|
||||
int ff_generate_avci_extradata(AVStream *st);
|
||||
|
||||
/**
|
||||
* Wrap errno on rename() error.
|
||||
*
|
||||
* @param oldpath source path
|
||||
* @param newpath destination path
|
||||
* @return 0 or AVERROR on failure
|
||||
*/
|
||||
static inline int ff_rename(const char *oldpath, const char *newpath)
|
||||
{
|
||||
if (rename(oldpath, newpath) == -1)
|
||||
return AVERROR(errno);
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Allocate extradata with additional FF_INPUT_BUFFER_PADDING_SIZE at end
|
||||
* which is always set to 0.
|
||||
|
@ -34,6 +34,7 @@
|
||||
|
||||
#include "libavutil/opt.h"
|
||||
#include "libavutil/avstring.h"
|
||||
#include "libavutil/file.h"
|
||||
#include "libavutil/mathematics.h"
|
||||
#include "libavutil/intreadwrite.h"
|
||||
|
||||
@ -282,8 +283,7 @@ static int write_manifest(AVFormatContext *s, int final)
|
||||
avio_printf(out, "</SmoothStreamingMedia>\n");
|
||||
avio_flush(out);
|
||||
avio_close(out);
|
||||
rename(temp_filename, filename);
|
||||
return 0;
|
||||
return ff_rename(temp_filename, filename);
|
||||
}
|
||||
|
||||
static int ism_write_header(AVFormatContext *s)
|
||||
@ -539,8 +539,11 @@ static int ism_flush(AVFormatContext *s, int final)
|
||||
snprintf(header_filename, sizeof(header_filename), "%s/FragmentInfo(%s=%"PRIu64")", os->dirname, os->stream_type_tag, start_ts);
|
||||
snprintf(target_filename, sizeof(target_filename), "%s/Fragments(%s=%"PRIu64")", os->dirname, os->stream_type_tag, start_ts);
|
||||
copy_moof(s, filename, header_filename, moof_size);
|
||||
rename(filename, target_filename);
|
||||
add_fragment(os, target_filename, header_filename, start_ts, duration, start_pos, size);
|
||||
ret = ff_rename(filename, target_filename);
|
||||
if (ret < 0)
|
||||
break;
|
||||
add_fragment(os, target_filename, header_filename, start_ts, duration,
|
||||
start_pos, size);
|
||||
}
|
||||
|
||||
if (c->window_size || (final && c->remove_at_exit)) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user