| Index: third_party/boost/boost/type_traits/is_same.hpp
|
| diff --git a/third_party/boost/boost/type_traits/is_same.hpp b/third_party/boost/boost/type_traits/is_same.hpp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..e0d1808b4d1def169ed354091b095c9bf7a40cd8
|
| --- /dev/null
|
| +++ b/third_party/boost/boost/type_traits/is_same.hpp
|
| @@ -0,0 +1,103 @@
|
| +
|
| +// (C) Copyright Dave Abrahams, Steve Cleary, Beman Dawes,
|
| +// Howard Hinnant and John Maddock 2000.
|
| +// (C) Copyright Mat Marcus, Jesse Jones and Adobe Systems Inc 2001
|
| +
|
| +// 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.
|
| +
|
| +// Fixed is_pointer, is_reference, is_const, is_volatile, is_same,
|
| +// is_member_pointer based on the Simulated Partial Specialization work
|
| +// of Mat Marcus and Jesse Jones. See http://opensource.adobe.com or
|
| +// http://groups.yahoo.com/group/boost/message/5441
|
| +// Some workarounds in here use ideas suggested from "Generic<Programming>:
|
| +// Mappings between Types and Values"
|
| +// by Andrei Alexandrescu (see http://www.cuj.com/experts/1810/alexandr.html).
|
| +
|
| +
|
| +#ifndef BOOST_TT_IS_SAME_HPP_INCLUDED
|
| +#define BOOST_TT_IS_SAME_HPP_INCLUDED
|
| +
|
| +#include <boost/type_traits/config.hpp>
|
| +#ifdef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
| +#include <boost/type_traits/detail/yes_no_type.hpp>
|
| +#include <boost/type_traits/detail/ice_and.hpp>
|
| +#include <boost/type_traits/is_reference.hpp>
|
| +#endif
|
| +// should be the last #include
|
| +#include <boost/type_traits/detail/bool_trait_def.hpp>
|
| +
|
| +namespace boost {
|
| +
|
| +#ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
| +
|
| +BOOST_TT_AUX_BOOL_TRAIT_DEF2(is_same,T,U,false)
|
| +BOOST_TT_AUX_BOOL_TRAIT_PARTIAL_SPEC2_1(typename T,is_same,T,T,true)
|
| +#if BOOST_WORKAROUND(__BORLANDC__, < 0x600)
|
| +// without this, Borland's compiler gives the wrong answer for
|
| +// references to arrays:
|
| +BOOST_TT_AUX_BOOL_TRAIT_PARTIAL_SPEC2_1(typename T,is_same,T&,T&,true)
|
| +#endif
|
| +
|
| +#else // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
| +
|
| +namespace detail {
|
| +
|
| +#ifdef BOOST_MSVC
|
| +// the following VC6 specific implementation is *NOT* legal
|
| +// C++, but has the advantage that it works for incomplete
|
| +// types.
|
| +
|
| +template< typename T1 >
|
| +struct is_same_part_1
|
| +{
|
| + template<typename T2> struct part_2 { enum { value = false }; };
|
| + template<> struct part_2<T1> { enum { value = true }; };
|
| +};
|
| +
|
| +template< typename T1, typename T2 >
|
| +struct is_same_impl
|
| +{
|
| + enum { value = detail::is_same_part_1<T1>::template part_2<T2>::value };
|
| +};
|
| +
|
| +#else // generic "no-partial-specialization" version
|
| +
|
| +template <typename T>
|
| +::boost::type_traits::yes_type
|
| +BOOST_TT_DECL is_same_tester(T*, T*);
|
| +
|
| +::boost::type_traits::no_type
|
| +BOOST_TT_DECL is_same_tester(...);
|
| +
|
| +template <typename T, typename U>
|
| +struct is_same_impl
|
| +{
|
| + static T t;
|
| + static U u;
|
| +
|
| + BOOST_STATIC_CONSTANT(bool, value =
|
| + (::boost::type_traits::ice_and<
|
| + (sizeof(type_traits::yes_type) == sizeof(detail::is_same_tester(&t,&u))),
|
| + (::boost::is_reference<T>::value == ::boost::is_reference<U>::value),
|
| + (sizeof(T) == sizeof(U))
|
| + >::value));
|
| +};
|
| +
|
| +#endif // BOOST_MSVC
|
| +
|
| +} // namespace detail
|
| +
|
| +BOOST_TT_AUX_BOOL_TRAIT_DEF2(is_same,T,U,(::boost::detail::is_same_impl<T,U>::value))
|
| +
|
| +#endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
| +
|
| +} // namespace boost
|
| +
|
| +#include <boost/type_traits/detail/bool_trait_undef.hpp>
|
| +
|
| +#endif // BOOST_TT_IS_SAME_HPP_INCLUDED
|
| +
|
|
|