Files
cereal/binary_archive/unordered_set.hpp
2013-06-14 13:47:52 -07:00

67 lines
1.6 KiB
C++

#ifndef CEREAL_BINARY_ARCHIVE_UNORDERED_SET_HPP_
#define CEREAL_BINARY_ARCHIVE_UNORDERED_SET_HPP_
#include <cereal/binary_archive/binary_archive.hpp>
#include <unordered_set>
namespace cereal
{
//! Saving for std::unordered_set to binary
template <class K, class H, class KE, class A>
void save( BinaryOutputArchive & ar, std::unordered_set<K, H, KE, A> const & unordered_set )
{
ar & unordered_set.size();
for( const auto & i : unordered_set )
ar & i;
}
//! Loading for std::unordered_set to binary
template <class K, class H, class KE, class A>
void load( BinaryInputArchive & ar, std::unordered_set<K, H, KE, A> & unordered_set )
{
size_t size;
ar & size;
unordered_set.reserve( size );
for( size_t i = 0; i < size; ++i )
{
K key;
ar & key;
unordered_set.insert( key );
}
}
//! Saving for std::unordered_multiset to binary
template <class K, class H, class KE, class A>
void save( BinaryOutputArchive & ar, std::unordered_multiset<K, H, KE, A> const & unordered_multiset )
{
ar & unordered_multiset.size();
for( const auto & i : unordered_multiset )
ar & i;
}
//! Loading for std::unordered_multiset to binary
template <class K, class H, class KE, class A>
void load( BinaryInputArchive & ar, std::unordered_multiset<K, H, KE, A> & unordered_multiset )
{
size_t size;
ar & size;
unordered_multiset.reserve( size );
for( size_t i = 0; i < size; ++i )
{
K key;
ar & key;
unordered_multiset.insert( key );
}
}
} // namespace cereal
#endif // CEREAL_BINARY_ARCHIVE_UNORDERED_SET_HPP_