fix typo
[enigma2.git] / lib / python / Screens / ScanSetup.py
index 6d51d015a52305578517114de9e077612f753bc6..6a9b0a799881e437802386c9234aa93378536532 100644 (file)
@@ -83,6 +83,8 @@ def getInitialTransponderList(tlist, pos):
                        #parm.inversion = 1     #eDVBFrontendParametersSatellite.Inversion.Off;
                        parm.inversion = 2              #AUTO
                        parm.orbital_position = pos
+                       parm.system = x[5]  #DVB-S or DVB-S2
+                       parm.modulation = x[6]
                        tlist.append(parm)
 
 def getInitialCableTransponderList(tlist, cable):
@@ -178,6 +180,7 @@ class ScanSetup(Screen):
                self.list.append(self.tunerEntry)
                
                self.typeOfScanEntry = None
+               self.systemEntry = None
                if (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-S"]):
                        self.typeOfScanEntry = getConfigListEntry(_("Type of scan"), config.scan.type)
                        self.list.append(self.typeOfScanEntry)
@@ -192,12 +195,18 @@ class ScanSetup(Screen):
                if (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-S"]):
 
                        if currentConfigSelectionElement(config.scan.type) == "single_transponder":
+                               self.systemEntry = getConfigListEntry(_('Transpondertype'), config.scan.sat.system)
+                               self.list.append(self.systemEntry)
                                self.list.append(getConfigListEntry(_('Satellite'), config.scan.satselection[config.scan.nims.value]))
                                self.list.append(getConfigListEntry(_('Frequency'), config.scan.sat.frequency))
                                self.list.append(getConfigListEntry(_('Inversion'), config.scan.sat.inversion))
                                self.list.append(getConfigListEntry(_('Symbol Rate'), config.scan.sat.symbolrate))
                                self.list.append(getConfigListEntry(_("Polarity"), config.scan.sat.polarization))
-                               self.list.append(getConfigListEntry(_("FEC"), config.scan.sat.fec))
+                               if currentConfigSelectionElement(config.scan.sat.system) == "dvb-s":
+                                       self.list.append(getConfigListEntry(_("FEC"), config.scan.sat.fec))
+                               elif currentConfigSelectionElement(config.scan.sat.system) == "dvb-s2":
+                                       self.list.append(getConfigListEntry(_("FEC"), config.scan.sat.fec_s2))
+                                       self.list.append(getConfigListEntry(_('Modulation'), config.scan.sat.modulation))
                        elif currentConfigSelectionElement(config.scan.type) == "single_satellite":
                                self.updateSatList()
                                print config.scan.satselection[config.scan.nims.value]
@@ -245,19 +254,20 @@ class ScanSetup(Screen):
                                self.list.append(getConfigListEntry(_("Hierarchy mode"), config.scan.ter.hierarchy))
                        elif currentConfigSelectionElement(config.scan.typeterrestrial) == "complete":
                                self.list.append(getConfigListEntry(_("Clear before scan"), config.scan.clearallservices))
-
-               if (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-S"] and currentConfigSelectionElement(config.scan.type) == "single_transponder") or \
-                       (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-C"] and currentConfigSelectionElement(config.scan.typecable) == "single_transponder") or \
-                       (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-T"] and currentConfigSelectionElement(config.scan.typeterrestrial) == "single_transponder"):
-                               self.configElementSNR = getConfigListEntry(_("SNR"), config.scan.snr)
-                               self.list.append(self.configElementSNR)
-                               self.configElementACG = getConfigListEntry(_("AGC"), config.scan.agc)
-                               self.list.append(self.configElementACG)
-                               self.configElementBER = getConfigListEntry(_("BER"), config.scan.ber)
-                               self.list.append(self.configElementBER)
-                               self.statusTimer.start(500, False)
-               else:
-                       self.statusTimer.stop()
+                       self.list.append(getConfigListEntry(_("Enable 5V for active antenna"), config.terrestrial.enable_5V))
+
+#              if (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-S"] and currentConfigSelectionElement(config.scan.type) == "single_transponder") or \
+#                      (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-C"] and currentConfigSelectionElement(config.scan.typecable) == "single_transponder") or \
+#                      (nimmanager.getNimType(config.scan.nims.value) == nimmanager.nimType["DVB-T"] and currentConfigSelectionElement(config.scan.typeterrestrial) == "single_transponder"):
+#                              self.configElementSNR = getConfigListEntry(_("SNR"), config.scan.snr)
+#                              self.list.append(self.configElementSNR)
+#                              self.configElementACG = getConfigListEntry(_("AGC"), config.scan.agc)
+#                              self.list.append(self.configElementACG)
+#                              self.configElementBER = getConfigListEntry(_("BER"), config.scan.ber)
+#                              self.list.append(self.configElementBER)
+#                              self.statusTimer.start(500, False)
+#              else:
+#                      self.statusTimer.stop()
 
                self["config"].list = self.list
                self["config"].l.setList(self.list)
@@ -272,7 +282,9 @@ class ScanSetup(Screen):
                print self["config"].getCurrent()
                if self["config"].getCurrent() == self.typeOfScanEntry:
                        self.createSetup()
-               if self["config"].getCurrent() == self.tunerEntry:
+               elif self["config"].getCurrent() == self.tunerEntry:
+                       self.createSetup()
+               elif self["config"].getCurrent() == self.systemEntry:
                        self.createSetup()
 
        def createConfig(self):
@@ -284,7 +296,7 @@ class ScanSetup(Screen):
                        config.scan.type = configElement_nonSave("config.scan.type", configSelection, 0, (("single_transponder", _("Single transponder")), ("single_satellite", _("Single satellite")), ("multisat", _("Multisat"))))
                        config.scan.typecable = configElement_nonSave("config.scan.typecable", configSelection, 0, (("single_transponder", _("Single transponder")), ("complete", _("Complete"))))
                        config.scan.typeterrestrial = configElement_nonSave("config.scan.typeterrestrial", configSelection, 0, (("single_transponder", _("Single transponder")), ("complete", _("Complete"))))
-                       config.scan.clearallservices = configElement_nonSave("config.scan.clearallservices", configSelection, 0, (("no", _("no")), ("yes", _("yes")), ("yes_hold_feeds", _("yes (hold feeds)"))))
+                       config.scan.clearallservices = configElement_nonSave("config.scan.clearallservices", configSelection, 0, (("no", _("no")), ("yes", _("yes")), ("yes_hold_feeds", _("yes (keep feeds)"))))
 
                        nimList = [ ]
                        for nim in nimmanager.nimList():
@@ -306,9 +318,10 @@ class ScanSetup(Screen):
                        config.scan.sat.inversion = configElement_nonSave("config.scan.sat.inversion", configSelection, 2, (("off", _("off")), ("on", _("on")), _("Auto")))
                        config.scan.sat.symbolrate = configElement_nonSave("config.scan.sat.symbolrate", configSequence, [27500], configsequencearg.get("INTEGER", (1, 99999)))
                        config.scan.sat.polarization = configElement_nonSave("config.scan.sat.polarization", configSelection, 0, (("horizontal", _("horizontal")), ("vertical", _("vertical")),  ("circular_left", _("circular left")), ("circular_right", _("circular right"))))
-                       config.scan.sat.fec = configElement_nonSave("config.scan.sat.fec", configSelection, 7, (("auto", _("Auto")), ("1_2", "1/2"), ("2_3", "2/3"), ("3_4", "3/4"), ("5_6", "5/6"), ("7_8", "7/8"), ("none", _("None"))))
-                       config.scan.sat.fec_s2 = configElement_nonSave("config.scan.sat.fec_s2", configSelection, 8, (("1_2", "1/2"), ("2_3", "2/3"), ("3_4", "3/4"), ("3_5", "3/5"), ("4_5", "4/5"), ("5_6", "5/6"), ("7_8", "7/8"), ("8_9", "8/9"), ("9_10", "9/10"))))
-
+                       config.scan.sat.fec = configElement_nonSave("config.scan.sat.fec", configSelection, 0, (("auto", _("Auto")), ("1_2", "1/2"), ("2_3", "2/3"), ("3_4", "3/4"), ("5_6", "5/6"), ("7_8", "7/8"), ("none", _("None"))))
+                       config.scan.sat.fec_s2 = configElement_nonSave("config.scan.sat.fec_s2", configSelection, 8, (("1_2", "1/2"), ("2_3", "2/3"), ("3_4", "3/4"), ("3_5", "3/5"), ("4_5", "4/5"), ("5_6", "5/6"), ("7_8", "7/8"), ("8_9", "8/9"), ("9_10", "9/10")))
+                       config.scan.sat.modulation = configElement_nonSave("config.scan.sat.modulation", configSelection, 0, (("qpsk", "QPSK"), ("8psk", "8PSK")))
+       
                        # cable
                        config.scan.cab.frequency = configElement_nonSave("config.scan.cab.frequency", configSequence, [466], configsequencearg.get("INTEGER", (50, 999)))
                        config.scan.cab.inversion = configElement_nonSave("config.scan.cab.inversion", configSelection, 2, (("off", _("off")), ("on", _("on")), ("auto", _("Auto"))))
@@ -360,15 +373,32 @@ class ScanSetup(Screen):
                if (self["config"].getCurrent()[1].parent.enabled == True):
                        self["config"].handleKey(config.key[str(number)])
 
-       def addSatTransponder(self, tlist, frequency, symbol_rate, polarisation, fec, inversion, orbital_position, system):
+       fecmap = { "auto": 0,
+                          "1_2": 1,
+                          "2_3": 2,
+                          "3_4": 3,
+                          "5_6": 4,
+                          "7_8": 5,
+                          "8_9": 6,
+                          "3_5": 7,
+                          "4_5": 8,
+                          "9_10": 9,
+                          "none": 15
+                          }
+
+       def addSatTransponder(self, tlist, frequency, symbol_rate, polarisation, fec, inversion, orbital_position, system, modulation):
                print "Add Sat: frequ: " + str(frequency) + " symbol: " + str(symbol_rate) + " pol: " + str(polarisation) + " fec: " + str(fec) + " inversion: " + str(inversion)
                print "orbpos: " + str(orbital_position)
                parm = eDVBFrontendParametersSatellite()
+               if modulation == 1:
+                       parm.modulation = 2 # eDVBFrontendParametersSatellite.Modulation.8PSK
+               else:
+                       parm.modulation = 1 # eDVBFrontendParametersSatellite.Modulation.QPSK
                parm.system = system
                parm.frequency = frequency * 1000
                parm.symbol_rate = symbol_rate * 1000
                parm.polarisation = polarisation # eDVBFrontendParametersSatellite.Polarisation.Verti
-               parm.fec = fec                  # eDVBFrontendParametersSatellite.FEC.f3_4;
+               parm.fec = self.fecmap[fec]                     # eDVBFrontendParametersSatellite.FEC.f3_4;
                #parm.fec = 6                                   # AUTO
                parm.inversion = inversion      #eDVBFrontendParametersSatellite.Inversion.Off;
                #parm.inversion = 2             #AUTO
@@ -405,13 +435,18 @@ class ScanSetup(Screen):
                                                l = len(nimsats)
                                                if l and l > selsatidx:
                                                        orbpos=nimsats[selsatidx][1]
+                                                       if currentConfigSelectionElement(config.scan.sat.system) == "dvb-s":
+                                                               fec = currentConfigSelectionElement(config.scan.sat.fec)
+                                                       else:
+                                                               fec = currentConfigSelectionElement(config.scan.sat.fec_s2)
                                                        self.addSatTransponder(tlist, config.scan.sat.frequency.value[0],
                                                                                config.scan.sat.symbolrate.value[0],
                                                                                config.scan.sat.polarization.value,
-                                                                               config.scan.sat.fec.value,
+                                                                               fec,
                                                                                config.scan.sat.inversion.value,
+                                                                               orbpos,
                                                                                config.scan.sat.system.value,
-                                                                               orbpos)
+                                                                               config.scan.sat.modulation)
                        elif currentConfigSelectionElement(config.scan.type) == "single_satellite":
                                sat = self.satList[config.scan.nims.value][config.scan.satselection[config.scan.nims.value].value]
                                getInitialTransponderList(tlist, int(sat[1]))
