mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 22:00:47 +01:00

Notably, this should detect whether an interface is "available" or not, which should prevent the failure is with dual SIM card setups. This is gated behind a field trial for now, to ensure this doesn't cause any regressions due to false negatives (interfaces that are usable but not listed as available by NWPathMonitor). Bug: webrtc:10966 Change-Id: Ia3942c4c57b525d08d8b340e2325f3705cfd0304 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/180923 Commit-Queue: Taylor <deadbeef@webrtc.org> Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> Reviewed-by: Jonas Oreland <jonaso@webrtc.org> Reviewed-by: Anders Carlsson <andersc@webrtc.org> Cr-Commit-Position: refs/heads/master@{#31977}
65 lines
2.2 KiB
Objective-C
65 lines
2.2 KiB
Objective-C
/*
|
|
* Copyright 2015 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.
|
|
*/
|
|
|
|
#import "RTCDispatcher+Private.h"
|
|
|
|
static dispatch_queue_t kAudioSessionQueue = nil;
|
|
static dispatch_queue_t kCaptureSessionQueue = nil;
|
|
static dispatch_queue_t kNetworkMonitorQueue = nil;
|
|
|
|
@implementation RTC_OBJC_TYPE (RTCDispatcher)
|
|
|
|
+ (void)initialize {
|
|
static dispatch_once_t onceToken;
|
|
dispatch_once(&onceToken, ^{
|
|
kAudioSessionQueue = dispatch_queue_create(
|
|
"org.webrtc.RTCDispatcherAudioSession",
|
|
DISPATCH_QUEUE_SERIAL);
|
|
kCaptureSessionQueue = dispatch_queue_create(
|
|
"org.webrtc.RTCDispatcherCaptureSession",
|
|
DISPATCH_QUEUE_SERIAL);
|
|
kNetworkMonitorQueue =
|
|
dispatch_queue_create("org.webrtc.RTCDispatcherNetworkMonitor", DISPATCH_QUEUE_SERIAL);
|
|
});
|
|
}
|
|
|
|
+ (void)dispatchAsyncOnType:(RTCDispatcherQueueType)dispatchType
|
|
block:(dispatch_block_t)block {
|
|
dispatch_queue_t queue = [self dispatchQueueForType:dispatchType];
|
|
dispatch_async(queue, block);
|
|
}
|
|
|
|
+ (BOOL)isOnQueueForType:(RTCDispatcherQueueType)dispatchType {
|
|
dispatch_queue_t targetQueue = [self dispatchQueueForType:dispatchType];
|
|
const char* targetLabel = dispatch_queue_get_label(targetQueue);
|
|
const char* currentLabel = dispatch_queue_get_label(DISPATCH_CURRENT_QUEUE_LABEL);
|
|
|
|
NSAssert(strlen(targetLabel) > 0, @"Label is required for the target queue.");
|
|
NSAssert(strlen(currentLabel) > 0, @"Label is required for the current queue.");
|
|
|
|
return strcmp(targetLabel, currentLabel) == 0;
|
|
}
|
|
|
|
#pragma mark - Private
|
|
|
|
+ (dispatch_queue_t)dispatchQueueForType:(RTCDispatcherQueueType)dispatchType {
|
|
switch (dispatchType) {
|
|
case RTCDispatcherTypeMain:
|
|
return dispatch_get_main_queue();
|
|
case RTCDispatcherTypeCaptureSession:
|
|
return kCaptureSessionQueue;
|
|
case RTCDispatcherTypeAudioSession:
|
|
return kAudioSessionQueue;
|
|
case RTCDispatcherTypeNetworkMonitor:
|
|
return kNetworkMonitorQueue;
|
|
}
|
|
}
|
|
|
|
@end
|