Anders Carlsson | 7bca8ca | 2018-08-30 09:30:29 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2018 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 | |
| 13 | #import "RTCLogging.h" |
| 14 | #import "RTCMacros.h" |
| 15 | |
| 16 | NS_ASSUME_NONNULL_BEGIN |
| 17 | |
| 18 | // This class intercepts WebRTC logs and forwards them to a registered block. |
| 19 | // This class is not threadsafe. |
Mirko Bonadei | e8d5724 | 2018-09-17 10:22:56 +0200 | [diff] [blame^] | 20 | RTC_OBJC_EXPORT |
Anders Carlsson | 7bca8ca | 2018-08-30 09:30:29 +0200 | [diff] [blame] | 21 | @interface RTCCallbackLogger : NSObject |
| 22 | |
| 23 | // The severity level to capture. The default is kRTCLoggingSeverityInfo. |
| 24 | @property(nonatomic, assign) RTCLoggingSeverity severity; |
| 25 | |
| 26 | // The callback will be called on the same thread that does the logging, so |
| 27 | // if the logging callback can be slow it may be a good idea to implement |
| 28 | // dispatching to some other queue. |
| 29 | - (void)start:(nullable void (^)(NSString*))callback; |
| 30 | |
| 31 | - (void)stop; |
| 32 | |
| 33 | @end |
| 34 | |
| 35 | NS_ASSUME_NONNULL_END |