X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/094b454c7e3b86cdcff697bb68cd367e53ba9e8e..663ae4876adf2ec53e4ffcb0b1d1fefa291c8b8b:/Navigation.py diff --git a/Navigation.py b/Navigation.py index 5fe26517..09daff34 100644 --- a/Navigation.py +++ b/Navigation.py @@ -11,19 +11,16 @@ class Navigation: raise NavigationInstance.instance NavigationInstance.instance = self - self.ServiceHandler = eServiceCenterPtr() - eServiceCenter.getInstance(self.ServiceHandler) + self.ServiceHandler = eServiceCenter.getInstance() import Navigation as Nav Nav.navcore = self - print "Navcore instance set!" - print Nav.navcore - self.pnav = pNavigation() self.pnav.m_event.get().append(self.callEvent) self.event = [ ] self.currentlyPlayingService = None + self.currentlyPlayingServiceReference = None self.RecordTimer = RecordTimer.RecordTimer() @@ -33,6 +30,10 @@ class Navigation: def playService(self, ref): self.currentlyPlayingServiceReference = None + if ref is None: + self.stopService() + return 0 + if not self.pnav.playService(ref): self.currentlyPlayingServiceReference = ref return 0 @@ -45,23 +46,28 @@ class Navigation: print "recording service: %s" % (str(ref)) if isinstance(ref, ServiceReference.ServiceReference): ref = ref.ref - service = iRecordableServicePtr() - if self.pnav.recordService(ref, service): + service = self.pnav.recordService(ref) + + if service is None: print "record returned non-zero" return None else: - print "ok, recordService didn't fail" return service def enqueueService(self, ref): return self.pnav.enqueueService(ref) def getCurrentService(self): - service = iPlayableServicePtr() - if self.pnav.getCurrentService(service): + service = self.pnav.getCurrentService() + + if service is None: return None + return service + def stopService(self): + self.pnav.stopService() + def getPlaylist(self): playlist = ePlaylistPtr() if self.pnav.getPlaylist(playlist): @@ -80,3 +86,6 @@ class Navigation: def shutdown(self): self.RecordTimer.shutdown() + + def stopUserServices(self): + self.stopService()