148 lines
5.2 KiB
Plaintext
148 lines
5.2 KiB
Plaintext
|
|
||
|
// (C) Copyright Runar Undheim, Robert Ramey & John Maddock 2008.
|
||
|
// 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_NEW_OPERATOR_HPP_INCLUDED
|
||
|
#define BOOST_TT_HAS_NEW_OPERATOR_HPP_INCLUDED
|
||
|
|
||
|
#include <new> // std::nothrow_t
|
||
|
#include <cstddef> // std::size_t
|
||
|
#include <boost/type_traits/integral_constant.hpp>
|
||
|
#include <boost/type_traits/detail/yes_no_type.hpp>
|
||
|
#include <boost/detail/workaround.hpp>
|
||
|
|
||
|
#if defined(new)
|
||
|
# if BOOST_WORKAROUND(BOOST_MSVC, >= 1310)
|
||
|
# define BOOST_TT_AUX_MACRO_NEW_DEFINED
|
||
|
# pragma push_macro("new")
|
||
|
# undef new
|
||
|
# else
|
||
|
# error "Sorry but you can't include this header if 'new' is defined as a macro."
|
||
|
# endif
|
||
|
#endif
|
||
|
|
||
|
namespace boost {
|
||
|
namespace detail {
|
||
|
template <class U, U x>
|
||
|
struct test;
|
||
|
|
||
|
template <typename T>
|
||
|
struct has_new_operator_impl {
|
||
|
template<class U>
|
||
|
static type_traits::yes_type check_sig1(
|
||
|
U*,
|
||
|
test<
|
||
|
void *(*)(std::size_t),
|
||
|
&U::operator new
|
||
|
>* = NULL
|
||
|
);
|
||
|
template<class U>
|
||
|
static type_traits::no_type check_sig1(...);
|
||
|
|
||
|
template<class U>
|
||
|
static type_traits::yes_type check_sig2(
|
||
|
U*,
|
||
|
test<
|
||
|
void *(*)(std::size_t, const std::nothrow_t&),
|
||
|
&U::operator new
|
||
|
>* = NULL
|
||
|
);
|
||
|
template<class U>
|
||
|
static type_traits::no_type check_sig2(...);
|
||
|
|
||
|
template<class U>
|
||
|
static type_traits::yes_type check_sig3(
|
||
|
U*,
|
||
|
test<
|
||
|
void *(*)(std::size_t, void*),
|
||
|
&U::operator new
|
||
|
>* = NULL
|
||
|
);
|
||
|
template<class U>
|
||
|
static type_traits::no_type check_sig3(...);
|
||
|
|
||
|
|
||
|
template<class U>
|
||
|
static type_traits::yes_type check_sig4(
|
||
|
U*,
|
||
|
test<
|
||
|
void *(*)(std::size_t),
|
||
|
&U::operator new[]
|
||
|
>* = NULL
|
||
|
);
|
||
|
template<class U>
|
||
|
static type_traits::no_type check_sig4(...);
|
||
|
|
||
|
template<class U>
|
||
|
static type_traits::yes_type check_sig5(
|
||
|
U*,
|
||
|
test<
|
||
|
void *(*)(std::size_t, const std::nothrow_t&),
|
||
|
&U::operator new[]
|
||
|
>* = NULL
|
||
|
);
|
||
|
template<class U>
|
||
|
static type_traits::no_type check_sig5(...);
|
||
|
|
||
|
template<class U>
|
||
|
static type_traits::yes_type check_sig6(
|
||
|
U*,
|
||
|
test<
|
||
|
void *(*)(std::size_t, void*),
|
||
|
&U::operator new[]
|
||
|
>* = NULL
|
||
|
);
|
||
|
template<class U>
|
||
|
static type_traits::no_type check_sig6(...);
|
||
|
|
||
|
// GCC2 won't even parse this template if we embed the computation
|
||
|
// of s1 in the computation of value.
|
||
|
#ifdef __GNUC__
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s1 = sizeof(has_new_operator_impl<T>::template check_sig1<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s2 = sizeof(has_new_operator_impl<T>::template check_sig2<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s3 = sizeof(has_new_operator_impl<T>::template check_sig3<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s4 = sizeof(has_new_operator_impl<T>::template check_sig4<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s5 = sizeof(has_new_operator_impl<T>::template check_sig5<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s6 = sizeof(has_new_operator_impl<T>::template check_sig6<T>(0)));
|
||
|
#else
|
||
|
#if BOOST_WORKAROUND(BOOST_MSVC_FULL_VER, >= 140050000)
|
||
|
#pragma warning(push)
|
||
|
#pragma warning(disable:6334)
|
||
|
#endif
|
||
|
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s1 = sizeof(check_sig1<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s2 = sizeof(check_sig2<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s3 = sizeof(check_sig3<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s4 = sizeof(check_sig4<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s5 = sizeof(check_sig5<T>(0)));
|
||
|
BOOST_STATIC_CONSTANT(unsigned, s6 = sizeof(check_sig6<T>(0)));
|
||
|
|
||
|
#if BOOST_WORKAROUND(BOOST_MSVC_FULL_VER, >= 140050000)
|
||
|
#pragma warning(pop)
|
||
|
#endif
|
||
|
#endif
|
||
|
BOOST_STATIC_CONSTANT(bool, value =
|
||
|
(s1 == sizeof(type_traits::yes_type)) ||
|
||
|
(s2 == sizeof(type_traits::yes_type)) ||
|
||
|
(s3 == sizeof(type_traits::yes_type)) ||
|
||
|
(s4 == sizeof(type_traits::yes_type)) ||
|
||
|
(s5 == sizeof(type_traits::yes_type)) ||
|
||
|
(s6 == sizeof(type_traits::yes_type))
|
||
|
);
|
||
|
};
|
||
|
} // namespace detail
|
||
|
|
||
|
template <class T> struct has_new_operator : public integral_constant<bool, ::boost::detail::has_new_operator_impl<T>::value>{};
|
||
|
|
||
|
} // namespace boost
|
||
|
|
||
|
#if defined(BOOST_TT_AUX_MACRO_NEW_DEFINED)
|
||
|
# pragma pop_macro("new")
|
||
|
#endif
|
||
|
|
||
|
#endif // BOOST_TT_HAS_NEW_OPERATOR_HPP_INCLUDED
|