X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fservice%2Fservice.h;h=6f6ab98088a815189838b21edc5693650a6bdbed;hb=57fadd1bacbbe2ae9d16ff24dc0a821a6b5da828;hp=fbe34278d3556b611f340d95b9e77343879435c5;hpb=ddc3964ed95d01e72229dc9af968a327cd84e56c;p=vuplus_dvbapp diff --git a/lib/service/service.h b/lib/service/service.h index fbe3427..6f6ab98 100644 --- a/lib/service/service.h +++ b/lib/service/service.h @@ -7,27 +7,41 @@ class eServiceCenter; +#ifndef SWIG typedef ePtr eServiceCenterPtr; +#endif class eServiceCenter: public iServiceHandler { -DECLARE_REF; -private: - std::map handler; + 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 &, iPlayableServicePtr &ptr); - RESULT record(const eServiceReference &, iRecordableServicePtr &ptr); - RESULT list(const eServiceReference &, iListableServicePtr &ptr); + 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(eServiceCenterPtr &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); +#endif + static SWIG_VOID(RESULT) getInstance(ePtr &SWIG_NAMED_OUTPUT(ptr)) { ptr = instance; return 0; } }; #endif