pkgsrc-wip/zoneminder/patches/patch-src_zm_thread_cpp

59 lines
1.6 KiB
Plaintext

$NetBSD: patch-src_zm_thread_cpp,v 1.2 2013/03/24 16:47:47 joerg Exp $
pthread_mutex_timedlock() is not available on NetBSD 5.0, and not required
in ZoneMinder.
Work around varying notion of an undefined mpid on pthread/not.
--- src/zm_thread.cpp.orig 2016-02-03 18:40:30.000000000 +0000
+++ src/zm_thread.cpp
@@ -72,6 +72,7 @@ void Mutex::lock()
throw ThreadException( stringtf( "Unable to lock pthread mutex: %s", strerror(errno) ) );
}
+#if 0
void Mutex::lock( int secs )
{
struct timespec timeout = getTimeout( secs );
@@ -85,6 +86,7 @@ void Mutex::lock( double secs )
if ( pthread_mutex_timedlock( &mMutex, &timeout ) < 0 )
throw ThreadException( stringtf( "Unable to timedlock pthread mutex: %s", strerror(errno) ) );
}
+#endif
void Mutex::unlock()
{
@@ -232,9 +234,15 @@ template <class T> void ThreadData<T>::u
Debug( 9, "Updated value, %p", this );
}
+#ifndef USE_PTHREAD
+#define MPID_UNDEFINED -1
+#else /* USE_PTHREAD */
+#define MPID_UNDEFINED NULL
+#endif /* USE_PTHREAD */
+
Thread::Thread() :
mThreadCondition( mThreadMutex ),
- mPid( -1 ),
+ mPid( MPID_UNDEFINED ),
mStarted( false ),
mRunning( false )
{
@@ -308,7 +316,7 @@ void Thread::join()
if ( isThread() )
throw ThreadException( "Can't self join thread" );
mThreadMutex.lock();
- if ( mPid >= 0 )
+ if ( mPid != MPID_UNDEFINED )
{
if ( mStarted )
{
@@ -337,4 +345,5 @@ void Thread::kill( int signal )
}
// Some explicit template instantiations
-#include "zm_threaddata.cpp"
+template class ThreadData<bool>;
+template class ThreadData<int>;