mirror of
https://github.com/USCiLab/cereal.git
synced 2025-10-18 01:45:52 +02:00
67 lines
1.6 KiB
C++
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_
|