// Copyright Daniel Wallin, David Abrahams 2005. Use, modification and // distribution is subject to 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 UNWRAP_CV_REFERENCE_050328_HPP #define UNWRAP_CV_REFERENCE_050328_HPP #include #include #include #include namespace lslboost { template class reference_wrapper; } namespace lslboost { namespace parameter { namespace aux { // // reference_wrapper support -- because of the forwarding problem, // when passing arguments positionally by non-const reference, we // ask users of named parameter interfaces to use ref(x) to wrap // them. // // is_cv_reference_wrapper returns mpl::true_ if T is of type // reference_wrapper cv template yes_tag is_cv_reference_wrapper_check(reference_wrapper const volatile*); no_tag is_cv_reference_wrapper_check(...); template struct is_cv_reference_wrapper { BOOST_STATIC_CONSTANT( bool, value = ( sizeof(is_cv_reference_wrapper_check((T*)0)) == sizeof(yes_tag) ) ); typedef mpl::bool_< #if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) is_cv_reference_wrapper:: #endif value> type; }; // Needed for unwrap_cv_reference below. T might be const, so // eval_if might fail because of deriving from T const on EDG. template struct get_type { typedef typename T::type type; }; #if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) template ::type> struct unwrap_cv_reference { typedef T type; }; template struct unwrap_cv_reference { typedef T const type; }; template struct unwrap_cv_reference : T {}; #else // Produces the unwrapped type to hold a reference to in named<> // Can't use lslboost::unwrap_reference<> here because it // doesn't handle the case where T = reference_wrapper cv template struct unwrap_cv_reference { typedef typename mpl::eval_if< is_cv_reference_wrapper , get_type , mpl::identity >::type type; }; #endif }}} // namespace lslboost::parameter::aux #endif // UNWRAP_CV_REFERENCE_050328_HPP