#include "job.h"
#include "writer.h"
#include "compose.hpp"
+#include "referenced_reel_asset.h"
#include "subtitle_content.h"
#include <boost/signals2.hpp>
#include <boost/foreach.hpp>
: _film (film)
, _player (new Player (film, film->playlist ()))
, _writer (new Writer (film, j))
- , _encoder (new Encoder (film, j, _writer))
+ , _encoder (new Encoder (film, _writer))
, _finishing (false)
{
int burnt_subtitles = 0;
int non_burnt_subtitles = 0;
BOOST_FOREACH (shared_ptr<const Content> c, _film->content ()) {
- shared_ptr<const SubtitleContent> sc = dynamic_pointer_cast<const SubtitleContent> (c);
- if (sc && sc->use_subtitles()) {
- if (sc->burn_subtitles()) {
+ if (c->subtitle && c->subtitle->use()) {
+ if (c->subtitle->burn()) {
++burnt_subtitles;
} else {
++non_burnt_subtitles;
}
for (DCPTime t; t < length; t += frame) {
- list<shared_ptr<PlayerVideo> > v = _player->get_video (t, true);
- for (list<shared_ptr<PlayerVideo> >::const_iterator i = v.begin(); i != v.end(); ++i) {
- _encoder->enqueue (*i);
- }
-
- shared_ptr<AudioBuffers> audio = _player->get_audio (t, frame, true);
- if (audio) {
- _writer->write (audio);
- }
+ _encoder->encode (_player->get_video (t, true));
+ _writer->write (_player->get_audio (t, frame, true));
if (non_burnt_subtitles) {
- _writer->write (_player->get_subtitles (t, frame, true, false));
+ _writer->write (_player->get_subtitles (t, frame, true, false, true));
}
}
- /* XXX: we should be passing through details of positions, at least... */
- BOOST_FOREACH (shared_ptr<dcp::ReelAsset> i, _player->get_reel_assets ()) {
+ BOOST_FOREACH (ReferencedReelAsset i, _player->get_reel_assets ()) {
_writer->write (i);
}