2015-12-15 05:39:30 -08:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2017-02-17 05:47:28 -08:00
|
|
|
#import <JavaScriptCore/JSBase.h>
|
|
|
|
|
2016-11-23 07:47:52 -08:00
|
|
|
#import <React/RCTBridge.h>
|
2015-12-15 05:39:30 -08:00
|
|
|
|
|
|
|
@class RCTModuleData;
|
2016-07-18 07:12:19 -07:00
|
|
|
@protocol RCTJavaScriptExecutor;
|
2015-12-15 05:39:30 -08:00
|
|
|
|
2016-09-19 04:43:06 -07:00
|
|
|
RCT_EXTERN NSArray<Class> *RCTGetModuleClasses(void);
|
|
|
|
|
2017-02-17 05:47:28 -08:00
|
|
|
RCT_EXTERN __attribute__((weak)) void RCTFBQuickPerformanceLoggerConfigureHooks(JSGlobalContextRef ctx);
|
|
|
|
|
2016-09-19 04:43:06 -07:00
|
|
|
#if RCT_DEBUG
|
|
|
|
RCT_EXTERN void RCTVerifyAllModulesExported(NSArray *extraModules);
|
|
|
|
#endif
|
|
|
|
|
2015-12-15 05:39:30 -08:00
|
|
|
@interface RCTBridge ()
|
|
|
|
|
2016-07-12 05:51:56 -07:00
|
|
|
// Private designated initializer
|
|
|
|
- (instancetype)initWithDelegate:(id<RCTBridgeDelegate>)delegate
|
|
|
|
bundleURL:(NSURL *)bundleURL
|
|
|
|
moduleProvider:(RCTBridgeModuleProviderBlock)block
|
|
|
|
launchOptions:(NSDictionary *)launchOptions NS_DESIGNATED_INITIALIZER;
|
|
|
|
|
2016-02-08 07:06:52 -08:00
|
|
|
// Used for the profiler flow events between JS and native
|
|
|
|
@property (nonatomic, assign) int64_t flowID;
|
|
|
|
@property (nonatomic, assign) CFMutableDictionaryRef flowIDMap;
|
2016-03-30 08:07:23 -07:00
|
|
|
@property (nonatomic, strong) NSLock *flowIDMapLock;
|
2016-02-08 07:06:52 -08:00
|
|
|
|
2015-12-15 05:39:30 -08:00
|
|
|
+ (instancetype)currentBridge;
|
|
|
|
+ (void)setCurrentBridge:(RCTBridge *)bridge;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Bridge setup code - creates an instance of RCTBachedBridge. Exposed for
|
|
|
|
* test only
|
|
|
|
*/
|
|
|
|
- (void)setUp;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is used to invoke a callback that was registered in the
|
|
|
|
* JavaScript application context. Safe to call from any thread.
|
|
|
|
*/
|
|
|
|
- (void)enqueueCallback:(NSNumber *)cbID args:(NSArray *)args;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This property is mostly used on the main thread, but may be touched from
|
|
|
|
* a background thread if the RCTBridge happens to deallocate on a background
|
|
|
|
* thread. Therefore, we want all writes to it to be seen atomically.
|
|
|
|
*/
|
|
|
|
@property (atomic, strong) RCTBridge *batchedBridge;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The block that creates the modules' instances to be added to the bridge.
|
|
|
|
* Exposed for the RCTBatchedBridge
|
|
|
|
*/
|
|
|
|
@property (nonatomic, copy, readonly) RCTBridgeModuleProviderBlock moduleProvider;
|
|
|
|
|
2016-01-04 10:39:07 -08:00
|
|
|
/**
|
|
|
|
* Used by RCTDevMenu to override the `hot` param of the current bundleURL.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, strong, readwrite) NSURL *bundleURL;
|
|
|
|
|
2015-12-15 05:39:30 -08:00
|
|
|
@end
|
|
|
|
|
|
|
|
@interface RCTBridge (RCTBatchedBridge)
|
|
|
|
|
2016-03-01 09:44:05 -08:00
|
|
|
/**
|
2016-07-18 07:12:19 -07:00
|
|
|
* Access the underlying JavaScript executor. You can use this in unit tests to detect
|
|
|
|
* when the executor has been invalidated, or when you want to schedule calls on the
|
|
|
|
* JS VM outside of React Native. Use with care!
|
2016-03-01 09:44:05 -08:00
|
|
|
*/
|
|
|
|
@property (nonatomic, weak, readonly) id<RCTJavaScriptExecutor> javaScriptExecutor;
|
|
|
|
|
2016-03-03 02:20:20 -08:00
|
|
|
/**
|
|
|
|
* Used by RCTModuleData
|
|
|
|
*/
|
|
|
|
@property (nonatomic, assign, readonly) BOOL moduleSetupComplete;
|
|
|
|
|
2016-09-26 16:01:40 -07:00
|
|
|
/**
|
|
|
|
* Called on the child bridge to run the executor and start loading.
|
|
|
|
*/
|
|
|
|
- (void)start;
|
|
|
|
|
2016-01-05 09:04:08 -08:00
|
|
|
/**
|
|
|
|
* Used by RCTModuleData to register the module for frame updates after it is
|
|
|
|
* lazily initialized.
|
|
|
|
*/
|
|
|
|
- (void)registerModuleForFrameUpdates:(id<RCTBridgeModule>)module
|
|
|
|
withModuleData:(RCTModuleData *)moduleData;
|
2015-12-15 05:39:30 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispatch work to a module's queue - this is also suports the fake RCTJSThread
|
|
|
|
* queue. Exposed for the RCTProfiler
|
|
|
|
*/
|
|
|
|
- (void)dispatchBlock:(dispatch_block_t)block queue:(dispatch_queue_t)queue;
|
|
|
|
|
2016-01-06 05:57:25 -08:00
|
|
|
/**
|
|
|
|
* Get the module data for a given module name. Used by UIManager to implement
|
|
|
|
* the `dispatchViewManagerCommand` method.
|
|
|
|
*/
|
|
|
|
- (RCTModuleData *)moduleDataForName:(NSString *)moduleName;
|
|
|
|
|
2015-12-15 05:39:30 -08:00
|
|
|
/**
|
|
|
|
* Systrace profiler toggling methods exposed for the RCTDevMenu
|
|
|
|
*/
|
|
|
|
- (void)startProfiling;
|
|
|
|
- (void)stopProfiling:(void (^)(NSData *))callback;
|
|
|
|
|
|
|
|
/**
|
2015-12-16 02:49:27 -08:00
|
|
|
* Exposed for the RCTJSCExecutor for sending native methods called from
|
2015-12-15 05:39:30 -08:00
|
|
|
* JavaScript in the middle of a batch.
|
|
|
|
*/
|
|
|
|
- (void)handleBuffer:(NSArray<NSArray *> *)buffer batchEnded:(BOOL)hasEnded;
|
|
|
|
|
2016-09-05 07:32:20 -07:00
|
|
|
/**
|
|
|
|
* Synchronously call a specific native module's method and return the result
|
|
|
|
*/
|
|
|
|
- (id)callNativeModule:(NSUInteger)moduleID
|
|
|
|
method:(NSUInteger)methodID
|
|
|
|
params:(NSArray *)params;
|
|
|
|
|
2015-12-15 05:39:30 -08:00
|
|
|
/**
|
2015-12-16 02:49:27 -08:00
|
|
|
* Exposed for the RCTJSCExecutor for lazily loading native modules
|
2015-12-15 05:39:30 -08:00
|
|
|
*/
|
|
|
|
- (NSArray *)configForModuleName:(NSString *)moduleName;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hook exposed for RCTLog to send logs to JavaScript when not running in JSC
|
|
|
|
*/
|
|
|
|
- (void)logMessage:(NSString *)message level:(NSString *)level;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allow super fast, one time, timers to skip the queue and be directly executed
|
|
|
|
*/
|
|
|
|
- (void)_immediatelyCallTimer:(NSNumber *)timer;
|
|
|
|
|
|
|
|
@end
|
2016-04-01 06:52:59 -07:00
|
|
|
|
|
|
|
@interface RCTBatchedBridge : RCTBridge <RCTInvalidating>
|
|
|
|
|
2016-07-22 09:50:48 -07:00
|
|
|
@property (nonatomic, weak, readonly) RCTBridge *parentBridge;
|
|
|
|
@property (nonatomic, weak, readonly) id<RCTJavaScriptExecutor> javaScriptExecutor;
|
|
|
|
@property (nonatomic, assign, readonly) BOOL moduleSetupComplete;
|
2016-04-01 06:52:59 -07:00
|
|
|
|
|
|
|
- (instancetype)initWithParentBridge:(RCTBridge *)bridge NS_DESIGNATED_INITIALIZER;
|
2016-09-26 16:01:40 -07:00
|
|
|
- (void)start;
|
2016-04-01 06:52:59 -07:00
|
|
|
|
|
|
|
@end
|