2 Copyright (C) 2018-2019 Carl Hetherington <cth@carlh.net>
4 This file is part of DCP-o-matic.
6 DCP-o-matic is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 DCP-o-matic is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
21 #include "check_content_change_job.h"
22 #include "job_manager.h"
23 #include "examine_content_job.h"
26 #include "dcpomatic_log.h"
27 #include <boost/foreach.hpp>
35 using boost::shared_ptr;
37 CheckContentChangeJob::CheckContentChangeJob (shared_ptr<const Film> film, shared_ptr<Job> following)
39 , _following (following)
45 CheckContentChangeJob::name () const
47 return _("Checking content for changes");
51 CheckContentChangeJob::json_name () const
53 return N_("check_content_change");
57 CheckContentChangeJob::run ()
59 set_progress_unknown ();
61 list<shared_ptr<Content> > changed;
63 BOOST_FOREACH (shared_ptr<Content> i, _film->content()) {
65 for (size_t j = 0; j < i->number_of_paths(); ++j) {
66 if (boost::filesystem::last_write_time(i->path(j)) != i->last_write_time(j)) {
67 LOG_GENERAL("File %1 changed; last_write_time now %2, was %3", i->path(j).string(), boost::filesystem::last_write_time(i->path(j)), i->last_write_time(j));
72 if (!ic && i->calculate_digest() != i->digest()) {
73 LOG_GENERAL("Content %1 changed; digest now %2, was %3", i->path(0).string(), i->calculate_digest(), i->digest());
77 changed.push_back (i);
81 BOOST_FOREACH (shared_ptr<Content> i, changed) {
82 JobManager::instance()->add(shared_ptr<Job>(new ExamineContentJob(_film, i)));
85 if (!changed.empty()) {
86 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.");
88 /* I'm assuming that _following is a make DCP job */
90 m += _("Choose 'Make DCP' again when you have done this.");
93 } else if (_following) {
94 JobManager::instance()->add (_following);
97 /* Only set this job as finished once we have added the following job, otherwise I think
98 it's possible that the tests will sporadically fail if they check for all jobs being
99 complete in the gap between this one finishing and _following being added.
103 set_state (FINISHED_OK);