summaryrefslogtreecommitdiff
path: root/source/modules/asura-utils/threading/semaphore.h
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2019-08-02 20:51:00 +0800
committerchai <chaifix@163.com>2019-08-02 20:51:00 +0800
commitbad78945ceba425f6a80e3b8dca2414d592970eb (patch)
tree8bf7540766349c534bf9e5746b24fd7507ba034e /source/modules/asura-utils/threading/semaphore.h
parent99b90496765df21c5f377f42b9ed073ccb34c1fd (diff)
*修改文件名格式
Diffstat (limited to 'source/modules/asura-utils/threading/semaphore.h')
-rw-r--r--source/modules/asura-utils/threading/semaphore.h68
1 files changed, 0 insertions, 68 deletions
diff --git a/source/modules/asura-utils/threading/semaphore.h b/source/modules/asura-utils/threading/semaphore.h
deleted file mode 100644
index ae7b10b..0000000
--- a/source/modules/asura-utils/threading/semaphore.h
+++ /dev/null
@@ -1,68 +0,0 @@
-#ifndef __ASURA_SEMAPHORE_H__
-#define __ASURA_SEMAPHORE_H__
-
-#include "../utils_config.h"
-
-#if ASURA_THREAD_WIN32
-#include <windows.h>
-#endif
-
-namespace_begin(AsuraEngine)
-namespace_begin(Threading)
-
-class SemaphoreImpl;
-
-///
-/// ź
-///
-class Semaphore
-{
-public:
-
- Semaphore(unsigned int init_count = 1);
- ~Semaphore();
-
- void Signal();
- bool Wait(int timeout = ASURA_MUTEX_MAXWAIT);
-
-private:
- SemaphoreImpl* m_Impl;
-};
-
-class SemaphoreImpl
-{
-public:
- SemaphoreImpl(unsigned int init_value)
- : m_Count(init_value)
- {
- };
- virtual ~SemaphoreImpl() {};
- virtual void Signal() = 0;
- virtual bool Wait(int timeout) = 0;
- inline int Current() { return m_Count; }
-protected:
- unsigned int m_Count;
-};
-
-#define wait(sem, ...) sem.Wait(__VA_ARGS__)
-#define signal(sem) sem.Signal()
-
-#if ASURA_THREAD_WIN32
-
-class SemaphoreWin32 : public SemaphoreImpl
-{
-public:
- SemaphoreWin32(unsigned int init_value);
- ~SemaphoreWin32();
- void Signal() override;
- bool Wait(int timeout) override;
-private:
- HANDLE m_Sem;
-};
-
-#endif // ASURA_THREAD_WIN32
-
-namespace_end
-namespace_end
-
-#endif \ No newline at end of file