1*b1cdbd2cSJim Jagielski/************************************************************** 2*b1cdbd2cSJim Jagielski * 3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski * distributed with this work for additional information 6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski * 11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski * 13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski * under the License. 19*b1cdbd2cSJim Jagielski * 20*b1cdbd2cSJim Jagielski *************************************************************/ 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski#ifndef SYSTEM_STL_FUNCTIONAL 23*b1cdbd2cSJim Jagielski#define SYSTEM_STL_FUNCTIONAL 24*b1cdbd2cSJim Jagielski 25*b1cdbd2cSJim Jagielski#if defined(HAVE_STL_INCLUDE_PATH) 26*b1cdbd2cSJim Jagielski // TODO: use computed include file name 27*b1cdbd2cSJim Jagielski #include_next <functional> 28*b1cdbd2cSJim Jagielski#elif defined(_MSC_VER) 29*b1cdbd2cSJim Jagielski #include <../../VC/include/functional> 30*b1cdbd2cSJim Jagielski namespace std { using tr1::hash; } 31*b1cdbd2cSJim Jagielski#if 0 // TODO: enable only when std::_Swap_adl is not available 32*b1cdbd2cSJim Jagielski // note: VS2008SP1 has known problems after a security update (KB971092,KB974479,KB974223) 33*b1cdbd2cSJim Jagielski namespace std{ template<class _T> void _Swap_adl(_T& l, _T& r) {swap(l,r);} } 34*b1cdbd2cSJim Jagielski#endif 35*b1cdbd2cSJim Jagielski#elif defined(__cplusplus) && (__cplusplus >= 201103L) 36*b1cdbd2cSJim Jagielski #include_next <functional> 37*b1cdbd2cSJim Jagielski#else // fall back to boost/tr1 38*b1cdbd2cSJim Jagielski #include <boost/tr1/tr1/functional> 39*b1cdbd2cSJim Jagielski #include <boost/functional/hash.hpp> 40*b1cdbd2cSJim Jagielski#endif 41*b1cdbd2cSJim Jagielski 42*b1cdbd2cSJim Jagielski 43*b1cdbd2cSJim Jagielski#ifndef NO_STLPORT4_EMULATION 44*b1cdbd2cSJim Jagielski 45*b1cdbd2cSJim Jagielskinamespace std 46*b1cdbd2cSJim Jagielski{ 47*b1cdbd2cSJim Jagielski// emulate SGI extensions to the STL using http://www.sgi.com/tech/stl/stl_function.h as reference 48*b1cdbd2cSJim Jagielskitemplate< typename T> struct identity : unary_function<T,T> { T operator()(const T& t) const { return t;} }; 49*b1cdbd2cSJim Jagielskitemplate< typename T, typename U> struct project2nd : public binary_function<T,U,U> { U operator()(const T&, const U& u) const { return u;}}; 50*b1cdbd2cSJim Jagielskitemplate<typename P> struct select1st : public unary_function<P, typename P::first_type> { const typename P::first_type& operator()(const P& p) const { return p.first; }}; 51*b1cdbd2cSJim Jagielskitemplate<typename P> struct select2nd : public unary_function<P, typename P::second_type> { const typename P::second_type& operator()(const P& p) const { return p.second; }}; 52*b1cdbd2cSJim Jagielski 53*b1cdbd2cSJim Jagielski#if (defined(_MSC_VER) && (_MSC_VER >= 1600)) || defined(__GXX_EXPERIMENTAL_CXX0X__) 54*b1cdbd2cSJim Jagielskitemplate<typename T> inline T&& forward( typename identity<T>::type&& t) { return t; } 55*b1cdbd2cSJim Jagielski#endif // C++11 move semantics 56*b1cdbd2cSJim Jagielski 57*b1cdbd2cSJim Jagielskitemplate<typename Op1, typename Op2> class unary_compose : public unary_function<typename Op2::argument_type, typename Op1::result_type> 58*b1cdbd2cSJim Jagielski{ 59*b1cdbd2cSJim Jagielskiprotected: 60*b1cdbd2cSJim Jagielski Op1 aOp1; 61*b1cdbd2cSJim Jagielski Op2 aOp2; 62*b1cdbd2cSJim Jagielskipublic: 63*b1cdbd2cSJim Jagielski unary_compose( const Op1& rOp1, const Op2& rOp2) : aOp1(rOp1), aOp2(rOp2) {} 64*b1cdbd2cSJim Jagielski typename Op1::result_type operator()( const typename Op2::argument_type& x) const { return aOp1(aOp2(x)); } 65*b1cdbd2cSJim Jagielski}; 66*b1cdbd2cSJim Jagielski 67*b1cdbd2cSJim Jagielskitemplate<typename Op1, typename Op2> inline unary_compose<Op1,Op2> compose1( const Op1& rOp1, const Op2& rOp2) { return unary_compose<Op1,Op2>(rOp1, rOp2); } 68*b1cdbd2cSJim Jagielski 69*b1cdbd2cSJim Jagielski} // namespace std 70*b1cdbd2cSJim Jagielski 71*b1cdbd2cSJim Jagielski#endif // NO_STLPORT4_EMULATION 72*b1cdbd2cSJim Jagielski 73*b1cdbd2cSJim Jagielski#endif 74*b1cdbd2cSJim Jagielski 75