diff options
| author | Wladimir J. van der Laan <[email protected]> | 2015-04-01 12:21:05 +0200 |
|---|---|---|
| committer | Wladimir J. van der Laan <[email protected]> | 2015-04-01 12:22:29 +0200 |
| commit | 41113e33ad62333d99fd8cc6bf717c0794681d86 (patch) | |
| tree | 7d1103a2abce71c7dd249e51f3d03bc73f3281de /src/util.cpp | |
| parent | Merge pull request #5833 (diff) | |
| parent | Initialization: setup environment before starting QT tests (diff) | |
| download | discoin-41113e33ad62333d99fd8cc6bf717c0794681d86.tar.xz discoin-41113e33ad62333d99fd8cc6bf717c0794681d86.zip | |
Merge pull request #5950
3a3ecc0 Initialization: setup environment before starting QT tests (dexX7)
fc3979a Initialization: setup environment before starting tests (dexX7)
ba0fa0d Initialization: set fallback locale as environment variable (dexX7)
Diffstat (limited to 'src/util.cpp')
| -rw-r--r-- | src/util.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/util.cpp b/src/util.cpp index 4192e44ae..5fef3a40d 100644 --- a/src/util.cpp +++ b/src/util.cpp @@ -723,18 +723,19 @@ void RenameThread(const char* name) void SetupEnvironment() { + std::locale loc("C"); // 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 + loc = std::locale(""); // Raises a runtime error if current locale is invalid } catch (const std::runtime_error&) { - std::locale::global(std::locale("C")); + setenv("LC_ALL", "C", 1); } #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()); + boost::filesystem::path::imbue(loc); } void SetThreadPriority(int nPriority) |