1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
5 * Hewlett-Packard Company
7 * Copyright (c) 1996-1998
8 * Silicon Graphics Computer Systems, Inc.
11 * Moscow Center for SPARC Technology
16 * This material is provided "as is", with absolutely no warranty expressed
17 * or implied. Any use is at your own risk.
19 * Permission to use or copy this software for any purpose is hereby granted
20 * without fee, provided the above notices are retained on all copies.
21 * Permission to modify the code and to distribute modified code is granted,
22 * provided the above notices are retained, and a notice that the code was
23 * modified is included with the above copyright notice.
28 * Lifted and paraphrased from STLport - with additions from Fridrich
29 * Strba and Thorsten Behrens
32 #ifndef INCLUDED_O3TL_COMPAT_FUNCTIONAL_HXX
33 #define INCLUDED_O3TL_COMPAT_FUNCTIONAL_HXX
40 /// Identity functor - return the input value
42 struct identity
: public std::unary_function
<T
, T
>
44 T
operator()(const T
& y
) const
50 /// Functor, given two parameters, return the first
51 template<class T1
,class T2
>
52 struct project1st
: public std::binary_function
<T1
, T2
, T1
>
54 T1
operator()(const T1
& y
, const T2
&) const
60 /// Functor, given two parameters, return the second
61 template<class T1
,class T2
>
62 struct project2nd
: public std::binary_function
<T1
, T2
, T2
>
64 T2
operator()(const T1
&, const T2
& x
) const
70 /// Select first value of a pair
72 struct select1st
: public std::unary_function
<P
, typename
P::first_type
>
74 const typename
P::first_type
& operator()(const P
& y
) const
80 /// Select second value of a pair
82 struct select2nd
: public std::unary_function
<P
, typename
P::second_type
>
84 const typename
P::second_type
& operator()(const P
& y
) const
90 /// Call F1 with the result of F2 applied to the one input parameter
91 template<class F1
, class F2
>
92 class unary_compose
: public std::unary_function
<typename
F2::argument_type
, typename
F1::result_type
>
95 unary_compose(const F1
& fnction1
, const F2
& fnction2
) : ftor1(fnction1
), ftor2(fnction2
) {}
97 typename
F1::result_type
operator()(const typename
F2::argument_type
& y
) const
99 return (ftor1(ftor2(y
)));
107 /// Create functor that calls F1 with the result of F2 applied to the one input parameter
108 template<class F1
, class F2
>
109 inline unary_compose
<F1
, F2
> compose1(const F1
& fnction1
, const F2
& fnction2
)
111 return (unary_compose
<F1
, F2
>(fnction1
, fnction2
));
114 /// Calls F2 and F3 for the two args of F1, respectively
115 template<class F1
, class F2
, class F3
>
116 class binary_compose
: public std::unary_function
<typename
F2::argument_type
,typename
F1::result_type
>
119 binary_compose(const F1
& fnction1
, const F2
& fnction2
, const F3
& fnction3
) : ftor1(fnction1
), ftor2(fnction2
), ftor3(fnction3
) {}
121 typename
F1::result_type
operator()(const typename
F2::argument_type
& y
) const
123 return (ftor1(ftor2(y
), ftor3(y
)));
132 /// Creates functor that calls F2 and F3 for the two args of F1, respectively
133 template<class F1
, class F2
, class F3
>
134 inline binary_compose
<F1
, F2
, F3
> compose2(const F1
& fnction1
, const F2
& fnction2
, const F3
& fnction3
)
136 return (binary_compose
<F1
, F2
, F3
>(fnction1
, fnction2
, fnction3
));
139 /// Algo that assigns val, val+1, ... to the given range
140 template<typename FwdIter
, typename ValueType
>
141 inline void iota(FwdIter first
, FwdIter last
, ValueType val
)
151 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */