From: Carl Hetherington Date: Tue, 20 Sep 2016 23:14:21 +0000 (+0100) Subject: Trim referred-to DCPs correctly using CPL entry point / duration. X-Git-Tag: v2.9.24~2 X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=commitdiff_plain;h=f9d0bc389d3f36263fb7a3b54d2263878a8ea7fb Trim referred-to DCPs correctly using CPL entry point / duration. --- diff --git a/ChangeLog b/ChangeLog index 4f22c362e..b080ee1d4 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2016-09-21 Carl Hetherington + + * Fix trimming of OV DCPs that are referred to (#956). + 2016-09-20 Carl Hetherington * Give better errors on SubRip parse failures. diff --git a/cscript b/cscript index 57d46737d..ef67e544f 100644 --- a/cscript +++ b/cscript @@ -233,7 +233,7 @@ def dependencies(target): ffmpeg_options = {} return (('ffmpeg-cdist', '1d4a1a4', ffmpeg_options), - ('libdcp', 'b105b7d'), + ('libdcp', 'd6fda12'), ('libsub', '3db5052')) def configure_options(target): diff --git a/src/lib/player.cc b/src/lib/player.cc index 1506436e1..c17cdfdc0 100644 --- a/src/lib/player.cc +++ b/src/lib/player.cc @@ -739,8 +739,17 @@ Player::get_reel_assets () int64_t offset = 0; BOOST_FOREACH (shared_ptr k, decoder->reels()) { + + DCPOMATIC_ASSERT (j->video_frame_rate ()); + double const cfr = j->video_frame_rate().get(); + Frame const trim_start = j->trim_start().frames_round (cfr); + Frame const trim_end = j->trim_end().frames_round (cfr); + DCPTime const from = i->position() + DCPTime::from_frames (offset, _film->video_frame_rate()); if (j->reference_video ()) { + DCPOMATIC_ASSERT (k->main_picture ()); + k->main_picture()->set_entry_point (trim_start); + k->main_picture()->set_duration (k->main_picture()->intrinsic_duration() - trim_start - trim_end); a.push_back ( ReferencedReelAsset ( k->main_picture (), @@ -750,6 +759,9 @@ Player::get_reel_assets () } if (j->reference_audio ()) { + DCPOMATIC_ASSERT (k->main_sound ()); + k->main_sound()->set_entry_point (trim_start); + k->main_sound()->set_duration (k->main_sound()->intrinsic_duration() - trim_start - trim_end); a.push_back ( ReferencedReelAsset ( k->main_sound (), @@ -760,6 +772,8 @@ Player::get_reel_assets () if (j->reference_subtitle ()) { DCPOMATIC_ASSERT (k->main_subtitle ()); + k->main_subtitle()->set_entry_point (trim_start); + k->main_subtitle()->set_duration (k->main_subtitle()->intrinsic_duration() - trim_start - trim_end); a.push_back ( ReferencedReelAsset ( k->main_subtitle (), diff --git a/test/vf_test.cc b/test/vf_test.cc index 4bfb2ad6e..ab39a6510 100644 --- a/test/vf_test.cc +++ b/test/vf_test.cc @@ -131,3 +131,40 @@ BOOST_AUTO_TEST_CASE (vf_test2) BOOST_CHECK_EQUAL (vf_c.cpls().front()->reels().front()->main_sound()->id(), sound_id); BOOST_REQUIRE (vf_c.cpls().front()->reels().front()->main_subtitle()); } + +/** Test creation of a VF using a trimmed OV; the output should have entry point / + * duration altered to effect the trimming. + */ +BOOST_AUTO_TEST_CASE (vf_test3) +{ + /* Make the OV */ + shared_ptr ov = new_test_film ("vf_test3_ov"); + ov->set_dcp_content_type (DCPContentType::from_isdcf_name ("TST")); + ov->set_name ("vf_test3_ov"); + shared_ptr video = content_factory (ov, "test/data/flat_red.png"); + ov->examine_and_add_content (video); + wait_for_jobs (); + video->video->set_length (24 * 5); + shared_ptr audio = content_factory (ov, "test/data/white.wav"); + ov->examine_and_add_content (audio); + wait_for_jobs (); + ov->make_dcp (); + wait_for_jobs (); + + /* Make the VF */ + shared_ptr vf = new_test_film ("vf_test3_vf"); + vf->set_name ("vf_test3_vf"); + vf->set_dcp_content_type (DCPContentType::from_isdcf_name ("TST")); + vf->set_reel_type (REELTYPE_BY_VIDEO_CONTENT); + shared_ptr dcp = dynamic_pointer_cast (content_factory (vf, ov->dir (ov->dcp_name ()))); + BOOST_REQUIRE (dcp); + dcp->set_trim_start (ContentTime::from_seconds (1)); + dcp->set_trim_end (ContentTime::from_seconds (1)); + vf->examine_and_add_content (dcp); + wait_for_jobs (); + dcp->set_reference_video (true); + dcp->set_reference_audio (true); + vf->make_dcp (); + wait_for_jobs (); + vf->write_metadata (); +}