From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/vp6/main.cpp | 100 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 Src/vp6/main.cpp (limited to 'Src/vp6/main.cpp') diff --git a/Src/vp6/main.cpp b/Src/vp6/main.cpp new file mode 100644 index 00000000..e08dc7fe --- /dev/null +++ b/Src/vp6/main.cpp @@ -0,0 +1,100 @@ +#include "api.h" +#include +#include "../Agave/Component/ifc_wa5component.h" +#include "../nu/Singleton.h" +#include "NSVFactory.h" +#include "duck_dxl.h" +#include "flv_vp6_decoder.h" +#include "avi_vp6_decoder.h" + +api_service *WASABI_API_SVC=0; +api_memmgr *WASABI_API_MEMMGR=0; + +class VP6Component : public ifc_wa5component +{ +public: + void RegisterServices(api_service *service); + int RegisterServicesSafeModeOk(); + void DeregisterServices(api_service *service); +protected: + RECVS_DISPATCH; +}; + +template +void ServiceBuild(api_T *&api_t, GUID factoryGUID_t) +{ + if (WASABI_API_SVC) + { + waServiceFactory *factory = WASABI_API_SVC->service_getServiceByGuid(factoryGUID_t); + if (factory) + api_t = reinterpret_cast( factory->getInterface() ); + } +} + +template +void ServiceRelease(api_T *api_t, GUID factoryGUID_t) +{ + if (WASABI_API_SVC && api_t) + { + waServiceFactory *factory = WASABI_API_SVC->service_getServiceByGuid(factoryGUID_t); + if (factory) + factory->releaseInterface(api_t); + } + api_t = NULL; +} + +static AVIDecoderCreator aviCreator; +static SingletonServiceFactory aviFactory; +FLVDecoderCreator flvCreator; +SingletonServiceFactory flvFactory; +static NSVFactory nsvFactory; +static SingletonServiceFactory factory; + +extern "C" +{ + int vp60_Init(void); + int vp60_Exit(void); +} + +void VP6Component::RegisterServices(api_service *service) +{ + WASABI_API_SVC = service; + ServiceBuild(WASABI_API_MEMMGR, memMgrApiServiceGuid); + factory.Register(WASABI_API_SVC, &nsvFactory); + flvFactory.Register(WASABI_API_SVC, &flvCreator); + aviFactory.Register(WASABI_API_SVC, &aviCreator); + + /* since we're delay loaded via WBM, it's safe to do this at load time */ + DXL_InitVideo(); + vp60_Init(); +} + +int VP6Component::RegisterServicesSafeModeOk() +{ + return 1; +} + +void VP6Component::DeregisterServices(api_service *service) +{ + factory.Deregister(WASABI_API_SVC); + flvFactory.Deregister(WASABI_API_SVC); + aviFactory.Deregister(WASABI_API_SVC); + ServiceRelease(WASABI_API_MEMMGR, memMgrApiServiceGuid); + + vp60_Exit(); + DXL_ExitVideo(); +} + +static VP6Component component; +extern "C" DLLEXPORT ifc_wa5component *GetWinamp5SystemComponent() +{ + return &component; +} + +#define CBCLASS VP6Component +START_DISPATCH; +VCB(API_WA5COMPONENT_REGISTERSERVICES, RegisterServices) +CB(15, RegisterServicesSafeModeOk) +VCB(API_WA5COMPONENT_DEREEGISTERSERVICES, DeregisterServices) +END_DISPATCH; +#undef CBCLASS \ No newline at end of file -- cgit