diff options
author | Vasil Dimov <vd@FreeBSD.org> | 2021-04-29 17:35:43 +0200 |
---|---|---|
committer | Vasil Dimov <vd@FreeBSD.org> | 2022-06-20 16:38:31 +0200 |
commit | e8ff3f0c52e7512a580bc907dc72e5bb141b4217 (patch) | |
tree | 0a2b42013e2cf72f01190f9e31d7beaa0e434148 /src/util/sock.cpp | |
parent | 175fb2670a2a24220afb3eea99b7b65b0aa89c76 (diff) |
net: remove CloseSocket()
Do the closing in `Sock::Reset()` and remove the standalone
`CloseSocket()`.
This reduces the exposure of low-level sockets (i.e. integer file
descriptors) outside of the `Sock` class.
Diffstat (limited to 'src/util/sock.cpp')
-rw-r--r-- | src/util/sock.cpp | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/src/util/sock.cpp b/src/util/sock.cpp index 20418a940c..aca83d4170 100644 --- a/src/util/sock.cpp +++ b/src/util/sock.cpp @@ -51,7 +51,20 @@ Sock& Sock::operator=(Sock&& other) SOCKET Sock::Get() const { return m_socket; } -void Sock::Reset() { CloseSocket(m_socket); } +void Sock::Reset() { + if (m_socket == INVALID_SOCKET) { + return; + } +#ifdef WIN32 + int ret = closesocket(m_socket); +#else + int ret = close(m_socket); +#endif + if (ret) { + LogPrintf("Error closing socket %d: %s\n", m_socket, NetworkErrorString(WSAGetLastError())); + } + m_socket = INVALID_SOCKET; +} ssize_t Sock::Send(const void* data, size_t len, int flags) const { @@ -382,19 +395,3 @@ std::string NetworkErrorString(int err) return SysErrorString(err); } #endif - -bool CloseSocket(SOCKET& hSocket) -{ - if (hSocket == INVALID_SOCKET) - return false; -#ifdef WIN32 - int ret = closesocket(hSocket); -#else - int ret = close(hSocket); -#endif - if (ret) { - LogPrintf("Socket close failed: %d. Error: %s\n", hSocket, NetworkErrorString(WSAGetLastError())); - } - hSocket = INVALID_SOCKET; - return ret != SOCKET_ERROR; -} |