78 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| //////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| // (C) Copyright Ion Gaztanaga 2009-2012.
 | |
| // 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/move for documentation.
 | |
| //
 | |
| //////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| //! \file
 | |
| 
 | |
| #ifndef BOOST_MOVE_TRAITS_HPP
 | |
| #define BOOST_MOVE_TRAITS_HPP
 | |
| 
 | |
| #ifndef BOOST_CONFIG_HPP
 | |
| #  include <boost/config.hpp>
 | |
| #endif
 | |
| #
 | |
| #if defined(BOOST_HAS_PRAGMA_ONCE)
 | |
| #  pragma once
 | |
| #endif
 | |
| 
 | |
| #include <boost/move/detail/config_begin.hpp>
 | |
| 
 | |
| #ifndef BOOST_NO_CXX11_RVALUE_REFERENCES
 | |
| #include <boost/move/core.hpp>
 | |
| #endif
 | |
| #include <boost/move/detail/meta_utils.hpp>
 | |
| #include <boost/move/detail/type_traits.hpp>
 | |
| 
 | |
| namespace boost {
 | |
| 
 | |
| //! If this trait yields to true
 | |
| //! (<i>has_trivial_destructor_after_move <T>::value == true</i>)
 | |
| //! means that if T is used as argument of a move construction/assignment,
 | |
| //! there is no need to call T's destructor.
 | |
| //! This optimization tipically is used to improve containers' performance.
 | |
| //!
 | |
| //! By default this trait is true if the type has trivial destructor,
 | |
| //! every class should specialize this trait if it wants to improve performance
 | |
| //! when inserted in containers.
 | |
| template <class T>
 | |
| struct has_trivial_destructor_after_move
 | |
|    : ::boost::move_detail::is_trivially_destructible<T>
 | |
| {};
 | |
| 
 | |
| //! By default this traits returns
 | |
| //! <pre>boost::is_nothrow_move_constructible<T>::value && boost::is_nothrow_move_assignable<T>::value </pre>.
 | |
| //! Classes with non-throwing move constructor
 | |
| //! and assignment can specialize this trait to obtain some performance improvements.
 | |
| template <class T>
 | |
| struct has_nothrow_move
 | |
| {
 | |
|    static const bool value = boost::move_detail::is_nothrow_move_constructible<T>::value &&
 | |
|                              boost::move_detail::is_nothrow_move_assignable<T>::value;
 | |
| };
 | |
| 
 | |
| namespace move_detail {
 | |
| 
 | |
| template <class T>
 | |
| struct is_nothrow_move_constructible_or_uncopyable
 | |
| {
 | |
|    //The standard requires is_nothrow_move_constructible for move_if_noexcept
 | |
|    //but a user (usually in C++03) might specialize has_nothrow_move which includes it
 | |
|    static const bool value = is_nothrow_move_constructible<T>::value ||
 | |
|                              has_nothrow_move<T>::value ||
 | |
|                             !is_copy_constructible<T>::value;
 | |
| };
 | |
| 
 | |
| }  //move_detail {
 | |
| }  //namespace boost {
 | |
| 
 | |
| #include <boost/move/detail/config_end.hpp>
 | |
| 
 | |
| #endif //#ifndef BOOST_MOVE_TRAITS_HPP
 | 
