Commit e78a7291 authored by Michael Niedermayer's avatar Michael Niedermayer

avformat/hlsenc: Use ff_rename() only for local files

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent da97e4c6
...@@ -245,8 +245,10 @@ static int hls_window(AVFormatContext *s, int last) ...@@ -245,8 +245,10 @@ static int hls_window(AVFormatContext *s, int last)
char temp_filename[1024]; char temp_filename[1024];
int64_t sequence = FFMAX(hls->start_sequence, hls->sequence - hls->nb_entries); int64_t sequence = FFMAX(hls->start_sequence, hls->sequence - hls->nb_entries);
int version = hls->flags & HLS_SINGLE_FILE ? 4 : 3; int version = hls->flags & HLS_SINGLE_FILE ? 4 : 3;
const char *proto = avio_find_protocol_name(s->filename);
int use_rename = proto && !strcmp(proto, "file");
snprintf(temp_filename, sizeof(temp_filename), "%s.tmp", s->filename); snprintf(temp_filename, sizeof(temp_filename), use_rename ? "%s.tmp" : "%s", s->filename);
if ((ret = avio_open2(&out, temp_filename, AVIO_FLAG_WRITE, if ((ret = avio_open2(&out, temp_filename, AVIO_FLAG_WRITE,
&s->interrupt_callback, NULL)) < 0) &s->interrupt_callback, NULL)) < 0)
goto fail; goto fail;
...@@ -282,7 +284,7 @@ static int hls_window(AVFormatContext *s, int last) ...@@ -282,7 +284,7 @@ static int hls_window(AVFormatContext *s, int last)
fail: fail:
avio_closep(&out); avio_closep(&out);
if (ret >= 0) if (ret >= 0 && use_rename)
ff_rename(temp_filename, s->filename, s); ff_rename(temp_filename, s->filename, s);
return ret; return ret;
} }
......
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