Skip to content

Commit 3895c67

Browse files
committed
Webkit SVN Tag 538.4
1 parent a775d4b commit 3895c67

File tree

1,828 files changed

+429888
-177441
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

1,828 files changed

+429888
-177441
lines changed
Lines changed: 109 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,109 @@
1+
/*
2+
* Copyright (C) 2013 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 APICallbackFunction_h
27+
#define APICallbackFunction_h
28+
29+
#include "APICast.h"
30+
#include "APIShims.h"
31+
#include "Error.h"
32+
#include "JSCallbackConstructor.h"
33+
#include <wtf/Vector.h>
34+
35+
namespace JSC {
36+
37+
struct APICallbackFunction {
38+
39+
template <typename T> static EncodedJSValue JSC_HOST_CALL call(ExecState*);
40+
template <typename T> static EncodedJSValue JSC_HOST_CALL construct(ExecState*);
41+
42+
};
43+
44+
template <typename T>
45+
EncodedJSValue JSC_HOST_CALL APICallbackFunction::call(ExecState* exec)
46+
{
47+
JSContextRef execRef = toRef(exec);
48+
JSObjectRef functionRef = toRef(exec->callee());
49+
JSObjectRef thisObjRef = toRef(jsCast<JSObject*>(exec->hostThisValue().toThis(exec, NotStrictMode)));
50+
51+
int argumentCount = static_cast<int>(exec->argumentCount());
52+
Vector<JSValueRef, 16> arguments;
53+
arguments.reserveInitialCapacity(argumentCount);
54+
for (int i = 0; i < argumentCount; i++)
55+
arguments.uncheckedAppend(toRef(exec, exec->uncheckedArgument(i)));
56+
57+
JSValueRef exception = 0;
58+
JSValueRef result;
59+
{
60+
APICallbackShim callbackShim(exec);
61+
result = jsCast<T*>(toJS(functionRef))->functionCallback()(execRef, functionRef, thisObjRef, argumentCount, arguments.data(), &exception);
62+
}
63+
if (exception)
64+
exec->vm().throwException(exec, toJS(exec, exception));
65+
66+
// result must be a valid JSValue.
67+
if (!result)
68+
return JSValue::encode(jsUndefined());
69+
70+
return JSValue::encode(toJS(exec, result));
71+
}
72+
73+
template <typename T>
74+
EncodedJSValue JSC_HOST_CALL APICallbackFunction::construct(ExecState* exec)
75+
{
76+
JSObject* constructor = exec->callee();
77+
JSContextRef ctx = toRef(exec);
78+
JSObjectRef constructorRef = toRef(constructor);
79+
80+
JSObjectCallAsConstructorCallback callback = jsCast<T*>(constructor)->constructCallback();
81+
if (callback) {
82+
size_t argumentCount = exec->argumentCount();
83+
Vector<JSValueRef, 16> arguments;
84+
arguments.reserveInitialCapacity(argumentCount);
85+
for (size_t i = 0; i < argumentCount; ++i)
86+
arguments.uncheckedAppend(toRef(exec, exec->uncheckedArgument(i)));
87+
88+
JSValueRef exception = 0;
89+
JSObjectRef result;
90+
{
91+
APICallbackShim callbackShim(exec);
92+
result = callback(ctx, constructorRef, argumentCount, arguments.data(), &exception);
93+
}
94+
if (exception) {
95+
exec->vm().throwException(exec, toJS(exec, exception));
96+
return JSValue::encode(toJS(exec, exception));
97+
}
98+
// result must be a valid JSValue.
99+
if (!result)
100+
return throwVMTypeError(exec);
101+
return JSValue::encode(toJS(result));
102+
}
103+
104+
return JSValue::encode(toJS(JSObjectMake(ctx, jsCast<JSCallbackConstructor*>(constructor)->classRef(), 0)));
105+
}
106+
107+
} // namespace JSC
108+
109+
#endif // APICallbackFunction_h

JavaScriptCore/API/APICast.h

Lines changed: 32 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -27,14 +27,14 @@
2727
#define APICast_h
2828

2929
#include "JSAPIValueWrapper.h"
30+
#include "JSCJSValue.h"
31+
#include "JSCJSValueInlines.h"
3032
#include "JSGlobalObject.h"
31-
#include "JSValue.h"
32-
#include <wtf/UnusedParam.h>
3333

3434
namespace JSC {
3535
class ExecState;
3636
class PropertyNameArray;
37-
class JSGlobalData;
37+
class VM;
3838
class JSObject;
3939
class JSValue;
4040
}
@@ -63,46 +63,63 @@ inline JSC::ExecState* toJS(JSGlobalContextRef c)
6363
inline JSC::JSValue toJS(JSC::ExecState* exec, JSValueRef v)
6464
{
6565
ASSERT_UNUSED(exec, exec);
66-
ASSERT(v);
6766
#if USE(JSVALUE32_64)
6867
JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
6968
if (!jsCell)
70-
return JSC::JSValue();
69+
return JSC::jsNull();
70+
JSC::JSValue result;
7171
if (jsCell->isAPIValueWrapper())
72-
return JSC::jsCast<JSC::JSAPIValueWrapper*>(jsCell)->value();
73-
return jsCell;
72+
result = JSC::jsCast<JSC::JSAPIValueWrapper*>(jsCell)->value();
73+
else
74+
result = jsCell;
7475
#else
75-
return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
76+
JSC::JSValue result = JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
7677
#endif
78+
if (!result)
79+
return JSC::jsNull();
80+
if (result.isCell())
81+
RELEASE_ASSERT(result.asCell()->methodTable());
82+
return result;
7783
}
7884

7985
inline JSC::JSValue toJSForGC(JSC::ExecState* exec, JSValueRef v)
8086
{
8187
ASSERT_UNUSED(exec, exec);
82-
ASSERT(v);
8388
#if USE(JSVALUE32_64)
8489
JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
8590
if (!jsCell)
8691
return JSC::JSValue();
87-
return jsCell;
92+
JSC::JSValue result = jsCell;
8893
#else
89-
return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
94+
JSC::JSValue result = JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
9095
#endif
96+
if (result && result.isCell())
97+
RELEASE_ASSERT(result.asCell()->methodTable());
98+
return result;
9199
}
92100

93-
inline JSC::JSObject* toJS(JSObjectRef o)
101+
// Used in JSObjectGetPrivate as that may be called during finalization
102+
inline JSC::JSObject* uncheckedToJS(JSObjectRef o)
94103
{
95104
return reinterpret_cast<JSC::JSObject*>(o);
96105
}
97106

107+
inline JSC::JSObject* toJS(JSObjectRef o)
108+
{
109+
JSC::JSObject* object = uncheckedToJS(o);
110+
if (object)
111+
RELEASE_ASSERT(object->methodTable());
112+
return object;
113+
}
114+
98115
inline JSC::PropertyNameArray* toJS(JSPropertyNameAccumulatorRef a)
99116
{
100117
return reinterpret_cast<JSC::PropertyNameArray*>(a);
101118
}
102119

103-
inline JSC::JSGlobalData* toJS(JSContextGroupRef g)
120+
inline JSC::VM* toJS(JSContextGroupRef g)
104121
{
105-
return reinterpret_cast<JSC::JSGlobalData*>(const_cast<OpaqueJSContextGroup*>(g));
122+
return reinterpret_cast<JSC::VM*>(const_cast<OpaqueJSContextGroup*>(g));
106123
}
107124

108125
inline JSValueRef toRef(JSC::ExecState* exec, JSC::JSValue v)
@@ -145,7 +162,7 @@ inline JSPropertyNameAccumulatorRef toRef(JSC::PropertyNameArray* l)
145162
return reinterpret_cast<JSPropertyNameAccumulatorRef>(l);
146163
}
147164

148-
inline JSContextGroupRef toRef(JSC::JSGlobalData* g)
165+
inline JSContextGroupRef toRef(JSC::VM* g)
149166
{
150167
return reinterpret_cast<JSContextGroupRef>(g);
151168
}

JavaScriptCore/API/APIShims.h

Lines changed: 19 additions & 41 deletions
Original file line numberDiff line numberDiff line change
@@ -28,97 +28,75 @@
2828

2929
#include "CallFrame.h"
3030
#include "GCActivityCallback.h"
31+
#include "IncrementalSweeper.h"
3132
#include "JSLock.h"
3233
#include <wtf/WTFThreadData.h>
3334

3435
namespace JSC {
3536

3637
class APIEntryShimWithoutLock {
37-
public:
38-
enum RefGlobalDataTag { DontRefGlobalData = 0, RefGlobalData };
39-
4038
protected:
41-
APIEntryShimWithoutLock(JSGlobalData* globalData, bool registerThread, RefGlobalDataTag shouldRefGlobalData)
42-
: m_shouldRefGlobalData(shouldRefGlobalData)
43-
, m_globalData(globalData)
44-
, m_entryIdentifierTable(wtfThreadData().setCurrentIdentifierTable(globalData->identifierTable))
39+
APIEntryShimWithoutLock(VM* vm, bool registerThread)
40+
: m_vm(vm)
41+
, m_entryIdentifierTable(wtfThreadData().setCurrentIdentifierTable(vm->identifierTable))
4542
{
46-
if (shouldRefGlobalData)
47-
m_globalData->ref();
48-
UNUSED_PARAM(registerThread);
4943
if (registerThread)
50-
globalData->heap.machineThreads().addCurrentThread();
51-
m_globalData->heap.activityCallback()->synchronize();
44+
vm->heap.machineThreads().addCurrentThread();
5245
}
5346

5447
~APIEntryShimWithoutLock()
5548
{
5649
wtfThreadData().setCurrentIdentifierTable(m_entryIdentifierTable);
57-
if (m_shouldRefGlobalData)
58-
m_globalData->deref();
5950
}
6051

6152
protected:
62-
RefGlobalDataTag m_shouldRefGlobalData;
63-
JSGlobalData* m_globalData;
53+
RefPtr<VM> m_vm;
6454
IdentifierTable* m_entryIdentifierTable;
6555
};
6656

6757
class APIEntryShim : public APIEntryShimWithoutLock {
6858
public:
6959
// Normal API entry
7060
APIEntryShim(ExecState* exec, bool registerThread = true)
71-
: APIEntryShimWithoutLock(&exec->globalData(), registerThread, RefGlobalData)
61+
: APIEntryShimWithoutLock(&exec->vm(), registerThread)
62+
, m_lockHolder(exec->vm().exclusiveThread ? 0 : exec)
7263
{
73-
init();
7464
}
7565

76-
// This constructor is necessary for HeapTimer to prevent it from accidentally resurrecting
77-
// the ref count of a "dead" JSGlobalData.
78-
APIEntryShim(JSGlobalData* globalData, RefGlobalDataTag refGlobalData, bool registerThread = true)
79-
: APIEntryShimWithoutLock(globalData, registerThread, refGlobalData)
66+
// JSPropertyNameAccumulator only has a vm.
67+
APIEntryShim(VM* vm, bool registerThread = true)
68+
: APIEntryShimWithoutLock(vm, registerThread)
69+
, m_lockHolder(vm->exclusiveThread ? 0 : vm)
8070
{
81-
init();
82-
}
83-
84-
// JSPropertyNameAccumulator only has a globalData.
85-
APIEntryShim(JSGlobalData* globalData, bool registerThread = true)
86-
: APIEntryShimWithoutLock(globalData, registerThread, RefGlobalData)
87-
{
88-
init();
8971
}
9072

9173
~APIEntryShim()
9274
{
93-
m_globalData->timeoutChecker.stop();
94-
m_globalData->apiLock().unlock();
75+
// Destroying our JSLockHolder should also destroy the VM.
76+
m_vm.clear();
9577
}
9678

9779
private:
98-
void init()
99-
{
100-
m_globalData->apiLock().lock();
101-
m_globalData->timeoutChecker.start();
102-
}
80+
JSLockHolder m_lockHolder;
10381
};
10482

10583
class APICallbackShim {
10684
public:
10785
APICallbackShim(ExecState* exec)
108-
: m_dropAllLocks(exec)
109-
, m_globalData(&exec->globalData())
86+
: m_dropAllLocks(exec->vm().exclusiveThread ? 0 : exec)
87+
, m_vm(&exec->vm())
11088
{
11189
wtfThreadData().resetCurrentIdentifierTable();
11290
}
11391

11492
~APICallbackShim()
11593
{
116-
wtfThreadData().setCurrentIdentifierTable(m_globalData->identifierTable);
94+
wtfThreadData().setCurrentIdentifierTable(m_vm->identifierTable);
11795
}
11896

11997
private:
12098
JSLock::DropAllLocks m_dropAllLocks;
121-
JSGlobalData* m_globalData;
99+
VM* m_vm;
122100
};
123101

124102
}
Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
/*
2+
* Copyright (C) 2013 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. AND ITS CONTRIBUTORS ``AS IS''
14+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15+
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16+
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17+
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23+
* THE POSSIBILITY OF SUCH DAMAGE.
24+
*/
25+
26+
#ifndef JSAPIWrapperObject_h
27+
#define JSAPIWrapperObject_h
28+
29+
#include "JSBase.h"
30+
#include "JSDestructibleObject.h"
31+
#include "WeakReferenceHarvester.h"
32+
33+
#if JSC_OBJC_API_ENABLED
34+
35+
namespace JSC {
36+
37+
class JSAPIWrapperObject : public JSDestructibleObject {
38+
public:
39+
typedef JSDestructibleObject Base;
40+
41+
void finishCreation(VM&);
42+
static void visitChildren(JSCell*, JSC::SlotVisitor&);
43+
44+
void* wrappedObject() { return m_wrappedObject; }
45+
void setWrappedObject(void*);
46+
47+
protected:
48+
static const unsigned StructureFlags = OverridesVisitChildren | Base::StructureFlags;
49+
50+
JSAPIWrapperObject(VM&, Structure*);
51+
52+
private:
53+
void* m_wrappedObject;
54+
};
55+
56+
} // namespace JSC
57+
58+
#endif // JSC_OBJC_API_ENABLED
59+
60+
#endif // JSAPIWrapperObject_h

0 commit comments

Comments
 (0)