Files
tubestation/third_party/libwebrtc/pc/usage_pattern.h
Michael Froman 1bd851f9c1 Bug 1766646 - Vendor libwebrtc from 880fa8169b
Upstream commit: https://webrtc.googlesource.com/src/+/880fa8169b2a34052bb36e6a68abcbf5cbfb217a
    Reland "Use backticks not vertical bars to denote variables in comments for /pc"

    Original change's description:
    > Revert "Use backticks not vertical bars to denote variables in comments for /pc"
    >
    > This reverts commit 37ee0f5e594dd772ec6d620b5e5ea8a751b684f0.
    >
    > Reason for revert: Revert in order to be able to revert https://webrtc-review.googlesource.com/c/src/+/225642
    >
    > Original change's description:
    > > Use backticks not vertical bars to denote variables in comments for /pc
    > >
    > > Bug: webrtc:12338
    > > Change-Id: I88cf10afa5fc810b95d2a585ab2e895dcc163b63
    > > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/226953
    > > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
    > > Commit-Queue: Artem Titov <titovartem@webrtc.org>
    > > Cr-Commit-Position: refs/heads/master@{#34575}
    >
    > TBR=hta@webrtc.org,titovartem@webrtc.org,webrtc-scoped@luci-project-accounts.iam.gserviceaccount.com
    >
    > Change-Id: I5eddd3a14e1f664bf831e5c294fbc4de5f6a88af
    > No-Presubmit: true
    > No-Tree-Checks: true
    > No-Try: true
    > Bug: webrtc:12338
    > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/227082
    > Reviewed-by: Björn Terelius <terelius@webrtc.org>
    > Commit-Queue: Björn Terelius <terelius@webrtc.org>
    > Cr-Commit-Position: refs/heads/master@{#34577}

    Bug: webrtc:12338
    Change-Id: I96bd229b73613c162d11d75fa4f5934e1b4295c7
    Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/227087
    Commit-Queue: Artem Titov <titovartem@webrtc.org>
    Reviewed-by: Harald Alvestrand <hta@webrtc.org>
    Cr-Commit-Position: refs/heads/master@{#34611}
2022-08-30 10:31:01 -04:00

78 lines
2.8 KiB
C++

/*
* Copyright 2020 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_USAGE_PATTERN_H_
#define PC_USAGE_PATTERN_H_
#include "api/peer_connection_interface.h"
namespace webrtc {
class PeerConnectionObserver;
// A bit in the usage pattern is registered when its defining event occurs
// at least once.
enum class UsageEvent : int {
TURN_SERVER_ADDED = 0x01,
STUN_SERVER_ADDED = 0x02,
DATA_ADDED = 0x04,
AUDIO_ADDED = 0x08,
VIDEO_ADDED = 0x10,
// `SetLocalDescription` returns successfully.
SET_LOCAL_DESCRIPTION_SUCCEEDED = 0x20,
// `SetRemoteDescription` returns successfully.
SET_REMOTE_DESCRIPTION_SUCCEEDED = 0x40,
// A local candidate (with type host, server-reflexive, or relay) is
// collected.
CANDIDATE_COLLECTED = 0x80,
// A remote candidate is successfully added via `AddIceCandidate`.
ADD_ICE_CANDIDATE_SUCCEEDED = 0x100,
ICE_STATE_CONNECTED = 0x200,
CLOSE_CALLED = 0x400,
// A local candidate with private IP is collected.
PRIVATE_CANDIDATE_COLLECTED = 0x800,
// A remote candidate with private IP is added, either via AddiceCandidate
// or from the remote description.
REMOTE_PRIVATE_CANDIDATE_ADDED = 0x1000,
// A local mDNS candidate is collected.
MDNS_CANDIDATE_COLLECTED = 0x2000,
// A remote mDNS candidate is added, either via AddIceCandidate or from the
// remote description.
REMOTE_MDNS_CANDIDATE_ADDED = 0x4000,
// A local candidate with IPv6 address is collected.
IPV6_CANDIDATE_COLLECTED = 0x8000,
// A remote candidate with IPv6 address is added, either via AddIceCandidate
// or from the remote description.
REMOTE_IPV6_CANDIDATE_ADDED = 0x10000,
// A remote candidate (with type host, server-reflexive, or relay) is
// successfully added, either via AddIceCandidate or from the remote
// description.
REMOTE_CANDIDATE_ADDED = 0x20000,
// An explicit host-host candidate pair is selected, i.e. both the local and
// the remote candidates have the host type. This does not include candidate
// pairs formed with equivalent prflx remote candidates, e.g. a host-prflx
// pair where the prflx candidate has the same base as a host candidate of
// the remote peer.
DIRECT_CONNECTION_SELECTED = 0x40000,
MAX_VALUE = 0x80000,
};
class UsagePattern {
public:
void NoteUsageEvent(UsageEvent event);
void ReportUsagePattern(PeerConnectionObserver* observer) const;
private:
int usage_event_accumulator_ = 0;
};
} // namespace webrtc
#endif // PC_USAGE_PATTERN_H_