do unlock thread before send signal
[enigma2.git] / ServiceReference.py
index c4c2f467ef93ca9a6114e686708327a5aa35ce9a..238e7f6caf0972cb3de11f3e41ad22845a8a0863 100644 (file)
@@ -6,21 +6,32 @@ import NavigationInstance
 class ServiceReference(eServiceReference):
        def __init__(self, ref):
                if isinstance(ref, str):
-                       ref = eServiceReference(ref)
-               self.ref = ref
+                       self.ref = eServiceReference(ref)
+               else:
+                       self.ref = ref
+               self.serviceHandler = eServiceCenter.getInstance()
 
-       def getStaticServiceInformation(self):
-               info = iStaticServiceInformationPtr()
-               if NavigationInstance.instance.ServiceHandler.info(self.ref, info):
-                       info = None
-               return info
-       
        def __str__(self):
                return self.ref.toString()
        
        def getServiceName(self):
-               info = self.getStaticServiceInformation()
-               if not info:
+               info = self.info()
+               if info is None:
                        return None
                
                return info.getName(self.ref)
+
+       def play(self):
+               return self.serviceHandler.info(self.ref)
+       
+       def record(self):
+               return self.serviceHandler.record(self.ref)
+       
+       def list(self):
+               return self.serviceHandler.list(self.ref)
+       
+       def info(self):
+               return self.serviceHandler.info(self.ref)
+
+       def offlineOperations(self):
+               return self.serviceHandler.offlineOperations(self.ref)