Repo created
This commit is contained in:
parent
81b91f4139
commit
f8c34fa5ee
22732 changed files with 4815320 additions and 2 deletions
49
TMessagesProj/jni/voip/webrtc/pc/usage_pattern.cc
Normal file
49
TMessagesProj/jni/voip/webrtc/pc/usage_pattern.cc
Normal file
|
|
@ -0,0 +1,49 @@
|
|||
/*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include "pc/usage_pattern.h"
|
||||
|
||||
#include "api/peer_connection_interface.h"
|
||||
#include "rtc_base/logging.h"
|
||||
#include "system_wrappers/include/metrics.h"
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
void UsagePattern::NoteUsageEvent(UsageEvent event) {
|
||||
usage_event_accumulator_ |= static_cast<int>(event);
|
||||
}
|
||||
|
||||
void UsagePattern::ReportUsagePattern(PeerConnectionObserver* observer) const {
|
||||
RTC_DLOG(LS_INFO) << "Usage signature is " << usage_event_accumulator_;
|
||||
RTC_HISTOGRAM_ENUMERATION_SPARSE("WebRTC.PeerConnection.UsagePattern",
|
||||
usage_event_accumulator_,
|
||||
static_cast<int>(UsageEvent::MAX_VALUE));
|
||||
const int bad_bits =
|
||||
static_cast<int>(UsageEvent::SET_LOCAL_DESCRIPTION_SUCCEEDED) |
|
||||
static_cast<int>(UsageEvent::CANDIDATE_COLLECTED);
|
||||
const int good_bits =
|
||||
static_cast<int>(UsageEvent::SET_REMOTE_DESCRIPTION_SUCCEEDED) |
|
||||
static_cast<int>(UsageEvent::REMOTE_CANDIDATE_ADDED) |
|
||||
static_cast<int>(UsageEvent::ICE_STATE_CONNECTED);
|
||||
if ((usage_event_accumulator_ & bad_bits) == bad_bits &&
|
||||
(usage_event_accumulator_ & good_bits) == 0) {
|
||||
// If called after close(), we can't report, because observer may have
|
||||
// been deallocated, and therefore pointer is null. Write to log instead.
|
||||
if (observer) {
|
||||
observer->OnInterestingUsage(usage_event_accumulator_);
|
||||
} else {
|
||||
RTC_LOG(LS_INFO) << "Interesting usage signature "
|
||||
<< usage_event_accumulator_
|
||||
<< " observed after observer shutdown";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace webrtc
|
||||
Loading…
Add table
Add a link
Reference in a new issue