[ES6] Implement Reflect.enumerate
[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 "JSPropertyNameIterator.h"
31 #include "Lookup.h"
32 #include "ObjectConstructor.h"
33
34 namespace JSC {
35
36 static EncodedJSValue JSC_HOST_CALL reflectObjectEnumerate(ExecState*);
37 static EncodedJSValue JSC_HOST_CALL reflectObjectIsExtensible(ExecState*);
38 static EncodedJSValue JSC_HOST_CALL reflectObjectOwnKeys(ExecState*);
39 static EncodedJSValue JSC_HOST_CALL reflectObjectPreventExtensions(ExecState*);
40
41 }
42
43 #include "ReflectObject.lut.h"
44
45 namespace JSC {
46
47 STATIC_ASSERT_IS_TRIVIALLY_DESTRUCTIBLE(ReflectObject);
48
49 const ClassInfo ReflectObject::s_info = { "Reflect", &Base::s_info, &reflectObjectTable, CREATE_METHOD_TABLE(ReflectObject) };
50
51 /* Source for ReflectObject.lut.h
52 @begin reflectObjectTable
53     apply             reflectObjectApply             DontEnum|Function 3
54     deleteProperty    reflectObjectDeleteProperty    DontEnum|Function 2
55     enumerate         reflectObjectEnumerate         DontEnum|Function 1
56     isExtensible      reflectObjectIsExtensible      DontEnum|Function 1
57     ownKeys           reflectObjectOwnKeys           DontEnum|Function 1
58     preventExtensions reflectObjectPreventExtensions DontEnum|Function 1
59 @end
60 */
61
62 ReflectObject::ReflectObject(VM& vm, Structure* structure)
63     : JSNonFinalObject(vm, structure)
64 {
65 }
66
67 void ReflectObject::finishCreation(VM& vm, JSGlobalObject*)
68 {
69     Base::finishCreation(vm);
70     ASSERT(inherits(info()));
71 }
72
73 bool ReflectObject::getOwnPropertySlot(JSObject* object, ExecState* exec, PropertyName propertyName, PropertySlot &slot)
74 {
75     return getStaticFunctionSlot<Base>(exec, reflectObjectTable, jsCast<ReflectObject*>(object), propertyName, slot);
76 }
77
78 // ------------------------------ Functions --------------------------------
79
80 EncodedJSValue JSC_HOST_CALL reflectObjectEnumerate(ExecState* exec)
81 {
82     JSValue target = exec->argument(0);
83     if (!target.isObject())
84         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.enumerate requires the first argument be an object")));
85     return JSValue::encode(JSPropertyNameIterator::create(exec, exec->lexicalGlobalObject()->propertyNameIteratorStructure(), asObject(target)));
86 }
87
88 EncodedJSValue JSC_HOST_CALL reflectObjectIsExtensible(ExecState* exec)
89 {
90     JSValue target = exec->argument(0);
91     if (!target.isObject())
92         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.isExtensible requires the first argument be an object")));
93     return JSValue::encode(jsBoolean(asObject(target)->isExtensible()));
94 }
95
96 EncodedJSValue JSC_HOST_CALL reflectObjectOwnKeys(ExecState* exec)
97 {
98     JSValue target = exec->argument(0);
99     if (!target.isObject())
100         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.ownKeys requires the first argument be an object")));
101     return JSValue::encode(ownPropertyKeys(exec, jsCast<JSObject*>(target), PropertyNameMode::StringsAndSymbols, DontEnumPropertiesMode::Include));
102 }
103
104 EncodedJSValue JSC_HOST_CALL reflectObjectPreventExtensions(ExecState* exec)
105 {
106     JSValue target = exec->argument(0);
107     if (!target.isObject())
108         return JSValue::encode(throwTypeError(exec, ASCIILiteral("Reflect.preventExtensions requires the first argument be an object")));
109     asObject(target)->preventExtensions(exec->vm());
110     return JSValue::encode(jsBoolean(true));
111 }
112
113 } // namespace JSC