X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Freel.cc;h=ff51c025b78dd664ebd9a47e827e77b042bf42c0;hb=bf59c288798851808359575662f202d390032aa7;hp=51aa560c706297a0658c5744808c1cbc9698d2c3;hpb=f8005516a681b805ccc2d929f63312ac711fdc24;p=libdcp.git diff --git a/src/reel.cc b/src/reel.cc index 51aa560c..ff51c025 100644 --- a/src/reel.cc +++ b/src/reel.cc @@ -21,6 +21,8 @@ #include "reel.h" #include "util.h" #include "picture_asset.h" +#include "mono_picture_asset.h" +#include "stereo_picture_asset.h" #include "sound_asset.h" #include "subtitle_asset.h" #include "kdm.h" @@ -29,25 +31,32 @@ using std::string; using std::list; using std::cout; using boost::shared_ptr; +using boost::dynamic_pointer_cast; using namespace libdcp; void -Reel::write_to_cpl (xmlpp::Element* node, bool interop) const +Reel::write_to_cpl (xmlpp::Element* node) const { xmlpp::Element* reel = node->add_child ("Reel"); reel->add_child("Id")->add_child_text ("urn:uuid:" + make_uuid()); xmlpp::Element* asset_list = reel->add_child ("AssetList"); - if (_main_picture) { - _main_picture->write_to_cpl (asset_list, interop); + if (_main_picture && dynamic_pointer_cast (_main_picture)) { + /* Mono pictures come before other stuff... */ + _main_picture->write_to_cpl (asset_list); } if (_main_sound) { - _main_sound->write_to_cpl (asset_list, interop); + _main_sound->write_to_cpl (asset_list); } if (_main_subtitle) { - _main_subtitle->write_to_cpl (asset_list, interop); + _main_subtitle->write_to_cpl (asset_list); + } + + if (_main_picture && dynamic_pointer_cast (_main_picture)) { + /* ... but stereo pictures must come after */ + _main_picture->write_to_cpl (asset_list); } }