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

Unified Diff: ppapi/cpp/private/net_address_private.cc

Issue 8511032: Make the Pepper Flash net address just private, not Flash-specific. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 years, 1 month 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: ppapi/cpp/private/net_address_private.cc
diff --git a/ppapi/cpp/private/net_address_private.cc b/ppapi/cpp/private/net_address_private.cc
new file mode 100644
index 0000000000000000000000000000000000000000..6b844da88cf2bb8d0cc9e1cdde5295f0c28c587c
--- /dev/null
+++ b/ppapi/cpp/private/net_address_private.cc
@@ -0,0 +1,77 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ppapi/cpp/private/net_address_private.h"
+
+#include "ppapi/c/pp_bool.h"
+#include "ppapi/cpp/module.h"
+#include "ppapi/cpp/module_impl.h"
+#include "ppapi/cpp/var.h"
+#include "ppapi/c/private/ppb_net_address_private.h"
+
+namespace pp {
+
+namespace {
+
+template <> const char* interface_name<PPB_NetAddress_Private>() {
+ return PPB_NETADDRESS_PRIVATE_INTERFACE;
+}
+
+} // namespace
+
+// static
+bool NetAddress::AreEqual(const PP_NetAddress_Private& addr1,
+ const PP_NetAddress_Private& addr2) {
+ if (!has_interface<PPB_NetAddress_Private>())
+ return false;
+ return !!get_interface<PPB_NetAddress_Private>()->AreEqual(&addr1, &addr2);
+}
+
+// static
+bool NetAddress::AreHostsEqual(const PP_NetAddress_Private& addr1,
+ const PP_NetAddress_Private& addr2) {
+ if (!has_interface<PPB_NetAddress_Private>())
+ return false;
+ return !!get_interface<PPB_NetAddress_Private>()->AreHostsEqual(&addr1,
+ &addr2);
+}
+
+// static
+std::string NetAddress::Describe(const PP_NetAddress_Private& addr,
+ bool include_port) {
+ if (!has_interface<PPB_NetAddress_Private>())
+ return std::string();
+
+ Module* module = Module::Get();
+ if (!module)
+ return std::string();
+
+ Var result(Var::PassRef(),
+ get_interface<PPB_NetAddress_Private>()->Describe(
+ module->pp_module(),
+ &addr,
+ PP_FromBool(include_port)));
+ return result.is_string() ? result.AsString() : std::string();
+}
+
+// static
+bool NetAddress::ReplacePort(const PP_NetAddress_Private& addr_in,
+ uint16_t port,
+ PP_NetAddress_Private* addr_out) {
+ if (!has_interface<PPB_NetAddress_Private>())
+ return false;
+ return !!get_interface<PPB_NetAddress_Private>()->ReplacePort(&addr_in,
+ port,
+ addr_out);
+}
+
+// static
+void NetAddress::GetAnyAddress(bool is_ipv6, PP_NetAddress_Private* addr) {
+ if (!has_interface<PPB_NetAddress_Private>())
+ return;
+ get_interface<PPB_NetAddress_Private>()->GetAnyAddress(PP_FromBool(is_ipv6),
+ addr);
+}
+
+} // namespace pp

Powered by Google App Engine
This is Rietveld 408576698