//----------------------------------------------------------------------------- // boost variant/recursive_wrapper_fwd.hpp header file // See http://www.boost.org for updates, documentation, and revision history. //----------------------------------------------------------------------------- // // Copyright (c) 2002 Eric Friedman, Itay Maman // Copyright (c) 2016-2019 Antony Polukhin // // Portions Copyright (C) 2002 David Abrahams // // 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) #ifndef BOOST_VARIANT_RECURSIVE_WRAPPER_FWD_HPP #define BOOST_VARIANT_RECURSIVE_WRAPPER_FWD_HPP #include #include #include #include #include #include namespace boost { ////////////////////////////////////////////////////////////////////////// // class template recursive_wrapper // // Enables recursive types in templates by breaking cyclic dependencies. // // For example: // // class my; // // typedef variant< int, recursive_wrapper > var; // // class my { // var var_; // ... // }; // template class recursive_wrapper; /////////////////////////////////////////////////////////////////////////////// // metafunction is_constructible partial specializations. // // recursive_wrapper is constructible only from T and recursive_wrapper. // template struct is_constructible, T> : boost::true_type{}; template struct is_constructible, const T> : boost::true_type{}; template struct is_constructible, T&> : boost::true_type{}; template struct is_constructible, const T&> : boost::true_type{}; template struct is_constructible, recursive_wrapper > : boost::true_type{}; template struct is_constructible, const recursive_wrapper > : boost::true_type{}; template struct is_constructible, recursive_wrapper& > : boost::true_type{}; template struct is_constructible, const recursive_wrapper& > : boost::true_type{}; template struct is_constructible, U > : boost::false_type{}; template struct is_constructible, const U > : boost::false_type{}; template struct is_constructible, U& > : boost::false_type{}; template struct is_constructible, const U& > : boost::false_type{}; template struct is_constructible, recursive_wrapper > : boost::false_type{}; template struct is_constructible, const recursive_wrapper > : boost::false_type{}; template struct is_constructible, recursive_wrapper& > : boost::false_type{}; template struct is_constructible, const recursive_wrapper& > : boost::false_type{}; // recursive_wrapper is not nothrow move constructible, because it's constructor does dynamic memory allocation. // This specialisation is required to workaround GCC6 issue: https://svn.boost.org/trac/boost/ticket/12680 template struct is_nothrow_move_constructible > : boost::false_type{}; /////////////////////////////////////////////////////////////////////////////// // metafunction is_recursive_wrapper (modeled on code by David Abrahams) // // True if specified type matches recursive_wrapper. // namespace detail { template struct is_recursive_wrapper_impl : mpl::false_ { }; template struct is_recursive_wrapper_impl< recursive_wrapper > : mpl::true_ { }; } // namespace detail template< typename T > struct is_recursive_wrapper : public ::boost::integral_constant::value)> { public: BOOST_MPL_AUX_LAMBDA_SUPPORT(1,is_recursive_wrapper,(T)) }; /////////////////////////////////////////////////////////////////////////////// // metafunction unwrap_recursive // // If specified type T matches recursive_wrapper, then U; else T. // template struct unwrap_recursive { typedef T type; BOOST_MPL_AUX_LAMBDA_SUPPORT(1,unwrap_recursive,(T)) }; template struct unwrap_recursive< recursive_wrapper > { typedef T type; BOOST_MPL_AUX_LAMBDA_SUPPORT_SPEC(1,unwrap_recursive,(T)) }; } // namespace boost #endif // BOOST_VARIANT_RECURSIVE_WRAPPER_FWD_HPP