2015-03-23 20:28:42 +00: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.
|
|
|
|
*/
|
2015-02-20 04:10:52 +00:00
|
|
|
|
2015-04-02 14:33:21 +00:00
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2015-07-28 22:48:46 +00:00
|
|
|
#import "RCTBridgeDelegate.h"
|
2015-02-20 04:10:52 +00:00
|
|
|
#import "RCTBridgeModule.h"
|
2015-04-21 12:26:51 +00:00
|
|
|
#import "RCTDefines.h"
|
2015-04-15 14:07:19 +00:00
|
|
|
#import "RCTFrameUpdate.h"
|
2015-02-20 04:10:52 +00:00
|
|
|
#import "RCTInvalidating.h"
|
|
|
|
#import "RCTJavaScriptExecutor.h"
|
|
|
|
|
2015-02-24 17:06:57 +00:00
|
|
|
@class RCTBridge;
|
2015-02-20 04:10:52 +00:00
|
|
|
@class RCTEventDispatcher;
|
|
|
|
|
2015-04-11 22:08:00 +00:00
|
|
|
/**
|
|
|
|
* This notification triggers a reload of all bridges currently running.
|
|
|
|
*/
|
2015-06-10 10:43:55 +00:00
|
|
|
RCT_EXTERN NSString *const RCTReloadNotification;
|
2015-04-11 22:08:00 +00:00
|
|
|
|
2015-07-28 18:07:45 +00:00
|
|
|
/**
|
|
|
|
* This notification fires when the bridge starts loading.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptWillStartLoadingNotification;
|
|
|
|
|
2015-04-11 22:08:00 +00:00
|
|
|
/**
|
|
|
|
* This notification fires when the bridge has finished loading.
|
|
|
|
*/
|
2015-06-10 10:43:55 +00:00
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptDidLoadNotification;
|
2015-04-11 22:08:00 +00:00
|
|
|
|
2015-05-07 11:29:31 +00:00
|
|
|
/**
|
|
|
|
* This notification fires when the bridge failed to load.
|
|
|
|
*/
|
2015-06-10 10:43:55 +00:00
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptDidFailToLoadNotification;
|
2015-05-07 11:29:31 +00:00
|
|
|
|
2015-07-01 00:08:28 +00:00
|
|
|
/**
|
|
|
|
* This notification fires when the bridge created all registered native modules
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTDidCreateNativeModules;
|
|
|
|
|
2015-02-24 17:06:57 +00:00
|
|
|
/**
|
|
|
|
* This block can be used to instantiate modules that require additional
|
|
|
|
* init parameters, or additional configuration prior to being used.
|
2015-03-01 23:33:55 +00: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 17:06:57 +00:00
|
|
|
*/
|
2015-03-01 23:33:55 +00:00
|
|
|
typedef NSArray *(^RCTBridgeModuleProviderBlock)(void);
|
2015-02-24 17:06:57 +00:00
|
|
|
|
2015-04-07 14:36:26 +00:00
|
|
|
/**
|
|
|
|
* This function returns the module name for a given class.
|
|
|
|
*/
|
2015-04-21 12:26:51 +00:00
|
|
|
RCT_EXTERN NSString *RCTBridgeModuleNameForClass(Class bridgeModuleClass);
|
2015-04-07 14:36:26 +00:00
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
/**
|
|
|
|
* Async batched bridge used to communicate with the JavaScript application.
|
|
|
|
*/
|
|
|
|
@interface RCTBridge : NSObject <RCTInvalidating>
|
|
|
|
|
2015-07-28 22:48:46 +00: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
|
|
|
|
launchOptions:(NSDictionary *)launchOptions NS_DESIGNATED_INITIALIZER;
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
/**
|
2015-07-28 22:48:46 +00:00
|
|
|
* DEPRECATED: Use initWithDelegate:launchOptions: instead
|
|
|
|
*
|
2015-02-20 04:10:52 +00: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 17:06:57 +00:00
|
|
|
* with the JavaScript code running in the executor. Modules will be automatically
|
2015-03-01 23:33:55 +00: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-20 04:10:52 +00:00
|
|
|
*/
|
2015-04-11 22:08:00 +00:00
|
|
|
- (instancetype)initWithBundleURL:(NSURL *)bundleURL
|
|
|
|
moduleProvider:(RCTBridgeModuleProviderBlock)block
|
|
|
|
launchOptions:(NSDictionary *)launchOptions NS_DESIGNATED_INITIALIZER;
|
2015-02-20 04:10:52 +00: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 20:01:39 +00:00
|
|
|
* with the JavaScript code. Safe to call from any thread.
|
2015-02-20 04:10:52 +00:00
|
|
|
*/
|
|
|
|
- (void)enqueueJSCall:(NSString *)moduleDotMethod args:(NSArray *)args;
|
|
|
|
|
2015-04-08 12:42:43 +00:00
|
|
|
/**
|
2015-06-15 20:01:39 +00:00
|
|
|
* DEPRECATED: Do not use.
|
2015-04-08 12:42:43 +00:00
|
|
|
*/
|
|
|
|
#define RCT_IMPORT_METHOD(module, method) \
|
2015-06-15 20:01:39 +00:00
|
|
|
_Pragma("message(\"This macro is no longer required\")")
|
2015-04-08 12:42:43 +00:00
|
|
|
|
2015-04-20 21:04:53 +00:00
|
|
|
/**
|
|
|
|
* URL of the script that was loaded into the bridge.
|
|
|
|
*/
|
2015-07-28 12:58:01 +00:00
|
|
|
@property (nonatomic, strong) NSURL *bundleURL;
|
2015-04-20 21:04:53 +00:00
|
|
|
|
2015-07-28 22:48:46 +00:00
|
|
|
/**
|
|
|
|
* The class of the executor currently being used *or* to be used after the next
|
|
|
|
* reload.
|
|
|
|
*/
|
2015-04-02 14:33:21 +00:00
|
|
|
@property (nonatomic, strong) Class executorClass;
|
|
|
|
|
2015-07-28 22:48:46 +00:00
|
|
|
/**
|
|
|
|
* The delegate provided during the bridge initialization
|
|
|
|
*/
|
|
|
|
@property (nonatomic, weak, readonly) id<RCTBridgeDelegate> delegate;
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
/**
|
|
|
|
* The event dispatcher is a wrapper around -enqueueJSCall:args: that provides a
|
|
|
|
* higher-level interface for sending UI events such as touches and text input.
|
2015-05-28 03:15:33 +00:00
|
|
|
*
|
|
|
|
* NOTE: RCTEventDispatcher is now a bridge module, this is implemented as a
|
|
|
|
* category but remains declared in the bridge to avoid breaking changes
|
|
|
|
*
|
|
|
|
* To be moved.
|
2015-02-20 04:10:52 +00:00
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly) RCTEventDispatcher *eventDispatcher;
|
|
|
|
|
2015-02-24 17:06:57 +00:00
|
|
|
/**
|
|
|
|
* A dictionary of all registered RCTBridgeModule instances, keyed by moduleName.
|
|
|
|
*/
|
|
|
|
@property (nonatomic, copy, readonly) NSDictionary *modules;
|
|
|
|
|
2015-04-08 12:42:43 +00:00
|
|
|
/**
|
|
|
|
* The launch options that were used to initialize the bridge.
|
|
|
|
*/
|
2015-03-26 01:59:42 +00:00
|
|
|
@property (nonatomic, copy, readonly) NSDictionary *launchOptions;
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
/**
|
2015-04-08 12:42:43 +00:00
|
|
|
* Use this to check if the bridge is currently loading.
|
2015-02-20 04:10:52 +00:00
|
|
|
*/
|
2015-04-11 22:08:00 +00:00
|
|
|
@property (nonatomic, readonly, getter=isLoading) BOOL loading;
|
2015-02-20 04:10:52 +00:00
|
|
|
|
[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 23:34:56 +00:00
|
|
|
/**
|
|
|
|
* The block passed in the constructor with pre-initialized modules
|
|
|
|
*/
|
|
|
|
@property (nonatomic, copy, readonly) RCTBridgeModuleProviderBlock moduleProvider;
|
|
|
|
|
2015-04-08 12:42:43 +00:00
|
|
|
/**
|
2015-04-20 19:06:02 +00:00
|
|
|
* Reload the bundle and reset executor & modules. Safe to call from any thread.
|
2015-04-08 12:42:43 +00:00
|
|
|
*/
|
2015-04-02 14:33:21 +00:00
|
|
|
- (void)reload;
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
@end
|