#ifndef BOOST_ARCHIVE_DETAIL_INTERFACE_OARCHIVE_HPP #define BOOST_ARCHIVE_DETAIL_INTERFACE_OARCHIVE_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) && (_MSC_VER >= 1020) # pragma once #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // interface_oarchive.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 #include #include #include // must be the last header namespace boost { template class shared_ptr; namespace serialization { class extended_type_info; } // namespace serialization namespace archive { namespace detail { class BOOST_ARCHIVE_OR_WARCHIVE_DECL(BOOST_PP_EMPTY()) basic_pointer_oserializer; template class interface_oarchive { protected: interface_oarchive(){}; public: ///////////////////////////////////////////////////////// // archive public interface typedef mpl::bool_ is_loading; typedef mpl::bool_ is_saving; // return a pointer to the most derived class Archive * This(){ return static_cast(this); } template const basic_pointer_oserializer * register_type(const T * = NULL){ const basic_pointer_oserializer & bpos = pointer_oserializer::get_instance(); this->This()->register_basic_serializer(bpos.get_basic_serializer()); return & bpos; } template Archive & operator<<(T & t){ this->This()->save_override(t, 0); return * this->This(); } // the & operator template Archive & operator&(T & t){ #ifndef BOOST_NO_FUNCTION_TEMPLATE_ORDERING return * this->This() << const_cast(t); #else return * this->This() << t; #endif } }; } // namespace detail } // namespace archive } // namespace boost #include // pops abi_suffix.hpp pragmas #endif // BOOST_ARCHIVE_DETAIL_INTERFACE_IARCHIVE_HPP