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 return self.configElements[key]
34 def setKey(self, key, value):
36 self.configElements[key] = value
39 if self.changed == 0: #no changes, so no write to disk needed
42 fileHandle = open(resolveFilename(SCOPE_CONFIG, "config"), "w")
44 keys = self.configElements.keys()
47 wstr = x + "=" + self.configElements[x] + "\n"
49 fileHandle.write(wstr)
53 def currentConfigSelectionElement(element):
54 return element.vals[element.value][0]
56 def getConfigSelectionElement(element, value):
58 for x in element.vals:
64 class configSelection:
65 def __init__(self, parent):
68 def checkValues(self):
69 if self.parent.value < 0:
70 self.parent.value = len(self.parent.vals) - 1
71 elif(self.parent.value > (len(self.parent.vals) - 1)):
80 def handleKey(self, key):
81 if key == config.key["prevElement"]:
82 self.parent.value = self.parent.value - 1
83 if key == config.key["nextElement"]:
84 self.parent.value = self.parent.value + 1
90 def __call__(self, selected): #needed by configlist
92 if isinstance(self.parent.vals[self.parent.value], str):
93 returnValue = _(self.parent.vals[self.parent.value])
95 returnValue = _(self.parent.vals[self.parent.value][1])
97 return ("text", returnValue)
100 def __init__(self, parent):
103 def checkValues(self):
105 # if self.parent.value < 0:
106 #self.parent.value = 0
108 #if(self.parent.value >= (len(self.parent.vals) - 1)):
109 #self.parent.value = len(self.parent.vals) - 1
117 def handleKey(self, key):
118 if key == config.key["prevElement"]:
119 self.parent.value = self.parent.value - self.parent.vals[1]
120 if key == config.key["nextElement"]:
121 self.parent.value = self.parent.value + self.parent.vals[1]
127 def __call__(self, selected): #needed by configlist
129 return ("text", strftime(self.parent.vals[0], localtime(self.parent.value)))
132 def __init__(self, parent):
135 def checkValues(self):
136 if self.parent.value < 0:
137 self.parent.value = 0
139 if(self.parent.value >= (len(self.parent.vals) - 1)):
140 self.parent.value = len(self.parent.vals) - 1
148 def handleKey(self, key):
149 if key == config.key["prevElement"]:
150 self.parent.value = self.parent.value - 1
151 if key == config.key["nextElement"]:
152 self.parent.value = self.parent.value + 1
158 def __call__(self, selected): #needed by configlist
161 return ("text", str(self.parent.vals[self.parent.value][0]))
163 class configSequenceArg:
164 def get(self, type, args = ()):
165 # configsequencearg.get ("IP")
167 return (("."), [(0,255),(0,255),(0,255),(0,255)], "")
168 # configsequencearg.get ("MAC")
170 return ((":"), [(1,255),(1,255),(1,255),(1,255),(1,255),(1,255)], "")
171 # configsequencearg.get ("CLOCK")
172 if (type == "CLOCK"):
173 return ((":"), [(0,23),(0,59)], "")
174 # configsequencearg.get("INTEGER", (min, max)) => x with min <= x <= max
175 if (type == "INTEGER"):
176 return ((":"), [args], "")
177 # configsequencearg.get("PINCODE", (number, "*")) => pin with number = length of pincode and "*" as numbers shown as stars
178 # configsequencearg.get("PINCODE", (number, "")) => pin with number = length of pincode and numbers shown
179 if (type == "PINCODE"):
180 return ((":"), [(0, (10**args[0])-1)], args[1])
181 # configsequencearg.get("FLOAT", [(min,max),(min1,max1)]) => x.y with min <= x <= max and min1 <= y <= max1
182 if (type == "FLOAT"):
183 return (("."), args, "")
185 def getFloat(self, element):
186 return float(("%d.%0" + str(len(str(element.vals[1][1][1]))) + "d") % (element.value[0], element.value[1]))
188 configsequencearg = configSequenceArg()
190 class configSequence:
191 def __init__(self, parent):
194 self.seperator = self.parent.vals[0]
195 self.valueBounds = self.parent.vals[1]
196 self.censorChar = self.parent.vals[2]
198 def checkValues(self):
201 for i in self.parent.value:
202 maxPos += len(str(self.valueBounds[num][1]))
203 while (self.valueBounds[num][0] > self.parent.value[num]):
204 self.parent.value[num] += 1
206 while (self.valueBounds[num][1] < self.parent.value[num]):
207 self.parent.value[num] -= 1
209 # if (self.valueBounds[num][0] <= i <= self.valueBounds[num][1]):
212 #self.parent.value[num] = self.valueBounds[num][0]
215 if self.markedPos >= maxPos:
216 self.markedPos = maxPos - 1
217 if self.markedPos < 0:
226 def handleKey(self, key):
227 #this will no change anything on the value itself
228 #so we can handle it here in gui element
229 if key == config.key["prevElement"]:
231 if key == config.key["nextElement"]:
234 if key >= config.key["0"] and key <= config.key["9"]:
236 for x in self.valueBounds:
237 self.blockLen.append(len(str(x[1])))
241 self.blockLenTotal = [0,]
242 for x in self.blockLen:
243 pos += self.blockLen[blocknumber]
244 self.blockLenTotal.append(pos)
245 if (pos - 1 >= self.markedPos):
250 number = 9 - config.key["9"] + key
251 # length of numberblock
252 numberLen = len(str(self.valueBounds[blocknumber][1]))
253 # position in the block
254 posinblock = self.markedPos - self.blockLenTotal[blocknumber]
256 oldvalue = self.parent.value[blocknumber]
257 olddec = oldvalue % 10 ** (numberLen - posinblock) - (oldvalue % 10 ** (numberLen - posinblock - 1))
258 newvalue = oldvalue - olddec + (10 ** (numberLen - posinblock - 1) * number)
260 self.parent.value[blocknumber] = newvalue
265 #FIXME: dont call when press left/right
268 def __call__(self, selected): #needed by configlist
270 mPos = self.markedPos
272 for i in self.parent.value:
273 if len(value): #fixme no heading separator possible
274 value += self.seperator
275 if mPos >= len(value) - 1:
278 #diff = self.valueBounds - len(str(i))
282 if (self.censorChar == ""):
283 value += ("%0" + str(len(str(self.valueBounds[num][1]))) + "d") % i
285 value += (self.censorChar * len(str(self.valueBounds[num][1])))
287 # only mark cursor when we are selected
288 # (this code is heavily ink optimized!)
289 if (self.parent.enabled == True):
290 return ("mtext"[1-selected:], value, [mPos])
292 return ("text", value)
295 # used as first parameter
296 # is the text of a fixed size or is the user able to extend the length of the text
300 def __init__(self, parent):
303 self.mode = self.parent.vals[0]
304 self.textInput = NumericalTextInput(self.nextEntry)
306 def checkValues(self):
307 if (self.markedPos < 0):
309 if (self.markedPos >= len(self.parent.value)):
310 self.markedPos = len(self.parent.value) - 1
319 self.parent.vals[1](self.parent.getConfigPath())
321 def handleKey(self, key):
322 #this will no change anything on the value itself
323 #so we can handle it here in gui element
324 if key == config.key["delete"]:
325 self.parent.value = self.parent.value[0:self.markedPos] + self.parent.value[self.markedPos + 1:]
326 if key == config.key["prevElement"]:
327 self.textInput.nextKey()
330 if key == config.key["nextElement"]:
331 self.textInput.nextKey()
333 if (self.mode == self.extendableSize):
334 if (self.markedPos >= len(self.parent.value)):
335 self.parent.value = self.parent.value.ljust(len(self.parent.value) + 1)
338 if key >= config.key["0"] and key <= config.key["9"]:
339 number = 9 - config.key["9"] + key
341 self.parent.value = self.parent.value[0:self.markedPos] + str(self.textInput.getKey(number)) + self.parent.value[self.markedPos + 1:]
347 def __call__(self, selected): #needed by configlist
348 return ("mtext"[1-selected:], str(self.parent.value), [self.markedPos])
351 def __init__(self, obj):
359 self.key = { "choseElement": 0,
376 configfile = configFile()
379 def __init__(self, parent):
388 def checkValues(self):
389 if self.parent.value < 0:
390 self.parent.value = 0
392 if self.parent.value > 10:
393 self.parent.value = 10
395 def handleKey(self, key):
396 if key == config.key["prevElement"]:
397 self.parent.value = self.parent.value - 1
398 if key == config.key["nextElement"]:
399 self.parent.value = self.parent.value + 1
404 def __call__(self, selected): #needed by configlist
406 return ("slider", self.parent.value * 10)
408 class ConfigSubsection:
414 def getIndexbyEntry(self, data):
416 tcnt = -1; #for defaultval
418 if int(x[1]) == int(data):
420 if int(x[1]) == int(self.defaultValue):
425 return 0 #prevent bigger then array
427 def datafromFile(self, control, data):
428 if control == ConfigSlider:
430 elif control == configSelection:
434 for x in data.split(":"):
441 return self.defaultValue
442 elif control == configDateTime:
444 elif control == configText:
446 elif control == configSequence:
448 part = data.split(self.vals[0])
452 elif control == configSatlist:
453 return self.getIndexbyEntry(data)
457 def datatoFile(self, control, data):
458 if control == ConfigSlider:
460 elif control == configSelection:
461 if len(self.vals) < data + 1:
463 if isinstance(self.vals[data], str):
470 confList.append("*" + str(x[0] + "*"))
472 confList.append(x[0])
474 return ":".join(confList)
476 elif control == configDateTime:
478 elif control == configText:
479 return str(data.strip())
480 elif control == configSequence:
488 value += self.vals[0]
489 value += (("%0" + str(len(str(self.vals[1][count][1]))) + "d") % i)
491 #value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data)
495 elif control == configSatlist:
496 return str(self.vals[self.value][1]);
501 #print "load:" + self.configPath
503 value = self.datafromFile(self.controlType, configfile.getKey(self.configPath))
508 #print "value not found - using default"
509 if self.controlType == configSatlist:
510 self.value = self.getIndexbyEntry(self.defaultValue)
511 elif self.controlType == configSequence:
512 self.value = self.defaultValue[:]
514 self.value = self.defaultValue
516 self.save() #add missing value to dict
518 #print "set val:" + str(value)
521 #is this right? activate settings after load/cancel and use default
524 def __init__(self, configPath, control, defaultValue, vals, saveDefaults = True):
525 self.configPath = configPath
526 self.defaultValue = defaultValue
527 self.controlType = control
529 self.notifierList = [ ]
531 self.saveDefaults = saveDefaults
534 def getConfigPath(self):
535 return self.configPath
537 def addNotifier(self, notifier):
538 self.notifierList.append(notifier);
542 for notifier in self.notifierList:
549 if self.controlType == configSatlist:
550 defaultValue = self.getIndexbyEntry(self.defaultValue)
552 defaultValue = self.defaultValue
553 if (defaultValue != self.value) or (self.saveDefaults == True):
554 configfile.setKey(self.configPath, self.datatoFile(self.controlType,self.value))
556 class configElement_nonSave(configElement):
557 def __init__(self, configPath, control, defaultValue, vals):
558 configElement.__init__(self, configPath, control, defaultValue, vals)
563 def getConfigListEntry(description, element):
565 item = b.controlType(b)
566 return ((description, item))
568 def configElementBoolean(name, default, texts=(_("Enable"), _("Disable"))):
569 return configElement(name, configSelection, default, texts)
571 config.misc = ConfigSubsection()