diff options
author | Max Kellermann <max@duempel.org> | 2013-01-15 22:32:13 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2013-01-15 22:41:56 +0100 |
commit | 5bb2d64ddb1aa9f7c3931bd00e2b4edcd1adfc5b (patch) | |
tree | 9b59b91b8f5a2f9fbd67b4a7eb6859ad5b562ba8 | |
parent | bc66dc45e6450c67320ba0408d5c34ebcafa0cb6 (diff) | |
download | mpd-5bb2d64ddb1aa9f7c3931bd00e2b4edcd1adfc5b.tar.gz mpd-5bb2d64ddb1aa9f7c3931bd00e2b4edcd1adfc5b.tar.xz mpd-5bb2d64ddb1aa9f7c3931bd00e2b4edcd1adfc5b.zip |
SocketError: merge duplicate FormatMessage() calls
Make a class that contains the formatting code and the buffer.
-rw-r--r-- | src/SocketError.hxx | 62 |
1 files changed, 36 insertions, 26 deletions
diff --git a/src/SocketError.hxx b/src/SocketError.hxx index ed9e71525..53a0c1d8f 100644 --- a/src/SocketError.hxx +++ b/src/SocketError.hxx @@ -87,27 +87,49 @@ IsSocketErrorClosed(socket_error_t code) #endif } +/** + * Helper class that formats a socket error message into a + * human-readable string. On Windows, a buffer is necessary for this, + * and this class hosts the buffer. + */ +class SocketErrorMessage { +#ifdef WIN32 + char msg[256]; +#else + const char *const msg; +#endif + +public: +#ifdef WIN32 + 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 + explicit SocketErrorMessage(socket_error_t code=GetSocketError()) + :msg(g_strerror(code)) {} +#endif + + operator const char *() const { + return msg; + } +}; + static inline void SetSocketError(GError **error_r, socket_error_t code) { #ifdef WIN32 if (error_r == NULL) return; +#endif - char buffer[256]; - DWORD nbytes = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | - FORMAT_MESSAGE_IGNORE_INSERTS | - FORMAT_MESSAGE_MAX_WIDTH_MASK, - NULL, code, 0, - (LPSTR)buffer, sizeof(buffer), NULL); - const char *msg = nbytes > 0 - ? buffer - : "Unknown error"; + const SocketErrorMessage msg(code); g_set_error_literal(error_r, SocketErrorQuark(), code, msg); -#else - g_set_error_literal(error_r, SocketErrorQuark(), code, - g_strerror(code)); -#endif } static inline void @@ -120,20 +142,8 @@ gcc_malloc static inline GError * NewSocketError(socket_error_t code) { -#ifdef WIN32 - char buffer[256]; - DWORD nbytes = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | - FORMAT_MESSAGE_IGNORE_INSERTS | - FORMAT_MESSAGE_MAX_WIDTH_MASK, - NULL, code, 0, - (LPSTR)buffer, sizeof(buffer), NULL); - const char *msg = nbytes > 0 - ? buffer - : "Unknown error"; + const SocketErrorMessage msg(code); return g_error_new_literal(SocketErrorQuark(), code, msg); -#else - return g_error_new_literal(SocketErrorQuark(), code, g_strerror(code)); -#endif } gcc_malloc |