2015-03-23 13:28:42 -07: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-19 20:10:52 -08:00
|
|
|
|
2015-04-20 02:09:11 -07:00
|
|
|
#import <objc/runtime.h>
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
#import <JavaScriptCore/JavaScriptCore.h>
|
|
|
|
|
2015-06-09 15:42:10 -07:00
|
|
|
#import "RCTBridgeModule.h"
|
2015-02-19 20:10:52 -08:00
|
|
|
#import "RCTInvalidating.h"
|
|
|
|
|
|
|
|
typedef void (^RCTJavaScriptCompleteBlock)(NSError *error);
|
2016-07-18 07:12:19 -07:00
|
|
|
typedef void (^RCTJavaScriptCallback)(id result, NSError *error);
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Abstracts away a JavaScript execution context - we may be running code in a
|
|
|
|
* web view (for debugging purposes), or may be running code in a `JSContext`.
|
|
|
|
*/
|
2015-06-09 15:42:10 -07:00
|
|
|
@protocol RCTJavaScriptExecutor <RCTInvalidating, RCTBridgeModule>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to set up the executor after the bridge has been fully initialized.
|
|
|
|
* Do any expensive setup in this method instead of `-init`.
|
|
|
|
*/
|
|
|
|
- (void)setUp;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2015-08-14 01:59:42 -07:00
|
|
|
/**
|
|
|
|
* Whether the executor has been invalidated
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly, getter=isValid) BOOL valid;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
/**
|
2015-12-08 15:57:34 -08:00
|
|
|
* Executes BatchedBridge.flushedQueue on JS thread and calls the given callback
|
|
|
|
* with JSValue, containing the next queue, and JSContext.
|
2015-02-19 20:10:52 -08:00
|
|
|
*/
|
2015-12-08 15:57:34 -08:00
|
|
|
- (void)flushedQueue:(RCTJavaScriptCallback)onComplete;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes BatchedBridge.callFunctionReturnFlushedQueue with the module name,
|
|
|
|
* method name and optional additional arguments on the JS thread and calls the
|
|
|
|
* given callback with JSValue, containing the next queue, and JSContext.
|
|
|
|
*/
|
|
|
|
- (void)callFunctionOnModule:(NSString *)module
|
|
|
|
method:(NSString *)method
|
|
|
|
arguments:(NSArray *)args
|
|
|
|
callback:(RCTJavaScriptCallback)onComplete;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes BatchedBridge.invokeCallbackAndReturnFlushedQueue with the cbID,
|
|
|
|
* and optional additional arguments on the JS thread and calls the
|
|
|
|
* given callback with JSValue, containing the next queue, and JSContext.
|
|
|
|
*/
|
|
|
|
- (void)invokeCallbackID:(NSNumber *)cbID
|
|
|
|
arguments:(NSArray *)args
|
|
|
|
callback:(RCTJavaScriptCallback)onComplete;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs an application script, and notifies of the script load being complete via `onComplete`.
|
|
|
|
*/
|
2015-10-16 08:10:25 -07:00
|
|
|
- (void)executeApplicationScript:(NSData *)script
|
2015-06-15 07:53:45 -07:00
|
|
|
sourceURL:(NSURL *)sourceURL
|
2015-02-19 20:10:52 -08:00
|
|
|
onComplete:(RCTJavaScriptCompleteBlock)onComplete;
|
|
|
|
|
|
|
|
- (void)injectJSONText:(NSString *)script
|
|
|
|
asGlobalObjectNamed:(NSString *)objectName
|
|
|
|
callback:(RCTJavaScriptCompleteBlock)onComplete;
|
2015-04-22 07:03:55 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enqueue a block to run in the executors JS thread. Fallback to `dispatch_async`
|
|
|
|
* on the main queue if the executor doesn't own a thread.
|
|
|
|
*/
|
|
|
|
- (void)executeBlockOnJavaScriptQueue:(dispatch_block_t)block;
|
|
|
|
|
2015-04-28 08:02:56 -07:00
|
|
|
/**
|
|
|
|
* Special case for Timers + ContextExecutor - instead of the default
|
|
|
|
* if jsthread then call else dispatch call on jsthread
|
|
|
|
* ensure the call is made async on the jsthread
|
|
|
|
*/
|
|
|
|
- (void)executeAsyncBlockOnJavaScriptQueue:(dispatch_block_t)block;
|
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
@end
|