X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/98efaa152afc767093651fc0a2316d90a19f757a..43b204fbde9c5b36848320079eb7e9576536ddc3:/lib/python/Components/config.py diff --git a/lib/python/Components/config.py b/lib/python/Components/config.py index 5a4ed12e..06bb62a2 100644 --- a/lib/python/Components/config.py +++ b/lib/python/Components/config.py @@ -27,13 +27,16 @@ class configFile: x = line.find("=") if x > -1: self.configElements[line[:x]] = line[x + 1:-1] - + def getKey(self, key): return self.configElements[key] - def setKey(self, key, value): + def setKey(self, key, value, isDefaultKey=False): self.changed = 1 - self.configElements[key] = value + if isDefaultKey and self.configElements.has_key(key): + del self.configElements[key] + else: + self.configElements[key] = value def save(self): if self.changed == 0: #no changes, so no write to disk needed @@ -260,8 +263,8 @@ class configSequence: self.parent.value[blocknumber] = newvalue self.markedPos += 1 - self.checkValues() - + self.checkValues() + #FIXME: dont call when press left/right self.parent.change() @@ -477,18 +480,20 @@ class configElement: return str(data) elif control == configText: return str(data.strip()) - elif control == configSequence: +# print self.vals +# print self.value try: - value = ((len(data) * ("%d" + self.vals[0]))[0:-1]) % tuple(data) + value = "" + count = 0 + for i in data: + if value !="": + value += self.vals[0] + value += (("%0" + str(len(str(self.vals[1][count][1]))) + "d") % i) + count += 1 + #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: -# if value !="": -# value += self.vals[0] -# value += str(i) return value elif control == configSatlist: return str(self.vals[self.value][1]); @@ -504,17 +509,18 @@ class configElement: if value == "": #print "value not found - using default" - if self.controlType == configSatlist: self.value = self.getIndexbyEntry(self.defaultValue) - else: + elif self.controlType == configSequence: + self.value = self.defaultValue[:] + else: self.value = self.defaultValue 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 self.change() @@ -534,14 +540,28 @@ class configElement: def addNotifier(self, notifier): self.notifierList.append(notifier); notifier(self); + def change(self): for notifier in self.notifierList: notifier(self) + def reload(self): self.loadData() + def save(self): - if self.defaultValue != self.value or self.saveDefaults == True: - configfile.setKey(self.configPath, self.datatoFile(self.controlType,self.value)) + if self.controlType == configSatlist: + defaultValue = self.getIndexbyEntry(self.defaultValue) + else: + defaultValue = self.defaultValue + if self.value != defaultValue or self.saveDefaults: + configfile.setKey(self.configPath, self.datatoFile(self.controlType, self.value)) + else: + try: + oldValue = configfile.getKey(self.configPath) + except: + oldValue = None + if oldValue is not None and oldValue != defaultValue: + configfile.setKey(self.configPath, self.datatoFile(self.controlType, self.value), True) class configElement_nonSave(configElement): def __init__(self, configPath, control, defaultValue, vals): @@ -549,13 +569,12 @@ class configElement_nonSave(configElement): def save(self): pass - + 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)