git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
DreamInfoHandler.py: small update for new index.xml's.
[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 79e0c9971afadedaf7121ee983aa40ea8ec7a5b9..210c1aab3c225543c175d20330a1627d3423a438 100644
(file)
--- a/
lib/python/Components/Converter/ServiceName.py
+++ b/
lib/python/Components/Converter/ServiceName.py
@@
-1,32
+1,51
@@
+# -*- coding: utf-8 -*-
from Components.Converter.Converter import Converter
from Components.Converter.Converter import Converter
-from enigma import iServiceInformation
+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 service.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, what):
+ if what[0] != self.CHANGED_SPECIFIC or what[1] in (iPlayableService.evStart,):
+ Converter.changed(self, what)