aboutsummaryrefslogtreecommitdiff
path: root/Src/Wasabi/api/service/svc_enum.h
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/service/svc_enum.h
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Wasabi/api/service/svc_enum.h')
-rw-r--r--Src/Wasabi/api/service/svc_enum.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/Src/Wasabi/api/service/svc_enum.h b/Src/Wasabi/api/service/svc_enum.h
new file mode 100644
index 00000000..40f5c651
--- /dev/null
+++ b/Src/Wasabi/api/service/svc_enum.h
@@ -0,0 +1,24 @@
+#ifndef _SVC_ENUM_H
+#define _SVC_ENUM_H
+
+// try to use this one, it does a clientLock for you
+#include <api/service/waservicefactory.h>
+template <class T>
+class castService {
+public:
+ castService(waServiceFactory *w, int global_lock=TRUE) : was(w), gl(global_lock) { }
+ operator T *() {
+ if (was == NULL) return NULL;
+ T *ret = static_cast<T *>(was->getInterface(gl));
+ return ret;
+ }
+private:
+ waServiceFactory *was;
+ int gl;
+};
+
+#include "svcenumbyguid.h"
+#include "svcenum.h"
+#include "svcenumt.h"
+
+#endif