mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-15 14:50:39 +01:00

The new processing applies only in Unified Plan mode.
Plan B retains the old-style processing.
This is a reland of 1fa06041bc
Original change's description:
> Make negotiationneeded processing in PeerConnection spec compliant.
>
> This CL fixes the problem of misfired negotiationneeded notifications due
> to the lack of a NegotiationNeeded slot and the proper procedure to
> update it.
>
>
> Change-Id: Ie273c691f11316c9846606446f6cf838226b5d5c
> Bug: chromium:740501
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/131283
> Commit-Queue: Guido Urdaneta <guidou@webrtc.org>
> Reviewed-by: Steve Anton <steveanton@webrtc.org>
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Reviewed-by: Magnus Jedvert <magjed@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#27594}
Bug: chromium:740501
Change-Id: I048ae81b2b00086f6d669e94eecf426f0db0ec08
TBR: steveanton@webrtc.org
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/133162
Commit-Queue: Guido Urdaneta <guidou@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#27640}
62 lines
2.3 KiB
C++
62 lines
2.3 KiB
C++
/*
|
|
* Copyright 2017 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 PC_RTP_MEDIA_UTILS_H_
|
|
#define PC_RTP_MEDIA_UTILS_H_
|
|
|
|
#include "api/rtp_transceiver_interface.h"
|
|
|
|
namespace webrtc {
|
|
|
|
// Returns the RtpTransceiverDirection that satisfies specified send and receive
|
|
// conditions.
|
|
RtpTransceiverDirection RtpTransceiverDirectionFromSendRecv(bool send,
|
|
bool recv);
|
|
|
|
// Returns true only if the direction will send media.
|
|
bool RtpTransceiverDirectionHasSend(RtpTransceiverDirection direction);
|
|
|
|
// Returns true only if the direction will receive media.
|
|
bool RtpTransceiverDirectionHasRecv(RtpTransceiverDirection direction);
|
|
|
|
// Returns the RtpTransceiverDirection which is the reverse of the given
|
|
// direction.
|
|
RtpTransceiverDirection RtpTransceiverDirectionReversed(
|
|
RtpTransceiverDirection direction);
|
|
|
|
// Returns the RtpTransceiverDirection with its send component set to |send|.
|
|
RtpTransceiverDirection RtpTransceiverDirectionWithSendSet(
|
|
RtpTransceiverDirection direction,
|
|
bool send = true);
|
|
|
|
// Returns the RtpTransceiverDirection with its recv component set to |recv|.
|
|
RtpTransceiverDirection RtpTransceiverDirectionWithRecvSet(
|
|
RtpTransceiverDirection direction,
|
|
bool recv = true);
|
|
|
|
// Returns an unspecified string representation of the given direction.
|
|
const char* RtpTransceiverDirectionToString(RtpTransceiverDirection direction);
|
|
|
|
// Returns the intersection of the directions of two transceivers.
|
|
RtpTransceiverDirection RtpTransceiverDirectionIntersection(
|
|
RtpTransceiverDirection lhs,
|
|
RtpTransceiverDirection rhs);
|
|
|
|
#ifdef UNIT_TEST
|
|
inline std::ostream& operator<<( // no-presubmit-check TODO(webrtc:8982)
|
|
std::ostream& os, // no-presubmit-check TODO(webrtc:8982)
|
|
RtpTransceiverDirection direction) {
|
|
return os << RtpTransceiverDirectionToString(direction);
|
|
}
|
|
#endif // UNIT_TEST
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // PC_RTP_MEDIA_UTILS_H_
|