X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fservice%2Fservice.h;h=ffc7d275de884556748bf1fb37e04141f9c60e7a;hb=2b49c99dcd77e5c65d9563b38ed25e3153144818;hp=f32e23d9d1ddcad8e012a1fc1cfea24b997cc71f;hpb=d63d2c3c6cbbd574dda4f8b00ebe6c661735edd5;p=vuplus_dvbapp diff --git a/lib/service/service.h b/lib/service/service.h index f32e23d..ffc7d27 100644 --- a/lib/service/service.h +++ b/lib/service/service.h @@ -5,25 +5,45 @@ #include #include -class eServiceCenter: public virtual iServiceHandler, public virtual iObject +class eServiceCenter; + +#ifndef SWIG +typedef ePtr eServiceCenterPtr; +#endif + +class eServiceCenter: public iServiceHandler { -DECLARE_REF; -private: + DECLARE_REF(eServiceCenter); std::map > handler; + std::map > extensions; static eServiceCenter *instance; +#ifdef SWIG + eServiceCenter(); + ~eServiceCenter(); +#endif public: +#ifndef SWIG 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); RESULT list(const eServiceReference &, ePtr &ptr); + RESULT info(const eServiceReference &, ePtr &ptr); + RESULT offlineOperations(const eServiceReference &, ePtr &ptr); // eServiceCenter - static RESULT getInstance(ePtr &ptr) { ptr = instance; return 0; } - RESULT addServiceFactory(int id, iServiceHandler *hnd); + static RESULT getPrivInstance(ePtr &ptr) { ptr = instance; return 0; } + 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; } }; #endif