aboutsummaryrefslogtreecommitdiff
path: root/Src/playlist/ScriptObjectService.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/playlist/ScriptObjectService.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/playlist/ScriptObjectService.cpp')
-rw-r--r--Src/playlist/ScriptObjectService.cpp42
1 files changed, 42 insertions, 0 deletions
diff --git a/Src/playlist/ScriptObjectService.cpp b/Src/playlist/ScriptObjectService.cpp
new file mode 100644
index 00000000..01c64410
--- /dev/null
+++ b/Src/playlist/ScriptObjectService.cpp
@@ -0,0 +1,42 @@
+#include "ScriptObjectService.h"
+#include <api/script/objects/rootobjcontroller.h>
+#include "SPlaylist.h"
+#include "SPlaylists.h"
+#include "SPlaylistsEnumerator.h"
+#include "SPlaylistManager.h"
+
+ScriptObjectController *script_root=0;
+PlaylistScriptController playlistController;
+PlaylistsScriptController playlistsController;
+PlaylistsEnumeratorScriptController playlistsEnumeratorController;
+PlaylistManagerScriptController playlistManagerController;
+
+ScriptObjectController *ScriptObjectService::getController(int n)
+{
+ switch (n)
+ {
+ case 0:
+ return &playlistController;
+ case 1:
+ return &playlistsController;
+ case 2:
+ return &playlistsEnumeratorController;
+ case 3:
+ return &playlistManagerController;
+ }
+
+ return 0;
+}
+
+
+void ScriptObjectService::onRegisterClasses(ScriptObjectController *rootController)
+{
+ script_root = rootController;
+}
+
+#define CBCLASS ScriptObjectService
+START_DISPATCH;
+ CB(GETCONTROLLER, getController);
+ VCB(ONREGISTER, onRegisterClasses);
+END_DISPATCH;
+#undef CBCLASS