Changes for MinGW compiler

This commit is contained in:
Constantine Tarasenkov 2014-06-11 02:38:57 +04:00
parent e2cbee77b8
commit 6aace693db
5 changed files with 15 additions and 4 deletions

View File

@ -42,6 +42,9 @@
#ifdef _WIN32
# define WIN32_LEAN_AND_MEAN
# ifdef __MINGW32__
# include <cstring>
# endif
# include <windows.h>
# undef ERROR
#endif
@ -228,7 +231,11 @@ int fmt::internal::StrError(
result = ERANGE;
buffer = message;
#elif _WIN32
# ifdef __MINGW32__
strerror(result);
# else
result = strerror_s(buffer, buffer_size, error_code);
# endif
// If the buffer is full then the message is probably truncated.
if (result == 0 && std::strlen(buffer) == buffer_size - 1)
result = ERANGE;

View File

@ -41,6 +41,10 @@
# define S_IRUSR _S_IREAD
# define S_IWUSR _S_IWRITE
# ifdef __MINGW32__
# define _SH_DENYNO 0x40
# endif
#endif // _WIN32
namespace {

View File

@ -35,7 +35,7 @@
#include <memory>
#include <sstream>
#ifdef _WIN32
#if defined(_WIN32) && !defined(__MINGW32__)
// Fix MSVC warning about "unsafe" fopen.
FILE *FOpen(const char *filename, const char *mode) {
FILE *f = 0;

View File

@ -32,13 +32,13 @@
#include <stdexcept>
#include <gtest/gtest-spi.h>
#ifdef _WIN32
#if defined(_WIN32) && !defined(__MINGW32__)
# include <crtdbg.h> // for _CrtSetReportMode
#endif // _WIN32
namespace {
#ifdef _WIN32
#if defined(_WIN32) && !defined(__MINGW32__)
// Suppresses Windows assertions on invalid file descriptors, making
// POSIX functions return proper error codes instead of crashing on Windows.

View File

@ -43,7 +43,7 @@ using fmt::StringRef;
namespace {
std::string GetSystemErrorMessage(int error_code) {
#ifndef _WIN32
#if defined(__MINGW32__) || !defined(_WIN32)
return strerror(error_code);
#else
enum { BUFFER_SIZE = 200 };