aboutsummaryrefslogtreecommitdiff
path: root/lib/python
diff options
context:
space:
mode:
Diffstat (limited to 'lib/python')
-rw-r--r--lib/python/Components/Task.py12
-rw-r--r--lib/python/Plugins/Extensions/DVDBurn/Process.py19
-rw-r--r--lib/python/Plugins/Extensions/DVDBurn/TitleList.py30
-rw-r--r--lib/python/Screens/InfoBar.py8
-rw-r--r--lib/python/Screens/InfoBarGenerics.py24
-rw-r--r--lib/python/Screens/TaskView.py38
6 files changed, 88 insertions, 43 deletions
diff --git a/lib/python/Components/Task.py b/lib/python/Components/Task.py
index a87f58d9..9a9d9fb7 100644
--- a/lib/python/Components/Task.py
+++ b/lib/python/Components/Task.py
@@ -244,6 +244,7 @@ class JobManager:
self.active_jobs = [ ]
self.failed_jobs = [ ]
self.job_classes = [ ]
+ self.in_background = False
self.active_job = None
def AddJob(self, job):
@@ -258,8 +259,11 @@ class JobManager:
def jobDone(self, job, task, problems):
print "job", job, "completed with", problems, "in", task
+ from Tools import Notifications
+ if self.in_background:
+ from Screens.TaskView import JobView
+ Notifications.AddNotification(JobView, self.active_job)
if problems:
- from Tools import Notifications
from Screens.MessageBox import MessageBox
if problems[0].RECOVERABLE:
Notifications.AddNotificationWithCallback(self.errorCB, MessageBox, _("Error: %s\nRetry?") % (problems[0].getErrorMessage(task)))
@@ -282,6 +286,12 @@ class JobManager:
self.active_job = None
self.kick()
+ def getPendingJobs(self):
+ list = [ ]
+ if self.active_job:
+ list.append(self.active_job)
+ list += self.active_jobs
+ return list
# some examples:
#class PartitionExistsPostcondition:
# def __init__(self, device):
diff --git a/lib/python/Plugins/Extensions/DVDBurn/Process.py b/lib/python/Plugins/Extensions/DVDBurn/Process.py
index 71f7c998..c89f79c9 100644
--- a/lib/python/Plugins/Extensions/DVDBurn/Process.py
+++ b/lib/python/Plugins/Extensions/DVDBurn/Process.py
@@ -1,4 +1,4 @@
-from Components.Task import Task, Job, job_manager, DiskspacePrecondition, Condition, ToolExistsPrecondition
+from Components.Task import Task, Job, DiskspacePrecondition, Condition, ToolExistsPrecondition
from Components.Harddisk import harddiskmanager
from Screens.MessageBox import MessageBox
@@ -663,7 +663,7 @@ class DVDJob(Job):
DVDAuthorTask(self, diskSpaceNeeded)
nr_titles = len(self.project.titles)
-
+
if self.menupreview:
PreviewTask(self)
else:
@@ -706,18 +706,3 @@ class DVDdataJob(Job):
CopyMeta(self, title.inputfile)
BurnTask(self, ["-follow-links", self.workspace])
RemoveDVDFolder(self)
-
-def Burn(session, project):
- j = DVDJob(project)
- job_manager.AddJob(j)
- return j
-
-def PreviewMenu(session, project):
- j = DVDJob(project, menupreview=True)
- job_manager.AddJob(j)
- return j
-
-def BurnDataTS(session, project):
- j = DVDdataJob(project)
- job_manager.AddJob(j)
- return j
diff --git a/lib/python/Plugins/Extensions/DVDBurn/TitleList.py b/lib/python/Plugins/Extensions/DVDBurn/TitleList.py
index 3a732115..1842a5d7 100644
--- a/lib/python/Plugins/Extensions/DVDBurn/TitleList.py
+++ b/lib/python/Plugins/Extensions/DVDBurn/TitleList.py
@@ -1,9 +1,11 @@
-import DVDProject, TitleList, TitleCutter, ProjectSettings, DVDToolbox
+import DVDProject, TitleList, TitleCutter, ProjectSettings, DVDToolbox, Process
from Screens.Screen import Screen
from Screens.ChoiceBox import ChoiceBox
from Screens.InputBox import InputBox
from Screens.MessageBox import MessageBox
from Screens.HelpMenu import HelpableScreen
+from Screens.TaskView import JobView
+from Components.Task import job_manager
from Components.ActionMap import HelpableActionMap, ActionMap
from Components.Sources.List import List
from Components.Sources.StaticText import StaticText
@@ -185,24 +187,28 @@ class TitleList(Screen, HelpableScreen):
def burnProject(self):
if self.project.settings.authormode.getValue() == "data_ts":
- import Process
- job = Process.BurnDataTS(self.session, self.project)
- from Screens.TaskView import JobView
- self.session.open(JobView, job)
+ job = Process.DVDdataJob(self.project)
+ job_manager.AddJob(job)
+ job_manager.in_background = False
+ self.session.openWithCallback(self.JobViewCB, JobView, job)
else:
autochapter = self.project.settings.autochapter.getValue()
if autochapter > 0:
for title in self.project.titles:
title.produceAutoChapter(autochapter)
- import Process
- job = Process.Burn(self.session, self.project)
- from Screens.TaskView import JobView
- self.session.open(JobView, job)
+ job = Process.DVDJob(self.project)
+ job_manager.AddJob(job)
+ job_manager.in_background = False
+ self.session.openWithCallback(self.JobViewCB, JobView, job)
- def previewMenu(self):
- import Process
- job = Process.PreviewMenu(self.session, self.project)
+ def JobViewCB(self, in_background):
+ job_manager.in_background = in_background
+ def previewMenu(self):
+ job = Process.DVDJob(self.project, menupreview=True)
+ job_manager.in_background = False
+ job_manager.AddJob(job)
+
def updateTitleList(self):
res = [ ]
totalsize = 0
diff --git a/lib/python/Screens/InfoBar.py b/lib/python/Screens/InfoBar.py
index 92510141..a6b2516e 100644
--- a/lib/python/Screens/InfoBar.py
+++ b/lib/python/Screens/InfoBar.py
@@ -20,7 +20,7 @@ from Screens.InfoBarGenerics import InfoBarShowHide, \
InfoBarSubserviceSelection, InfoBarShowMovies, InfoBarTimeshift, \
InfoBarServiceNotifications, InfoBarPVRState, InfoBarCueSheetSupport, InfoBarSimpleEventView, \
InfoBarSummarySupport, InfoBarMoviePlayerSummarySupport, InfoBarTimeshiftState, InfoBarTeletextPlugin, InfoBarExtensions, \
- InfoBarSubtitleSupport, InfoBarPiP, InfoBarPlugins, InfoBarSleepTimer, InfoBarServiceErrorPopupSupport
+ InfoBarSubtitleSupport, InfoBarPiP, InfoBarPlugins, InfoBarSleepTimer, InfoBarServiceErrorPopupSupport, InfoBarJobman
profile("LOAD:InitBar_Components")
from Components.ActionMap import HelpableActionMap
@@ -36,7 +36,7 @@ class InfoBar(InfoBarBase, InfoBarShowHide,
HelpableScreen, InfoBarAdditionalInfo, InfoBarNotifications, InfoBarDish,
InfoBarSubserviceSelection, InfoBarTimeshift, InfoBarSeek,
InfoBarSummarySupport, InfoBarTimeshiftState, InfoBarTeletextPlugin, InfoBarExtensions,
- InfoBarPiP, InfoBarPlugins, InfoBarSubtitleSupport, InfoBarSleepTimer, InfoBarServiceErrorPopupSupport,
+ InfoBarPiP, InfoBarPlugins, InfoBarSubtitleSupport, InfoBarSleepTimer, InfoBarServiceErrorPopupSupport, InfoBarJobman,
Screen):
ALLOW_SUSPEND = True
@@ -57,8 +57,8 @@ class InfoBar(InfoBarBase, InfoBarShowHide,
InfoBarInstantRecord, InfoBarAudioSelection, \
InfoBarAdditionalInfo, InfoBarNotifications, InfoBarDish, InfoBarSubserviceSelection, \
InfoBarTimeshift, InfoBarSeek, InfoBarSummarySupport, InfoBarTimeshiftState, \
- InfoBarTeletextPlugin, InfoBarExtensions, InfoBarPiP, InfoBarSubtitleSupport, InfoBarSleepTimer, \
- InfoBarPlugins, InfoBarServiceErrorPopupSupport:
+ InfoBarTeletextPlugin, InfoBarExtensions, InfoBarPiP, InfoBarSubtitleSupport, InfoBarJobman, \
+ InfoBarSleepTimer, InfoBarPlugins, InfoBarServiceErrorPopupSupport:
x.__init__(self)
self.helpList.append((self["actions"], "InfobarActions", [("showMovies", _("view recordings..."))]))
diff --git a/lib/python/Screens/InfoBarGenerics.py b/lib/python/Screens/InfoBarGenerics.py
index f0130fc7..6cd310be 100644
--- a/lib/python/Screens/InfoBarGenerics.py
+++ b/lib/python/Screens/InfoBarGenerics.py
@@ -1274,6 +1274,30 @@ class InfoBarPlugins:
def runPlugin(self, plugin):
plugin(session = self.session, servicelist = self.servicelist)
+from Components.Task import job_manager
+class InfoBarJobman:
+ def __init__(self):
+ self.addExtension(extension = self.getJobList, type = InfoBarExtensions.EXTENSION_LIST)
+
+ def getJobList(self):
+ list = []
+ for job in job_manager.getPendingJobs():
+ list.append(((boundFunction(self.getJobName, job), boundFunction(self.showJobView, job), lambda: True), None))
+ 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)))
+
+ def showJobView(self, job):
+ from Screens.TaskView import JobView
+ job_manager.in_background = False
+ self.session.openWithCallback(self.JobViewCB, JobView, job)
+
+ def JobViewCB(self, in_background):
+ from Screens.TaskView import JobView
+ job_manager.in_background = in_background
+
# depends on InfoBarExtensions
class InfoBarSleepTimer:
def __init__(self):
diff --git a/lib/python/Screens/TaskView.py b/lib/python/Screens/TaskView.py
index 790e9bc6..48961f61 100644
--- a/lib/python/Screens/TaskView.py
+++ b/lib/python/Screens/TaskView.py
@@ -2,22 +2,27 @@ from Screen import Screen
from InfoBarGenerics import InfoBarNotifications
class JobView(InfoBarNotifications, Screen):
- def __init__(self, session, job, cancelable = True, close_on_finish = False):
+ def __init__(self, session, job, parent=None, cancelable = True, backgroundable = True, close_on_finish = False):
from Components.Sources.StaticText import StaticText
from Components.Sources.Progress import Progress
from Components.Sources.Boolean import Boolean
from Components.ActionMap import ActionMap
- Screen.__init__(self, session)
+ Screen.__init__(self, session, parent)
InfoBarNotifications.__init__(self)
+ self.parent = parent
self.job = job
+ self.job.taskview = self
self.close_on_finish = close_on_finish
- self.cancelable = cancelable
self["job_name"] = StaticText(job.name)
self["job_progress"] = Progress()
self["job_status"] = StaticText()
self["job_task"] = StaticText()
self["finished"] = Boolean()
+ self["cancelable"] = Boolean(cancelable)
+ self["backgroundable"] = Boolean(backgroundable)
+
+ self["key_blue"] = StaticText(_("Background"))
self.onShow.append(self.windowShow)
self.onHide.append(self.windowHide)
@@ -25,7 +30,13 @@ class JobView(InfoBarNotifications, Screen):
self["actions"] = ActionMap(["OkCancelActions"],
{
"ok": self.ok,
- "cancel": self.abort
+ "cancel": self.ok
+ })
+ self["ColorActions"] = ActionMap(["ColorActions"],
+ {
+ "red": self.abort,
+ "green": self.ok,
+ "blue": self.background,
})
def windowShow(self):
@@ -40,7 +51,7 @@ class JobView(InfoBarNotifications, Screen):
j = self.job
self["job_progress"].range = j.end
self["job_progress"].value = j.progress
- print "JobView::state_changed:", j.end, 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]
if j.status == j.IN_PROGRESS:
self["job_task"].text = j.tasks[j.current_task].name
@@ -49,15 +60,24 @@ class JobView(InfoBarNotifications, Screen):
if j.status in [j.FINISHED, j.FAILED]:
if self.close_on_finish:
self.close()
- else:
+ self["backgroundable"].boolean = False
+ if j.status == j.FINISHED:
self["finished"].boolean = True
+ self["cancelable"].boolean = False
+ elif j.status == j.FAILED:
+ self["cancelable"].boolean = True
+
+ def background(self):
+ print "[background]"
+ if self["backgroundable"].boolean == True:
+ self.close(True)
def ok(self):
if self.job.status in [self.job.FINISHED, self.job.FAILED]:
- self.close()
+ self.close(False)
def abort(self):
if self.job.status in [self.job.FINISHED, self.job.FAILED]:
- self.close()
- if self.cancelable:
+ self.close(False)
+ if self["cancelable"].boolean == True:
self.job.cancel()