system/SocketError: un-inline constructor

Reduces header dependencies.
This commit is contained in:
Max Kellermann 2013-09-04 23:36:30 +02:00
parent 29030b54c9
commit ee9e238179
3 changed files with 26 additions and 13 deletions

View File

@ -32,6 +32,8 @@
#include "util/Error.hxx" #include "util/Error.hxx"
#include "util/Domain.hxx" #include "util/Domain.hxx"
#include <glib.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <fcntl.h> #include <fcntl.h>

View File

@ -21,4 +21,26 @@
#include "SocketError.hxx" #include "SocketError.hxx"
#include "util/Domain.hxx" #include "util/Domain.hxx"
#include <glib.h>
const Domain socket_domain("socket"); const Domain socket_domain("socket");
#ifdef WIN32
SocketErrorMessage::SocketErrorMessage(socket_error_t code)
{
DWORD nbytes = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS |
FORMAT_MESSAGE_MAX_WIDTH_MASK,
NULL, code, 0,
(LPSTR)msg, sizeof(msg), NULL);
if (nbytes == 0)
strcpy(msg, "Unknown error");
}
#else
SocketErrorMessage::SocketErrorMessage(socket_error_t code)
:msg(g_strerror(code)) {}
#endif

View File

@ -23,8 +23,6 @@
#include "gcc.h" #include "gcc.h"
#include "util/Error.hxx" #include "util/Error.hxx"
#include <glib.h>
#ifdef WIN32 #ifdef WIN32
#include <winsock2.h> #include <winsock2.h>
typedef DWORD socket_error_t; typedef DWORD socket_error_t;
@ -97,18 +95,9 @@ class SocketErrorMessage {
public: public:
#ifdef WIN32 #ifdef WIN32
explicit SocketErrorMessage(socket_error_t code=GetSocketError()) { explicit SocketErrorMessage(socket_error_t code=GetSocketError());
DWORD nbytes = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS |
FORMAT_MESSAGE_MAX_WIDTH_MASK,
NULL, code, 0,
(LPSTR)msg, sizeof(msg), NULL);
if (nbytes == 0)
strcpy(msg, "Unknown error");
}
#else #else
explicit SocketErrorMessage(socket_error_t code=GetSocketError()) explicit SocketErrorMessage(socket_error_t code=GetSocketError());
:msg(g_strerror(code)) {}
#endif #endif
operator const char *() const { operator const char *() const {