Merge pull request #581 from worktycho/strerror
Switched cEvent to use strerror_r for error messages
This commit is contained in:
commit
c8be9b5b1a
@ -2,7 +2,7 @@
|
|||||||
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
||||||
|
|
||||||
#include "BlockingTCPLink.h"
|
#include "BlockingTCPLink.h"
|
||||||
|
#include "Errors.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -75,7 +75,7 @@ bool cBlockingTCPLink::Connect(const char * iAddress, unsigned int iPort)
|
|||||||
server.sin_port = htons( (unsigned short)iPort);
|
server.sin_port = htons( (unsigned short)iPort);
|
||||||
if (connect(m_Socket, (struct sockaddr *)&server, sizeof(server)))
|
if (connect(m_Socket, (struct sockaddr *)&server, sizeof(server)))
|
||||||
{
|
{
|
||||||
LOGWARN("cTCPLink: Connection to \"%s:%d\" failed (%s)", iAddress, iPort, cSocket::GetErrorString( cSocket::GetLastError() ).c_str() );
|
LOGWARN("cTCPLink: Connection to \"%s:%d\" failed (%s)", iAddress, iPort,GetOSErrorString( cSocket::GetLastError() ).c_str() );
|
||||||
CloseSocket();
|
CloseSocket();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
53
src/OSSupport/Errors.cpp
Normal file
53
src/OSSupport/Errors.cpp
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
|
||||||
|
#include "Globals.h"
|
||||||
|
|
||||||
|
#include "Errors.h"
|
||||||
|
|
||||||
|
AString GetOSErrorString( int a_ErrNo )
|
||||||
|
{
|
||||||
|
char buffer[ 1024 ];
|
||||||
|
AString Out;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
|
||||||
|
FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, NULL, a_ErrNo, 0, buffer, ARRAYCOUNT(buffer), NULL);
|
||||||
|
Printf(Out, "%d: %s", a_ErrNo, buffer);
|
||||||
|
if (!Out.empty() && (Out[Out.length() - 1] == '\n'))
|
||||||
|
{
|
||||||
|
Out.erase(Out.length() - 2);
|
||||||
|
}
|
||||||
|
return Out;
|
||||||
|
|
||||||
|
#else // _WIN32
|
||||||
|
|
||||||
|
// According to http://linux.die.net/man/3/strerror_r there are two versions of strerror_r():
|
||||||
|
|
||||||
|
#if ( _GNU_SOURCE ) && !defined(ANDROID_NDK) // GNU version of strerror_r()
|
||||||
|
|
||||||
|
char * res = strerror_r( errno, buffer, ARRAYCOUNT(buffer) );
|
||||||
|
if( res != NULL )
|
||||||
|
{
|
||||||
|
Printf(Out, "%d: %s", a_ErrNo, res);
|
||||||
|
return Out;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else // XSI version of strerror_r():
|
||||||
|
|
||||||
|
int res = strerror_r( errno, buffer, ARRAYCOUNT(buffer) );
|
||||||
|
if( res == 0 )
|
||||||
|
{
|
||||||
|
Printf(Out, "%d: %s", a_ErrNo, buffer);
|
||||||
|
return Out;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // strerror_r() version
|
||||||
|
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Printf(Out, "Error %d while getting error string for error #%d!", errno, a_ErrNo);
|
||||||
|
return Out;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // else _WIN32
|
||||||
|
}
|
||||||
|
|
5
src/OSSupport/Errors.h
Normal file
5
src/OSSupport/Errors.h
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
AString GetOSErrorString(int a_ErrNo);
|
||||||
|
|
@ -7,7 +7,7 @@
|
|||||||
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
||||||
|
|
||||||
#include "Event.h"
|
#include "Event.h"
|
||||||
|
#include "Errors.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -35,14 +35,16 @@ cEvent::cEvent(void)
|
|||||||
m_Event = sem_open(EventName.c_str(), O_CREAT, 777, 0 );
|
m_Event = sem_open(EventName.c_str(), O_CREAT, 777, 0 );
|
||||||
if (m_Event == SEM_FAILED)
|
if (m_Event == SEM_FAILED)
|
||||||
{
|
{
|
||||||
LOGERROR("cEvent: Cannot create event, errno = %i. Aborting server.", errno);
|
AString error = GetOSErrorString(errno);
|
||||||
|
LOGERROR("cEvent: Cannot create event, err = %s. Aborting server.", error.c_str());
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
// Unlink the semaphore immediately - it will continue to function but will not pollute the namespace
|
// Unlink the semaphore immediately - it will continue to function but will not pollute the namespace
|
||||||
// We don't store the name, so can't call this in the destructor
|
// We don't store the name, so can't call this in the destructor
|
||||||
if (sem_unlink(EventName.c_str()) != 0)
|
if (sem_unlink(EventName.c_str()) != 0)
|
||||||
{
|
{
|
||||||
LOGWARN("ERROR: Could not unlink cEvent. (%i)", errno);
|
AString error = GetOSErrorString(errno);
|
||||||
|
LOGWARN("ERROR: Could not unlink cEvent. (%s)", error.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // *nix
|
#endif // *nix
|
||||||
@ -61,7 +63,8 @@ cEvent::~cEvent()
|
|||||||
{
|
{
|
||||||
if (sem_close(m_Event) != 0)
|
if (sem_close(m_Event) != 0)
|
||||||
{
|
{
|
||||||
LOGERROR("ERROR: Could not close cEvent. (%i)", errno);
|
AString error = GetOSErrorString(errno);
|
||||||
|
LOGERROR("ERROR: Could not close cEvent. (%s)", error.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -88,7 +91,8 @@ void cEvent::Wait(void)
|
|||||||
int res = sem_wait(m_Event);
|
int res = sem_wait(m_Event);
|
||||||
if (res != 0 )
|
if (res != 0 )
|
||||||
{
|
{
|
||||||
LOGWARN("cEvent: waiting for the event failed: %i, errno = %i. Continuing, but server may be unstable.", res, errno);
|
AString error = GetOSErrorString(errno);
|
||||||
|
LOGWARN("cEvent: waiting for the event failed: %i, err = %s. Continuing, but server may be unstable.", res, error.c_str());
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -108,7 +112,8 @@ void cEvent::Set(void)
|
|||||||
int res = sem_post(m_Event);
|
int res = sem_post(m_Event);
|
||||||
if (res != 0)
|
if (res != 0)
|
||||||
{
|
{
|
||||||
LOGWARN("cEvent: Could not set cEvent: %i, errno = %d", res, errno);
|
AString error = GetOSErrorString(errno);
|
||||||
|
LOGWARN("cEvent: Could not set cEvent: %i, err = %s", res, error.c_str());
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -105,58 +105,6 @@ void cSocket::ShutdownReadWrite(void)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
AString cSocket::GetErrorString( int a_ErrNo )
|
|
||||||
{
|
|
||||||
char buffer[ 1024 ];
|
|
||||||
AString Out;
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
|
|
||||||
FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, NULL, a_ErrNo, 0, buffer, ARRAYCOUNT(buffer), NULL);
|
|
||||||
Printf(Out, "%d: %s", a_ErrNo, buffer);
|
|
||||||
if (!Out.empty() && (Out[Out.length() - 1] == '\n'))
|
|
||||||
{
|
|
||||||
Out.erase(Out.length() - 2);
|
|
||||||
}
|
|
||||||
return Out;
|
|
||||||
|
|
||||||
#else // _WIN32
|
|
||||||
|
|
||||||
// According to http://linux.die.net/man/3/strerror_r there are two versions of strerror_r():
|
|
||||||
|
|
||||||
#if ( _GNU_SOURCE ) && !defined(ANDROID_NDK) // GNU version of strerror_r()
|
|
||||||
|
|
||||||
char * res = strerror_r( errno, buffer, ARRAYCOUNT(buffer) );
|
|
||||||
if( res != NULL )
|
|
||||||
{
|
|
||||||
Printf(Out, "%d: %s", a_ErrNo, res);
|
|
||||||
return Out;
|
|
||||||
}
|
|
||||||
|
|
||||||
#else // XSI version of strerror_r():
|
|
||||||
|
|
||||||
int res = strerror_r( errno, buffer, ARRAYCOUNT(buffer) );
|
|
||||||
if( res == 0 )
|
|
||||||
{
|
|
||||||
Printf(Out, "%d: %s", a_ErrNo, buffer);
|
|
||||||
return Out;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // strerror_r() version
|
|
||||||
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Printf(Out, "Error %d while getting error string for error #%d!", errno, a_ErrNo);
|
|
||||||
return Out;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // else _WIN32
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int cSocket::GetLastError()
|
int cSocket::GetLastError()
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#include "Errors.h"
|
||||||
|
|
||||||
|
|
||||||
class cSocket
|
class cSocket
|
||||||
@ -57,11 +57,10 @@ public:
|
|||||||
/// Initializes the network stack. Returns 0 on success, or another number as an error code.
|
/// Initializes the network stack. Returns 0 on success, or another number as an error code.
|
||||||
static int WSAStartup(void);
|
static int WSAStartup(void);
|
||||||
|
|
||||||
static AString GetErrorString(int a_ErrNo);
|
|
||||||
static int GetLastError();
|
static int GetLastError();
|
||||||
static AString GetLastErrorString(void)
|
static AString GetLastErrorString(void)
|
||||||
{
|
{
|
||||||
return GetErrorString(GetLastError());
|
return GetOSErrorString(GetLastError());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a new socket of the specified address family
|
/// Creates a new socket of the specified address family
|
||||||
@ -115,4 +114,4 @@ public:
|
|||||||
private:
|
private:
|
||||||
xSocket m_Socket;
|
xSocket m_Socket;
|
||||||
AString m_IPString;
|
AString m_IPString;
|
||||||
};
|
};
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "SocketThreads.h"
|
#include "SocketThreads.h"
|
||||||
|
#include "Errors.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -556,7 +557,7 @@ void cSocketThreads::cSocketThread::WriteToSockets(fd_set * a_Write)
|
|||||||
if (Sent < 0)
|
if (Sent < 0)
|
||||||
{
|
{
|
||||||
int Err = cSocket::GetLastError();
|
int Err = cSocket::GetLastError();
|
||||||
LOGWARNING("Error %d while writing to client \"%s\", disconnecting. \"%s\"", Err, m_Slots[i].m_Socket.GetIPString().c_str(), cSocket::GetErrorString(Err).c_str());
|
LOGWARNING("Error %d while writing to client \"%s\", disconnecting. \"%s\"", Err, m_Slots[i].m_Socket.GetIPString().c_str(), GetOSErrorString(Err).c_str());
|
||||||
m_Slots[i].m_Socket.CloseSocket();
|
m_Slots[i].m_Socket.CloseSocket();
|
||||||
if (m_Slots[i].m_Client != NULL)
|
if (m_Slots[i].m_Client != NULL)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user