fixes bug #556
[enigma2.git] / ServiceReference.py
index 150708d105ef560289be01c84b4a8e3722f90e4d..5d11ae77499189606f0cb00e58ca099abc0afa95 100644 (file)
@@ -1,13 +1,11 @@
-
-from enigma import *
-
-import NavigationInstance
+from enigma import eServiceReference, eServiceCenter
 
 class ServiceReference(eServiceReference):
        def __init__(self, ref):
-               if isinstance(ref, str):
-                       ref = eServiceReference(ref)
-               self.ref = ref
+               if not isinstance(ref, eServiceReference):
+                       self.ref = eServiceReference(ref or "")
+               else:
+                       self.ref = ref
                self.serviceHandler = eServiceCenter.getInstance()
 
        def __str__(self):
@@ -15,22 +13,16 @@ class ServiceReference(eServiceReference):
        
        def getServiceName(self):
                info = self.info()
-               if info is None:
-                       return None
-               
-               return info.getName(self.ref)
+               return info and info.getName(self.ref) or ""
 
-       def play(self):
+       def info(self):
                return self.serviceHandler.info(self.ref)
-       
-       def record(self):
-               return self.serviceHandler.record(self.ref)
-       
+
        def list(self):
-               return self.serviceHandler.list(self)
+               return self.serviceHandler.list(self.ref)
        
-       def info(self):
-               return self.serviceHandler.info(self)
-
-       def offlineOperations(self):
-               return self.serviceHandler.offlineOperations(self.ref)
+       def getType(self):
+               return self.ref.type
+       
+       def getPath(self):
+               return self.ref.getPath()