Reece Wilson
51a2816f3f
[+] IConditionMutex::TryLock() ... Timed is still too much of an ask for this interface, i think. There's a good reason as to why this isn't a iwaitable. This condvar interface must be as common and primitive as possible.
55 lines
1.1 KiB
C++
55 lines
1.1 KiB
C++
/***
|
|
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
File: AuConditionMutex.Win32.cpp
|
|
Date: 2021-6-12
|
|
Author: Reece
|
|
***/
|
|
#include <Source/RuntimeInternal.hpp>
|
|
#include "AuConditionMutex.Generic.hpp"
|
|
|
|
#if !defined(_AURUNTIME_GENERICCM)
|
|
|
|
namespace Aurora::Threading::Primitives
|
|
{
|
|
Win32ConditionMutex::Win32ConditionMutex()
|
|
{
|
|
::InitializeSRWLock(&this->lock_);
|
|
}
|
|
|
|
Win32ConditionMutex::~Win32ConditionMutex()
|
|
{
|
|
}
|
|
|
|
bool Win32ConditionMutex::TryLock()
|
|
{
|
|
return ::TryAcquireSRWLockExclusive(&this->lock_);
|
|
}
|
|
|
|
void Win32ConditionMutex::Lock()
|
|
{
|
|
::AcquireSRWLockExclusive(&this->lock_);
|
|
}
|
|
|
|
void Win32ConditionMutex::Unlock()
|
|
{
|
|
::ReleaseSRWLockExclusive(&this->lock_);
|
|
}
|
|
|
|
AuUInt Win32ConditionMutex::GetOSHandle()
|
|
{
|
|
return reinterpret_cast<AuUInt>(&this->lock_);
|
|
}
|
|
|
|
AUKN_SYM IConditionMutex *ConditionMutexNew()
|
|
{
|
|
return _new Win32ConditionMutex();
|
|
}
|
|
|
|
AUKN_SYM void ConditionMutexRelease(IConditionMutex *pMutex)
|
|
{
|
|
AuSafeDelete<Win32ConditionMutex *>(pMutex);
|
|
}
|
|
}
|
|
|
|
#endif |