| /* |
| * Copyright (c) 2012 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 MODULES_RTP_RTCP_SOURCE_RTP_RECEIVER_STRATEGY_H_ |
| #define MODULES_RTP_RTCP_SOURCE_RTP_RECEIVER_STRATEGY_H_ |
| |
| #include "modules/rtp_rtcp/include/rtp_rtcp.h" |
| #include "modules/rtp_rtcp/include/rtp_rtcp_defines.h" |
| #include "modules/rtp_rtcp/source/rtp_utility.h" |
| #include "rtc_base/criticalsection.h" |
| |
| namespace webrtc { |
| |
| struct CodecInst; |
| |
| // This strategy deals with media-specific RTP packet processing. |
| // This class is not thread-safe and must be protected by its caller. |
| class RTPReceiverStrategy { |
| public: |
| static RTPReceiverStrategy* CreateVideoStrategy(RtpData* data_callback); |
| static RTPReceiverStrategy* CreateAudioStrategy(RtpData* data_callback); |
| |
| virtual ~RTPReceiverStrategy(); |
| |
| // Parses the RTP packet and calls the data callback with the payload data. |
| // Implementations are encouraged to use the provided packet buffer and RTP |
| // header as arguments to the callback; implementations are also allowed to |
| // make changes in the data as necessary. The specific_payload argument |
| // provides audio or video-specific data. |
| virtual int32_t ParseRtpPacket(WebRtcRTPHeader* rtp_header, |
| const PayloadUnion& specific_payload, |
| const uint8_t* payload, |
| size_t payload_length, |
| int64_t timestamp_ms) = 0; |
| |
| protected: |
| // The data callback is where we should send received payload data. |
| // See ParseRtpPacket. This class does not claim ownership of the callback. |
| // Implementations must NOT hold any critical sections while calling the |
| // callback. |
| // |
| // Note: Implementations may call the callback for other reasons than calls |
| // to ParseRtpPacket, for instance if the implementation somehow recovers a |
| // packet. |
| explicit RTPReceiverStrategy(RtpData* data_callback); |
| |
| rtc::CriticalSection crit_sect_; |
| RtpData* data_callback_; |
| }; |
| } // namespace webrtc |
| |
| #endif // MODULES_RTP_RTCP_SOURCE_RTP_RECEIVER_STRATEGY_H_ |