Provide a similar fix to the one in ff639b3cf30afcc097bfd21d39c8d15f466cadd6
authorCarl Hetherington <cth@carlh.net>
Sun, 25 Sep 2022 23:02:43 +0000 (01:02 +0200)
committerCarl Hetherington <cth@carlh.net>
Sun, 25 Sep 2022 23:02:43 +0000 (01:02 +0200)
for DCPs that contain subtitle files without <Font> tags.

src/lib/dcp_examiner.cc
test/subtitle_font_id_test.cc

index 5de8c89050caf391ed57848e64d433ed9414f7e9..0cfe499a3234b982063e7617c4fe98405140c6d0 100644 (file)
@@ -252,6 +252,10 @@ DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
                        _reel_lengths.push_back (i->atmos()->actual_duration());
                }
 
+               if (reel_fonts.empty()) {
+                       reel_fonts.push_back(make_shared<dcpomatic::Font>(""));
+               }
+
                _fonts.push_back(reel_fonts);
        }
 
index 5bcf454bd2f29942032732d667e9f68c2d1f7668..658d970e1e38b2dcc50fc054253728971a4af4e7 100644 (file)
 #include "lib/film.h"
 #include "lib/font.h"
 #include "lib/text_content.h"
+#include <dcp/cpl.h>
+#include <dcp/dcp.h>
+#include <dcp/reel.h>
+#include <dcp/reel_subtitle_asset.h>
 #include <dcp/smpte_subtitle_asset.h>
 #include "test.h"
 #include <boost/test/unit_test.hpp>
 
 
 using std::make_shared;
+using std::shared_ptr;
 
 
 BOOST_AUTO_TEST_CASE(full_dcp_subtitle_font_id_test)
@@ -123,3 +128,58 @@ BOOST_AUTO_TEST_CASE(make_dcp_with_subs_without_font_tag)
        BOOST_CHECK(check_font_data.begin()->second == dcp::ArrayData(default_font_file()));
 }
 
+
+BOOST_AUTO_TEST_CASE(make_dcp_with_subs_in_dcp_without_font_tag)
+{
+       /* Make a DCP with some subs in */
+       auto source_subs = content_factory("test/data/short.srt");
+       auto source = new_test_film2("make_dcp_with_subs_in_dcp_without_font_tag_source", { source_subs });
+       source->set_interop(true);
+       make_and_verify_dcp(
+               source,
+               {
+                       dcp::VerificationNote::Code::MISSING_SUBTITLE_LANGUAGE,
+                       dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME,
+                       dcp::VerificationNote::Code::MISSING_CPL_METADATA,
+                       dcp::VerificationNote::Code::INVALID_STANDARD
+               });
+
+       /* Find the ID of the subs */
+       dcp::DCP source_dcp(source->dir(source->dcp_name()));
+       source_dcp.read();
+       BOOST_REQUIRE(!source_dcp.cpls().empty());
+       BOOST_REQUIRE(!source_dcp.cpls()[0]->reels().empty());
+       BOOST_REQUIRE(source_dcp.cpls()[0]->reels()[0]->main_subtitle());
+       auto const id = source_dcp.cpls()[0]->reels()[0]->main_subtitle()->asset()->id();
+
+       /* Graft in some bad subs with no <Font> tag */
+       auto source_subtitle_file = subtitle_file(source);
+       boost::filesystem::copy_file("test/data/no_font.xml", source_subtitle_file, boost::filesystem::copy_options::overwrite_existing);
+
+       /* Fix the <Id> tag */
+       {
+               Editor editor(source_subtitle_file);
+               editor.replace("4dd8ee05-5986-4c67-a6f8-bbeac62e21db", id);
+       }
+
+       /* Now make a project which imports that DCP and makes another DCP from it */
+       auto dcp_content = make_shared<DCPContent>(source->dir(source->dcp_name()));
+       auto film = new_test_film2("make_dcp_with_subs_without_font_tag", { dcp_content });
+       BOOST_REQUIRE(!dcp_content->text.empty());
+       dcp_content->text.front()->set_use(true);
+       make_and_verify_dcp(
+               film,
+               {
+                       dcp::VerificationNote::Code::MISSING_SUBTITLE_LANGUAGE,
+                       dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME,
+                       dcp::VerificationNote::Code::MISSING_CPL_METADATA
+               });
+
+       auto check_file = subtitle_file(film);
+       dcp::SMPTESubtitleAsset check_asset(check_file);
+       BOOST_CHECK_EQUAL(check_asset.load_font_nodes().size(), 1U);
+       auto check_font_data = check_asset.font_data();
+       BOOST_CHECK_EQUAL(check_font_data.size(), 1U);
+       BOOST_CHECK(check_font_data.begin()->second == dcp::ArrayData(default_font_file()));
+}
+