projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix crashes on x-thread signal emission.
[dcpomatic.git]
/
src
/
lib
/
transcoder.h
diff --git
a/src/lib/transcoder.h
b/src/lib/transcoder.h
index 43c70df0066be67e26fe5f9d921422204930f902..ed0a6b1b561bb45a628080819d0866944e8a37f8 100644
(file)
--- a/
src/lib/transcoder.h
+++ b/
src/lib/transcoder.h
@@
-17,52
+17,34
@@
*/
*/
-/** @file src/transcoder.h
- * @brief A class which takes a FilmState and some Options, then uses those to transcode a Film.
- *
- * A decoder is selected according to the content type, and the encoder can be specified
- * as a parameter to the constructor.
- */
+#include "types.h"
+#include "encoder.h"
class Film;
class Film;
-class Job;
class Encoder;
class Encoder;
-class FilmState;
-class Matcher;
class VideoFilter;
class VideoFilter;
-class Gain;
-class VideoDecoder;
-class AudioDecoder;
-class DelayLine;
-class Options;
+class Player;
-/** @class Transcoder
- * @brief A class which takes a FilmState and some Options, then uses those to transcode a Film.
- *
- * A decoder is selected according to the content type, and the encoder can be specified
- * as a parameter to the constructor.
- */
-class Transcoder
+/** @class Transcoder */
+class Transcoder : public boost::noncopyable
{
public:
{
public:
- Transcoder (boost::shared_ptr<
Film> f, boost::shared_ptr<const Options> o, Job* j, boost::shared_ptr<Encoder> e
);
+ Transcoder (boost::shared_ptr<
const Film>, boost::shared_ptr<Job>
);
void go ();
void go ();
- boost::shared_ptr<VideoDecoder> video_decoder () const {
- return _decoders.first;
+ 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;
}
}
-protected:
- boost::shared_ptr<Film> _film;
- boost::shared_ptr<const Options> _opt;
- /** A Job that is running this Transcoder, or 0 */
- Job* _job;
- /** The encoder that we will use */
+private:
+ boost::shared_ptr<const Film> _film;
+ boost::shared_ptr<Player> _player;
+ boost::shared_ptr<Writer> _writer;
boost::shared_ptr<Encoder> _encoder;
boost::shared_ptr<Encoder> _encoder;
- /** The decoders that we will use */
- std::pair<boost::shared_ptr<VideoDecoder>, boost::shared_ptr<AudioDecoder> > _decoders;
- boost::shared_ptr<Matcher> _matcher;
- boost::shared_ptr<DelayLine> _delay_line;
- boost::shared_ptr<Gain> _gain;
+ bool _finishing;
};
};