| //===----------------------------------------------------------------------===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is dual licensed under the MIT and the University of Illinois Open |
| // Source Licenses. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| // <functional> |
| |
| // template <class T> |
| // struct hash |
| // : public unary_function<T, size_t> |
| // { |
| // size_t operator()(T val) const; |
| // }; |
| |
| // Not very portable |
| |
| #include <string_view> |
| #include <string> |
| #include <cassert> |
| #include <type_traits> |
| |
| using std::string_view; |
| |
| template <class SV> |
| void |
| test() |
| { |
| typedef std::hash<SV> H; |
| static_assert((std::is_same<typename H::argument_type, SV>::value), "" ); |
| static_assert((std::is_same<typename H::result_type, std::size_t>::value), "" ); |
| |
| typedef typename SV::value_type char_type; |
| typedef std::basic_string<char_type> String; |
| typedef std::hash<String> SH; |
| |
| char_type g1 [ 10 ]; |
| char_type g2 [ 10 ]; |
| for ( int i = 0; i < 10; ++i ) |
| g1[i] = g2[9-i] = static_cast<char_type>('0' + i); |
| H h; |
| SH sh; |
| SV s1(g1, 10); |
| String ss1(s1); |
| SV s2(g2, 10); |
| String ss2(s2); |
| assert(h(s1) == h(s1)); |
| assert(h(s1) != h(s2)); |
| assert(sh(ss1) == h(s1)); |
| assert(sh(ss2) == h(s2)); |
| } |
| |
| int main() |
| { |
| test<std::string_view>(); |
| #ifndef _LIBCPP_HAS_NO_UNICODE_CHARS |
| test<std::u16string_view>(); |
| test<std::u32string_view>(); |
| #endif // _LIBCPP_HAS_NO_UNICODE_CHARS |
| test<std::wstring_view>(); |
| } |