projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Remove Content::path(), add Content::path_summary().
[dcpomatic.git]
/
src
/
lib
/
transcode_job.cc
diff --git
a/src/lib/transcode_job.cc
b/src/lib/transcode_job.cc
index 5e9e58667864b2dbf533ed7574b5eddb5b68e4ca..fd69b08e7c58b5a353570433d5f53c937585ed48 100644
(file)
--- a/
src/lib/transcode_job.cc
+++ b/
src/lib/transcode_job.cc
@@
-24,12
+24,11
@@
#include <iostream>
#include <iomanip>
#include "transcode_job.h"
#include <iostream>
#include <iomanip>
#include "transcode_job.h"
-#include "j2k_wav_encoder.h"
#include "film.h"
#include "film.h"
-#include "format.h"
#include "transcoder.h"
#include "log.h"
#include "transcoder.h"
#include "log.h"
-#include "encoder_factory.h"
+
+#include "i18n.h"
using std::string;
using std::stringstream;
using std::string;
using std::stringstream;
@@
-38,11
+37,9
@@
using std::setprecision;
using boost::shared_ptr;
/** @param s Film to use.
using boost::shared_ptr;
/** @param s Film to use.
- * @param o Options.
*/
*/
-TranscodeJob::TranscodeJob (shared_ptr<Film> f, shared_ptr<const Options> o, shared_ptr<Job> req)
- : Job (f, req)
- , _opt (o)
+TranscodeJob::TranscodeJob (shared_ptr<const Film> f)
+ : Job (f)
{
}
{
}
@@
-50,7
+47,7
@@
TranscodeJob::TranscodeJob (shared_ptr<Film> f, shared_ptr<const Options> o, sha
string
TranscodeJob::name () const
{
string
TranscodeJob::name () const
{
- return String::compose (
"Transcode %1"
, _film->name());
+ return String::compose (
_("Transcode %1")
, _film->name());
}
void
}
void
@@
-58,22
+55,20
@@
TranscodeJob::run ()
{
try {
{
try {
- _film->log()->log ("Transcode job starting");
- _film->log()->log (String::compose ("Audio delay is %1ms", _film->audio_delay()));
+ _film->log()->log (N_("Transcode job starting"));
- _encoder = encoder_factory (_film, _opt);
- Transcoder w (_film, _opt, this, _encoder);
- w.go ();
+ _transcoder.reset (new Transcoder (_film, shared_from_this ()));
+ _transcoder->go ();
set_progress (1);
set_state (FINISHED_OK);
set_progress (1);
set_state (FINISHED_OK);
- _film->log()->log (
"Transcode job completed successfully"
);
+ _film->log()->log (
N_("Transcode job completed successfully")
);
} catch (std::exception& e) {
set_progress (1);
set_state (FINISHED_ERROR);
} catch (std::exception& e) {
set_progress (1);
set_state (FINISHED_ERROR);
- _film->log()->log (String::compose (
"Transcode job failed (%1)"
, e.what()));
+ _film->log()->log (String::compose (
N_("Transcode job failed (%1)")
, e.what()));
throw;
}
throw;
}
@@
-82,16
+77,11
@@
TranscodeJob::run ()
string
TranscodeJob::status () const
{
string
TranscodeJob::status () const
{
- if (!_
en
coder) {
- return
"0%"
;
+ if (!_
trans
coder) {
+ return
_("0%")
;
}
}
- if (_encoder->skipping () && !finished ()) {
- return "skipping already-encoded frames";
- }
-
-
- float const fps = _encoder->current_frames_per_second ();
+ float const fps = _transcoder->current_encoding_rate ();
if (fps == 0) {
return Job::status ();
}
if (fps == 0) {
return Job::status ();
}
@@
-100,8
+90,8
@@
TranscodeJob::status () const
s << Job::status ();
s << Job::status ();
- if (!finished ()) {
- s << "; " << fixed << setprecision (1) << fps << "
frames per second"
;
+ if (!finished ()
&& !_transcoder->finishing ()
) {
+ s << "; " << fixed << setprecision (1) << fps << "
" << _("frames per second")
;
}
return s.str ();
}
return s.str ();
@@
-110,12
+100,17
@@
TranscodeJob::status () const
int
TranscodeJob::remaining_time () const
{
int
TranscodeJob::remaining_time () const
{
- float fps = _encoder->current_frames_per_second ();
+ if (!_transcoder) {
+ return 0;
+ }
+
+ float fps = _transcoder->current_encoding_rate ();
+
if (fps == 0) {
return 0;
}
if (fps == 0) {
return 0;
}
- /*
We assume that dcp_length() is valid
*/
-
SourceFrame const left = _film->dcp_trim_start() + _film->dcp_length().get() - _encoder->video_frame
();
+ /*
Compute approximate proposed length here, as it's only here that we need it
*/
+
OutputVideoFrame const left = _film->time_to_video_frames (_film->length ()) - _transcoder->video_frames_out
();
return left / fps;
}
return left / fps;
}