[JSC] Pass VM& parameter as much as possible
[WebKit.git] / Source / JavaScriptCore / API / APICast.h
1 /*
2  * Copyright (C) 2006 Apple Inc.  All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  */
25
26 #ifndef APICast_h
27 #define APICast_h
28
29 #include "JSAPIValueWrapper.h"
30 #include "JSCJSValue.h"
31 #include "JSCJSValueInlines.h"
32 #include "JSGlobalObject.h"
33
34 namespace JSC {
35     class ExecState;
36     class PropertyNameArray;
37     class VM;
38     class JSObject;
39     class JSValue;
40 }
41
42 typedef const struct OpaqueJSContextGroup* JSContextGroupRef;
43 typedef const struct OpaqueJSContext* JSContextRef;
44 typedef struct OpaqueJSContext* JSGlobalContextRef;
45 typedef struct OpaqueJSPropertyNameAccumulator* JSPropertyNameAccumulatorRef;
46 typedef const struct OpaqueJSValue* JSValueRef;
47 typedef struct OpaqueJSValue* JSObjectRef;
48
49 /* Opaque typing convenience methods */
50
51 inline JSC::ExecState* toJS(JSContextRef c)
52 {
53     ASSERT(c);
54     return reinterpret_cast<JSC::ExecState*>(const_cast<OpaqueJSContext*>(c));
55 }
56
57 inline JSC::ExecState* toJS(JSGlobalContextRef c)
58 {
59     ASSERT(c);
60     return reinterpret_cast<JSC::ExecState*>(c);
61 }
62
63 inline JSC::JSGlobalObject* toJSGlobalObject(JSGlobalContextRef context)
64 {
65     return toJS(context)->lexicalGlobalObject();
66 }
67
68 inline JSC::JSValue toJS(JSC::ExecState* exec, JSValueRef v)
69 {
70     ASSERT_UNUSED(exec, exec);
71 #if USE(JSVALUE32_64)
72     JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
73     if (!jsCell)
74         return JSC::jsNull();
75     JSC::JSValue result;
76     if (jsCell->isAPIValueWrapper())
77         result = JSC::jsCast<JSC::JSAPIValueWrapper*>(jsCell)->value();
78     else
79         result = jsCell;
80 #else
81     JSC::JSValue result = JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
82 #endif
83     if (!result)
84         return JSC::jsNull();
85     if (result.isCell())
86         RELEASE_ASSERT(result.asCell()->methodTable(exec->vm()));
87     return result;
88 }
89
90 inline JSC::JSValue toJSForGC(JSC::ExecState* exec, JSValueRef v)
91 {
92     ASSERT_UNUSED(exec, exec);
93 #if USE(JSVALUE32_64)
94     JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
95     if (!jsCell)
96         return JSC::JSValue();
97     JSC::JSValue result = jsCell;
98 #else
99     JSC::JSValue result = JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
100 #endif
101     if (result && result.isCell())
102         RELEASE_ASSERT(result.asCell()->methodTable(exec->vm()));
103     return result;
104 }
105
106 // Used in JSObjectGetPrivate as that may be called during finalization
107 inline JSC::JSObject* uncheckedToJS(JSObjectRef o)
108 {
109     return reinterpret_cast<JSC::JSObject*>(o);
110 }
111
112 inline JSC::JSObject* toJS(JSObjectRef o)
113 {
114     JSC::JSObject* object = uncheckedToJS(o);
115     if (object)
116         RELEASE_ASSERT(object->methodTable());
117     return object;
118 }
119
120 inline JSC::PropertyNameArray* toJS(JSPropertyNameAccumulatorRef a)
121 {
122     return reinterpret_cast<JSC::PropertyNameArray*>(a);
123 }
124
125 inline JSC::VM* toJS(JSContextGroupRef g)
126 {
127     return reinterpret_cast<JSC::VM*>(const_cast<OpaqueJSContextGroup*>(g));
128 }
129
130 inline JSValueRef toRef(JSC::ExecState* exec, JSC::JSValue v)
131 {
132     ASSERT(exec->vm().currentThreadIsHoldingAPILock());
133 #if USE(JSVALUE32_64)
134     if (!v)
135         return 0;
136     if (!v.isCell())
137         return reinterpret_cast<JSValueRef>(JSC::jsAPIValueWrapper(exec, v).asCell());
138     return reinterpret_cast<JSValueRef>(v.asCell());
139 #else
140     UNUSED_PARAM(exec);
141     return reinterpret_cast<JSValueRef>(JSC::JSValue::encode(v));
142 #endif
143 }
144
145 inline JSObjectRef toRef(JSC::JSObject* o)
146 {
147     return reinterpret_cast<JSObjectRef>(o);
148 }
149
150 inline JSObjectRef toRef(const JSC::JSObject* o)
151 {
152     return reinterpret_cast<JSObjectRef>(const_cast<JSC::JSObject*>(o));
153 }
154
155 inline JSContextRef toRef(JSC::ExecState* e)
156 {
157     return reinterpret_cast<JSContextRef>(e);
158 }
159
160 inline JSGlobalContextRef toGlobalRef(JSC::ExecState* e)
161 {
162     ASSERT(e == e->lexicalGlobalObject()->globalExec());
163     return reinterpret_cast<JSGlobalContextRef>(e);
164 }
165
166 inline JSPropertyNameAccumulatorRef toRef(JSC::PropertyNameArray* l)
167 {
168     return reinterpret_cast<JSPropertyNameAccumulatorRef>(l);
169 }
170
171 inline JSContextGroupRef toRef(JSC::VM* g)
172 {
173     return reinterpret_cast<JSContextGroupRef>(g);
174 }
175
176 #endif // APICast_h