diff --git a/thirdparty/etcpak/System.cpp b/thirdparty/etcpak/System.cpp index 1383d0ecd0..041f2676e8 100644 --- a/thirdparty/etcpak/System.cpp +++ b/thirdparty/etcpak/System.cpp @@ -2,7 +2,6 @@ #ifdef _WIN32 # include #else -# include # include #endif @@ -35,7 +34,7 @@ unsigned int System::CPUCores() void System::SetThreadName( std::thread& thread, const char* name ) { -#ifdef _WIN32 +#ifdef _MSC_VER const DWORD MS_VC_EXCEPTION=0x406D1388; # pragma pack( push, 8 ) @@ -62,7 +61,5 @@ void System::SetThreadName( std::thread& thread, const char* name ) __except(EXCEPTION_EXECUTE_HANDLER) { } -#elif !defined(__APPLE__) - pthread_setname_np( thread.native_handle(), name ); #endif } diff --git a/thirdparty/etcpak/TaskDispatch.cpp b/thirdparty/etcpak/TaskDispatch.cpp index 7287da4de2..b1ba17953b 100644 --- a/thirdparty/etcpak/TaskDispatch.cpp +++ b/thirdparty/etcpak/TaskDispatch.cpp @@ -1,5 +1,8 @@ #include #include +#ifndef _MSC_VER +#include +#endif #include "Debug.hpp" #include "System.hpp" @@ -22,15 +25,19 @@ TaskDispatch::TaskDispatch( size_t workers ) { char tmp[16]; sprintf( tmp, "Worker %zu", i ); -#ifdef __APPLE__ +#ifdef _MSC_VER + auto worker = std::thread( [this]{ Worker(); } ); + System::SetThreadName( worker, tmp ); +#else // Using pthread. auto worker = std::thread( [this, tmp]{ +#ifdef __APPLE__ pthread_setname_np( tmp ); +#else // Linux or MinGW. + pthread_setname_np( pthread_self(), tmp ); +#endif Worker(); } ); -#else - auto worker = std::thread( [this]{ Worker(); } ); #endif - System::SetThreadName( worker, tmp ); m_workers.emplace_back( std::move( worker ) ); }