remove unneeded imports
[enigma2.git] / lib / python / Components / Renderer / Picon.py
index 2dfafb99cd19185cfbf528d7edcadeff76da5155..d5212638343f15f492f2b9259b5698caf6b778e5 100644 (file)
@@ -3,18 +3,28 @@
 ##
 from Renderer import Renderer
 from enigma import ePixmap
-from Tools.Directories import pathExists, fileExists, SCOPE_SKIN_IMAGE, resolveFilename
+from Tools.Directories import fileExists, SCOPE_SKIN_IMAGE, resolveFilename
 
 class Picon(Renderer):
-       pngname = ""
-       nameCache = { }
-       searchPaths = ['/usr/share/enigma2/picon/',
-                               '/media/cf/picon/',
-                               '/media/usb/picon/',
-                               '/media/hdd/picon/']
+       searchPaths = ['/usr/share/enigma2/%s/',
+                               '/media/cf/%s/',
+                               '/media/usb/%s/']
 
        def __init__(self):
                Renderer.__init__(self)
+               self.path = "picon"
+               self.nameCache = { }
+               self.pngname = ""
+
+       def applySkin(self, desktop):
+               attribs = [ ]
+               for (attrib, value) in self.skinAttributes:
+                       if attrib == "path":
+                               self.path = value
+                       else:
+                               attribs.append((attrib,value))
+               self.skinAttributes = attribs
+               return Renderer.applySkin(self, desktop)
 
        GUI_WIDGET = ePixmap
 
@@ -26,7 +36,7 @@ class Picon(Renderer):
                                # strip all after last :
                                pos = sname.rfind(':')
                                if pos != -1:
-                                       sname = sname[:pos].rstrip(':')
+                                       sname = sname[:pos].rstrip(':').replace(':','_')
                                pngname = self.nameCache.get(sname, "")
                                if pngname == "":
                                        pngname = self.findPicon(sname)
@@ -45,7 +55,7 @@ class Picon(Renderer):
 
        def findPicon(self, serviceName):
                for path in self.searchPaths:
-                       pngname = path + serviceName + ".png"
+                       pngname = (path % self.path) + serviceName + ".png"
                        if fileExists(pngname):
                                return pngname
                return ""