7 #include "packager/app/mpd_generator_flags.h"
8 #include "packager/app/vlog_flags.h"
9 #include "packager/base/at_exit.h"
10 #include "packager/base/command_line.h"
11 #include "packager/base/logging.h"
12 #include "packager/base/strings/string_split.h"
13 #include "packager/base/strings/stringprintf.h"
14 #include "packager/mpd/util/mpd_writer.h"
15 #include "packager/version/version.h"
21 #endif // defined(OS_WIN)
26 "MPD generation driver program.\n"
27 "This program accepts MediaInfo files in human readable text "
28 "format and outputs an MPD.\n"
29 "The main use case for this is to output MPD for VOD.\n"
31 " Each MediaInfo can only have one of VideoInfo, AudioInfo, or TextInfo.\n"
32 " There will be at most 3 AdaptationSets in the MPD, i.e. 1 video, 1 "
33 "audio, and 1 text.\n"
35 "%s --input=\"video1.media_info,video2.media_info,audio1.media_info\" "
36 "--output=\"video_audio.mpd\"";
42 kFailedToWriteMpdToFileError
45 ExitStatus CheckRequiredFlags() {
46 if (FLAGS_input.empty()) {
47 LOG(ERROR) <<
"--input is required.";
48 return kEmptyInputError;
51 if (FLAGS_output.empty()) {
52 LOG(ERROR) <<
"--output is required.";
53 return kEmptyOutputError;
59 ExitStatus RunMpdGenerator() {
60 DCHECK_EQ(CheckRequiredFlags(), kSuccess);
61 std::vector<std::string> base_urls;
62 std::vector<std::string> input_files;
63 typedef std::vector<std::string>::const_iterator Iterator;
65 base::SplitString(FLAGS_input,
',', &input_files);
67 if (!FLAGS_base_urls.empty()) {
68 base::SplitString(FLAGS_base_urls,
',', &base_urls);
72 for (Iterator it = base_urls.begin(); it != base_urls.end(); ++it)
73 mpd_writer.AddBaseUrl(*it);
75 for (Iterator it = input_files.begin(); it != input_files.end(); ++it) {
76 if (!mpd_writer.AddFile(it->c_str(), FLAGS_output)) {
77 LOG(WARNING) <<
"MpdWriter failed to read " << *it <<
", skipping.";
81 if (!mpd_writer.WriteMpdToFile(FLAGS_output.c_str())) {
82 LOG(ERROR) <<
"Failed to write MPD to " << FLAGS_output;
83 return kFailedToWriteMpdToFileError;
89 int MpdMain(
int argc,
char** argv) {
90 base::AtExitManager exit;
92 base::CommandLine::Init(argc, argv);
93 CHECK(logging::InitLogging(logging::LoggingSettings()));
95 google::SetUsageMessage(base::StringPrintf(kUsage, argv[0]));
96 google::ParseCommandLineFlags(&argc, &argv,
true);
98 ExitStatus status = CheckRequiredFlags();
99 if (status != kSuccess) {
100 const std::string version_string = base::StringPrintf(
101 "mpd_generator version %s", GetPackagerVersion().c_str());
102 google::ShowUsageWithFlags(version_string.c_str());
106 return RunMpdGenerator();
114 int wmain(
int argc,
wchar_t* argv[],
wchar_t* envp[]) {
115 std::unique_ptr<char* [], std::function<void(char**)>> utf8_argv(
116 new char*[argc], [argc](
char** utf8_args) {
124 std::wstring_convert<std::codecvt_utf8<wchar_t>> converter;
125 for (
int idx = 0; idx < argc; ++idx) {
126 std::string utf8_arg(converter.to_bytes(argv[idx]));
128 utf8_argv[idx] =
new char[utf8_arg.size()];
129 memcpy(utf8_argv[idx], &utf8_arg[0], utf8_arg.size());
131 return shaka::MpdMain(argc, utf8_argv.get());
134 int main(
int argc,
char** argv) {
135 return shaka::MpdMain(argc, argv);
137 #endif // !defined(OS_WIN)