add some stuff
[enigma2.git] / lib / python / Components / NimManager.py
index 2086bee839b08131e808499e4d6be579f33d0e7a..09928d07f0104811f111412318dd0430551dc8cf 100644 (file)
@@ -8,6 +8,7 @@ from config import configSequence
 from config import configsequencearg
 from config import configSatlist
 
+from enigma import *
 
 import xml.dom.minidom
 from xml.dom import EMPTY_NAMESPACE
@@ -17,6 +18,65 @@ from Tools import XMLTools
 from xml.sax import make_parser
 from xml.sax.handler import ContentHandler
 
+class SecConfigure:
+       def addLNBSimple(self, slotid, orbpos, toneburstmode, diseqcmode, diseqcpos):
+               #simple defaults
+               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
+               sec.setDiSEqCMode(diseqcmode)
+               sec.setToneburst(toneburstmode)
+               sec.setCommittedCommand(diseqcpos)
+               #print "set orbpos to:" + str(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(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
+                                       print "FIXME add support for advanced config"
+               
+       def __init__(self, nimmgr):
+               self.NimManager = nimmgr
+               self.update()
+               
 class boundFunction:
        def __init__(self, fnc, *args):
                self.fnc = fnc
@@ -45,27 +105,20 @@ 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 = { }
 
-               #FIXME: path ok???
                print "Reading satellites.xml"
                parser = make_parser()
                satHandler = self.parseSats(self.satList, self.satellites)
                parser.setContentHandler(satHandler)
                parser.parse('/etc/tuxbox/satellites.xml')
-    
-               #satdom = xml.dom.minidom.parse('/etc/tuxbox/satellites.xml')
-
-
-               #for entries in elementsWithTag(satdom.childNodes, "satellites"):
-                       #for x in elementsWithTag(entries.childNodes, "sat"):
-                               ##print "found sat " + x.getAttribute('name') + " " + str(x.getAttribute('position'))
-                               #tpos = x.getAttribute('position')
-                               #tname = x.getAttribute('name')
-                               ##tname.encode('utf8')
-                               #self.satellites[tpos] = tname
-                               #self.satList.append( (tname, tpos) )
 
        def getNimType(self, slotID):
                #FIXME get it from /proc
@@ -121,10 +174,10 @@ class NimManager:
                return list
        
        def getSatListForNim(self, slotid):
-               print "slotid:", slotid
+               #print "slotid:", slotid
                list = []
-               print "self.satellites:", self.satList[config.Nims[slotid].diseqcA.value]
-               print "diseqcA:", config.Nims[slotid].diseqcA.value
+               #print "self.satellites:", self.satList[config.Nims[slotid].diseqcA.value]
+               #print "diseqcA:", config.Nims[slotid].diseqcA.value
                if (config.Nims[slotid].diseqcMode.value <= 3):
                        list.append(self.satList[config.Nims[slotid].diseqcA.value])
                if (0 < config.Nims[slotid].diseqcMode.value <= 3):
@@ -136,17 +189,23 @@ class NimManager:
 
        #callbacks for c++ config
        def nimConfigModeChanged(self, slotid, mode):
-               print "nimConfigModeChanged set to " + str(mode)
+               #print "nimConfigModeChanged set to " + str(mode)
+               pass
        def nimDiseqcModeChanged(self, slotid, mode):
-               print "nimDiseqcModeChanged set to " + str(mode)
+               #print "nimDiseqcModeChanged set to " + str(mode)
+               pass
        def nimPortAChanged(self, slotid, val):
-               print "nimDiseqcA set to " + str(val)
+               #print "nimDiseqcA set to " + str(val)
+               pass
        def nimPortBChanged(self, slotid, val):
-               print "nimDiseqcB set to " + str(val)
+               #print "nimDiseqcB set to " + str(val)
+               pass
        def nimPortCChanged(self, slotid, val):
-               print "nimDiseqcC set to " + str(val)
+               #print "nimDiseqcC set to " + str(val)
+               pass
        def nimPortDChanged(self, slotid, val):
-               print "nimDiseqcD set to " + str(val)
+               #print "nimDiseqcD set to " + str(val)
+               pass
 
 
 def InitNimManager(nimmgr):
@@ -169,25 +228,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", [(1,90),(1,999)]));
-                       config.Nims[x].latitude = configElement(cname + "latitude",configSequence, [0,0], configsequencearg.get("FLOAT", [(1,90),(1,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,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()