aboutsummaryrefslogtreecommitdiff
path: root/lib/python
diff options
context:
space:
mode:
authorAndreas Frisch <andreas.frisch@multimedia-labs.de>2008-10-15 10:30:24 +0000
committerAndreas Frisch <andreas.frisch@multimedia-labs.de>2008-10-15 10:30:24 +0000
commit0c2185a46606c2ac3e41205fe92e6d5ba4ead1b9 (patch)
tree250e48970d8cfb3939a815b9e275d6c9c472373c /lib/python
parentf90166ed3e8f94ef638a0f9adfa48cd1e455a637 (diff)
downloadenigma2-0c2185a46606c2ac3e41205fe92e6d5ba4ead1b9.tar.gz
enigma2-0c2185a46606c2ac3e41205fe92e6d5ba4ead1b9.zip
check for running jobs before shutting down/rebooting
Diffstat (limited to 'lib/python')
-rw-r--r--lib/python/Components/Task.py3
-rw-r--r--lib/python/Screens/InfoBarGenerics.py3
-rw-r--r--lib/python/Screens/Standby.py19
-rw-r--r--lib/python/Screens/TaskView.py25
4 files changed, 31 insertions, 19 deletions
diff --git a/lib/python/Components/Task.py b/lib/python/Components/Task.py
index 9a9d9fb7..659660e8 100644
--- a/lib/python/Components/Task.py
+++ b/lib/python/Components/Task.py
@@ -37,6 +37,9 @@ class Job(object):
progress = property(getProgress)
+ def getStatustext(self):
+ return { self.NOT_STARTED: _("Waiting"), self.IN_PROGRESS: _("In Progress"), self.FINISHED: _("Finished"), self.FAILED: _("Failed") }[self.status]
+
def task_progress_changed_CB(self):
self.state_changed()
diff --git a/lib/python/Screens/InfoBarGenerics.py b/lib/python/Screens/InfoBarGenerics.py
index 6cd310be..1156e139 100644
--- a/lib/python/Screens/InfoBarGenerics.py
+++ b/lib/python/Screens/InfoBarGenerics.py
@@ -1286,8 +1286,7 @@ class InfoBarJobman:
return list
def getJobName(self, job):
- statustext = {job.NOT_STARTED: _("Waiting"), job.IN_PROGRESS: _("In Progress"), job.FINISHED: _("Finished"), job.FAILED: _("Failed")}[job.status]
- return "%s: %s (%d%%)" % (statustext, job.name, int(100*job.progress/float(job.end)))
+ return "%s: %s (%d%%)" % (job.getStatustext(), job.name, int(100*job.progress/float(job.end)))
def showJobView(self, job):
from Screens.TaskView import JobView
diff --git a/lib/python/Screens/Standby.py b/lib/python/Screens/Standby.py
index fd7ca8ef..4c3a1720 100644
--- a/lib/python/Screens/Standby.py
+++ b/lib/python/Screens/Standby.py
@@ -89,6 +89,7 @@ class StandbySummary(Screen):
from enigma import quitMainloop, iRecordableService
from Screens.MessageBox import MessageBox
from time import time
+from Components.Task import job_manager
inTryQuitMainloop = False
@@ -96,19 +97,29 @@ class TryQuitMainloop(MessageBox):
def __init__(self, session, retvalue=1, timeout=-1, default_yes = True):
self.retval=retvalue
recordings = len(session.nav.getRecordings())
+ jobs = len(job_manager.getPendingJobs())
self.connected = False
+ reason = ""
next_rec_time = -1
if not recordings:
- next_rec_time = session.nav.RecordTimer.getNextRecordingTime()
+ next_rec_time = session.nav.RecordTimer.getNextRecordingTime()
if recordings or (next_rec_time > 0 and (next_rec_time - time()) < 360):
+ reason = _("Recording(s) are in progress or coming up in few seconds!") + '\n'
+ if jobs:
+ if jobs == 1:
+ job = job_manager.getPendingJobs()[0]
+ reason += "%s: %s (%d%%)\n" % (job.getStatustext(), job.name, int(100*job.progress/float(job.end)))
+ else:
+ reason += (_("%d jobs are running in the background!") % jobs) + '\n'
+ if reason:
if retvalue == 1:
- MessageBox.__init__(self, session, _("Recording(s) are in progress or coming up in few seconds... really shutdown now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
+ MessageBox.__init__(self, session, reason+_("Really shutdown now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
elif retvalue == 2:
- MessageBox.__init__(self, session, _("Recording(s) are in progress or coming up in few seconds... really reboot now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
+ MessageBox.__init__(self, session, reason+_("Really reboot now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
elif retvalue == 4:
pass
else:
- MessageBox.__init__(self, session, _("Recording(s) are in progress or coming up in few seconds... really restart now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
+ MessageBox.__init__(self, session, reason+_("Really restart now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
self.skinName = "MessageBox"
session.nav.record_event.append(self.getRecordEvent)
self.connected = True
diff --git a/lib/python/Screens/TaskView.py b/lib/python/Screens/TaskView.py
index 06348579..8d38ed62 100644
--- a/lib/python/Screens/TaskView.py
+++ b/lib/python/Screens/TaskView.py
@@ -13,6 +13,7 @@ class JobView(InfoBarNotifications, Screen, ConfigListScreen):
from Components.ActionMap import ActionMap
Screen.__init__(self, session, parent)
InfoBarNotifications.__init__(self)
+ ConfigListScreen.__init__(self, [])
self.parent = parent
self.job = job
self.job.taskview = self
@@ -30,18 +31,15 @@ class JobView(InfoBarNotifications, Screen, ConfigListScreen):
self.onShow.append(self.windowShow)
self.onHide.append(self.windowHide)
- self["actions"] = ActionMap(["OkCancelActions"],
- {
- "ok": self.ok,
- "cancel": self.ok
- })
- self["ColorActions"] = ActionMap(["ColorActions"],
- {
- "red": self.abort,
- "green": self.ok,
- "blue": self.background,
- })
- ConfigListScreen.__init__(self, [])
+ self["setupActions"] = ActionMap(["SetupActions", "ColorActions"],
+ {
+ "green": self.ok,
+ "red": self.abort,
+ "blue": self.background,
+ "cancel": self.ok,
+ "ok": self.ok,
+ }, -2)
+
self.afterevents = [ "nothing", "standby", "deepstandby", "close" ]
self.settings = ConfigSubsection()
self.settings.afterEvent = ConfigSelection(choices = [("nothing", _("do nothing")), ("close", _("Close")), ("standby", _("go to standby")), ("deepstandby", _("go to deep standby"))], default = self.afterevents[afterEvent])
@@ -71,7 +69,7 @@ class JobView(InfoBarNotifications, Screen, ConfigListScreen):
self["job_progress"].range = j.end
self["job_progress"].value = j.progress
#print "JobView::state_changed:", j.end, j.progress
- self["job_status"].text = {j.NOT_STARTED: _("Waiting"), j.IN_PROGRESS: _("In Progress"), j.FINISHED: _("Finished"), j.FAILED: _("Failed")}[j.status]
+ self["job_status"].text = j.getStatustext()
if j.status == j.IN_PROGRESS:
self["job_task"].text = j.tasks[j.current_task].name
else:
@@ -100,6 +98,7 @@ class JobView(InfoBarNotifications, Screen, ConfigListScreen):
self.job.cancel()
def performAfterEvent(self):
+ self["config"].hide()
if self.settings.afterEvent.getValue() == "nothing":
return
elif self.settings.afterEvent.getValue() == "close":