| /* |
| * Copyright (C) 2006 Apple Computer, 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 COMPUTER, 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 COMPUTER, 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 "JSGlobalObject.h" |
| #include "JSValue.h" |
| #include <wtf/UnusedParam.h> |
| |
| namespace JSC { |
| class ExecState; |
| class PropertyNameArray; |
| class JSGlobalData; |
| 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::ExecState* toJS(JSContextRef c) |
| { |
| ASSERT(c); |
| return reinterpret_cast<JSC::ExecState*>(const_cast<OpaqueJSContext*>(c)); |
| } |
| |
| inline JSC::ExecState* toJS(JSGlobalContextRef c) |
| { |
| ASSERT(c); |
| return reinterpret_cast<JSC::ExecState*>(c); |
| } |
| |
| inline JSC::JSValue toJS(JSC::ExecState* exec, JSValueRef v) |
| { |
| ASSERT_UNUSED(exec, exec); |
| ASSERT(v); |
| #if USE(JSVALUE32_64) |
| JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v)); |
| if (!jsCell) |
| return JSC::JSValue(); |
| if (jsCell->isAPIValueWrapper()) |
| return static_cast<JSC::JSAPIValueWrapper*>(jsCell)->value(); |
| return jsCell; |
| #else |
| return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v))); |
| #endif |
| } |
| |
| inline JSC::JSValue toJSForGC(JSC::ExecState* exec, JSValueRef v) |
| { |
| ASSERT_UNUSED(exec, exec); |
| ASSERT(v); |
| #if USE(JSVALUE32_64) |
| JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v)); |
| if (!jsCell) |
| return JSC::JSValue(); |
| return jsCell; |
| #else |
| return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v))); |
| #endif |
| } |
| |
| inline JSC::JSObject* toJS(JSObjectRef o) |
| { |
| return reinterpret_cast<JSC::JSObject*>(o); |
| } |
| |
| inline JSC::PropertyNameArray* toJS(JSPropertyNameAccumulatorRef a) |
| { |
| return reinterpret_cast<JSC::PropertyNameArray*>(a); |
| } |
| |
| inline JSC::JSGlobalData* toJS(JSContextGroupRef g) |
| { |
| return reinterpret_cast<JSC::JSGlobalData*>(const_cast<OpaqueJSContextGroup*>(g)); |
| } |
| |
| inline JSValueRef toRef(JSC::ExecState* exec, JSC::JSValue v) |
| { |
| #if USE(JSVALUE32_64) |
| if (!v) |
| return 0; |
| if (!v.isCell()) |
| return reinterpret_cast<JSValueRef>(JSC::jsAPIValueWrapper(exec, v).asCell()); |
| return reinterpret_cast<JSValueRef>(v.asCell()); |
| #else |
| UNUSED_PARAM(exec); |
| return reinterpret_cast<JSValueRef>(JSC::JSValue::encode(v)); |
| #endif |
| } |
| |
| inline JSObjectRef toRef(JSC::JSObject* o) |
| { |
| return reinterpret_cast<JSObjectRef>(o); |
| } |
| |
| inline JSObjectRef toRef(const JSC::JSObject* o) |
| { |
| return reinterpret_cast<JSObjectRef>(const_cast<JSC::JSObject*>(o)); |
| } |
| |
| inline JSContextRef toRef(JSC::ExecState* e) |
| { |
| return reinterpret_cast<JSContextRef>(e); |
| } |
| |
| inline JSGlobalContextRef toGlobalRef(JSC::ExecState* e) |
| { |
| ASSERT(e == e->lexicalGlobalObject()->globalExec()); |
| return reinterpret_cast<JSGlobalContextRef>(e); |
| } |
| |
| inline JSPropertyNameAccumulatorRef toRef(JSC::PropertyNameArray* l) |
| { |
| return reinterpret_cast<JSPropertyNameAccumulatorRef>(l); |
| } |
| |
| inline JSContextGroupRef toRef(JSC::JSGlobalData* g) |
| { |
| return reinterpret_cast<JSContextGroupRef>(g); |
| } |
| |
| #endif // APICast_h |