dart-sdk/runtime/bin/sync_socket_win.cc
Zach Anderson f407419d0a [vm] Reland: Prefix HOST_OS_* and TARGET_OS_* with DART_
This relands https://dart-review.googlesource.com/c/sdk/+/205633
but without renaming TARGET_OS_IPHONE to DART_TARGET_OS_IPHONE.
It also changes uses of TARGET_OS_IOS to
DART_TARGET_OS_MACOS_IOS to be consistent with the rest of the
VM.

TargetConditionals.h for XCode 13 defines several
TARGET_OS_* preprocessor symbols that confuse the
Dart build. There is probably a more targeted fix
for this, but renaming the symbols that Dart uses
will also prevent this problem if more symbols
are added to the platform headers in the future.

See: https://github.com/dart-lang/sdk/issues/46499

TEST=It builds.

Change-Id: Ie775c19dd23cfdf5f65e5ebc6ee4ec3a561676fa
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/205860
Commit-Queue: Zach Anderson <zra@google.com>
Reviewed-by: Alexander Aprelev <aam@google.com>
2021-07-02 19:06:45 +00:00

100 lines
3 KiB
C++

// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
#include "platform/globals.h"
#if defined(DART_HOST_OS_WINDOWS)
#include "bin/socket_base.h"
#include "bin/sync_socket.h"
namespace dart {
namespace bin {
bool SynchronousSocket::Initialize() {
return SocketBase::Initialize();
}
static intptr_t Create(const RawAddr& addr) {
const intptr_t type = SOCK_STREAM;
SOCKET s = WSASocket(addr.ss.ss_family, type, 0, NULL, 0, 0);
return (s == INVALID_SOCKET) ? -1 : s;
}
static intptr_t Connect(intptr_t fd, const RawAddr& addr) {
SOCKET socket = static_cast<SOCKET>(fd);
intptr_t result =
connect(socket, &addr.addr, SocketAddress::GetAddrLength(addr));
return (result == SOCKET_ERROR) ? -1 : socket;
}
intptr_t SynchronousSocket::CreateConnect(const RawAddr& addr) {
intptr_t fd = Create(addr);
return (fd < 0) ? fd : Connect(fd, addr);
}
intptr_t SynchronousSocket::Available(intptr_t fd) {
SOCKET socket = static_cast<SOCKET>(fd);
DWORD available;
intptr_t result = ioctlsocket(socket, FIONREAD, &available);
return (result == SOCKET_ERROR) ? -1 : static_cast<intptr_t>(available);
}
intptr_t SynchronousSocket::GetPort(intptr_t fd) {
SOCKET socket = static_cast<SOCKET>(fd);
RawAddr raw;
socklen_t size = sizeof(raw);
if (getsockname(socket, &raw.addr, &size) == SOCKET_ERROR) {
return 0;
}
return SocketAddress::GetAddrPort(raw);
}
SocketAddress* SynchronousSocket::GetRemotePeer(intptr_t fd, intptr_t* port) {
SOCKET socket = static_cast<SOCKET>(fd);
RawAddr raw;
socklen_t size = sizeof(raw);
if (getpeername(socket, &raw.addr, &size)) {
return NULL;
}
*port = SocketAddress::GetAddrPort(raw);
// Clear the port before calling WSAAddressToString as WSAAddressToString
// includes the port in the formatted string.
SocketAddress::SetAddrPort(&raw, 0);
return new SocketAddress(&raw.addr);
}
intptr_t SynchronousSocket::Read(intptr_t fd,
void* buffer,
intptr_t num_bytes) {
SOCKET socket = static_cast<SOCKET>(fd);
return recv(socket, reinterpret_cast<char*>(buffer), num_bytes, 0);
}
intptr_t SynchronousSocket::Write(intptr_t fd,
const void* buffer,
intptr_t num_bytes) {
SOCKET socket = static_cast<SOCKET>(fd);
return send(socket, reinterpret_cast<const char*>(buffer), num_bytes, 0);
}
void SynchronousSocket::ShutdownRead(intptr_t fd) {
SOCKET socket = static_cast<SOCKET>(fd);
shutdown(socket, SD_RECEIVE);
}
void SynchronousSocket::ShutdownWrite(intptr_t fd) {
SOCKET socket = static_cast<SOCKET>(fd);
shutdown(socket, SD_SEND);
}
void SynchronousSocket::Close(intptr_t fd) {
SOCKET socket = static_cast<SOCKET>(fd);
closesocket(socket);
}
} // namespace bin
} // namespace dart
#endif // defined(DART_HOST_OS_WINDOWS)