fix tunerlist, force both tuners as available
[enigma2.git] / lib / python / Components / NimManager.py
index 3b6bfffdeb57e0cb1932c2cc5904e9143db6a713..8bbe2810545f7522cb3e54157b391f91b71a6a7f 100644 (file)
@@ -21,48 +21,53 @@ from xml.sax.handler import ContentHandler
 class SecConfigure:
        def addLNBSimple(self, slotid, orbpos, toneburstmode, diseqcmode, diseqcpos):
                #simple defaults
-               eDVBSatelliteEquipmentControl.getInstance().addLNB()
-               eDVBSatelliteEquipmentControl.getInstance().setLNBTunerMask(1 << slotid)
-               eDVBSatelliteEquipmentControl.getInstance().setLNBLOFL(9750000)
-               eDVBSatelliteEquipmentControl.getInstance().setLNBLOFH(10600000)
-               eDVBSatelliteEquipmentControl.getInstance().setLNBThreshold(11750000)
-               eDVBSatelliteEquipmentControl.getInstance().setRepeats(0)
-               eDVBSatelliteEquipmentControl.getInstance().setFastDiSEqC(0)
-               eDVBSatelliteEquipmentControl.getInstance().setSeqRepeat(0)
-               eDVBSatelliteEquipmentControl.getInstance().setVoltageMode(0) #HV
-               eDVBSatelliteEquipmentControl.getInstance().setToneMode(0)              #HILO
-               eDVBSatelliteEquipmentControl.getInstance().setCommandOrder(0)
+               sec = eDVBSatelliteEquipmentControl.getInstance()
+               sec.addLNB()
+               sec.setLNBTunerMask(1 << slotid)
+               sec.setLNBLOFL(9750000)
+               sec.setLNBLOFH(10600000)
+               sec.setLNBThreshold(11750000)
+               sec.setRepeats(0)
+               sec.setFastDiSEqC(0)
+               sec.setSeqRepeat(0)
+               sec.setVoltageMode(0) #HV
+               sec.setToneMode(0)              #HILO
+               sec.setCommandOrder(0)
                #user values
-               eDVBSatelliteEquipmentControl.getInstance().setDiSEqCMode(diseqcmode)
-               eDVBSatelliteEquipmentControl.getInstance().setToneburst(toneburstmode)
-               eDVBSatelliteEquipmentControl.getInstance().setCommittedCommand(diseqcpos)
-
+               sec.setDiSEqCMode(diseqcmode)
+               sec.setToneburst(toneburstmode)
+               sec.setCommittedCommand(diseqcpos)
                #print "set orbpos to:" + str(orbpos)
-               eDVBSatelliteEquipmentControl.getInstance().addSatellite(orbpos)
+               sec.addSatellite(orbpos)
+               self.satList.append(orbpos)
+
+       def getSatList(self):
+               return self.satList
 
        def update(self):
                eDVBSatelliteEquipmentControl.getInstance().clear()
+               self.satList = []
 
                for slot in self.NimManager.nimslots:
                        x = slot.slotid
+                       nim = config.Nims[x]
                        if slot.nimType == self.NimManager.nimType["DVB-S"]:
