2016-06-27 François Dumont <fdumont@gcc.gnu.org>
[official-gcc.git] / libstdc++-v3 / testsuite / ext / concept_checks.cc
blobea36f9d2e25316b026826bf31fd1728412f1e09e
1 // 2001-12-28 Phil Edwards <pme@gcc.gnu.org>
2 //
3 // Copyright (C) 2001-2016 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your option)
9 // any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with this library; see the file COPYING3. If not see
18 // <http://www.gnu.org/licenses/>.
20 // Concept checking must remain sane.
22 // { dg-options "-D_GLIBCXX_CONCEPT_CHECKS" }
24 #include <vector>
25 #include <string>
26 #include <algorithm>
27 #include <testsuite_hooks.h>
29 using namespace std;
32 // PR libstdc++/2054 and follow-up discussion
33 struct indirectCompare
35 indirectCompare(const vector<string>& v) : V(v) {}
37 bool operator()( int x, int y) const
39 return V[x] < V[y];
42 bool operator()( int x, const string& a) const
44 return V[x] < a;
47 bool operator()( const string& a, int x) const
49 return V[x] < a;
52 const vector<string>& V;
55 void
56 test2054( )
58 const int Maxi = 1022;
60 vector<string> Words(Maxi);
61 vector<int> Index(Maxi);
63 for(size_t i = 0; i < Index.size(); i++)
64 Index[i] = i;
66 indirectCompare aComparison(Words);
68 sort(Index.begin(), Index.end(), aComparison);
70 string SearchTerm;
72 lower_bound(Index.begin(), Index.end(), SearchTerm, aComparison);
73 upper_bound(Index.begin(), Index.end(), SearchTerm, aComparison);
74 equal_range(Index.begin(), Index.end(), SearchTerm, aComparison);
75 binary_search(Index.begin(), Index.end(), SearchTerm, aComparison);
78 int main()
80 test2054();
81 return 0;