X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fjob_manager.h;h=c8450bfdae152e3d4101ad0f1b3c063825e4cc55;hp=3cd8be6d67e21207caaeb86cb25d57943ac87b57;hb=a6c4b4fa16d9c6597e362044b875f3d6df80753f;hpb=1934870acbab5efe51afecff46081a5850876eee diff --git a/src/lib/job_manager.h b/src/lib/job_manager.h index 3cd8be6d6..c8450bfda 100644 --- a/src/lib/job_manager.h +++ b/src/lib/job_manager.h @@ -1,68 +1,115 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ + /** @file src/job_manager.h * @brief A simple scheduler for jobs. */ + +#include "job.h" #include "signaller.h" #include #include #include +#include #include -class Job; -extern void wait_for_jobs (); + +class Film; +class Playlist; +class Content; +struct threed_test7; + + +extern bool wait_for_jobs (); + /** @class JobManager * @brief A simple scheduler for jobs. */ -class JobManager : public Signaller, public boost::noncopyable +class JobManager : public Signaller { public: + JobManager (JobManager const&) = delete; + JobManager& operator= (JobManager const&) = delete; - boost::shared_ptr add (boost::shared_ptr); - std::list > get () const; + std::shared_ptr add (std::shared_ptr); + std::shared_ptr add_after (std::shared_ptr after, std::shared_ptr j); + std::list> get () const; bool work_to_do () const; bool errors () const; - - boost::signals2::signal)> JobAdded; - boost::signals2::signal ActiveJobsChanged; + void increase_priority (std::shared_ptr); + void decrease_priority (std::shared_ptr); + void pause (); + void resume (); + bool paused () const { + boost::mutex::scoped_lock lm (_mutex); + return _paused; + } + + void analyse_audio ( + std::shared_ptr film, + std::shared_ptr playlist, + bool from_zero, + boost::signals2::connection& connection, + std::function ready + ); + + void analyse_subtitles ( + std::shared_ptr film, + std::shared_ptr content, + boost::signals2::connection& connection, + std::function ready + ); + + boost::signals2::signal)> JobAdded; + boost::signals2::signal JobsReordered; + boost::signals2::signal, boost::optional)> ActiveJobsChanged; static JobManager* instance (); static void drop (); private: /* This function is part of the test suite */ - friend void ::wait_for_jobs (); + friend bool ::wait_for_jobs (); + friend struct threed_test7; JobManager (); ~JobManager (); void scheduler (); void start (); + void job_finished (); mutable boost::mutex _mutex; - std::list > _jobs; - bool _terminate; + boost::condition _schedule_condition; + /** List of jobs in the order that they will be executed */ + std::list> _jobs; + std::list _connections; + bool _terminate = false; + + boost::optional _last_active_job; + boost::thread _scheduler; - bool _last_active_jobs; - boost::thread* _scheduler; + /** true if all jobs should be paused */ + bool _paused = false; static JobManager* _instance; };