aboutsummaryrefslogtreecommitdiff
path: root/src/util.cpp
diff options
context:
space:
mode:
authorWladimir J. van der Laan <[email protected]>2015-03-24 08:33:41 +0100
committerWladimir J. van der Laan <[email protected]>2015-03-24 08:33:50 +0100
commit28cc24f961628dce6cd21970f0c1929dde80b18a (patch)
tree41463cd4dfba0426c4fe561b8f0baa7a968bc3c9 /src/util.cpp
parentMerge #5758: refactor: move BDB (bitdb / db.h) interaction from init.cpp to w... (diff)
parentInitialization: set Boost path locale in main thread (diff)
downloaddiscoin-28cc24f961628dce6cd21970f0c1929dde80b18a.tar.xz
discoin-28cc24f961628dce6cd21970f0c1929dde80b18a.zip
Merge pull request #5877
317e66c Initialization: set Boost path locale in main thread (dexX7)
Diffstat (limited to 'src/util.cpp')
-rw-r--r--src/util.cpp18
1 files changed, 9 insertions, 9 deletions
diff --git a/src/util.cpp b/src/util.cpp
index 792f00b61..4192e44ae 100644
--- a/src/util.cpp
+++ b/src/util.cpp
@@ -723,18 +723,18 @@ void RenameThread(const char* name)
void SetupEnvironment()
{
-#ifndef WIN32
- try
- {
-#if BOOST_FILESYSTEM_VERSION == 3
- boost::filesystem::path::codecvt(); // Raises runtime error if current locale is invalid
-#else // boost filesystem v2
- std::locale(); // Raises runtime error if current locale is invalid
-#endif
+ // On most POSIX systems (e.g. Linux, but not BSD) the environment's locale
+ // may be invalid, in which case the "C" locale is used as fallback.
+#if !defined(WIN32) && !defined(MAC_OSX) && !defined(__FreeBSD__) && !defined(__OpenBSD__)
+ try {
+ std::locale(""); // Raises a runtime error if current locale is invalid
} catch (const std::runtime_error&) {
- setenv("LC_ALL", "C", 1); // Force C locale
+ std::locale::global(std::locale("C"));
}
#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)