X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fjob_manager.h;h=dd7a28db208914c3c67e06d09f04d5acd1c96595;hb=8f8730cadb3dae36e8aa7b7c732a7c162eac0fb6;hp=c623b6ef98d7f7fd5831b9644281a10946b58084;hpb=f5bc071ddac2355da1d116404cc37f4485e97699;p=dcpomatic.git diff --git a/src/lib/job_manager.h b/src/lib/job_manager.h index c623b6ef9..dd7a28db2 100644 --- a/src/lib/job_manager.h +++ b/src/lib/job_manager.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2015 Carl Hetherington + Copyright (C) 2012-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -26,11 +26,14 @@ #include #include #include +#include #include class Job; class Film; class Playlist; +class Content; +struct threed_test7; extern bool wait_for_jobs (); @@ -41,15 +44,30 @@ class JobManager : public Signaller, public boost::noncopyable { public: 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 + ); + + void analyse_subtitles ( + boost::shared_ptr film, + boost::shared_ptr content, boost::signals2::connection& connection, boost::function ready ); @@ -64,20 +82,26 @@ public: 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; + boost::thread _scheduler; static JobManager* _instance; };