aboutsummaryrefslogtreecommitdiff
path: root/Src/Wasabi/api/timer/osx_timer.cpp
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/Wasabi/api/timer/osx_timer.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Wasabi/api/timer/osx_timer.cpp')
-rw-r--r--Src/Wasabi/api/timer/osx_timer.cpp38
1 files changed, 38 insertions, 0 deletions
diff --git a/Src/Wasabi/api/timer/osx_timer.cpp b/Src/Wasabi/api/timer/osx_timer.cpp
new file mode 100644
index 00000000..450c58e1
--- /dev/null
+++ b/Src/Wasabi/api/timer/osx_timer.cpp
@@ -0,0 +1,38 @@
+#include "osx_timer.h"
+#include <api/timer/timerclient.h>
+
+timer_api *timerApi = NULL;
+
+
+TimerApi::TimerApi()
+{
+ mainEventLoop = GetMainEventLoop();
+}
+
+static void WasabiTimerProc(EventLoopTimerRef inTimer, void * inUserData)
+{
+ TimerClient *client = (TimerClient *)inUserData;
+ if (client)
+ client->timerclient_timerCallback(inTimer);
+}
+
+
+TimerToken TimerApi::timer_add(TimerClient *client, int id, int ms)
+{
+ EventLoopTimerRef token;
+ OSStatus err = InstallEventLoopTimer(mainEventLoop,
+ (float)ms/1000.0f,
+ (float)ms/1000.0f,
+ WasabiTimerProc,
+ client,
+ &token);
+ if (err == noErr)
+ return token;
+ else
+ return 0;
+}
+
+void TimerApi::timer_remove(TimerClient *client, TimerToken token)
+{
+ RemoveEventLoopTimer(token);
+}