}
};
- auto maybe_copy_font = [&maybe_copy](shared_ptr<const dcp::SubtitleAsset> asset, bool rename, bool hard_link, bool soft_link) {
+ auto maybe_copy_font_and_images = [&maybe_copy, output_dir, copy](shared_ptr<const dcp::SubtitleAsset> asset, bool rename, bool hard_link, bool soft_link) {
auto interop = dynamic_pointer_cast<const dcp::InteropSubtitleAsset>(asset);
boost::optional<boost::filesystem::path> extra;
if (interop) {
for (auto font_asset: interop->font_assets()) {
maybe_copy(font_asset->id(), rename, hard_link, soft_link, extra);
}
+ for (auto subtitle: interop->subtitles()) {
+ if (auto image = dynamic_pointer_cast<const dcp::SubtitleImage>(subtitle)) {
+ auto const output_path = *output_dir / asset->id() / image->file()->filename();
+ copy(*image->file(), output_path, hard_link, soft_link);
+ }
+ }
}
return extra;
};
maybe_copy_from_reel(reel->main_picture(), rename, hard_link, soft_link);
maybe_copy_from_reel(reel->main_sound(), rename, hard_link, soft_link);
if (reel->main_subtitle()) {
- auto extra = maybe_copy_font(reel->main_subtitle()->asset(), rename, hard_link, soft_link);
+ auto extra = maybe_copy_font_and_images(reel->main_subtitle()->asset(), rename, hard_link, soft_link);
maybe_copy_from_reel(reel->main_subtitle(), rename, hard_link, soft_link, extra);
}
for (auto ccap: reel->closed_captions()) {
- auto extra = maybe_copy_font(ccap->asset(), rename, hard_link, soft_link);
+ auto extra = maybe_copy_font_and_images(ccap->asset(), rename, hard_link, soft_link);
maybe_copy_from_reel(ccap, rename, hard_link, soft_link, extra);
}
maybe_copy_from_reel(reel->atmos(), rename, hard_link, soft_link);