aboutsummaryrefslogtreecommitdiff
path: root/Src/replicant/nx/win/nxcondition.c
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/replicant/nx/win/nxcondition.c
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/replicant/nx/win/nxcondition.c')
-rw-r--r--Src/replicant/nx/win/nxcondition.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/Src/replicant/nx/win/nxcondition.c b/Src/replicant/nx/win/nxcondition.c
new file mode 100644
index 00000000..1e3ef009
--- /dev/null
+++ b/Src/replicant/nx/win/nxcondition.c
@@ -0,0 +1,66 @@
+#include "nxcondition.h"
+#include "foundation/error.h"
+
+int NXConditionInitialize(nx_condition_t condition)
+{
+ if (condition == 0)
+ return NErr_NullPointer;
+
+ InitializeCriticalSection(&condition->mutex);
+ InitializeConditionVariable(&condition->condition);
+ return NErr_Success;
+}
+
+int NXConditionDestroy(nx_condition_t condition)
+{
+ if (condition == 0)
+ return NErr_NullPointer;
+
+ DeleteCriticalSection(&condition->mutex);
+ return NErr_Success;
+}
+
+int NXConditionLock(nx_condition_t condition)
+{
+ if (condition == 0)
+ return NErr_NullPointer;
+
+ EnterCriticalSection(&condition->mutex);
+ return NErr_Success;
+}
+
+int NXConditionUnlock(nx_condition_t condition)
+{
+if (condition == 0)
+ return NErr_NullPointer;
+
+ LeaveCriticalSection(&condition->mutex);
+ return NErr_Success;
+}
+
+int NXConditionWait(nx_condition_t condition)
+{
+ if (condition == 0)
+ return NErr_NullPointer;
+
+ SleepConditionVariableCS(&condition->condition, &condition->mutex, INFINITE);
+ return NErr_Success;
+}
+
+int NXConditionTimedWait(nx_condition_t condition, unsigned int milliseconds)
+{
+ if (condition == 0)
+ return NErr_NullPointer;
+
+ SleepConditionVariableCS(&condition->condition, &condition->mutex, milliseconds);
+ return NErr_Success;
+}
+
+int NXConditionSignal(nx_condition_t condition)
+{
+ if (condition == 0)
+ return NErr_NullPointer;
+
+ WakeConditionVariable(&condition->condition);
+ return NErr_Success;
+} \ No newline at end of file