2 from Tools.NumericalTextInput import *
3 from Tools.Directories import *
8 self.configElements = { }
10 self.file = open(resolveFilename(SCOPE_CONFIG, "config"))
12 print "cannot open config file"
16 line = self.file.readline()
20 if line.startswith("#"): #skip comments
26 def addElement(self, line):
29 self.configElements[line[:x]] = line[x + 1:-1]
31 def getKey(self, key):
32 if self.configElements.has_key(key):
33 return self.configElements[key]
36 def setKey(self, key, value, isDefaultKey=False):
38 if isDefaultKey and self.configElements.has_key(key):
39 del self.configElements[key]
41 self.configElements[key] = value
44 if self.changed == 0: #no changes, so no write to disk needed
47 fileHandle = open(resolveFilename(SCOPE_CONFIG, "config"), "w")
49 keys = self.configElements.keys()
52 wstr = x + "=" + self.configElements[x] + "\n"
54 fileHandle.write(wstr)
58 def currentConfigSelectionElement(element):
59 return element.vals[element.value][0]
61 def getConfigSelectionElement(element, value):
63 for x in element.vals:
69 class configSelection:
70 def __init__(self, parent):
73 def checkValues(self):
74 if self.parent.value < 0:
75 self.parent.value = len(self.parent.vals) - 1
76 elif(self.parent.value > (len(self.parent.vals) - 1)):
85 def handleKey(self, key):
86 if key == config.key["prevElement"]:
87 self.parent.value = self.parent.value - 1
88 if key == config.key["nextElement"]:
89 self.parent.value = self.parent.value + 1
95 def __call__(self, selected): #needed by configlist
97 if isinstance(self.parent.vals[self.parent.value], str):
98 returnValue = _(self.parent.vals[self.parent.value])
100 returnValue = _(self.parent.vals[self.parent.value][1])
102 return ("text", returnValue)
104 class configDateTime:
105 def __init__(self, parent):
108 def checkValues(self):
110 # if self.parent.value < 0:
111 #self.parent.value = 0
113 #if(self.parent.value >= (len(self.parent.vals) - 1)):
114 #self.parent.value = len(self.parent.vals) - 1
122 def handleKey(self, key):
123 if key == config.key["prevElement"]:
124 self.parent.value = self.parent.value - self.parent.vals[1]
125 if key == config.key["nextElement"]:
126 self.parent.value = self.parent.value + self.parent.vals[1]
132 def __call__(self, selected): #needed by configlist
134 return ("text", strftime(self.parent.vals[0], localtime(self.parent.value)))
137 def __init__(self, parent):
140 def checkValues(self):
141 if self.parent.value < 0:
142 self.parent.value = 0
144 if(self.parent.value >= (len(self.parent.vals) - 1)):
145 self.parent.value = len(self.parent.vals) - 1
153 def handleKey(self, key):
154 if key == config.key["prevElement"]:
155 self.parent.value = self.parent.value - 1
156 if key == config.key["nextElement"]:
157 self.parent.value = self.parent.value + 1
163 def __call__(self, selected): #needed by configlist
166 return ("text", str(self.parent.vals[self.parent.value][0]))
168 class configSequenceArg:
169 def get(self, type, args = ()):
170 # configsequencearg.get ("IP")
172 return (("."), [(0,255),(0,255),(0,255),(0,255)], "")
173 # configsequencearg.get ("MAC")
175 return ((":"), [(1,255),(1,255),(1,255),(1,255),(1,255),(1,255)], "")
176 # configsequencearg.get ("CLOCK")
177 if (type == "CLOCK"):
178 return ((":"), [(0,23),(0,59)], "")
179 # configsequencearg.get("INTEGER", (min, max)) => x with min <= x <= max
180 if (type == "INTEGER"):
181 return ((":"), [args], "")
182 # configsequencearg.get("PINCODE", (number, "*")) => pin with number = length of pincode and "*" as numbers shown as stars
183 # configsequencearg.get("PINCODE", (number, "")) => pin with number = length of pincode and numbers shown
184 if (type == "PINCODE"):
185 return ((":"), [(0, (10**args[0])-1)], args[1])
186 # configsequencearg.get("FLOAT", [(min,max),(min1,max1)]) => x.y with min <= x <= max and min1 <= y <= max1
187 if (type == "FLOAT"):
188 return (("."), args, "")
190 def getFloat(self, element):
191 return float(("%d.%0" + str(len(str(element.vals[1][1][1]))) + "d") % (element.value[0], element.value[1]))
193 configsequencearg = configSequenceArg()
195 class configSequence:
196 def __init__(self, parent):
199 self.seperator = self.parent.vals[0]
200 self.valueBounds = self.parent.vals[1]
201 self.censorChar = self.parent.vals[2]
203 def checkValues(self):
206 for i in self.parent.value:
207 maxPos += len(str(self.valueBounds[num][1]))
208 while (self.valueBounds[num][0] > self.parent.value[num]):
209 self.parent.value[num] += 1
211 while (self.valueBounds[num][1] < self.parent.value[num]):
212 self.parent.value[num] -= 1
214 # if (self.valueBounds[num][0] <= i <= self.valueBounds[num][1]):
217 #self.parent.value[num] = self.valueBounds[num][0]
220 if self.markedPos >= maxPos:
221 self.markedPos = maxPos - 1
222 if self.markedPos < 0:
231 def handleKey(self, key):
232 #this will no change anything on the value itself
233 #so we can handle it here in gui element
234 if key == config.key["prevElement"]:
236 if key == config.key["nextElement"]:
239 if key >= config.key["0"] and key <= config.key["9"]:
241 for x in self.valueBounds:
242 self.blockLen.append(len(str(x[1])))
246 self.blockLenTotal = [0,]
247 for x in self.blockLen:
248 pos += self.blockLen[blocknumber]
249 self.blockLenTotal.append(pos)
250 if (pos - 1 >= self.markedPos):
255 number = 9 - config.key["9"] + key
256 # length of numberblock
257 numberLen = len(str(self.valueBounds[blocknumber][1]))
258 # position in the block
259 posinblock = self.markedPos - self.blockLenTotal[blocknumber]
261 oldvalue = self.parent.value[blocknumber]
262 olddec = oldvalue % 10 ** (numberLen - posinblock) - (oldvalue % 10 ** (numberLen - posinblock - 1))
263 newvalue = oldvalue - olddec + (10 ** (numberLen - posinblock - 1) * number)
265 self.parent.value[blocknumber] = newvalue
270 #FIXME: dont call when press left/right
273 def __call__(self, selected): #needed by configlist
275 mPos = self.markedPos
277 for i in self.parent.value:
278 if len(value): #fixme no heading separator possible
279 value += self.seperator
280 if mPos >= len(value) - 1:
283 #diff = self.valueBounds - len(str(i))
287 if (self.censorChar == ""):
288 value += ("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i
290 value += (self.censorChar * len(str(self.valueBounds[num][1])))
292 # only mark cursor when we are selected
293 # (this code is heavily ink optimized!)
294 if (self.parent.enabled == True):
295 return ("mtext"[1-selected:], value, [mPos])
297 return ("text", value)
300 # used as first parameter
301 # is the text of a fixed size or is the user able to extend the length of the text
305 def __init__(self, parent):
308 self.mode = self.parent.vals[0]
309 self.textInput = NumericalTextInput(self.nextEntry)
311 def checkValues(self):
312 if (self.markedPos < 0):
314 if (self.markedPos >= len(self.parent.value)):
315 self.markedPos = len(self.parent.value) - 1
324 self.parent.vals[1](self.parent.getConfigPath())
326 def handleKey(self, key):
327 #this will no change anything on the value itself
328 #so we can handle it here in gui element
329 if key == config.key["delete"]:
330 self.parent.value = self.parent.value[0:self.markedPos] + self.parent.value[self.markedPos + 1:]
331 if key == config.key["prevElement"]:
332 self.textInput.nextKey()
335 if key == config.key["nextElement"]:
336 self.textInput.nextKey()
338 if (self.mode == self.extendableSize):
339 if (self.markedPos >= len(self.parent.value)):
340 self.parent.value = self.parent.value.ljust(len(self.parent.value) + 1)
343 if key >= config.key["0"] and key <= config.key["9"]:
344 number = 9 - config.key["9"] + key
346 self.parent.value = self.parent.value[0:self.markedPos] + str(self.textInput.getKey(number)) + self.parent.value[self.markedPos + 1:]
352 def __call__(self, selected): #needed by configlist
353 return ("mtext"[1-selected:], str(self.parent.value), [self.markedPos])
356 def __init__(self, obj):
364 self.key = { "choseElement": 0,
381 configfile = configFile()
384 def __init__(self, parent):
393 def checkValues(self):
394 if self.parent.value < 0:
395 self.parent.value = 0
397 if self.parent.value > 10:
398 self.parent.value = 10
400 def handleKey(self, key):
401 if key == config.key["prevElement"]:
402 self.parent.value = self.parent.value - 1
403 if key == config.key["nextElement"]:
404 self.parent.value = self.parent.value + 1
409 def __call__(self, selected): #needed by configlist
411 return ("slider", self.parent.value * 10)
413 class ConfigSubsection:
419 def getIndexbyEntry(self, data):
421 tcnt = -1; #for defaultval
423 if int(x[1]) == int(data):
425 if int(x[1]) == int(self.defaultValue):
430 return 0 #prevent bigger then array
432 def datafromFile(self, control, data):
433 if control == ConfigSlider:
435 elif control == configSelection:
439 for x in data.split(":"):
446 return self.defaultValue
447 elif control == configDateTime:
449 elif control == configText:
451 elif control == configSequence:
453 part = data.split(self.vals[0])
457 elif control == configSatlist:
458 return self.getIndexbyEntry(data)
462 def datatoFile(self, control, data):
463 if control == ConfigSlider:
465 elif control == configSelection:
466 if len(self.vals) < data + 1:
468 if isinstance(self.vals[data], str):
475 confList.append("*" + str(x[0] + "*"))
477 confList.append(x[0])
479 return ":".join(confList)
481 elif control == configDateTime:
483 elif control == configText:
484 return str(data.strip())
485 elif control == configSequence:
493 value += self.vals[0]
494 value += (("%0" + str(len(str(self.vals[1][count][1]))) + "d") % i)
496 #value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data)
500 elif control == configSatlist:
501 return str(self.vals[self.value][1]);
506 #print "load:" + self.configPath
508 value = self.datafromFile(self.controlType, configfile.getKey(self.configPath))
513 #print "value not found - using default"
514 if self.controlType == configSatlist:
515 self.value = self.getIndexbyEntry(self.defaultValue)
516 elif self.controlType == configSequence:
517 self.value = self.defaultValue[:]
519 self.value = self.defaultValue
521 self.save() #add missing value to dict
523 #print "set val:" + str(value)
526 #is this right? activate settings after load/cancel and use default
529 def __init__(self, configPath, control, defaultValue, vals, saveDefaults = True):
530 self.configPath = configPath
531 self.defaultValue = defaultValue
532 self.controlType = control
534 self.notifierList = [ ]
536 self.saveDefaults = saveDefaults
539 def getConfigPath(self):
540 return self.configPath
542 def addNotifier(self, notifier):
543 self.notifierList.append(notifier);
547 for notifier in self.notifierList:
554 if self.controlType == configSatlist:
555 defaultValue = self.getIndexbyEntry(self.defaultValue)
557 defaultValue = self.defaultValue
558 if self.value != defaultValue or self.saveDefaults:
559 configfile.setKey(self.configPath, self.datatoFile(self.controlType, self.value))
561 oldValue = configfile.getKey(self.configPath)
562 if oldValue is not None and oldValue != defaultValue:
563 configfile.setKey(self.configPath, self.datatoFile(self.controlType, self.value), True)
565 class configElement_nonSave(configElement):
566 def __init__(self, configPath, control, defaultValue, vals):
567 configElement.__init__(self, configPath, control, defaultValue, vals)
572 def getConfigListEntry(description, element):
574 item = b.controlType(b)
575 return ((description, item))
577 def configElementBoolean(name, default, texts=(_("Enable"), _("Disable"))):
578 return configElement(name, configSelection, default, texts)
580 config.misc = ConfigSubsection()