@@ -604,19 +639,29 @@ class ScanSimple(Screen):
                tlist = []
 
                nimcount = nimmanager.getNimSocketCount()
+               have_terrestrial = False
                if nimcount > 0:
+                       nimtype = nimmanager.getNimType(0)
                        scan_possible=True
                        config.scan = ConfigSubsection()
-                       config.scan.clearallservices = configElement_nonSave("config.scan.clearallservices", configSelection, 0, (("no", _("no")), ("yes", _("yes")), ("yes_hold_feeds", _("yes (hold feeds)"))))
+                       config.scan.clearallservices = configElement_nonSave("config.scan.clearallservices", configSelection, 0, (("no", _("no")), ("yes", _("yes")), ("yes_hold_feeds", _("yes (keep feeds)"))))
                        self.list.append(getConfigListEntry(_("Clear before scan"), config.scan.clearallservices))
                        nim = configElement_nonSave(0, configSelection, 0, (("yes", _("yes")), ("no", _("no"))))
-                       if nimmanager.getNimType(0) == nimmanager.nimType["DVB-S"] and not len(nimmanager.getSatListForNim(0)):
+                       if nimtype == nimmanager.nimType["DVB-T"]:
+                               have_terrestrial = True
+                       elif nimtype == nimmanager.nimType["DVB-S"] and not len(nimmanager.getSatListForNim(0)):
                                scan_possible=False
                        if scan_possible:
                                self.list.append(getConfigListEntry(_("Scan NIM") + " 0 (" + nimmanager.getNimTypeName(0) + ")", nim))
+       
                if nimcount > 1 and self.ScanNimTwoNeeded():
                        nim = configElement_nonSave(1, configSelection, 0, (("yes", _("yes")), ("no", _("no"))))
                        self.list.append(getConfigListEntry(_("Scan NIM") + " 1 (" + nimmanager.getNimTypeName(1) + ")", nim))
+                       if nimmanager.getNimType(1) == nimmanager.nimType["DVB-T"]:
+                               have_terrestrial = True
+
+               if have_terrestrial:
+                       self.list.append(getConfigListEntry(_("Enable 5V for active antenna"), config.terrestrial.enable_5V))
 
                self["config"] = ConfigList(self.list)
                self["header"] = Label(_("Automatic Scan"))