git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
first working version of TempFanControl plugin with Sensors and FanControl component
[enigma2.git]
/
lib
/
python
/
Components
/
Converter
/
ServiceName.py
diff --git
a/lib/python/Components/Converter/ServiceName.py
b/lib/python/Components/Converter/ServiceName.py
index 77647dd05dd40fc14a66b6f585f5455254f39aa6..210c1aab3c225543c175d20330a1627d3423a438 100644
(file)
--- a/
lib/python/Components/Converter/ServiceName.py
+++ b/
lib/python/Components/Converter/ServiceName.py
@@
-1,36
+1,51
@@
+# -*- coding: utf-8 -*-
from Components.Converter.Converter import Converter
from Components.Converter.Converter import Converter
-from enigma import iServiceInformation, iPlayableService
+from enigma import iServiceInformation, iPlayableService, iPlayableServicePtr
+from Components.Element import cached
class ServiceName(Converter, object):
NAME = 0
PROVIDER = 1
class ServiceName(Converter, object):
NAME = 0
PROVIDER = 1
+ REFERENCE = 2
- def __init__(self, type
, *args, **kwargs
):
- Converter.__init__(self)
+ def __init__(self, type):
+ Converter.__init__(self
, type
)
if type == "Provider":
self.type = self.PROVIDER
if type == "Provider":
self.type = self.PROVIDER
+ elif type == "Reference":
+ self.type = self.REFERENCE
else:
self.type = self.NAME
else:
self.type = self.NAME
- def getServiceInfoValue(self, info, what):
- v = info.getInfo(what)
- if v !=
-2
:
+ def getServiceInfoValue(self, info, what
, ref=None
):
+ v =
ref and info.getInfo(ref, what) or
info.getInfo(what)
+ if v !=
iServiceInformation.resIsString
:
return "N/A"
return "N/A"
- return info.getInfoString(what)
+ return
ref and info.getInfoString(ref, what) or
info.getInfoString(what)
+ @cached
def getText(self):
service = self.source.service
def getText(self):
service = self.source.service
- info = service and service.info()
+ if isinstance(service, iPlayableServicePtr):
+ info = service and service.info()
+ ref = None
+ else: # reference
+ info = service and self.source.info
+ ref = service
if info is None:
return ""
if info is None:
return ""
-
if self.type == self.NAME:
if self.type == self.NAME:
- return info.getName()
+ name = ref and info.getName(ref)
+ if name is None:
+ name = info.getName()
+ return name.replace('\xc2\x86', '').replace('\xc2\x87', '')
elif self.type == self.PROVIDER:
elif self.type == self.PROVIDER:
- return self.getServiceInfoValue(info, iServiceInformation.sProvider)
+ return self.getServiceInfoValue(info, iServiceInformation.sProvider, ref)
+ elif self.type == self.REFERENCE:
+ return self.getServiceInfoValue(info, iServiceInformation.sServiceref, ref)
text = property(getText)
text = property(getText)
- def changed(self,
*args
):
- if
not len(args) or args[0] in [iPlayableService.evStart, iPlayableService.evEnd]
:
- Converter.changed(self)
+ def changed(self,
what
):
+ if
what[0] != self.CHANGED_SPECIFIC or what[1] in (iPlayableService.evStart,)
:
+ Converter.changed(self
, what
)