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-20 09:09:11 +00:00
|
|
|
#import <objc/runtime.h>
|
|
|
|
|
2015-02-20 04:10:52 +00:00
|
|
|
#import <JavaScriptCore/JavaScriptCore.h>
|
|
|
|
|
|
|
|
#import "RCTInvalidating.h"
|
|
|
|
|
|
|
|
typedef void (^RCTJavaScriptCompleteBlock)(NSError *error);
|
2015-03-01 23:33:55 +00:00
|
|
|
typedef void (^RCTJavaScriptCallback)(id json, NSError *error);
|
2015-02-20 04:10:52 +00: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`.
|
|
|
|
*/
|
|
|
|
@protocol RCTJavaScriptExecutor <RCTInvalidating>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes given method with arguments on JS thread and calls the given callback
|
|
|
|
* with JSValue and JSContext as a result of the JS module call.
|
|
|
|
*/
|
|
|
|
- (void)executeJSCall:(NSString *)name
|
|
|
|
method:(NSString *)method
|
|
|
|
arguments:(NSArray *)arguments
|
2015-04-20 09:09:11 +00:00
|
|
|
context:(NSNumber *)executorID
|
2015-02-20 04:10:52 +00:00
|
|
|
callback:(RCTJavaScriptCallback)onComplete;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs an application script, and notifies of the script load being complete via `onComplete`.
|
|
|
|
*/
|
|
|
|
- (void)executeApplicationScript:(NSString *)script
|
|
|
|
sourceURL:(NSURL *)url
|
|
|
|
onComplete:(RCTJavaScriptCompleteBlock)onComplete;
|
|
|
|
|
|
|
|
- (void)injectJSONText:(NSString *)script
|
|
|
|
asGlobalObjectNamed:(NSString *)objectName
|
|
|
|
callback:(RCTJavaScriptCompleteBlock)onComplete;
|
2015-04-22 14:03:55 +00: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-02-20 04:10:52 +00:00
|
|
|
@end
|
2015-04-20 09:09:11 +00:00
|
|
|
|
|
|
|
static const char *RCTJavaScriptExecutorID = "RCTJavaScriptExecutorID";
|
|
|
|
__used static id<RCTJavaScriptExecutor> RCTCreateExecutor(Class executorClass)
|
|
|
|
{
|
|
|
|
static NSUInteger executorID = 0;
|
|
|
|
id<RCTJavaScriptExecutor> executor = [[executorClass alloc] init];
|
2015-04-20 18:03:56 +00:00
|
|
|
if (executor) {
|
|
|
|
objc_setAssociatedObject(executor, RCTJavaScriptExecutorID, @(++executorID), OBJC_ASSOCIATION_RETAIN);
|
|
|
|
}
|
2015-04-20 09:09:11 +00:00
|
|
|
return executor;
|
|
|
|
}
|
|
|
|
|
|
|
|
__used static NSNumber *RCTGetExecutorID(id<RCTJavaScriptExecutor> executor)
|
|
|
|
{
|
2015-04-20 18:03:56 +00:00
|
|
|
return executor ? objc_getAssociatedObject(executor, RCTJavaScriptExecutorID) : @0;
|
2015-04-20 09:09:11 +00:00
|
|
|
}
|