1 // 2001-12-28 Phil Edwards <pme@gcc.gnu.org>
3 // Copyright (C) 2001-2017 Free Software Foundation, Inc.
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)
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" }
27 #include <testsuite_hooks.h>
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
42 bool operator()( int x
, const string
& a
) const
47 bool operator()( const string
& a
, int x
) const
52 const vector
<string
>& V
;
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
++)
66 indirectCompare
aComparison(Words
);
68 sort(Index
.begin(), Index
.end(), aComparison
);
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
);