diff options
Diffstat (limited to '3rdParty/Boost/src/boost/serialization/smart_cast.hpp')
| -rw-r--r-- | 3rdParty/Boost/src/boost/serialization/smart_cast.hpp | 38 | 
1 files changed, 20 insertions, 18 deletions
| diff --git a/3rdParty/Boost/src/boost/serialization/smart_cast.hpp b/3rdParty/Boost/src/boost/serialization/smart_cast.hpp index c240a55..02edb4b 100644 --- a/3rdParty/Boost/src/boost/serialization/smart_cast.hpp +++ b/3rdParty/Boost/src/boost/serialization/smart_cast.hpp @@ -3,5 +3,5 @@  // MS compatible compilers support #pragma once -#if defined(_MSC_VER) && (_MSC_VER >= 1020) +#if defined(_MSC_VER)  # pragma once  #endif @@ -57,4 +57,6 @@  #include <boost/mpl/identity.hpp> +#include <boost/serialization/throw_exception.hpp> +  namespace boost {  namespace serialization { @@ -94,13 +96,13 @@ namespace smart_cast_impl {                      // not be the most efficient method. This will conflict with                      // the original smart_cast motivation. -                    typedef BOOST_DEDUCED_TYPENAME mpl::eval_if< -                            BOOST_DEDUCED_TYPENAME mpl::and_< +                    typedef typename mpl::eval_if< +                            typename mpl::and_<                                  mpl::not_<is_base_and_derived< -                                    BOOST_DEDUCED_TYPENAME remove_reference< T >::type, +                                    typename remove_reference< T >::type,                                      U                                  > >,                                  mpl::not_<is_base_and_derived<                                      U, -                                    BOOST_DEDUCED_TYPENAME remove_reference< T >::type +                                    typename remove_reference< T >::type                                  > >                              >, @@ -130,5 +132,5 @@ namespace smart_cast_impl {                  >::type::cast(u);              #else -                typedef BOOST_DEDUCED_TYPENAME mpl::eval_if< +                typedef typename mpl::eval_if<                      boost::is_polymorphic<U>,                      mpl::identity<polymorphic>, @@ -160,5 +162,5 @@ namespace smart_cast_impl {                      T tmp = dynamic_cast< T >(u);                      #ifndef NDEBUG -                        if ( tmp == 0 ) throw std::bad_cast(); +                        if ( tmp == 0 ) throw_exception(std::bad_cast());                      #endif                      return tmp; @@ -169,5 +171,5 @@ namespace smart_cast_impl {              static T cast(U * u){                  // if we're in debug mode -                #if ! defined(NDEBUG) || defined(__BORLANDC__) && (__BORLANDC__ <= 0x560) +                #if 0 //! defined(NDEBUG) || defined(__BORLANDC__) && (__BORLANDC__ <= 0x560)                      // do a checked dynamic cast                      return cross::cast(u); @@ -179,13 +181,13 @@ namespace smart_cast_impl {                      // the original smart_cast motivation.                      typedef -                        BOOST_DEDUCED_TYPENAME mpl::eval_if< -                            BOOST_DEDUCED_TYPENAME mpl::and_< +                        typename mpl::eval_if< +                            typename mpl::and_<                                  mpl::not_<is_base_and_derived< -                                    BOOST_DEDUCED_TYPENAME remove_pointer< T >::type, +                                    typename remove_pointer< T >::type,                                      U                                  > >,                                  mpl::not_<is_base_and_derived<                                      U, -                                    BOOST_DEDUCED_TYPENAME remove_pointer< T >::type +                                    typename remove_pointer< T >::type                                  > >                              >, @@ -202,5 +204,5 @@ namespace smart_cast_impl {                  T tmp = dynamic_cast< T >(u);                  #ifndef NDEBUG -                    if ( tmp == 0 ) throw std::bad_cast(); +                    if ( tmp == 0 ) throw_exception(std::bad_cast());                  #endif                  return tmp; @@ -225,5 +227,5 @@ namespace smart_cast_impl {                  >::type::cast(u);              #else -                typedef BOOST_DEDUCED_TYPENAME mpl::eval_if< +                typedef typename mpl::eval_if<                      boost::is_polymorphic<U>,                      mpl::identity<polymorphic>, @@ -266,6 +268,6 @@ template<class T, class U>  T smart_cast(U u) {      typedef -        BOOST_DEDUCED_TYPENAME mpl::eval_if< -            BOOST_DEDUCED_TYPENAME mpl::or_< +        typename mpl::eval_if< +            typename mpl::or_<                  boost::is_same<void *, U>,                  boost::is_same<void *, T>, @@ -275,8 +277,8 @@ T smart_cast(U u) {              mpl::identity<smart_cast_impl::void_pointer< T > >,          // else -        BOOST_DEDUCED_TYPENAME mpl::eval_if<boost::is_pointer<U>, +        typename mpl::eval_if<boost::is_pointer<U>,              mpl::identity<smart_cast_impl::pointer< T > >,          // else -        BOOST_DEDUCED_TYPENAME mpl::eval_if<boost::is_reference<U>, +        typename mpl::eval_if<boost::is_reference<U>,              mpl::identity<smart_cast_impl::reference< T > >,          // else | 
 Swift
 Swift