Fix crashes when using templates in some cases (#2491).
authorCarl Hetherington <cth@carlh.net>
Wed, 22 Mar 2023 23:29:40 +0000 (00:29 +0100)
committerCarl Hetherington <cth@carlh.net>
Thu, 23 Mar 2023 15:51:38 +0000 (16:51 +0100)
If a template had content with N audio channels there would be various
problems if content with <N channels was subsequently added.

src/lib/audio_content.cc
test/data
test/template_test.cc [new file with mode: 0644]
test/wscript

index 6a93ff11943cd66958116266408bd6e9267117bc..7083de714dcf411946c65598cdaf07d23e52ee32 100644 (file)
@@ -409,7 +409,9 @@ AudioContent::take_settings_from (shared_ptr<const AudioContent> c)
        size_t j = 0;
 
        while (i < _streams.size() && j < c->_streams.size()) {
-               _streams[i]->set_mapping (c->_streams[j]->mapping());
+               auto mapping = _streams[i]->mapping();
+               mapping.take_from(c->_streams[j]->mapping());
+               _streams[i]->set_mapping(mapping);
                ++i;
                ++j;
        }
index 1bda4d6e0a3fd9c455166aa9a6b70ac348bc83d0..c79ab114fdd6ca5f2f20a9d13d9203826f7f6c6a 160000 (submodule)
--- a/test/data
+++ b/test/data
@@ -1 +1 @@
-Subproject commit 1bda4d6e0a3fd9c455166aa9a6b70ac348bc83d0
+Subproject commit c79ab114fdd6ca5f2f20a9d13d9203826f7f6c6a
diff --git a/test/template_test.cc b/test/template_test.cc
new file mode 100644 (file)
index 0000000..6af7751
--- /dev/null
@@ -0,0 +1,47 @@
+/*
+    Copyright (C) 2023 Carl Hetherington <cth@carlh.net>
+
+    This file is part of DCP-o-matic.
+
+    DCP-o-matic is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    DCP-o-matic is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
+
+*/
+
+
+#include "lib/audio_content.h"
+#include "lib/config.h"
+#include "lib/content_factory.h"
+#include "lib/film.h"
+#include "test.h"
+#include <boost/test/unit_test.hpp>
+
+
+/* Bug #2491 */
+BOOST_AUTO_TEST_CASE(template_wrong_channel_counts)
+{
+       ConfigRestorer cr;
+
+       Config::override_path = "test/data";
+
+       auto film = new_test_film2("template_wrong_channel_counts", {});
+       film->use_template("Bug");
+
+       auto mono = content_factory("test/data/C.wav").front();
+       film->examine_and_add_content(mono);
+       BOOST_REQUIRE(!wait_for_jobs());
+
+       BOOST_REQUIRE_EQUAL(mono->audio->streams().size(), 1U);
+       BOOST_CHECK_EQUAL(mono->audio->streams()[0]->channels(), 1);
+}
+
index 6c85def54bddc4037751b609fd7cc2a9eec661ea..dc108acb6bb72912ba69a330902719ed20ca950e 100644 (file)
@@ -149,6 +149,7 @@ def build(bld):
                  subtitle_reel_number_test.cc
                  subtitle_timing_test.cc
                  subtitle_trim_test.cc
+                 template_test.cc
                  test.cc
                  text_decoder_test.cc
                  threed_test.cc