From: Jay Satiro Date: Wed, 29 Jul 2020 07:21:57 +0000 (-0400) Subject: tool_cb_wrt: fix outfile mode flags for Windows X-Git-Tag: curl-7_72_0~68 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=5f79891658708ccdc2ca6b616595a51840c27b07;p=thirdparty%2Fcurl.git tool_cb_wrt: fix outfile mode flags for Windows - Use S_IREAD and S_IWRITE mode permission flags to create the file on Windows instead of S_IRUSR, S_IWUSR, etc. Windows only accepts a combination of S_IREAD and S_IWRITE. It does not acknowledge other combinations, for which it may generate an assertion. This is a follow-up to 81b4e99 from yesterday, which improved the existing file check with -J. Ref: https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/open-wopen#remarks Ref: https://github.com/curl/curl/pull/5731 Closes https://github.com/curl/curl/pull/5742 --- diff --git a/src/tool_cb_wrt.c b/src/tool_cb_wrt.c index e0742630ba..64b62fefd4 100644 --- a/src/tool_cb_wrt.c +++ b/src/tool_cb_wrt.c @@ -26,6 +26,8 @@ #include #endif +#include + #define ENABLE_CURLX_PRINTF /* use our own printf() functions */ #include "curlx.h" @@ -57,9 +59,10 @@ bool tool_create_output_file(struct OutStruct *outs, #define O_BINARY 0 #endif int fd = open(outs->filename, O_CREAT | O_WRONLY | O_EXCL | O_BINARY, - S_IRUSR | S_IWUSR -#ifdef S_IRGRP - | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH +#ifdef WIN32 + S_IREAD | S_IWRITE +#else + S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH #endif ); if(fd != -1) {