6 self.configElements = { }
8 self.file = open("config")
10 print "cannot open config file"
14 line = self.file.readline()
18 if line.startswith("#"): #skip comments
24 def addElement(self, line):
27 self.configElements[line[:x]] = line[x + 1:]
29 def getKey(self, key):
30 return self.configElements[key]
32 def setKey(self, key, value):
34 self.configElements[key] = value
37 if self.changed == 0: #no changes, so no write to disk needed
40 fileHandle = open("config", "w")
42 keys = self.configElements.keys()
45 wstr = x + "=" + self.configElements[x]
47 if wstr[len(wstr) - 1] != '\n':
50 fileHandle.write(wstr)
54 class configSelection:
55 def __init__(self, parent):
58 def checkValues(self):
59 if self.parent.value < 0:
62 if(self.parent.value >= (len(self.parent.vals) - 1)):
63 self.parent.value = len(self.parent.vals) - 1
71 def handleKey(self, key):
72 if key == config.key["prevElement"]:
73 self.parent.value = self.parent.value - 1
74 if key == config.key["nextElement"]:
75 self.parent.value = self.parent.value + 1
81 def __call__(self, selected): #needed by configlist
83 return ("text", self.parent.vals[self.parent.value])
86 def __init__(self, parent):
89 def checkValues(self):
91 # if self.parent.value < 0:
92 #self.parent.value = 0
94 #if(self.parent.value >= (len(self.parent.vals) - 1)):
95 #self.parent.value = len(self.parent.vals) - 1
103 def handleKey(self, key):
104 if key == config.key["prevElement"]:
105 self.parent.value = self.parent.value - self.parent.vals[1]
106 if key == config.key["nextElement"]:
107 self.parent.value = self.parent.value + self.parent.vals[1]
113 def __call__(self, selected): #needed by configlist
115 return ("text", strftime(self.parent.vals[0], localtime(self.parent.value)))
118 def __init__(self, parent):
121 def checkValues(self):
122 if self.parent.value < 0:
123 self.parent.value = 0
125 if(self.parent.value >= (len(self.parent.vals) - 1)):
126 self.parent.value = len(self.parent.vals) - 1
134 def handleKey(self, key):
135 if key == config.key["prevElement"]:
136 self.parent.value = self.parent.value - 1
137 if key == config.key["nextElement"]:
138 self.parent.value = self.parent.value + 1
144 def __call__(self, selected): #needed by configlist
147 return ("text", str(self.parent.vals[self.parent.value][0]))
149 class configSequenceArg:
150 def get(self, type, args = ()):
151 # configsequencearg.get ("IP")
153 return (("."), [(1,255),(0,255),(0,255),(0,255)], "")
154 # configsequencearg.get ("MAC")
156 return ((":"), [(1,255),(1,255),(1,255),(1,255),(1,255),(1,255)], "")
157 # configsequencearg.get ("CLOCK")
158 if (type == "CLOCK"):
159 return ((":"), [(0,23),(0,59)], "")
160 # configsequencearg.get("INTEGER", (min, max)) => x with min <= x <= max
161 if (type == "INTEGER"):
162 return ((":"), [args], "")
163 # configsequencearg.get("PINCODE", (number, "*")) => pin with number = length of pincode and "*" as numbers shown as stars
164 # configsequencearg.get("PINCODE", (number, "")) => pin with number = length of pincode and numbers shown
165 if (type == "PINCODE"):
166 return ((":"), [(0, (10**args[0])-1)], args[1])
167 # configsequencearg.get("FLOAT", [(min,max),(min1,max1)]) => x.y with min <= x <= max and min1 <= y <= max1
168 if (type == "FLOAT"):
169 return (("."), args, "")
171 configsequencearg = configSequenceArg()
173 class configSequence:
174 def __init__(self, parent):
177 self.seperator = self.parent.vals[0]
178 self.valueBounds = self.parent.vals[1]
179 self.censorChar = self.parent.vals[2]
181 def checkValues(self):
184 for i in self.parent.value:
185 maxPos += len(str(self.valueBounds[num][1]))
186 while (self.valueBounds[num][0] > self.parent.value[num]):
187 self.parent.value[num] += 1
189 while (self.valueBounds[num][1] < self.parent.value[num]):
190 self.parent.value[num] -= 1
192 # if (self.valueBounds[num][0] <= i <= self.valueBounds[num][1]):
195 #self.parent.value[num] = self.valueBounds[num][0]
198 if self.markedPos >= maxPos:
199 self.markedPos = maxPos - 1
200 if self.markedPos < 0:
209 def handleKey(self, key):
210 #this will no change anything on the value itself
211 #so we can handle it here in gui element
212 if key == config.key["prevElement"]:
214 if key == config.key["nextElement"]:
217 if key >= config.key["0"] and key <= config.key["9"]:
218 number = 9 - config.key["9"] + key
219 # length of numberblock
220 numberLen = len(str(self.valueBounds[0][1]))
221 # position in the block
222 posinblock = self.markedPos % numberLen
224 blocknumber = self.markedPos / numberLen
226 oldvalue = self.parent.value[blocknumber]
227 olddec = oldvalue % 10 ** (numberLen - posinblock) - (oldvalue % 10 ** (numberLen - posinblock - 1))
228 newvalue = oldvalue - olddec + (10 ** (numberLen - posinblock - 1) * number)
230 print "You actually pressed a number (" + str(number) + ") which will be added at block number " + str(blocknumber) + " on position " + str(posinblock)
231 print "Old value: " + str(oldvalue) + " olddec: " + str(olddec) + " newvalue: " + str(newvalue)
232 self.parent.value[blocknumber] = newvalue
240 #FIXME: dont call when press left/right
243 def __call__(self, selected): #needed by configlist
245 mPos = self.markedPos
246 print "Positon: " + str(mPos)
248 for i in self.parent.value:
249 if len(value): #fixme no heading separator possible
250 value += self.seperator
251 if mPos >= len(value) - 1:
254 #diff = self.valueBounds - len(str(i))
258 print (("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i)
259 if (self.censorChar == ""):
260 value += ("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i
262 value += (self.censorChar * len(str(self.valueBounds[num][1])))
264 # only mark cursor when we are selected
265 # (this code is heavily ink optimized!)
266 return ("mtext"[1-selected:], value, [mPos])
269 def __init__(self, obj):
277 self.key = { "choseElement": 0,
292 configfile = configFile()
295 def __init__(self, parent):
304 def checkValues(self):
305 if self.parent.value < 0:
306 self.parent.value = 0
308 if self.parent.value > 10:
309 self.parent.value = 10
311 def handleKey(self, key):
312 if key == config.key["prevElement"]:
313 self.parent.value = self.parent.value - 1
314 if key == config.key["nextElement"]:
315 self.parent.value = self.parent.value + 1
320 def __call__(self, selected): #needed by configlist
322 return ("slider", self.parent.value * 10)
324 class ConfigSubsection:
330 def getIndexbyEntry(self, data):
332 tcnt = -1; #for defaultval
334 if int(x[1]) == int(data):
336 if int(x[1]) == int(self.defaultValue):
341 return 0 #prevent bigger then array
343 def datafromFile(self, control, data):
344 if control == ConfigSlider:
346 elif control == configSelection:
348 elif control == configDateTime:
350 elif control == configSequence:
352 part = data.split(self.vals[0])
356 elif control == configSatlist:
357 return self.getIndexbyEntry(data)
361 def datatoFile(self, control, data):
362 if control == ConfigSlider:
364 elif control == configSelection:
366 elif control == configDateTime:
368 elif control == configSequence:
369 value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data)
370 # just in case you don't understand the above, here an equivalent:
374 # value += self.vals[0]
377 elif control == configSatlist:
378 return str(self.vals[self.value][1]);
384 value = self.datafromFile(self.controlType, configfile.getKey(self.configPath))
389 #print "value not found - using default"
391 if self.controlType == configSatlist:
392 self.value = self.getIndexbyEntry(self.defaultValue)
394 self.value = self.defaultValue
396 self.save() #add missing value to dict
400 #is this right? activate settings after load/cancel and use default
403 def __init__(self, configPath, control, defaultValue, vals):
404 self.configPath = configPath
405 self.defaultValue = defaultValue
406 self.controlType = control
408 self.notifierList = [ ]
411 def addNotifier(self, notifier):
412 self.notifierList.append(notifier);
415 for notifier in self.notifierList:
420 configfile.setKey(self.configPath, self.datatoFile(self.controlType,self.value))
422 class configElement_nonSave(configElement):
423 def __init__(self, configPath, control, defaultValue, vals):
424 configElement.__init__(self, configPath, control, defaultValue, vals)
429 def getConfigListEntry(description, element):
431 item = b.controlType(b)
432 return ((description, item))