diff options
| author | Remko Tronçon <git@el-tramo.be> | 2013-05-15 19:44:37 (GMT) | 
|---|---|---|
| committer | Remko Tronçon <git@el-tramo.be> | 2013-05-17 19:00:55 (GMT) | 
| commit | de39ce6ec44647cee92853e2928cf5475af992e6 (patch) | |
| tree | 1f86dd075900aeeb9b91cdd120d71052458ca6ff /Swiften/Base/Paths.cpp | |
| parent | 927d62cc54c8a5087dba6b61afa9ad30dc528a23 (diff) | |
| download | swift-de39ce6ec44647cee92853e2928cf5475af992e6.zip swift-de39ce6ec44647cee92853e2928cf5475af992e6.tar.bz2 | |
Fixed unicode path handling.
- Use boost::filesystem::path consistently for referring to files.
- Use boost::filesystem streams for I/O, such that paths are always handled
  correctly.
- Use stringToPath and pathToString for conversion between strings and
  boost::filesystem::path, to ensure we have consistent unicode handling
  across platforms and environments. The default constructor and string
  conversion uses platform-dependent encoding, depending on the global
  locale set in the application, which causes problems. So, unless you are
  in platform dependent code, the default constructor and string() function
  should not be used. When constructing paths from other paths (e.g. using
  operator/), also use stringToPath (instead of string arguments) if the path
  can contain unicode characters.
Change-Id: If286bd9e71c8414afc0b24ba67e26ab7608ef6ea
Diffstat (limited to 'Swiften/Base/Paths.cpp')
| -rw-r--r-- | Swiften/Base/Paths.cpp | 7 | 
1 files changed, 4 insertions, 3 deletions
| diff --git a/Swiften/Base/Paths.cpp b/Swiften/Base/Paths.cpp index d434cc1..8ad1159 100644 --- a/Swiften/Base/Paths.cpp +++ b/Swiften/Base/Paths.cpp @@ -36,10 +36,11 @@ boost::filesystem::path Paths::getExecutablePath() {  		return boost::filesystem::path(std::string(reinterpret_cast<const char*>(vecptr(path)), path.size()).c_str()).parent_path();  	}  #elif defined(SWIFTEN_PLATFORM_WINDOWS) -	ByteArray data; +	std::vector<wchar_t> data;  	data.resize(2048); -	GetModuleFileName(NULL, reinterpret_cast<char*>(vecptr(data)), data.size()); -	return boost::filesystem::path(std::string(reinterpret_cast<const char*>(vecptr(data)), data.size()).c_str()).parent_path(); +	GetModuleFileNameW(NULL, vecptr(data), data.size()); +	return boost::filesystem::path( +			std::wstring(vecptr(data), data.size())).parent_path();  #endif  	return boost::filesystem::path();  } | 
 Swift
 Swift