blob: 3dddead60ef6a1df8be6aadb9db517a8c590b139 [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 */
37+ (void)dispatchAsyncOnType:(RTCDispatcherQueueType)dispatchType
38 block:(dispatch_block_t)block;
39
sakalcee51412017-05-03 03:50:17 -070040/** Returns YES if run on queue for the dispatchType otherwise NO.
41 * Useful for asserting that a method is run on a correct queue.
42 */
43+ (BOOL)isOnQueueForType:(RTCDispatcherQueueType)dispatchType;
44
hayscedd8fef2015-12-08 11:08:39 -080045@end