diff options
author | Remko Tronçon <git@el-tramo.be> | 2009-06-01 08:48:42 (GMT) |
---|---|---|
committer | Remko Tronçon <git@el-tramo.be> | 2009-06-01 09:24:28 (GMT) |
commit | 2812bddd81f8a1b804c7460f4e14cd0aa393d129 (patch) | |
tree | d46294f35150c4f0f43deaf2d31fceaf945ae715 /3rdParty/Boost/boost/type_traits/msvc | |
download | swift-contrib-2812bddd81f8a1b804c7460f4e14cd0aa393d129.zip swift-contrib-2812bddd81f8a1b804c7460f4e14cd0aa393d129.tar.bz2 |
Import.
Diffstat (limited to '3rdParty/Boost/boost/type_traits/msvc')
9 files changed, 743 insertions, 0 deletions
diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_all_extents.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_all_extents.hpp new file mode 100644 index 0000000..3517132 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_all_extents.hpp @@ -0,0 +1,47 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_ALL_EXTENT_HOLT_2004_0827 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_ALL_EXTENT_HOLT_2004_0827 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_array.hpp> + +namespace boost { + template<typename T> + struct remove_all_extents; + + namespace detail { + template<bool IsArray> + struct remove_all_extents_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + }; + template<> + struct remove_all_extents_impl_typeof<true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U[]); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( *((T*)NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type reduced_type; + typedef typename remove_all_extents<reduced_type>::type type; + }; + }; + } //namespace detail + + template<typename T> + struct remove_all_extents { + typedef typename detail::remove_all_extents_impl_typeof< + boost::is_array<T>::value + >::template inner<T,remove_all_extents<T> >::type type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_all_extents,T) + }; +} //namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_BOUNDS_HOLT_2004_0827 + diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_bounds.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_bounds.hpp new file mode 100644 index 0000000..12a9b05 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_bounds.hpp @@ -0,0 +1,43 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_BOUNDS_HOLT_2004_0827 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_BOUNDS_HOLT_2004_0827 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_array.hpp> + +namespace boost { + namespace detail { + template<bool IsArray> + struct remove_bounds_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + }; + template<> + struct remove_bounds_impl_typeof<true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U[]); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( *((T*)NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + }; + } //namespace detail + + template<typename T> + struct remove_bounds { + typedef typename detail::remove_bounds_impl_typeof< + boost::is_array<T>::value + >::template inner<T,remove_bounds<T> >::type type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_bounds,T) + }; +} //namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_BOUNDS_HOLT_2004_0827 + diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_const.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_const.hpp new file mode 100644 index 0000000..5395e80 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_const.hpp @@ -0,0 +1,143 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_CONST_HOLT_2004_0828 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_CONST_HOLT_2004_0828 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_volatile.hpp> +#include <boost/type_traits/is_const.hpp> +#include <boost/type_traits/is_pointer.hpp> +#include <boost/type_traits/is_array.hpp> + +namespace boost { + namespace detail { + template<bool IsPointer,bool IsArray,bool IsConst,bool IsVolatile> + struct remove_const_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + template<> //Const + struct remove_const_impl_typeof<false,false,true,false> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U const&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //CV + struct remove_const_impl_typeof<false,false,true,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U volatile,ID> test(U const volatile&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //Const Pointer + struct remove_const_impl_typeof<true,false,true,false> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(void(*)(U const[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //CV Pointer + struct remove_const_impl_typeof<true,false,true,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U volatile,ID> test(void(*)(U const volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //Const Array + struct remove_const_impl_typeof<false,true,true,false> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U[value],ID> test(void(*)(U const[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + + template<> //CV Array + struct remove_const_impl_typeof<false,true,true,true> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U volatile[value],ID> test(void(*)(U const volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + + } //namespace detail + + template<typename T> + struct remove_const { + typedef detail::remove_const_impl_typeof< + boost::is_pointer<T>::value, + boost::is_array<T>::value, + boost::is_const<T>::value, + boost::is_volatile<T>::value + > remove_const_type; + typedef typename + remove_const_type::template inner< + typename remove_const_type::template transform_type<T>::type, + remove_const<T> + >::type + type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_const,T) + }; +}//namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_CONST_HOLT_2004_0828 diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_cv.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_cv.hpp new file mode 100644 index 0000000..c7b0379 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_cv.hpp @@ -0,0 +1,190 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_CV_HOLT_2004_0901 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_CV_HOLT_2004_0901 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_volatile.hpp> +#include <boost/type_traits/is_const.hpp> +#include <boost/type_traits/is_pointer.hpp> +#include <boost/type_traits/is_array.hpp> + +namespace boost { + namespace detail { + template<bool IsPointer,bool IsArray,bool IsConst,bool IsVolatile> + struct remove_cv_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + template<> //Volatile + struct remove_cv_impl_typeof<false,false,false,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U volatile&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //Const + struct remove_cv_impl_typeof<false,false,true,false> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U const&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //CV + struct remove_cv_impl_typeof<false,false,true,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U const volatile&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //Volatile Pointer + struct remove_cv_impl_typeof<true,false,false,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(void(*)(U volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //Const Pointer + struct remove_cv_impl_typeof<true,false,true,false> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(void(*)(U const[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //CV Pointer + struct remove_cv_impl_typeof<true,false,true,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(void(*)(U const volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //Volatile Array + struct remove_cv_impl_typeof<false,true,false,true> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U[value],ID> test(void(*)(U volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + template<> //Const Array + struct remove_cv_impl_typeof<false,true,true,false> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U[value],ID> test(void(*)(U const[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + + template<> //CV Array + struct remove_cv_impl_typeof<false,true,true,true> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U[value],ID> test(void(*)(U const volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + + } //namespace detail + + template<typename T> + struct remove_cv { + typedef detail::remove_cv_impl_typeof< + boost::is_pointer<T>::value, + boost::is_array<T>::value, + boost::is_const<T>::value, + boost::is_volatile<T>::value + > remove_cv_type; + typedef typename + remove_cv_type::template inner< + typename remove_cv_type::template transform_type<T>::type, + remove_cv<T> + >::type + type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_cv,T) + }; +}//namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_CV_HOLT_2004_0901 diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_extent.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_extent.hpp new file mode 100644 index 0000000..f87ec41 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_extent.hpp @@ -0,0 +1,43 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_EXTENT_HOLT_2004_0827 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_EXTENT_HOLT_2004_0827 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_array.hpp> + +namespace boost { + namespace detail { + template<bool IsArray> + struct remove_extent_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + }; + template<> + struct remove_extent_impl_typeof<true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U[]); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( *((T*)NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + }; + } //namespace detail + + template<typename T> + struct remove_extent { + typedef typename detail::remove_extent_impl_typeof< + boost::is_array<T>::value + >::template inner<T,remove_extent<T> >::type type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_extent,T) + }; +} //namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_BOUNDS_HOLT_2004_0827 + diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_pointer.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_pointer.hpp new file mode 100644 index 0000000..8b9b0d4 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_pointer.hpp @@ -0,0 +1,42 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_POINTER_HOLT_2004_0827 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_POINTER_HOLT_2004_0827 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_pointer.hpp> + +namespace boost { + namespace detail { + template<int IsPointer> + struct remove_pointer_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + }; + template<> + struct remove_pointer_impl_typeof<true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U*); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( *((T*)NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + }; + } //namespace detail + + template<typename T> + struct remove_pointer { + typedef typename detail::remove_pointer_impl_typeof< + boost::is_pointer<T>::value + >::template inner<T,remove_pointer<T> >::type type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_pointer,T) + }; +} //namespace boost + +#endif //BOOST_TYPE_TRAITS_REMOVE_POINTER_HOLT_2004_0827 diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_reference.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_reference.hpp new file mode 100644 index 0000000..367d352 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_reference.hpp @@ -0,0 +1,42 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_REFERENCE_HOLT_2004_0827 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_REFERENCE_HOLT_2004_0827 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_reference.hpp> + +namespace boost { + namespace detail { + template<bool IsReference> + struct remove_reference_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + }; + template<> + struct remove_reference_impl_typeof<true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + }; + } //namespace detail + + template<typename T> + struct remove_reference { + typedef typename detail::remove_reference_impl_typeof< + boost::is_reference<T>::value + >::template inner<T,remove_reference<T> >::type type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_reference,T) + }; +} //namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_REFERENCE_HOLT_2004_0827 diff --git a/3rdParty/Boost/boost/type_traits/msvc/remove_volatile.hpp b/3rdParty/Boost/boost/type_traits/msvc/remove_volatile.hpp new file mode 100644 index 0000000..3759f2a --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/remove_volatile.hpp @@ -0,0 +1,143 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPE_TRAITS_MSVC_REMOVE_VOLATILE_HOLT_2004_0828 +#define BOOST_TYPE_TRAITS_MSVC_REMOVE_VOLATILE_HOLT_2004_0828 + +#include <boost/type_traits/msvc/typeof.hpp> +#include <boost/type_traits/is_volatile.hpp> +#include <boost/type_traits/is_const.hpp> +#include <boost/type_traits/is_pointer.hpp> +#include <boost/type_traits/is_array.hpp> + +namespace boost { + namespace detail { + template<bool IsPointer,bool IsArray,bool IsConst,bool IsVolatile> + struct remove_volatile_impl_typeof { + template<typename T,typename ID> + struct inner { + typedef T type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + template<> //Volatile + struct remove_volatile_impl_typeof<false,false,false,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(U volatile&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //CV + struct remove_volatile_impl_typeof<false,false,true,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U const,ID> test(U const volatile&(*)()); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (T(*)())(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T& type; + }; + }; + template<> //Volatile Pointer + struct remove_volatile_impl_typeof<true,false,false,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U,ID> test(void(*)(U volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //CV Pointer + struct remove_volatile_impl_typeof<true,false,true,true> { + template<typename T,typename ID> + struct inner { + template<typename U> + static msvc_register_type<U const,ID> test(void(*)(U const volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type[]; + }; + }; + template<> //Volatile Array + struct remove_volatile_impl_typeof<false,true,false,true> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U[value],ID> test(void(*)(U volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + + template<> //CV Array + struct remove_volatile_impl_typeof<false,true,true,true> { + template<typename T,typename ID> + struct inner { + BOOST_STATIC_CONSTANT(unsigned,value=(sizeof(T)/sizeof((*((T*)NULL))[0]))); + + template<typename U> + static msvc_register_type<U const[value],ID> test(void(*)(U const volatile[])); + static msvc_register_type<T,ID> test(...); + BOOST_STATIC_CONSTANT(unsigned,register_test=sizeof(test( (void(*)(T))(NULL) ) )); + typedef typename msvc_extract_type<ID>::id2type::type type; + }; + template<typename T> + struct transform_type { + typedef T type; + }; + }; + + } //namespace detail + + template<typename T> + struct remove_volatile { + typedef detail::remove_volatile_impl_typeof< + boost::is_pointer<T>::value, + boost::is_array<T>::value, + boost::is_const<T>::value, + boost::is_volatile<T>::value + > remove_volatile_type; + typedef typename + remove_volatile_type::template inner< + typename remove_volatile_type::template transform_type<T>::type, + remove_volatile<T> + >::type + type; + BOOST_MPL_AUX_LAMBDA_SUPPORT(1,remove_volatile,T) + }; +}//namespace boost + +#endif //BOOST_TYPE_TRAITS_MSVC_REMOVE_VOLATILE_HOLT_2004_0828 diff --git a/3rdParty/Boost/boost/type_traits/msvc/typeof.hpp b/3rdParty/Boost/boost/type_traits/msvc/typeof.hpp new file mode 100644 index 0000000..ebb0e80 --- /dev/null +++ b/3rdParty/Boost/boost/type_traits/msvc/typeof.hpp @@ -0,0 +1,50 @@ +// Copyright (C) 2004 Peder Holt +// Use, modification and distribution is subject to the Boost Software +// License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) + +#ifndef BOOST_TYPETRAITS_MSVC_TYPEOF_HPP +#define BOOST_TYPETRAITS_MSVC_TYPEOF_HPP + +#include <boost/config.hpp> +#include <boost/detail/workaround.hpp> + +namespace boost { namespace detail { +# if BOOST_WORKAROUND(BOOST_MSVC,==1300) + template<typename ID> + struct msvc_extract_type + { + template<bool> + struct id2type_impl; + + typedef id2type_impl<true> id2type; + }; + + template<typename T, typename ID> + struct msvc_register_type : msvc_extract_type<ID> + { + template<> + struct id2type_impl<true> //VC7.0 specific bugfeature + { + typedef T type; + }; + }; +# else + template<typename ID> + struct msvc_extract_type + { + struct id2type; + }; + + template<typename T, typename ID> + struct msvc_register_type : msvc_extract_type<ID> + { + typedef msvc_extract_type<ID> base_type; + struct base_type::id2type // This uses nice VC6.5 and VC7.1 bugfeature + { + typedef T type; + }; + }; +# endif +}} + +#endif //BOOST_TYPETRAITS_MSVC_TYPEOF_IMPL_HPP |