aboutsummaryrefslogtreecommitdiff
path: root/Src/replicant/nx/win/nxthread.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/nxthread.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/nxthread.c')
-rw-r--r--Src/replicant/nx/win/nxthread.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/Src/replicant/nx/win/nxthread.c b/Src/replicant/nx/win/nxthread.c
new file mode 100644
index 00000000..0c049ad4
--- /dev/null
+++ b/Src/replicant/nx/win/nxthread.c
@@ -0,0 +1,25 @@
+#include "nxthread.h"
+#include "foundation/error.h"
+
+int NXThreadCreate(nx_thread_t *thread, nx_thread_func_t thread_function, nx_thread_parameter_t parameter)
+{
+ *thread = (nx_thread_t)CreateThread(0, 0, thread_function, parameter, 0, 0);
+ return NErr_Success;
+}
+
+int NXThreadJoin(nx_thread_t t, nx_thread_return_t *retval)
+{
+ if (!t)
+ return NErr_NullPointer;
+ WaitForSingleObject((HANDLE)t, INFINITE);
+ if (retval)
+ GetExitCodeThread((HANDLE)t, retval);
+ CloseHandle((HANDLE)t);
+ return NErr_Success;
+}
+
+int NXThreadCurrentSetPriority(int priority)
+{
+ SetThreadPriority(GetCurrentThread(), priority);
+ return NErr_Success;
+} \ No newline at end of file