Go back to respecting the user's choice for the number of audio channels in the MXF.
authorCarl Hetherington <cth@carlh.net>
Tue, 25 Jul 2023 09:04:30 +0000 (11:04 +0200)
committerCarl Hetherington <cth@carlh.net>
Sun, 6 Aug 2023 20:05:03 +0000 (22:05 +0200)
12 files changed:
src/lib/reel_writer.cc
src/lib/writer.cc
test/audio_processor_test.cc
test/content_test.cc
test/cpl_metadata_test.cc
test/ffmpeg_audio_test.cc
test/import_dcp_test.cc
test/no_use_video_test.cc
test/player_test.cc
test/reels_test.cc
test/srt_subtitle_test.cc
test/threed_test.cc

index e8db82fbb26976424fbbab26ef375a6d7ad1f22c..7c0c9188acca116074081c9b8e1d92004aeca589 100644 (file)
@@ -179,8 +179,7 @@ ReelWriter::ReelWriter (
                _sound_asset = make_shared<dcp::SoundAsset> (
                        dcp::Fraction(film()->video_frame_rate(), 1),
                        film()->audio_frame_rate(),
-                       /* Always make 16-channel sound assets for SMPTE; libdcp will pad unused channels for us */
-                       standard == dcp::Standard::SMPTE ? MAX_DCP_AUDIO_CHANNELS : film()->audio_channels(),
+                       film()->audio_channels(),
                        lang ? *lang : dcp::LanguageTag("en-US"),
                        standard
                        );
index 71e9d579dacbc91d078665cbdc7922e9f552993f..8b8ab89deb9540bb72453dcfc3d072ab85d2273b 100644 (file)
@@ -653,9 +653,12 @@ Writer::finish (boost::filesystem::path output_dcp)
                field = dcp::MCASoundField::FIVE_POINT_ONE;
        }
 
-       dcp::MainSoundConfiguration msc(field, MAX_DCP_AUDIO_CHANNELS);
+       auto const audio_channels = film()->audio_channels();
+       dcp::MainSoundConfiguration msc(field, audio_channels);
        for (auto i: film()->mapped_audio_channels()) {
-               msc.set_mapping(i, static_cast<dcp::Channel>(i));
+               if (i < audio_channels) {
+                       msc.set_mapping(i, static_cast<dcp::Channel>(i));
+               }
        }
 
        cpl->set_main_sound_configuration(msc);
index 8d59a3fe9033f5bc8187b101677ec8b916672575..4fe5eeb10c044015f5a7cc09c90f619ea55f3e77 100644 (file)
@@ -47,7 +47,7 @@ BOOST_AUTO_TEST_CASE (audio_processor_test)
        film->examine_and_add_content (c);
        BOOST_REQUIRE (!wait_for_jobs());
 
-       film->set_audio_channels (6);
+       film->set_audio_channels(16);
        film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TST"));
        film->set_audio_processor (AudioProcessor::from_id ("mid-side-decoder"));
 
index 85862af82e32e0f44328d8a556d0d49d2d1d4c23..47099025efbd18d59d4e599ac4ae4791f5a843d6 100644 (file)
@@ -45,6 +45,7 @@ BOOST_AUTO_TEST_CASE (content_test1)
        film->set_dcp_content_type (DCPContentType::from_isdcf_name ("FTR"));
        film->set_name ("content_test1");
        film->set_container (Ratio::from_id ("185"));
+       film->set_audio_channels(16);
 
        auto content = content_factory(TestPaths::private_data() / "demo_sound_bug.mkv")[0];
        film->examine_and_add_content (content);
@@ -150,6 +151,8 @@ BOOST_AUTO_TEST_CASE (content_test6)
                &cl
                );
 
+       film->set_audio_channels(16);
+
        make_and_verify_dcp (film);
        check_dcp (TestPaths::private_data() / "fha", film);
 
index b8346c6637cb045ea5177913c20fbde93627c2c1..544e78899d2b9c8f8dfb3eb628b303c2b8585c75 100644 (file)
@@ -71,7 +71,7 @@ BOOST_AUTO_TEST_CASE(main_sound_configuration_test_51_vi)
        BOOST_REQUIRE(msc);
 
        /* We think this should say 51 not 71 at the start (#2580) */
