peerplays-fc/include/fc/container/flat.hpp

147 lines
4.8 KiB
C++
Raw Normal View History

2015-02-23 14:06:04 +00:00
#pragma once
#include <fc/variant.hpp>
2015-02-23 19:01:58 +00:00
#include <fc/container/flat_fwd.hpp>
2015-02-23 14:06:04 +00:00
#include <boost/container/flat_map.hpp>
#include <boost/container/flat_set.hpp>
2015-02-23 19:01:58 +00:00
#include <fc/io/raw_fwd.hpp>
2015-02-23 14:06:04 +00:00
namespace fc {
namespace raw {
template<typename Stream, typename T>
inline void pack( Stream& s, const flat_set<T>& value, uint32_t _max_depth ) {
FC_ASSERT( _max_depth > 0 );
--_max_depth;
pack( s, unsigned_int((uint32_t)value.size()), _max_depth );
2015-02-23 14:06:04 +00:00
auto itr = value.begin();
auto end = value.end();
while( itr != end ) {
fc::raw::pack( s, *itr, _max_depth );
2015-02-23 14:06:04 +00:00
++itr;
}
}
template<typename Stream, typename T>
inline void unpack( Stream& s, flat_set<T>& value, uint32_t _max_depth ) {
FC_ASSERT( _max_depth > 0 );
--_max_depth;
unsigned_int size; unpack( s, size, _max_depth );
2015-02-23 14:06:04 +00:00
value.clear();
FC_ASSERT( size.value*sizeof(T) < MAX_ARRAY_ALLOC_SIZE );
value.reserve(size.value);
for( uint32_t i = 0; i < size.value; ++i )
{
T tmp;
fc::raw::unpack( s, tmp, _max_depth );
2015-02-23 14:06:04 +00:00
value.insert( std::move(tmp) );
}
}
2016-09-15 19:27:50 +00:00
template<typename Stream, typename K, typename... V>
inline void pack( Stream& s, const flat_map<K,V...>& value, uint32_t _max_depth ) {
FC_ASSERT( _max_depth > 0 );
--_max_depth;
pack( s, unsigned_int((uint32_t)value.size()), _max_depth );
2015-02-23 14:06:04 +00:00
auto itr = value.begin();
auto end = value.end();
while( itr != end ) {
fc::raw::pack( s, *itr, _max_depth );
2015-02-23 14:06:04 +00:00
++itr;
}
}
2016-09-15 19:27:50 +00:00
template<typename Stream, typename K, typename V, typename... A>
inline void unpack( Stream& s, flat_map<K,V,A...>& value, uint32_t _max_depth )
2015-02-23 14:06:04 +00:00
{
FC_ASSERT( _max_depth > 0 );
--_max_depth;
unsigned_int size; unpack( s, size, _max_depth );
2015-02-23 14:06:04 +00:00
value.clear();
FC_ASSERT( size.value*(sizeof(K)+sizeof(V)) < MAX_ARRAY_ALLOC_SIZE );
value.reserve(size.value);
for( uint32_t i = 0; i < size.value; ++i )
{
std::pair<K,V> tmp;
fc::raw::unpack( s, tmp, _max_depth );
2015-02-23 14:06:04 +00:00
value.insert( std::move(tmp) );
}
}
template<typename Stream, typename T, typename A>
void pack( Stream& s, const bip::vector<T,A>& value, uint32_t _max_depth ) {
FC_ASSERT( _max_depth > 0 );
--_max_depth;
pack( s, unsigned_int((uint32_t)value.size()), _max_depth );
if( !std::is_fundamental<T>::value ) {
auto itr = value.begin();
auto end = value.end();
while( itr != end ) {
fc::raw::pack( s, *itr, _max_depth );
++itr;
}
} else {
s.write( (const char*)value.data(), value.size() );
}
}
template<typename Stream, typename T, typename A>
void unpack( Stream& s, bip::vector<T,A>& value, uint32_t _max_depth ) {
FC_ASSERT( _max_depth > 0 );
--_max_depth;
unsigned_int size;
unpack( s, size, _max_depth );
value.resize( size );
if( !std::is_fundamental<T>::value ) {
for( auto& item : value )
unpack( s, item, _max_depth );
} else {
s.read( (char*)value.data(), value.size() );
}
}
2015-02-23 14:06:04 +00:00
} // namespace raw
template<typename T>
void to_variant( const flat_set<T>& var, variant& vo, uint32_t _max_depth )
2015-02-23 14:06:04 +00:00
{
FC_ASSERT( _max_depth > 0 );
--_max_depth;
2015-02-23 14:06:04 +00:00
std::vector<variant> vars(var.size());
size_t i = 0;
for( const auto& item : var )
vars[i++] = variant( item, _max_depth );
2015-02-23 14:06:04 +00:00
vo = vars;
}
template<typename T>
void from_variant( const variant& var, flat_set<T>& vo, uint32_t _max_depth )
2015-02-23 14:06:04 +00:00
{
FC_ASSERT( _max_depth > 0 );
--_max_depth;
2015-02-23 14:06:04 +00:00
const variants& vars = var.get_array();
vo.clear();
vo.reserve( vars.size() );
for( const auto& item : vars )
vo.insert( item.as<T>(_max_depth) );
2015-02-23 14:06:04 +00:00
}
2016-09-15 19:27:50 +00:00
template<typename K, typename... T>
void to_variant( const flat_map<K, T...>& var, variant& vo, uint32_t _max_depth )
2015-02-23 14:06:04 +00:00
{
FC_ASSERT( _max_depth > 0 );
--_max_depth;
2015-02-23 14:06:04 +00:00
std::vector< variant > vars(var.size());
size_t i = 0;
for( const auto& item : var )
vars[i++] = variant( item, _max_depth );
2015-02-23 14:06:04 +00:00
vo = vars;
}
2016-09-15 19:27:50 +00:00
template<typename K, typename T, typename... A>
void from_variant( const variant& var, flat_map<K, T, A...>& vo, uint32_t _max_depth )
2015-02-23 14:06:04 +00:00
{
FC_ASSERT( _max_depth > 0 );
--_max_depth;
2015-02-23 14:06:04 +00:00
const variants& vars = var.get_array();
vo.clear();
for( const auto& item : vars )
vo.insert( item.as<std::pair<K,T>>(_max_depth) );
2015-02-23 14:06:04 +00:00
}
}