1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- //////////////////////////////////////////////////////////////////////////////
- //
- // (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
|