-       BOOST_CHECK_EQUAL(msc->to_string(), "51/L,R,C,LFE,Ls,Rs,-,VIN,-,-,-,-,-,-,-,-");
+       BOOST_CHECK_EQUAL(msc->to_string(), "51/L,R,C,LFE,Ls,Rs,-,VIN");
 }
 
 
@@ -117,5 +117,5 @@ BOOST_AUTO_TEST_CASE(main_sound_configuration_test_71)
        auto msc = cpl->main_sound_configuration();
        BOOST_REQUIRE(msc);
 
-       BOOST_CHECK_EQUAL(msc->to_string(), "71/L,R,C,LFE,Lss,Rss,-,VIN,-,-,Lrs,Rrs,-,-,-,-");
+       BOOST_CHECK_EQUAL(msc->to_string(), "71/L,R,C,LFE,Lss,Rss,-,VIN,-,-,Lrs,Rrs");
 }
index 910fc942c488d4d28a90b53d218eb4bedfaf6dd4..b2a83aad8a48e52e09b3db59159cdc133234a4ff 100644 (file)
@@ -58,8 +58,10 @@ BOOST_AUTO_TEST_CASE (ffmpeg_audio_test)
 
        BOOST_REQUIRE (!wait_for_jobs());
 
+       int constexpr audio_channels = 6;
+
        film->set_container (Ratio::from_id ("185"));
-       film->set_audio_channels (6);
+       film->set_audio_channels(audio_channels);
        film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TST"));
        make_and_verify_dcp (film);
 
@@ -71,7 +73,7 @@ BOOST_AUTO_TEST_CASE (ffmpeg_audio_test)
 
        auto sound_asset = check.cpls().front()->reels().front()->main_sound ();
        BOOST_CHECK (sound_asset);
-       BOOST_CHECK_EQUAL(sound_asset->asset()->channels (), 16);
+       BOOST_REQUIRE_EQUAL(sound_asset->asset()->channels (), audio_channels);
 
        /* Sample index in the DCP */
        int n = 0;
