blob: bee7ae26806d3ac4ef4938b18bd89ee5e0034700 [file]
/*
* Copyright (c) 2026 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_encoder_factory.h"
#include <optional>
#include <string>
#include "absl/algorithm/container.h"
#include "api/video_codecs/scalability_mode.h"
#include "api/video_codecs/sdp_video_format.h"
namespace webrtc {
VideoEncoderFactory::CodecSupport VideoEncoderFactory::QueryCodecSupport(
const SdpVideoFormat& format,
std::optional<std::string> scalability_mode) const {
// Default implementation, query for supported formats and check if the
// specified format is supported. If a scalability mode is specified, check
// that it is present in the matching format's scalability_modes list.
for (const auto& supported_format : GetSupportedFormats()) {
if (supported_format.IsSameCodec(format)) {
if (!scalability_mode.has_value()) {
return {.is_supported = true};
} else {
// Unable to use existing scalability mode parser due to circular
// dependency between api/video_codecs and modules/video_coding.
return {.is_supported = absl::c_any_of(
supported_format.scalability_modes,
[&](ScalabilityMode supported_mode) {
return ScalabilityModeToString(supported_mode) ==
*scalability_mode;
})};
}
}
}
return {.is_supported = false};
}
} // namespace webrtc