aboutsummaryrefslogtreecommitdiff
path: root/lib/python
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2005-12-19 14:35:19 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2005-12-19 14:35:19 +0000
commitf973710dc6bcfc13f8db4e5720dd2aeb1518b012 (patch)
tree2587e239e9fa626bf4c478f08a8946bb7f66434c /lib/python
parent4aa7b11f525aaa22b3ad6b0d247ea67f39b498de (diff)
downloadenigma2-f973710dc6bcfc13f8db4e5720dd2aeb1518b012.tar.gz
enigma2-f973710dc6bcfc13f8db4e5720dd2aeb1518b012.zip
show real satellite name in satellite list
Diffstat (limited to 'lib/python')
-rw-r--r--lib/python/Components/ServiceList.py12
-rw-r--r--lib/python/Screens/ChannelSelection.py39
2 files changed, 41 insertions, 10 deletions
diff --git a/lib/python/Components/ServiceList.py b/lib/python/Components/ServiceList.py
index d24f956a..4c10c660 100644
--- a/lib/python/Components/ServiceList.py
+++ b/lib/python/Components/ServiceList.py
@@ -79,9 +79,17 @@ class ServiceList(HTMLComponent, GUIComponent):
def setPlayableIgnoreService(self, ref):
self.l.setIgnoreService(ref)
- def setRoot(self, root):
+ def setRoot(self, root, justSet=False):
self.root = root
- self.l.setRoot(root)
+ self.l.setRoot(root, justSet)
+ if not justSet:
+ self.l.sort()
+
+ def addService(self, service):
+ self.l.addService(service)
+
+ def finishFill(self):
+ self.l.FillFinished()
self.l.sort()
# stuff for multiple marks (edit mode / later multiepg)
diff --git a/lib/python/Screens/ChannelSelection.py b/lib/python/Screens/ChannelSelection.py
index c7d8d167..a7752274 100644
--- a/lib/python/Screens/ChannelSelection.py
+++ b/lib/python/Screens/ChannelSelection.py
@@ -7,6 +7,7 @@ from enigma import eServiceReference, eEPGCache, eEPGCachePtr, eServiceCenter, e
from Components.config import config, configElement, ConfigSubsection, configText
from Screens.FixedMenu import FixedMenu
from Tools.NumericalTextInput import NumericalTextInput
+from Components.NimManager import nimmanager
import xml.dom.minidom
@@ -34,7 +35,7 @@ class ChannelContextMenu(FixedMenu):
haveBouquets = csel.bouquet_root.getPath().find('FROM BOUQUET "bouquets.') != -1
if not csel.bouquet_mark_edit and not csel.movemode and not inBouquetRootList:
- if (csel.getCurrentSelection().type & eServiceReference.flagDirectory) != eServiceReference.flagDirectory:
+ if (csel.getCurrentSelection().flags & eServiceReference.flagDirectory) != eServiceReference.flagDirectory:
if haveBouquets:
menu.append((_("add service to bouquet"), self.addServiceToBouquetSelected))
else:
@@ -251,8 +252,8 @@ class ChannelSelectionBase(Screen):
self.service_types = self.service_types_tv
- #self.bouquet_root = eServiceReference('1:7:1:0:0:0:0:0:0:0:(type == 1) FROM BOUQUET "bouquets.tv" ORDER BY bouquet')
- self.bouquet_root = eServiceReference('%s FROM BOUQUET "userbouquet.favourites.tv" ORDER BY bouquet'%(self.service_types))
+ self.bouquet_root = eServiceReference('1:7:1:0:0:0:0:0:0:0:(type == 1) FROM BOUQUET "bouquets.tv" ORDER BY bouquet')
+ #self.bouquet_root = eServiceReference('%s FROM BOUQUET "userbouquet.favourites.tv" ORDER BY bouquet'%(self.service_types))
self["key_red"] = Button(_("All"))
self["key_green"] = Button(_("Satellites"))
@@ -290,14 +291,14 @@ class ChannelSelectionBase(Screen):
offsetCount += 1
return offsetCount
- def setRootBase(self, root):
+ def setRootBase(self, root, justSet=False):
inBouquetRootList = root.getPath().find('FROM BOUQUET "bouquets.') != -1 #FIXME HACK
if not inBouquetRootList and (root.getPath().find('FROM BOUQUET') != -1):
self.servicelist.setMode(ServiceList.MODE_FAVOURITES)
self.servicelist.setNumberOffset(self.getBouquetNumOffset(root))
else:
self.servicelist.setMode(ServiceList.MODE_NORMAL)
- self.servicelist.setRoot(root)
+ self.servicelist.setRoot(root, justSet)
def moveUp(self):
self.servicelist.moveUp()
@@ -311,7 +312,29 @@ class ChannelSelectionBase(Screen):
def showSatellites(self):
ref = eServiceReference('%s FROM SATELLITES ORDER BY satellitePosition'%(self.service_types))
- self.setRoot(ref)
+ self.setRoot(ref, True)
+ serviceHandler = eServiceCenter.getInstance()
+ servicelist = serviceHandler.list(ref)
+ if not servicelist is None:
+ while True:
+ service = servicelist.getNext()
+ if not service.valid(): #check if end of list
+ break
+ orbpos = service.getData(4) >> 16
+ if service.getPath().find("FROM PROVIDER") != -1:
+ service_name = _("Providers")
+ else:
+ service_name = _("Services")
+ try:
+ service_name += ' - %s'%(nimmanager.getSatDescription(orbpos))
+ service.setName(str(service_name)) # why we need this cast?
+ except:
+ if orbpos > 1800: # west
+ service.setName("%s (%3.1fW)"%(str, (0 - (orbpos - 3600)) / 10.0))
+ else:
+ service.setName("%s (%3.1fE)"%(str, orbpos / 10.0))
+ self.servicelist.addService(service)
+ self.servicelist.finishFill()
def showProviders(self):
ref = eServiceReference('%s FROM PROVIDERS ORDER BY name'%(self.service_types))
@@ -432,9 +455,9 @@ class ChannelSelection(ChannelSelectionBase, ChannelSelectionEdit):
self.zap()
self.close(ref)
- def setRoot(self, root):
+ def setRoot(self, root, justSet=False):
if not self.movemode:
- self.setRootBase(root)
+ self.setRootBase(root, justSet)
#called from infoBar and channelSelected
def zap(self):