unique_pred.pass.cpp revision d24c465beaec2fe9a0e365e6379cd5d3acaeb2ca
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 19bool g(int x, int y) 20{ 21 return x == y; 22} 23 24int 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 TEST_STD_VER >= 11 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