Skip to content

Commit

Permalink
Test for workaround of static constexpr issue
Browse files Browse the repository at this point in the history
  • Loading branch information
gulrak committed Aug 24, 2019
1 parent 135015f commit cbe0c61
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 11 deletions.
33 changes: 22 additions & 11 deletions include/ghc/filesystem.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -192,24 +192,35 @@ class GHC_FS_API_CLASS not_implemented_exception : public std::logic_error
}
};

// 30.10.8 class path
class GHC_FS_API_CLASS path
template<typename char_type>
class path_helper_base
{
public:
using value_type = char_type;
#ifdef GHC_OS_WINDOWS
#ifdef GHC_WIN_WSTRING_STRING_TYPE
#define GHC_USE_WCHAR_T
using value_type = std::wstring::value_type;
#else
using value_type = std::string::value_type;
#endif
using string_type = std::basic_string<value_type>;
static constexpr value_type preferred_separator = '\\';
#else
using value_type = std::string::value_type;
using string_type = std::basic_string<value_type>;
static constexpr value_type preferred_separator = '/';
#endif
};

template <typename char_type>
constexpr char_type path_helper_base<char_type>::preferred_separator;

// 30.10.8 class path
class GHC_FS_API_CLASS path
#if defined(GHC_OS_WINDOWS) && defined(GHC_WIN_WSTRING_STRING_TYPE)
#define GHC_USE_WCHAR_T
: private path_helper_base<std::wstring::value_type>
#else
: private path_helper_base<std::string::value_type>
#endif
{
public:
using path_helper_base::value_type;
using string_type = std::basic_string<value_type>;
using path_helper_base::preferred_separator;

// 30.10.10.1 enumeration format
/// The path format in wich the constructor argument is given.
enum format {
Expand Down
9 changes: 9 additions & 0 deletions test/filesystem_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -345,6 +345,15 @@ TEST_CASE("fs::detail::toUtf8", "[filesystem][fs.detail.utf8]")
}
#endif

TEST_CASE("30.10.8.1 path::preferred_separator", "[filesystem][path][fs.path.generic]")
{
#ifdef GHC_OS_WINDOWS
CHECK(fs::path::preferred_separator == '\\');
#else
CHECK(fs::path::preferred_separator == '/');
#endif
}

#ifndef GHC_OS_WINDOWS
TEST_CASE("30.10.8.1 path(\"//host\").has_root_name()", "[filesystem][path][fs.path.generic]")
{
Expand Down

0 comments on commit cbe0c61

Please sign in to comment.