X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fservice%2Fservice.h;h=ffc7d275de884556748bf1fb37e04141f9c60e7a;hb=f0fa458aa15610408a16f3214a6e857f16b0c646;hp=77173c53a60a48b3c4610962da19fdaa8a90ef8a;hpb=ed40f6f85c9c07c3c1224ae20601082c0309a631;p=vuplus_dvbapp diff --git a/lib/service/service.h b/lib/service/service.h index 77173c5..ffc7d27 100644 --- a/lib/service/service.h +++ b/lib/service/service.h @@ -13,9 +13,9 @@ typedef ePtr eServiceCenterPtr; class eServiceCenter: public iServiceHandler { -DECLARE_REF(eServiceCenter); -private: + DECLARE_REF(eServiceCenter); std::map > handler; + std::map > extensions; static eServiceCenter *instance; #ifdef SWIG eServiceCenter(); @@ -26,6 +26,9 @@ public: eServiceCenter(); virtual ~eServiceCenter(); + int getServiceTypeForExtension(const char *str); + int getServiceTypeForExtension(const std::string &str); + // iServiceHandler RESULT play(const eServiceReference &, ePtr &ptr); RESULT record(const eServiceReference &, ePtr &ptr); @@ -35,8 +38,10 @@ public: // eServiceCenter static RESULT getPrivInstance(ePtr &ptr) { ptr = instance; return 0; } - RESULT addServiceFactory(int id, iServiceHandler *hnd); + RESULT addServiceFactory(int id, iServiceHandler *hnd, std::list &extensions); RESULT removeServiceFactory(int id); + RESULT addFactoryExtension(int id, const char *extension); + RESULT removeFactoryExtension(int id, const char *extension); #endif static SWIG_VOID(RESULT) getInstance(ePtr &SWIG_NAMED_OUTPUT(ptr)) { ptr = instance; return 0; } };