/** * 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. */ #import #import "RCTJavaScriptExecutor.h" typedef void (^RCTJavaScriptValueCallback)(JSValue *result, NSError *error); /** * Default name for the JS thread */ RCT_EXTERN NSString *const RCTJSCThreadName; /** * 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; /** * @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 /** * Uses a JavaScriptCore context as the execution engine. */ @interface RCTJSCExecutor : NSObject /** * Returns whether executor uses custom JSC library. * This value is used to initialize RCTJSCWrapper. * @default is NO. */ @property (nonatomic, readonly, assign) BOOL useCustomJSCLibrary; /** * Inits a new executor instance with given flag that's used * to initialize RCTJSCWrapper. */ - (instancetype)initWithUseCustomJSCLibrary:(BOOL)useCustomJSCLibrary; /** * Create a NSError from a JSError object. * * If available, the error's userInfo property will contain the JS stacktrace under * the RCTJSStackTraceKey key. */ - (NSError *)errorForJSError:(JSValue *)jsError; /** * @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. */ + (instancetype)initializedExecutorWithContextProvider:(RCTJSContextProvider *)JSContextProvider applicationScript:(NSData *)applicationScript sourceURL:(NSURL *)sourceURL JSContext:(JSContext **)JSContext error:(NSError **)error; /** * Invokes the given module/method directly. The completion block will be called with the * JSValue returned by the JS context. * * Currently this does not flush the JS-to-native message queue. */ - (void)callFunctionOnModule:(NSString *)module method:(NSString *)method arguments:(NSArray *)args jsValueCallback:(RCTJavaScriptValueCallback)onComplete; @end