///////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2008 // // Distributed under the Boost Software License, Version 1.0. // (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // // See http://www.boost.org/libs/intrusive for documentation. // ///////////////////////////////////////////////////////////////////////////// #ifndef BOOST_INTRUSIVE_PRIORITY_COMPARE_HPP #define BOOST_INTRUSIVE_PRIORITY_COMPARE_HPP #include #include #include #include #if defined(BOOST_HAS_PRAGMA_ONCE) # pragma once #endif namespace boost { namespace intrusive { /// @cond namespace adldft { template BOOST_INTRUSIVE_FORCEINLINE bool priority_order(const T &t, const U &u) { return t < u; } } //namespace adldft { /// @endcond template struct priority_compare { //Compatibility with std::binary_function typedef T first_argument_type; typedef T second_argument_type; typedef bool result_type; BOOST_INTRUSIVE_FORCEINLINE bool operator()(const T &val, const T &val2) const { using adldft::priority_order; return priority_order(val, val2); } }; template <> struct priority_compare { template BOOST_INTRUSIVE_FORCEINLINE bool operator()(const T &t, const U &u) const { using adldft::priority_order; return priority_order(t, u); } }; /// @cond template struct get_prio_comp { typedef PrioComp type; }; template struct get_prio_comp { typedef ::boost::intrusive::priority_compare type; }; /// @endcond } //namespace intrusive } //namespace boost #include #endif //BOOST_INTRUSIVE_PRIORITY_COMPARE_HPP