Merge reload-branch up to revision 101000
[official-gcc.git] / libstdc++-v3 / testsuite / 25_algorithms / adjacent_find / check_type.cc
blob65f725df17938824abf2fe81a0937d301a0dc2bc
1 // Copyright (C) 2005 Free Software Foundation, Inc.
2 //
3 // This file is part of the GNU ISO C++ Library. This library is free
4 // software; you can redistribute it and/or modify it under the
5 // terms of the GNU General Public License as published by the
6 // Free Software Foundation; either version 2, or (at your option)
7 // any later version.
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License along
15 // with this library; see the file COPYING. If not, write to the Free
16 // Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
17 // USA.
19 // 25.1.5 [lib.alg.adjacent_find]
21 // { dg-do compile }
23 #include <algorithm>
24 #include <testsuite_iterators.h>
26 using __gnu_test::forward_iterator_wrapper;
28 struct S { };
30 bool operator==(const S&, const S&) {return true;}
32 struct X { };
34 bool predicate(const X&, const X&) {return true;}
36 forward_iterator_wrapper<S>
37 test1(forward_iterator_wrapper<S>& s)
38 { return std::adjacent_find(s, s); }
40 forward_iterator_wrapper<X>
41 test2(forward_iterator_wrapper<X>& x)
42 { return std::adjacent_find(x, x, predicate); }