mirror of
https://github.com/status-im/react-native.git
synced 2025-01-19 14:02:10 +00:00
9062bda79b
Summary: @public Add `RCTAssertThread` to `RCTAssert.h` for convenience when checking the current/queue, it accepts either a `NSString *`, `NSThread *` or `dispatch_queue_t` as the object to be checked Also add a check to `-[RCTUIManager addUIBlock:]` - There was a discussion on github (https://github.com/facebook/react-native/issues/1365) due to the weird behavior caused by calling it from a different thread/queue (it might be added after `batchDidComplete` has been called and will just be dispatched on the next call from JS to objc) Test Plan: Change `-[RCTAnimationExperimentalManager methodQueue]` to return `dispatch_get_main_queue()` and run the 2048 example, it should dispatch with a helpful message (screenshot on the comments)
80 lines
2.2 KiB
Objective-C
80 lines
2.2 KiB
Objective-C
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*/
|
|
|
|
#import "RCTAssert.h"
|
|
|
|
NSString *const RCTErrorDomain = @"RCTErrorDomain";
|
|
|
|
RCTAssertFunction RCTCurrentAssertFunction = nil;
|
|
|
|
void _RCTAssertFormat(
|
|
BOOL condition,
|
|
const char *fileName,
|
|
int lineNumber,
|
|
const char *function,
|
|
NSString *format, ...)
|
|
{
|
|
if (RCTCurrentAssertFunction) {
|
|
|
|
va_list args;
|
|
va_start(args, format);
|
|
NSString *message = [[NSString alloc] initWithFormat:format arguments:args];
|
|
va_end(args);
|
|
|
|
RCTCurrentAssertFunction(
|
|
condition, @(fileName), @(lineNumber), @(function), message
|
|
);
|
|
}
|
|
}
|
|
|
|
void RCTSetAssertFunction(RCTAssertFunction assertFunction)
|
|
{
|
|
RCTCurrentAssertFunction = assertFunction;
|
|
}
|
|
|
|
RCTAssertFunction RCTGetAssertFunction(void)
|
|
{
|
|
return RCTCurrentAssertFunction;
|
|
}
|
|
|
|
void RCTAddAssertFunction(RCTAssertFunction assertFunction)
|
|
{
|
|
RCTAssertFunction existing = RCTCurrentAssertFunction;
|
|
if (existing) {
|
|
RCTCurrentAssertFunction = ^(BOOL condition,
|
|
NSString *fileName,
|
|
NSNumber *lineNumber,
|
|
NSString *function,
|
|
NSString *message) {
|
|
|
|
existing(condition, fileName, lineNumber, function, message);
|
|
assertFunction(condition, fileName, lineNumber, function, message);
|
|
};
|
|
} else {
|
|
RCTCurrentAssertFunction = assertFunction;
|
|
}
|
|
}
|
|
|
|
NSString *RCTCurrentThreadName(void)
|
|
{
|
|
NSThread *thread = [NSThread currentThread];
|
|
NSString *threadName = [thread isMainThread] ? @"main" : thread.name;
|
|
if (threadName.length == 0) {
|
|
#if DEBUG // This is DEBUG not RCT_DEBUG because it *really* must not ship in RC
|
|
#pragma clang diagnostic push
|
|
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
|
|
threadName = @(dispatch_queue_get_label(dispatch_get_current_queue()));
|
|
#pragma clang diagnostic pop
|
|
#else
|
|
threadName = [NSString stringWithFormat:@"%p", thread];
|
|
#endif
|
|
}
|
|
return threadName;
|
|
}
|