Skip to content

Commit a9b7686

Browse files
author
Dario Segura
committed
-[JSC] Updated to latest version from WebKit's GIT
-[JSC] Made Objective-C bridge compatible with iOS 5 and 6 -[JSC] Changed some code to not use private frameworks, a bit slower but "legal" -[JSC] Now builds armv7 and armv7s sliced binary.
1 parent a775d4b commit a9b7686

File tree

2,536 files changed

+317519
-136169
lines changed

Some content is hidden

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

2,536 files changed

+317519
-136169
lines changed
Lines changed: 72 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,72 @@
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 <wtf/Vector.h>
33+
34+
namespace JSC {
35+
36+
struct APICallbackFunction {
37+
38+
template <typename T> static EncodedJSValue JSC_HOST_CALL call(ExecState*);
39+
40+
};
41+
42+
template <typename T>
43+
EncodedJSValue JSC_HOST_CALL APICallbackFunction::call(ExecState* exec)
44+
{
45+
JSContextRef execRef = toRef(exec);
46+
JSObjectRef functionRef = toRef(exec->callee());
47+
JSObjectRef thisObjRef = toRef(jsCast<JSObject*>(exec->hostThisValue().toThis(exec, NotStrictMode)));
48+
49+
int argumentCount = static_cast<int>(exec->argumentCount());
50+
Vector<JSValueRef, 16> arguments;
51+
arguments.reserveInitialCapacity(argumentCount);
52+
for (int i = 0; i < argumentCount; i++)
53+
arguments.uncheckedAppend(toRef(exec, exec->argument(i)));
54+
55+
JSValueRef exception = 0;
56+
JSValueRef result;
57+
{
58+
APICallbackShim callbackShim(exec);
59+
result = jsCast<T*>(toJS(functionRef))->m_callback(execRef, functionRef, thisObjRef, argumentCount, arguments.data(), &exception);
60+
}
61+
if (exception)
62+
exec->vm().throwException(exec, toJS(exec, exception));
63+
64+
// result must be a valid JSValue.
65+
if (!result)
66+
return JSValue::encode(jsUndefined());
67+
68+
return JSValue::encode(toJS(exec, result));
69+
}
70+
} // namespace JSC
71+
72+
#endif // APICallbackFunction_h

JavaScriptCore/API/APICast.h

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

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

3433
namespace JSC {
3534
class ExecState;
3635
class PropertyNameArray;
37-
class JSGlobalData;
36+
class VM;
3837
class JSObject;
3938
class JSValue;
4039
}
@@ -63,46 +62,63 @@ inline JSC::ExecState* toJS(JSGlobalContextRef c)
6362
inline JSC::JSValue toJS(JSC::ExecState* exec, JSValueRef v)
6463
{
6564
ASSERT_UNUSED(exec, exec);
66-
ASSERT(v);
6765
#if USE(JSVALUE32_64)
6866
JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
6967
if (!jsCell)
70-
return JSC::JSValue();
68+
return JSC::jsNull();
69+
JSC::JSValue result;
7170
if (jsCell->isAPIValueWrapper())
72-
return JSC::jsCast<JSC::JSAPIValueWrapper*>(jsCell)->value();
73-
return jsCell;
71+
result = JSC::jsCast<JSC::JSAPIValueWrapper*>(jsCell)->value();
72+
else
73+
result = jsCell;
7474
#else
75-
return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
75+
JSC::JSValue result = JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
7676
#endif
77+
if (!result)
78+
return JSC::jsNull();
79+
if (result.isCell())
80+
RELEASE_ASSERT(result.asCell()->methodTable());
81+
return result;
7782
}
7883

7984
inline JSC::JSValue toJSForGC(JSC::ExecState* exec, JSValueRef v)
8085
{
8186
ASSERT_UNUSED(exec, exec);
82-
ASSERT(v);
8387
#if USE(JSVALUE32_64)
8488
JSC::JSCell* jsCell = reinterpret_cast<JSC::JSCell*>(const_cast<OpaqueJSValue*>(v));
8589
if (!jsCell)
8690
return JSC::JSValue();
87-
return jsCell;
91+
JSC::JSValue result = jsCell;
8892
#else
89-
return JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
93+
JSC::JSValue result = JSC::JSValue::decode(reinterpret_cast<JSC::EncodedJSValue>(const_cast<OpaqueJSValue*>(v)));
9094
#endif
95+
if (result && result.isCell())
96+
RELEASE_ASSERT(result.asCell()->methodTable());
97+
return result;
9198
}
9299

93-
inline JSC::JSObject* toJS(JSObjectRef o)
100+
// Used in JSObjectGetPrivate as that may be called during finalization
101+
inline JSC::JSObject* uncheckedToJS(JSObjectRef o)
94102
{
95103
return reinterpret_cast<JSC::JSObject*>(o);
96104
}
97105

106+
inline JSC::JSObject* toJS(JSObjectRef o)
107+
{
108+
JSC::JSObject* object = uncheckedToJS(o);
109+
if (object)
110+
RELEASE_ASSERT(object->methodTable());
111+
return object;
112+
}
113+
98114
inline JSC::PropertyNameArray* toJS(JSPropertyNameAccumulatorRef a)
99115
{
100116
return reinterpret_cast<JSC::PropertyNameArray*>(a);
101117
}
102118

103-
inline JSC::JSGlobalData* toJS(JSContextGroupRef g)
119+
inline JSC::VM* toJS(JSContextGroupRef g)
104120
{
105-
return reinterpret_cast<JSC::JSGlobalData*>(const_cast<OpaqueJSContextGroup*>(g));
121+
return reinterpret_cast<JSC::VM*>(const_cast<OpaqueJSContextGroup*>(g));
106122
}
107123

108124
inline JSValueRef toRef(JSC::ExecState* exec, JSC::JSValue v)
@@ -145,7 +161,7 @@ inline JSPropertyNameAccumulatorRef toRef(JSC::PropertyNameArray* l)
145161
return reinterpret_cast<JSPropertyNameAccumulatorRef>(l);
146162
}
147163

148-
inline JSContextGroupRef toRef(JSC::JSGlobalData* g)
164+
inline JSContextGroupRef toRef(JSC::VM* g)
149165
{
150166
return reinterpret_cast<JSContextGroupRef>(g);
151167
}

JavaScriptCore/API/APIShims.h

100644100755
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)