From 5673d7a051662afd129fa409cdbf3adb6119689e Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 8 Nov 2013 09:33:37 +0000 Subject: Don't display frames per second during digest calculation; clear job sub-name on completion; print job name more nicely when there is no sub name. --- src/lib/job.cc | 1 + src/lib/transcode_job.cc | 4 ++-- src/lib/transcoder.cc | 3 +++ src/lib/transcoder.h | 6 ++++++ 4 files changed, 12 insertions(+), 2 deletions(-) (limited to 'src/lib') diff --git a/src/lib/job.cc b/src/lib/job.cc index cc52a29f2..9981934ec 100644 --- a/src/lib/job.cc +++ b/src/lib/job.cc @@ -189,6 +189,7 @@ Job::set_state (State s) if (_state == FINISHED_OK || _state == FINISHED_ERROR || _state == FINISHED_CANCELLED) { _ran_for = elapsed_time (); finished = true; + _sub_name.clear (); } } diff --git a/src/lib/transcode_job.cc b/src/lib/transcode_job.cc index 74b425c1e..fd69b08e7 100644 --- a/src/lib/transcode_job.cc +++ b/src/lib/transcode_job.cc @@ -90,8 +90,8 @@ TranscodeJob::status () const s << Job::status (); - if (!finished ()) { - s << "; " << fixed << setprecision (1) << fps << N_(" ") << _("frames per second"); + if (!finished () && !_transcoder->finishing ()) { + s << "; " << fixed << setprecision (1) << fps << " " << _("frames per second"); } return s.str (); diff --git a/src/lib/transcoder.cc b/src/lib/transcoder.cc index 717f28556..24f22a9cb 100644 --- a/src/lib/transcoder.cc +++ b/src/lib/transcoder.cc @@ -66,6 +66,7 @@ Transcoder::Transcoder (shared_ptr f, shared_ptr j) : _job (j) , _player (f->make_player ()) , _encoder (new Encoder (f, j)) + , _finishing (false) { _player->Video.connect (bind (video_proxy, _encoder, _1, _2, _3, _4)); _player->Audio.connect (bind (audio_proxy, _encoder, _1)); @@ -76,6 +77,8 @@ Transcoder::go () { _encoder->process_begin (); while (!_player->pass ()) {} + + _finishing = true; _encoder->process_end (); } diff --git a/src/lib/transcoder.h b/src/lib/transcoder.h index 9c0de29bf..b1183b0bb 100644 --- a/src/lib/transcoder.h +++ b/src/lib/transcoder.h @@ -40,9 +40,15 @@ public: float current_encoding_rate () const; int video_frames_out () const; + /** @return true if we are in the process of calling Encoder::process_end */ + bool finishing () const { + return _finishing; + } + private: /** A Job that is running this Transcoder, or 0 */ boost::shared_ptr _job; boost::shared_ptr _player; boost::shared_ptr _encoder; + bool _finishing; }; -- cgit v1.2.3