+class configSatlist:
+ def __init__(self, parent):
+ self.parent = parent
+
+ def checkValues(self):
+ if self.parent.value < 0:
+ self.parent.value = 0
+
+ if(self.parent.value >= (len(self.parent.vals) - 1)):
+ self.parent.value = len(self.parent.vals) - 1
+
+ def cancel(self):
+ self.parent.reload()
+
+ def save(self):
+ self.parent.save()
+
+ def handleKey(self, key):
+ if key == config.key["prevElement"]:
+ self.parent.value = self.parent.value - 1
+ if key == config.key["nextElement"]:
+ self.parent.value = self.parent.value + 1
+
+ self.checkValues()
+
+ self.parent.change()
+
+ def __call__(self, selected): #needed by configlist
+ self.checkValues()
+ #fixme
+ return ("text", str(self.parent.vals[self.parent.value][0]))
+
+class configSequenceArg:
+ def get(self, type, args = ()):
+ # configsequencearg.get ("IP")
+ if (type == "IP"):
+ return (("."), [(1,255),(0,255),(0,255),(0,255)])
+ # configsequencearg.get ("MAC")
+ if (type == "MAC"):
+ return ((":"), [(1,255),(1,255),(1,255),(1,255),(1,255),(1,255)])
+ # configsequencearg.get("INTEGER", (min, max)) => x with min <= x <= max
+ if (type == "INTEGER"):
+ return ((":"), [args])
+ # configsequencearg.get("FLOAT", [(min,max),(min1,max1)]) => x.y with min <= x <= max and min1 <= y <= max1
+ if (type == "FLOAT"):
+ return (("."), args)
+
+configsequencearg = configSequenceArg()
+
+class configSequence:
+ def __init__(self, parent):
+ self.parent = parent
+ self.markedPos = 0
+ self.seperator = self.parent.vals[0]
+ self.valueBounds = self.parent.vals[1]
+
+ def checkValues(self):
+ maxPos = 0
+ num = 0
+ for i in self.parent.value:
+ maxPos += len(str(self.valueBounds[num][1]))
+ while (self.valueBounds[num][0] > self.parent.value[num]):
+ self.parent.value[num] += 1
+
+ while (self.valueBounds[num][1] < self.parent.value[num]):
+ self.parent.value[num] -= 1
+
+# if (self.valueBounds[num][0] <= i <= self.valueBounds[num][1]):
+ #pass
+ #else:
+ #self.parent.value[num] = self.valueBounds[num][0]
+ num += 1
+
+ if self.markedPos >= maxPos:
+ self.markedPos = maxPos - 1
+ if self.markedPos < 0:
+ self.markedPos = 0
+
+ def cancel(self):
+ self.parent.reload()
+
+ def save(self):
+ self.parent.save()
+
+ def handleKey(self, key):
+ #this will no change anything on the value itself
+ #so we can handle it here in gui element
+ if key == config.key["prevElement"]:
+ self.markedPos -= 1
+ if key == config.key["nextElement"]:
+ self.markedPos += 1
+
+ if key >= config.key["0"] and key <= config.key["9"]:
+ number = 9 - config.key["9"] + key
+ # length of numberblock
+ numberLen = len(str(self.valueBounds[0][1]))
+ # position in the block
+ posinblock = self.markedPos % numberLen
+ # blocknumber
+ blocknumber = self.markedPos / numberLen
+
+ oldvalue = self.parent.value[blocknumber]
+ olddec = oldvalue % 10 ** (numberLen - posinblock) - (oldvalue % 10 ** (numberLen - posinblock - 1))
+ newvalue = oldvalue - olddec + (10 ** (numberLen - posinblock - 1) * number)
+
+ print "You actually pressed a number (" + str(number) + ") which will be added at block number " + str(blocknumber) + " on position " + str(posinblock)
+ print "Old value: " + str(oldvalue) + " olddec: " + str(olddec) + " newvalue: " + str(newvalue)
+ self.parent.value[blocknumber] = newvalue
+ self.markedPos += 1
+
+ self.checkValues()
+
+ print "markPos:",
+ print self.markedPos
+
+ #FIXME: dont call when press left/right
+ self.parent.change()
+
+ def __call__(self, selected): #needed by configlist
+ value = ""
+ mPos = self.markedPos
+ print "Positon: " + str(mPos)
+ num = 0;
+ for i in self.parent.value:
+ if len(value): #fixme no heading separator possible
+ value += self.seperator
+ if mPos >= len(value) - 1:
+ mPos += 1
+
+ #diff = self.valueBounds - len(str(i))
+ #if diff > 0:
+ ## if this helps?!
+ #value += " " * diff
+ print (("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i)
+ value += ("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i
+ num += 1
+ # only mark cursor when we are selected
+ # (this code is heavily ink optimized!)
+ return ("mtext"[1-selected:], value, [mPos])
+