293 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			293 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| // (C) Copyright Joaquin M Lopez Munoz  2006-2013
 | |
| // (C) Copyright Ion Gaztanaga          2014-2014
 | |
| //
 | |
| // 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_DETAIL_EBO_HOLDER_HPP
 | |
| #define BOOST_INTRUSIVE_DETAIL_EBO_HOLDER_HPP
 | |
| 
 | |
| #ifndef BOOST_CONFIG_HPP
 | |
| #  include <boost/config.hpp>
 | |
| #endif
 | |
| 
 | |
| #if defined(BOOST_HAS_PRAGMA_ONCE)
 | |
| #  pragma once
 | |
| #endif
 | |
| 
 | |
| #include <boost/intrusive/detail/workaround.hpp>
 | |
| #include <boost/move/utility_core.hpp>
 | |
| 
 | |
| namespace boost {
 | |
| namespace intrusive {
 | |
| namespace detail {
 | |
| 
 | |
| #if defined(BOOST_MSVC) || defined(__BORLANDC_)
 | |
| #define BOOST_INTRUSIVE_TT_DECL __cdecl
 | |
| #else
 | |
| #define BOOST_INTRUSIVE_TT_DECL
 | |
| #endif
 | |
| 
 | |
| #if defined(_MSC_EXTENSIONS) && !defined(__BORLAND__) && !defined(_WIN64) && !defined(_M_ARM) && !defined(UNDER_CE)
 | |
| #define BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| #endif
 | |
| 
 | |
| template <typename T>
 | |
| struct is_unary_or_binary_function_impl
 | |
| {  static const bool value = false; };
 | |
| 
 | |
| // see boost ticket #4094
 | |
| // avoid duplicate definitions of is_unary_or_binary_function_impl
 | |
| #ifndef BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| 
 | |
| template <typename R>
 | |
| struct is_unary_or_binary_function_impl<R (*)()>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| template <typename R>
 | |
| struct is_unary_or_binary_function_impl<R (*)(...)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #else // BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| 
 | |
| template <typename R>
 | |
| struct is_unary_or_binary_function_impl<R (__stdcall*)()>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #ifndef _MANAGED
 | |
| 
 | |
| template <typename R>
 | |
| struct is_unary_or_binary_function_impl<R (__fastcall*)()>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #endif
 | |
| 
 | |
| template <typename R>
 | |
| struct is_unary_or_binary_function_impl<R (__cdecl*)()>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| template <typename R>
 | |
| struct is_unary_or_binary_function_impl<R (__cdecl*)(...)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #endif
 | |
| 
 | |
| // see boost ticket #4094
 | |
| // avoid duplicate definitions of is_unary_or_binary_function_impl
 | |
| #ifndef BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| 
 | |
| template <typename R, class T0>
 | |
| struct is_unary_or_binary_function_impl<R (*)(T0)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| template <typename R, class T0>
 | |
| struct is_unary_or_binary_function_impl<R (*)(T0...)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #else // BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| 
 | |
| template <typename R, class T0>
 | |
| struct is_unary_or_binary_function_impl<R (__stdcall*)(T0)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #ifndef _MANAGED
 | |
| 
 | |
| template <typename R, class T0>
 | |
| struct is_unary_or_binary_function_impl<R (__fastcall*)(T0)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #endif
 | |
| 
 | |
| template <typename R, class T0>
 | |
| struct is_unary_or_binary_function_impl<R (__cdecl*)(T0)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| template <typename R, class T0>
 | |
| struct is_unary_or_binary_function_impl<R (__cdecl*)(T0...)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #endif
 | |
| 
 | |
| // see boost ticket #4094
 | |
| // avoid duplicate definitions of is_unary_or_binary_function_impl
 | |
| #ifndef BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| 
 | |
| template <typename R, class T0, class T1>
 | |
| struct is_unary_or_binary_function_impl<R (*)(T0, T1)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| template <typename R, class T0, class T1>
 | |
| struct is_unary_or_binary_function_impl<R (*)(T0, T1...)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #else // BOOST_INTRUSIVE_TT_TEST_MSC_FUNC_SIGS
 | |
| 
 | |
| template <typename R, class T0, class T1>
 | |
| struct is_unary_or_binary_function_impl<R (__stdcall*)(T0, T1)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #ifndef _MANAGED
 | |
| 
 | |
| template <typename R, class T0, class T1>
 | |
| struct is_unary_or_binary_function_impl<R (__fastcall*)(T0, T1)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| #endif
 | |
| 
 | |
| template <typename R, class T0, class T1>
 | |
| struct is_unary_or_binary_function_impl<R (__cdecl*)(T0, T1)>
 | |
| {  static const bool value = true;  };
 | |
| 
 | |
| template <typename R, class T0, class T1>
 | |
| struct is_unary_or_binary_function_impl<R (__cdecl*)(T0, T1...)>
 | |
| {  static const bool value = true;  };
 | |
| #endif
 | |
| 
 | |
| template <typename T>
 | |
| struct is_unary_or_binary_function_impl<T&>
 | |
| {  static const bool value = false; };
 | |
| 
 | |
| template<typename T>
 | |
| struct is_unary_or_binary_function : is_unary_or_binary_function_impl<T>
 | |
| {};
 | |
| 
 | |
| template<typename T, bool = is_unary_or_binary_function<T>::value>
 | |
| class ebo_functor_holder
 | |
| {
 | |
|    BOOST_COPYABLE_AND_MOVABLE(ebo_functor_holder)
 | |
| 
 | |
|    public:
 | |
|    typedef T functor_type;
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder()
 | |
|       : t_()
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE explicit ebo_functor_holder(const T &t)
 | |
|       : t_(t)
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE explicit ebo_functor_holder(BOOST_RV_REF(T) t)
 | |
|       : t_(::boost::move(t))
 | |
|    {}
 | |
| 
 | |
|    template<class Arg1, class Arg2>
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder(BOOST_FWD_REF(Arg1) arg1, BOOST_FWD_REF(Arg2) arg2)
 | |
|       : t_(::boost::forward<Arg1>(arg1), ::boost::forward<Arg2>(arg2))
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder(const ebo_functor_holder &x)
 | |
|       : t_(x.t_)
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder(BOOST_RV_REF(ebo_functor_holder) x)
 | |
|       : t_(x.t_)
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(BOOST_COPY_ASSIGN_REF(ebo_functor_holder) x)
 | |
|    {
 | |
|       this->get() = x.get();
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(BOOST_RV_REF(ebo_functor_holder) x)
 | |
|    {
 | |
|       this->get() = ::boost::move(x.get());
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(const T &x)
 | |
|    {
 | |
|       this->get() = x;
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(BOOST_RV_REF(T) x)
 | |
|    {
 | |
|       this->get() = ::boost::move(x);
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE T&       get(){return t_;}
 | |
|    BOOST_INTRUSIVE_FORCEINLINE const T& get()const{return t_;}
 | |
| 
 | |
|    private:
 | |
|    T t_;
 | |
| };
 | |
| 
 | |
| template<typename T>
 | |
| class ebo_functor_holder<T, false>
 | |
|    :  public T
 | |
| {
 | |
|    BOOST_COPYABLE_AND_MOVABLE(ebo_functor_holder)
 | |
| 
 | |
|    public:
 | |
|    typedef T functor_type;
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder()
 | |
|       : T()
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE explicit ebo_functor_holder(const T &t)
 | |
|       : T(t)
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE explicit ebo_functor_holder(BOOST_RV_REF(T) t)
 | |
|       : T(::boost::move(t))
 | |
|    {}
 | |
| 
 | |
|    template<class Arg1, class Arg2>
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder(BOOST_FWD_REF(Arg1) arg1, BOOST_FWD_REF(Arg2) arg2)
 | |
|       : T(::boost::forward<Arg1>(arg1), ::boost::forward<Arg2>(arg2))
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder(const ebo_functor_holder &x)
 | |
|       : T(static_cast<const T&>(x))
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder(BOOST_RV_REF(ebo_functor_holder) x)
 | |
|       : T(BOOST_MOVE_BASE(T, x))
 | |
|    {}
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(BOOST_COPY_ASSIGN_REF(ebo_functor_holder) x)
 | |
|    {
 | |
|       const ebo_functor_holder&r = x;
 | |
|       this->get() = r;
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(BOOST_RV_REF(ebo_functor_holder) x)
 | |
|    {
 | |
|       this->get() = ::boost::move(x.get());
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(const T &x)
 | |
|    {
 | |
|       this->get() = x;
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE ebo_functor_holder& operator=(BOOST_RV_REF(T) x)
 | |
|    {
 | |
|       this->get() = ::boost::move(x);
 | |
|       return *this;
 | |
|    }
 | |
| 
 | |
|    BOOST_INTRUSIVE_FORCEINLINE T&       get(){return *this;}
 | |
|    BOOST_INTRUSIVE_FORCEINLINE const T& get()const{return *this;}
 | |
| };
 | |
| 
 | |
| }  //namespace detail {
 | |
| }  //namespace intrusive {
 | |
| }  //namespace boost {
 | |
| 
 | |
| #endif   //#ifndef BOOST_INTRUSIVE_DETAIL_EBO_HOLDER_HPP
 | 
