OLD | NEW |
1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/builtins/builtins-utils.h" | 5 #include "src/builtins/builtins-utils.h" |
6 #include "src/builtins/builtins.h" | 6 #include "src/builtins/builtins.h" |
7 #include "src/counters.h" | 7 #include "src/counters.h" |
8 #include "src/elements.h" | 8 #include "src/elements.h" |
9 #include "src/objects-inl.h" | 9 #include "src/objects-inl.h" |
10 | 10 |
11 namespace v8 { | 11 namespace v8 { |
12 namespace internal { | 12 namespace internal { |
13 | 13 |
14 // ----------------------------------------------------------------------------- | 14 // ----------------------------------------------------------------------------- |
15 // ES6 section 22.2 TypedArray Objects | 15 // ES6 section 22.2 TypedArray Objects |
16 | 16 |
17 // ES6 section 22.2.3.1 get %TypedArray%.prototype.buffer | 17 // ES6 section 22.2.3.1 get %TypedArray%.prototype.buffer |
18 BUILTIN(TypedArrayPrototypeBuffer) { | 18 BUILTIN(TypedArrayPrototypeBuffer) { |
19 HandleScope scope(isolate); | 19 HandleScope scope(isolate); |
20 CHECK_RECEIVER(JSTypedArray, typed_array, | 20 CHECK_RECEIVER(JSTypedArray, typed_array, "get TypedArray.prototype.buffer"); |
21 "get %TypedArray%.prototype.buffer"); | |
22 return *typed_array->GetBuffer(); | 21 return *typed_array->GetBuffer(); |
23 } | 22 } |
24 | 23 |
25 namespace { | 24 namespace { |
26 | 25 |
27 int64_t CapRelativeIndex(Handle<Object> num, int64_t minimum, int64_t maximum) { | 26 int64_t CapRelativeIndex(Handle<Object> num, int64_t minimum, int64_t maximum) { |
28 int64_t relative; | 27 int64_t relative; |
29 if (V8_LIKELY(num->IsSmi())) { | 28 if (V8_LIKELY(num->IsSmi())) { |
30 relative = Smi::cast(*num)->value(); | 29 relative = Smi::cast(*num)->value(); |
31 } else { | 30 } else { |
(...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
122 } // namespace | 121 } // namespace |
123 | 122 |
124 BUILTIN(TypedArrayPrototypeCopyWithin) { | 123 BUILTIN(TypedArrayPrototypeCopyWithin) { |
125 HandleScope scope(isolate); | 124 HandleScope scope(isolate); |
126 | 125 |
127 Handle<JSTypedArray> array; | 126 Handle<JSTypedArray> array; |
128 const char* method = "%TypedArray%.prototype.copyWithin"; | 127 const char* method = "%TypedArray%.prototype.copyWithin"; |
129 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 128 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
130 isolate, array, JSTypedArray::Validate(isolate, args.receiver(), method)); | 129 isolate, array, JSTypedArray::Validate(isolate, args.receiver(), method)); |
131 | 130 |
| 131 if (V8_UNLIKELY(array->WasNeutered())) return *array; |
| 132 |
132 int64_t len = array->length_value(); | 133 int64_t len = array->length_value(); |
133 int64_t to = 0; | 134 int64_t to = 0; |
134 int64_t from = 0; | 135 int64_t from = 0; |
135 int64_t final = len; | 136 int64_t final = len; |
136 | 137 |
137 if (V8_LIKELY(args.length() > 1)) { | 138 if (V8_LIKELY(args.length() > 1)) { |
138 Handle<Object> num; | 139 Handle<Object> num; |
139 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 140 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
140 isolate, num, Object::ToInteger(isolate, args.at<Object>(1))); | 141 isolate, num, Object::ToInteger(isolate, args.at<Object>(1))); |
141 to = CapRelativeIndex(num, 0, len); | 142 to = CapRelativeIndex(num, 0, len); |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
185 } | 186 } |
186 | 187 |
187 BUILTIN(TypedArrayPrototypeFill) { | 188 BUILTIN(TypedArrayPrototypeFill) { |
188 HandleScope scope(isolate); | 189 HandleScope scope(isolate); |
189 | 190 |
190 Handle<JSTypedArray> array; | 191 Handle<JSTypedArray> array; |
191 const char* method = "%TypedArray%.prototype.fill"; | 192 const char* method = "%TypedArray%.prototype.fill"; |
192 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 193 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
193 isolate, array, JSTypedArray::Validate(isolate, args.receiver(), method)); | 194 isolate, array, JSTypedArray::Validate(isolate, args.receiver(), method)); |
194 | 195 |
| 196 if (V8_UNLIKELY(array->WasNeutered())) return *array; |
| 197 |
195 int64_t len = array->length_value(); | 198 int64_t len = array->length_value(); |
196 int64_t start = 0; | 199 int64_t start = 0; |
197 int64_t end = len; | 200 int64_t end = len; |
198 | 201 |
199 if (args.length() > 2) { | 202 if (args.length() > 2) { |
200 Handle<Object> num = args.atOrUndefined(isolate, 2); | 203 Handle<Object> num = args.atOrUndefined(isolate, 2); |
201 if (!num->IsUndefined(isolate)) { | 204 if (!num->IsUndefined(isolate)) { |
202 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 205 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
203 isolate, num, Object::ToInteger(isolate, num)); | 206 isolate, num, Object::ToInteger(isolate, num)); |
204 start = CapRelativeIndex(num, 0, len); | 207 start = CapRelativeIndex(num, 0, len); |
(...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
330 } | 333 } |
331 | 334 |
332 BUILTIN(TypedArrayPrototypeReverse) { | 335 BUILTIN(TypedArrayPrototypeReverse) { |
333 HandleScope scope(isolate); | 336 HandleScope scope(isolate); |
334 | 337 |
335 Handle<JSTypedArray> array; | 338 Handle<JSTypedArray> array; |
336 const char* method = "%TypedArray%.prototype.reverse"; | 339 const char* method = "%TypedArray%.prototype.reverse"; |
337 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 340 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
338 isolate, array, JSTypedArray::Validate(isolate, args.receiver(), method)); | 341 isolate, array, JSTypedArray::Validate(isolate, args.receiver(), method)); |
339 | 342 |
| 343 if (V8_UNLIKELY(array->WasNeutered())) return *array; |
| 344 |
340 ElementsAccessor* elements = array->GetElementsAccessor(); | 345 ElementsAccessor* elements = array->GetElementsAccessor(); |
341 elements->Reverse(*array); | 346 elements->Reverse(*array); |
342 return *array; | 347 return *array; |
343 } | 348 } |
344 | 349 |
345 BUILTIN(TypedArrayPrototypeSlice) { | 350 BUILTIN(TypedArrayPrototypeSlice) { |
346 HandleScope scope(isolate); | 351 HandleScope scope(isolate); |
347 | 352 |
348 Handle<JSTypedArray> array; | 353 Handle<JSTypedArray> array; |
349 const char* method = "%TypedArray%.prototype.slice"; | 354 const char* method = "%TypedArray%.prototype.slice"; |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
387 | 392 |
388 if (count == 0) return *result_array; | 393 if (count == 0) return *result_array; |
389 | 394 |
390 ElementsAccessor* accessor = array->GetElementsAccessor(); | 395 ElementsAccessor* accessor = array->GetElementsAccessor(); |
391 return *accessor->Slice(array, static_cast<uint32_t>(start), | 396 return *accessor->Slice(array, static_cast<uint32_t>(start), |
392 static_cast<uint32_t>(end), result_array); | 397 static_cast<uint32_t>(end), result_array); |
393 } | 398 } |
394 | 399 |
395 } // namespace internal | 400 } // namespace internal |
396 } // namespace v8 | 401 } // namespace v8 |
OLD | NEW |