cereal
A C++11 library for serialization
|
A structure holding a map from type_indices to output serializer functions. More...
#include </build/libcereal-SAfJB3/libcereal-1.3.2+dfsg/include/cereal/details/polymorphic_impl.hpp>
Classes | |
struct | Serializers |
Struct containing the serializer functions for all pointer types. More... | |
Public Types | |
typedef std::function< void(void *, void const *, std::type_info const &)> | Serializer |
A serializer function. More... | |
Public Attributes | |
std::map< std::type_index, Serializers > | map |
A map of serializers for pointers of all registered types. | |
A structure holding a map from type_indices to output serializer functions.
A static object of this map should be created for each registered archive type, containing entries for every registered type that describe how to properly cast the type to its real type in polymorphic scenarios for shared_ptr, weak_ptr, and unique_ptr.
typedef std::function<void(void*, void const *, std::type_info const &)> cereal::detail::OutputBindingMap< Archive >::Serializer |
A serializer function.
Serializer functions return nothing and take an archive as their first parameter (will be cast properly inside the function, a pointer to actual data (contents of smart_ptr's get() function) as their second parameter, and the type info of the owning smart_ptr as their final parameter