summaryrefslogtreecommitdiffstats
path: root/libcxx/test/std/strings/basic.string/string.cons
diff options
context:
space:
mode:
authorMarshall Clow <mclow.lists@gmail.com>2018-02-08 16:25:57 +0000
committerMarshall Clow <mclow.lists@gmail.com>2018-02-08 16:25:57 +0000
commit2a81d30471a8a39accf969d6277aeb1d5f37032a (patch)
tree2cf19f39255f0d68624ecff75452a04cec9d9395 /libcxx/test/std/strings/basic.string/string.cons
parent09051f2925ae059ac724ebd2b6de01aa239f26c6 (diff)
downloadbcm5719-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.cpp57
-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.cpp82
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);
+ }
+}
OpenPOWER on IntegriCloud