#include "threadData.h"
#include "moduleLogic.h"
#include <maya/MCommonSystemUtils.h>
#include <maya/MSpinLock.h>
#include <thread>
#include <chrono>
volatile bool threadData::bThreadToExecute =true ;
volatile bool threadData::bWaitingForCommand =false ;
static threadData tdata ;
struct _threadData *threadData::getThreadData () {
return (&tdata) ;
}
MThreadRetVal threadData::AsyncModuleThread (void *data) {
threadData *myData =(threadData *)data ;
while ( threadData::bThreadToExecute ) {
int ithreadDataDelay =threadDataDelayDefault ;
char *val =getenv (threadDataDelayName) ;
if ( val != NULL && *val != _T('\0') )
ithreadDataDelay =atoi (val) ;
MModuleLogic::ModuleDetectionLogicCmdExecute (myData) ;
std::this_thread::sleep_for(std::chrono::seconds(ithreadDataDelay));
}
return (0) ;
}
static volatile int g_async_count =0 ;
void threadData::AsyncModuleThreadEnded (void *data) {
g_async_count++ ;
}
MStatus threadData::startThread () {
{
}
threadData::bThreadToExecute =true ;
threadData::bWaitingForCommand =false ;
if ( ms != MS::kSuccess )
return (ms) ;
threadData::AsyncModuleThread,
(void *)threadData::getThreadData (),
threadData::AsyncModuleThreadEnded,
NULL
) ;
return (ms) ;
}
bool threadData::Maya_InterlockedCompare (volatile int *variable, int compareValue) {
exchangeSpinLock.
lock () ;
bool rtn =(*variable == compareValue) ;
exchangeSpinLock.unlock () ;
return (rtn) ;
}
void threadData::WaitForAsyncThreads (int val) {
while ( !threadData::Maya_InterlockedCompare (&g_async_count, val)) {
std::this_thread::yield();
}
}
void threadData::stopThread () {
threadData::bThreadToExecute =false ;
threadData::WaitForAsyncThreads (1) ;
}