- add timer, RecordTimer
[enigma2.git] / screens.py
index a3fc2e16640a257c62827dd2dbb846a5c7090c30..288a2256c7504708fc75fd02fc262ba8c39a2de0 100644 (file)
@@ -6,6 +6,7 @@ import xml.dom.minidom
 from xml.dom import EMPTY_NAMESPACE
 from skin import elementsWithTag
 
+import time
 
 # some screens
 def doGlobal(screen):
@@ -306,7 +307,7 @@ class channelSelection(Screen):
                        self["list"].removeMarked(ref)
                else:
                        self["list"].addMarked(ref)
-               
+                       
        def channelSelected(self):
                self.session.nav.playService(self["list"].getCurrent())
                self.close()
@@ -332,7 +333,8 @@ class infoBar(Screen):
                                "switchChannel": self.switchChannel,
                                "mainMenu": self.mainMenu,
                                "zapUp": self.zapUp,
-                               "zapDown": self.zapDown
+                               "zapDown": self.zapDown,
+                               "instantRecord": self.instantRecord
                        })
                self["okbutton"] = Button("mainMenu", [self.mainMenu])
                
@@ -345,6 +347,8 @@ class infoBar(Screen):
 
                self["Event_Now_Duration"] = EventInfo(self.session.nav, EventInfo.Now_Duration)
                self["Event_Next_Duration"] = EventInfo(self.session.nav, EventInfo.Next_Duration)
+               
+               self.recording = None
        
        def mainMenu(self):
                print "loading mainmenu XML..."
@@ -360,6 +364,27 @@ class infoBar(Screen):
 
        def     zapDown(self):
                self.servicelist.zapDown()
+               
+       def instantRecord(self):
+               if self.recording != None:
+                       print "remove entry"
+                       self.session.nav.RecordTimer.removeEntry(self.recording)
+                       self.recording = None
+               else:
+                       serviceref = self.session.nav.getCurrentlyPlayingServiceReference()
+                       
+                       # try to get event info
+                       epg = None
+                       service = self.session.nav.getCurrentService()
+                       if service != None:
+                               info = iServiceInformationPtr()
+                               if not service.info(info):
+                                       ev = eServiceEventPtr()
+                                       if info.getEvent(ev, 0) == 0:
+                                               epg = ev
+
+                       self.recording = self.session.nav.recordWithTimer(time.time(), time.time() + 30, serviceref, epg)
+                       print "got entry: %s" % (str(self.recording))
 
 # a clock display dialog
 class clockDisplay(Screen):
@@ -395,4 +420,3 @@ class serviceScan(Screen):
                                "ok": self.ok,
                                "cancel": self.cancel
                        })
-