Try to fix crash on drop()ping JobManager. More debugging when resampler fails.
[dcpomatic.git] / src / lib / job_manager.h
1 /*
2     Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 /** @file  src/job_manager.h
21  *  @brief A simple scheduler for jobs.
22  */
23
24 #include <list>
25 #include <boost/thread/mutex.hpp>
26 #include <boost/thread.hpp>
27 #include <boost/signals2.hpp>
28
29 class Job;
30
31 /** @class JobManager
32  *  @brief A simple scheduler for jobs.
33  */
34 class JobManager : public boost::noncopyable
35 {
36 public:
37
38         boost::shared_ptr<Job> add (boost::shared_ptr<Job>);
39         std::list<boost::shared_ptr<Job> > get () const;
40         bool work_to_do () const;
41         bool errors () const;
42
43         boost::signals2::signal<void (boost::weak_ptr<Job>)> JobAdded;
44         boost::signals2::signal<void (bool)> ActiveJobsChanged;
45
46         static JobManager* instance ();
47         static void drop ();
48
49 private:
50         /* This function is part of the test suite */
51         friend void ::wait_for_jobs ();
52         
53         JobManager ();
54         ~JobManager ();
55         void scheduler ();
56         
57         mutable boost::mutex _mutex;
58         std::list<boost::shared_ptr<Job> > _jobs;
59         bool _terminate;
60
61         bool _last_active_jobs;
62         boost::thread* _scheduler;
63
64         static JobManager* _instance;
65 };