Remove excessive headers from JavaScriptCore
[WebKit-https.git] / Source / JavaScriptCore / runtime / JSArrayBufferPrototype.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 "JSArrayBufferPrototype.h"
28
29 #include "Error.h"
30 #include "ExceptionHelpers.h"
31 #include "JSArrayBuffer.h"
32 #include "JSFunction.h"
33 #include "JSCInlines.h"
34 #include "TypedArrayAdaptors.h"
35
36 namespace JSC {
37
38 static EncodedJSValue JSC_HOST_CALL arrayBufferProtoFuncSlice(ExecState* exec)
39 {
40     VM& vm = exec->vm();
41     auto scope = DECLARE_THROW_SCOPE(vm);
42
43     JSFunction* callee = jsCast<JSFunction*>(exec->jsCallee());
44     
45     JSArrayBuffer* thisObject = jsDynamicCast<JSArrayBuffer*>(vm, exec->thisValue());
46     if (!thisObject)
47         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver of slice must be an array buffer."));
48     
49     if (!exec->argumentCount())
50         return throwVMTypeError(exec, scope, ASCIILiteral("Slice requires at least one argument."));
51     
52     int32_t begin = exec->argument(0).toInt32(exec);
53     RETURN_IF_EXCEPTION(scope, encodedJSValue());
54     
55     int32_t end;
56     if (exec->argumentCount() >= 2) {
57         end = exec->uncheckedArgument(1).toInt32(exec);
58         RETURN_IF_EXCEPTION(scope, encodedJSValue());
59     } else
60         end = thisObject->impl()->byteLength();
61     
62     RefPtr<ArrayBuffer> newBuffer = thisObject->impl()->slice(begin, end);
63     if (!newBuffer)
64         return JSValue::encode(throwOutOfMemoryError(exec, scope));
65     
66     Structure* structure = callee->globalObject()->arrayBufferStructure(newBuffer->sharingMode());
67     
68     JSArrayBuffer* result = JSArrayBuffer::create(vm, structure, WTFMove(newBuffer));
69     
70     return JSValue::encode(result);
71 }
72
73 // http://tc39.github.io/ecmascript_sharedmem/shmem.html#sec-get-arraybuffer.prototype.bytelength
74 static EncodedJSValue JSC_HOST_CALL arrayBufferProtoGetterFuncByteLength(ExecState* exec)
75 {
76     VM& vm = exec->vm();
77     auto scope = DECLARE_THROW_SCOPE(vm);
78     JSValue thisValue = exec->thisValue();
79     if (!thisValue.isObject())
80         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver should be an array buffer but was not an object"));
81
82     auto* thisObject = jsDynamicCast<JSArrayBuffer*>(vm, thisValue);
83     if (!thisObject)
84         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver should be an array buffer"));
85     if (thisObject->isShared())
86         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver should not be a shared array buffer"));
87
88     scope.release();
89
90     return JSValue::encode(jsNumber(thisObject->impl()->byteLength()));
91 }
92
93 // http://tc39.github.io/ecmascript_sharedmem/shmem.html#StructuredData.SharedArrayBuffer.prototype.get_byteLength
94 static EncodedJSValue JSC_HOST_CALL sharedArrayBufferProtoGetterFuncByteLength(ExecState* exec)
95 {
96     VM& vm = exec->vm();
97     auto scope = DECLARE_THROW_SCOPE(vm);
98     JSValue thisValue = exec->thisValue();
99     if (!thisValue.isObject())
100         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver should be an array buffer but was not an object"));
101
102     auto* thisObject = jsDynamicCast<JSArrayBuffer*>(vm, thisValue);
103     if (!thisObject)
104         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver should be an array buffer"));
105     if (!thisObject->isShared())
106         return throwVMTypeError(exec, scope, ASCIILiteral("Receiver should be a shared array buffer"));
107
108     scope.release();
109
110     return JSValue::encode(jsNumber(thisObject->impl()->byteLength()));
111 }
112
113 const ClassInfo JSArrayBufferPrototype::s_info = {
114     "ArrayBufferPrototype", &Base::s_info, nullptr, nullptr, CREATE_METHOD_TABLE(JSArrayBufferPrototype)
115 };
116
117 JSArrayBufferPrototype::JSArrayBufferPrototype(VM& vm, Structure* structure, ArrayBufferSharingMode sharingMode)
118     : Base(vm, structure)
119     , m_sharingMode(sharingMode)
120 {
121 }
122
123 void JSArrayBufferPrototype::finishCreation(VM& vm, JSGlobalObject* globalObject)
124 {
125     Base::finishCreation(vm);
126     
127     JSC_NATIVE_FUNCTION_WITHOUT_TRANSITION(vm.propertyNames->slice, arrayBufferProtoFuncSlice, DontEnum, 2);
128     putDirectWithoutTransition(vm, vm.propertyNames->toStringTagSymbol, jsString(&vm, arrayBufferSharingModeName(m_sharingMode)), DontEnum | ReadOnly);
129     if (m_sharingMode == ArrayBufferSharingMode::Default)
130         JSC_NATIVE_GETTER(vm.propertyNames->byteLength, arrayBufferProtoGetterFuncByteLength, DontEnum | ReadOnly);
131     else
132         JSC_NATIVE_GETTER(vm.propertyNames->byteLength, sharedArrayBufferProtoGetterFuncByteLength, DontEnum | ReadOnly);
133 }
134
135 JSArrayBufferPrototype* JSArrayBufferPrototype::create(VM& vm, JSGlobalObject* globalObject, Structure* structure, ArrayBufferSharingMode sharingMode)
136 {
137     JSArrayBufferPrototype* prototype =
138         new (NotNull, allocateCell<JSArrayBufferPrototype>(vm.heap))
139         JSArrayBufferPrototype(vm, structure, sharingMode);
140     prototype->finishCreation(vm, globalObject);
141     return prototype;
142 }
143
144 Structure* JSArrayBufferPrototype::createStructure(
145     VM& vm, JSGlobalObject* globalObject, JSValue prototype)
146 {
147     return Structure::create(
148         vm, globalObject, prototype, TypeInfo(ObjectType, StructureFlags), info());
149 }
150
151 } // namespace JSC
152