Chris@16: #ifndef BOOST_SERIALIZATION_BASE_OBJECT_HPP Chris@16: #define BOOST_SERIALIZATION_BASE_OBJECT_HPP Chris@16: Chris@16: // MS compatible compilers support #pragma once Chris@101: #if defined(_MSC_VER) Chris@16: # pragma once Chris@16: #endif Chris@16: Chris@16: /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 Chris@16: // base_object.hpp: Chris@16: Chris@16: // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com . Chris@16: // Use, modification and distribution is subject to the Boost Software Chris@16: // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at Chris@16: // http://www.boost.org/LICENSE_1_0.txt) Chris@16: Chris@16: // See http://www.boost.org for updates, documentation, and revision history. Chris@16: Chris@16: // if no archive headers have been included this is a no op Chris@16: // this is to permit BOOST_EXPORT etc to be included in a Chris@16: // file declaration header Chris@16: Chris@16: #include Chris@16: #include Chris@16: Chris@16: #include Chris@16: #include Chris@16: #include Chris@16: #include Chris@16: Chris@16: #include Chris@16: #include Chris@16: #include Chris@16: #include Chris@16: Chris@16: #include Chris@16: #include Chris@16: #include Chris@16: #include Chris@16: Chris@16: namespace boost { Chris@16: namespace serialization { Chris@16: Chris@16: namespace detail Chris@16: { Chris@16: // get the base type for a given derived type Chris@16: // preserving the const-ness Chris@16: template Chris@16: struct base_cast Chris@16: { Chris@101: typedef typename Chris@16: mpl::if_< Chris@16: is_const, Chris@16: const B, Chris@16: B Chris@16: >::type type; Chris@16: BOOST_STATIC_ASSERT(is_const::value == is_const::value); Chris@16: }; Chris@16: Chris@16: // only register void casts if the types are polymorphic Chris@16: template Chris@16: struct base_register Chris@16: { Chris@16: struct polymorphic { Chris@16: static void const * invoke(){ Chris@16: Base const * const b = 0; Chris@16: Derived const * const d = 0; Chris@16: return & void_cast_register(d, b); Chris@16: } Chris@16: }; Chris@16: struct non_polymorphic { Chris@16: static void const * invoke(){ Chris@16: return 0; Chris@16: } Chris@16: }; Chris@16: static void const * invoke(){ Chris@101: typedef typename mpl::eval_if< Chris@16: is_polymorphic, Chris@16: mpl::identity, Chris@16: mpl::identity Chris@16: >::type type; Chris@16: return type::invoke(); Chris@16: } Chris@16: }; Chris@16: Chris@16: } // namespace detail Chris@16: #if defined(__BORLANDC__) && __BORLANDC__ < 0x610 Chris@16: template Chris@16: const Base & Chris@16: base_object(const Derived & d) Chris@16: { Chris@16: BOOST_STATIC_ASSERT(! is_pointer::value); Chris@16: detail::base_register::invoke(); Chris@16: return access::cast_reference(d); Chris@16: } Chris@16: #else Chris@16: template Chris@101: typename detail::base_cast::type & Chris@16: base_object(Derived &d) Chris@16: { Chris@16: BOOST_STATIC_ASSERT(( is_base_and_derived::value)); Chris@16: BOOST_STATIC_ASSERT(! is_pointer::value); Chris@101: typedef typename detail::base_cast::type type; Chris@16: detail::base_register::invoke(); Chris@16: return access::cast_reference(d); Chris@16: } Chris@16: #endif Chris@16: Chris@16: } // namespace serialization Chris@16: } // namespace boost Chris@16: Chris@16: #endif // BOOST_SERIALIZATION_BASE_OBJECT_HPP