diff options
author | kwolekr <kwolekr@minetest.net> | 2015-11-08 18:14:36 -0500 |
---|---|---|
committer | kwolekr <kwolekr@minetest.net> | 2015-11-08 18:16:02 -0500 |
commit | 88a3977954f537b391c714be2a52da6b19711154 (patch) | |
tree | 69b6b469546b8772a195b80d4886802f919adb1e /src | |
parent | 4ae6e509ffe886492598610a3511179ad87c1f43 (diff) | |
download | minetest-88a3977954f537b391c714be2a52da6b19711154.tar.gz minetest-88a3977954f537b391c714be2a52da6b19711154.tar.bz2 minetest-88a3977954f537b391c714be2a52da6b19711154.zip |
Add errno to socket creation failed exception
Diffstat (limited to 'src')
-rw-r--r-- | src/socket.cpp | 11 | ||||
-rw-r--r-- | src/socket.h | 6 |
2 files changed, 10 insertions, 7 deletions
diff --git a/src/socket.cpp b/src/socket.cpp index 47fffcc4d..17fa1924d 100644 --- a/src/socket.cpp +++ b/src/socket.cpp @@ -44,8 +44,9 @@ with this program; if not, write to the Free Software Foundation, Inc., #include <windows.h> #include <winsock2.h> #include <ws2tcpip.h> -typedef SOCKET socket_t; -typedef int socklen_t; + #define LAST_SOCKET_ERR() WSAGetLastError() + typedef SOCKET socket_t; + typedef int socklen_t; #else #include <sys/types.h> #include <sys/socket.h> @@ -54,7 +55,8 @@ typedef int socklen_t; #include <netdb.h> #include <unistd.h> #include <arpa/inet.h> -typedef int socket_t; + #define LAST_SOCKET_ERR() (errno) + typedef int socket_t; #endif // Set to true to enable verbose debug output @@ -339,7 +341,8 @@ bool UDPSocket::init(bool ipv6, bool noExceptions) if (noExceptions) { return false; } else { - throw SocketException("Failed to create socket"); + throw SocketException(std::string("Failed to create socket: error ") + + itos(LAST_SOCKET_ERR())); } } diff --git a/src/socket.h b/src/socket.h index c7dd78f66..8d1ad70ff 100644 --- a/src/socket.h +++ b/src/socket.h @@ -45,7 +45,7 @@ extern bool socket_enable_debug_output; class SocketException : public BaseException { public: - SocketException(const char *s): + SocketException(const std::string &s): BaseException(s) { } @@ -54,7 +54,7 @@ public: class ResolveError : public BaseException { public: - ResolveError(const char *s): + ResolveError(const std::string &s): BaseException(s) { } @@ -63,7 +63,7 @@ public: class SendFailedException : public BaseException { public: - SendFailedException(const char *s): + SendFailedException(const std::string &s): BaseException(s) { } |