summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2023-05-30 12:23:00 +0200
committerCarl Hetherington <cth@carlh.net>2023-05-30 12:23:30 +0200
commit3ef1d207f33502fa5e114924f0f9abeeda97900a (patch)
treecf4ff38f0eccbb5cd7a8de2ce565d5f7ae950087
parent575932b8dccb30a02e0cc140b52aede72828a69a (diff)
Add --config option to map (#2543).
-rw-r--r--src/lib/map_cli.cc12
m---------test/data0
-rw-r--r--test/map_cli_test.cc29
3 files changed, 40 insertions, 1 deletions
diff --git a/src/lib/map_cli.cc b/src/lib/map_cli.cc
index 1b99afa94..c95d7f1a1 100644
--- a/src/lib/map_cli.cc
+++ b/src/lib/map_cli.cc
@@ -63,6 +63,7 @@ help(std::function<void (string)> out)
out(" -s, --soft-link using soft links instead of copying");
out(" -d, --assets-dir look in this directory for assets (can be given more than once)");
out(" -r, --rename rename all files to <uuid>.<mxf|xml>");
+ out(" --config <dir> directory containing config.xml and cinemas.xml");
}
@@ -74,6 +75,7 @@ map_cli(int argc, char* argv[], std::function<void (string)> out)
bool soft_link = false;
bool rename = false;
vector<boost::filesystem::path> assets_dir;
+ optional<boost::filesystem::path> config_dir;
/* This makes it possible to call getopt several times in the same executable, for tests */
optind = 0;
@@ -87,10 +89,11 @@ map_cli(int argc, char* argv[], std::function<void (string)> out)
{ "soft-link", no_argument, 0, 's' },
{ "assets-dir", required_argument, 0, 'd' },
{ "rename", no_argument, 0, 'r' },
+ { "config", required_argument, 0, 'c' },
{ 0, 0, 0, 0 }
};
- int c = getopt_long(argc, argv, "ho:lsd:r", long_options, &option_index);
+ int c = getopt_long(argc, argv, "ho:lsd:rc:", long_options, &option_index);
if (c == -1) {
break;
@@ -117,6 +120,9 @@ map_cli(int argc, char* argv[], std::function<void (string)> out)
case 'r':
rename = true;
break;
+ case 'c':
+ config_dir = optarg;
+ break;
}
}
@@ -127,6 +133,10 @@ map_cli(int argc, char* argv[], std::function<void (string)> out)
exit(EXIT_FAILURE);
}
+ if (config_dir) {
+ State::override_path = *config_dir;
+ }
+
vector<boost::filesystem::path> cpl_filenames;
for (int i = optind; i < argc; ++i) {
cpl_filenames.push_back(argv[i]);
diff --git a/test/data b/test/data
-Subproject 31458f4b7a93bd95d23b4b58eb89503e8cec875
+Subproject ece8e470df37357b9a9c29360c15213b6e71ec3
diff --git a/test/map_cli_test.cc b/test/map_cli_test.cc
index 3e6abc059..ffe281de5 100644
--- a/test/map_cli_test.cc
+++ b/test/map_cli_test.cc
@@ -353,3 +353,32 @@ BOOST_AUTO_TEST_CASE(map_two_smpte_cpls_each_with_subs)
{
test_two_cpls_each_with_subs("map_two_smpte_cpls_each_with_subs", false);
}
+
+
+BOOST_AUTO_TEST_CASE(map_with_given_config)
+{
+ string const name = "map_with_given_config";
+ string const out = String::compose("build/test/%1_out", name);
+
+ auto content = content_factory("test/data/flat_red.png");
+ auto film = new_test_film2(name + "_in", content);
+ make_and_verify_dcp(film);
+
+ vector<string> const args = {
+ "map_cli",
+ "-o", out,
+ "-d", film->dir(film->dcp_name()).string(),
+ "--config", "test/data/map_with_given_config",
+ find_cpl(film->dir(film->dcp_name())).string()
+ };
+
+ boost::filesystem::remove_all(out);
+
+ Config::instance()->drop();
+ vector<string> output_messages;
+ auto error = run(args, output_messages);
+ BOOST_CHECK(!error);
+
+ /* It should be signed by the key in test/data/map_with_given_config, not the one in test/data/signer_key */
+ BOOST_CHECK(dcp::file_to_string(find_file(out, "cpl_")).find("dnQualifier=\\+uOcNN2lPuxpxgd/5vNkkBER0GE=,CN=CS.dcpomatic.smpte-430-2.LEAF,OU=dcpomatic.com,O=dcpomatic.com") != std::string::npos);
+}