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
|
|
|
|
|
|
|
#import <JavaScriptCore/JavaScriptCore.h>
|
|
|
|
|
2015-04-23 08:04:16 -07:00
|
|
|
#import "RCTJavaScriptExecutor.h"
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2016-02-12 03:49:51 -08:00
|
|
|
/**
|
|
|
|
* Default name for the JS thread
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTJSCThreadName;
|
|
|
|
|
2016-02-15 12:57:21 -08:00
|
|
|
/**
|
|
|
|
* This notification fires on the JS thread immediately after a `JSContext`
|
|
|
|
* is fully initialized, but before the JS bundle has been loaded. The object
|
|
|
|
* of this notification is the `JSContext`. Native modules should listen for
|
|
|
|
* notification only if they need to install custom functionality into the
|
|
|
|
* context. Note that this notification won't fire when debugging in Chrome.
|
|
|
|
*/
|
|
|
|
RCT_EXTERN NSString *const RCTJavaScriptContextCreatedNotification;
|
|
|
|
|
2016-07-08 12:19:27 -07:00
|
|
|
/**
|
|
|
|
* @experimental
|
|
|
|
* May be used to pre-create the JSContext to make RCTJSCExecutor creation less costly.
|
|
|
|
* Avoid using this; it's experimental and is not likely to be supported long-term.
|
|
|
|
*/
|
|
|
|
@interface RCTJSContextProvider : NSObject
|
|
|
|
|
|
|
|
- (instancetype)initWithUseCustomJSCLibrary:(BOOL)useCustomJSCLibrary;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
2016-05-31 12:50:48 -07:00
|
|
|
/**
|
|
|
|
* Uses a JavaScriptCore context as the execution engine.
|
|
|
|
*/
|
|
|
|
@interface RCTJSCExecutor : NSObject <RCTJavaScriptExecutor>
|
|
|
|
|
|
|
|
/**
|
2016-06-06 11:10:24 -07:00
|
|
|
* Returns whether executor uses custom JSC library.
|
|
|
|
* This value is used to initialize RCTJSCWrapper.
|
2016-05-31 12:50:48 -07:00
|
|
|
* @default is NO.
|
|
|
|
*/
|
2016-06-06 11:10:24 -07:00
|
|
|
@property (nonatomic, readonly, assign) BOOL useCustomJSCLibrary;
|
2016-05-31 12:50:48 -07:00
|
|
|
|
|
|
|
/**
|
2016-06-06 11:10:24 -07:00
|
|
|
* Inits a new executor instance with given flag that's used
|
2016-05-31 12:50:48 -07:00
|
|
|
* to initialize RCTJSCWrapper.
|
|
|
|
*/
|
2016-06-06 11:10:24 -07:00
|
|
|
- (instancetype)initWithUseCustomJSCLibrary:(BOOL)useCustomJSCLibrary;
|
2016-05-31 12:50:48 -07:00
|
|
|
|
2016-04-28 13:41:55 -07:00
|
|
|
/**
|
|
|
|
* Create a NSError from a JSError object.
|
|
|
|
*
|
|
|
|
* If available, the error's userInfo property will contain the JS stacktrace under
|
|
|
|
* the RCTJSStackTraceKey key.
|
|
|
|
*/
|
2016-07-13 08:19:37 -07:00
|
|
|
- (NSError *)errorForJSError:(JSValue *)jsError;
|
2015-02-19 20:10:52 -08:00
|
|
|
|
2016-07-07 13:31:14 -07:00
|
|
|
/**
|
2016-07-12 05:13:30 -07:00
|
|
|
* @experimental
|
|
|
|
* Pass a RCTJSContextProvider object to use an NSThread/JSContext pair that have already been created.
|
|
|
|
* The returned executor has already executed the supplied application script synchronously.
|
|
|
|
* The underlying JSContext will be returned in the JSContext pointer if it is non-NULL and there was no error.
|
|
|
|
* If an error occurs, this method will return nil and specify the error in the error pointer if it is non-NULL.
|
2016-07-07 13:31:14 -07:00
|
|
|
*/
|
2016-07-12 05:13:30 -07:00
|
|
|
+ (instancetype)initializedExecutorWithContextProvider:(RCTJSContextProvider *)JSContextProvider
|
|
|
|
applicationScript:(NSData *)applicationScript
|
|
|
|
sourceURL:(NSURL *)sourceURL
|
|
|
|
JSContext:(JSContext **)JSContext
|
|
|
|
error:(NSError **)error;
|
2016-07-07 13:31:14 -07:00
|
|
|
|
2015-02-19 20:10:52 -08:00
|
|
|
@end
|