e0369becb06f3b982cfd90a5db2039e633bd4125
[WebKit-https.git] / Source / JavaScriptCore / runtime / JSGlobalObjectInlines.h
1 /*
2  * Copyright (C) 2016 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 #pragma once
27
28 #include "JSGlobalObject.h"
29
30 #include "ArrayConstructor.h"
31 #include "ArrayPrototype.h"
32 #include "ObjectPrototype.h"
33
34 namespace JSC {
35
36 ALWAYS_INLINE bool JSGlobalObject::objectPrototypeIsSane()
37 {
38     return !hasIndexedProperties(m_objectPrototype->indexingType())
39         && m_objectPrototype->getPrototypeDirect(vm()).isNull();
40 }
41
42 ALWAYS_INLINE bool JSGlobalObject::arrayPrototypeChainIsSane()
43 {
44     return !hasIndexedProperties(m_arrayPrototype->indexingType())
45         && m_arrayPrototype->getPrototypeDirect(vm()) == m_objectPrototype.get()
46         && objectPrototypeIsSane();
47 }
48
49 ALWAYS_INLINE bool JSGlobalObject::stringPrototypeChainIsSane()
50 {
51     return !hasIndexedProperties(m_stringPrototype->indexingType())
52         && m_stringPrototype->getPrototypeDirect(vm()) == m_objectPrototype.get()
53         && objectPrototypeIsSane();
54 }
55
56 ALWAYS_INLINE bool JSGlobalObject::isArrayPrototypeIteratorProtocolFastAndNonObservable()
57 {
58     // We're fast if we don't have any indexed properties on the prototype.
59     // We're non-observable if the iteration protocol hasn't changed.
60     //
61     // Note: it only makes sense to call this from the main thread. If you're
62     // trying to prove this behavior on the compiler thread, you'll want to
63     // carefully set up watchpoints to have correct ordering while JS code is
64     // executing concurrently.
65
66     return arrayIteratorProtocolWatchpointSet().isStillValid() && !isHavingABadTime() && arrayPrototypeChainIsSane();
67 }
68
69 // We're non-observable if the iteration protocol hasn't changed.
70 //
71 // Note: it only makes sense to call this from the main thread. If you're
72 // trying to prove this behavior on the compiler thread, you'll want to
73 // carefully set up watchpoints to have correct ordering while JS code is
74 // executing concurrently.
75 ALWAYS_INLINE bool JSGlobalObject::isMapPrototypeIteratorProtocolFastAndNonObservable()
76 {
77     return mapIteratorProtocolWatchpointSet().isStillValid();
78 }
79
80 ALWAYS_INLINE bool JSGlobalObject::isSetPrototypeIteratorProtocolFastAndNonObservable()
81 {
82     return setIteratorProtocolWatchpointSet().isStillValid();
83 }
84
85 ALWAYS_INLINE bool JSGlobalObject::isStringPrototypeIteratorProtocolFastAndNonObservable()
86 {
87     return stringIteratorProtocolWatchpointSet().isStillValid();
88 }
89
90 ALWAYS_INLINE bool JSGlobalObject::isMapPrototypeSetFastAndNonObservable()
91 {
92     return mapSetWatchpointSet().isStillValid();
93 }
94
95 ALWAYS_INLINE bool JSGlobalObject::isSetPrototypeAddFastAndNonObservable()
96 {
97     return setAddWatchpointSet().isStillValid();
98 }
99
100 ALWAYS_INLINE Structure* JSGlobalObject::arrayStructureForIndexingTypeDuringAllocation(JSGlobalObject* globalObject, IndexingType indexingType, JSValue newTarget) const
101 {
102     return InternalFunction::createSubclassStructure(globalObject, globalObject->arrayConstructor(), newTarget, arrayStructureForIndexingTypeDuringAllocation(indexingType));
103 }
104
105 ALWAYS_INLINE VM& getVM(JSGlobalObject* globalObject)
106 {
107     return globalObject->vm();
108 }
109
110 } // namespace JSC