1 //===----------------------------------------------------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is dual licensed under the MIT and the University of Illinois Open 6 // Source Licenses. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 // <list> 11 12 // template <class BinaryPred> void unique(BinaryPred pred); 13 14 #include <list> 15 #include <cassert> 16 17 #include "min_allocator.h" 18 19 bool g(int x, int y) 20 { 21 return x == y; 22 } 23 24 int main() 25 { 26 { 27 int a1[] = {2, 1, 1, 4, 4, 4, 4, 3, 3}; 28 int a2[] = {2, 1, 4, 3}; 29 std::list<int> c(a1, a1+sizeof(a1)/sizeof(a1[0])); 30 c.unique(g); 31 assert(c == std::list<int>(a2, a2+4)); 32 } 33 #if __cplusplus >= 201103L 34 { 35 int a1[] = {2, 1, 1, 4, 4, 4, 4, 3, 3}; 36 int a2[] = {2, 1, 4, 3}; 37 std::list<int, min_allocator<int>> c(a1, a1+sizeof(a1)/sizeof(a1[0])); 38 c.unique(g); 39 assert((c == std::list<int, min_allocator<int>>(a2, a2+4))); 40 } 41 #endif 42 } 43