Merge pull request #1510 from mc-server/TimedEvent
Added a cEvent::Wait() with timeout.
This commit is contained in:
commit
89713e23e4
src/OSSupport
@ -39,6 +39,6 @@ if(NOT MSVC)
|
||||
add_library(OSSupport ${SRCS} ${HDRS})
|
||||
|
||||
if(UNIX)
|
||||
target_link_libraries(OSSupport pthread)
|
||||
target_link_libraries(OSSupport pthread rt)
|
||||
endif()
|
||||
endif()
|
||||
|
@ -102,6 +102,53 @@ void cEvent::Wait(void)
|
||||
|
||||
|
||||
|
||||
bool cEvent::Wait(int a_TimeoutMSec)
|
||||
{
|
||||
#ifdef _WIN32
|
||||
DWORD res = WaitForSingleObject(m_Event, (DWORD)a_TimeoutMSec);
|
||||
switch (res)
|
||||
{
|
||||
case WAIT_OBJECT_0: return true; // Regular event signalled
|
||||
case WAIT_TIMEOUT: return false; // Regular event timeout
|
||||
default:
|
||||
{
|
||||
LOGWARN("cEvent: waiting for the event failed: %u, GLE = %u. Continuing, but server may be unstable.", (unsigned)res, (unsigned)GetLastError());
|
||||
return false;
|
||||
}
|
||||
}
|
||||
#else
|
||||
// Get the current time:
|
||||
timespec timeout;
|
||||
if (clock_gettime(CLOCK_REALTIME, &timeout) == -1)
|
||||
{
|
||||
LOGWARN("cEvent: Getting current time failed: %i, err = %s. Continuing, but the server may be unstable.", errno, GetOSErrorString(errno).c_str());
|
||||
return false;
|
||||
}
|
||||
|
||||
// Add the specified timeout:
|
||||
timeout.tv_sec += a_TimeoutMSec / 1000;
|
||||
timeout.tv_nsec += (a_TimeoutMSec % 1000) * 1000000; // 1 msec = 1000000 usec
|
||||
|
||||
// Wait with timeout:
|
||||
int res = sem_timedwait(m_Event, &timeout);
|
||||
switch (res)
|
||||
{
|
||||
case 0: return true; // Regular event signalled
|
||||
case ETIMEDOUT: return false; // Regular even timeout
|
||||
default:
|
||||
{
|
||||
AString error = GetOSErrorString(errno);
|
||||
LOGWARN("cEvent: waiting for the event failed: %i, err = %s. Continuing, but server may be unstable.", res, error.c_str());
|
||||
return false;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
void cEvent::Set(void)
|
||||
{
|
||||
#ifdef _WIN32
|
||||
|
@ -24,6 +24,10 @@ public:
|
||||
|
||||
void Wait(void);
|
||||
void Set (void);
|
||||
|
||||
/** Waits for the event until either it is signalled, or the (relative) timeout is passed.
|
||||
Returns true if the event was signalled, false if the timeout was hit or there was an error. */
|
||||
bool Wait(int a_TimeoutMSec);
|
||||
|
||||
private:
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user