Remove excessive headers from JavaScriptCore
[WebKit-https.git] / Source / JavaScriptCore / runtime / JSArrayBufferConstructor.cpp
1 /*
2  * Copyright (C) 2013, 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 #include "config.h"
27 #include "JSArrayBufferConstructor.h"
28
29 #include "BuiltinNames.h"
30 #include "Error.h"
31 #include "ExceptionHelpers.h"
32 #include "GetterSetter.h"
33 #include "JSArrayBuffer.h"
34 #include "JSArrayBufferPrototype.h"
35 #include "JSGlobalObject.h"
36 #include "JSCInlines.h"
37
38 namespace JSC {
39
40 static EncodedJSValue JSC_HOST_CALL arrayBufferFuncIsView(ExecState*);
41
42 const ClassInfo JSArrayBufferConstructor::s_info = {
43     "Function", &Base::s_info, nullptr, nullptr,
44     CREATE_METHOD_TABLE(JSArrayBufferConstructor)
45 };
46
47 JSArrayBufferConstructor::JSArrayBufferConstructor(VM& vm, Structure* structure, ArrayBufferSharingMode sharingMode)
48     : Base(vm, structure)
49     , m_sharingMode(sharingMode)
50 {
51 }
52
53 void JSArrayBufferConstructor::finishCreation(VM& vm, JSArrayBufferPrototype* prototype, GetterSetter* speciesSymbol)
54 {
55     Base::finishCreation(vm, ASCIILiteral(arrayBufferSharingModeName(m_sharingMode)));
56     putDirectWithoutTransition(vm, vm.propertyNames->prototype, prototype, DontEnum | DontDelete | ReadOnly);
57     putDirectWithoutTransition(vm, vm.propertyNames->length, jsNumber(1), DontEnum | ReadOnly);
58     putDirectNonIndexAccessor(vm, vm.propertyNames->speciesSymbol, speciesSymbol, Accessor | ReadOnly | DontEnum);
59
60     if (m_sharingMode == ArrayBufferSharingMode::Default) {
61         JSGlobalObject* globalObject = this->globalObject();
62         JSC_NATIVE_FUNCTION_WITHOUT_TRANSITION(vm.propertyNames->isView, arrayBufferFuncIsView, DontEnum, 1);
63         JSC_NATIVE_FUNCTION_WITHOUT_TRANSITION(vm.propertyNames->builtinNames().isViewPrivateName(), arrayBufferFuncIsView, DontEnum, 1);
64     }
65 }
66
67 JSArrayBufferConstructor* JSArrayBufferConstructor::create(VM& vm, Structure* structure, JSArrayBufferPrototype* prototype, GetterSetter* speciesSymbol, ArrayBufferSharingMode sharingMode)
68 {
69     JSArrayBufferConstructor* result =
70         new (NotNull, allocateCell<JSArrayBufferConstructor>(vm.heap))
71         JSArrayBufferConstructor(vm, structure, sharingMode);
72     result->finishCreation(vm, prototype, speciesSymbol);
73     return result;
74 }
75
76 Structure* JSArrayBufferConstructor::createStructure(
77     VM& vm, JSGlobalObject* globalObject, JSValue prototype)
78 {
79     return Structure::create(
80         vm, globalObject, prototype, TypeInfo(ObjectType, StructureFlags), info());
81 }
82
83 static EncodedJSValue JSC_HOST_CALL constructArrayBuffer(ExecState* exec)
84 {
85     VM& vm = exec->vm();
86     auto scope = DECLARE_THROW_SCOPE(vm);
87
88     JSArrayBufferConstructor* constructor =
89         jsCast<JSArrayBufferConstructor*>(exec->jsCallee());
90
91     Structure* arrayBufferStructure = InternalFunction::createSubclassStructure(exec, exec->newTarget(), constructor->globalObject()->arrayBufferStructure(constructor->sharingMode()));
92     RETURN_IF_EXCEPTION(scope, { });
93
94     unsigned length;
95     if (exec->argumentCount()) {
96         length = exec->uncheckedArgument(0).toIndex(exec, "length");
97         RETURN_IF_EXCEPTION(scope, encodedJSValue());
98     } else {
99         // Although the documentation doesn't say so, it is in fact correct to say
100         // "new ArrayBuffer()". The result is the same as allocating an array buffer
101         // with a zero length.
102         length = 0;
103     }
104
105     auto buffer = ArrayBuffer::tryCreate(length, 1);
106     if (!buffer)
107         return JSValue::encode(throwOutOfMemoryError(exec, scope));
108     
109     if (constructor->sharingMode() == ArrayBufferSharingMode::Shared)
110         buffer->makeShared();
111     ASSERT(constructor->sharingMode() == buffer->sharingMode());
112
113     JSArrayBuffer* result = JSArrayBuffer::create(vm, arrayBufferStructure, WTFMove(buffer));
114     return JSValue::encode(result);
115 }
116
117 static EncodedJSValue JSC_HOST_CALL callArrayBuffer(ExecState* exec)
118 {
119     VM& vm = exec->vm();
120     auto scope = DECLARE_THROW_SCOPE(vm);
121     return JSValue::encode(throwConstructorCannotBeCalledAsFunctionTypeError(exec, scope, "ArrayBuffer"));
122 }
123
124 ConstructType JSArrayBufferConstructor::getConstructData(
125     JSCell*, ConstructData& constructData)
126 {
127     constructData.native.function = constructArrayBuffer;
128     return ConstructType::Host;
129 }
130
131 CallType JSArrayBufferConstructor::getCallData(JSCell*, CallData& callData)
132 {
133     callData.native.function = callArrayBuffer;
134     return CallType::Host;
135 }
136
137 // ------------------------------ Functions --------------------------------
138
139 // ECMA 24.1.3.1
140 EncodedJSValue JSC_HOST_CALL arrayBufferFuncIsView(ExecState* exec)
141 {
142     return JSValue::encode(jsBoolean(jsDynamicCast<JSArrayBufferView*>(exec->vm(), exec->argument(0))));
143 }
144     
145
146 } // namespace JSC
147