summaryrefslogtreecommitdiff
path: root/src/lib/check_content_change_job.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2021-11-28 10:39:03 +0100
committerCarl Hetherington <cth@carlh.net>2021-11-28 21:13:15 +0100
commit94ab538738526948c5a52ed1222be1e484255541 (patch)
treef14be732d23dfac5ee41149eaee2db43b1710d32 /src/lib/check_content_change_job.cc
parentd41a59b6ef7a8c935f182d498ae4df0bdd66ba02 (diff)
Rearrange checking (and re-examining) content.
Most importantly, checking of content for changes before making a DCP is now done in the TranscodeJob (rather than being in a separate job). This makes things a little neater and also makes the batch converter less confusing when you add a job whose content has changed.
Diffstat (limited to 'src/lib/check_content_change_job.cc')
-rw-r--r--src/lib/check_content_change_job.cc34
1 files changed, 4 insertions, 30 deletions
diff --git a/src/lib/check_content_change_job.cc b/src/lib/check_content_change_job.cc
index 967291bb3..500e03c1d 100644
--- a/src/lib/check_content_change_job.cc
+++ b/src/lib/check_content_change_job.cc
@@ -32,11 +32,8 @@ using std::list;
using std::cout;
using std::shared_ptr;
-/** @param gui true if we are running this job from the GUI, false if it's the CLI */
-CheckContentChangeJob::CheckContentChangeJob (shared_ptr<const Film> film, shared_ptr<Job> following, bool gui)
+CheckContentChangeJob::CheckContentChangeJob (shared_ptr<const Film> film)
: Job (film)
- , _following (following)
- , _gui (gui)
{
}
@@ -68,35 +65,12 @@ CheckContentChangeJob::run ()
std::copy_if (content.begin(), content.end(), std::back_inserter(changed), [](shared_ptr<Content> c) { return c->changed(); });
if (!changed.empty()) {
- if (_gui) {
- for (auto i: changed) {
- JobManager::instance()->add(shared_ptr<Job>(new ExamineContentJob(_film, i)));
- }
- string m = _("Some files have been changed since they were added to the project.\n\nThese files will now be re-examined, so you may need to check their settings.");
- if (_following) {
- /* I'm assuming that _following is a make DCP job */
- m += " ";
- m += _("Choose 'Make DCP' again when you have done this.");
- }
- set_message (m);
- } else {
- set_progress (1);
- set_state (FINISHED_ERROR);
- set_error (
- _("Some files have been changed since they were added to the project. Open the project in DCP-o-matic, check the settings, then save it before trying again."),
- ""
- );
- return;
+ for (auto i: changed) {
+ JobManager::instance()->add(make_shared<ExamineContentJob>(_film, i));
}
- } else if (_following) {
- JobManager::instance()->add (_following);
+ set_message (_("Some files have been changed since they were added to the project.\n\nThese files will now be re-examined, so you may need to check their settings."));
}
- /* Only set this job as finished once we have added the following job, otherwise I think
- it's possible that the tests will sporadically fail if they check for all jobs being
- complete in the gap between this one finishing and _following being added.
- */
-
set_progress (1);
set_state (FINISHED_OK);
}