diff options
| author | Carl Hetherington <cth@carlh.net> | 2021-11-28 10:39:03 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2021-11-28 21:13:15 +0100 |
| commit | 94ab538738526948c5a52ed1222be1e484255541 (patch) | |
| tree | f14be732d23dfac5ee41149eaee2db43b1710d32 /src/lib/check_content_change_job.cc | |
| parent | d41a59b6ef7a8c935f182d498ae4df0bdd66ba02 (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.cc | 34 |
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); } |
