X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fjob_manager.cc;h=26e2d28970a71c0f5a9d90b7582ed2738fd2fca0;hb=4358c54894741eef96bc8018a57fb2b0c059a4c1;hp=44c81e725aafb8f439fa30eb066b7b840dfc84e7;hpb=7dad3914a40ba78b8a1964a0b27f88da0ff802d7;p=dcpomatic.git diff --git a/src/lib/job_manager.cc b/src/lib/job_manager.cc index 44c81e725..26e2d2897 100644 --- a/src/lib/job_manager.cc +++ b/src/lib/job_manager.cc @@ -153,15 +153,12 @@ JobManager::scheduler () boost::mutex::scoped_lock lm (_mutex); - optional active_job; - while (true) { bool have_new = false; bool have_running = false; BOOST_FOREACH (shared_ptr i, _jobs) { if (i->running()) { have_running = true; - active_job = i->json_name(); } if (i->is_new()) { have_new = true; @@ -183,23 +180,24 @@ JobManager::scheduler () if (i->is_new()) { _connections.push_back (i->FinishedImmediate.connect(bind(&JobManager::job_finished, this))); i->start (); + emit (boost::bind (boost::ref (ActiveJobsChanged), _last_active_job, i->json_name())); + _last_active_job = i->json_name (); /* Only start one job at once */ break; } } - - lm.unlock (); - - if (active_job != _last_active_job) { - emit (boost::bind (boost::ref (ActiveJobsChanged), _last_active_job, active_job)); - _last_active_job = active_job; - } } } void JobManager::job_finished () { + { + boost::mutex::scoped_lock lm (_mutex); + emit (boost::bind (boost::ref (ActiveJobsChanged), _last_active_job, optional())); + _last_active_job = optional(); + } + _empty_condition.notify_all (); } @@ -235,7 +233,7 @@ JobManager::analyse_audio ( BOOST_FOREACH (shared_ptr i, _jobs) { shared_ptr a = dynamic_pointer_cast (i); - if (a && a->playlist () == playlist) { + if (a && a->path() == film->audio_analysis_path(playlist)) { i->when_finished (connection, ready); return; }