-                               print "slot: " + str(x) + " configmode: " + str(config.Nims[x].configMode.value)
-                               if config.Nims[x].configMode.value == 0:                #simple config
-                                       if config.Nims[x].diseqcMode.value == 0:                        #single
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcA.vals[config.Nims[x].diseqcA.value][1]), 0, 0, 4)
-                                       elif config.Nims[x].diseqcMode.value == 1:              #Toneburst A/B
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcA.vals[config.Nims[x].diseqcA.value][1]), 1, 0, 4)
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcB.vals[config.Nims[x].diseqcB.value][1]), 1, 0, 4)
-                                       elif config.Nims[x].diseqcMode.value == 2:              #DiSEqC A/B
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcA.vals[config.Nims[x].diseqcA.value][1]), 0, 1, 0)
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcB.vals[config.Nims[x].diseqcB.value][1]), 0, 1, 1)
-                                       elif config.Nims[x].diseqcMode.value == 3:              #DiSEqC A/B/C/D
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcA.vals[config.Nims[x].diseqcA.value][1]), 0, 1, 0)
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcB.vals[config.Nims[x].diseqcB.value][1]), 0, 1, 1)
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcC.vals[config.Nims[x].diseqcC.value][1]), 0, 1, 2)
-                                               self.addLNBSimple(x, int(config.Nims[x].diseqcD.vals[config.Nims[x].diseqcD.value][1]), 0, 1, 3)
-                                               pass
-                                       elif config.Nims[x].diseqcMode.value == 4:              #Positioner
+                               print "slot: " + str(x) + " configmode: " + str(nim.configMode.value)
+                               if nim.configMode.value == 0:           #simple config
+                                       if nim.diseqcMode.value == 0:                   #single
+                                               self.addLNBSimple(x, int(nim.diseqcA.vals[nim.diseqcA.value][1]), 0, 0, 4)
+                                       elif nim.diseqcMode.value == 1:         #Toneburst A/B
+                                               self.addLNBSimple(x, int(nim.diseqcA.vals[nim.diseqcA.value][1]), 1, 0, 4)
+                                               self.addLNBSimple(x, int(nim.diseqcB.vals[nim.diseqcB.value][1]), 1, 0, 4)
+                                       elif nim.diseqcMode.value == 2:         #DiSEqC A/B
+                                               self.addLNBSimple(x, int(nim.diseqcA.vals[nim.diseqcA.value][1]), 0, 1, 0)
+                                               self.addLNBSimple(x, int(nim.diseqcB.vals[nim.diseqcB.value][1]), 0, 1, 1)
+                                       elif nim.diseqcMode.value == 3:         #DiSEqC A/B/C/D
+                                               self.addLNBSimple(x, int(nim.diseqcA.vals[nim.diseqcA.value][1]), 0, 1, 0)
+                                               self.addLNBSimple(x, int(nim.diseqcB.vals[nim.diseqcB.value][1]), 0, 1, 1)
+                                               self.addLNBSimple(x, int(nim.diseqcC.vals[nim.diseqcC.value][1]), 0, 1, 2)
+                                               self.addLNBSimple(x, int(nim.diseqcD.vals[nim.diseqcD.value][1]), 0, 1, 3)
+                                       elif nim.diseqcMode.value == 4:         #Positioner
                                                print "FIXME: positioner suppport"
                                        pass
                                else:                                                                                                                                   #advanced config
@@ -100,6 +105,12 @@ class NimManager:
                                self.satellites[tpos] = tname
                                self.satList.append( (tname, tpos) )
 
+       def getConfiguredSats(self):
+               return self.sec.getSatList()
+
+       def getSatDescription(self, pos):
+               return self.satellites[str(pos)]
+
        def readSatsfromFile(self):
                self.satellites = { }
 
@@ -113,6 +124,8 @@ class NimManager:
                #FIXME get it from /proc
                if slotID == 0:
                        return self.nimType["DVB-S"]
+               elif slotID == 1:
+                       return self.nimType["DVB-S"]
                else:
                        return self.nimType["empty/unknown"]
 
@@ -184,9 +197,10 @@ class NimManager:
                #print "nimDiseqcModeChanged set to " + str(mode)
                pass
        def nimPortAChanged(self, slotid, val):
-               #print "nimDiseqcA set to " + str(val)
+               #print "nimDiseqcA set to " + str(slotid) + " val:" + str(val)
                pass
        def nimPortBChanged(self, slotid, val):
+               #print "nimDiseqcA set to " + str(slotid) + " val:" + str(val)
                #print "nimDiseqcB set to " + str(val)
                pass
        def nimPortCChanged(self, slotid, val):
@@ -198,8 +212,10 @@ class NimManager:
 
 
 def InitNimManager(nimmgr):
-       config.Nims = [ConfigSubsection()] * nimmgr.nimCount
-
+       config.Nims = []
+       for x in range(nimmgr.nimCount):
+               config.Nims.append(ConfigSubsection())
+               
        def nimConfigModeChanged(slotid, configElement):
                nimmgr.nimConfigModeChanged(slotid, configElement.value)
        def nimDiseqcModeChanged(slotid, configElement):
