X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fjob_manager.h;h=2788fc657d2a00278e81ac55fb6c785059134dce;hp=d1d33cfc2ce7e7dc3ac4693d579d7309e0ec30e5;hb=f0c10e92b849566e458bc323f8783a6fe83e52d2;hpb=922361469072474da4294a90f1436cd0117cb90f diff --git a/src/lib/job_manager.h b/src/lib/job_manager.h index d1d33cfc2..2788fc657 100644 --- a/src/lib/job_manager.h +++ b/src/lib/job_manager.h @@ -1,19 +1,20 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2018 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 . */ @@ -21,35 +22,78 @@ * @brief A simple scheduler for jobs. */ -#include +#include "signaller.h" #include +#include +#include +#include +#include class Job; +class Film; +class Playlist; +struct threed_test7; + +extern bool wait_for_jobs (); /** @class JobManager * @brief A simple scheduler for jobs. - * - * JobManager simply keeps a list of pending jobs, and assumes that all the jobs - * are sufficiently CPU intensive that there is no point running them in parallel; - * so jobs are just run one after the other. */ -class JobManager +class JobManager : public Signaller, public boost::noncopyable { public: - - void add (boost::shared_ptr); - void add_after (boost::shared_ptr after, boost::shared_ptr j); + boost::shared_ptr add (boost::shared_ptr); + boost::shared_ptr add_after (boost::shared_ptr after, boost::shared_ptr j); std::list > get () const; bool work_to_do () const; + bool errors () const; + void increase_priority (boost::shared_ptr); + void decrease_priority (boost::shared_ptr); + void pause (); + void resume (); + bool paused () const { + boost::mutex::scoped_lock lm (_mutex); + return _paused; + } + + void analyse_audio ( + boost::shared_ptr film, + boost::shared_ptr playlist, + bool from_zero, + boost::signals2::connection& connection, + boost::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 bool ::wait_for_jobs (); + friend struct threed_test7; + JobManager (); + ~JobManager (); void scheduler (); - + void start (); + void priority_changed (); + void job_finished (); + mutable boost::mutex _mutex; + boost::condition _empty_condition; + /** List of jobs in the order that they will be executed */ std::list > _jobs; + std::list _connections; + bool _terminate; + bool _paused; + boost::shared_ptr _paused_job; + + boost::optional _last_active_job; + boost::thread* _scheduler; static JobManager* _instance; };