x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
oserializer.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\archive\detail\oserializer.hpp
旋转
特效
属性
历史版本
#ifndef BOOST_ARCHIVE_OSERIALIZER_HPP #define BOOST_ARCHIVE_OSERIALIZER_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) && (_MSC_VER >= 1020) # pragma once #pragma inline_depth(511) #pragma inline_recursion(on) #endif #if defined(__MWERKS__) #pragma inline_depth(511) #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // oserializer.hpp: interface for serialization system. // (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
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#ifndef BOOST_SERIALIZATION_DEFAULT_TYPE_INFO #include
#endif // the following is need only for dynamic cast of polymorphic pointers #include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
namespace boost { namespace serialization { class extended_type_info; } // namespace serialization namespace archive { // an accessor to permit friend access to archives. Needed because // some compilers don't handle friend templates completely class save_access { public: template
static void end_preamble(Archive & ar){ ar.end_preamble(); } template
static void save_primitive(Archive & ar, const T & t){ ar.end_preamble(); ar.save(t); } }; namespace detail { template
class oserializer : public basic_oserializer { private: // private constructor to inhibit any existence other than the // static one explicit BOOST_DLLEXPORT oserializer() : basic_oserializer( * boost::serialization::type_info_implementation
::type::get_instance() ) {} public: virtual BOOST_DLLEXPORT void save_object_data( basic_oarchive & ar, const void *x ) const BOOST_USED ; virtual bool class_info() const { return boost::serialization::implementation_level
::value >= boost::serialization::object_class_info; } virtual bool tracking(const unsigned int /* flags */) const { // if(0 != (flags & no_tracking)) // return false; return boost::serialization::tracking_level
::value == boost::serialization::track_always || boost::serialization::tracking_level
::value == boost::serialization::track_selectively && serialized_as_pointer(); } virtual unsigned int version() const { return ::boost::serialization::version
::value; } virtual bool is_polymorphic() const { typedef BOOST_DEDUCED_TYPENAME boost::serialization::type_info_implementation< T >::type::is_polymorphic::type typex; return typex::value; } static oserializer & get_instance(){ static oserializer instance; return instance; } virtual ~oserializer(){} }; template
BOOST_DLLEXPORT void oserializer
::save_object_data( basic_oarchive & ar, const void *x ) const { // make sure call is routed through the highest interface that might // be specialized by the user. boost::serialization::serialize_adl( boost::smart_cast_reference
(ar), * static_cast
(const_cast
(x)), version() ); } template
class pointer_oserializer : public archive_pointer_oserializer
, public dynamically_initialized
> { private: virtual const basic_oserializer & get_basic_serializer() const { return oserializer
::get_instance(); } virtual BOOST_DLLEXPORT void save_object_ptr( basic_oarchive & ar, const void * x ) const BOOST_USED ; #if defined(__GNUC__) || ( defined(BOOST_MSVC) && (_MSC_VER <= 1300) ) public: #endif // private constructor to inhibit any existence other than the // static one. Note GCC doesn't permit constructor to be private explicit BOOST_DLLEXPORT pointer_oserializer() BOOST_USED; friend struct dynamically_initialized
>; public: #if !defined(__BORLANDC__) // at least one compiler (CW) seems to require that serialize_adl // be explicitly instantiated. Still under investigation. void (* const m)(Archive &, T &, const unsigned); boost::serialization::extended_type_info * (* e)(); #endif BOOST_DLLEXPORT static const pointer_oserializer & get_instance() BOOST_USED; }; template
BOOST_DLLEXPORT void pointer_oserializer
::save_object_ptr( basic_oarchive & ar, const void * x ) const { assert(NULL != x); // make sure call is routed through the highest interface that might // be specialized by the user. T * t = static_cast
(const_cast
(x)); const unsigned int file_version = boost::serialization::version
::value; Archive & ar_impl = boost::smart_cast_reference
(ar); boost::serialization::save_construct_data_adl
( ar_impl, t, file_version ); ar_impl << boost::serialization::make_nvp(NULL, * t); } template
#if !defined(__BORLANDC__) BOOST_DLLEXPORT pointer_oserializer
::pointer_oserializer() : archive_pointer_oserializer
( * boost::serialization::type_info_implementation
::type::get_instance() ), m(boost::serialization::serialize_adl
), e(boost::serialization::type_info_implementation
::type::get_instance) #else BOOST_DLLEXPORT pointer_oserializer
::pointer_oserializer() : archive_pointer_oserializer
( * boost::serialization::type_info_implementation
::type::get_instance() ) #endif { // make sure appropriate member function is instantiated oserializer
& bos = oserializer
::get_instance(); bos.set_bpos(this); } template
BOOST_DLLEXPORT const pointer_oserializer
& pointer_oserializer
::get_instance() { // note: comeau complains without full qualification return dynamically_initialized
>::instance; } template
struct save_non_pointer_type { // note this bounces the call right back to the archive // with no runtime overhead struct save_primitive { static void invoke(Archive & ar, const T & t){ save_access::save_primitive(ar, t); } }; // same as above but passes through serialization struct save_only { static void invoke(Archive & ar, const T & t){ // make sure call is routed through the highest interface that might // be specialized by the user. boost::serialization::serialize_adl( ar, const_cast
(t), ::boost::serialization::version
::value ); } }; // adds class information to the archive. This includes // serialization level and class version struct save_standard { static void invoke(Archive &ar, const T & t){ ar.save_object(& t, oserializer
::get_instance()); } }; // adds class information to the archive. This includes // serialization level and class version struct save_conditional { static void invoke(Archive &ar, const T &t){ //if(0 == (ar.get_flags() & no_tracking)) save_standard::invoke(ar, t); //else // save_only::invoke(ar, t); } }; typedef BOOST_DEDUCED_TYPENAME mpl::eval_if< // if its primitive mpl::equal_to< boost::serialization::implementation_level
, mpl::int_
>, mpl::identity
, // else BOOST_DEDUCED_TYPENAME mpl::eval_if< // class info / version mpl::greater_equal< boost::serialization::implementation_level
, mpl::int_
>, // do standard save mpl::identity
, // else BOOST_DEDUCED_TYPENAME mpl::eval_if< // no tracking mpl::equal_to< boost::serialization::tracking_level
, mpl::int_
>, // do a fast save mpl::identity
, // else // do a fast save only tracking is turned off mpl::identity
> > >::type typex; static void invoke(Archive & ar, const T & t){ // check that we're not trying to serialize something that // has been marked not to be serialized. If this your program // traps here, you've tried to serialize a class whose trait // has been marked "non-serializable". Either reset the trait // (see level.hpp) or change program not to serialize items of this class BOOST_STATIC_ASSERT(( mpl::greater_equal< boost::serialization::implementation_level
, mpl::int_
>::value )); typex::invoke(ar, t); }; }; template
struct save_pointer_type { template
struct abstract { static const basic_pointer_oserializer * register_type(Archive & /* ar */){ // it has? to be polymorphic BOOST_STATIC_ASSERT( boost::serialization::type_info_implementation
::type::is_polymorphic::value ); return static_cast
(NULL); } }; template
struct non_abstract { static const basic_pointer_oserializer * register_type(Archive & ar){ return ar.register_type(static_cast
(NULL)); } }; template
static const basic_pointer_oserializer * register_type(Archive &ar, T & /*t*/){ // there should never be any need to save an abstract polymorphic // class pointer. Inhibiting code generation for this // permits abstract base classes to be used - note: exception // virtual serialize functions used for plug-ins typedef BOOST_DEDUCED_TYPENAME mpl::eval_if< serialization::is_abstract
, mpl::identity
>, mpl::identity
> >::type typex; return typex::register_type(ar); } template
struct non_polymorphic { static void save( Archive &ar, const T & t, const basic_pointer_oserializer * bpos_ptr ){ // save the requested pointer type ar.save_pointer(& t, bpos_ptr); } }; template
struct polymorphic { static void save( Archive &ar, const T & t, const basic_pointer_oserializer * bpos_ptr ){ const boost::serialization::extended_type_info * this_type = boost::serialization::type_info_implementation
::type::get_instance(); // retrieve the true type of the object pointed to // if this assertion fails its an error in this library assert(NULL != this_type); const boost::serialization::extended_type_info * true_type = boost::serialization::type_info_implementation
::type::get_derived_extended_type_info(t); // note:if this exception is thrown, be sure that derived pointer // is either regsitered or exported. if(NULL == true_type){ boost::throw_exception( archive_exception(archive_exception::unregistered_class) ); } // if its not a pointer to a more derived type const void *vp = static_cast
(&t); if(*this_type == *true_type){ ar.save_pointer(vp, bpos_ptr); return; } // convert pointer to more derived type. if this is thrown // it means that the base/derived relationship hasn't be registered vp = serialization::void_downcast(*true_type, *this_type, &t); if(NULL == vp){ boost::throw_exception( archive_exception(archive_exception::unregistered_cast) ); } // sice true_type is valid, and this only gets made if the // pointer oserializer object has been created, this should never // fail bpos_ptr = archive_pointer_oserializer
::find(* true_type); assert(NULL != bpos_ptr); if(NULL == bpos_ptr) boost::throw_exception( archive_exception(archive_exception::unregistered_class) ); ar.save_pointer(vp, bpos_ptr); } }; template
static void save( Archive & ar, const T &t, const basic_pointer_oserializer * bpos_ptr ){ typedef BOOST_DEDUCED_TYPENAME mpl::eval_if< BOOST_DEDUCED_TYPENAME boost::serialization:: type_info_implementation
::type::is_polymorphic, mpl::identity
>, mpl::identity
> >::type typey; typey::save(ar, const_cast
(t), bpos_ptr); } template
static void const_check(T & t){ BOOST_STATIC_ASSERT(! boost::is_const
::value); } static void invoke(Archive &ar, const TPtr t){ #ifdef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION // if your program traps here, its because you tried to do // something like ar << t where t is a pointer to a const value // void f3(A const* a, text_oarchive& oa) // { // oa << a; // } // with a compiler which doesn't support remove_const // const_check(* t); #else // otherwise remove the const #endif const basic_pointer_oserializer * bpos_ptr = register_type(ar, * t); if(NULL == t){ basic_oarchive & boa = boost::smart_cast_reference
(ar); boa.save_null_pointer(); save_access::end_preamble(ar); return; } save(ar, * t, bpos_ptr); }; }; template
struct save_enum_type { static void invoke(Archive &ar, const T &t){ // convert enum to integers on save const int i = static_cast
(t); ar << boost::serialization::make_nvp(NULL, i); } }; template
struct save_array_type { static void invoke(Archive &ar, const T &t){ typedef typename remove_all_extents
::type value_type; save_access::end_preamble(ar); // consider alignment int count = sizeof(t) / ( static_cast
(static_cast
(&t[1])) - static_cast
(static_cast
(&t[0])) ); ar << BOOST_SERIALIZATION_NVP(count); ar << serialization::make_array(static_cast
(&t[0]),count); } }; #if 0 // note bogus arguments to workaround msvc 6 silent runtime failure // declaration to satisfy gcc template
BOOST_DLLEXPORT const basic_pointer_oserializer & instantiate_pointer_oserializer( Archive * /* ar = NULL */, T * /* t = NULL */ ) BOOST_USED ; // definition template
BOOST_DLLEXPORT const basic_pointer_oserializer & instantiate_pointer_oserializer( Archive * /* ar = NULL */, T * /* t = NULL */ ){ return pointer_oserializer
::instance; } #endif } // detail template
inline void save(Archive & ar, const T &t){ typedef BOOST_DEDUCED_TYPENAME mpl::eval_if
, mpl::identity
>, //else BOOST_DEDUCED_TYPENAME mpl::eval_if
, mpl::identity
>, //else BOOST_DEDUCED_TYPENAME mpl::eval_if
, mpl::identity
>, //else mpl::identity
> > > >::type typex; typex::invoke(ar, t); } #ifndef BOOST_NO_FUNCTION_TEMPLATE_ORDERING template
struct check_tracking { typedef BOOST_DEDUCED_TYPENAME mpl::if_< // if its never tracked. BOOST_DEDUCED_TYPENAME mpl::equal_to< serialization::tracking_level
, mpl::int_
>, // it better not be a pointer mpl::not_
>, //else // otherwise if it might be tracked. So there shouldn't // be any problem making a const is_const
>::type typex; BOOST_STATIC_CONSTANT(bool, value = typex::value); }; template
inline void save(Archive & ar, T &t){ // if your program traps here, it indicates that your doing one of the following: // a) serializing an object of a type marked "track_never" through a pointer. // b) saving an non-const object of a type not markd "track_never) // Either of these conditions may be an indicator of an error usage of the // serialization library and should be double checked. See documentation on // object tracking. Also, see the "rationale" section of the documenation // for motivation for this checking. BOOST_STATIC_ASSERT(check_tracking
::value); save(ar, const_cast
(t)); } #endif } // namespace archive } // namespace boost #endif // BOOST_ARCHIVE_OSERIALIZER_HPP
oserializer.hpp
网页地址
文件地址
上一页
24/28
下一页
下载
( 20 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.