* 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.
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "config.h"
#import "APICast.h"
-#import "APIShims.h"
+#import "JSCInlines.h"
#import "JSContextInternal.h"
+#import "JSContextPrivate.h"
+#import "JSContextRefInternal.h"
#import "JSGlobalObject.h"
#import "JSValueInternal.h"
#import "JSVirtualMachineInternal.h"
#import "JSWrapperMap.h"
#import "JavaScriptCore.h"
#import "ObjcRuntimeExtras.h"
-#import "Operations.h"
#import "StrongInlines.h"
#import <wtf/HashSet.h>
return m_context;
}
-- (id)init
+- (instancetype)init
{
return [self initWithVirtualMachine:[[[JSVirtualMachine alloc] init] autorelease]];
}
-- (id)initWithVirtualMachine:(JSVirtualMachine *)virtualMachine
+- (instancetype)initWithVirtualMachine:(JSVirtualMachine *)virtualMachine
{
self = [super init];
if (!self)
- (void)dealloc
{
+ m_exception.clear();
[m_wrapperMap release];
JSGlobalContextRelease(m_context);
[m_virtualMachine release];
- (JSValue *)evaluateScript:(NSString *)script
{
- JSValueRef exceptionValue = 0;
+ return [self evaluateScript:script withSourceURL:nil];
+}
+
+- (JSValue *)evaluateScript:(NSString *)script withSourceURL:(NSURL *)sourceURL
+{
+ JSValueRef exceptionValue = nullptr;
JSStringRef scriptJS = JSStringCreateWithCFString((CFStringRef)script);
- JSValueRef result = JSEvaluateScript(m_context, scriptJS, 0, 0, 0, &exceptionValue);
+ JSStringRef sourceURLJS = sourceURL ? JSStringCreateWithCFString((CFStringRef)[sourceURL absoluteString]) : nullptr;
+ JSValueRef result = JSEvaluateScript(m_context, scriptJS, nullptr, sourceURLJS, 0, &exceptionValue);
+ if (sourceURLJS)
+ JSStringRelease(sourceURLJS);
JSStringRelease(scriptJS);
if (exceptionValue)
- (void)setException:(JSValue *)value
{
+ JSC::JSLockHolder locker(toJS(m_context));
if (value)
m_exception.set(toJS(m_context)->vm(), toJS(JSValueToObject(m_context, valueInternalValue(value), 0)));
else
{
WTFThreadData& threadData = wtfThreadData();
CallbackData *entry = (CallbackData *)threadData.m_apiData;
+ if (!entry)
+ return nil;
+ return [JSValue valueWithJSValueRef:entry->thisValue inContext:[JSContext currentContext]];
+}
- if (!entry->currentThis)
- entry->currentThis = [[JSValue alloc] initWithValue:entry->thisValue inContext:[JSContext currentContext]];
-
- return entry->currentThis;
++ (JSValue *)currentCallee
+{
+ WTFThreadData& threadData = wtfThreadData();
+ CallbackData *entry = (CallbackData *)threadData.m_apiData;
+ if (!entry)
+ return nil;
+ return [JSValue valueWithJSValueRef:entry->calleeValue inContext:[JSContext currentContext]];
}
+ (NSArray *)currentArguments
WTFThreadData& threadData = wtfThreadData();
CallbackData *entry = (CallbackData *)threadData.m_apiData;
+ if (!entry)
+ return nil;
+
if (!entry->currentArguments) {
JSContext *context = [JSContext currentContext];
size_t count = entry->argumentCount;
return m_virtualMachine;
}
+- (NSString *)name
+{
+ JSStringRef name = JSGlobalContextCopyName(m_context);
+ if (!name)
+ return nil;
+
+ return (NSString *)adoptCF(JSStringCopyCFString(kCFAllocatorDefault, name)).autorelease();
+}
+
+- (void)setName:(NSString *)name
+{
+ JSStringRef nameJS = name ? JSStringCreateWithCFString((CFStringRef)[[name copy] autorelease]) : nullptr;
+ JSGlobalContextSetName(m_context, nameJS);
+ if (nameJS)
+ JSStringRelease(nameJS);
+}
+
+- (BOOL)_remoteInspectionEnabled
+{
+ return JSGlobalContextGetRemoteInspectionEnabled(m_context);
+}
+
+- (void)_setRemoteInspectionEnabled:(BOOL)enabled
+{
+ JSGlobalContextSetRemoteInspectionEnabled(m_context, enabled);
+}
+
+- (BOOL)_includesNativeCallStackWhenReportingExceptions
+{
+ return JSGlobalContextGetIncludesNativeCallStackWhenReportingExceptions(m_context);
+}
+
+- (void)_setIncludesNativeCallStackWhenReportingExceptions:(BOOL)includeNativeCallStack
+{
+ JSGlobalContextSetIncludesNativeCallStackWhenReportingExceptions(m_context, includeNativeCallStack);
+}
+
+- (CFRunLoopRef)_debuggerRunLoop
+{
+ return JSGlobalContextGetDebuggerRunLoop(m_context);
+}
+
+- (void)_setDebuggerRunLoop:(CFRunLoopRef)runLoop
+{
+ JSGlobalContextSetDebuggerRunLoop(m_context, runLoop);
+}
+
@end
@implementation JSContext(SubscriptSupport)
@end
-@implementation JSContext(Internal)
+@implementation JSContext (Internal)
-- (id)initWithGlobalContextRef:(JSGlobalContextRef)context
+- (instancetype)initWithGlobalContextRef:(JSGlobalContextRef)context
{
self = [super init];
if (!self)
return NO;
}
-- (void)beginCallbackWithData:(CallbackData *)callbackData thisValue:(JSValueRef)thisValue argumentCount:(size_t)argumentCount arguments:(const JSValueRef *)arguments
+- (void)beginCallbackWithData:(CallbackData *)callbackData calleeValue:(JSValueRef)calleeValue thisValue:(JSValueRef)thisValue argumentCount:(size_t)argumentCount arguments:(const JSValueRef *)arguments
{
WTFThreadData& threadData = wtfThreadData();
[self retain];
CallbackData *prevStack = (CallbackData *)threadData.m_apiData;
- *callbackData = (CallbackData){ prevStack, self, [self.exception retain], thisValue, nil, argumentCount, arguments, nil };
+ *callbackData = (CallbackData){ prevStack, self, [self.exception retain], calleeValue, thisValue, argumentCount, arguments, nil };
threadData.m_apiData = callbackData;
self.exception = nil;
}
WTFThreadData& threadData = wtfThreadData();
self.exception = callbackData->preservedException;
[callbackData->preservedException release];
- [callbackData->currentThis release];
[callbackData->currentArguments release];
threadData.m_apiData = callbackData->next;
[self release];
- (JSValue *)wrapperForObjCObject:(id)object
{
- // Lock access to m_wrapperMap
- JSC::JSLockHolder lock(toJS(m_context));
+ JSC::JSLockHolder locker(toJS(m_context));
return [m_wrapperMap jsWrapperForObject:object];
}
- (JSValue *)wrapperForJSObject:(JSValueRef)value
{
- JSC::JSLockHolder lock(toJS(m_context));
+ JSC::JSLockHolder locker(toJS(m_context));
return [m_wrapperMap objcWrapperForJSValueRef:value];
}