20
20
#include "gettext.h"
21
21
#define SECURITY_WIN32
22
22
#include <sspi.h>
23
+ #include "../repository.h"
23
24
24
25
#define HCAST (type , handle ) ((type)(intptr_t)handle)
25
26
@@ -549,6 +550,7 @@ static int is_local_named_pipe_path(const char *filename)
549
550
550
551
int mingw_open (const char * filename , int oflags , ...)
551
552
{
553
+ static int append_atomically = -1 ;
552
554
typedef int (* open_fn_t )(wchar_t const * wfilename , int oflags , ...);
553
555
va_list args ;
554
556
unsigned mode ;
@@ -565,7 +567,16 @@ int mingw_open (const char *filename, int oflags, ...)
565
567
return -1 ;
566
568
}
567
569
568
- if ((oflags & O_APPEND ) && !is_local_named_pipe_path (filename ))
570
+ /*
571
+ * Only set append_atomically to default value(1) when repo is initialized
572
+ * and fail to get config value
573
+ */
574
+ if (append_atomically < 0 && the_repository && the_repository -> commondir &&
575
+ git_config_get_bool ("windows.appendatomically" , & append_atomically ))
576
+ append_atomically = 1 ;
577
+
578
+ if (append_atomically && (oflags & O_APPEND ) &&
579
+ !is_local_named_pipe_path (filename ))
569
580
open_fn = mingw_open_append ;
570
581
else
571
582
open_fn = _wopen ;
@@ -714,9 +725,28 @@ ssize_t mingw_write(int fd, const void *buf, size_t len)
714
725
715
726
/* check if fd is a pipe */
716
727
HANDLE h = (HANDLE ) _get_osfhandle (fd );
717
- if (GetFileType (h ) != FILE_TYPE_PIPE )
728
+ if (GetFileType (h ) != FILE_TYPE_PIPE ) {
729
+ if (orig == EINVAL ) {
730
+ wchar_t path [MAX_PATH ];
731
+ DWORD ret = GetFinalPathNameByHandleW (h , path ,
732
+ ARRAY_SIZE (path ), 0 );
733
+ UINT drive_type = ret > 0 && ret < ARRAY_SIZE (path ) ?
734
+ GetDriveTypeW (path ) : DRIVE_UNKNOWN ;
735
+
736
+ /*
737
+ * The default atomic append causes such an error on
738
+ * network file systems, in such a case, it should be
739
+ * turned off via config.
740
+ *
741
+ * `drive_type` of UNC path: DRIVE_NO_ROOT_DIR
742
+ */
743
+ if (DRIVE_NO_ROOT_DIR == drive_type || DRIVE_REMOTE == drive_type )
744
+ warning ("invalid write operation detected; you may try:\n"
745
+ "\n\tgit config windows.appendAtomically false" );
746
+ }
747
+
718
748
errno = orig ;
719
- else if (orig == EINVAL )
749
+ } else if (orig == EINVAL )
720
750
errno = EPIPE ;
721
751
else {
722
752
DWORD buf_size ;
0 commit comments