X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/7b9d3432c8b671621bba5803a0e44cb295f7f6f8..e4034b7fce157a23fcd2668a59ccc7a32d19ac84:/lib/python/Components/config.py diff --git a/lib/python/Components/config.py b/lib/python/Components/config.py index 75dee0ce..7137845f 100644 --- a/lib/python/Components/config.py +++ b/lib/python/Components/config.py @@ -1,4 +1,5 @@ from time import * +from Tools.NumericalTextInput import * class configFile: def __init__(self): @@ -24,7 +25,7 @@ class configFile: def addElement(self, line): x = line.find("=") if x > -1: - self.configElements[line[:x]] = line[x + 1:] + self.configElements[line[:x]] = line[x + 1:-1] def getKey(self, key): return self.configElements[key] @@ -42,10 +43,7 @@ class configFile: keys = self.configElements.keys() keys.sort() for x in keys: - wstr = x + "=" + self.configElements[x] - - if wstr[len(wstr) - 1] != '\n': - wstr = wstr + "\n" + wstr = x + "=" + self.configElements[x] + "\n" fileHandle.write(wstr) @@ -57,10 +55,9 @@ class configSelection: 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 + self.parent.value = len(self.parent.vals) - 1 + elif(self.parent.value > (len(self.parent.vals) - 1)): + self.parent.value = 0 def cancel(self): self.parent.reload() @@ -76,11 +73,11 @@ class configSelection: self.checkValues() - self.parent.change() + self.parent.change() def __call__(self, selected): #needed by configlist self.checkValues() - return ("text", self.parent.vals[self.parent.value]) + return ("text", _(self.parent.vals[self.parent.value])) class configDateTime: def __init__(self, parent): @@ -275,6 +272,7 @@ class configText: self.parent = parent self.markedPos = 0 self.mode = self.parent.vals[0] + self.textInput = NumericalTextInput(self.nextEntry) def checkValues(self): if (self.markedPos < 0): @@ -287,23 +285,32 @@ class configText: def save(self): self.parent.save() + + def nextEntry(self): + print self.parent + self.parent.vals[1](self.parent.getConfigPath()) 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["delete"]: + self.parent.value = self.parent.value[0:self.markedPos] + self.parent.value[self.markedPos + 1:] if key == config.key["prevElement"]: + self.textInput.nextKey() self.markedPos -= 1 + if key == config.key["nextElement"]: + self.textInput.nextKey() self.markedPos += 1 if (self.mode == self.extendableSize): if (self.markedPos >= len(self.parent.value)): self.parent.value = self.parent.value.ljust(len(self.parent.value) + 1) - + if key >= config.key["0"] and key <= config.key["9"]: number = 9 - config.key["9"] + key - self.parent.value = self.parent.value[0:self.markedPos] + str(number) + self.parent.value[self.markedPos + 1:] + self.parent.value = self.parent.value[0:self.markedPos] + str(self.textInput.getKey(number)) + self.parent.value[self.markedPos + 1:] self.checkValues() @@ -324,6 +331,7 @@ class Config: self.key = { "choseElement": 0, "prevElement": 1, "nextElement": 2, + "delete": 3, "0": 10, "1": 11, "2": 12, @@ -336,6 +344,7 @@ class Config: "9": 19 } config = Config(); + configfile = configFile() class ConfigSlider: @@ -384,7 +393,7 @@ class configElement: tcnt = cnt cnt += 1 if tcnt != -1: - return tcnt + return tcnt return 0 #prevent bigger then array def datafromFile(self, control, data): @@ -418,7 +427,11 @@ class configElement: return str(data.strip()) elif control == configSequence: - value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data) + print data + try: + value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data) + except: + value = str(data) # just in case you don't understand the above, here an equivalent: # value = "" # for i in data: @@ -432,6 +445,7 @@ class configElement: return "" def loadData(self): + #print "load:" + self.configPath try: value = self.datafromFile(self.controlType, configfile.getKey(self.configPath)) except: @@ -447,6 +461,7 @@ class configElement: self.save() #add missing value to dict else: + #print "set val:" + str(value) self.value = value #is this right? activate settings after load/cancel and use default @@ -460,6 +475,10 @@ class configElement: self.notifierList = [ ] self.enabled = True self.loadData() + + def getConfigPath(self): + return self.configPath + def addNotifier(self, notifier): self.notifierList.append(notifier); notifier(self); @@ -482,3 +501,9 @@ def getConfigListEntry(description, element): b = element item = b.controlType(b) return ((description, item)) + + +def configElementBoolean(name, default, texts=(_("Enable"), _("Disable"))): + return configElement(name, configSelection, default, texts) + +config.misc = ConfigSubsection()