1bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//===----------------------------------------------------------------------===// 2bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// 3f5256e16dfc425c1d466f6308d4026d529ce9e0bHoward Hinnant// The LLVM Compiler Infrastructure 4bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// 5b64f8b07c104c6cc986570ac8ee0ed16a9f23976Howard Hinnant// This file is dual licensed under the MIT and the University of Illinois Open 6b64f8b07c104c6cc986570ac8ee0ed16a9f23976Howard Hinnant// Source Licenses. See LICENSE.TXT for details. 7bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// 8bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant//===----------------------------------------------------------------------===// 9bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 10bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// <vector> 11bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 12bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant// vector(const vector& v, const allocator_type& a); 13bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 14bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant#include <vector> 15bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant#include <cassert> 161b92188a82b01e76ac6e8ad5f997293c2a078adcMarshall Clow#include "test_allocator.h" 17061d0cc4db18d17bf01ed14c5db0be098205bd47Marshall Clow#include "min_allocator.h" 18bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 19bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnanttemplate <class C> 20bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnantvoid 21bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnanttest(const C& x, const typename C::allocator_type& a) 22bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant{ 23bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant unsigned s = x.size(); 24bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant C c(x, a); 25bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(c.__invariants()); 26bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(c.size() == s); 27bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(c == x); 28bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant} 29bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant 30bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnantint main() 31bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant{ 32bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant { 33bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant int a[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 8, 7, 6, 5, 4, 3, 1, 0}; 34bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant int* an = a + sizeof(a)/sizeof(a[0]); 35bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant test(std::vector<int>(a, an), std::allocator<int>()); 36bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant } 37bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant { 38bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant std::vector<int, test_allocator<int> > l(3, 2, test_allocator<int>(5)); 39bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant std::vector<int, test_allocator<int> > l2(l, test_allocator<int>(3)); 40bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(l2 == l); 41bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(l2.get_allocator() == test_allocator<int>(3)); 42bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant } 43bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant { 44bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant std::vector<int, other_allocator<int> > l(3, 2, other_allocator<int>(5)); 45bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant std::vector<int, other_allocator<int> > l2(l, other_allocator<int>(3)); 46bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(l2 == l); 47bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant assert(l2.get_allocator() == other_allocator<int>(3)); 48bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant } 492c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant#if __cplusplus >= 201103L 502c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant { 512c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant int a[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 8, 7, 6, 5, 4, 3, 1, 0}; 522c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant int* an = a + sizeof(a)/sizeof(a[0]); 532c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant test(std::vector<int, min_allocator<int>>(a, an), min_allocator<int>()); 542c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant } 552c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant { 562c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant std::vector<int, min_allocator<int> > l(3, 2, min_allocator<int>()); 572c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant std::vector<int, min_allocator<int> > l2(l, min_allocator<int>()); 582c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant assert(l2 == l); 592c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant assert(l2.get_allocator() == min_allocator<int>()); 602c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant } 612c39cbe0207908bca2e1da40e16cbc443d2e7438Howard Hinnant#endif 62bc8d3f97eb5c958007f2713238472e0c1c8fe02Howard Hinnant} 63