Index: libcxx/include/filesystem =================================================================== --- libcxx/include/filesystem +++ libcxx/include/filesystem @@ -1197,7 +1197,12 @@ #if defined(_LIBCPP_WIN32API) _LIBCPP_INLINE_VISIBILITY std::wstring wstring() const { return __pn_; } - std::wstring generic_wstring() const { return __pn_; } + std::wstring generic_wstring() const { + std::wstring __s; + __s.resize(__pn_.size()); + std::replace_copy(__pn_.begin(), __pn_.end(), __s.begin(), '\\', '/'); + return __s; + } #if !defined(_LIBCPP_HAS_NO_LOCALIZATION) template , @@ -1234,13 +1239,21 @@ class _Allocator = allocator<_ECharT> > basic_string<_ECharT, _Traits, _Allocator> generic_string(const _Allocator& __a = _Allocator()) const { - return string<_ECharT, _Traits, _Allocator>(__a); + using _Str = basic_string<_ECharT, _Traits, _Allocator>; + _Str __s = string<_ECharT, _Traits, _Allocator>(__a); + std::replace(__s.begin(), __s.end(), + static_cast<_ECharT>('\\'), static_cast<_ECharT>('/')); + return __s; } std::string generic_string() const { return generic_string(); } std::u16string generic_u16string() const { return generic_string(); } std::u32string generic_u32string() const { return generic_string(); } - __u8_string generic_u8string() const { return u8string(); } + __u8_string generic_u8string() const { + __u8_string __s = u8string(); + std::replace(__s.begin(), __s.end(), '\\', '/'); + return __s; + } #endif /* !_LIBCPP_HAS_NO_LOCALIZATION */ #else /* !_WIN32 */ Index: libcxx/test/std/input.output/filesystems/class.path/path.member/path.generic.obs/named_overloads.pass.cpp =================================================================== --- libcxx/test/std/input.output/filesystems/class.path/path.member/path.generic.obs/named_overloads.pass.cpp +++ libcxx/test/std/input.output/filesystems/class.path/path.member/path.generic.obs/named_overloads.pass.cpp @@ -32,17 +32,24 @@ #include "min_allocator.h" #include "filesystem_test_helper.h" -MultiStringType longString = MKSTR("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ/123456789/abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"); +MultiStringType input = MKSTR("c:\\foo\\bar"); +#ifdef _WIN32 +// On windows, the generic_* accessors return a path with forward slashes +MultiStringType ref = MKSTR("c:/foo/bar"); +#else +// On posix, the input string is returned as-is +MultiStringType ref = MKSTR("c:\\foo\\bar"); +#endif int main(int, char**) { using namespace fs; - auto const& MS = longString; - const char* value = longString; + auto const& MS = ref; + const char* value = input; const path p(value); { std::string s = p.generic_string(); - assert(s == value); + assert(s == (const char*)MS); } { #if TEST_STD_VER > 17 && defined(__cpp_char8_t)