xref: /dflybsd-src/contrib/gcc-8.0/libstdc++-v3/include/bits/predefined_ops.h (revision 38fd149817dfbff97799f62fcb70be98c4e32523)
1*38fd1498Szrj // Default predicates for internal use -*- C++ -*-
2*38fd1498Szrj 
3*38fd1498Szrj // Copyright (C) 2013-2018 Free Software Foundation, Inc.
4*38fd1498Szrj //
5*38fd1498Szrj // This file is part of the GNU ISO C++ Library.  This library is free
6*38fd1498Szrj // software; you can redistribute it and/or modify it under the
7*38fd1498Szrj // terms of the GNU General Public License as published by the
8*38fd1498Szrj // Free Software Foundation; either version 3, or (at your option)
9*38fd1498Szrj // any later version.
10*38fd1498Szrj 
11*38fd1498Szrj // This library is distributed in the hope that it will be useful,
12*38fd1498Szrj // but WITHOUT ANY WARRANTY; without even the implied warranty of
13*38fd1498Szrj // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14*38fd1498Szrj // GNU General Public License for more details.
15*38fd1498Szrj 
16*38fd1498Szrj // Under Section 7 of GPL version 3, you are granted additional
17*38fd1498Szrj // permissions described in the GCC Runtime Library Exception, version
18*38fd1498Szrj // 3.1, as published by the Free Software Foundation.
19*38fd1498Szrj 
20*38fd1498Szrj // You should have received a copy of the GNU General Public License and
21*38fd1498Szrj // a copy of the GCC Runtime Library Exception along with this program;
22*38fd1498Szrj // see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
23*38fd1498Szrj // <http://www.gnu.org/licenses/>.
24*38fd1498Szrj 
25*38fd1498Szrj /** @file predefined_ops.h
26*38fd1498Szrj  *  This is an internal header file, included by other library headers.
27*38fd1498Szrj  *  You should not attempt to use it directly. @headername{algorithm}
28*38fd1498Szrj  */
29*38fd1498Szrj 
30*38fd1498Szrj #ifndef _GLIBCXX_PREDEFINED_OPS_H
31*38fd1498Szrj #define _GLIBCXX_PREDEFINED_OPS_H	1
32*38fd1498Szrj 
33*38fd1498Szrj namespace __gnu_cxx
34*38fd1498Szrj {
35*38fd1498Szrj namespace __ops
36*38fd1498Szrj {
37*38fd1498Szrj   struct _Iter_less_iter
38*38fd1498Szrj   {
39*38fd1498Szrj     template<typename _Iterator1, typename _Iterator2>
40*38fd1498Szrj       _GLIBCXX14_CONSTEXPR
41*38fd1498Szrj       bool
operator_Iter_less_iter42*38fd1498Szrj       operator()(_Iterator1 __it1, _Iterator2 __it2) const
43*38fd1498Szrj       { return *__it1 < *__it2; }
44*38fd1498Szrj   };
45*38fd1498Szrj 
46*38fd1498Szrj   _GLIBCXX14_CONSTEXPR
47*38fd1498Szrj   inline _Iter_less_iter
__iter_less_iter()48*38fd1498Szrj   __iter_less_iter()
49*38fd1498Szrj   { return _Iter_less_iter(); }
50*38fd1498Szrj 
51*38fd1498Szrj   struct _Iter_less_val
52*38fd1498Szrj   {
53*38fd1498Szrj #if __cplusplus >= 201103L
54*38fd1498Szrj     constexpr _Iter_less_val() = default;
55*38fd1498Szrj #else
56*38fd1498Szrj     _Iter_less_val() { }
57*38fd1498Szrj #endif
58*38fd1498Szrj 
59*38fd1498Szrj     explicit
_Iter_less_val_Iter_less_val60*38fd1498Szrj     _Iter_less_val(_Iter_less_iter) { }
61*38fd1498Szrj 
62*38fd1498Szrj     template<typename _Iterator, typename _Value>
63*38fd1498Szrj       bool
operator_Iter_less_val64*38fd1498Szrj       operator()(_Iterator __it, _Value& __val) const
65*38fd1498Szrj       { return *__it < __val; }
66*38fd1498Szrj   };
67*38fd1498Szrj 
68*38fd1498Szrj   inline _Iter_less_val
__iter_less_val()69*38fd1498Szrj   __iter_less_val()
70*38fd1498Szrj   { return _Iter_less_val(); }
71*38fd1498Szrj 
72*38fd1498Szrj   inline _Iter_less_val
__iter_comp_val(_Iter_less_iter)73*38fd1498Szrj   __iter_comp_val(_Iter_less_iter)
74*38fd1498Szrj   { return _Iter_less_val(); }
75*38fd1498Szrj 
76*38fd1498Szrj   struct _Val_less_iter
77*38fd1498Szrj   {
78*38fd1498Szrj #if __cplusplus >= 201103L
79*38fd1498Szrj     constexpr _Val_less_iter() = default;
80*38fd1498Szrj #else
81*38fd1498Szrj     _Val_less_iter() { }
82*38fd1498Szrj #endif
83*38fd1498Szrj 
84*38fd1498Szrj     explicit
_Val_less_iter_Val_less_iter85*38fd1498Szrj     _Val_less_iter(_Iter_less_iter) { }
86*38fd1498Szrj 
87*38fd1498Szrj     template<typename _Value, typename _Iterator>
88*38fd1498Szrj       bool
operator_Val_less_iter89*38fd1498Szrj       operator()(_Value& __val, _Iterator __it) const
90*38fd1498Szrj       { return __val < *__it; }
91*38fd1498Szrj   };
92*38fd1498Szrj 
93*38fd1498Szrj   inline _Val_less_iter
__val_less_iter()94*38fd1498Szrj   __val_less_iter()
95*38fd1498Szrj   { return _Val_less_iter(); }
96*38fd1498Szrj 
97*38fd1498Szrj   inline _Val_less_iter
__val_comp_iter(_Iter_less_iter)98*38fd1498Szrj   __val_comp_iter(_Iter_less_iter)
99*38fd1498Szrj   { return _Val_less_iter(); }
100*38fd1498Szrj 
101*38fd1498Szrj   struct _Iter_equal_to_iter
102*38fd1498Szrj   {
103*38fd1498Szrj     template<typename _Iterator1, typename _Iterator2>
104*38fd1498Szrj       bool
operator_Iter_equal_to_iter105*38fd1498Szrj       operator()(_Iterator1 __it1, _Iterator2 __it2) const
106*38fd1498Szrj       { return *__it1 == *__it2; }
107*38fd1498Szrj   };
108*38fd1498Szrj 
109*38fd1498Szrj   inline _Iter_equal_to_iter
__iter_equal_to_iter()110*38fd1498Szrj   __iter_equal_to_iter()
111*38fd1498Szrj   { return _Iter_equal_to_iter(); }
112*38fd1498Szrj 
113*38fd1498Szrj   struct _Iter_equal_to_val
114*38fd1498Szrj   {
115*38fd1498Szrj     template<typename _Iterator, typename _Value>
116*38fd1498Szrj       bool
operator_Iter_equal_to_val117*38fd1498Szrj       operator()(_Iterator __it, _Value& __val) const
118*38fd1498Szrj       { return *__it == __val; }
119*38fd1498Szrj   };
120*38fd1498Szrj 
121*38fd1498Szrj   inline _Iter_equal_to_val
__iter_equal_to_val()122*38fd1498Szrj   __iter_equal_to_val()
123*38fd1498Szrj   { return _Iter_equal_to_val(); }
124*38fd1498Szrj 
125*38fd1498Szrj   inline _Iter_equal_to_val
__iter_comp_val(_Iter_equal_to_iter)126*38fd1498Szrj   __iter_comp_val(_Iter_equal_to_iter)
127*38fd1498Szrj   { return _Iter_equal_to_val(); }
128*38fd1498Szrj 
129*38fd1498Szrj   template<typename _Compare>
130*38fd1498Szrj     struct _Iter_comp_iter
131*38fd1498Szrj     {
132*38fd1498Szrj       _Compare _M_comp;
133*38fd1498Szrj 
134*38fd1498Szrj       explicit _GLIBCXX14_CONSTEXPR
_Iter_comp_iter_Iter_comp_iter135*38fd1498Szrj       _Iter_comp_iter(_Compare __comp)
136*38fd1498Szrj 	: _M_comp(_GLIBCXX_MOVE(__comp))
137*38fd1498Szrj       { }
138*38fd1498Szrj 
139*38fd1498Szrj       template<typename _Iterator1, typename _Iterator2>
140*38fd1498Szrj         _GLIBCXX14_CONSTEXPR
141*38fd1498Szrj         bool
operator_Iter_comp_iter142*38fd1498Szrj         operator()(_Iterator1 __it1, _Iterator2 __it2)
143*38fd1498Szrj         { return bool(_M_comp(*__it1, *__it2)); }
144*38fd1498Szrj     };
145*38fd1498Szrj 
146*38fd1498Szrj   template<typename _Compare>
147*38fd1498Szrj     _GLIBCXX14_CONSTEXPR
148*38fd1498Szrj     inline _Iter_comp_iter<_Compare>
__iter_comp_iter(_Compare __comp)149*38fd1498Szrj     __iter_comp_iter(_Compare __comp)
150*38fd1498Szrj     { return _Iter_comp_iter<_Compare>(_GLIBCXX_MOVE(__comp)); }
151*38fd1498Szrj 
152*38fd1498Szrj   template<typename _Compare>
153*38fd1498Szrj     struct _Iter_comp_val
154*38fd1498Szrj     {
155*38fd1498Szrj       _Compare _M_comp;
156*38fd1498Szrj 
157*38fd1498Szrj       explicit
_Iter_comp_val_Iter_comp_val158*38fd1498Szrj       _Iter_comp_val(_Compare __comp)
159*38fd1498Szrj 	: _M_comp(_GLIBCXX_MOVE(__comp))
160*38fd1498Szrj       { }
161*38fd1498Szrj 
162*38fd1498Szrj       explicit
_Iter_comp_val_Iter_comp_val163*38fd1498Szrj       _Iter_comp_val(const _Iter_comp_iter<_Compare>& __comp)
164*38fd1498Szrj 	: _M_comp(__comp._M_comp)
165*38fd1498Szrj       { }
166*38fd1498Szrj 
167*38fd1498Szrj #if __cplusplus >= 201103L
168*38fd1498Szrj       explicit
_Iter_comp_val_Iter_comp_val169*38fd1498Szrj       _Iter_comp_val(_Iter_comp_iter<_Compare>&& __comp)
170*38fd1498Szrj 	: _M_comp(std::move(__comp._M_comp))
171*38fd1498Szrj       { }
172*38fd1498Szrj #endif
173*38fd1498Szrj 
174*38fd1498Szrj       template<typename _Iterator, typename _Value>
175*38fd1498Szrj 	bool
operator_Iter_comp_val176*38fd1498Szrj 	operator()(_Iterator __it, _Value& __val)
177*38fd1498Szrj 	{ return bool(_M_comp(*__it, __val)); }
178*38fd1498Szrj     };
179*38fd1498Szrj 
180*38fd1498Szrj   template<typename _Compare>
181*38fd1498Szrj    inline _Iter_comp_val<_Compare>
__iter_comp_val(_Compare __comp)182*38fd1498Szrj     __iter_comp_val(_Compare __comp)
183*38fd1498Szrj     { return _Iter_comp_val<_Compare>(_GLIBCXX_MOVE(__comp)); }
184*38fd1498Szrj 
185*38fd1498Szrj   template<typename _Compare>
186*38fd1498Szrj     inline _Iter_comp_val<_Compare>
__iter_comp_val(_Iter_comp_iter<_Compare> __comp)187*38fd1498Szrj     __iter_comp_val(_Iter_comp_iter<_Compare> __comp)
188*38fd1498Szrj     { return _Iter_comp_val<_Compare>(_GLIBCXX_MOVE(__comp)); }
189*38fd1498Szrj 
190*38fd1498Szrj   template<typename _Compare>
191*38fd1498Szrj     struct _Val_comp_iter
192*38fd1498Szrj     {
193*38fd1498Szrj       _Compare _M_comp;
194*38fd1498Szrj 
195*38fd1498Szrj       explicit
_Val_comp_iter_Val_comp_iter196*38fd1498Szrj       _Val_comp_iter(_Compare __comp)
197*38fd1498Szrj 	: _M_comp(_GLIBCXX_MOVE(__comp))
198*38fd1498Szrj       { }
199*38fd1498Szrj 
200*38fd1498Szrj       explicit
_Val_comp_iter_Val_comp_iter201*38fd1498Szrj       _Val_comp_iter(const _Iter_comp_iter<_Compare>& __comp)
202*38fd1498Szrj 	: _M_comp(__comp._M_comp)
203*38fd1498Szrj       { }
204*38fd1498Szrj 
205*38fd1498Szrj #if __cplusplus >= 201103L
206*38fd1498Szrj       explicit
_Val_comp_iter_Val_comp_iter207*38fd1498Szrj       _Val_comp_iter(_Iter_comp_iter<_Compare>&& __comp)
208*38fd1498Szrj 	: _M_comp(std::move(__comp._M_comp))
209*38fd1498Szrj       { }
210*38fd1498Szrj #endif
211*38fd1498Szrj 
212*38fd1498Szrj       template<typename _Value, typename _Iterator>
213*38fd1498Szrj 	bool
operator_Val_comp_iter214*38fd1498Szrj 	operator()(_Value& __val, _Iterator __it)
215*38fd1498Szrj 	{ return bool(_M_comp(__val, *__it)); }
216*38fd1498Szrj     };
217*38fd1498Szrj 
218*38fd1498Szrj   template<typename _Compare>
219*38fd1498Szrj     inline _Val_comp_iter<_Compare>
__val_comp_iter(_Compare __comp)220*38fd1498Szrj     __val_comp_iter(_Compare __comp)
221*38fd1498Szrj     { return _Val_comp_iter<_Compare>(_GLIBCXX_MOVE(__comp)); }
222*38fd1498Szrj 
223*38fd1498Szrj   template<typename _Compare>
224*38fd1498Szrj     inline _Val_comp_iter<_Compare>
__val_comp_iter(_Iter_comp_iter<_Compare> __comp)225*38fd1498Szrj     __val_comp_iter(_Iter_comp_iter<_Compare> __comp)
226*38fd1498Szrj     { return _Val_comp_iter<_Compare>(_GLIBCXX_MOVE(__comp)); }
227*38fd1498Szrj 
228*38fd1498Szrj   template<typename _Value>
229*38fd1498Szrj     struct _Iter_equals_val
230*38fd1498Szrj     {
231*38fd1498Szrj       _Value& _M_value;
232*38fd1498Szrj 
233*38fd1498Szrj       explicit
_Iter_equals_val_Iter_equals_val234*38fd1498Szrj       _Iter_equals_val(_Value& __value)
235*38fd1498Szrj 	: _M_value(__value)
236*38fd1498Szrj       { }
237*38fd1498Szrj 
238*38fd1498Szrj       template<typename _Iterator>
239*38fd1498Szrj 	bool
operator_Iter_equals_val240*38fd1498Szrj 	operator()(_Iterator __it)
241*38fd1498Szrj 	{ return *__it == _M_value; }
242*38fd1498Szrj     };
243*38fd1498Szrj 
244*38fd1498Szrj   template<typename _Value>
245*38fd1498Szrj     inline _Iter_equals_val<_Value>
__iter_equals_val(_Value & __val)246*38fd1498Szrj     __iter_equals_val(_Value& __val)
247*38fd1498Szrj     { return _Iter_equals_val<_Value>(__val); }
248*38fd1498Szrj 
249*38fd1498Szrj   template<typename _Iterator1>
250*38fd1498Szrj     struct _Iter_equals_iter
251*38fd1498Szrj     {
252*38fd1498Szrj       _Iterator1 _M_it1;
253*38fd1498Szrj 
254*38fd1498Szrj       explicit
_Iter_equals_iter_Iter_equals_iter255*38fd1498Szrj       _Iter_equals_iter(_Iterator1 __it1)
256*38fd1498Szrj 	: _M_it1(__it1)
257*38fd1498Szrj       { }
258*38fd1498Szrj 
259*38fd1498Szrj       template<typename _Iterator2>
260*38fd1498Szrj 	bool
operator_Iter_equals_iter261*38fd1498Szrj 	operator()(_Iterator2 __it2)
262*38fd1498Szrj 	{ return *__it2 == *_M_it1; }
263*38fd1498Szrj     };
264*38fd1498Szrj 
265*38fd1498Szrj   template<typename _Iterator>
266*38fd1498Szrj     inline _Iter_equals_iter<_Iterator>
__iter_comp_iter(_Iter_equal_to_iter,_Iterator __it)267*38fd1498Szrj     __iter_comp_iter(_Iter_equal_to_iter, _Iterator __it)
268*38fd1498Szrj     { return _Iter_equals_iter<_Iterator>(__it); }
269*38fd1498Szrj 
270*38fd1498Szrj   template<typename _Predicate>
271*38fd1498Szrj     struct _Iter_pred
272*38fd1498Szrj     {
273*38fd1498Szrj       _Predicate _M_pred;
274*38fd1498Szrj 
275*38fd1498Szrj       explicit
_Iter_pred_Iter_pred276*38fd1498Szrj       _Iter_pred(_Predicate __pred)
277*38fd1498Szrj 	: _M_pred(_GLIBCXX_MOVE(__pred))
278*38fd1498Szrj       { }
279*38fd1498Szrj 
280*38fd1498Szrj       template<typename _Iterator>
281*38fd1498Szrj 	bool
operator_Iter_pred282*38fd1498Szrj 	operator()(_Iterator __it)
283*38fd1498Szrj 	{ return bool(_M_pred(*__it)); }
284*38fd1498Szrj     };
285*38fd1498Szrj 
286*38fd1498Szrj   template<typename _Predicate>
287*38fd1498Szrj     inline _Iter_pred<_Predicate>
__pred_iter(_Predicate __pred)288*38fd1498Szrj     __pred_iter(_Predicate __pred)
289*38fd1498Szrj     { return _Iter_pred<_Predicate>(_GLIBCXX_MOVE(__pred)); }
290*38fd1498Szrj 
291*38fd1498Szrj   template<typename _Compare, typename _Value>
292*38fd1498Szrj     struct _Iter_comp_to_val
293*38fd1498Szrj     {
294*38fd1498Szrj       _Compare _M_comp;
295*38fd1498Szrj       _Value& _M_value;
296*38fd1498Szrj 
_Iter_comp_to_val_Iter_comp_to_val297*38fd1498Szrj       _Iter_comp_to_val(_Compare __comp, _Value& __value)
298*38fd1498Szrj 	: _M_comp(_GLIBCXX_MOVE(__comp)), _M_value(__value)
299*38fd1498Szrj       { }
300*38fd1498Szrj 
301*38fd1498Szrj       template<typename _Iterator>
302*38fd1498Szrj 	bool
operator_Iter_comp_to_val303*38fd1498Szrj 	operator()(_Iterator __it)
304*38fd1498Szrj 	{ return bool(_M_comp(*__it, _M_value)); }
305*38fd1498Szrj     };
306*38fd1498Szrj 
307*38fd1498Szrj   template<typename _Compare, typename _Value>
308*38fd1498Szrj     _Iter_comp_to_val<_Compare, _Value>
__iter_comp_val(_Compare __comp,_Value & __val)309*38fd1498Szrj     __iter_comp_val(_Compare __comp, _Value &__val)
310*38fd1498Szrj     {
311*38fd1498Szrj       return _Iter_comp_to_val<_Compare, _Value>(_GLIBCXX_MOVE(__comp), __val);
312*38fd1498Szrj     }
313*38fd1498Szrj 
314*38fd1498Szrj   template<typename _Compare, typename _Iterator1>
315*38fd1498Szrj     struct _Iter_comp_to_iter
316*38fd1498Szrj     {
317*38fd1498Szrj       _Compare _M_comp;
318*38fd1498Szrj       _Iterator1 _M_it1;
319*38fd1498Szrj 
_Iter_comp_to_iter_Iter_comp_to_iter320*38fd1498Szrj       _Iter_comp_to_iter(_Compare __comp, _Iterator1 __it1)
321*38fd1498Szrj 	: _M_comp(_GLIBCXX_MOVE(__comp)), _M_it1(__it1)
322*38fd1498Szrj       { }
323*38fd1498Szrj 
324*38fd1498Szrj       template<typename _Iterator2>
325*38fd1498Szrj 	bool
operator_Iter_comp_to_iter326*38fd1498Szrj 	operator()(_Iterator2 __it2)
327*38fd1498Szrj 	{ return bool(_M_comp(*__it2, *_M_it1)); }
328*38fd1498Szrj     };
329*38fd1498Szrj 
330*38fd1498Szrj   template<typename _Compare, typename _Iterator>
331*38fd1498Szrj     inline _Iter_comp_to_iter<_Compare, _Iterator>
__iter_comp_iter(_Iter_comp_iter<_Compare> __comp,_Iterator __it)332*38fd1498Szrj     __iter_comp_iter(_Iter_comp_iter<_Compare> __comp, _Iterator __it)
333*38fd1498Szrj     {
334*38fd1498Szrj       return _Iter_comp_to_iter<_Compare, _Iterator>(
335*38fd1498Szrj 	  _GLIBCXX_MOVE(__comp._M_comp), __it);
336*38fd1498Szrj     }
337*38fd1498Szrj 
338*38fd1498Szrj   template<typename _Predicate>
339*38fd1498Szrj     struct _Iter_negate
340*38fd1498Szrj     {
341*38fd1498Szrj       _Predicate _M_pred;
342*38fd1498Szrj 
343*38fd1498Szrj       explicit
_Iter_negate_Iter_negate344*38fd1498Szrj       _Iter_negate(_Predicate __pred)
345*38fd1498Szrj 	: _M_pred(_GLIBCXX_MOVE(__pred))
346*38fd1498Szrj       { }
347*38fd1498Szrj 
348*38fd1498Szrj       template<typename _Iterator>
349*38fd1498Szrj 	bool
operator_Iter_negate350*38fd1498Szrj 	operator()(_Iterator __it)
351*38fd1498Szrj 	{ return !bool(_M_pred(*__it)); }
352*38fd1498Szrj     };
353*38fd1498Szrj 
354*38fd1498Szrj   template<typename _Predicate>
355*38fd1498Szrj     inline _Iter_negate<_Predicate>
__negate(_Iter_pred<_Predicate> __pred)356*38fd1498Szrj     __negate(_Iter_pred<_Predicate> __pred)
357*38fd1498Szrj     { return _Iter_negate<_Predicate>(_GLIBCXX_MOVE(__pred._M_pred)); }
358*38fd1498Szrj 
359*38fd1498Szrj } // namespace __ops
360*38fd1498Szrj } // namespace __gnu_cxx
361*38fd1498Szrj 
362*38fd1498Szrj #endif
363