///////////////////////////////////////////////////////////////////////////// // // (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 BHO_INTRUSIVE_PRIORITY_COMPARE_HPP #define BHO_INTRUSIVE_PRIORITY_COMPARE_HPP #include #include #include #include #if defined(BHO_HAS_PRAGMA_ONCE) # pragma once #endif namespace bho { namespace intrusive { /// @cond namespace adldft { template BHO_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; BHO_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 BHO_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 ::bho::intrusive::priority_compare type; }; /// @endcond } //namespace intrusive } //namespace bho #include #endif //BHO_INTRUSIVE_PRIORITY_COMPARE_HPP