From: hschang Date: Fri, 2 Nov 2018 08:25:55 +0000 (+0900) Subject: [ChannelSelection] Fix to remove terrestrial/cable services in channel list. X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=commitdiff_plain;h=dad72faaed7b58cf7a6ec324e1a8652548ec7162 [ChannelSelection] Fix to remove terrestrial/cable services in channel list. --- diff --git a/lib/python/Screens/ChannelSelection.py b/lib/python/Screens/ChannelSelection.py index fc176a7..6882a93 100755 --- a/lib/python/Screens/ChannelSelection.py +++ b/lib/python/Screens/ChannelSelection.py @@ -141,8 +141,14 @@ class ChannelContextMenu(Screen): if not inBouquet: append_when_current_valid(current, menu, (_("add service to favourites"), self.addServiceToBouquetSelected), level = 0) else: - if current_root.getPath().find('FROM SATELLITES') != -1: - append_when_current_valid(current, menu, (_("remove selected satellite"), self.removeSatelliteServices), level = 0) + if 'FROM SATELLITES' in current_root.getPath() and _("Services") in eServiceCenter.getInstance().info(current).getName(current): + unsigned_orbpos = current.getUnsignedData(4) >> 16 + if unsigned_orbpos == 0xFFFF: #Cable + append_when_current_valid(current, menu, (_("remove cable services"), self.removeSatelliteServices), level = 0) + elif unsigned_orbpos == 0xEEEE: #Terrestrial + append_when_current_valid(current, menu, (_("remove terrestrial services"), self.removeSatelliteServices), level = 0) + else: + append_when_current_valid(current, menu, (_("remove selected satellite"), self.removeSatelliteServices), level = 0) if haveBouquets: if not inBouquet and current_sel_path.find("PROVIDERS") == -1: append_when_current_valid(current, menu, (_("copy to bouquets"), self.copyCurrentToBouquetList), level = 0) @@ -260,14 +266,7 @@ class ChannelContextMenu(Screen): self.close(False) def removeSatelliteServices(self): - curpath = self.csel.getCurrentSelection().getPath() - idx = curpath.find("satellitePosition == ") - if idx != -1: - tmp = curpath[idx+21:] - idx = tmp.find(')') - if idx != -1: - satpos = int(tmp[:idx]) - eDVBDB.getInstance().removeServices(-1, -1, -1, satpos) + self.csel.removeSatelliteServices() self.close() def copyCurrentToBouquetList(self): @@ -571,6 +570,55 @@ class ChannelSelectionEdit: except OSError: print "error during remove of", filename + def removeSatelliteServices(self): + current = self.getCurrentSelection() + unsigned_orbpos = current.getUnsignedData(4) >> 16 + if unsigned_orbpos == 0XFFFF: + msg = _("Are you sure to remove all cable services?") + elif unsigned_orbpos == 0XEEEE: + msg = _("Are you sure to remove all terrestrial services?") + else: + orbpos = current.getData(4) >> 16 + try: + service_name = str(nimmanager.getSatDescription(orbpos)) + except: + if orbpos > 1800: # west + orbpos = 3600 - orbpos + h = _("W") + else: + h = _("E") + service_name = ("%d.%d" + h) % (orbpos / 10, orbpos % 10) + msg = _("Are you sure to remove all %s services?" % service_name) + self.session.openWithCallback(self.removeSatelliteServicesCallback, MessageBox, msg) + + def removeSatelliteServicesCallback(self, res): + if not res: + return + + currentIndex = self.servicelist.getCurrentIndex() + current = self.getCurrentSelection() + unsigned_orbpos = current.getUnsignedData(4) >> 16 + if unsigned_orbpos == 0XFFFF: + eDVBDB.getInstance().removeServices(0xFFFF0000 - 0x100000000) + elif unsigned_orbpos == 0XEEEE: + eDVBDB.getInstance().removeServices(0xEEEE0000 - 0x100000000) + else: + curpath = self.getCurrentSelection().getPath() + idx = curpath.find("satellitePosition == ") + if idx != -1: + tmp = curpath[idx+21:] + idx = tmp.find(')') + if idx != -1: + satpos = int(tmp[:idx]) + eDVBDB.getInstance().removeServices(-1, -1, -1, satpos) + + if hasattr(self, 'setMode') and hasattr(self, 'showSatellites'): + self.setMode() + self.showSatellites() + self.servicelist.moveToIndex(currentIndex) + if currentIndex != self.servicelist.getCurrentIndex(): + self.servicelist.instance.moveSelection(self.servicelist.instance.moveEnd) + # multiple marked entry stuff ( edit mode, later multiepg selection ) def startMarkedEdit(self, type): self.savedPath = self.servicePath[:]