diff options
| author | Carl Hetherington <cth@carlh.net> | 2021-11-04 23:43:54 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2021-11-13 22:34:20 +0100 |
| commit | 8d42eb1c35c095f307b62d0620835bedaa46a9fb (patch) | |
| tree | b85922b895d01ed259cec50f4165bc1345a59e46 | |
| parent | b81e38775c4c03eaeb64bce19cec408e99dded14 (diff) | |
Add Job::seconds_since_last_progress_update().
| -rw-r--r-- | src/lib/job.cc | 16 | ||||
| -rw-r--r-- | src/lib/job.h | 1 |
2 files changed, 17 insertions, 0 deletions
diff --git a/src/lib/job.cc b/src/lib/job.cc index cb2120de1..4c8199bdc 100644 --- a/src/lib/job.cc +++ b/src/lib/job.cc @@ -361,6 +361,22 @@ Job::check_for_interruption_or_pause () } } + +optional<float> +Job::seconds_since_last_progress_update () const +{ + boost::mutex::scoped_lock lm (_progress_mutex); + if (!_last_progress_update) { + return {}; + } + + struct timeval now; + gettimeofday (&now, 0); + + return seconds(now) - seconds(*_last_progress_update); +} + + /** Set the progress of the current part of the job. * @param p Progress (from 0 to 1) * @param force Do not ignore this update, even if it hasn't been long since the last one. diff --git a/src/lib/job.h b/src/lib/job.h index 96f0acbe5..b44fd1365 100644 --- a/src/lib/job.h +++ b/src/lib/job.h @@ -81,6 +81,7 @@ public: void set_progress (float, bool force = false); void sub (std::string); boost::optional<float> progress () const; + boost::optional<float> seconds_since_last_progress_update () const; std::shared_ptr<const Film> film () const { return _film; |
