Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(862)

Unified Diff: remoting/host/chromoting_param_traits.cc

Issue 1853643007: Migrate remoting to net::IPAddress. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Added ParamTraits Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: remoting/host/chromoting_param_traits.cc
diff --git a/remoting/host/chromoting_param_traits.cc b/remoting/host/chromoting_param_traits.cc
index 89918aa8d2fb846ce0efdb819acc1e8e6213d32b..4a55274f5d8b5aff56be2f7bbf31f4327bffbbd2 100644
--- a/remoting/host/chromoting_param_traits.cc
+++ b/remoting/host/chromoting_param_traits.cc
@@ -7,6 +7,7 @@
#include <stdint.h>
#include "base/strings/stringprintf.h"
+#include "ipc/ipc_message_utils.h"
#include "third_party/webrtc/modules/desktop_capture/desktop_frame.h"
namespace IPC {
@@ -188,5 +189,56 @@ void ParamTraits<remoting::ScreenResolution>::Log(
p.dpi().x(), p.dpi().y()));
}
+// static
+void ParamTraits<net::IPAddress>::Write(base::Pickle* m, const param_type& p) {
+ WriteParam(m, p.bytes());
+}
+
+// static
+bool ParamTraits<net::IPAddress>::Read(const base::Pickle* m,
+ base::PickleIterator* iter,
+ param_type* p) {
+ std::vector<uint8_t> bytes;
+ if (!ReadParam(m, iter, &bytes))
+ return false;
+ if (bytes.size() && bytes.size() != net::IPAddress::kIPv4AddressSize &&
+ bytes.size() != net::IPAddress::kIPv6AddressSize) {
Wez 2016/04/05 17:08:01 This would be more readable as: if (bytes.empty()
martijnc 2016/04/05 20:08:48 Done.
+ return false;
+ }
+ *p = net::IPAddress(bytes);
+ return true;
+}
+
+// static
+void ParamTraits<net::IPAddress>::Log(const param_type& p, std::string* l) {
+ l->append("IPAddress:" + (p.empty() ? "(empty)" : p.ToString()));
+}
+
+// static
+void ParamTraits<net::IPEndPoint>::Write(base::Pickle* m, const param_type& p) {
+ WriteParam(m, p.address());
+ WriteParam(m, p.port());
+}
+
+// static
+bool ParamTraits<net::IPEndPoint>::Read(const base::Pickle* m,
+ base::PickleIterator* iter,
+ param_type* p) {
+ net::IPAddress address;
+ uint16_t port;
+ if (!ReadParam(m, iter, &address) || !ReadParam(m, iter, &port))
+ return false;
+ if (!address.empty() && !address.IsValid())
Wez 2016/04/05 17:08:01 Similarly, this is painful to parse; better to hav
martijnc 2016/04/05 20:08:48 Done. (the IPAddress should always be valid (or e
Wez 2016/04/05 20:12:27 The IPAddress ParamTraits doesn't seem to do an Is
martijnc 2016/04/05 21:16:29 Done.
+ return false;
+
+ *p = net::IPEndPoint(address, port);
+ return true;
+}
+
+// static
+void ParamTraits<net::IPEndPoint>::Log(const param_type& p, std::string* l) {
+ l->append("IPEndPoint: " + p.ToString());
+}
+
} // namespace IPC

Powered by Google App Engine
This is Rietveld 408576698