X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/232de34f743061ff056b6208f1cf22d88ab755d3..4abd28c8904cc0858fa811e8d9438304624f888b:/skin.py diff --git a/skin.py b/skin.py index 30160161..a4d43f24 100644 --- a/skin.py +++ b/skin.py @@ -17,10 +17,8 @@ def dump(x, i=0): from Tools.Directories import resolveFilename, SCOPE_SKIN, SCOPE_SKIN_IMAGE # read the skin -skinfile = file(resolveFilename(SCOPE_SKIN, 'skin.xml'), 'r') -dom = xml.dom.minidom.parseString(skinfile.read()) -skinfile.close() - +dom_skin = xml.dom.minidom.parse(resolveFilename(SCOPE_SKIN, 'skin.xml')) +dom_skin_default = xml.dom.minidom.parse(resolveFilename(SCOPE_SKIN, 'skin_default.xml')) def parsePosition(str): x, y = str.split(',') @@ -155,7 +153,7 @@ def applyAllAttributes(guiObject, desktop, attributes): def loadSkin(desktop): print "loading skin..." - skin = dom.childNodes[0] + skin = dom_skin.childNodes[0] assert skin.tagName == "skin", "root element in skin must be 'skin'!" for c in elementsWithTag(skin.childNodes, "colors"): @@ -203,14 +201,24 @@ def readSkin(screen, skin, name, desktop): myscreen = None # first, find the corresponding screen element - skin = dom.childNodes[0] + skin = dom_skin.childNodes[0] + skin_default = dom_skin_default.childNodes[0] for x in elementsWithTag(skin.childNodes, "screen"): if x.getAttribute('name') == name: myscreen = x - del skin + break + + # if not found, check default skin + if myscreen is None: + for x in elementsWithTag(skin_default.childNodes, "screen"): + if x.getAttribute('name') == name: + myscreen = x + break + + del skin, skin_default - # try embedded skin + # otherwise try embedded skin myscreen = myscreen or getattr(screen, "parsedSkin", None) # try uncompiled embedded skin