[iOS] Arabic letter Yeh is drawn in LastResort
[WebKit-https.git] / Source / JavaScriptCore / runtime / ReflectObject.cpp
1 /*
2  * Copyright (C) 2015 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 #include "config.h"
27 #include "ReflectObject.h"
28
29 #include "JSCInlines.h"
30 #include "JSGlobalObjectFunctions.h"
31 #include "JSPropertyNameIterator.h"
32 #include "Lookup.h"
33 #include "ObjectConstructor.h"
34
35 namespace JSC {
36
37 static EncodedJSValue JSC_HOST_CALL reflectObjectEnumerate(ExecState*);
38 static EncodedJSValue JSC_HOST_CALL reflectObjectGetPrototypeOf(ExecState*);
39 static EncodedJSValue JSC_HOST_CALL reflectObjectIsExtensible(ExecState*);
40 static EncodedJSValue JSC_HOST_CALL reflectObjectOwnKeys(ExecState*);
41 static EncodedJSValue JSC_HOST_CALL reflectObjectPreventExtensions(ExecState*);
42 static EncodedJSValue JSC_HOST_CALL reflectObjectSetPrototypeOf(ExecState*);
43
44 }
45
46 #include "ReflectObject.lut.h"
47
48 namespace JSC {
49
50 STATIC_ASSERT_IS_TRIVIALLY_DESTRUCTIBLE(ReflectObject);
51
52 const ClassInfo ReflectObject::s_info = { "Reflect", &Base::s_info, &reflectObjectTable, CREATE_METHOD_TABLE(ReflectObject) };
53
54 /* Source for ReflectObject.lut.h
55 @begin reflectObjectTable
56     apply             reflectObjectApply             DontEnum|Function 3
57     deleteProperty    reflectObjectDeleteProperty    DontEnum|Function 2
58     enumerate         reflectObjectEnumerate         DontEnum|Function 1
59     getPrototypeOf    reflectObjectGetPrototypeOf    DontEnum|Function 1
60     isExtensible      reflectObjectIsExtensible      DontEnum|Function 1
61     ownKeys           reflectObjectOwnKeys           DontEnum|Function 1
62     preventExtensions reflectObjectPreventExtensions DontEnum|Function 1
63     setPrototypeOf    reflectObjectSetPrototypeOf    DontEnum|Function 2
64 @end
65 */
66
67 ReflectObject::ReflectObject(VM& vm, Structure* structure)
68     : JSNonFinalObject(vm, structure)
69 {
70 }
71
72 void ReflectObject::finishCreation(VM& vm, JSGlobalObject*)
73 {
74     Base::finishCreation(vm);
75     ASSERT(inherits(info()));
76 }
77
78 bool ReflectObject::getOwnPropertySlot(JSObject* object, ExecState* exec, PropertyName propertyName, PropertySlot &slot)
79 {
80     return getStaticFunctionSlot<Base>(exec, reflectObjectTable, jsCast<ReflectObject*>(object), propertyName, slot);
81 }
82
83 // ------------------------------ Functions --------------------------------
84
85 EncodedJSValue JSC_HOST_CALL reflectObjectEnumerate(ExecState* exec)
86 {
87     JSValue target = exec->argument(0);
88     if (!target.isObject())
89         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.enumerate requires the first argument be an object")));
90     return JSValue::encode(JSPropertyNameIterator::create(exec, exec->lexicalGlobalObject()->propertyNameIteratorStructure(), asObject(target)));
91 }
92
93 EncodedJSValue JSC_HOST_CALL reflectObjectGetPrototypeOf(ExecState* exec)
94 {
95     JSValue target = exec->argument(0);
96     if (!target.isObject())
97         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.getPrototypeOf requires the first argument be an object")));
98     return JSValue::encode(objectConstructorGetPrototypeOf(exec, asObject(target)));
99 }
100
101 EncodedJSValue JSC_HOST_CALL reflectObjectIsExtensible(ExecState* exec)
102 {
103     JSValue target = exec->argument(0);
104     if (!target.isObject())
105         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.isExtensible requires the first argument be an object")));
106     return JSValue::encode(jsBoolean(asObject(target)->isExtensible()));
107 }
108
109 EncodedJSValue JSC_HOST_CALL reflectObjectOwnKeys(ExecState* exec)
110 {
111     JSValue target = exec->argument(0);
112     if (!target.isObject())
113         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.ownKeys requires the first argument be an object")));
114     return JSValue::encode(ownPropertyKeys(exec, jsCast<JSObject*>(target), PropertyNameMode::StringsAndSymbols, DontEnumPropertiesMode::Include));
115 }
116
117 EncodedJSValue JSC_HOST_CALL reflectObjectPreventExtensions(ExecState* exec)
118 {
119     JSValue target = exec->argument(0);
120     if (!target.isObject())
121         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.preventExtensions requires the first argument be an object")));
122     asObject(target)->preventExtensions(exec->vm());
123     return JSValue::encode(jsBoolean(true));
124 }
125
126 EncodedJSValue JSC_HOST_CALL reflectObjectSetPrototypeOf(ExecState* exec)
127 {
128     JSValue target = exec->argument(0);
129     if (!target.isObject())
130         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.setPrototypeOf requires the first argument be an object")));
131     JSValue proto = exec->argument(1);
132     if (!proto.isObject() && !proto.isNull())
133         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.setPrototypeOf requires the second argument be either an object or null")));
134
135     JSObject* object = asObject(target);
136
137     if (!checkProtoSetterAccessAllowed(exec, object))
138         return JSValue::encode(jsBoolean(false));
139
140     if (!object->isExtensible())
141         return JSValue::encode(jsBoolean(false));
142
143     return JSValue::encode(jsBoolean(object->setPrototypeWithCycleCheck(exec, proto)));
144 }
145
146 } // namespace JSC