aboutsummaryrefslogtreecommitdiff
path: root/Src/png/factory_png.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/png/factory_png.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/png/factory_png.cpp')
-rw-r--r--Src/png/factory_png.cpp71
1 files changed, 71 insertions, 0 deletions
diff --git a/Src/png/factory_png.cpp b/Src/png/factory_png.cpp
new file mode 100644
index 00000000..3837918b
--- /dev/null
+++ b/Src/png/factory_png.cpp
@@ -0,0 +1,71 @@
+#include "api__png.h"
+#include "factory_png.h"
+#include "PNGLoader.h"
+
+FOURCC PNGFactory::GetServiceType()
+{
+ return PNGLoader::getServiceType();
+}
+
+const char *PNGFactory::GetServiceName()
+{
+ return PNGLoader::getServiceName();
+}
+
+
+// {5E04FB28-53F5-4032-BD29-032B87EC3725}
+static const GUID pngGUID =
+{ 0x5e04fb28, 0x53f5, 0x4032, { 0xbd, 0x29, 0x3, 0x2b, 0x87, 0xec, 0x37, 0x25 } };
+
+GUID PNGFactory::GetGUID()
+{
+ return pngGUID;
+}
+
+void *PNGFactory::GetInterface(int global_lock)
+{
+ svc_imageLoader *ifc=new PNGLoader;
+// if (global_lock)
+// WASABI_API_SVC->service_lock(this, (void *)ifc);
+ return ifc;
+}
+
+int PNGFactory::SupportNonLockingInterface()
+{
+ return 1;
+}
+
+int PNGFactory::ReleaseInterface(void *ifc)
+{
+ //WASABI_API_SVC->service_unlock(ifc);
+ svc_imageLoader *png = static_cast<svc_imageLoader *>(ifc);
+ PNGLoader *pngloader = static_cast<PNGLoader *>(png);
+ delete pngloader;
+ return 1;
+}
+
+const char *PNGFactory::GetTestString()
+{
+ return 0;
+}
+
+int PNGFactory::ServiceNotify(int msg, int param1, int param2)
+{
+ return 1;
+}
+
+#ifdef CBCLASS
+#undef CBCLASS
+#endif
+
+#define CBCLASS PNGFactory
+START_DISPATCH;
+CB(WASERVICEFACTORY_GETSERVICETYPE, GetServiceType)
+CB(WASERVICEFACTORY_GETSERVICENAME, GetServiceName)
+CB(WASERVICEFACTORY_GETGUID, GetGUID)
+CB(WASERVICEFACTORY_GETINTERFACE, GetInterface)
+CB(WASERVICEFACTORY_SUPPORTNONLOCKINGGETINTERFACE, SupportNonLockingInterface)
+CB(WASERVICEFACTORY_RELEASEINTERFACE, ReleaseInterface)
+CB(WASERVICEFACTORY_GETTESTSTRING, GetTestString)
+CB(WASERVICEFACTORY_SERVICENOTIFY, ServiceNotify)
+END_DISPATCH;