124 lines
3.6 KiB
C++
124 lines
3.6 KiB
C++
// Copyright 2014 Google Inc. All rights reserved.
|
|
//
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file or at
|
|
// https://developers.google.com/open-source/licenses/bsd
|
|
|
|
#include <iostream>
|
|
|
|
#include "app/fixed_key_encryption_flags.h"
|
|
#include "app/packager_common.h"
|
|
#include "app/muxer_flags.h"
|
|
#include "app/single_muxer_flags.h"
|
|
#include "app/widevine_encryption_flags.h"
|
|
#include "base/file_util.h"
|
|
#include "base/logging.h"
|
|
#include "base/strings/stringprintf.h"
|
|
#include "media/base/demuxer.h"
|
|
#include "media/base/encryption_key_source.h"
|
|
#include "media/base/muxer_options.h"
|
|
#include "media/event/vod_media_info_dump_muxer_listener.h"
|
|
#include "media/file/file.h"
|
|
#include "media/file/file_closer.h"
|
|
#include "media/formats/mp4/mp4_muxer.h"
|
|
|
|
namespace {
|
|
const char kUsage[] =
|
|
"Single-stream packager driver program. Sample Usage:\n%s <input> [flags]";
|
|
} // namespace
|
|
|
|
namespace media {
|
|
|
|
bool GetSingleMuxerOptions(MuxerOptions* muxer_options) {
|
|
DCHECK(muxer_options);
|
|
|
|
if (!GetMuxerOptions(muxer_options))
|
|
return false;
|
|
|
|
muxer_options->output_file_name = FLAGS_output;
|
|
muxer_options->segment_template = FLAGS_segment_template;
|
|
|
|
return true;
|
|
}
|
|
|
|
bool RunPackager(const std::string& input) {
|
|
Status status;
|
|
|
|
// Setup and initialize Demuxer.
|
|
Demuxer demuxer(input, NULL);
|
|
status = demuxer.Initialize();
|
|
if (!status.ok()) {
|
|
LOG(ERROR) << "Demuxer failed to initialize: " << status.ToString();
|
|
return false;
|
|
}
|
|
|
|
if (FLAGS_dump_stream_info)
|
|
DumpStreamInfo(demuxer.streams());
|
|
|
|
if (FLAGS_output.empty()) {
|
|
if (!FLAGS_dump_stream_info)
|
|
LOG(WARNING) << "No output specified. Exiting.";
|
|
return true;
|
|
}
|
|
|
|
// Setup muxer.
|
|
MuxerOptions muxer_options;
|
|
if (!GetSingleMuxerOptions(&muxer_options))
|
|
return false;
|
|
|
|
scoped_ptr<Muxer> muxer(new mp4::MP4Muxer(muxer_options));
|
|
scoped_ptr<event::MuxerListener> muxer_listener;
|
|
scoped_ptr<File, FileCloser> mpd_file;
|
|
if (FLAGS_output_media_info) {
|
|
std::string output_mpd_file_name = FLAGS_output + ".media_info";
|
|
mpd_file.reset(File::Open(output_mpd_file_name.c_str(), "w"));
|
|
if (!mpd_file) {
|
|
LOG(ERROR) << "Failed to open " << output_mpd_file_name;
|
|
return false;
|
|
}
|
|
|
|
scoped_ptr<event::VodMediaInfoDumpMuxerListener> media_info_muxer_listener(
|
|
new event::VodMediaInfoDumpMuxerListener(mpd_file.get()));
|
|
media_info_muxer_listener->SetContentProtectionSchemeIdUri(
|
|
FLAGS_scheme_id_uri);
|
|
muxer_listener = media_info_muxer_listener.Pass();
|
|
muxer->SetMuxerListener(muxer_listener.get());
|
|
}
|
|
|
|
if (!AddStreamToMuxer(demuxer.streams(), FLAGS_stream, muxer.get()))
|
|
return false;
|
|
|
|
scoped_ptr<EncryptionKeySource> encryption_key_source;
|
|
if (FLAGS_enable_widevine_encryption || FLAGS_enable_fixed_key_encryption) {
|
|
encryption_key_source = CreateEncryptionKeySource();
|
|
if (!encryption_key_source)
|
|
return false;
|
|
muxer->SetEncryptionKeySource(encryption_key_source.get(),
|
|
FLAGS_max_sd_pixels,
|
|
FLAGS_clear_lead,
|
|
FLAGS_crypto_period_duration);
|
|
}
|
|
|
|
// Start remuxing process.
|
|
status = demuxer.Run();
|
|
if (!status.ok()) {
|
|
LOG(ERROR) << "Remuxing failed: " << status.ToString();
|
|
return false;
|
|
}
|
|
|
|
printf("Packaging completed successfully.\n");
|
|
return true;
|
|
}
|
|
|
|
} // namespace media
|
|
|
|
int main(int argc, char** argv) {
|
|
google::SetUsageMessage(base::StringPrintf(kUsage, argv[0]));
|
|
google::ParseCommandLineFlags(&argc, &argv, true);
|
|
if (argc != 2) {
|
|
google::ShowUsageWithFlags(argv[0]);
|
|
return 1;
|
|
}
|
|
return media::RunPackager(argv[1]) ? 0 : 1;
|
|
}
|