Windows: only add a no-op pthread_sigmask() when needed
authorJohannes Schindelin <johannes.schindelin@gmx.de>
Wed, 11 May 2016 15:10:30 +0000 (17:10 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 11 May 2016 21:02:10 +0000 (14:02 -0700)
In f924b52 (Windows: add pthread_sigmask() that does nothing,
2016-05-01), we introduced a no-op for Windows. However, this breaks
building Git in Git for Windows' SDK because pthread_sigmask() is
already a no-op there, #define'd in the pthread_signal.h header in
/mingw64/x86_64-w64-mingw32/include/.

Let's wrap the definition of pthread_sigmask() in a guard that skips
it when compiling with MinGW-w64' headers.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
compat/win32/pthread.h
index e74157cd4d04d304b96fe88a70804b240f798b1c..7eac560d85a2a10f63673e763fa47203af216f4b 100644 (file)
@@ -101,9 +101,11 @@ static inline void *pthread_getspecific(pthread_key_t key)
        return TlsGetValue(key);
 }
 
        return TlsGetValue(key);
 }
 
+#ifndef __MINGW64_VERSION_MAJOR
 static inline int pthread_sigmask(int how, const sigset_t *set, sigset_t *oset)
 {
        return 0;
 }
 static inline int pthread_sigmask(int how, const sigset_t *set, sigset_t *oset)
 {
        return 0;
 }
+#endif
 
 #endif /* PTHREAD_H */
 
 #endif /* PTHREAD_H */