mirror of
https://github.com/status-im/react-native.git
synced 2025-01-27 01:40:08 +00:00
RCTCxxBridge: Use C++ atomic
Summary: The next in my series of :atom: migrations. Closes https://github.com/facebook/react-native/pull/15277 Differential Revision: D5526460 Pulled By: javache fbshipit-source-id: e4ba54a5911c4a76280edf8aa164ac5aa935a945
This commit is contained in:
parent
688c74693b
commit
7c528cd569
@ -11,7 +11,6 @@
|
||||
|
||||
#include <atomic>
|
||||
#include <future>
|
||||
#include <libkern/OSAtomic.h>
|
||||
|
||||
#import <React/RCTAssert.h>
|
||||
#import <React/RCTBridge+Private.h>
|
||||
@ -135,8 +134,7 @@ struct RCTInstanceCallback : public InstanceCallback {
|
||||
BOOL _wasBatchActive;
|
||||
|
||||
NSMutableArray<dispatch_block_t> *_pendingCalls;
|
||||
// This is accessed using OSAtomic... calls.
|
||||
volatile int32_t _pendingCount;
|
||||
std::atomic<NSInteger> _pendingCount;
|
||||
|
||||
// Native modules
|
||||
NSMutableDictionary<NSString *, RCTModuleData *> *_moduleDataByName;
|
||||
@ -952,7 +950,7 @@ RCT_NOT_IMPLEMENTED(- (instancetype)initWithBundleURL:(__unused NSURL *)bundleUR
|
||||
// Phase 1: jsQueueBlocks are added to the queue; _pendingCount is
|
||||
// incremented for each. If the first block is created after self.loading is
|
||||
// true, phase 1 will be nothing.
|
||||
OSAtomicIncrement32Barrier(&_pendingCount);
|
||||
_pendingCount++;
|
||||
dispatch_block_t jsQueueBlock = ^{
|
||||
// From the perspective of the JS queue:
|
||||
if (self.loading) {
|
||||
@ -964,7 +962,7 @@ RCT_NOT_IMPLEMENTED(- (instancetype)initWithBundleURL:(__unused NSURL *)bundleUR
|
||||
// each block is executed, adding work to the queue, and _pendingCount is
|
||||
// decremented.
|
||||
block();
|
||||
OSAtomicDecrement32Barrier(&self->_pendingCount);
|
||||
self->_pendingCount--;
|
||||
}
|
||||
};
|
||||
[self ensureOnJavaScriptThread:jsQueueBlock];
|
||||
@ -992,7 +990,7 @@ RCT_NOT_IMPLEMENTED(- (instancetype)initWithBundleURL:(__unused NSURL *)bundleUR
|
||||
_pendingCalls = nil;
|
||||
for (dispatch_block_t call in pendingCalls) {
|
||||
call();
|
||||
OSAtomicDecrement32Barrier(&_pendingCount);
|
||||
_pendingCount--;
|
||||
}
|
||||
_loading = NO;
|
||||
RCT_PROFILE_END_EVENT(RCTProfileTagAlways, @"");
|
||||
|
Loading…
x
Reference in New Issue
Block a user