#ifndef BOOST_ARCHIVE_DETAIL_POLYMORPHIC_OARCHIVE_ROUTE_HPP #define BOOST_ARCHIVE_DETAIL_POLYMORPHIC_OARCHIVE_ROUTE_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) # pragma once #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // polymorphic_oarchive_route.hpp // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com . // Use, modification and distribution is 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 for updates, documentation, and revision history. #include #include #include // size_t #include #if defined(BOOST_NO_STDC_NAMESPACE) namespace std{ using ::size_t; } // namespace std #endif #include #include #include #include // must be the last header namespace boost { namespace serialization { class extended_type_info; } // namespace serialization namespace archive { namespace detail{ class basic_oserializer; class basic_pointer_oserializer; #ifdef BOOST_MSVC # pragma warning(push) # pragma warning(disable : 4511 4512) #endif template class polymorphic_oarchive_route : public polymorphic_oarchive, // note: gcc dynamic cross cast fails if the the derivation below is // not public. I think this is a mistake. public /*protected*/ ArchiveImplementation { private: // these are used by the serialization library. void save_object( const void *x, const detail::basic_oserializer & bos ) BOOST_OVERRIDE { ArchiveImplementation::save_object(x, bos); } void save_pointer( const void * t, const detail::basic_pointer_oserializer * bpos_ptr ) BOOST_OVERRIDE { ArchiveImplementation::save_pointer(t, bpos_ptr); } void save_null_pointer() BOOST_OVERRIDE { ArchiveImplementation::save_null_pointer(); } // primitive types the only ones permitted by polymorphic archives void save(const bool t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const char t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const signed char t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const unsigned char t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #ifndef BOOST_NO_CWCHAR #ifndef BOOST_NO_INTRINSIC_WCHAR_T void save(const wchar_t t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #endif #endif void save(const short t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const unsigned short t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const int t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const unsigned int t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const long t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const unsigned long t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #if defined(BOOST_HAS_LONG_LONG) void save(const boost::long_long_type t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const boost::ulong_long_type t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #elif defined(BOOST_HAS_MS_INT64) void save(const boost::int64_t t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const boost::uint64_t t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #endif void save(const float t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const double t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } void save(const std::string & t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #ifndef BOOST_NO_STD_WSTRING void save(const std::wstring & t) BOOST_OVERRIDE { ArchiveImplementation::save(t); } #endif boost::serialization::library_version_type get_library_version() const BOOST_OVERRIDE { return ArchiveImplementation::get_library_version(); } unsigned int get_flags() const BOOST_OVERRIDE { return ArchiveImplementation::get_flags(); } void save_binary(const void * t, std::size_t size) BOOST_OVERRIDE { ArchiveImplementation::save_binary(t, size); } // used for xml and other tagged formats default does nothing void save_start(const char * name) BOOST_OVERRIDE { ArchiveImplementation::save_start(name); } void save_end(const char * name) BOOST_OVERRIDE { ArchiveImplementation::save_end(name); } void end_preamble() BOOST_OVERRIDE { ArchiveImplementation::end_preamble(); } void register_basic_serializer(const detail::basic_oserializer & bos) BOOST_OVERRIDE { ArchiveImplementation::register_basic_serializer(bos); } helper_collection & get_helper_collection() BOOST_OVERRIDE { return ArchiveImplementation::get_helper_collection(); } public: // this can't be inherited because they appear in multiple // parents typedef mpl::bool_ is_loading; typedef mpl::bool_ is_saving; // the << operator template polymorphic_oarchive & operator<<(T & t){ return polymorphic_oarchive::operator<<(t); } // the & operator template polymorphic_oarchive & operator&(T & t){ return polymorphic_oarchive::operator&(t); } // register type function template const basic_pointer_oserializer * register_type(T * t = NULL){ return ArchiveImplementation::register_type(t); } // all current archives take a stream as constructor argument template polymorphic_oarchive_route( std::basic_ostream<_Elem, _Tr> & os, unsigned int flags = 0 ) : ArchiveImplementation(os, flags) {} ~polymorphic_oarchive_route() BOOST_OVERRIDE {} }; } // namespace detail } // namespace archive } // namespace boost #ifdef BOOST_MSVC #pragma warning(pop) #endif #include // pops abi_suffix.hpp pragmas #endif // BOOST_ARCHIVE_DETAIL_POLYMORPHIC_OARCHIVE_DISPATCH_HPP