blob: 740adb321565c64586d6fec9f62b7d3c19b09298 [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.
*/
#ifndef API_RTP_HEADER_EXTENSION_ID_H_
#define API_RTP_HEADER_EXTENSION_ID_H_
#include "absl/base/macros.h"
#include "absl/strings/str_format.h"
#include "rtc_base/strong_alias.h"
namespace webrtc {
// This class represents the ID of an RTP header extension, as
// defined in RFC 8285 section 4.
// It is a number between 1 and 255, and needs to have a consistent
// association with an URI for all RTP packets in an RTP session,
// such as that defined by a BUNDLE.
// We allow the value 0 to mean "not set".
// TODO: bugs.webrtc.org/514817938 - change to underlying "uint8_t"
// once initialization prevents creation of illegal values.
class RtpHeaderExtensionId
: public StrongAlias<class RtpHeaderExtensionIdTag, int> {
public:
static const RtpHeaderExtensionId kMinId;
static const RtpHeaderExtensionId kMaxId;
static const RtpHeaderExtensionId kOneByteHeaderExtensionMaxId;
// Factory function for the NotSet value.
static constexpr RtpHeaderExtensionId NotSet() {
return RtpHeaderExtensionId(Internal{}, 0);
}
// The default constructor makes a NotSet.
constexpr RtpHeaderExtensionId() : StrongAlias(0) {}
// Implicit conversion from and to int, required for downstream
// during conversion.
// TODO: bugs.webrtc.org/514817938 - make explicit when downstream fixed.
constexpr RtpHeaderExtensionId(int id) // NOLINT: explicit
: StrongAlias(id) {
// TODO: bugs.webrtc.org/514817938 - enable these checks when tests fixed.
// RTC_DCHECK_GE(id, kMinId.value());
// RTC_DCHECK_LE(id, kMaxId.value());
}
// TODO: bugs.webrtc.org/514817938 - RTC_DCHECK(id is valid).
[[deprecated]] ABSL_REFACTOR_INLINE //
constexpr
operator int() const& { // NOLINT: explicit
return value();
}
// Returns true for an extension id that is set and is in the legal range.
constexpr bool Valid() const {
return value() >= kMinId.value() && value() <= kMaxId.value();
}
constexpr bool IsSet() const { return value() != 0; }
template <typename Sink>
friend void AbslStringify(Sink& sink, RtpHeaderExtensionId id) {
absl::Format(&sink, "%d", id.value());
}
private:
class Internal {};
explicit constexpr RtpHeaderExtensionId(Internal tag, int id)
: StrongAlias(id) {}
};
inline constexpr RtpHeaderExtensionId RtpHeaderExtensionId::kMinId =
RtpHeaderExtensionId(Internal{}, 1);
inline constexpr RtpHeaderExtensionId RtpHeaderExtensionId::kMaxId =
RtpHeaderExtensionId(Internal{}, 255);
inline constexpr RtpHeaderExtensionId
RtpHeaderExtensionId::kOneByteHeaderExtensionMaxId =
RtpHeaderExtensionId(Internal{}, 14);
} // namespace webrtc
#endif // API_RTP_HEADER_EXTENSION_ID_H_