Browse Source

This version of hsEvent more accurately matches the previous (Win32)

behavior, and also serves as a proper binary semaphore.
Michael Hansen 11 years ago
parent
commit
658d5b6f71
  1. 19
      Sources/Plasma/CoreLib/hsThread.h

19
Sources/Plasma/CoreLib/hsThread.h

@ -175,19 +175,34 @@ class hsEvent
{ {
std::mutex fMutex; std::mutex fMutex;
std::condition_variable fCondition; std::condition_variable fCondition;
bool fEvent;
public: public:
hsEvent() { } hsEvent() : fEvent(false) { }
inline void Wait() inline void Wait()
{ {
std::unique_lock<std::mutex> lock(fMutex); std::unique_lock<std::mutex> lock(fMutex);
fCondition.wait(lock); fCondition.wait(lock, [this]() { return fEvent; });
fEvent = false;
}
template <class _Rep, class _Period>
inline bool Wait(const std::chrono::duration<_Rep, _Period> &duration)
{
std::unique_lock<std::mutex> lock(fMutex);
bool result = fCondition.wait_for(lock, duration, [this]() { return fEvent; });
if (result)
fEvent = false;
return result;
} }
inline void Signal() inline void Signal()
{ {
std::unique_lock<std::mutex> lock(fMutex); std::unique_lock<std::mutex> lock(fMutex);
fEvent = true;
fCondition.notify_one(); fCondition.notify_one();
} }
}; };

Loading…
Cancel
Save