@@ -217,27 +233,28 @@ def InitNimManager(nimmgr):
        for slot in nimmgr.nimslots:
                x = slot.slotid
                cname = nimmgr.getConfigPrefix(x)
+               nim = config.Nims[x]
                
                if slot.nimType == nimmgr.nimType["DVB-S"]:
-                       config.Nims[x].configMode = configElement(cname + "configMode",configSelection, 0, ("Simple", "Advanced"));
-                       config.Nims[x].diseqcMode = configElement(cname + "diseqcMode",configSelection, 2, ("Single", "Toneburst A/B", "DiSEqC A/B", "DiSEqC A/B/C/D", "Positioner"));
-                       config.Nims[x].diseqcA = configElement(cname + "diseqcA",configSatlist, 192, nimmgr.satList);
-                       config.Nims[x].diseqcB = configElement(cname + "diseqcB",configSatlist, 130, nimmgr.satList);
-                       config.Nims[x].diseqcC = configElement(cname + "diseqcC",configSatlist, 0, nimmgr.satList);
-                       config.Nims[x].diseqcD = configElement(cname + "diseqcD",configSatlist, 0, nimmgr.satList);
-                       config.Nims[x].longitude = configElement(cname + "longitude",configSequence, [0,0], configsequencearg.get("FLOAT", [(0,90),(0,999)]));
-                       config.Nims[x].latitude = configElement(cname + "latitude",configSequence, [0,0], configsequencearg.get("FLOAT", [(0,90),(0,999)]));
+                       nim.configMode = configElement(cname + "configMode",configSelection, 0, ("Simple", "Advanced"));
+                       nim.diseqcMode = configElement(cname + "diseqcMode",configSelection, 2, ("Single", "Toneburst A/B", "DiSEqC A/B", "DiSEqC A/B/C/D", "Positioner"));
+                       nim.diseqcA = configElement(cname + "diseqcA",configSatlist, 192, nimmgr.satList);
+                       nim.diseqcB = configElement(cname + "diseqcB",configSatlist, 130, nimmgr.satList);
+                       nim.diseqcC = configElement(cname + "diseqcC",configSatlist, 0, nimmgr.satList);
+                       nim.diseqcD = configElement(cname + "diseqcD",configSatlist, 0, nimmgr.satList);
+                       nim.longitude = configElement(cname + "longitude",configSequence, [0,0], configsequencearg.get("FLOAT", [(0,90),(0,999)]));
+                       nim.latitude = configElement(cname + "latitude",configSequence, [0,0], configsequencearg.get("FLOAT", [(0,90),(0,999)]));
                        
                        #perhaps the instance of the slot is more useful?
-                       config.Nims[x].configMode.addNotifier(boundFunction(nimConfigModeChanged,x))
-                       config.Nims[x].diseqcMode.addNotifier(boundFunction(nimDiseqcModeChanged,x))
-                       config.Nims[x].diseqcA.addNotifier(boundFunction(nimPortAChanged,x))
-                       config.Nims[x].diseqcB.addNotifier(boundFunction(nimPortBChanged,x))
-                       config.Nims[x].diseqcC.addNotifier(boundFunction(nimPortCChanged,x))
-                       config.Nims[x].diseqcD.addNotifier(boundFunction(nimPortDChanged,x))
+                       nim.configMode.addNotifier(boundFunction(nimConfigModeChanged,x))
+                       nim.diseqcMode.addNotifier(boundFunction(nimDiseqcModeChanged,x))
+                       nim.diseqcA.addNotifier(boundFunction(nimPortAChanged,int(x)))
+                       nim.diseqcB.addNotifier(boundFunction(nimPortBChanged,x))
+                       nim.diseqcC.addNotifier(boundFunction(nimPortCChanged,x))
+                       nim.diseqcD.addNotifier(boundFunction(nimPortDChanged,x))
                else:
                        print "pls add support for this frontend type!"         
-                       
+
        nimmgr.sec = SecConfigure(nimmgr)
 
 nimmanager = NimManager()