| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 | #ifndef BOOST_ARCHIVE_TEXT_OARCHIVE_HPP#define BOOST_ARCHIVE_TEXT_OARCHIVE_HPP// MS compatible compilers support #pragma once#if defined(_MSC_VER)# pragma once#endif/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8// text_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 <ostream>#include <cstddef> // std::size_t#include <boost/config.hpp>#if defined(BOOST_NO_STDC_NAMESPACE)namespace std{    using ::size_t;} // namespace std#endif#include <boost/archive/detail/auto_link_archive.hpp>#include <boost/archive/basic_text_oprimitive.hpp>#include <boost/archive/basic_text_oarchive.hpp>#include <boost/archive/detail/register_archive.hpp>#include <boost/serialization/item_version_type.hpp>#include <boost/archive/detail/abi_prefix.hpp> // must be the last header#ifdef BOOST_MSVC#  pragma warning(push)#  pragma warning(disable : 4511 4512)#endifnamespace boost {namespace archive {namespace detail {    template<class Archive> class interface_oarchive;} // namespace detailtemplate<class Archive>class BOOST_SYMBOL_VISIBLE text_oarchive_impl :     /* protected ? */ public basic_text_oprimitive<std::ostream>,     public basic_text_oarchive<Archive>{#ifdef BOOST_NO_MEMBER_TEMPLATE_FRIENDSpublic:#elseprotected:    friend class detail::interface_oarchive<Archive>;    friend class basic_text_oarchive<Archive>;    friend class save_access;#endif    template<class T>    void save(const T & t){        this->newtoken();        basic_text_oprimitive<std::ostream>::save(t);    }    void save(const version_type & t){        save(static_cast<unsigned int>(t));    }    void save(const boost::serialization::item_version_type & t){        save(static_cast<unsigned int>(t));    }    BOOST_ARCHIVE_DECL void    save(const char * t);    #ifndef BOOST_NO_INTRINSIC_WCHAR_T    BOOST_ARCHIVE_DECL void    save(const wchar_t * t);    #endif    BOOST_ARCHIVE_DECL void    save(const std::string &s);    #ifndef BOOST_NO_STD_WSTRING    BOOST_ARCHIVE_DECL void    save(const std::wstring &ws);    #endif    BOOST_ARCHIVE_DECL    text_oarchive_impl(std::ostream & os, unsigned int flags);    // don't import inline definitions! leave this as a reminder.    //BOOST_ARCHIVE_DECL    ~text_oarchive_impl(){};public:    BOOST_ARCHIVE_DECL void    save_binary(const void *address, std::size_t count);};// do not derive from this class.  If you want to extend this functionality// via inhertance, derived from text_oarchive_impl instead.  This will// preserve correct static polymorphism.class BOOST_SYMBOL_VISIBLE text_oarchive :    public text_oarchive_impl<text_oarchive>{public:    text_oarchive(std::ostream & os_, unsigned int flags = 0) :        // note: added _ to suppress useless gcc warning        text_oarchive_impl<text_oarchive>(os_, flags)    {        if(0 == (flags & no_header))            init();    }    ~text_oarchive(){}};} // namespace archive} // namespace boost// required by exportBOOST_SERIALIZATION_REGISTER_ARCHIVE(boost::archive::text_oarchive)#ifdef BOOST_MSVC#pragma warning(pop)#endif#include <boost/archive/detail/abi_suffix.hpp> // pops abi_suffix.hpp pragmas#endif // BOOST_ARCHIVE_TEXT_OARCHIVE_HPP
 |