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 165a83710eSEric Fiselier #include <string> 175a83710eSEric Fiselier #include <iterator> 185a83710eSEric Fiselier #include <cassert> 19*fbfb2ab6SStephan T. Lavavej #include <cstddef> 205a83710eSEric Fiselier 211f4231f8SEric Fiselier #include "test_macros.h" 225a83710eSEric Fiselier #include "test_allocator.h" 235a83710eSEric Fiselier #include "../input_iterator.h" 245a83710eSEric Fiselier #include "min_allocator.h" 255a83710eSEric Fiselier 265a83710eSEric Fiselier template <class It> 275a83710eSEric Fiselier void 285a83710eSEric Fiselier test(It first, It last) 295a83710eSEric Fiselier { 305a83710eSEric Fiselier typedef typename std::iterator_traits<It>::value_type charT; 315a83710eSEric Fiselier typedef std::basic_string<charT, std::char_traits<charT>, test_allocator<charT> > S; 325a83710eSEric Fiselier typedef typename S::traits_type T; 335a83710eSEric Fiselier typedef typename S::allocator_type A; 345a83710eSEric Fiselier S s2(first, last); 351f4231f8SEric Fiselier LIBCPP_ASSERT(s2.__invariants()); 36*fbfb2ab6SStephan T. Lavavej assert(s2.size() == static_cast<std::size_t>(std::distance(first, last))); 375a83710eSEric Fiselier unsigned i = 0; 385a83710eSEric Fiselier for (It it = first; it != last; ++it, ++i) 395a83710eSEric Fiselier assert(s2[i] == *it); 405a83710eSEric Fiselier assert(s2.get_allocator() == A()); 415a83710eSEric Fiselier assert(s2.capacity() >= s2.size()); 425a83710eSEric Fiselier } 435a83710eSEric Fiselier 445a83710eSEric Fiselier template <class It, class A> 455a83710eSEric Fiselier void 465a83710eSEric Fiselier test(It first, It last, const A& a) 475a83710eSEric Fiselier { 485a83710eSEric Fiselier typedef typename std::iterator_traits<It>::value_type charT; 495a83710eSEric Fiselier typedef std::basic_string<charT, std::char_traits<charT>, A> S; 505a83710eSEric Fiselier typedef typename S::traits_type T; 515a83710eSEric Fiselier S s2(first, last, a); 521f4231f8SEric Fiselier LIBCPP_ASSERT(s2.__invariants()); 53*fbfb2ab6SStephan T. Lavavej assert(s2.size() == static_cast<std::size_t>(std::distance(first, last))); 545a83710eSEric Fiselier unsigned i = 0; 555a83710eSEric Fiselier for (It it = first; it != last; ++it, ++i) 565a83710eSEric Fiselier assert(s2[i] == *it); 575a83710eSEric Fiselier assert(s2.get_allocator() == a); 585a83710eSEric Fiselier assert(s2.capacity() >= s2.size()); 595a83710eSEric Fiselier } 605a83710eSEric Fiselier 615a83710eSEric Fiselier int main() 625a83710eSEric Fiselier { 635a83710eSEric Fiselier { 645a83710eSEric Fiselier typedef test_allocator<char> A; 655a83710eSEric Fiselier const char* s = "12345678901234567890123456789012345678901234567890"; 665a83710eSEric Fiselier 675a83710eSEric Fiselier test(s, s); 685a83710eSEric Fiselier test(s, s, A(2)); 695a83710eSEric Fiselier 705a83710eSEric Fiselier test(s, s+1); 715a83710eSEric Fiselier test(s, s+1, A(2)); 725a83710eSEric Fiselier 735a83710eSEric Fiselier test(s, s+10); 745a83710eSEric Fiselier test(s, s+10, A(2)); 755a83710eSEric Fiselier 765a83710eSEric Fiselier test(s, s+50); 775a83710eSEric Fiselier test(s, s+50, A(2)); 785a83710eSEric Fiselier 795a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s)); 805a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s), A(2)); 815a83710eSEric Fiselier 825a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1)); 835a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1), A(2)); 845a83710eSEric Fiselier 855a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10)); 865a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10), A(2)); 875a83710eSEric Fiselier 885a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50)); 895a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50), A(2)); 905a83710eSEric Fiselier } 911f4231f8SEric Fiselier #if TEST_STD_VER >= 11 925a83710eSEric Fiselier { 935a83710eSEric Fiselier typedef min_allocator<char> A; 945a83710eSEric Fiselier const char* s = "12345678901234567890123456789012345678901234567890"; 955a83710eSEric Fiselier 965a83710eSEric Fiselier test(s, s); 975a83710eSEric Fiselier test(s, s, A()); 985a83710eSEric Fiselier 995a83710eSEric Fiselier test(s, s+1); 1005a83710eSEric Fiselier test(s, s+1, A()); 1015a83710eSEric Fiselier 1025a83710eSEric Fiselier test(s, s+10); 1035a83710eSEric Fiselier test(s, s+10, A()); 1045a83710eSEric Fiselier 1055a83710eSEric Fiselier test(s, s+50); 1065a83710eSEric Fiselier test(s, s+50, A()); 1075a83710eSEric Fiselier 1085a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s)); 1095a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s), A()); 1105a83710eSEric Fiselier 1115a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1)); 1125a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+1), A()); 1135a83710eSEric Fiselier 1145a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10)); 1155a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+10), A()); 1165a83710eSEric Fiselier 1175a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50)); 1185a83710eSEric Fiselier test(input_iterator<const char*>(s), input_iterator<const char*>(s+50), A()); 1195a83710eSEric Fiselier } 1205a83710eSEric Fiselier #endif 1215a83710eSEric Fiselier } 122