aboutsummaryrefslogtreecommitdiff
path: root/src/serialization/serialization.h
diff options
context:
space:
mode:
authorRiccardo Spagni <ric@spagni.net>2016-10-04 11:27:38 +0200
committerRiccardo Spagni <ric@spagni.net>2016-10-04 11:27:38 +0200
commit2ef81914b5528a3d37df4d74806d75aa326b1993 (patch)
tree27e6366dd8e30f7ac3ade7b7863c588f66aa5826 /src/serialization/serialization.h
parentMerge pull request #1159 (diff)
parentwallet: cold wallet transaction signing (diff)
downloadmonero-2ef81914b5528a3d37df4d74806d75aa326b1993.tar.xz
Merge pull request #1140
bba6af9 wallet: cold wallet transaction signing (moneromooo-monero) 9872dcb wallet: fix log confusion between bytes and kilobytes (moneromooo-monero) d9b0bf9 cryptonote_core: make extra field removal more generic (moneromooo-monero) 98f19d4 serialization: add support for serializing std::pair and std::list (moneromooo-monero)
Diffstat (limited to 'src/serialization/serialization.h')
-rw-r--r--src/serialization/serialization.h27
1 files changed, 23 insertions, 4 deletions
diff --git a/src/serialization/serialization.h b/src/serialization/serialization.h
index 177cdf33a..dac43720b 100644
--- a/src/serialization/serialization.h
+++ b/src/serialization/serialization.h
@@ -41,6 +41,7 @@
#pragma once
#include <vector>
+#include <list>
#include <string>
#include <boost/type_traits/is_integral.hpp>
#include <boost/type_traits/integral_constant.hpp>
@@ -59,6 +60,16 @@ struct is_blob_type { typedef boost::false_type type; };
template <class T>
struct has_free_serializer { typedef boost::true_type type; };
+/*! \struct is_pair_type
+ *
+ * \brief a descriptor for dispatching serialize
+ */
+template <class T>
+struct is_pair_type { typedef boost::false_type type; };
+
+template<typename F, typename S>
+struct is_pair_type<std::pair<F,S>> { typedef boost::true_type type; };
+
/*! \struct serializer
*
* \brief ... wouldn't a class be better?
@@ -75,20 +86,26 @@ struct has_free_serializer { typedef boost::true_type type; };
template <class Archive, class T>
struct serializer{
static bool serialize(Archive &ar, T &v) {
- return serialize(ar, v, typename boost::is_integral<T>::type(), typename is_blob_type<T>::type());
+ return serialize(ar, v, typename boost::is_integral<T>::type(), typename is_blob_type<T>::type(), typename is_pair_type<T>::type());
}
- static bool serialize(Archive &ar, T &v, boost::false_type, boost::true_type) {
+ template<typename A>
+ static bool serialize(Archive &ar, T &v, boost::false_type, boost::true_type, A a) {
ar.serialize_blob(&v, sizeof(v));
return true;
}
- static bool serialize(Archive &ar, T &v, boost::true_type, boost::false_type) {
+ template<typename A>
+ static bool serialize(Archive &ar, T &v, boost::true_type, boost::false_type, A a) {
ar.serialize_int(v);
return true;
}
- static bool serialize(Archive &ar, T &v, boost::false_type, boost::false_type) {
+ static bool serialize(Archive &ar, T &v, boost::false_type, boost::false_type, boost::false_type) {
//serialize_custom(ar, v, typename has_free_serializer<T>::type());
return v.do_serialize(ar);
}
+ static bool serialize(Archive &ar, T &v, boost::false_type, boost::false_type, boost::true_type) {
+ //serialize_custom(ar, v, typename has_free_serializer<T>::type());
+ return do_serialize(ar, v);
+ }
static void serialize_custom(Archive &ar, T &v, boost::true_type) {
}
};
@@ -328,3 +345,5 @@ namespace serialization {
#include "string.h"
#include "vector.h"
+#include "list.h"
+#include "pair.h"