fs/Charset.cxx: replace \ with / when converting path to UTF-8 on Windows

This commit is contained in:
Denis Krjuchkov 2013-12-05 12:51:01 +06:00
parent dc554ca61f
commit 62dc8e4131

View File

@ -23,9 +23,12 @@
#include "Limits.hxx" #include "Limits.hxx"
#include "system/FatalError.hxx" #include "system/FatalError.hxx"
#include "Log.hxx" #include "Log.hxx"
#include "Traits.hxx"
#include <glib.h> #include <glib.h>
#include <algorithm>
#include <assert.h> #include <assert.h>
#include <string.h> #include <string.h>
@ -74,13 +77,29 @@ GetFSCharset()
return fs_charset.empty() ? "utf-8" : fs_charset.c_str(); return fs_charset.empty() ? "utf-8" : fs_charset.c_str();
} }
static inline void FixSeparators(std::string &s)
{
#ifdef WIN32
// For whatever reason GCC can't convert constexpr to value reference.
// This leads to link errors when passing separators directly.
auto from = PathTraitsFS::SEPARATOR;
auto to = PathTraitsUTF8::SEPARATOR;
std::replace(s.begin(), s.end(), from, to);
#else
(void)s;
#endif
}
std::string std::string
PathToUTF8(const char *path_fs) PathToUTF8(const char *path_fs)
{ {
assert(path_fs != nullptr); assert(path_fs != nullptr);
if (fs_charset.empty()) if (fs_charset.empty()) {
return std::string(path_fs); auto result = std::string(path_fs);
FixSeparators(result);
return result;
}
GIConv conv = g_iconv_open("utf-8", fs_charset.c_str()); GIConv conv = g_iconv_open("utf-8", fs_charset.c_str());
if (conv == reinterpret_cast<GIConv>(-1)) if (conv == reinterpret_cast<GIConv>(-1))
@ -101,7 +120,9 @@ PathToUTF8(const char *path_fs)
if (ret == static_cast<size_t>(-1) || in_left > 0) if (ret == static_cast<size_t>(-1) || in_left > 0)
return std::string(); return std::string();
return std::string(path_utf8, sizeof(path_utf8) - out_left); auto result_path = std::string(path_utf8, sizeof(path_utf8) - out_left);
FixSeparators(result_path);
return result_path;
} }
char * char *