blob: 03387471c4981a2515f7e2b4bdab0ad49eab2e5c [file] [log] [blame]
hayscedd8fef2015-12-08 11:08:39 -08001/*
2 * Copyright 2015 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#import <Foundation/Foundation.h>
12
tkchin9eeb6242016-04-27 01:54:20 -070013#import <WebRTC/RTCMacros.h>
tkchin8b577ed2016-04-19 10:04:41 -070014
hayscedd8fef2015-12-08 11:08:39 -080015typedef NS_ENUM(NSInteger, RTCDispatcherQueueType) {
16 // Main dispatcher queue.
17 RTCDispatcherTypeMain,
18 // Used for starting/stopping AVCaptureSession, and assigning
19 // capture session to AVCaptureVideoPreviewLayer.
20 RTCDispatcherTypeCaptureSession,
tkchin0ce3bf92016-03-12 16:52:04 -080021 // Used for operations on AVAudioSession.
22 RTCDispatcherTypeAudioSession,
hayscedd8fef2015-12-08 11:08:39 -080023};
24
25/** Dispatcher that asynchronously dispatches blocks to a specific
26 * shared dispatch queue.
27 */
tkchin8b577ed2016-04-19 10:04:41 -070028RTC_EXPORT
hayscedd8fef2015-12-08 11:08:39 -080029@interface RTCDispatcher : NSObject
30
31- (instancetype)init NS_UNAVAILABLE;
32
33/** Dispatch the block asynchronously on the queue for dispatchType.
34 * @param dispatchType The queue type to dispatch on.
35 * @param block The block to dispatch asynchronously.
36 */
Yves Gerey665174f2018-06-19 15:03:05 +020037+ (void)dispatchAsyncOnType:(RTCDispatcherQueueType)dispatchType block:(dispatch_block_t)block;
hayscedd8fef2015-12-08 11:08:39 -080038
sakalcee51412017-05-03 03:50:17 -070039/** Returns YES if run on queue for the dispatchType otherwise NO.
40 * Useful for asserting that a method is run on a correct queue.
41 */
42+ (BOOL)isOnQueueForType:(RTCDispatcherQueueType)dispatchType;
43
hayscedd8fef2015-12-08 11:08:39 -080044@end