projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Make batch converter basically work.
[dcpomatic.git]
/
src
/
lib
/
job.cc
diff --git
a/src/lib/job.cc
b/src/lib/job.cc
index 1c66d87d379a7ba8395fa128be4c4aa26876220b..9a5812fa7426dfb451fb619951b606769be16e06 100644
(file)
--- a/
src/lib/job.cc
+++ b/
src/lib/job.cc
@@
-26,6
+26,7
@@
#include <libdcp/exceptions.h>
#include "job.h"
#include "util.h"
#include <libdcp/exceptions.h>
#include "job.h"
#include "util.h"
+#include "cross.h"
#include "i18n.h"
#include "i18n.h"
@@
-155,6
+156,13
@@
Job::finished_cancelled () const
return _state == FINISHED_CANCELLED;
}
return _state == FINISHED_CANCELLED;
}
+bool
+Job::paused () const
+{
+ boost::mutex::scoped_lock lm (_state_mutex);
+ return _state == PAUSED;
+}
+
/** Set the state of this job.
* @param s New state.
*/
/** Set the state of this job.
* @param s New state.
*/
@@
-190,6
+198,10
@@
Job::set_progress (float p)
_progress_unknown = false;
_stack.back().normalised = p;
boost::this_thread::interruption_point ();
_progress_unknown = false;
_stack.back().normalised = p;
boost::this_thread::interruption_point ();
+
+ if (paused ()) {
+ dvdomatic_sleep (1);
+ }
}
/** @return fractional overall progress, or -1 if not known */
}
/** @return fractional overall progress, or -1 if not known */
@@
-326,3
+338,19
@@
Job::cancel ()
_thread->interrupt ();
_thread->join ();
}
_thread->interrupt ();
_thread->join ();
}
+
+void
+Job::pause ()
+{
+ if (running ()) {
+ set_state (PAUSED);
+ }
+}
+
+void
+Job::resume ()
+{
+ if (paused ()) {
+ set_state (RUNNING);
+ }
+}