Initialization: set Boost path locale in main thread
The path locale is lazy initialized and to avoid deinitialization errors
in multithreading environments, it is set explicitly by the main thread.
Conflicts:
src/util.cpp
Rebased-From: 317e66c741
Github-Pull: #5877
This commit is contained in:
parent
10c09f98b2
commit
c9e022b7ee
21
src/util.cpp
21
src/util.cpp
|
@ -713,19 +713,18 @@ void RenameThread(const char* name)
|
||||||
|
|
||||||
void SetupEnvironment()
|
void SetupEnvironment()
|
||||||
{
|
{
|
||||||
#ifndef WIN32
|
// On most POSIX systems (e.g. Linux, but not BSD) the environment's locale
|
||||||
try
|
// may be invalid, in which case the "C" locale is used as fallback.
|
||||||
{
|
#if !defined(WIN32) && !defined(MAC_OSX) && !defined(__FreeBSD__) && !defined(__OpenBSD__)
|
||||||
#if BOOST_FILESYSTEM_VERSION == 3
|
try {
|
||||||
boost::filesystem::path::codecvt(); // Raises runtime error if current locale is invalid
|
std::locale(""); // Raises a runtime error if current locale is invalid
|
||||||
#else // boost filesystem v2
|
} catch (const std::runtime_error&) {
|
||||||
std::locale(); // Raises runtime error if current locale is invalid
|
std::locale::global(std::locale("C"));
|
||||||
#endif
|
|
||||||
} catch(std::runtime_error &e)
|
|
||||||
{
|
|
||||||
setenv("LC_ALL", "C", 1); // Force C locale
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
// The path locale is lazy initialized and to avoid deinitialization errors
|
||||||
|
// in multithreading environments, it is set explicitly by the main thread.
|
||||||
|
boost::filesystem::path::imbue(std::locale());
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetThreadPriority(int nPriority)
|
void SetThreadPriority(int nPriority)
|
||||||
|
|
Loading…
Reference in New Issue