Index: ipc/ipc_message_utils.cc |
diff --git a/ipc/ipc_message_utils.cc b/ipc/ipc_message_utils.cc |
index 60c12ab60f96f879259612c993acf89d0c749cd0..098b02262aeadf59b0ec87e91830af9536457d9e 100644 |
--- a/ipc/ipc_message_utils.cc |
+++ b/ipc/ipc_message_utils.cc |
@@ -9,6 +9,7 @@ |
#include "base/files/file_path.h" |
#include "base/json/json_writer.h" |
+#include "base/nonce.h" |
#include "base/strings/nullable_string16.h" |
#include "base/strings/string_number_conversions.h" |
#include "base/strings/utf_string_conversions.h" |
@@ -998,6 +999,33 @@ void ParamTraits<base::TimeTicks>::Log(const param_type& p, std::string* l) { |
ParamTraits<int64_t>::Log(p.ToInternalValue(), l); |
} |
+void ParamTraits<base::Nonce>::GetSize(base::PickleSizer* sizer, |
+ const param_type& p) { |
+ sizer->AddBytes(2 * sizeof(uint64_t)); |
+} |
+ |
+void ParamTraits<base::Nonce>::Write(base::Pickle* m, const param_type& p) { |
+ ParamTraits<int64_t>::Write(m, p.high()); |
Fady Samuel
2016/09/13 20:28:44
uint64_t?
tguilbert
2016/09/13 21:11:44
Oops! You are right, TY. Done.
|
+ ParamTraits<int64_t>::Write(m, p.low()); |
+} |
+ |
+bool ParamTraits<base::Nonce>::Read(const base::Pickle* m, |
+ base::PickleIterator* iter, |
+ param_type* r) { |
+ int64_t high; |
+ int64_t low; |
+ if (!ParamTraits<int64_t>::Read(m, iter, &high) || |
Fady Samuel
2016/09/13 20:28:44
Shouldn't this be uint64_t?
tguilbert
2016/09/13 21:11:44
Done.
|
+ !ParamTraits<int64_t>::Read(m, iter, &low)) |
+ return false; |
+ |
+ *r = base::Nonce::Deserialize(high, low); |
+ return true; |
+} |
+ |
+void ParamTraits<base::Nonce>::Log(const param_type& p, std::string* l) { |
+ l->append(p.ToString()); |
+} |
+ |
void ParamTraits<IPC::ChannelHandle>::GetSize(base::PickleSizer* sizer, |
const param_type& p) { |
GetParamSize(sizer, p.name); |