projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix font_id_map errors when importing DCP subtitles that have no
[dcpomatic.git]
/
src
/
lib
/
job_manager.h
diff --git
a/src/lib/job_manager.h
b/src/lib/job_manager.h
index e0b72994df9dd2ab87495df0c6be3eb710afca2e..71db33fd6bf9d2b14fe8037ec1c56a5d7de1de67 100644
(file)
--- a/
src/lib/job_manager.h
+++ b/
src/lib/job_manager.h
@@
-1,5
+1,5
@@
/*
/*
- Copyright (C) 2012-20
18
Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2012-20
21
Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
This file is part of DCP-o-matic.
@@
-18,10
+18,12
@@
*/
*/
+
/** @file src/job_manager.h
* @brief A simple scheduler for jobs.
*/
/** @file src/job_manager.h
* @brief A simple scheduler for jobs.
*/
+
#include "signaller.h"
#include <boost/thread/mutex.hpp>
#include <boost/thread.hpp>
#include "signaller.h"
#include <boost/thread/mutex.hpp>
#include <boost/thread.hpp>
@@
-29,25
+31,33
@@
#include <boost/thread/condition.hpp>
#include <list>
#include <boost/thread/condition.hpp>
#include <list>
+
class Job;
class Film;
class Playlist;
class Job;
class Film;
class Playlist;
+class Content;
+struct threed_test7;
+
extern bool wait_for_jobs ();
extern bool wait_for_jobs ();
+
/** @class JobManager
* @brief A simple scheduler for jobs.
*/
/** @class JobManager
* @brief A simple scheduler for jobs.
*/
-class JobManager : public Signaller
, public boost::noncopyable
+class JobManager : public Signaller
{
public:
{
public:
- boost::shared_ptr<Job> add (boost::shared_ptr<Job>);
- boost::shared_ptr<Job> add_after (boost::shared_ptr<Job> after, boost::shared_ptr<Job> j);
- std::list<boost::shared_ptr<Job> > get () const;
+ JobManager (JobManager const&) = delete;
+ JobManager& operator= (JobManager const&) = delete;
+
+ std::shared_ptr<Job> add (std::shared_ptr<Job>);
+ std::shared_ptr<Job> add_after (std::shared_ptr<Job> after, std::shared_ptr<Job> j);
+ std::list<std::shared_ptr<Job>> get () const;
bool work_to_do () const;
bool errors () const;
bool work_to_do () const;
bool errors () const;
- void increase_priority (
boost
::shared_ptr<Job>);
- void decrease_priority (
boost
::shared_ptr<Job>);
+ void increase_priority (
std
::shared_ptr<Job>);
+ void decrease_priority (
std
::shared_ptr<Job>);
void pause ();
void resume ();
bool paused () const {
void pause ();
void resume ();
bool paused () const {
@@
-56,14
+66,21
@@
public:
}
void analyse_audio (
}
void analyse_audio (
-
boost
::shared_ptr<const Film> film,
-
boost
::shared_ptr<const Playlist> playlist,
+
std
::shared_ptr<const Film> film,
+
std
::shared_ptr<const Playlist> playlist,
bool from_zero,
boost::signals2::connection& connection,
bool from_zero,
boost::signals2::connection& connection,
- boost::function<void()> ready
+ std::function<void()> ready
+ );
+
+ void analyse_subtitles (
+ std::shared_ptr<const Film> film,
+ std::shared_ptr<Content> content,
+ boost::signals2::connection& connection,
+ std::function<void()> ready
);
);
- boost::signals2::signal<void (
boost
::weak_ptr<Job>)> JobAdded;
+ boost::signals2::signal<void (
std
::weak_ptr<Job>)> JobAdded;
boost::signals2::signal<void ()> JobsReordered;
boost::signals2::signal<void (boost::optional<std::string>, boost::optional<std::string>)> ActiveJobsChanged;
boost::signals2::signal<void ()> JobsReordered;
boost::signals2::signal<void (boost::optional<std::string>, boost::optional<std::string>)> ActiveJobsChanged;
@@
-73,25
+90,25
@@
public:
private:
/* This function is part of the test suite */
friend bool ::wait_for_jobs ();
private:
/* This function is part of the test suite */
friend bool ::wait_for_jobs ();
+ friend struct threed_test7;
JobManager ();
~JobManager ();
void scheduler ();
void start ();
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 */
void job_finished ();
mutable boost::mutex _mutex;
boost::condition _empty_condition;
/** List of jobs in the order that they will be executed */
- std::list<
boost::shared_ptr<Job>
> _jobs;
+ std::list<
std::shared_ptr<Job>
> _jobs;
std::list<boost::signals2::connection> _connections;
std::list<boost::signals2::connection> _connections;
- bool _terminate;
- bool _paused;
-
boost
::shared_ptr<Job> _paused_job;
+ bool _terminate
= false
;
+ bool _paused
= false
;
+
std
::shared_ptr<Job> _paused_job;
boost::optional<std::string> _last_active_job;
boost::optional<std::string> _last_active_job;
- boost::thread
*
_scheduler;
+ boost::thread _scheduler;
static JobManager* _instance;
};
static JobManager* _instance;
};