| /* |
| * Copyright (C) 2013-2019 Apple Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY |
| * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR |
| * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef JSContext_h |
| #define JSContext_h |
| |
| #include <JavaScriptCore/JavaScript.h> |
| #include <JavaScriptCore/WebKitAvailability.h> |
| |
| #if JSC_OBJC_API_ENABLED |
| |
| @class JSScript, JSVirtualMachine, JSValue, JSContext; |
| |
| /*! |
| @interface |
| @discussion A JSContext is a JavaScript execution environment. All |
| JavaScript execution takes place within a context, and all JavaScript values |
| are tied to a context. |
| */ |
| JSC_CLASS_AVAILABLE(macos(10.9), ios(7.0)) |
| @interface JSContext : NSObject |
| |
| /*! |
| @methodgroup Creating New JSContexts |
| */ |
| /*! |
| @method |
| @abstract Create a JSContext. |
| @result The new context. |
| */ |
| - (instancetype)init; |
| |
| /*! |
| @method |
| @abstract Create a JSContext in the specified virtual machine. |
| @param virtualMachine The JSVirtualMachine in which the context will be created. |
| @result The new context. |
| */ |
| - (instancetype)initWithVirtualMachine:(JSVirtualMachine *)virtualMachine; |
| |
| /*! |
| @methodgroup Evaluating Scripts |
| */ |
| /*! |
| @method |
| @abstract Evaluate a string of JavaScript code. |
| @param script A string containing the JavaScript code to evaluate. |
| @result The last value generated by the script. |
| */ |
| - (JSValue *)evaluateScript:(NSString *)script; |
| |
| /*! |
| @method |
| @abstract Evaluate a string of JavaScript code, with a URL for the script's source file. |
| @param script A string containing the JavaScript code to evaluate. |
| @param sourceURL A URL for the script's source file. Used by debuggers and when reporting exceptions. This parameter is informative only: it does not change the behavior of the script. |
| @result The last value generated by the script. |
| */ |
| - (JSValue *)evaluateScript:(NSString *)script withSourceURL:(NSURL *)sourceURL JSC_API_AVAILABLE(macos(10.10), ios(8.0)); |
| |
| /*! |
| @methodgroup Callback Accessors |
| */ |
| /*! |
| @method |
| @abstract Get the JSContext that is currently executing. |
| @discussion This method may be called from within an Objective-C block or method invoked |
| as a callback from JavaScript to retrieve the callback's context. Outside of |
| a callback from JavaScript this method will return nil. |
| @result The currently executing JSContext or nil if there isn't one. |
| */ |
| + (JSContext *)currentContext; |
| |
| /*! |
| @method |
| @abstract Get the JavaScript function that is currently executing. |
| @discussion This method may be called from within an Objective-C block or method invoked |
| as a callback from JavaScript to retrieve the callback's context. Outside of |
| a callback from JavaScript this method will return nil. |
| @result The currently executing JavaScript function or nil if there isn't one. |
| */ |
| + (JSValue *)currentCallee JSC_API_AVAILABLE(macos(10.10), ios(8.0)); |
| |
| /*! |
| @method |
| @abstract Get the <code>this</code> value of the currently executing method. |
| @discussion This method may be called from within an Objective-C block or method invoked |
| as a callback from JavaScript to retrieve the callback's this value. Outside |
| of a callback from JavaScript this method will return nil. |
| @result The current <code>this</code> value or nil if there isn't one. |
| */ |
| + (JSValue *)currentThis; |
| |
| /*! |
| @method |
| @abstract Get the arguments to the current callback. |
| @discussion This method may be called from within an Objective-C block or method invoked |
| as a callback from JavaScript to retrieve the callback's arguments, objects |
| in the returned array are instances of JSValue. Outside of a callback from |
| JavaScript this method will return nil. |
| @result An NSArray of the arguments nil if there is no current callback. |
| */ |
| + (NSArray *)currentArguments; |
| |
| /*! |
| @functiongroup Global Properties |
| */ |
| |
| /*! |
| @property |
| @abstract Get the global object of the context. |
| @discussion This method retrieves the global object of the JavaScript execution context. |
| Instances of JSContext originating from WebKit will return a reference to the |
| WindowProxy object. |
| @result The global object. |
| */ |
| @property (readonly, strong) JSValue *globalObject; |
| |
| /*! |
| @property |
| @discussion The <code>exception</code> property may be used to throw an exception to JavaScript. |
| |
| Before a callback is made from JavaScript to an Objective-C block or method, |
| the prior value of the exception property will be preserved and the property |
| will be set to nil. After the callback has completed the new value of the |
| exception property will be read, and prior value restored. If the new value |
| of exception is not nil, the callback will result in that value being thrown. |
| |
| This property may also be used to check for uncaught exceptions arising from |
| API function calls (since the default behaviour of <code>exceptionHandler</code> is to |
| assign an uncaught exception to this property). |
| */ |
| @property (strong) JSValue *exception; |
| |
| /*! |
| @property |
| @discussion If a call to an API function results in an uncaught JavaScript exception, the |
| <code>exceptionHandler</code> block will be invoked. The default implementation for the |
| exception handler will store the exception to the exception property on |
| context. As a consequence the default behaviour is for uncaught exceptions |
| occurring within a callback from JavaScript to be rethrown upon return. |
| Setting this value to nil will cause all exceptions occurring |
| within a callback from JavaScript to be silently caught. |
| */ |
| @property (copy) void(^exceptionHandler)(JSContext *context, JSValue *exception); |
| |
| /*! |
| @property |
| @discussion All instances of JSContext are associated with a JSVirtualMachine. |
| */ |
| @property (readonly, strong) JSVirtualMachine *virtualMachine; |
| |
| /*! |
| @property |
| @discussion Name of the JSContext. Exposed when remote debugging the context. |
| */ |
| @property (copy) NSString *name JSC_API_AVAILABLE(macos(10.10), ios(8.0)); |
| @end |
| |
| /*! |
| @category |
| @discussion Instances of JSContext implement the following methods in order to enable |
| support for subscript access by key and index, for example: |
| |
| @textblock |
| JSContext *context; |
| JSValue *v = context[@"X"]; // Get value for "X" from the global object. |
| context[@"Y"] = v; // Assign 'v' to "Y" on the global object. |
| @/textblock |
| |
| An object key passed as a subscript will be converted to a JavaScript value, |
| and then the value converted to a string used to resolve a property of the |
| global object. |
| */ |
| @interface JSContext (SubscriptSupport) |
| |
| /*! |
| @method |
| @abstract Get a particular property on the global object. |
| @result The JSValue for the global object's property. |
| */ |
| - (JSValue *)objectForKeyedSubscript:(id)key; |
| |
| /*! |
| @method |
| @abstract Set a particular property on the global object. |
| */ |
| - (void)setObject:(id)object forKeyedSubscript:(NSObject <NSCopying> *)key; |
| |
| @end |
| |
| /*! |
| @category |
| @discussion These functions are for bridging between the C API and the Objective-C API. |
| */ |
| @interface JSContext (JSContextRefSupport) |
| |
| /*! |
| @method |
| @abstract Create a JSContext, wrapping its C API counterpart. |
| @result The JSContext equivalent of the provided JSGlobalContextRef. |
| */ |
| + (JSContext *)contextWithJSGlobalContextRef:(JSGlobalContextRef)jsGlobalContextRef; |
| |
| /*! |
| @property |
| @abstract Get the C API counterpart wrapped by a JSContext. |
| @result The C API equivalent of this JSContext. |
| */ |
| @property (readonly) JSGlobalContextRef JSGlobalContextRef; |
| |
| @end |
| |
| #endif |
| |
| #endif // JSContext_h |