webrtc_m130/api/video_codecs/video_decoder.cc
Boris Tsirkin 932e361a94 Format /api folder
At Meta, we have formatted the repo according to WebRTC .clang-format
file. Currently, those changes are stored as patch and we'd like to
apply them to the base WebRTC release instead.

I will be submitting CLs per folder. The plan is to format all h|cc|mm|m
files, while exlcuding Matlab files from the formatter as clang
misinterprets them as ObjC.

Formatting done via:

git ls-files | grep -E '^api\/.*\.(h|cc)' | xargs clang-format -i

No-Iwyu: Includes didn't change and it isn't related to formatting
Bug: webrtc:42225392
Change-Id: I4d7470104983d5d32612f9347301354265fb34c8
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/373520
Commit-Queue: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#43671}
2025-01-07 18:41:45 -08:00

67 lines
2.0 KiB
C++

/*
* Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "api/video_codecs/video_decoder.h"
#include <cstdint>
#include <optional>
#include <string>
#include "api/video/video_frame.h"
#include "rtc_base/checks.h"
#include "rtc_base/strings/string_builder.h"
namespace webrtc {
int32_t DecodedImageCallback::Decoded(VideoFrame& decodedImage,
int64_t /* decode_time_ms */) {
// The default implementation ignores custom decode time value.
return Decoded(decodedImage);
}
void DecodedImageCallback::Decoded(VideoFrame& decodedImage,
std::optional<int32_t> decode_time_ms,
std::optional<uint8_t> /* qp */) {
Decoded(decodedImage, decode_time_ms.value_or(-1));
}
VideoDecoder::DecoderInfo VideoDecoder::GetDecoderInfo() const {
DecoderInfo info;
info.implementation_name = ImplementationName();
return info;
}
const char* VideoDecoder::ImplementationName() const {
return "unknown";
}
std::string VideoDecoder::DecoderInfo::ToString() const {
char string_buf[2048];
rtc::SimpleStringBuilder oss(string_buf);
oss << "DecoderInfo { "
<< "prefers_late_decoding = " << "implementation_name = '"
<< implementation_name << "', " << "is_hardware_accelerated = "
<< (is_hardware_accelerated ? "true" : "false") << " }";
return oss.str();
}
bool VideoDecoder::DecoderInfo::operator==(const DecoderInfo& rhs) const {
return is_hardware_accelerated == rhs.is_hardware_accelerated &&
implementation_name == rhs.implementation_name;
}
void VideoDecoder::Settings::set_number_of_cores(int value) {
RTC_DCHECK_GT(value, 0);
number_of_cores_ = value;
}
} // namespace webrtc