1 #ifndef BOOST_ARCHIVE_BASIC_ARCHIVE_HPP
2 #define BOOST_ARCHIVE_BASIC_ARCHIVE_HPP
4 // MS compatible compilers support #pragma once
9 /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8
12 // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com .
13 // Use, modification and distribution is subject to the Boost Software
14 // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
15 // http://www.boost.org/LICENSE_1_0.txt)
17 // See http://www.boost.org for updates, documentation, and revision history.
18 #include <cstring> // count
19 #include <boost/assert.hpp>
20 #include <boost/config.hpp>
21 #include <boost/cstdint.hpp> // size_t
22 #include <boost/noncopyable.hpp>
23 #include <boost/integer_traits.hpp>
25 #include <boost/archive/detail/auto_link_archive.hpp>
26 #include <boost/archive/detail/abi_prefix.hpp> // must be the last header
32 #pragma warning( push )
33 #pragma warning( disable : 4244 4267 )
36 /* NOTE : Warning : Warning : Warning : Warning : Warning
37 * Don't ever changes this. If you do, they previously created
38 * binary archives won't be readable !!!
40 class library_version_type {
42 typedef uint_least16_t base_type;
45 library_version_type(): t(0) {};
46 explicit library_version_type(const unsigned int & t_) : t(t_){
47 BOOST_ASSERT(t_ <= boost::integer_traits<base_type>::const_max);
49 library_version_type(const library_version_type & t_) :
52 library_version_type & operator=(const library_version_type & rhs){
56 // used for text output
57 operator base_type () const {
60 // used for text input
61 operator base_type & (){
64 bool operator==(const library_version_type & rhs) const {
67 bool operator<(const library_version_type & rhs) const {
72 BOOST_ARCHIVE_DECL library_version_type
73 BOOST_ARCHIVE_VERSION();
77 typedef uint_least32_t base_type;
80 // should be private - but MPI fails if it's not!!!
81 version_type(): t(0) {};
82 explicit version_type(const unsigned int & t_) : t(t_){
83 BOOST_ASSERT(t_ <= boost::integer_traits<base_type>::const_max);
85 version_type(const version_type & t_) :
88 version_type & operator=(const version_type & rhs){
92 // used for text output
93 operator base_type () const {
96 // used for text intput
97 operator base_type & (){
100 bool operator==(const version_type & rhs) const {
103 bool operator<(const version_type & rhs) const {
108 class class_id_type {
110 typedef int_least16_t base_type;
113 // should be private - but then can't use BOOST_STRONG_TYPE below
114 class_id_type() : t(0) {};
115 explicit class_id_type(const int t_) : t(t_){
116 BOOST_ASSERT(t_ <= boost::integer_traits<base_type>::const_max);
118 explicit class_id_type(const std::size_t t_) : t(t_){
119 // BOOST_ASSERT(t_ <= boost::integer_traits<base_type>::const_max);
121 class_id_type(const class_id_type & t_) :
124 class_id_type & operator=(const class_id_type & rhs){
129 // used for text output
130 operator int () const {
133 // used for text input
134 operator int_least16_t &() {
137 bool operator==(const class_id_type & rhs) const {
140 bool operator<(const class_id_type & rhs) const {
145 #define NULL_POINTER_TAG boost::archive::class_id_type(-1)
147 class object_id_type {
149 typedef uint_least32_t base_type;
152 object_id_type(): t(0) {};
153 // note: presumes that size_t >= unsigned int.
154 explicit object_id_type(const std::size_t & t_) : t(t_){
155 BOOST_ASSERT(t_ <= boost::integer_traits<base_type>::const_max);
157 object_id_type(const object_id_type & t_) :
160 object_id_type & operator=(const object_id_type & rhs){
164 // used for text output
165 operator uint_least32_t () const {
168 // used for text input
169 operator uint_least32_t & () {
172 bool operator==(const object_id_type & rhs) const {
175 bool operator<(const object_id_type & rhs) const {
180 #if defined(_MSC_VER)
181 #pragma warning( pop )
184 struct tracking_type {
186 explicit tracking_type(const bool t_ = false)
189 tracking_type(const tracking_type & t_)
192 operator bool () const {
198 tracking_type & operator=(const bool t_){
202 bool operator==(const tracking_type & rhs) const {
205 bool operator==(const bool & rhs) const {
208 tracking_type & operator=(const tracking_type & rhs){
214 struct class_name_type :
215 private boost::noncopyable
218 operator const char * & () const {
219 return const_cast<const char * &>(t);
224 std::size_t size() const {
225 return std::strlen(t);
227 explicit class_name_type(const char *key_)
228 : t(const_cast<char *>(key_)){}
229 explicit class_name_type(char *key_)
231 class_name_type & operator=(const class_name_type & rhs){
238 no_header = 1, // suppress archive header info
239 no_codecvt = 2, // suppress alteration of codecvt facet
240 no_xml_tag_checking = 4, // suppress checking of xml tags
241 no_tracking = 8, // suppress ALL tracking
245 BOOST_ARCHIVE_DECL const char *
246 BOOST_ARCHIVE_SIGNATURE();
248 /* NOTE : Warning : Warning : Warning : Warning : Warning
249 * If any of these are changed to different sized types,
250 * binary_iarchive won't be able to read older archives
251 * unless you rev the library version and include conditional
252 * code based on the library version. There is nothing
253 * inherently wrong in doing this - but you have to be super
254 * careful because it's easy to get wrong and start breaking
258 #define BOOST_ARCHIVE_STRONG_TYPEDEF(T, D) \
259 class D : public T { \
261 explicit D(const T tt) : T(tt){} \
265 BOOST_ARCHIVE_STRONG_TYPEDEF(class_id_type, class_id_reference_type)
266 BOOST_ARCHIVE_STRONG_TYPEDEF(class_id_type, class_id_optional_type)
267 BOOST_ARCHIVE_STRONG_TYPEDEF(object_id_type, object_reference_type)
269 }// namespace archive
272 #include <boost/archive/detail/abi_suffix.hpp> // pops abi_suffix.hpp pragmas
274 #include <boost/serialization/level.hpp>
276 // set implementation level to primitive for all types
277 // used internally by the serialization library
279 BOOST_CLASS_IMPLEMENTATION(boost::archive::library_version_type, primitive_type)
280 BOOST_CLASS_IMPLEMENTATION(boost::archive::version_type, primitive_type)
281 BOOST_CLASS_IMPLEMENTATION(boost::archive::class_id_type, primitive_type)
282 BOOST_CLASS_IMPLEMENTATION(boost::archive::class_id_reference_type, primitive_type)
283 BOOST_CLASS_IMPLEMENTATION(boost::archive::class_id_optional_type, primitive_type)
284 BOOST_CLASS_IMPLEMENTATION(boost::archive::class_name_type, primitive_type)
285 BOOST_CLASS_IMPLEMENTATION(boost::archive::object_id_type, primitive_type)
286 BOOST_CLASS_IMPLEMENTATION(boost::archive::object_reference_type, primitive_type)
287 BOOST_CLASS_IMPLEMENTATION(boost::archive::tracking_type, primitive_type)
289 #include <boost/serialization/is_bitwise_serializable.hpp>
291 // set types used internally by the serialization library
292 // to be bitwise serializable
294 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::library_version_type)
295 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::version_type)
296 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::class_id_type)
297 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::class_id_reference_type)
298 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::class_id_optional_type)
299 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::class_name_type)
300 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::object_id_type)
301 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::object_reference_type)
302 BOOST_IS_BITWISE_SERIALIZABLE(boost::archive::tracking_type)
304 #endif //BOOST_ARCHIVE_BASIC_ARCHIVE_HPP