x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
basic_binary_iprimitive.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\archive\basic_binary_iprimitive.hpp
旋转
特效
属性
历史版本
#ifndef BOOST_ARCHIVE_BINARY_IPRIMITIVE_HPP #define BOOST_ARCHIVE_BINARY_IPRIMITIVE_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 // basic_binary_iprimitive.hpp // // archives stored as native binary - this should be the fastest way // to archive the state of a group of obects. It makes no attempt to // convert to any canonical form. // IN GENERAL, ARCHIVES CREATED WITH THIS CLASS WILL NOT BE READABLE // ON PLATFORM APART FROM THE ONE THEY ARE CREATED ON // (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
// std::memcpy #include
// std::size_t #include
// basic_streambuf #include
#include
#if defined(BOOST_NO_STDC_NAMESPACE) namespace std{ using ::memcpy; using ::size_t; } // namespace std #endif #include
#include
#include
//#include
//#include
#include
#include
#include
#include
#include
#include
#include
// must be the last header namespace boost { namespace archive { ///////////////////////////////////////////////////////////////////////////// // class binary_iarchive - read serialized objects from a input binary stream template
class basic_binary_iprimitive { #ifndef BOOST_NO_MEMBER_TEMPLATE_FRIENDS friend class load_access; protected: #else public: #endif std::basic_streambuf
& m_sb; // return a pointer to the most derived class Archive * This(){ return static_cast
(this); } boost::scoped_ptr
archive_locale; basic_streambuf_locale_saver
locale_saver; // main template for serilization of primitive types template
void load(T & t){ load_binary(& t, sizeof(T)); } ///////////////////////////////////////////////////////// // fundamental types that need special treatment // trap usage of invalid uninitialized boolean void load(bool & t){ load_binary(& t, sizeof(t)); int i = t; assert(0 == i || 1 == i); (void)i; // warning suppression for release builds. } BOOST_ARCHIVE_OR_WARCHIVE_DECL(void) load(std::string &s); #ifndef BOOST_NO_STD_WSTRING BOOST_ARCHIVE_OR_WARCHIVE_DECL(void) load(std::wstring &ws); #endif BOOST_ARCHIVE_OR_WARCHIVE_DECL(void) load(char * t); BOOST_ARCHIVE_OR_WARCHIVE_DECL(void) load(wchar_t * t); BOOST_ARCHIVE_OR_WARCHIVE_DECL(void) init(); BOOST_ARCHIVE_OR_WARCHIVE_DECL(BOOST_PP_EMPTY()) basic_binary_iprimitive( std::basic_streambuf
& sb, bool no_codecvt ); BOOST_ARCHIVE_OR_WARCHIVE_DECL(BOOST_PP_EMPTY()) ~basic_binary_iprimitive(); public: // we provide an optimized load for all fundamental types //typedef serialization::is_bitwise_serializable
// use_array_optimization; struct use_array_optimization { template
struct apply : public serialization::is_bitwise_serializable
{}; }; // the optimized load_array dispatches to load_binary template
void load_array(serialization::array
& a, unsigned int) { load_binary(a.address(),a.count()*sizeof(ValueType)); } void load_binary(void *address, std::size_t count); }; template
inline void basic_binary_iprimitive
::load_binary( void *address, std::size_t count ){ #if 0 assert( static_cast
((std::numeric_limits
::max)()) >= count ); //if(is.fail()) // boost::throw_exception(archive_exception(archive_exception::stream_error)); // note: an optimizer should eliminate the following for char files std::size_t s = count / sizeof(BOOST_DEDUCED_TYPENAME IStream::char_type); is.read( static_cast
(address), s ); // note: an optimizer should eliminate the following for char files s = count % sizeof(BOOST_DEDUCED_TYPENAME IStream::char_type); if(0 < s){ if(is.fail()) boost::throw_exception(archive_exception(archive_exception::stream_error)); BOOST_DEDUCED_TYPENAME IStream::char_type t; is.read(& t, 1); std::memcpy(address, &t, s); } #endif // note: an optimizer should eliminate the following for char files std::streamsize s = count / sizeof(Elem); std::streamsize scount = m_sb.sgetn( static_cast
(address), s ); if(scount != static_cast
(s)) boost::throw_exception( archive_exception(archive_exception::stream_error) ); // note: an optimizer should eliminate the following for char files s = count % sizeof(Elem); if(0 < s){ // if(is.fail()) // boost::throw_exception(archive_exception(archive_exception::stream_error)); Elem t; scount = m_sb.sgetn(& t, 1); if(scount != 1) boost::throw_exception( archive_exception(archive_exception::stream_error) ); std::memcpy(address, &t, s); } } } // namespace archive } // namespace boost #include
// pop pragams #endif // BOOST_ARCHIVE_BINARY_IPRIMITIVE_HPP
basic_binary_iprimitive.hpp
网页地址
文件地址
上一页
5/46
下一页
下载
( 6 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.