/* * Copyright (C) 2006-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 APICast_h #define APICast_h #include "JSAPIValueWrapper.h" #include "JSCJSValue.h" #include "JSCJSValueInlines.h" #include "JSGlobalObject.h" #include "HeapCellInlines.h" namespace JSC { class CallFrame; class PropertyNameArray; class VM; class JSObject; class JSValue; } typedef const struct OpaqueJSContextGroup* JSContextGroupRef; typedef const struct OpaqueJSContext* JSContextRef; typedef struct OpaqueJSContext* JSGlobalContextRef; typedef struct OpaqueJSPropertyNameAccumulator* JSPropertyNameAccumulatorRef; typedef const struct OpaqueJSValue* JSValueRef; typedef struct OpaqueJSValue* JSObjectRef; /* Opaque typing convenience methods */ inline JSC::JSGlobalObject* toJS(JSContextRef context) { ASSERT(context); return reinterpret_cast(const_cast(context)); } inline JSC::JSGlobalObject* toJS(JSGlobalContextRef context) { ASSERT(context); return reinterpret_cast(context); } inline JSC::JSGlobalObject* toJSGlobalObject(JSGlobalContextRef context) { return toJS(context); } inline JSC::JSValue toJS(JSC::JSGlobalObject* globalObject, JSValueRef v) { ASSERT_UNUSED(globalObject, globalObject); #if !CPU(ADDRESS64) JSC::JSCell* jsCell = reinterpret_cast(const_cast(v)); if (!jsCell) return JSC::jsNull(); JSC::JSValue result; if (jsCell->isAPIValueWrapper()) result = JSC::jsCast(jsCell)->value(); else result = jsCell; #else JSC::JSValue result = bitwise_cast(v); #endif if (!result) return JSC::jsNull(); if (result.isCell()) RELEASE_ASSERT(result.asCell()->methodTable(getVM(globalObject))); return result; } #if CPU(ADDRESS64) inline JSC::JSValue toJS(JSValueRef value) { return bitwise_cast(value); } #endif inline JSC::JSValue toJSForGC(JSC::JSGlobalObject* globalObject, JSValueRef v) { ASSERT_UNUSED(globalObject, globalObject); #if !CPU(ADDRESS64) JSC::JSCell* jsCell = reinterpret_cast(const_cast(v)); if (!jsCell) return JSC::JSValue(); JSC::JSValue result = jsCell; #else JSC::JSValue result = bitwise_cast(v); #endif if (result && result.isCell()) RELEASE_ASSERT(result.asCell()->methodTable(getVM(globalObject))); return result; } // Used in JSObjectGetPrivate as that may be called during finalization inline JSC::JSObject* uncheckedToJS(JSObjectRef o) { return reinterpret_cast(o); } inline JSC::JSObject* toJS(JSObjectRef o) { JSC::JSObject* object = uncheckedToJS(o); if (object) RELEASE_ASSERT(object->methodTable(object->vm())); return object; } inline JSC::PropertyNameArray* toJS(JSPropertyNameAccumulatorRef a) { return reinterpret_cast(a); } inline JSC::VM* toJS(JSContextGroupRef g) { return reinterpret_cast(const_cast(g)); } inline JSValueRef toRef(JSC::VM& vm, JSC::JSValue v) { ASSERT(vm.currentThreadIsHoldingAPILock()); #if !CPU(ADDRESS64) if (!v) return 0; if (!v.isCell()) return reinterpret_cast(JSC::JSAPIValueWrapper::create(vm, v)); return reinterpret_cast(v.asCell()); #else UNUSED_PARAM(vm); return bitwise_cast(v); #endif } inline JSValueRef toRef(JSC::JSGlobalObject* globalObject, JSC::JSValue v) { return toRef(getVM(globalObject), v); } #if CPU(ADDRESS64) inline JSValueRef toRef(JSC::JSValue v) { return bitwise_cast(v); } #endif inline JSObjectRef toRef(JSC::JSObject* o) { return reinterpret_cast(o); } inline JSObjectRef toRef(const JSC::JSObject* o) { return reinterpret_cast(const_cast(o)); } inline JSContextRef toRef(JSC::JSGlobalObject* globalObject) { return reinterpret_cast(globalObject); } inline JSGlobalContextRef toGlobalRef(JSC::JSGlobalObject* globalObject) { return reinterpret_cast(globalObject); } inline JSPropertyNameAccumulatorRef toRef(JSC::PropertyNameArray* l) { return reinterpret_cast(l); } inline JSContextGroupRef toRef(JSC::VM* g) { return reinterpret_cast(g); } #endif // APICast_h