allow styleable TemplatedMultiContent lists
[enigma2.git] / lib / python / Components / Converter / Streaming.py
index ece174908084c0ad49fa98786cc1a6f0a65e687e..2746ee847aa7c5cf8b89c16f778b46c826e3435a 100644 (file)
@@ -1,6 +1,13 @@
 from Converter import Converter
 from Components.Element import cached
 
 from Converter import Converter
 from Components.Element import cached
 
+# the protocol works as the following:
+
+# lines starting with '-' are fatal errors (no recovery possible),
+# lines starting with '=' are progress notices,
+# lines starting with '+' are PIDs to record:
+#      "+d:[p:t[,p:t...]]" with d=demux nr, p: pid, t: type
+
 class Streaming(Converter):
        def __init__(self, type):
                Converter.__init__(self, type)
 class Streaming(Converter):
        def __init__(self, type):
                Converter.__init__(self, type)
@@ -9,21 +16,20 @@ class Streaming(Converter):
        def getText(self):
                service = self.source.service
                if service is None:
        def getText(self):
                service = self.source.service
                if service is None:
-                       return "-NO SERVICE"
+                       return "-NO SERVICE\n"
 
                streaming = service.stream()
                s = streaming and streaming.getStreamingData()
 
 
                streaming = service.stream()
                s = streaming and streaming.getStreamingData()
 
-               if streaming is None:
+               if s is None:
                        err = service.getError()
                        err = service.getError()
-                       return "-1SERVICE ERROR:%d" % err
-
-               r = streaming.getStreamingData()
-               if r is None:
-                       return "-NO STREAM"
+                       if err:
+                               return "-SERVICE ERROR:%d\n" % err
+                       else:
+                               return "=NO STREAM\n"
 
 
-               demux = r["demux"]
-               pids = ','.join(["%x:%s" % (x[0], x[1]) for x in r["pids"]])
+               demux = s["demux"]
+               pids = ','.join(["%x:%s" % (x[0], x[1]) for x in s["pids"]])
 
                return "+%d:%s\n" % (demux, pids)
 
 
                return "+%d:%s\n" % (demux, pids)