/* * Copyright 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. */ #ifndef RTC_BASE_MESSAGE_BUFFER_READER_H_ #define RTC_BASE_MESSAGE_BUFFER_READER_H_ #include "rtc_base/byte_buffer.h" namespace webrtc { // A simple subclass of the ByteBufferReader that exposes the starting address // of the message and its length, so that we can recall previously parsed data. class MessageBufferReader : public rtc::ByteBufferReader { public: MessageBufferReader(const char* bytes, size_t len) : rtc::ByteBufferReader(bytes, len) {} ~MessageBufferReader() = default; // Starting address of the message. const char* MessageData() const { return bytes_; } // Total length of the message. Note that this is different from Length(), // which is the length of the remaining message from the current offset. size_t MessageLength() const { return size_; } // Current offset in the message. size_t CurrentOffset() const { return start_; } }; } // namespace webrtc #endif // RTC_BASE_MESSAGE_BUFFER_READER_H_