+def tryOpen(filename):
+ try:
+ procFile = open(filename)
+ except IOError:
+ return ""
+ return procFile
+
+class SecConfigure:
+ def addLNBSimple(self, slotid, diseqcmode, toneburstmode = 0, diseqcpos = 0, orbpos = 0, longitude = 0, latitude = 0, loDirection = 0, laDirection = 0):
+ #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)
+
+ if (0 <= diseqcmode < 3):
+ sec.addSatellite(orbpos)
+ self.satList.append(orbpos)
+ elif (diseqcmode == 3): # diseqc 1.2
+ sec.setLatitude(latitude)
+ sec.setLaDirection(laDirection)
+ sec.setLongitude(longitude)
+ sec.setLoDirection(loDirection)
+ sec.setUseInputpower(True)
+ sec.setInputpowerDelta(50)
+
+ for x in self.NimManager.satList:
+ print "Add sat " + str(x[1])
+ sec.addSatellite(int(x[1]))
+ sec.setVoltageMode(0)
+ sec.setToneMode(0)
+ self.satList.append(int(x[1]))
+
+
+ def linkNIMs(self, nim1, nim2):
+ eDVBSatelliteEquipmentControl.getInstance().setTunerLinked(nim1, nim2)
+
+ 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 == 1:
+ self.linkNIMs(x, nim.linkedTo.value)
+ nim = config.Nims[nim.linkedTo.value]
+ if nim.configMode.value == 0: #simple config
+ if nim.diseqcMode.value == 0: #single
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcA.vals[nim.diseqcA.value][1]), toneburstmode = 0, diseqcmode = 0, diseqcpos = 4)
+ elif nim.diseqcMode.value == 1: #Toneburst A/B
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcA.vals[nim.diseqcA.value][1]), toneburstmode = 1, diseqcmode = 0, diseqcpos = 4)
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcB.vals[nim.diseqcB.value][1]), toneburstmode = 1, diseqcmode = 0, diseqcpos = 4)
+ elif nim.diseqcMode.value == 2: #DiSEqC A/B
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcA.vals[nim.diseqcA.value][1]), toneburstmode = 0, diseqcmode = 1, diseqcpos = 0)
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcB.vals[nim.diseqcB.value][1]), toneburstmode = 0, diseqcmode = 1, diseqcpos = 1)
+ elif nim.diseqcMode.value == 3: #DiSEqC A/B/C/D
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcA.vals[nim.diseqcA.value][1]), toneburstmode = 0, diseqcmode = 1, diseqcpos = 0)
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcB.vals[nim.diseqcB.value][1]), toneburstmode = 0, diseqcmode = 1, diseqcpos = 1)
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcC.vals[nim.diseqcC.value][1]), toneburstmode = 0, diseqcmode = 1, diseqcpos = 2)
+ self.addLNBSimple(slotid = x, orbpos = int(nim.diseqcD.vals[nim.diseqcD.value][1]), toneburstmode = 0, diseqcmode = 1, diseqcpos = 3)
+ elif nim.diseqcMode.value == 4: #Positioner
+ self.addLNBSimple(slotid = x, diseqcmode = 3, longitude = float(str(nim.longitude.value[0]) + "." + str(nim.longitude.value[1])), loDirection = nim.longitudeOrientation.value - 2, latitude = float(str(nim.latitude.value[0]) + "." + str(nim.latitude.value[1])), laDirection = nim.latitudeOrientation.value)
+ pass
+ else: #advanced config
+ print "FIXME add support for advanced config"
+
+ def __init__(self, nimmgr):
+ self.NimManager = nimmgr
+ self.update()
+