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
|