| Index: webrtc/modules/rtp_rtcp/source/rtp_header_extension.h
|
| diff --git a/webrtc/modules/rtp_rtcp/source/rtp_header_extension.h b/webrtc/modules/rtp_rtcp/source/rtp_header_extension.h
|
| index b053f7f8ca2910c3c55eb2bfbbfa78a4263ddacb..a8591c77e9dbb1a57395e0e94a3ff90ac036631e 100644
|
| --- a/webrtc/modules/rtp_rtcp/source/rtp_header_extension.h
|
| +++ b/webrtc/modules/rtp_rtcp/source/rtp_header_extension.h
|
| @@ -11,10 +11,13 @@
|
| #ifndef WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_HEADER_EXTENSION_H_
|
| #define WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_HEADER_EXTENSION_H_
|
|
|
| -#include <map>
|
| +#include <initializer_list>
|
| +#include <string>
|
|
|
| +#include "webrtc/base/basictypes.h"
|
| +#include "webrtc/base/checks.h"
|
| +#include "webrtc/config.h"
|
| #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h"
|
| -#include "webrtc/typedefs.h"
|
|
|
| namespace webrtc {
|
|
|
| @@ -35,74 +38,63 @@
|
| // Maximum playout delay value in milliseconds.
|
| const int kPlayoutDelayMaxMs = 40950;
|
|
|
| -struct HeaderExtension {
|
| - explicit HeaderExtension(RTPExtensionType extension_type)
|
| - : type(extension_type), length(0) {
|
| - Init();
|
| - }
|
| -
|
| - void Init() {
|
| - // TODO(solenberg): Create handler classes for header extensions so we can
|
| - // get rid of switches like these as well as handling code spread out all
|
| - // over.
|
| - switch (type) {
|
| - case kRtpExtensionTransmissionTimeOffset:
|
| - length = kTransmissionTimeOffsetLength;
|
| - break;
|
| - case kRtpExtensionAudioLevel:
|
| - length = kAudioLevelLength;
|
| - break;
|
| - case kRtpExtensionAbsoluteSendTime:
|
| - length = kAbsoluteSendTimeLength;
|
| - break;
|
| - case kRtpExtensionVideoRotation:
|
| - length = kVideoRotationLength;
|
| - break;
|
| - case kRtpExtensionTransportSequenceNumber:
|
| - length = kTransportSequenceNumberLength;
|
| - break;
|
| - case kRtpExtensionPlayoutDelay:
|
| - length = kPlayoutDelayLength;
|
| - break;
|
| - default:
|
| - assert(false);
|
| - }
|
| - }
|
| -
|
| - const RTPExtensionType type;
|
| - uint8_t length;
|
| -};
|
| -
|
| class RtpHeaderExtensionMap {
|
| public:
|
| static constexpr RTPExtensionType kInvalidType = kRtpExtensionNone;
|
| static constexpr uint8_t kInvalidId = 0;
|
| +
|
| RtpHeaderExtensionMap();
|
| - ~RtpHeaderExtensionMap();
|
| + RtpHeaderExtensionMap(std::initializer_list<RtpExtension>);
|
|
|
| - void Erase();
|
| + template <typename Extension>
|
| + bool Register(uint8_t id) {
|
| + return Register(id, Extension::kId, Extension::kValueSizeBytes,
|
| + Extension::kUri);
|
| + }
|
| + bool RegisterByType(uint8_t id, RTPExtensionType type);
|
| + bool RegisterByUri(uint8_t id, const std::string& uri);
|
|
|
| - int32_t Register(RTPExtensionType type, uint8_t id);
|
| + bool IsRegistered(RTPExtensionType type) const {
|
| + return GetId(type) != kInvalidId;
|
| + }
|
| + // Return kInvalidType if not found.
|
| + RTPExtensionType GetType(uint8_t id) const {
|
| + RTC_DCHECK_GE(id, kMinId);
|
| + RTC_DCHECK_LE(id, kMaxId);
|
| + return types_[id];
|
| + }
|
| + // Return kInvalidId if not found.
|
| + uint8_t GetId(RTPExtensionType type) const {
|
| + RTC_DCHECK_GT(type, kRtpExtensionNone);
|
| + RTC_DCHECK_LT(type, kRtpExtensionNumberOfExtensions);
|
| + return ids_[type];
|
| + }
|
|
|
| - int32_t Deregister(RTPExtensionType type);
|
| -
|
| - bool IsRegistered(RTPExtensionType type) const;
|
| -
|
| - int32_t GetType(uint8_t id, RTPExtensionType* type) const;
|
| - // Return kInvalidType if not found.
|
| - RTPExtensionType GetType(uint8_t id) const;
|
| -
|
| - int32_t GetId(const RTPExtensionType type, uint8_t* id) const;
|
| - // Return kInvalidId if not found.
|
| - uint8_t GetId(RTPExtensionType type) const;
|
| size_t GetTotalLengthInBytes() const;
|
|
|
| - void GetCopy(RtpHeaderExtensionMap* map) const;
|
| -
|
| - int32_t Size() const;
|
| + // TODO(danilchap): Remove use of the functions below.
|
| + void Erase() { *this = RtpHeaderExtensionMap(); }
|
| + int32_t Register(RTPExtensionType type, uint8_t id) {
|
| + return RegisterByType(id, type) ? 0 : -1;
|
| + }
|
| + int32_t Deregister(RTPExtensionType type);
|
| + int32_t GetType(uint8_t id, RTPExtensionType* type) const {
|
| + *type = GetType(id);
|
| + return *type == kInvalidType ? -1 : 0;
|
| + }
|
| + void GetCopy(RtpHeaderExtensionMap* copy) const { *copy = *this; }
|
|
|
| private:
|
| - std::map<uint8_t, HeaderExtension*> extensionMap_;
|
| + static constexpr uint8_t kMinId = 1;
|
| + static constexpr uint8_t kMaxId = 14;
|
| + bool Register(uint8_t id,
|
| + RTPExtensionType type,
|
| + size_t value_size,
|
| + const char* uri);
|
| +
|
| + size_t total_values_size_bytes_ = 0;
|
| + RTPExtensionType types_[kMaxId + 1];
|
| + uint8_t ids_[kRtpExtensionNumberOfExtensions];
|
| };
|
| } // namespace webrtc
|
|
|
|
|