git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
show how much services are found after the scan
[enigma2.git]
/
lib
/
python
/
Components
/
config.py
diff --git
a/lib/python/Components/config.py
b/lib/python/Components/config.py
index 75dee0ce9119f29810634abd9419f15595859074..3bbdde107af8f15d4ed8b19b5c6f91a1c266af3a 100644
(file)
--- a/
lib/python/Components/config.py
+++ b/
lib/python/Components/config.py
@@
-1,11
+1,13
@@
from time import *
from time import *
+from Tools.NumericalTextInput import *
+from Tools.Directories import *
class configFile:
def __init__(self):
self.changed = 0
self.configElements = { }
try:
class configFile:
def __init__(self):
self.changed = 0
self.configElements = { }
try:
- self.file = open(
"config"
)
+ self.file = open(
resolveFilename(SCOPE_CONFIG, "config")
)
except IOError:
print "cannot open config file"
return
except IOError:
print "cannot open config file"
return
@@
-24,7
+26,7
@@
class configFile:
def addElement(self, line):
x = line.find("=")
if x > -1:
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]
def getKey(self, key):
return self.configElements[key]
@@
-37,15
+39,12
@@
class configFile:
if self.changed == 0: #no changes, so no write to disk needed
return
if self.changed == 0: #no changes, so no write to disk needed
return
- fileHandle = open(
"config"
, "w")
+ fileHandle = open(
resolveFilename(SCOPE_CONFIG, "config")
, "w")
keys = self.configElements.keys()
keys.sort()
for x in keys:
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)
fileHandle.write(wstr)
@@
-57,10
+56,9
@@
class configSelection:
def checkValues(self):
if self.parent.value < 0:
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()
def cancel(self):
self.parent.reload()
@@
-76,11
+74,11
@@
class configSelection:
self.checkValues()
self.checkValues()
- self.parent.change()
+ self.parent.change()
def __call__(self, selected): #needed by configlist
self.checkValues()
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):
class configDateTime:
def __init__(self, parent):
@@
-150,7
+148,7
@@
class configSequenceArg:
def get(self, type, args = ()):
# configsequencearg.get ("IP")
if (type == "IP"):
def get(self, type, args = ()):
# configsequencearg.get ("IP")
if (type == "IP"):
- return (("."), [(
1
,255),(0,255),(0,255),(0,255)], "")
+ return (("."), [(
0
,255),(0,255),(0,255),(0,255)], "")
# configsequencearg.get ("MAC")
if (type == "MAC"):
return ((":"), [(1,255),(1,255),(1,255),(1,255),(1,255),(1,255)], "")
# configsequencearg.get ("MAC")
if (type == "MAC"):
return ((":"), [(1,255),(1,255),(1,255),(1,255),(1,255),(1,255)], "")
@@
-215,13
+213,26
@@
class configSequence:
self.markedPos += 1
if key >= config.key["0"] and key <= config.key["9"]:
self.markedPos += 1
if key >= config.key["0"] and key <= config.key["9"]:
+ self.blockLen = []
+ for x in self.valueBounds:
+ self.blockLen.append(len(str(x[1])))
+
+ pos = 0
+ blocknumber = 0
+ self.blockLenTotal = [0,]
+ for x in self.blockLen:
+ pos += self.blockLen[blocknumber]
+ self.blockLenTotal.append(pos)
+ if (pos - 1 >= self.markedPos):
+ pass
+ else:
+ blocknumber += 1
+
number = 9 - config.key["9"] + key
# length of numberblock
number = 9 - config.key["9"] + key
# length of numberblock
- numberLen = len(str(self.valueBounds[
0
][1]))
+ numberLen = len(str(self.valueBounds[
blocknumber
][1]))
# position in the block
# position in the block
- posinblock = self.markedPos % numberLen
- # blocknumber
- blocknumber = self.markedPos / numberLen
+ posinblock = self.markedPos - self.blockLenTotal[blocknumber]
oldvalue = self.parent.value[blocknumber]
olddec = oldvalue % 10 ** (numberLen - posinblock) - (oldvalue % 10 ** (numberLen - posinblock - 1))
oldvalue = self.parent.value[blocknumber]
olddec = oldvalue % 10 ** (numberLen - posinblock) - (oldvalue % 10 ** (numberLen - posinblock - 1))
@@
-263,8
+274,11
@@
class configSequence:
num += 1
# only mark cursor when we are selected
# (this code is heavily ink optimized!)
num += 1
# only mark cursor when we are selected
# (this code is heavily ink optimized!)
- return ("mtext"[1-selected:], value, [mPos])
-
+ if (self.parent.enabled == True):
+ return ("mtext"[1-selected:], value, [mPos])
+ else:
+ return ("text", value)
+
class configText:
# used as first parameter
# is the text of a fixed size or is the user able to extend the length of the text
class configText:
# used as first parameter
# is the text of a fixed size or is the user able to extend the length of the text
@@
-275,6
+289,7
@@
class configText:
self.parent = parent
self.markedPos = 0
self.mode = self.parent.vals[0]
self.parent = parent
self.markedPos = 0
self.mode = self.parent.vals[0]
+ self.textInput = NumericalTextInput(self.nextEntry)
def checkValues(self):
if (self.markedPos < 0):
def checkValues(self):
if (self.markedPos < 0):
@@
-287,23
+302,32
@@
class configText:
def save(self):
self.parent.save()
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
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"]:
if key == config.key["prevElement"]:
+ self.textInput.nextKey()
self.markedPos -= 1
self.markedPos -= 1
+
if key == config.key["nextElement"]:
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)
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
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()
self.checkValues()
@@
-324,6
+348,7
@@
class Config:
self.key = { "choseElement": 0,
"prevElement": 1,
"nextElement": 2,
self.key = { "choseElement": 0,
"prevElement": 1,
"nextElement": 2,
+ "delete": 3,
"0": 10,
"1": 11,
"2": 12,
"0": 10,
"1": 11,
"2": 12,
@@
-336,6
+361,7
@@
class Config:
"9": 19 }
config = Config();
"9": 19 }
config = Config();
+
configfile = configFile()
class ConfigSlider:
configfile = configFile()
class ConfigSlider:
@@
-384,7
+410,7
@@
class configElement:
tcnt = cnt
cnt += 1
if tcnt != -1:
tcnt = cnt
cnt += 1
if tcnt != -1:
- return tcnt
+ return tcnt
return 0 #prevent bigger then array
def datafromFile(self, control, data):
return 0 #prevent bigger then array
def datafromFile(self, control, data):
@@
-418,7
+444,11
@@
class configElement:
return str(data.strip())
elif control == configSequence:
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:
# just in case you don't understand the above, here an equivalent:
# value = ""
# for i in data:
@@
-432,6
+462,7
@@
class configElement:
return ""
def loadData(self):
return ""
def loadData(self):
+ #print "load:" + self.configPath
try:
value = self.datafromFile(self.controlType, configfile.getKey(self.configPath))
except:
try:
value = self.datafromFile(self.controlType, configfile.getKey(self.configPath))
except:
@@
-447,6
+478,7
@@
class configElement:
self.save() #add missing value to dict
else:
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.value = value
#is this right? activate settings after load/cancel and use default
@@
-460,6
+492,10
@@
class configElement:
self.notifierList = [ ]
self.enabled = True
self.loadData()
self.notifierList = [ ]
self.enabled = True
self.loadData()
+
+ def getConfigPath(self):
+ return self.configPath
+
def addNotifier(self, notifier):
self.notifierList.append(notifier);
notifier(self);
def addNotifier(self, notifier):
self.notifierList.append(notifier);
notifier(self);
@@
-482,3
+518,9
@@
def getConfigListEntry(description, element):
b = element
item = b.controlType(b)
return ((description, item))
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()