- fixed dvb scan
[enigma2.git] / skin.py
diff --git a/skin.py b/skin.py
index 5d482fdb32f0ab4b751f22f2a331a6aa5626fb47..9fbdfeb4fa34f3446fad55c2340b98a76aacace1 100644 (file)
--- a/skin.py
+++ b/skin.py
@@ -11,11 +11,26 @@ def dump(x, i=0):
                None
 
 dom = xml.dom.minidom.parseString(
-       "<screen name=\"clockDialog\" position=\"300,100\" size=\"300,300\"> \
-               <widget name=\"okbutton\" position=\"10,10\" size=\"280,40\" /> \
-               <widget name=\"theClock\" position=\"10,60\" size=\"280,50\" /> \
-               <widget name=\"title\" position=\"10,120\" size=\"280,50\" /> \
-       </screen>")
+       """
+       <skin>
+               <screen name="testDialog">
+                       <widget name="okbutton" position="10,190" size="280,50" />
+                       <widget name="title" position="10,10" size="280,20" />
+                       <widget name="menu" position="10,30" size="280,140" />
+               </screen>
+               <screen name="clockDisplay" position="300,100" size="300,300">
+                       <widget name="okbutton" position="10,10" size="280,40" />
+                       <widget name="title" position="10,120" size="280,50" />
+                       <widget name="theClock" position="10,60" size="280,50" />
+               </screen>
+               <screen name="mainMenu" position="300,100" size="300,300">
+                       <widget name="title" position="10,10" size="280,80" />
+                       <widget name="okbutton" position="10,190" size="280,50" />
+               </screen>
+       </skin>
+""")
+
+
 
 def parsePosition(str):
        x, y = str.split(',')
@@ -43,22 +58,26 @@ def applyGUIskin(screen, skin, name):
        myscreen = None
        
        # first, find the corresponding screen element
-       screens = dom.getElementsByTagName("screen")
+       skin = dom.getElementsByTagName("skin")[0]
+       screens = skin.getElementsByTagName("screen")
+       del skin
        for x in screens:
                if x.getAttribute('name') == name:
                        myscreen = x
        
-       if myscreen == None:
-               print "no skin for screen " + name + " found!"
-               return;
+       assert myscreen != None, "no skin for screen '" + name + "' found!"
        
        # now walk all widgets
        for widget in myscreen.getElementsByTagName("widget"):
-               name = widget.getAttribute('name')
-               if name == None:
+               wname = widget.getAttribute('name')
+               if wname == None:
                        print "widget has no name!"
                        continue
                
                # get corresponding gui object
-               guiObject = screen.data[name]["instance"]
+               try:
+                       guiObject = screen.data[wname]["instance"]
+               except:
+                       raise str("component with name '" + wname + "' was not found in skin of screen '" + name + "'!")
+               
                applyAttributes(guiObject, widget)