added an example for weekday selection
[enigma2.git] / lib / python / Components / config.py
index 7f8f50727c166bbf50ab99a0c8e1585a5f3b6c43..dfd5d5971a2bcd39a9c5c961cffaecf029069306 100644 (file)
@@ -1,3 +1,5 @@
+from time import *
+
 class configFile:
        def __init__(self):
                self.changed = 0
@@ -37,7 +39,9 @@ class configFile:
                        
                fileHandle = open("config", "w")
                
-               for x in self.configElements:
+               keys = self.configElements.keys()
+               keys.sort()
+               for x in keys:
                        wstr = x + "=" + self.configElements[x]
                        
                        if wstr[len(wstr) - 1] != '\n':
@@ -78,6 +82,38 @@ class configSelection:
                self.checkValues()
                return ("text", self.parent.vals[self.parent.value])
 
+class configDateTime:
+       def __init__(self, parent):
+               self.parent = parent
+               
+       def checkValues(self):
+               pass
+#              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 - self.parent.vals[1]
+               if key == config.key["nextElement"]:
+                       self.parent.value = self.parent.value + self.parent.vals[1]
+               
+               self.checkValues()
+
+               self.parent.change()    
+
+       def __call__(self, selected):                   #needed by configlist
+               self.checkValues()
+               return ("text", strftime(self.parent.vals[0], localtime(self.parent.value)))
+       
 class configSatlist:
        def __init__(self, parent):
                self.parent = parent
@@ -109,16 +145,53 @@ class configSatlist:
                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("PINCODE", (number, "*")) => pin with number = length of pincode and "*" as numbers shown as stars
+               # configsequencearg.get("PINCODE", (number, "")) => pin with number = length of pincode and numbers shown
+               if (type == "PINCODE"):
+                       return ((":"), [(0, (10**args[0])-1)], args[1])
+               # 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]
+               self.censorChar = self.parent.vals[2]
+
        def checkValues(self):
-               maxPos = len(self.parent.value) * self.parent.vals[1] 
-               print maxPos
-                       
+               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:
@@ -141,7 +214,7 @@ class configSequence:
                if key >= config.key["0"] and key <= config.key["9"]:
                        number = 9 - config.key["9"] + key
                        # length of numberblock
-                       numberLen = len(str(self.parent.vals[1][1]))
+                       numberLen = len(str(self.valueBounds[0][1]))
                        # position in the block
                        posinblock = self.markedPos % numberLen
                        # blocknumber
@@ -168,19 +241,23 @@ class configSequence:
                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.parent.vals[0]
+                               value += self.seperator
                                if mPos >= len(value) - 1:
                                        mPos += 1
                                
-                       #diff =         self.parent.vals[1] - len(str(i))
+                       #diff =         self.valueBounds - len(str(i))
                        #if diff > 0:
                                ## if this helps?!
                                #value += " " * diff
-                       print (("%0" + str(len(str(self.parent.vals[1][1]))) + "d") % i)
-                       value += ("%0" + str(len(str(self.parent.vals[1][1]))) + "d") % i
-
+                       print (("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i)
+                       if (self.censorChar == ""):
+                               value += ("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i
+                       else:
+                               value += (self.censorChar * len(str(self.valueBounds[num][1])))
+                       num += 1
                        # only mark cursor when we are selected
                        # (this code is heavily ink optimized!)
                return ("mtext"[1-selected:], value, [mPos])
@@ -265,6 +342,8 @@ class configElement:
                        return int(data);
                elif control == configSelection:
                        return int(data);
+               elif control == configDateTime:
+                       return int(data);
                elif control == configSequence:
                        list = [ ]
                        part = data.split(self.vals[0])
@@ -281,6 +360,8 @@ class configElement:
                        return str(data);
                elif control == configSelection:
                        return str(data);
+               elif control == configDateTime:
+                       return str(data);
                elif control == configSequence:
                        value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data)
 #                      just in case you don't understand the above, here an equivalent:
@@ -302,7 +383,7 @@ class configElement:
                        value = ""
 
                if value == "":
-                       print "value not found - using default"
+                       #print "value not found - using default"
 
                        if self.controlType == configSatlist:
                                self.value = self.getIndexbyEntry(self.defaultValue)
@@ -334,3 +415,17 @@ class configElement:
                self.loadData()
        def save(self):
                configfile.setKey(self.configPath, self.datatoFile(self.controlType,self.value))
+
+class configElement_nonSave(configElement):
+       def __init__(self, configPath, control, defaultValue, vals):
+               configElement.__init__(self, configPath, control, defaultValue, vals)
+
+       def save(self):
+               pass
+               
+def getConfigListEntry(description, element):
+       b = element
+       item = b.controlType(b)
+       return ((description, item))
+
+       
\ No newline at end of file