#include "create_cli.h"
#include "dcp_content_type.h"
#include "ratio.h"
+#include "config.h"
#include "compose.hpp"
#include <dcp/raw_convert.h>
#include <string>
" --fourk make a 4K DCP rather than a 2K one\n"
" -o, --output <dir> output directory\n"
" --threed make a 3D DCP\n"
+ " --j2k-bandwidth <Mbit/s> J2K bandwidth in Mbit/s\n"
" --left-eye next piece of content is for the left eye\n"
" --right-eye next piece of content is for the right eye\n";
string template_name_string;
string config_dir_string;
string output_dir_string;
+ int j2k_bandwidth_int = 0;
VideoFrameType next_frame_type = VIDEO_FRAME_TYPE_2D;
int i = 1;
argument_option(i, argc, argv, "", "--standard", &claimed, &error, &standard_string);
argument_option(i, argc, argv, "", "--config", &claimed, &error, &config_dir_string);
argument_option(i, argc, argv, "-o", "--output", &claimed, &error, &output_dir_string);
+ argument_option(i, argc, argv, "", "--j2k-bandwidth", &claimed, &error, &j2k_bandwidth_int);
if (!claimed) {
if (a.length() > 2 && a.substr(0, 2) == "--") {
dcp_frame_rate = dcp_frame_rate_int;
}
+ if (j2k_bandwidth_int) {
+ j2k_bandwidth = j2k_bandwidth_int * 1000000;
+ }
+
dcp_content_type = DCPContentType::from_isdcf_name(dcp_content_type_string);
if (!dcp_content_type) {
error = String::compose("%1: unrecognised DCP content type '%2'", argv[0], dcp_content_type_string);
if (name.empty()) {
name = content[0].path.leaf().string();
}
+
+ if (j2k_bandwidth && (*j2k_bandwidth < 10000000 || *j2k_bandwidth > Config::instance()->maximum_j2k_bandwidth())) {
+ error = String::compose("%1: j2k-bandwidth must be between 10 and %2 Mbit/s", argv[0], (Config::instance()->maximum_j2k_bandwidth() / 1000000));
+ return;
+ }
}
BOOST_CHECK_EQUAL (cc.content[0].path, "foo.mp4");
BOOST_CHECK_EQUAL (cc.fourk, true);
BOOST_CHECK (!cc.error);
+
+ cc = run ("dcpomatic2_create --j2k-bandwidth 120 --content-ratio 185 foo.mp4");
+ BOOST_REQUIRE_EQUAL (cc.content.size(), 1);
+ BOOST_CHECK_EQUAL (cc.content[0].path, "foo.mp4");
+ BOOST_REQUIRE (cc.j2k_bandwidth);
+ BOOST_CHECK_EQUAL (*cc.j2k_bandwidth, 120000000);
+ BOOST_CHECK (!cc.error);
}