// (C) Copyright 2009-2011 Frederic Bron. // // Use, modification and distribution are 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). // // See http://www.boost.org/libs/type_traits for most recent version including documentation. #ifndef BOOST_TT_HAS_PLUS_ASSIGN_HPP_INCLUDED #define BOOST_TT_HAS_PLUS_ASSIGN_HPP_INCLUDED #include #include // cannot include this header without getting warnings of the kind: // gcc: // warning: value computed is not used // warning: comparison between signed and unsigned integer expressions // msvc: // warning C4018: '<' : signed/unsigned mismatch // warning C4244: '+=' : conversion from 'double' to 'char', possible loss of data // warning C4547: '*' : operator before comma has no effect; expected operator with side-effect // warning C4800: 'int' : forcing value to bool 'true' or 'false' (performance warning) // warning C4804: '<' : unsafe use of type 'bool' in operation // warning C4805: '==' : unsafe mix of type 'bool' and type 'char' in operation // cannot find another implementation -> declared as system header to suppress these warnings. #if defined(__GNUC__) # pragma GCC system_header #elif defined(BOOST_MSVC) # pragma warning ( push ) # pragma warning ( disable : 4018 4244 4547 4800 4804 4805 4913 4133) # if BOOST_WORKAROUND(BOOST_MSVC_FULL_VER, >= 140050000) # pragma warning ( disable : 6334) # endif #endif #if defined(BOOST_TT_HAS_ACCURATE_BINARY_OPERATOR_DETECTION) #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace binary_op_detail { struct dont_care; template > struct has_plus_assign_ret_imp : public boost::false_type {}; template struct has_plus_assign_ret_imp::type>() += std::declval::type>())> > : public boost::integral_constant::type>() += std::declval::type>()), Ret>::value> {}; template > struct has_plus_assign_void_imp : public boost::false_type {}; template struct has_plus_assign_void_imp::type>() += std::declval::type>())> > : public boost::integral_constant::type>() += std::declval::type>())>::value> {}; template > struct has_plus_assign_dc_imp : public boost::false_type {}; template struct has_plus_assign_dc_imp::type>() += std::declval::type>())> > : public boost::true_type {}; template struct has_plus_assign_filter_ret : public boost::binary_op_detail:: has_plus_assign_ret_imp {}; template struct has_plus_assign_filter_ret : public boost::binary_op_detail:: has_plus_assign_void_imp {}; template struct has_plus_assign_filter_ret : public boost::binary_op_detail:: has_plus_assign_dc_imp {}; template struct has_plus_assign_filter_impossible : public boost::binary_op_detail:: has_plus_assign_filter_ret {}; template struct has_plus_assign_filter_impossible : public boost::false_type {}; } template struct has_plus_assign : public boost::binary_op_detail:: has_plus_assign_filter_impossible ::type>::value && boost::is_pointer::type>::value && !boost::is_same::type>::type>::value> {}; } #else #define BOOST_TT_TRAIT_NAME has_plus_assign #define BOOST_TT_TRAIT_OP += #define BOOST_TT_FORBIDDEN_IF\ (\ /* Lhs==pointer and Rhs==pointer */\ (\ ::boost::is_pointer< Lhs_noref >::value && \ ::boost::is_pointer< Rhs_noref >::value\ ) || \ /* Lhs==void* and Rhs==fundamental */\ (\ ::boost::is_pointer< Lhs_noref >::value && \ ::boost::is_void< Lhs_noptr >::value && \ ::boost::is_fundamental< Rhs_nocv >::value\ ) || \ /* Rhs==void* and Lhs==fundamental */\ (\ ::boost::is_pointer< Rhs_noref >::value && \ ::boost::is_void< Rhs_noptr >::value && \ ::boost::is_fundamental< Lhs_nocv >::value\ ) || \ /* Lhs==pointer and Rhs==fundamental and Rhs!=integral */\ (\ ::boost::is_pointer< Lhs_noref >::value && \ ::boost::is_fundamental< Rhs_nocv >::value && \ (! ::boost::is_integral< Rhs_noref >::value )\ ) || \ /* Rhs==pointer and Lhs==fundamental and Lhs!=bool */\ (\ ::boost::is_pointer< Rhs_noref >::value && \ ::boost::is_fundamental< Lhs_nocv >::value && \ (! ::boost::is_same< Lhs_nocv, bool >::value )\ ) || \ /* (Lhs==fundamental or Lhs==pointer) and (Rhs==fundamental or Rhs==pointer) and (Lhs==const) */\ (\ (\ ::boost::is_fundamental< Lhs_nocv >::value || \ ::boost::is_pointer< Lhs_noref >::value\ ) && \ ( \ ::boost::is_fundamental< Rhs_nocv >::value || \ ::boost::is_pointer< Rhs_noref >::value\ ) && \ ::boost::is_const< Lhs_noref >::value\ )\ ) #include #undef BOOST_TT_TRAIT_NAME #undef BOOST_TT_TRAIT_OP #undef BOOST_TT_FORBIDDEN_IF #endif #endif