2023-12-01 17:32:19 +00:00
|
|
|
// Copyright 2018 Google LLC. All rights reserved.
|
2018-03-29 18:00:14 +00:00
|
|
|
//
|
|
|
|
// 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
|
|
|
|
|
2023-12-01 17:32:19 +00:00
|
|
|
#include <packager/media/formats/webvtt/text_padder.h>
|
2018-03-29 18:00:14 +00:00
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
|
2023-12-01 17:32:19 +00:00
|
|
|
#include <absl/log/check.h>
|
|
|
|
|
|
|
|
#include <packager/macros/status.h>
|
2018-03-29 18:00:14 +00:00
|
|
|
|
|
|
|
namespace shaka {
|
|
|
|
namespace media {
|
|
|
|
namespace {
|
|
|
|
const uint64_t kStreamIndex = 0;
|
|
|
|
} // namespace
|
|
|
|
|
2018-06-21 19:58:34 +00:00
|
|
|
TextPadder::TextPadder(int64_t zero_start_bias_ms)
|
|
|
|
: zero_start_bias_ms_(zero_start_bias_ms) {}
|
2018-03-29 18:00:14 +00:00
|
|
|
|
|
|
|
Status TextPadder::InitializeInternal() {
|
|
|
|
return Status::OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
Status TextPadder::Process(std::unique_ptr<StreamData> data) {
|
|
|
|
DCHECK_EQ(data->stream_index, kStreamIndex);
|
|
|
|
const bool is_text_sample =
|
|
|
|
data->stream_data_type == StreamDataType::kTextSample;
|
|
|
|
return is_text_sample ? OnTextSample(std::move(data))
|
|
|
|
: Dispatch(std::move(data));
|
|
|
|
}
|
|
|
|
|
|
|
|
Status TextPadder::OnTextSample(std::unique_ptr<StreamData> data) {
|
|
|
|
const TextSample& sample = *data->text_sample;
|
|
|
|
|
2018-06-21 19:58:34 +00:00
|
|
|
// If this is the first sample we have seen, we need to check if we should
|
|
|
|
// start at time zero.
|
|
|
|
if (max_end_time_ms_ < 0) {
|
|
|
|
max_end_time_ms_ =
|
2024-02-08 18:39:50 +00:00
|
|
|
zero_start_bias_ms_ && sample.start_time() > zero_start_bias_ms_
|
|
|
|
? sample.start_time()
|
|
|
|
: 0;
|
2018-06-21 19:58:34 +00:00
|
|
|
}
|
|
|
|
|
2018-03-29 18:00:14 +00:00
|
|
|
// Check if there will be a gap between samples if we just dispatch this
|
|
|
|
// sample right away. If there will be one, create an empty sample that will
|
|
|
|
// fill in that gap.
|
|
|
|
if (sample.start_time() > max_end_time_ms_) {
|
2020-08-24 22:23:15 +00:00
|
|
|
const std::string kNoId = "";
|
|
|
|
auto filler = std::make_shared<TextSample>(kNoId, max_end_time_ms_,
|
|
|
|
sample.start_time(),
|
|
|
|
TextSettings{}, TextFragment{});
|
2018-03-29 18:00:14 +00:00
|
|
|
RETURN_IF_ERROR(
|
|
|
|
MediaHandler::DispatchTextSample(kStreamIndex, std::move(filler)));
|
|
|
|
}
|
|
|
|
|
|
|
|
max_end_time_ms_ = std::max(max_end_time_ms_, sample.EndTime());
|
|
|
|
return Dispatch(std::move(data));
|
|
|
|
}
|
|
|
|
} // namespace media
|
|
|
|
} // namespace shaka
|