mirror of
https://github.com/status-im/react-native.git
synced 2025-01-27 01:40:08 +00:00
Fix Modules concurrent access
Reviewed By: fkgozali Differential Revision: D8379392 fbshipit-source-id: 72495950ea5fcf37f5b1cc3413666879dfc81e5c
This commit is contained in:
parent
a130239257
commit
2f53573d4f
@ -34,9 +34,14 @@ NSString *const RCTBridgeDidDownloadScriptNotificationSourceKey = @"source";
|
||||
NSString *const RCTBridgeDidDownloadScriptNotificationBridgeDescriptionKey = @"bridgeDescription";
|
||||
|
||||
static NSMutableArray<Class> *RCTModuleClasses;
|
||||
static dispatch_queue_t RCTModuleClassesSyncQueue;
|
||||
NSArray<Class> *RCTGetModuleClasses(void)
|
||||
{
|
||||
return RCTModuleClasses;
|
||||
__block NSArray<Class> *result;
|
||||
dispatch_sync(RCTModuleClassesSyncQueue, ^{
|
||||
result = [RCTModuleClasses copy];
|
||||
});
|
||||
return result;
|
||||
}
|
||||
|
||||
void RCTFBQuickPerformanceLoggerConfigureHooks(__unused JSGlobalContextRef ctx) { }
|
||||
@ -51,6 +56,7 @@ void RCTRegisterModule(Class moduleClass)
|
||||
static dispatch_once_t onceToken;
|
||||
dispatch_once(&onceToken, ^{
|
||||
RCTModuleClasses = [NSMutableArray new];
|
||||
RCTModuleClassesSyncQueue = dispatch_queue_create("com.facebook.react.ModuleClassesSyncQueue", DISPATCH_QUEUE_CONCURRENT);
|
||||
});
|
||||
|
||||
RCTAssert([moduleClass conformsToProtocol:@protocol(RCTBridgeModule)],
|
||||
@ -58,7 +64,9 @@ void RCTRegisterModule(Class moduleClass)
|
||||
moduleClass);
|
||||
|
||||
// Register module
|
||||
[RCTModuleClasses addObject:moduleClass];
|
||||
dispatch_barrier_async(RCTModuleClassesSyncQueue, ^{
|
||||
[RCTModuleClasses addObject:moduleClass];
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
x
Reference in New Issue
Block a user