Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(331)

Side by Side Diff: webrtc/modules/rtp_rtcp/source/rtcp_packet/receiver_report.h

Issue 2937403002: Style fixes in rtcp_packet/ (Closed)
Patch Set: CR response Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_MODULES_RTP_RTCP_SOURCE_RTCP_PACKET_RECEIVER_REPORT_H_ 11 #ifndef WEBRTC_MODULES_RTP_RTCP_SOURCE_RTCP_PACKET_RECEIVER_REPORT_H_
12 #define WEBRTC_MODULES_RTP_RTCP_SOURCE_RTCP_PACKET_RECEIVER_REPORT_H_ 12 #define WEBRTC_MODULES_RTP_RTCP_SOURCE_RTCP_PACKET_RECEIVER_REPORT_H_
13 13
14 #include <vector> 14 #include <vector>
15 15
16 #include "webrtc/base/basictypes.h" 16 #include "webrtc/base/basictypes.h"
17 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet.h" 17 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet.h"
18 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet/report_block.h" 18 #include "webrtc/modules/rtp_rtcp/source/rtcp_packet/report_block.h"
19 19
20 namespace webrtc { 20 namespace webrtc {
21 namespace rtcp { 21 namespace rtcp {
22 class CommonHeader; 22 class CommonHeader;
23 23
24 class ReceiverReport : public RtcpPacket { 24 class ReceiverReport : public RtcpPacket {
25 public: 25 public:
26 static constexpr uint8_t kPacketType = 201; 26 static constexpr uint8_t kPacketType = 201;
27 ReceiverReport() : sender_ssrc_(0) {} 27 ReceiverReport();
28 ~ReceiverReport() override {} 28 ~ReceiverReport() override;
29 29
30 // Parse assumes header is already parsed and validated. 30 // Parse assumes header is already parsed and validated.
31 bool Parse(const CommonHeader& packet); 31 bool Parse(const CommonHeader& packet);
32 32
33 void SetSenderSsrc(uint32_t ssrc) { sender_ssrc_ = ssrc; } 33 void SetSenderSsrc(uint32_t ssrc) { sender_ssrc_ = ssrc; }
34 bool AddReportBlock(const ReportBlock& block); 34 bool AddReportBlock(const ReportBlock& block);
35 35
36 uint32_t sender_ssrc() const { return sender_ssrc_; } 36 uint32_t sender_ssrc() const { return sender_ssrc_; }
37 const std::vector<ReportBlock>& report_blocks() const { 37 const std::vector<ReportBlock>& report_blocks() const {
38 return report_blocks_; 38 return report_blocks_;
39 } 39 }
40 40
41 protected: 41 size_t BlockLength() const override;
42
42 bool Create(uint8_t* packet, 43 bool Create(uint8_t* packet,
43 size_t* index, 44 size_t* index,
44 size_t max_length, 45 size_t max_length,
45 RtcpPacket::PacketReadyCallback* callback) const override; 46 RtcpPacket::PacketReadyCallback* callback) const override;
46 47
47 private: 48 private:
48 static const size_t kRrBaseLength = 4; 49 static const size_t kRrBaseLength = 4;
49 static const size_t kMaxNumberOfReportBlocks = 0x1F; 50 static const size_t kMaxNumberOfReportBlocks = 0x1F;
50 51
51 size_t BlockLength() const override {
52 return kHeaderLength + kRrBaseLength +
53 report_blocks_.size() * ReportBlock::kLength;
54 }
55
56 uint32_t sender_ssrc_; 52 uint32_t sender_ssrc_;
57 std::vector<ReportBlock> report_blocks_; 53 std::vector<ReportBlock> report_blocks_;
58 }; 54 };
59 55
60 } // namespace rtcp 56 } // namespace rtcp
61 } // namespace webrtc 57 } // namespace webrtc
62 #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_RTCP_PACKET_RECEIVER_REPORT_H_ 58 #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_RTCP_PACKET_RECEIVER_REPORT_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698