15a83710eSEric Fiselier //===----------------------------------------------------------------------===// 25a83710eSEric Fiselier // 35a83710eSEric Fiselier // The LLVM Compiler Infrastructure 45a83710eSEric Fiselier // 55a83710eSEric Fiselier // This file is dual licensed under the MIT and the University of Illinois Open 65a83710eSEric Fiselier // Source Licenses. See LICENSE.TXT for details. 75a83710eSEric Fiselier // 85a83710eSEric Fiselier //===----------------------------------------------------------------------===// 95a83710eSEric Fiselier 105a83710eSEric Fiselier // <string> 115a83710eSEric Fiselier 125a83710eSEric Fiselier // template<class InputIterator> 135a83710eSEric Fiselier // basic_string(InputIterator begin, InputIterator end, 145a83710eSEric Fiselier // const Allocator& a = Allocator()); 155a83710eSEric Fiselier 16*6d9f750dSMarshall Clow // template<class InputIterator, 17*6d9f750dSMarshall Clow // class Allocator = allocator<typename iterator_traits<InputIterator>::value_type>> 18*6d9f750dSMarshall Clow // basic_string(InputIterator, InputIterator, Allocator = Allocator()) 19*6d9f750dSMarshall Clow // -> basic_string<typename iterator_traits<InputIterator>::value_type, 20*6d9f750dSMarshall Clow // char_traits<typename iterator_traits<InputIterator>::value_type>, 21*6d9f750dSMarshall Clow // Allocator>; 22*6d9f750dSMarshall Clow // 23*6d9f750dSMarshall Clow // The deduction guide shall not participate in overload resolution if InputIterator 24*6d9f750dSMarshall Clow // is a type that does not qualify as an input iterator, or if Allocator is a type 25*6d9f750dSMarshall Clow // that does not qualify as an allocator. 26*6d9f750dSMarshall Clow 27*6d9f750dSMarshall Clow 285a83710eSEric Fiselier #include <string> 295a83710eSEric Fiselier #include <iterator> 305a83710eSEric Fiselier #include <cassert> 31fbfb2ab6SStephan T. Lavavej #include <cstddef> 325a83710eSEric Fiselier 331f4231f8SEric Fiselier #include "test_macros.h" 345a83710eSEric Fiselier #include "test_allocator.h" 355a83710eSEric Fiselier #include "../input_iterator.h" 365a83710eSEric Fiselier #include "min_allocator.h" 375a83710eSEric Fiselier 385a83710eSEric Fiselier template <class It> 395a83710eSEric Fiselier void 405a83710eSEric Fiselier test(It first, It last) 415a83710eSEric Fiselier { 425a83710eSEric Fiselier typedef typename std::iterator_traits<It>::value_type charT; 435a83710eSEric Fiselier typedef std::basic_string<charT, std::char_traits<charT>, test_allocator<charT> > S; 445a83710eSEric Fiselier typedef typename S::allocator_type A; 455a83710eSEric Fiselier S s2(first, last); 461f4231f8SEric Fiselier LIBCPP_ASSERT(s2.__invariants()); 47fbfb2ab6SStephan T. Lavavej assert(s2.size() == static_cast<std::size_t>(std::distance(first, last))); 485a83710eSEric Fiselier unsigned i = 0; 495a83710eSEric Fiselier for (It it = first; it != last; ++it, ++i) 505a83710eSEric Fiselier assert(s2[i] == *it); 515a83710eSEric Fiselier assert(s2.get_allocator() == A()); 525a83710eSEric Fiselier assert(s2.capacity() >= s2.size()); 535a83710eSEric Fiselier } 545a83710eSEric Fiselier 555a83710eSEric Fiselier template <class It, class A> 565a83710eSEric Fiselier void 575a83710eSEric Fiselier test(It first, It last, const A& a) 585a83710eSEric Fiselier { 595a83710eSEric Fiselier typedef typename std::iterator_traits<It>::value_type charT; 605a83710eSEric Fiselier typedef std::basic_string<charT, std::char_traits<charT>, A> S; 615a83710eSEric Fiselier S s2(first, last, a); 621f4231f8SEric Fiselier LIBCPP_ASSERT(s2.__invariants()); 63fbfb2ab6SStephan T. Lavavej assert(s2.size() == static_cast<std::size_t>(std::distance(first, last))); 645a83710eSEric Fiselier unsigned i = 0; 655a83710eSEric Fiselier for (It it = first; it != last; ++it, ++i) 665a83710eSEric Fiselier assert(s2[i] == *it); 675a83710eSEric Fiselier assert(s2.get_allocator() == a); 685a83710eSEric Fiselier assert(s2.capacity() >= s2.size()); 695a83710eSEric Fiselier } 705a83710eSEric Fiselier 715a83710eSEric Fiselier int main() 725a83710eSEric Fiselier { 735a83710eSEric Fiselier { 745a83710eSEric Fiselier typedef test_allocator<char> A; 755a83710eSEric Fiselier const char* s = "12345678901234567890123456789012345678901234567890"; 765a83710eSEric Fiselier 775a83710eSEric Fiselier test(s, s); 785a83710eSEric Fiselier test(s, s, A(2)); 795a83710eSEric Fiselier 805a83710eSEric Fiselier test(s, s+1); 815a83710eSEric Fiselier test(s, s+1, A(2)); 825a83710eSEric Fiselier 835a83710eSEric Fiselier test(s, s+10); 845a83710eSEric Fiselier test(s, s+10, A(2)); 855a83710eSEric Fiselier 865a83710eSEric Fiselier test(s, s+50); 875a83710eSEric Fiselier test(s, s+50, A(2)); 885a83710eSEric Fiselier 895a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s)); 905a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s), A(2)); 915a83710eSEric Fiselier 925a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1)); 935a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1), A(2)); 945a83710eSEric Fiselier 955a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10)); 965a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10), A(2)); 975a83710eSEric Fiselier 985a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50)); 995a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50), A(2)); 1005a83710eSEric Fiselier } 1011f4231f8SEric Fiselier #if TEST_STD_VER >= 11 1025a83710eSEric Fiselier { 1035a83710eSEric Fiselier typedef min_allocator<char> A; 1045a83710eSEric Fiselier const char* s = "12345678901234567890123456789012345678901234567890"; 1055a83710eSEric Fiselier 1065a83710eSEric Fiselier test(s, s); 1075a83710eSEric Fiselier test(s, s, A()); 1085a83710eSEric Fiselier 1095a83710eSEric Fiselier test(s, s+1); 1105a83710eSEric Fiselier test(s, s+1, A()); 1115a83710eSEric Fiselier 1125a83710eSEric Fiselier test(s, s+10); 1135a83710eSEric Fiselier test(s, s+10, A()); 1145a83710eSEric Fiselier 1155a83710eSEric Fiselier test(s, s+50); 1165a83710eSEric Fiselier test(s, s+50, A()); 1175a83710eSEric Fiselier 1185a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s)); 1195a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s), A()); 1205a83710eSEric Fiselier 1215a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1)); 1225a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1), A()); 1235a83710eSEric Fiselier 1245a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10)); 1255a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10), A()); 1265a83710eSEric Fiselier 1275a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50)); 1285a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50), A()); 1295a83710eSEric Fiselier } 1305a83710eSEric Fiselier #endif 131*6d9f750dSMarshall Clow 132*6d9f750dSMarshall Clow // Test deduction guides 133*6d9f750dSMarshall Clow #if TEST_STD_VER > 14 134*6d9f750dSMarshall Clow { 135*6d9f750dSMarshall Clow const char* s = "12345678901234"; 136*6d9f750dSMarshall Clow std::basic_string s1{s, s+10, std::allocator<char>{}}; 137*6d9f750dSMarshall Clow using S = decltype(s1); // what type did we get? 138*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::value_type, char>, ""); 139*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::traits_type, std::char_traits<char>>, ""); 140*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::allocator_type, std::allocator<char>>, ""); 141*6d9f750dSMarshall Clow assert(s1.size() == 10); 142*6d9f750dSMarshall Clow assert(s1.compare(0, s1.size(), s, s1.size()) == 0); 143*6d9f750dSMarshall Clow } 144*6d9f750dSMarshall Clow { 145*6d9f750dSMarshall Clow const wchar_t* s = L"12345678901234"; 146*6d9f750dSMarshall Clow std::basic_string s1{s, s+10, test_allocator<wchar_t>{}}; 147*6d9f750dSMarshall Clow using S = decltype(s1); // what type did we get? 148*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::value_type, wchar_t>, ""); 149*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::traits_type, std::char_traits<wchar_t>>, ""); 150*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::allocator_type, test_allocator<wchar_t>>, ""); 151*6d9f750dSMarshall Clow assert(s1.size() == 10); 152*6d9f750dSMarshall Clow assert(s1.compare(0, s1.size(), s, s1.size()) == 0); 153*6d9f750dSMarshall Clow } 154*6d9f750dSMarshall Clow { 155*6d9f750dSMarshall Clow const char16_t* s = u"12345678901234"; 156*6d9f750dSMarshall Clow std::basic_string s1{s, s+10, min_allocator<char16_t>{}}; 157*6d9f750dSMarshall Clow using S = decltype(s1); // what type did we get? 158*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::value_type, char16_t>, ""); 159*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::traits_type, std::char_traits<char16_t>>, ""); 160*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::allocator_type, min_allocator<char16_t>>, ""); 161*6d9f750dSMarshall Clow assert(s1.size() == 10); 162*6d9f750dSMarshall Clow assert(s1.compare(0, s1.size(), s, s1.size()) == 0); 163*6d9f750dSMarshall Clow } 164*6d9f750dSMarshall Clow { 165*6d9f750dSMarshall Clow const char32_t* s = U"12345678901234"; 166*6d9f750dSMarshall Clow std::basic_string s1{s, s+10, explicit_allocator<char32_t>{}}; 167*6d9f750dSMarshall Clow using S = decltype(s1); // what type did we get? 168*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::value_type, char32_t>, ""); 169*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::traits_type, std::char_traits<char32_t>>, ""); 170*6d9f750dSMarshall Clow static_assert(std::is_same_v<S::allocator_type, explicit_allocator<char32_t>>, ""); 171*6d9f750dSMarshall Clow assert(s1.size() == 10); 172*6d9f750dSMarshall Clow assert(s1.compare(0, s1.size(), s, s1.size()) == 0); 173*6d9f750dSMarshall Clow } 174*6d9f750dSMarshall Clow #endif 1755a83710eSEric Fiselier } 176