diff options
author | Marshall Clow <mclow.lists@gmail.com> | 2018-02-08 16:25:57 +0000 |
---|---|---|
committer | Marshall Clow <mclow.lists@gmail.com> | 2018-02-08 16:25:57 +0000 |
commit | 2a81d30471a8a39accf969d6277aeb1d5f37032a (patch) | |
tree | 2cf19f39255f0d68624ecff75452a04cec9d9395 /libcxx/test/std/strings/basic.string/string.cons | |
parent | 09051f2925ae059ac724ebd2b6de01aa239f26c6 (diff) | |
download | bcm5719-llvm-2a81d30471a8a39accf969d6277aeb1d5f37032a.tar.gz bcm5719-llvm-2a81d30471a8a39accf969d6277aeb1d5f37032a.zip |
Clean up string's deduction guides tests. Mark old versions of clang as unsupported, b/c they don't have deduction guides, even in C++17 mode
llvm-svn: 324619
Diffstat (limited to 'libcxx/test/std/strings/basic.string/string.cons')
-rw-r--r-- | libcxx/test/std/strings/basic.string/string.cons/iter_alloc.pass.cpp | 57 | ||||
-rw-r--r-- | libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.fail.cpp (renamed from libcxx/test/std/strings/basic.string/string.cons/iter_alloc.fail.cpp) | 2 | ||||
-rw-r--r-- | libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.pass.cpp | 82 |
3 files changed, 83 insertions, 58 deletions
diff --git a/libcxx/test/std/strings/basic.string/string.cons/iter_alloc.pass.cpp b/libcxx/test/std/strings/basic.string/string.cons/iter_alloc.pass.cpp index 9314ecb9a05..e7fefacc068 100644 --- a/libcxx/test/std/strings/basic.string/string.cons/iter_alloc.pass.cpp +++ b/libcxx/test/std/strings/basic.string/string.cons/iter_alloc.pass.cpp @@ -13,17 +13,6 @@ // basic_string(InputIterator begin, InputIterator end, // const Allocator& a = Allocator()); -// template<class InputIterator, -// class Allocator = allocator<typename iterator_traits<InputIterator>::value_type>> -// basic_string(InputIterator, InputIterator, Allocator = Allocator()) -// -> basic_string<typename iterator_traits<InputIterator>::value_type, -// char_traits<typename iterator_traits<InputIterator>::value_type>, -// Allocator>; -// -// The deduction guide shall not participate in overload resolution if InputIterator -// is a type that does not qualify as an input iterator, or if Allocator is a type -// that does not qualify as an allocator. - #include <string> #include <iterator> @@ -128,50 +117,4 @@ int main() test(input_iterator<const char*>(s), input_iterator<const char*>(s+50), A()); } #endif - -#if 0 -// Test deduction guides -#if TEST_STD_VER > 14 - { - const char* s = "12345678901234"; - std::basic_string s1{s, s+10, std::allocator<char>{}}; - using S = decltype(s1); // what type did we get? - static_assert(std::is_same_v<S::value_type, char>, ""); - static_assert(std::is_same_v<S::traits_type, std::char_traits<char>>, ""); - static_assert(std::is_same_v<S::allocator_type, std::allocator<char>>, ""); - assert(s1.size() == 10); - assert(s1.compare(0, s1.size(), s, s1.size()) == 0); - } - { - const wchar_t* s = L"12345678901234"; - std::basic_string s1{s, s+10, test_allocator<wchar_t>{}}; - using S = decltype(s1); // what type did we get? - static_assert(std::is_same_v<S::value_type, wchar_t>, ""); - static_assert(std::is_same_v<S::traits_type, std::char_traits<wchar_t>>, ""); - static_assert(std::is_same_v<S::allocator_type, test_allocator<wchar_t>>, ""); - assert(s1.size() == 10); - assert(s1.compare(0, s1.size(), s, s1.size()) == 0); - } - { - const char16_t* s = u"12345678901234"; - std::basic_string s1{s, s+10, min_allocator<char16_t>{}}; - using S = decltype(s1); // what type did we get? - static_assert(std::is_same_v<S::value_type, char16_t>, ""); - static_assert(std::is_same_v<S::traits_type, std::char_traits<char16_t>>, ""); - static_assert(std::is_same_v<S::allocator_type, min_allocator<char16_t>>, ""); - assert(s1.size() == 10); - assert(s1.compare(0, s1.size(), s, s1.size()) == 0); - } - { - const char32_t* s = U"12345678901234"; - std::basic_string s1{s, s+10, explicit_allocator<char32_t>{}}; - using S = decltype(s1); // what type did we get? - static_assert(std::is_same_v<S::value_type, char32_t>, ""); - static_assert(std::is_same_v<S::traits_type, std::char_traits<char32_t>>, ""); - static_assert(std::is_same_v<S::allocator_type, explicit_allocator<char32_t>>, ""); - assert(s1.size() == 10); - assert(s1.compare(0, s1.size(), s, s1.size()) == 0); - } -#endif -#endif } diff --git a/libcxx/test/std/strings/basic.string/string.cons/iter_alloc.fail.cpp b/libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.fail.cpp index 449b75d905f..56a7d4e5b62 100644 --- a/libcxx/test/std/strings/basic.string/string.cons/iter_alloc.fail.cpp +++ b/libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.fail.cpp @@ -9,7 +9,7 @@ // <string> // UNSUPPORTED: c++98, c++03, c++11, c++14 -// XFAIL: c++17 +// UNSUPPORTED: clang-3.3, clang-3.4, clang-3.5, clang-3.6, clang-3.7, clang-3.8, clang-3.9, clang.4-0 // template<class InputIterator, // class Allocator = allocator<typename iterator_traits<InputIterator>::value_type>> diff --git a/libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.pass.cpp b/libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.pass.cpp new file mode 100644 index 00000000000..49b1cff82b8 --- /dev/null +++ b/libcxx/test/std/strings/basic.string/string.cons/iter_alloc_deduction.pass.cpp @@ -0,0 +1,82 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// <string> +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// UNSUPPORTED: clang-3.3, clang-3.4, clang-3.5, clang-3.6, clang-3.7, clang-3.8, clang-3.9, clang.4-0 + +// template<class InputIterator> +// basic_string(InputIterator begin, InputIterator end, +// const Allocator& a = Allocator()); + +// template<class InputIterator, +// class Allocator = allocator<typename iterator_traits<InputIterator>::value_type>> +// basic_string(InputIterator, InputIterator, Allocator = Allocator()) +// -> basic_string<typename iterator_traits<InputIterator>::value_type, +// char_traits<typename iterator_traits<InputIterator>::value_type>, +// Allocator>; +// +// The deduction guide shall not participate in overload resolution if InputIterator +// is a type that does not qualify as an input iterator, or if Allocator is a type +// that does not qualify as an allocator. + + +#include <string> +#include <iterator> +#include <cassert> +#include <cstddef> + +#include "test_macros.h" +#include "test_allocator.h" +#include "../input_iterator.h" +#include "min_allocator.h" + +int main() +{ + { + const char* s = "12345678901234"; + std::basic_string s1{s, s+10, std::allocator<char>{}}; + using S = decltype(s1); // what type did we get? + static_assert(std::is_same_v<S::value_type, char>, ""); + static_assert(std::is_same_v<S::traits_type, std::char_traits<char>>, ""); + static_assert(std::is_same_v<S::allocator_type, std::allocator<char>>, ""); + assert(s1.size() == 10); + assert(s1.compare(0, s1.size(), s, s1.size()) == 0); + } + { + const wchar_t* s = L"12345678901234"; + std::basic_string s1{s, s+10, test_allocator<wchar_t>{}}; + using S = decltype(s1); // what type did we get? + static_assert(std::is_same_v<S::value_type, wchar_t>, ""); + static_assert(std::is_same_v<S::traits_type, std::char_traits<wchar_t>>, ""); + static_assert(std::is_same_v<S::allocator_type, test_allocator<wchar_t>>, ""); + assert(s1.size() == 10); + assert(s1.compare(0, s1.size(), s, s1.size()) == 0); + } + { + const char16_t* s = u"12345678901234"; + std::basic_string s1{s, s+10, min_allocator<char16_t>{}}; + using S = decltype(s1); // what type did we get? + static_assert(std::is_same_v<S::value_type, char16_t>, ""); + static_assert(std::is_same_v<S::traits_type, std::char_traits<char16_t>>, ""); + static_assert(std::is_same_v<S::allocator_type, min_allocator<char16_t>>, ""); + assert(s1.size() == 10); + assert(s1.compare(0, s1.size(), s, s1.size()) == 0); + } + { + const char32_t* s = U"12345678901234"; + std::basic_string s1{s, s+10, explicit_allocator<char32_t>{}}; + using S = decltype(s1); // what type did we get? + static_assert(std::is_same_v<S::value_type, char32_t>, ""); + static_assert(std::is_same_v<S::traits_type, std::char_traits<char32_t>>, ""); + static_assert(std::is_same_v<S::allocator_type, explicit_allocator<char32_t>>, ""); + assert(s1.size() == 10); + assert(s1.compare(0, s1.size(), s, s1.size()) == 0); + } +} |