|
1 |
| -# -*- coding: utf-8 -*- |
| 1 | +from enigma import iPlayableService |
| 2 | + |
| 3 | +from Components.Element import cached |
2 | 4 | from Components.PerServiceDisplay import PerServiceBase
|
3 |
| -from enigma import iPlayableService, iPlayableService, eServiceCenter |
4 | 5 | from Components.Sources.Source import Source
|
5 |
| -from Components.Element import cached |
6 | 6 | import NavigationInstance
|
7 | 7 |
|
8 | 8 |
|
9 | 9 | class CurrentService(PerServiceBase, Source):
|
10 | 10 | def __init__(self, navcore):
|
11 | 11 | Source.__init__(self)
|
12 |
| - PerServiceBase.__init__(self, navcore, |
13 |
| - { |
14 |
| - iPlayableService.evStart: self.serviceEvent, |
15 |
| - iPlayableService.evEnd: self.serviceEvent, |
16 |
| - # FIXME: we should check 'interesting_events' |
17 |
| - # which is not always provided. |
18 |
| - iPlayableService.evUpdatedInfo: self.serviceEvent, |
19 |
| - iPlayableService.evUpdatedEventInfo: self.serviceEvent, |
20 |
| - iPlayableService.evNewProgramInfo: self.serviceEvent, |
21 |
| - iPlayableService.evCuesheetChanged: self.serviceEvent, |
22 |
| - iPlayableService.evVideoSizeChanged: self.serviceEvent, |
23 |
| - iPlayableService.evVideoGammaChanged: self.serviceEvent, |
24 |
| - iPlayableService.evHBBTVInfo: self.serviceEvent |
25 |
| - }, with_event=True) |
| 12 | + PerServiceBase.__init__(self, navcore, { |
| 13 | + iPlayableService.evStart: self.serviceEvent, |
| 14 | + iPlayableService.evEnd: self.serviceEvent, |
| 15 | + # FIXME: We should check 'interesting_events' which is not always provided. |
| 16 | + iPlayableService.evUpdatedInfo: self.serviceEvent, |
| 17 | + iPlayableService.evUpdatedEventInfo: self.serviceEvent, |
| 18 | + iPlayableService.evNewProgramInfo: self.serviceEvent, |
| 19 | + iPlayableService.evCuesheetChanged: self.serviceEvent, |
| 20 | + iPlayableService.evVideoSizeChanged: self.serviceEvent, |
| 21 | + iPlayableService.evVideoGammaChanged: self.serviceEvent, |
| 22 | + iPlayableService.evHBBTVInfo: self.serviceEvent |
| 23 | + }, with_event=True) |
26 | 24 | self.navcore = navcore
|
27 |
| - self.srv = None |
28 |
| - self.info = None |
29 | 25 | self.ref = None
|
30 |
| - self.onManualNewService = [] |
31 | 26 |
|
32 | 27 | def serviceEvent(self, event):
|
33 |
| - self.srv = None |
34 |
| - self.info = None |
35 | 28 | self.changed((self.CHANGED_SPECIFIC, event))
|
36 | 29 |
|
37 | 30 | @cached
|
38 | 31 | def getCurrentService(self):
|
39 |
| - return self.srv or self.navcore.getCurrentService() |
| 32 | + return self.navcore.getCurrentService() |
| 33 | + |
| 34 | + def getCurrentServiceReference(self): |
| 35 | + return self.navcore.getCurrentlyPlayingServiceReference() |
40 | 36 |
|
41 | 37 | service = property(getCurrentService)
|
42 | 38 |
|
43 | 39 | @cached
|
44 | 40 | def getCurrentServiceRef(self):
|
45 | 41 | if self.ref:
|
46 | 42 | return self.ref
|
47 |
| - if NavigationInstance.instance is not None: |
48 |
| - return self.srv or NavigationInstance.instance.getCurrentlyPlayingServiceOrGroup() |
49 |
| - return None |
| 43 | + return NavigationInstance.instance.getCurrentlyPlayingServiceOrGroup() if NavigationInstance.instance is not None else None |
50 | 44 |
|
51 | 45 | def setCurrentServiceRef(self, ref):
|
52 | 46 | self.ref = ref
|
53 | 47 |
|
54 |
| - serviceref = property(getCurrentServiceRef, setCurrentServiceRef) |
55 |
| - |
56 |
| - def newService(self, ref): |
57 |
| - if ref and isinstance(ref, bool): |
58 |
| - self.srv = None |
59 |
| - elif ref: |
60 |
| - self.srv = ref |
61 |
| - self.info = eServiceCenter.getInstance().info(ref) |
62 |
| - else: |
63 |
| - self.srv = ref |
64 |
| - |
65 |
| - for x in self.onManualNewService: |
66 |
| - x() |
67 |
| - |
68 |
| - self.changed((self.CHANGED_SPECIFIC, iPlayableService.evStart)) |
| 48 | + serviceref = property(getCurrentServiceRef, setCurrentServiceRef) # TODO: serviceRef |
69 | 49 |
|
70 | 50 | @cached
|
71 | 51 | def getCurrentBouquetName(self):
|
72 |
| - if NavigationInstance.instance is not None: |
73 |
| - return NavigationInstance.instance.currentBouquetName |
74 |
| - return "" |
| 52 | + return NavigationInstance.instance.currentBouquetName if NavigationInstance.instance is not None else "" |
75 | 53 |
|
76 | 54 | currentBouquetName = property(getCurrentBouquetName)
|
77 | 55 |
|
|
0 commit comments