2015-03-23 13:28:42 -07:00
|
|
|
/**
|
2018-09-11 15:27:47 -07:00
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
2015-03-23 13:28:42 -07:00
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2015-03-23 13:28:42 -07:00
|
|
|
*/
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-04-02 07:33:21 -07:00
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2016-11-23 07:47:52 -08:00
|
|
|
#import <React/RCTBridgeDelegate.h>
|
|
|
|
#import <React/RCTBridgeModule.h>
|
|
|
|
#import <React/RCTDefines.h>
|
|
|
|
#import <React/RCTFrameUpdate.h>
|
|
|
|
#import <React/RCTInvalidating.h>
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2016-09-28 14:00:16 -07:00
|
|
|
@class JSValue;
|
2015-02-24 09:06:57 -08:00
|
|
|
@class RCTBridge;
|
2015-02-19 20:10:52 -08:00
|
|
|
@class RCTEventDispatcher;
|
2016-07-07 07:20:03 -07:00
|
|
|
@class RCTPerformanceLogger;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-07-28 11:07:45 -07:00
|
|
|
/**
|
2018-03-06 11:01:34 -08:00
|
|
|
* This notification fires when the bridge initializes.
|
2015-07-28 11:07:45 -07:00
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptWillStartLoadingNotification;
|
|
|
|
|
2018-03-06 11:01:34 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This notification fires when the bridge starts executing the JS bundle.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptWillStartExecutingNotification;
|
|
|
|
|
2015-04-11 15:08:00 -07:00
|
|
|
/**
|
2015-12-15 05:42:45 -08:00
|
|
|
* This notification fires when the bridge has finished loading the JS bundle.
|
2015-04-11 15:08:00 -07:00
|
|
|
*/
|
2015-06-10 03:43:55 -07:00
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptDidLoadNotification;
|
2015-04-11 15:08:00 -07:00
|
|
|
|
2015-05-07 04:29:31 -07:00
|
|
|
/**
|
2015-12-15 05:42:45 -08:00
|
|
|
* This notification fires when the bridge failed to load the JS bundle. The
|
2018-01-12 22:03:51 -08:00
|
|
|
* `error` key can be used to determine the error that occurred.
|
2015-05-07 04:29:31 -07:00
|
|
|
*/
|
2015-06-10 03:43:55 -07:00
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptDidFailToLoadNotification;
|
2015-05-07 04:29:31 -07:00
|
|
|
|
2015-06-30 17:08:28 -07:00
|
|
|
/**
|
2015-12-15 05:42:45 -08:00
|
|
|
* This notification fires each time a native module is instantiated. The
|
|
|
|
* `module` key will contain a reference to the newly-created module instance.
|
|
|
|
* Note that this notification may be fired before the module is available via
|
|
|
|
* the `[bridge moduleForClass:]` method.
|
2015-06-30 17:08:28 -07:00
|
|
|
*/
|
2015-12-15 05:42:45 -08:00
|
|
|
RCT_EXTERN NSString *const RCTDidInitializeModuleNotification;
|
2015-06-30 17:08:28 -07:00
|
|
|
|
2017-08-17 17:09:59 -07:00
|
|
|
/**
|
|
|
|
* This notification fires just before the bridge starts processing a request to
|
|
|
|
* reload.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTBridgeWillReloadNotification;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This notification fires just before the bridge begins downloading a script
|
|
|
|
* from the packager.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTBridgeWillDownloadScriptNotification;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This notification fires just after the bridge finishes downloading a script
|
|
|
|
* from the packager.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTBridgeDidDownloadScriptNotification;
|
|
|
|
|
2017-08-31 05:25:19 -07:00
|
|
|
/**
|
|
|
|
* Key for the RCTSource object in the RCTBridgeDidDownloadScriptNotification
|
|
|
|
* userInfo dictionary.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTBridgeDidDownloadScriptNotificationSourceKey;
|
|
|
|
|
2018-04-10 19:23:07 -07:00
|
|
|
/**
|
|
|
|
* Key for the bridge description (NSString_ in the
|
|
|
|
* RCTBridgeDidDownloadScriptNotification userInfo dictionary.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTBridgeDidDownloadScriptNotificationBridgeDescriptionKey;
|
|
|
|
|
2015-02-24 09:06:57 -08:00
|
|
|
/**
|
|
|
|
* This block can be used to instantiate modules that require additional
|
|
|
|
* init parameters, or additional configuration prior to being used.
|
2015-03-01 15:33:55 -08:00
|
|
|
* The bridge will call this block to instatiate the modules, and will
|
|
|
|
* be responsible for invalidating/releasing them when the bridge is destroyed.
|
|
|
|
* For this reason, the block should always return new module instances, and
|
|
|
|
* module instances should not be shared between bridges.
|
2015-02-24 09:06:57 -08:00
|
|
|
*/
|
2017-04-07 11:11:03 -07:00
|
|
|
typedef NSArray<id<RCTBridgeModule>> *(^RCTBridgeModuleListProvider)(void);
|
2015-02-24 09:06:57 -08:00
|
|
|
|
2015-04-07 07:36:26 -07:00
|
|
|
/**
|
|
|
|
* This function returns the module name for a given class.
|
|
|
|
*/
|
2015-04-21 05:26:51 -07:00
|
|
|
RCT_EXTERN NSString *RCTBridgeModuleNameForClass(Class bridgeModuleClass);
|
2015-04-07 07:36:26 -07:00
|
|
|
|
2018-08-29 15:36:24 -07:00
|
|
|
/**
|
|
|
|
* Experimental.
|
|
|
|
* Check/set if JSI-bound NativeModule is enabled. By default it's off.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN BOOL RCTJSINativeModuleEnabled(void);
|
|
|
|
RCT_EXTERN void RCTEnableJSINativeModule(BOOL enabled);
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
/**
|
|
|
|
* Async batched bridge used to communicate with the JavaScript application.
|
|
|
|
*/
|
|
|
|
@interface RCTBridge : NSObject <RCTInvalidating>
|
|
|
|
|
2015-07-28 15:48:46 -07:00
|
|
|
/**
|
|
|
|
* Creates a new bridge with a custom RCTBridgeDelegate.
|
|
|
|
*
|
|
|
|
* All the interaction with the JavaScript context should be done using the bridge
|
|
|
|
* instance of the RCTBridgeModules. Modules will be automatically instantiated
|
|
|
|
* using the default contructor, but you can optionally pass in an array of
|
|
|
|
* pre-initialized module instances if they require additional init parameters
|
|
|
|
* or configuration.
|
|
|
|
*/
|
|
|
|
- (instancetype)initWithDelegate:(id<RCTBridgeDelegate>)delegate
|
2016-07-12 05:51:56 -07:00
|
|
|
launchOptions:(NSDictionary *)launchOptions;
|
2015-07-28 15:48:46 -07:00
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
/**
|
2015-07-28 15:48:46 -07:00
|
|
|
* DEPRECATED: Use initWithDelegate:launchOptions: instead
|
|
|
|
*
|
2015-02-19 20:10:52 -08:00
|
|
|
* The designated initializer. This creates a new bridge on top of the specified
|
|
|
|
* executor. The bridge should then be used for all subsequent communication
|
2015-02-24 09:06:57 -08:00
|
|
|
* with the JavaScript code running in the executor. Modules will be automatically
|
2015-03-01 15:33:55 -08:00
|
|
|
* instantiated using the default contructor, but you can optionally pass in an
|
|
|
|
* array of pre-initialized module instances if they require additional init
|
|
|
|
* parameters or configuration.
|
2015-02-19 20:10:52 -08:00
|
|
|
*/
|
2015-04-11 15:08:00 -07:00
|
|
|
- (instancetype)initWithBundleURL:(NSURL *)bundleURL
|
2017-04-07 11:11:03 -07:00
|
|
|
moduleProvider:(RCTBridgeModuleListProvider)block
|
2016-07-12 05:51:56 -07:00
|
|
|
launchOptions:(NSDictionary *)launchOptions;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is used to call functions in the JavaScript application context.
|
|
|
|
* It is primarily intended for use by modules that require two-way communication
|
2015-06-15 13:01:39 -07:00
|
|
|
* with the JavaScript code. Safe to call from any thread.
|
2015-02-19 20:10:52 -08:00
|
|
|
*/
|
|
|
|
- (void)enqueueJSCall:(NSString *)moduleDotMethod args:(NSArray *)args;
|
2016-07-18 07:12:22 -07:00
|
|
|
- (void)enqueueJSCall:(NSString *)module method:(NSString *)method args:(NSArray *)args completion:(dispatch_block_t)completion;
|
|
|
|
|
2017-11-09 11:55:39 -08:00
|
|
|
/**
|
|
|
|
* This method registers the file path of an additional JS segment by its ID.
|
|
|
|
*
|
|
|
|
* @experimental
|
|
|
|
*/
|
|
|
|
- (void)registerSegmentWithId:(NSUInteger)segmentId path:(NSString *)path;
|
|
|
|
|
2015-04-08 05:42:43 -07:00
|
|
|
/**
|
2015-11-25 03:09:00 -08:00
|
|
|
* Retrieve a bridge module instance by name or class. Note that modules are
|
|
|
|
* lazily instantiated, so calling these methods for the first time with a given
|
|
|
|
* module name/class may cause the class to be sychronously instantiated,
|
2016-03-03 02:20:20 -08:00
|
|
|
* potentially blocking both the calling thread and main thread for a short time.
|
2015-11-25 03:09:00 -08:00
|
|
|
*/
|
|
|
|
- (id)moduleForName:(NSString *)moduleName;
|
|
|
|
- (id)moduleForClass:(Class)moduleClass;
|
|
|
|
|
2016-03-03 02:20:20 -08:00
|
|
|
/**
|
|
|
|
* Convenience method for retrieving all modules conforming to a given protocol.
|
|
|
|
* Modules will be sychronously instantiated if they haven't already been,
|
|
|
|
* potentially blocking both the calling thread and main thread for a short time.
|
|
|
|
*/
|
|
|
|
- (NSArray *)modulesConformingToProtocol:(Protocol *)protocol;
|
|
|
|
|
2016-03-07 09:30:20 -08:00
|
|
|
/**
|
|
|
|
* Test if a module has been initialized. Use this prior to calling
|
2016-03-23 17:22:16 -07:00
|
|
|
* `moduleForClass:` or `moduleForName:` if you do not want to cause the module
|
2016-03-07 09:30:20 -08:00
|
|
|
* to be instantiated if it hasn't been already.
|
|
|
|
*/
|
|
|
|
- (BOOL)moduleIsInitialized:(Class)moduleClass;
|
|
|
|
|
2018-02-13 22:26:43 -08:00
|
|
|
/**
|
|
|
|
* Retrieve an extra module that gets bound to the JS context, if any.
|
|
|
|
*/
|
|
|
|
- (id)jsBoundExtraModuleForClass:(Class)moduleClass;
|
|
|
|
|
2015-11-25 03:09:00 -08:00
|
|
|
/**
|
|
|
|
* All registered bridge module classes.
|
2015-04-08 05:42:43 -07:00
|
|
|
*/
|
2015-11-25 03:09:00 -08:00
|
|
|
@property (nonatomic, copy, readonly) NSArray<Class> *moduleClasses;
|
2015-04-08 05:42:43 -07:00
|
|
|
|
2015-04-20 14:04:53 -07:00
|
|
|
/**
|
|
|
|
* URL of the script that was loaded into the bridge.
|
|
|
|
*/
|
2016-01-04 10:39:07 -08:00
|
|
|
@property (nonatomic, strong, readonly) NSURL *bundleURL;
|
2015-04-20 14:04:53 -07:00
|
|
|
|
2015-07-28 15:48:46 -07:00
|
|
|
/**
|
2016-01-04 10:39:07 -08:00
|
|
|
* The class of the executor currently being used. Changes to this value will
|
|
|
|
* take effect after the bridge is reloaded.
|
2015-07-28 15:48:46 -07:00
|
|
|
*/
|
2015-04-02 07:33:21 -07:00
|
|
|
@property (nonatomic, strong) Class executorClass;
|
|
|
|
|
2015-07-28 15:48:46 -07:00
|
|
|
/**
|
|
|
|
* The delegate provided during the bridge initialization
|
|
|
|
*/
|
|
|
|
@property (nonatomic, weak, readonly) id<RCTBridgeDelegate> delegate;
|
|
|
|
|
2015-04-08 05:42:43 -07:00
|
|
|
/**
|
|
|
|
* The launch options that were used to initialize the bridge.
|
|
|
|
*/
|
2015-03-25 18:59:42 -07:00
|
|
|
@property (nonatomic, copy, readonly) NSDictionary *launchOptions;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
/**
|
2015-04-08 05:42:43 -07:00
|
|
|
* Use this to check if the bridge is currently loading.
|
2015-02-19 20:10:52 -08:00
|
|
|
*/
|
2015-04-11 15:08:00 -07:00
|
|
|
@property (nonatomic, readonly, getter=isLoading) BOOL loading;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-08-14 01:59:42 -07:00
|
|
|
/**
|
|
|
|
* Use this to check if the bridge has been invalidated.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly, getter=isValid) BOOL valid;
|
|
|
|
|
2016-07-07 07:20:03 -07:00
|
|
|
/**
|
|
|
|
* Link to the Performance Logger that logs React Native perf events.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly, strong) RCTPerformanceLogger *performanceLogger;
|
|
|
|
|
[ReactNative] Move module info from bridge to RCTModuleData
Summary:
@public
The info about bridge modules (such as id, name, queue, methods...) was spread
across arrays & dictionaries on the bridge, move it into a specific class.
It also removes a lot of information that was statically cached, and now have
the same lifecycle of the bridge.
Also moved RCTModuleMethod, RCTFrameUpdate and RCTBatchedBridge into it's own
files, for organization sake.
NOTE: This diff seems huge, but most of it was just moving code :)
Test Plan:
Tested UIExplorer & UIExplorer tests, Catalyst, MAdMan and Groups. Everything
looks fine.
2015-06-24 16:34:56 -07:00
|
|
|
/**
|
2015-11-25 03:09:00 -08:00
|
|
|
* Reload the bundle and reset executor & modules. Safe to call from any thread.
|
[ReactNative] Move module info from bridge to RCTModuleData
Summary:
@public
The info about bridge modules (such as id, name, queue, methods...) was spread
across arrays & dictionaries on the bridge, move it into a specific class.
It also removes a lot of information that was statically cached, and now have
the same lifecycle of the bridge.
Also moved RCTModuleMethod, RCTFrameUpdate and RCTBatchedBridge into it's own
files, for organization sake.
NOTE: This diff seems huge, but most of it was just moving code :)
Test Plan:
Tested UIExplorer & UIExplorer tests, Catalyst, MAdMan and Groups. Everything
looks fine.
2015-06-24 16:34:56 -07:00
|
|
|
*/
|
2015-11-25 03:09:00 -08:00
|
|
|
- (void)reload;
|
|
|
|
|
2016-09-07 17:24:23 -07:00
|
|
|
/**
|
|
|
|
* Inform the bridge, and anything subscribing to it, that it should reload.
|
|
|
|
*/
|
2016-12-07 16:27:55 -08:00
|
|
|
- (void)requestReload __deprecated_msg("Call reload instead");
|
2016-09-07 17:24:23 -07:00
|
|
|
|
2015-12-11 06:54:56 -08:00
|
|
|
/**
|
2018-01-12 22:03:51 -08:00
|
|
|
* Says whether bridge has started receiving calls from javascript.
|
2015-12-11 06:54:56 -08:00
|
|
|
*/
|
|
|
|
- (BOOL)isBatchActive;
|
|
|
|
|
2015-11-25 03:09:00 -08:00
|
|
|
@end
|