Blame SOURCES/0007-curl-7.63.0-JO-preserve-local-file.patch

b35f73
From ff74657fb645e7175971128a171ef7d5ece40d77 Mon Sep 17 00:00:00 2001
b35f73
From: Daniel Stenberg <daniel@haxx.se>
b35f73
Date: Mon, 17 Dec 2018 12:51:51 +0100
b35f73
Subject: [PATCH] curl -J: do not append to the destination file
b35f73
b35f73
Reported-by: Kamil Dudka
b35f73
Fixes #3380
b35f73
Closes #3381
b35f73
b35f73
Upstream-commit: 4849267197682e69cfa056c2bd7a44acd123a917
b35f73
Signed-off-by: Kamil Dudka <kdudka@redhat.com>
b35f73
---
b35f73
 src/tool_cb_hdr.c  | 6 +++---
b35f73
 src/tool_cb_wrt.c  | 9 ++++-----
b35f73
 src/tool_cb_wrt.h  | 2 +-
b35f73
 src/tool_operate.c | 2 +-
b35f73
 4 files changed, 9 insertions(+), 10 deletions(-)
b35f73
b35f73
diff --git a/src/tool_cb_hdr.c b/src/tool_cb_hdr.c
b35f73
index 84b0d9c..3844904 100644
b35f73
--- a/src/tool_cb_hdr.c
b35f73
+++ b/src/tool_cb_hdr.c
b35f73
@@ -148,12 +148,12 @@ size_t tool_header_cb(char *ptr, size_t size, size_t nmemb, void *userdata)
b35f73
         outs->filename = filename;
b35f73
         outs->alloc_filename = TRUE;
b35f73
         hdrcbdata->honor_cd_filename = FALSE; /* done now! */
b35f73
-        if(!tool_create_output_file(outs, TRUE))
b35f73
+        if(!tool_create_output_file(outs))
b35f73
           return failure;
b35f73
       }
b35f73
       break;
b35f73
     }
b35f73
-    if(!outs->stream && !tool_create_output_file(outs, FALSE))
b35f73
+    if(!outs->stream && !tool_create_output_file(outs))
b35f73
       return failure;
b35f73
   }
b35f73
 
b35f73
@@ -162,7 +162,7 @@ size_t tool_header_cb(char *ptr, size_t size, size_t nmemb, void *userdata)
b35f73
     /* bold headers only happen for HTTP(S) and RTSP */
b35f73
     char *value = NULL;
b35f73
 
b35f73
-    if(!outs->stream && !tool_create_output_file(outs, FALSE))
b35f73
+    if(!outs->stream && !tool_create_output_file(outs))
b35f73
       return failure;
b35f73
 
b35f73
     if(hdrcbdata->global->isatty && hdrcbdata->global->styled_output)
b35f73
diff --git a/src/tool_cb_wrt.c b/src/tool_cb_wrt.c
b35f73
index 2cb5e1b..195d6e7 100644
b35f73
--- a/src/tool_cb_wrt.c
b35f73
+++ b/src/tool_cb_wrt.c
b35f73
@@ -32,8 +32,7 @@
b35f73
 #include "memdebug.h" /* keep this as LAST include */
b35f73
 
b35f73
 /* create a local file for writing, return TRUE on success */
b35f73
-bool tool_create_output_file(struct OutStruct *outs,
b35f73
-                             bool append)
b35f73
+bool tool_create_output_file(struct OutStruct *outs)
b35f73
 {
b35f73
   struct GlobalConfig *global = outs->config->global;
b35f73
   FILE *file;
b35f73
@@ -43,7 +42,7 @@ bool tool_create_output_file(struct OutStruct *outs,
b35f73
     return FALSE;
b35f73
   }
b35f73
 
b35f73
-  if(outs->is_cd_filename && !append) {
b35f73
+  if(outs->is_cd_filename) {
b35f73
     /* don't overwrite existing files */
b35f73
     file = fopen(outs->filename, "rb");
b35f73
     if(file) {
b35f73
@@ -55,7 +54,7 @@ bool tool_create_output_file(struct OutStruct *outs,
b35f73
   }
b35f73
 
b35f73
   /* open file for writing */
b35f73
-  file = fopen(outs->filename, append?"ab":"wb");
b35f73
+  file = fopen(outs->filename, "wb");
b35f73
   if(!file) {
b35f73
     warnf(global, "Failed to create the file %s: %s\n", outs->filename,
b35f73
           strerror(errno));
b35f73
@@ -142,7 +141,7 @@ size_t tool_write_cb(char *buffer, size_t sz, size_t nmemb, void *userdata)
b35f73
   }
b35f73
 #endif
b35f73
 
b35f73
-  if(!outs->stream && !tool_create_output_file(outs, FALSE))
b35f73
+  if(!outs->stream && !tool_create_output_file(outs))
b35f73
     return failure;
b35f73
 
b35f73
   if(is_tty && (outs->bytes < 2000) && !config->terminal_binary_ok) {
b35f73
diff --git a/src/tool_cb_wrt.h b/src/tool_cb_wrt.h
b35f73
index 51e002b..188d3ea 100644
b35f73
--- a/src/tool_cb_wrt.h
b35f73
+++ b/src/tool_cb_wrt.h
b35f73
@@ -30,7 +30,7 @@
b35f73
 size_t tool_write_cb(char *buffer, size_t sz, size_t nmemb, void *userdata);
b35f73
 
b35f73
 /* create a local file for writing, return TRUE on success */
b35f73
-bool tool_create_output_file(struct OutStruct *outs, bool append);
b35f73
+bool tool_create_output_file(struct OutStruct *outs);
b35f73
 
b35f73
 #endif /* HEADER_CURL_TOOL_CB_WRT_H */
b35f73
 
b35f73
diff --git a/src/tool_operate.c b/src/tool_operate.c
b35f73
index e53a9d8..429e9cf 100644
b35f73
--- a/src/tool_operate.c
b35f73
+++ b/src/tool_operate.c
b35f73
@@ -1581,7 +1581,7 @@ static CURLcode operate_do(struct GlobalConfig *global,
b35f73
             /* do not create (or even overwrite) the file in case we get no
b35f73
                data because of unmet condition */
b35f73
             curl_easy_getinfo(curl, CURLINFO_CONDITION_UNMET, &cond_unmet);
b35f73
-            if(!cond_unmet && !tool_create_output_file(&outs, FALSE))
b35f73
+            if(!cond_unmet && !tool_create_output_file(&outs))
b35f73
               result = CURLE_WRITE_ERROR;
b35f73
           }
b35f73
 
b35f73
-- 
b35f73
2.17.2
b35f73