@@ -82,7 +84,7 @@ BOOST_AUTO_TEST_CASE (ffmpeg_audio_test)
                auto sound_frame = sound_asset->asset()->start_read()->get_frame (frame++);
                uint8_t const * d = sound_frame->data ();
                for (int offset = 0; offset < sound_frame->size(); offset += (3 * sound_asset->asset()->channels())) {
-                       for (auto channel = 0; channel < MAX_DCP_AUDIO_CHANNELS; ++channel) {
+                       for (auto channel = 0; channel < audio_channels; ++channel) {
                                auto const sample = d[offset + channel * 3 + 1] | (d[offset + channel * 3 + 2] << 8);
                                if (channel == 2) {
                                        /* Input should be on centre */
index acac790513ea6480b747a18dee64be26d37496b5..7387c7be7379f533687fbd58aaa1769985eca8d2 100644 (file)
@@ -85,6 +85,7 @@ BOOST_AUTO_TEST_CASE (import_dcp_test)
        B->set_dcp_content_type (DCPContentType::from_isdcf_name ("TLR"));
        B->set_name ("frobozz");
        B->set_interop (false);
+       B->set_audio_channels(16);
 
        auto d = make_shared<DCPContent>("build/test/import_dcp_test/" + A->dcp_name());
        B->examine_and_add_content (d);
index 0ad17d7b9e0e8ec0fb6121143b8b93d7a5f28f4d..b2e01958166474e46ae8c175dde0a49f80e3aadb 100644 (file)
@@ -61,6 +61,8 @@ BOOST_AUTO_TEST_CASE (no_use_video_test1)
        B->set_position (film, dcpomatic::DCPTime());
        A->video->set_use (false);
 
+       film->set_audio_channels(16);
+
        make_and_verify_dcp (film);
 
        check_dcp ("test/data/no_use_video_test1", film);
@@ -81,6 +83,8 @@ BOOST_AUTO_TEST_CASE (no_use_video_test2)
        B->set_position (film, dcpomatic::DCPTime());
        A->video->set_use (false);
 
+       film->set_audio_channels(16);
+
        make_and_verify_dcp (film);
 
        check_dcp (TestPaths::private_data() / "no_use_video_test2", film);
index a6e7cd2ded37fa73233a5c11854fe137a6226a5d..5120c018018e02c172ef59d5b5375409acf73a90 100644 (file)
@@ -558,6 +558,7 @@ BOOST_AUTO_TEST_CASE(multiple_sound_files_bug)
        auto C = content_factory(TestPaths::private_data() / "kook" / "3.wav").front();
 
        auto film = new_test_film2("multiple_sound_files_bug", { A, B, C }, &cl);
+       film->set_audio_channels(16);
        C->set_position(film, DCPTime(3840000));
 
        make_and_verify_dcp(film, { dcp::VerificationNote::Code::MISSING_CPL_METADATA });
@@ -573,6 +574,7 @@ BOOST_AUTO_TEST_CASE(trimmed_sound_mix_bug_13)
        auto A = content_factory("test/data/sine_16_48_440_10.wav").front();
        auto B = content_factory("test/data/sine_16_44.1_440_10.wav").front();
        auto film = new_test_film2("trimmed_sound_mix_bug_13", { A, B });
+       film->set_audio_channels(16);
 
        A->set_position(film, DCPTime());
        A->audio->set_gain(-12);
@@ -600,6 +602,7 @@ BOOST_AUTO_TEST_CASE(trimmed_sound_mix_bug_13_frame_rate_change)
        A->set_video_frame_rate(film, 24);
        B->set_video_frame_rate(film, 24);
        film->set_video_frame_rate(25);
+       film->set_audio_channels(16);
 
        make_and_verify_dcp(film, { dcp::VerificationNote::Code::MISSING_CPL_METADATA });
        check_mxf_audio_file("test/data/trimmed_sound_mix_bug_13_frame_rate_change.mxf", dcp_file(film, "pcm_"));
index de3f56d2ef99ea54ebcce452cac16b80ee89d99b..3d4dd0e6e2ea16dce5b8781394123c5270acf418 100644 (file)
@@ -134,6 +134,8 @@ BOOST_AUTO_TEST_CASE (reels_test2)
        BOOST_CHECK_EQUAL (film->reels().size(), 3U);
        BOOST_REQUIRE (!wait_for_jobs());
 
+       film->set_audio_channels(16);
+
        make_and_verify_dcp (film);
 
        check_dcp ("test/data/reels_test2", film->dir (film->dcp_name()));
@@ -141,6 +143,7 @@ BOOST_AUTO_TEST_CASE (reels_test2)
        auto c = make_shared<DCPContent>(film->dir(film->dcp_name()));
        auto film2 = new_test_film2 ("reels_test2b", {c});
        film2->set_reel_type (ReelType::BY_VIDEO_CONTENT);
+       film2->set_audio_channels(16);
 
        auto r = film2->reels ();
        BOOST_CHECK_EQUAL (r.size(), 3U);
@@ -210,6 +213,8 @@ BOOST_AUTO_TEST_CASE (reels_test4)
        film->examine_and_add_content (subs);
        BOOST_REQUIRE (!wait_for_jobs());
 
+       film->set_audio_channels(16);
+
        auto reels = film->reels();
        BOOST_REQUIRE_EQUAL (reels.size(), 4U);
        auto i = reels.begin ();
index 3863ebf9f26a8aad1250f3f5d482f921dd7aeeb3..c9aab59d977deebbc7c111a0457d4a4173c335b4 100644 (file)
@@ -55,6 +55,7 @@ BOOST_AUTO_TEST_CASE (srt_subtitle_test)
        film->set_name ("frobozz");
        film->set_audio_channels (6);
        film->set_interop (false);
+       film->set_audio_channels(16);
        auto content = make_shared<StringTextFileContent>("test/data/subrip2.srt");
        film->examine_and_add_content (content);
        BOOST_REQUIRE (!wait_for_jobs());
index 87ddd25aec252b75f64a333b4725a08f513f72cd..a53b4d10e3ce2c39a29818dbad4c1e8deab9cc53 100644 (file)
@@ -168,6 +168,7 @@ BOOST_AUTO_TEST_CASE (threed_test6)
        film->examine_and_add_content (L);
        auto R = make_shared<FFmpegContent>("test/data/3dR.mp4");
        film->examine_and_add_content (R);
+       film->set_audio_channels(16);
        BOOST_REQUIRE (!wait_for_jobs());
 
        L->video->set_frame_type (VideoFrameType::THREE_D_LEFT);