diff options
author | madmaxoft <github@xoft.cz> | 2014-01-27 21:27:13 +0100 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2014-01-27 21:27:13 +0100 |
commit | cc1284a753874aa7d351a6ea41aaec4662ca6e57 (patch) | |
tree | 1d865db64553efc61d16203e06eb93d83e636bc0 /src/OSSupport/Socket.cpp | |
parent | Fixed client packet parsing. (diff) | |
download | cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.tar cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.tar.gz cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.tar.bz2 cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.tar.lz cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.tar.xz cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.tar.zst cuberite-cc1284a753874aa7d351a6ea41aaec4662ca6e57.zip |
Diffstat (limited to '')
-rw-r--r-- | src/OSSupport/Socket.cpp | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/src/OSSupport/Socket.cpp b/src/OSSupport/Socket.cpp index 4226a7535..3248eed88 100644 --- a/src/OSSupport/Socket.cpp +++ b/src/OSSupport/Socket.cpp @@ -320,7 +320,7 @@ bool cSocket::ConnectIPv4(const AString & a_HostNameOrAddr, unsigned short a_Por -int cSocket::Receive(char* a_Buffer, unsigned int a_Length, unsigned int a_Flags) +int cSocket::Receive(char * a_Buffer, unsigned int a_Length, unsigned int a_Flags) { return recv(m_Socket, a_Buffer, a_Length, a_Flags); } @@ -354,3 +354,32 @@ unsigned short cSocket::GetPort(void) const + +void cSocket::SetNonBlocking(void) +{ + #ifdef _WIN32 + u_long NonBlocking = 1; + int res = ioctlsocket(m_Socket, FIONBIO, &NonBlocking); + if (res != 0) + { + LOGERROR("Cannot set socket to non-blocking. This would make the server deadlock later on, aborting.\nErr: %d, %d, %s", + res, GetLastError(), GetLastErrorString().c_str() + ); + abort(); + } + #else + int NonBlocking = 1; + int res = ioctl(m_Socket, FIONBIO, (char *)&NonBlocking); + if (res != 0) + { + LOGERROR("Cannot set socket to non-blocking. This would make the server deadlock later on, aborting.\nErr: %d, %d, %s", + res, GetLastError(), GetLastErrorString().c_str() + ); + abort(); + } + #endif +} + + + + |