⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 polymorphic_oarchive_impl.hpp

📁 CGAL is a collaborative effort of several sites in Europe and Israel. The goal is to make the most i
💻 HPP
字号:
#ifndef BOOST_ARCHIVE_DETAIL_POLYMORPHIC_OARCHIVE_IMPL_HPP#define BOOST_ARCHIVE_DETAIL_POLYMORPHIC_OARCHIVE_IMPL_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// polymorphic_oarchive_impl.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 <string>#include <ostream>#include <boost/noncopyable.hpp>#include <boost/cstdint.hpp>#include <cstddef> // size_t#include <boost/config.hpp>#if defined(BOOST_NO_STDC_NAMESPACE)namespace std{     using ::size_t; } // namespace std#endif#include <boost/archive/polymorphic_oarchive.hpp>namespace boost { namespace archive {namespace detail{class basic_oserializer;class basic_pointer_oserializer;template<class ArchiveImplementation>class polymorphic_oarchive_impl :     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 boost::noncopyable{private:    // these are used by the serialization library.    virtual void save_object(        const void *x,         const detail::basic_oserializer & bos    ){        ArchiveImplementation::save_object(x, bos);    }    virtual void save_pointer(        const void * t,         const detail::basic_pointer_oserializer * bpos_ptr    ){        ArchiveImplementation::save_pointer(t, bpos_ptr);    }    virtual void save_null_pointer(){        ArchiveImplementation::save_null_pointer();    }    // primitive types the only ones permitted by polymorphic archives    virtual void save(const bool t){        ArchiveImplementation::save(t);    }    virtual void save(const char t){        ArchiveImplementation::save(t);    }    virtual void save(const signed char t){        ArchiveImplementation::save(t);    }    virtual void save(const unsigned char t){        ArchiveImplementation::save(t);    }    #ifndef BOOST_NO_CWCHAR    #ifndef BOOST_NO_INTRINSIC_WCHAR_T    virtual void save(const wchar_t t){        ArchiveImplementation::save(t);    }    #endif    #endif    virtual void save(const short t){        ArchiveImplementation::save(t);    }    virtual void save(const unsigned short t){        ArchiveImplementation::save(t);    }    virtual void save(const int t){        ArchiveImplementation::save(t);    }    virtual void save(const unsigned int t){        ArchiveImplementation::save(t);    }    virtual void save(const long t){        ArchiveImplementation::save(t);    }    virtual void save(const unsigned long t){        ArchiveImplementation::save(t);    }    #if !defined(BOOST_NO_INTRINSIC_INT64_T)    virtual void save(const boost::int64_t t){        ArchiveImplementation::save(t);    }    virtual void save(const boost::uint64_t t){        ArchiveImplementation::save(t);    }    #endif    virtual void save(const float t){        ArchiveImplementation::save(t);    }    virtual void save(const double t){        ArchiveImplementation::save(t);    }    virtual void save(const std::string & t){        ArchiveImplementation::save(t);    }    #ifndef BOOST_NO_STD_WSTRING    virtual void save(const std::wstring & t){        ArchiveImplementation::save(t);    }    #endif    virtual unsigned int library_version() const{        return ArchiveImplementation::library_version();    }    virtual void save_binary(const void * t, std::size_t size){        ArchiveImplementation::save(t);    }    // used for xml and other tagged formats default does nothing    virtual void save_start(const char * name){        ArchiveImplementation::save_start(name);    }    virtual void save_end(const char * name){        ArchiveImplementation::save_end(name);    }    virtual void end_preamble(){        ArchiveImplementation::end_preamble();    }    virtual void register_basic_serializer(const detail::basic_oserializer & bos){        ArchiveImplementation::register_basic_serializer(bos);    }public:    // to avoie ambiguities when using this class directly, trap an pass one    // to the implemenation these operations.    // note: we presume that older compilers will never create a const    // argument from a non-const by copyiing    template<class T>    polymorphic_oarchive & operator<<(const T & t){        return polymorphic_oarchive::operator<<(t);    }    // the & operator     template<class T>    polymorphic_oarchive & operator&(const T & t){        return polymorphic_oarchive::operator&(t);    }    // define operators for non-const arguments.  Don't depend one the const    // ones below because the compiler MAY make a temporary copy to    // create the const parameter (Though I havn't seen this happen).     #ifndef BOOST_NO_FUNCTION_TEMPLATE_ORDERING        // the << operator        template<class T>        polymorphic_oarchive & operator<<(T & t){            // if trap here, we're saving a tracted non-const            // value - this could be a stack variable with the same            // address for multiple items. This would be the source of very             // subtle errors and should be double checked            // BOOST_STATIC_WARNING(            //     serialization::tracking_level == serialization::track_never            // );            return polymorphic_oarchive::operator<<(t);        }        // the & operator         template<class T>        polymorphic_oarchive & operator&(T & t){            return polymorphic_oarchive::operator&(t);        }    #endif    // all current archives take a stream as constructor argument    template <class _Elem, class _Tr>    polymorphic_oarchive_impl(        std::basic_ostream<_Elem, _Tr> & os,         unsigned int flags = 0    ) :        ArchiveImplementation(os, flags | no_header)    {        // postpone archive initialization until build is complete        if(0 == (flags & no_header))            ArchiveImplementation::init();    }};} // namespace detail} // namespace archive} // namespace boost#endif // BOOST_ARCHIVE_DETAIL_POLYMORPHIC_OARCHIVE_IMPL_HPP

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -