76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
								 | 
							
								// (C) Copyright 2005 Matthias Troyer
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// 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)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								//  Authors: Matthias Troyer
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef BOOST_MPI_DETAIL_MPI_DATATYPE_OARCHIVE_HPP
							 | 
						||
| 
								 | 
							
								#define BOOST_MPI_DETAIL_MPI_DATATYPE_OARCHIVE_HPP
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <boost/type_traits/is_enum.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/mpl/bool.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/archive/detail/oserializer.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/archive/detail/auto_link_archive.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/archive/basic_archive.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/mpi/detail/ignore_skeleton_oarchive.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/mpi/detail/mpi_datatype_primitive.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/mpi/datatype_fwd.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/mpl/assert.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/static_assert.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/integer.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/archive/detail/register_archive.hpp>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace boost { namespace mpi { namespace detail {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// an archive wrapper that stores only the data members but not the
							 | 
						||
| 
								 | 
							
								// special types defined by the serialization library
							 | 
						||
| 
								 | 
							
								// to define the data skeletons (classes, pointers, container sizes, ...)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class mpi_datatype_oarchive
							 | 
						||
| 
								 | 
							
								  : public mpi_datatype_primitive,
							 | 
						||
| 
								 | 
							
								    public ignore_skeleton_oarchive<mpi_datatype_oarchive>
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								public:
							 | 
						||
| 
								 | 
							
								    template <class T>
							 | 
						||
| 
								 | 
							
								    mpi_datatype_oarchive(const T& x)
							 | 
						||
| 
								 | 
							
								         :  mpi_datatype_primitive(&x) // register address
							 | 
						||
| 
								 | 
							
								        {
							 | 
						||
| 
								 | 
							
								          BOOST_MPL_ASSERT((is_mpi_datatype<T>));
							 | 
						||
| 
								 | 
							
								          *this << x;                   // serialize the object
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    template<class T>
							 | 
						||
| 
								 | 
							
								    void save_override(T const& t)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								      save_enum(t,boost::is_enum<T>());
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    template<class T>
							 | 
						||
| 
								 | 
							
								    void save_enum(T const& t, mpl::false_)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								      ignore_skeleton_oarchive<mpi_datatype_oarchive>::save_override(t);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    template<class T>
							 | 
						||
| 
								 | 
							
								    void save_enum(T const& t, mpl::true_)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								      // select the right sized integer for the enum
							 | 
						||
| 
								 | 
							
								      typedef typename boost::uint_t<8*sizeof(T)>::least int_type;
							 | 
						||
| 
								 | 
							
								      BOOST_STATIC_ASSERT((sizeof(T)==sizeof(int_type)));
							 | 
						||
| 
								 | 
							
								      this->save(*reinterpret_cast<int_type const*>(&t));
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								} } } // end namespace boost::mpi::detail
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// required by export
							 | 
						||
| 
								 | 
							
								BOOST_SERIALIZATION_REGISTER_ARCHIVE(boost::mpi::detail::mpi_datatype_oarchive)
							 | 
						||
| 
								 | 
							
								BOOST_SERIALIZATION_REGISTER_ARCHIVE(boost::mpi::detail::ignore_skeleton_oarchive<boost::mpi::detail::mpi_datatype_oarchive>)
							 | 
						||
| 
								 | 
							
								BOOST_SERIALIZATION_USE_ARRAY_OPTIMIZATION(boost::mpi::detail::mpi_datatype_oarchive)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif // BOOST_MPI_DETAIL_MPI_DATATYPE_OARCHIVE_HPP
							 |