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

Unified Diff: runtime/bin/socket.h

Issue 2797993005: Re-land socket refactor with fixes for Windows. (Closed)
Patch Set: Rebased + reverted original revert Created 3 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
« no previous file with comments | « runtime/bin/process_win.cc ('k') | runtime/bin/socket.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/bin/socket.h
diff --git a/runtime/bin/socket.h b/runtime/bin/socket.h
index a34fd73585921e228659da9b65137bb819e5d183..29edee9005217c3a53c9066dfde0d8ea5f89991d 100644
--- a/runtime/bin/socket.h
+++ b/runtime/bin/socket.h
@@ -9,25 +9,10 @@
#error "socket.h can only be included on builds with IO enabled"
#endif
-#include "platform/globals.h"
-// Declare the OS-specific types ahead of defining the generic class.
-#if defined(HOST_OS_ANDROID)
-#include "bin/socket_android.h"
-#elif defined(HOST_OS_FUCHSIA)
-#include "bin/socket_fuchsia.h"
-#elif defined(HOST_OS_LINUX)
-#include "bin/socket_linux.h"
-#elif defined(HOST_OS_MACOS)
-#include "bin/socket_macos.h"
-#elif defined(HOST_OS_WINDOWS)
-#include "bin/socket_win.h"
-#else
-#error Unknown target os.
-#endif
-
#include "bin/builtin.h"
#include "bin/dartutils.h"
#include "bin/reference_counting.h"
+#include "bin/socket_base.h"
#include "bin/thread.h"
#include "bin/utils.h"
#include "platform/hashmap.h"
@@ -35,218 +20,8 @@
namespace dart {
namespace bin {
-union RawAddr {
- struct sockaddr_in in;
- struct sockaddr_in6 in6;
- struct sockaddr_storage ss;
- struct sockaddr addr;
-};
-
-class SocketAddress {
- public:
- enum {
- TYPE_ANY = -1,
- TYPE_IPV4,
- TYPE_IPV6,
- };
-
- enum {
- ADDRESS_LOOPBACK_IP_V4,
- ADDRESS_LOOPBACK_IP_V6,
- ADDRESS_ANY_IP_V4,
- ADDRESS_ANY_IP_V6,
- ADDRESS_FIRST = ADDRESS_LOOPBACK_IP_V4,
- ADDRESS_LAST = ADDRESS_ANY_IP_V6,
- };
-
- explicit SocketAddress(struct sockaddr* sa);
-
- ~SocketAddress() {}
-
- int GetType() {
- if (addr_.ss.ss_family == AF_INET6) {
- return TYPE_IPV6;
- }
- return TYPE_IPV4;
- }
-
- const char* as_string() const { return as_string_; }
- const RawAddr& addr() const { return addr_; }
-
- static intptr_t GetAddrLength(const RawAddr& addr) {
- ASSERT((addr.ss.ss_family == AF_INET) || (addr.ss.ss_family == AF_INET6));
- return (addr.ss.ss_family == AF_INET6) ? sizeof(struct sockaddr_in6)
- : sizeof(struct sockaddr_in);
- }
-
- static intptr_t GetInAddrLength(const RawAddr& addr) {
- ASSERT((addr.ss.ss_family == AF_INET) || (addr.ss.ss_family == AF_INET6));
- return (addr.ss.ss_family == AF_INET6) ? sizeof(struct in6_addr)
- : sizeof(struct in_addr);
- }
-
- static bool AreAddressesEqual(const RawAddr& a, const RawAddr& b) {
- if (a.ss.ss_family == AF_INET) {
- if (b.ss.ss_family != AF_INET) {
- return false;
- }
- return memcmp(&a.in.sin_addr, &b.in.sin_addr, sizeof(a.in.sin_addr)) == 0;
- } else if (a.ss.ss_family == AF_INET6) {
- if (b.ss.ss_family != AF_INET6) {
- return false;
- }
- return memcmp(&a.in6.sin6_addr, &b.in6.sin6_addr,
- sizeof(a.in6.sin6_addr)) == 0;
- } else {
- UNREACHABLE();
- return false;
- }
- }
-
- static void GetSockAddr(Dart_Handle obj, RawAddr* addr) {
- Dart_TypedData_Type data_type;
- uint8_t* data = NULL;
- intptr_t len;
- Dart_Handle result = Dart_TypedDataAcquireData(
- obj, &data_type, reinterpret_cast<void**>(&data), &len);
- if (Dart_IsError(result)) {
- Dart_PropagateError(result);
- }
- if ((data_type != Dart_TypedData_kUint8) ||
- ((len != sizeof(in_addr)) && (len != sizeof(in6_addr)))) {
- Dart_PropagateError(
- Dart_NewApiError("Unexpected type for socket address"));
- }
- memset(reinterpret_cast<void*>(addr), 0, sizeof(RawAddr));
- if (len == sizeof(in_addr)) {
- addr->in.sin_family = AF_INET;
- memmove(reinterpret_cast<void*>(&addr->in.sin_addr), data, len);
- } else {
- ASSERT(len == sizeof(in6_addr));
- addr->in6.sin6_family = AF_INET6;
- memmove(reinterpret_cast<void*>(&addr->in6.sin6_addr), data, len);
- }
- Dart_TypedDataReleaseData(obj);
- }
-
- static int16_t FromType(int type) {
- if (type == TYPE_ANY) {
- return AF_UNSPEC;
- }
- if (type == TYPE_IPV4) {
- return AF_INET;
- }
- ASSERT((type == TYPE_IPV6) && "Invalid type");
- return AF_INET6;
- }
-
- static void SetAddrPort(RawAddr* addr, intptr_t port) {
- if (addr->ss.ss_family == AF_INET) {
- addr->in.sin_port = htons(port);
- } else {
- addr->in6.sin6_port = htons(port);
- }
- }
-
- static intptr_t GetAddrPort(const RawAddr& addr) {
- if (addr.ss.ss_family == AF_INET) {
- return ntohs(addr.in.sin_port);
- } else {
- return ntohs(addr.in6.sin6_port);
- }
- }
-
- static Dart_Handle ToTypedData(const RawAddr& addr) {
- int len = GetInAddrLength(addr);
- Dart_Handle result = Dart_NewTypedData(Dart_TypedData_kUint8, len);
- if (Dart_IsError(result)) {
- Dart_PropagateError(result);
- }
- Dart_Handle err;
- if (addr.addr.sa_family == AF_INET6) {
- err = Dart_ListSetAsBytes(
- result, 0, reinterpret_cast<const uint8_t*>(&addr.in6.sin6_addr),
- len);
- } else {
- err = Dart_ListSetAsBytes(
- result, 0, reinterpret_cast<const uint8_t*>(&addr.in.sin_addr), len);
- }
- if (Dart_IsError(err)) {
- Dart_PropagateError(err);
- }
- return result;
- }
-
- static CObjectUint8Array* ToCObject(const RawAddr& addr) {
- int in_addr_len = SocketAddress::GetInAddrLength(addr);
- const void* in_addr;
- CObjectUint8Array* data =
- new CObjectUint8Array(CObject::NewUint8Array(in_addr_len));
- if (addr.addr.sa_family == AF_INET6) {
- in_addr = reinterpret_cast<const void*>(&addr.in6.sin6_addr);
- } else {
- in_addr = reinterpret_cast<const void*>(&addr.in.sin_addr);
- }
- memmove(data->Buffer(), in_addr, in_addr_len);
- return data;
- }
-
- private:
- char as_string_[INET6_ADDRSTRLEN];
- RawAddr addr_;
-
- DISALLOW_COPY_AND_ASSIGN(SocketAddress);
-};
-
-
-class InterfaceSocketAddress {
- public:
- InterfaceSocketAddress(struct sockaddr* sa,
- const char* interface_name,
- intptr_t interface_index)
- : socket_address_(new SocketAddress(sa)),
- interface_name_(interface_name),
- interface_index_(interface_index) {}
-
- ~InterfaceSocketAddress() { delete socket_address_; }
-
- SocketAddress* socket_address() const { return socket_address_; }
- const char* interface_name() const { return interface_name_; }
- int interface_index() const { return interface_index_; }
-
- private:
- SocketAddress* socket_address_;
- const char* interface_name_;
- intptr_t interface_index_;
-
- DISALLOW_COPY_AND_ASSIGN(InterfaceSocketAddress);
-};
-
-
-template <typename T>
-class AddressList {
- public:
- explicit AddressList(intptr_t count)
- : count_(count), addresses_(new T*[count_]) {}
-
- ~AddressList() {
- for (intptr_t i = 0; i < count_; i++) {
- delete addresses_[i];
- }
- delete[] addresses_;
- }
-
- intptr_t count() const { return count_; }
- T* GetAt(intptr_t i) const { return addresses_[i]; }
- void SetAt(intptr_t i, T* addr) { addresses_[i] = addr; }
-
- private:
- const intptr_t count_;
- T** addresses_;
-
- DISALLOW_COPY_AND_ASSIGN(AddressList);
-};
-
+// TODO(bkonyi): Socket should also inherit from SocketBase once it is
+// refactored to use instance methods when possible.
// We write Sockets into the native field of the _NativeSocket object
// on the Dart side. They are allocated in SetSocketIdNativeField(), and are
@@ -274,22 +49,8 @@ class Socket : public ReferenceCounted<Socket> {
Dart_Port port() const { return port_; }
void set_port(Dart_Port port) { port_ = port; }
- // TODO(dart:io): Convert these to instance methods where possible.
static bool Initialize();
- static intptr_t Available(intptr_t fd);
- static intptr_t Read(intptr_t fd, void* buffer, intptr_t num_bytes);
- static intptr_t Write(intptr_t fd, const void* buffer, intptr_t num_bytes);
- // Send data on a socket. The port to send to is specified in the port
- // component of the passed RawAddr structure. The RawAddr structure is only
- // used for datagram sockets.
- static intptr_t SendTo(intptr_t fd,
- const void* buffer,
- intptr_t num_bytes,
- const RawAddr& addr);
- static intptr_t RecvFrom(intptr_t fd,
- void* buffer,
- intptr_t num_bytes,
- RawAddr* addr);
+
// Creates a socket which is bound and connected. The port to connect to is
// specified as the port component of the passed RawAddr structure.
static intptr_t CreateConnect(const RawAddr& addr);
@@ -297,55 +58,9 @@ class Socket : public ReferenceCounted<Socket> {
// specified as the port component of the passed RawAddr structure.
static intptr_t CreateBindConnect(const RawAddr& addr,
const RawAddr& source_addr);
- // Returns true if the given error-number is because the system was not able
- // to bind the socket to a specific IP.
- static bool IsBindError(intptr_t error_number);
// Creates a datagram socket which is bound. The port to bind
// to is specified as the port component of the RawAddr structure.
static intptr_t CreateBindDatagram(const RawAddr& addr, bool reuseAddress);
- static intptr_t GetPort(intptr_t fd);
- static SocketAddress* GetRemotePeer(intptr_t fd, intptr_t* port);
- static void GetError(intptr_t fd, OSError* os_error);
- static int GetType(intptr_t fd);
- static intptr_t GetStdioHandle(intptr_t num);
- static void Close(intptr_t fd);
- static bool GetNoDelay(intptr_t fd, bool* enabled);
- static bool SetNoDelay(intptr_t fd, bool enabled);
- static bool GetMulticastLoop(intptr_t fd, intptr_t protocol, bool* enabled);
- static bool SetMulticastLoop(intptr_t fd, intptr_t protocol, bool enabled);
- static bool GetMulticastHops(intptr_t fd, intptr_t protocol, int* value);
- static bool SetMulticastHops(intptr_t fd, intptr_t protocol, int value);
- static bool GetBroadcast(intptr_t fd, bool* value);
- static bool SetBroadcast(intptr_t fd, bool value);
- static bool JoinMulticast(intptr_t fd,
- const RawAddr& addr,
- const RawAddr& interface,
- int interfaceIndex);
- static bool LeaveMulticast(intptr_t fd,
- const RawAddr& addr,
- const RawAddr& interface,
- int interfaceIndex);
-
- // Perform a hostname lookup. Returns a AddressList of SocketAddress's.
- static AddressList<SocketAddress>* LookupAddress(const char* host,
- int type,
- OSError** os_error);
-
- static bool ReverseLookup(const RawAddr& addr,
- char* host,
- intptr_t host_len,
- OSError** os_error);
-
- static bool ParseAddress(int type, const char* address, RawAddr* addr);
- static bool FormatNumericAddress(const RawAddr& addr, char* address, int len);
-
- // Whether ListInterfaces is supported.
- static bool ListInterfacesSupported();
-
- // List interfaces. Returns a AddressList of InterfaceSocketAddress's.
- static AddressList<InterfaceSocketAddress>* ListInterfaces(
- int type,
- OSError** os_error);
static CObject* LookupRequest(const CObjectArray& request);
static CObject* ListInterfacesRequest(const CObjectArray& request);
« no previous file with comments | « runtime/bin/process_win.cc ('k') | runtime/bin/socket.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698