source: webkit/trunk/JavaScriptCore/API/APICast.h@ 49802

Last change on this file since 49802 was 49802, checked in by [email protected], 16 years ago

Added a private API for getting a global context from a context, for
clients who want to preserve a context for a later callback.

Patch by Geoffrey Garen <[email protected]> on 2009-10-19
Reviewed by Sam Weinig.

  • API/APICast.h:

(toGlobalRef): Added an ASSERT, since this function is used more often
than before.

  • API/JSContextRef.cpp:
  • API/JSContextRefPrivate.h: Added. The new API.
  • API/tests/testapi.c:

(print_callAsFunction):
(main): Test the new API.

  • Property svn:eol-style set to native
File size: 4.1 KB
Line 
1/*
2 * Copyright (C) 2006 Apple Computer, 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 COMPUTER, 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 COMPUTER, 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 "JSGlobalObject.h"
31#include "JSValue.h"
32#include <wtf/Platform.h>
33#include <wtf/UnusedParam.h>
34
35namespace JSC {
36 class ExecState;
37 class PropertyNameArray;
38 class JSGlobalData;
39 class JSObject;
40 class JSValue;
41}
42
43typedef const struct OpaqueJSContextGroup* JSContextGroupRef;
44typedef const struct OpaqueJSContext* JSContextRef;
45typedef struct OpaqueJSContext* JSGlobalContextRef;
46typedef struct OpaqueJSPropertyNameAccumulator* JSPropertyNameAccumulatorRef;
47typedef const struct OpaqueJSValue* JSValueRef;
48typedef struct OpaqueJSValue* JSObjectRef;
49
50/* Opaque typing convenience methods */
51
52inline JSC::ExecState* toJS(JSContextRef c)
53{
54 return reinterpret_cast<JSC::ExecState*>(const_cast<OpaqueJSContext*>(c));
55}
56
57inline JSC::ExecState* toJS(JSGlobalContextRef c)
58{
59 return reinterpret_cast<JSC::ExecState*>(c);
60}
61
62inline JSC::JSValue toJS(JSC::ExecState*, JSValueRef v)
63{
64#if USE(JSVALUE32_64)
65 JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
66 if (!jsCell)
67 return JSC::JSValue();
68 if (jsCell->isAPIValueWrapper())
69 return static_cast<JSC::JSAPIValueWrapper*>(jsCell)->value();
70 return jsCell;
71#else
72 return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
73#endif
74}
75
76inline JSC::JSObject* toJS(JSObjectRef o)
77{
78 return reinterpret_cast<JSC::JSObject*>(o);
79}
80
81inline JSC::PropertyNameArray* toJS(JSPropertyNameAccumulatorRef a)
82{
83 return reinterpret_cast<JSC::PropertyNameArray*>(a);
84}
85
86inline JSC::JSGlobalData* toJS(JSContextGroupRef g)
87{
88 return reinterpret_cast<JSC::JSGlobalData*>(const_cast<OpaqueJSContextGroup*>(g));
89}
90
91inline JSValueRef toRef(JSC::ExecState* exec, JSC::JSValue v)
92{
93#if USE(JSVALUE32_64)
94 if (!v)
95 return 0;
96 if (!v.isCell())
97 return reinterpret_cast<JSValueRef>(asCell(JSC::jsAPIValueWrapper(exec, v)));
98 return reinterpret_cast<JSValueRef>(asCell(v));
99#else
100 UNUSED_PARAM(exec);
101 return reinterpret_cast<JSValueRef>(JSC::JSValue::encode(v));
102#endif
103}
104
105inline JSObjectRef toRef(JSC::JSObject* o)
106{
107 return reinterpret_cast<JSObjectRef>(o);
108}
109
110inline JSObjectRef toRef(const JSC::JSObject* o)
111{
112 return reinterpret_cast<JSObjectRef>(const_cast<JSC::JSObject*>(o));
113}
114
115inline JSContextRef toRef(JSC::ExecState* e)
116{
117 return reinterpret_cast<JSContextRef>(e);
118}
119
120inline JSGlobalContextRef toGlobalRef(JSC::ExecState* e)
121{
122 ASSERT(e == e->lexicalGlobalObject()->globalExec());
123 return reinterpret_cast<JSGlobalContextRef>(e);
124}
125
126inline JSPropertyNameAccumulatorRef toRef(JSC::PropertyNameArray* l)
127{
128 return reinterpret_cast<JSPropertyNameAccumulatorRef>(l);
129}
130
131inline JSContextGroupRef toRef(JSC::JSGlobalData* g)
132{
133 return reinterpret_cast<JSContextGroupRef>(g);
134}
135
136#endif // APICast_h
Note: See TracBrowser for help on using the repository browser.