OLD | NEW |
---|---|
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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 (function(global, utils) { | 5 (function(global, utils) { |
6 | 6 |
7 "use strict"; | 7 "use strict"; |
8 | 8 |
9 %CheckIsBootstrapping(); | 9 %CheckIsBootstrapping(); |
10 | 10 |
11 // ------------------------------------------------------------------- | 11 // ------------------------------------------------------------------- |
12 // Imports | 12 // Imports |
13 | 13 |
14 // array.js has to come before typedarray.js for this to work | 14 // array.js has to come before typedarray.js for this to work |
15 var ArrayToString = utils.ImportNow("ArrayToString"); | 15 var ArrayToString = utils.ImportNow("ArrayToString"); |
16 var ArrayValues; | |
17 var GetIterator; | 16 var GetIterator; |
18 var GetMethod; | 17 var GetMethod; |
19 var GlobalArray = global.Array; | 18 var GlobalArray = global.Array; |
20 var GlobalArrayBuffer = global.ArrayBuffer; | 19 var GlobalArrayBuffer = global.ArrayBuffer; |
21 var GlobalArrayBufferPrototype = GlobalArrayBuffer.prototype; | 20 var GlobalArrayBufferPrototype = GlobalArrayBuffer.prototype; |
22 var GlobalObject = global.Object; | 21 var GlobalObject = global.Object; |
23 var InnerArrayFilter; | 22 var InnerArrayFilter; |
24 var InnerArrayFind; | 23 var InnerArrayFind; |
25 var InnerArrayFindIndex; | 24 var InnerArrayFindIndex; |
26 var InnerArrayJoin; | 25 var InnerArrayJoin; |
(...skipping 23 matching lines...) Expand all Loading... | |
50 | 49 |
51 macro DECLARE_GLOBALS(INDEX, NAME, SIZE) | 50 macro DECLARE_GLOBALS(INDEX, NAME, SIZE) |
52 var GlobalNAME = global.NAME; | 51 var GlobalNAME = global.NAME; |
53 endmacro | 52 endmacro |
54 | 53 |
55 TYPED_ARRAYS(DECLARE_GLOBALS) | 54 TYPED_ARRAYS(DECLARE_GLOBALS) |
56 | 55 |
57 var GlobalTypedArray = %object_get_prototype_of(GlobalUint8Array); | 56 var GlobalTypedArray = %object_get_prototype_of(GlobalUint8Array); |
58 | 57 |
59 utils.Import(function(from) { | 58 utils.Import(function(from) { |
60 ArrayValues = from.ArrayValues; | |
61 GetIterator = from.GetIterator; | 59 GetIterator = from.GetIterator; |
62 GetMethod = from.GetMethod; | 60 GetMethod = from.GetMethod; |
63 InnerArrayFilter = from.InnerArrayFilter; | 61 InnerArrayFilter = from.InnerArrayFilter; |
64 InnerArrayFind = from.InnerArrayFind; | 62 InnerArrayFind = from.InnerArrayFind; |
65 InnerArrayFindIndex = from.InnerArrayFindIndex; | 63 InnerArrayFindIndex = from.InnerArrayFindIndex; |
66 InnerArrayJoin = from.InnerArrayJoin; | 64 InnerArrayJoin = from.InnerArrayJoin; |
67 InnerArraySort = from.InnerArraySort; | 65 InnerArraySort = from.InnerArraySort; |
68 InnerArrayToLocaleString = from.InnerArrayToLocaleString; | 66 InnerArrayToLocaleString = from.InnerArrayToLocaleString; |
69 MaxSimple = from.MaxSimple; | 67 MaxSimple = from.MaxSimple; |
70 MinSimple = from.MinSimple; | 68 MinSimple = from.MinSimple; |
(...skipping 17 matching lines...) Expand all Loading... | |
88 throw %make_type_error(kIncompatibleMethodReceiver, | 86 throw %make_type_error(kIncompatibleMethodReceiver, |
89 "TypedArrayDefaultConstructor", this); | 87 "TypedArrayDefaultConstructor", this); |
90 } | 88 } |
91 | 89 |
92 function TypedArrayCreate(constructor, arg0, arg1, arg2) { | 90 function TypedArrayCreate(constructor, arg0, arg1, arg2) { |
93 if (IS_UNDEFINED(arg1)) { | 91 if (IS_UNDEFINED(arg1)) { |
94 var newTypedArray = new constructor(arg0); | 92 var newTypedArray = new constructor(arg0); |
95 } else { | 93 } else { |
96 var newTypedArray = new constructor(arg0, arg1, arg2); | 94 var newTypedArray = new constructor(arg0, arg1, arg2); |
97 } | 95 } |
98 if (!IS_TYPEDARRAY(newTypedArray)) throw %make_type_error(kNotTypedArray); | 96 %ValidateTypedArray(newTypedArray, "TypedArrayCreate"); |
adamk
2017/03/27 19:48:20
I'm worried that adding a runtime call here might
Choongwoo Han
2017/03/28 09:50:58
Actually this function is not related with default
| |
99 // TODO(littledan): Check for being detached, here and elsewhere | |
100 // All callers where the first argument is a Number have no additional | |
101 // arguments. | |
102 if (IS_NUMBER(arg0) && %_TypedArrayGetLength(newTypedArray) < arg0) { | 97 if (IS_NUMBER(arg0) && %_TypedArrayGetLength(newTypedArray) < arg0) { |
103 throw %make_type_error(kTypedArrayTooShort); | 98 throw %make_type_error(kTypedArrayTooShort); |
104 } | 99 } |
105 return newTypedArray; | 100 return newTypedArray; |
106 } | 101 } |
107 | 102 |
108 function TypedArraySpeciesCreate(exemplar, arg0, arg1, arg2, conservative) { | 103 function TypedArraySpeciesCreate(exemplar, arg0, arg1, arg2) { |
109 var defaultConstructor = TypedArrayDefaultConstructor(exemplar); | 104 var defaultConstructor = TypedArrayDefaultConstructor(exemplar); |
110 var constructor = SpeciesConstructor(exemplar, defaultConstructor, | 105 var constructor = SpeciesConstructor(exemplar, defaultConstructor); |
111 conservative); | |
112 return TypedArrayCreate(constructor, arg0, arg1, arg2); | 106 return TypedArrayCreate(constructor, arg0, arg1, arg2); |
113 } | 107 } |
114 | 108 |
115 macro TYPED_ARRAY_CONSTRUCTOR(ARRAY_ID, NAME, ELEMENT_SIZE) | 109 macro TYPED_ARRAY_CONSTRUCTOR(ARRAY_ID, NAME, ELEMENT_SIZE) |
116 function NAMEConstructByIterable(obj, iterable, iteratorFn) { | 110 function NAMEConstructByIterable(obj, iterable, iteratorFn) { |
117 var list = new InternalArray(); | 111 var list = new InternalArray(); |
118 // Reading the Symbol.iterator property of iterable twice would be | 112 // Reading the Symbol.iterator property of iterable twice would be |
119 // observable with getters, so instead, we call the function which | 113 // observable with getters, so instead, we call the function which |
120 // was already looked up, and wrap it in another iterable. The | 114 // was already looked up, and wrap it in another iterable. The |
121 // __proto__ of the new iterable is set to null to avoid any chance | 115 // __proto__ of the new iterable is set to null to avoid any chance |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
194 endInt = MinSimple(endInt, srcLength); | 188 endInt = MinSimple(endInt, srcLength); |
195 } | 189 } |
196 | 190 |
197 if (endInt < beginInt) { | 191 if (endInt < beginInt) { |
198 endInt = beginInt; | 192 endInt = beginInt; |
199 } | 193 } |
200 | 194 |
201 var newLength = endInt - beginInt; | 195 var newLength = endInt - beginInt; |
202 var beginByteOffset = | 196 var beginByteOffset = |
203 %_ArrayBufferViewGetByteOffset(this) + beginInt * ELEMENT_SIZE; | 197 %_ArrayBufferViewGetByteOffset(this) + beginInt * ELEMENT_SIZE; |
204 // BUG(v8:4665): For web compatibility, subarray needs to always build an | 198 return TypedArraySpeciesCreate(this, %TypedArrayGetBuffer(this), |
205 // instance of the default constructor. | 199 beginByteOffset, newLength); |
206 // TODO(littledan): Switch to the standard or standardize the fix | |
207 return new GlobalNAME(%TypedArrayGetBuffer(this), beginByteOffset, newLength); | |
208 } | 200 } |
209 endmacro | 201 endmacro |
210 | 202 |
211 TYPED_ARRAYS(TYPED_ARRAY_CONSTRUCTOR) | 203 TYPED_ARRAYS(TYPED_ARRAY_CONSTRUCTOR) |
212 | 204 |
213 function TypedArraySubArray(begin, end) { | 205 function TypedArraySubArray(begin, end) { |
214 switch (%_ClassOf(this)) { | 206 switch (%_ClassOf(this)) { |
215 macro TYPED_ARRAY_SUBARRAY_CASE(ARRAY_ID, NAME, ELEMENT_SIZE) | 207 macro TYPED_ARRAY_SUBARRAY_CASE(ARRAY_ID, NAME, ELEMENT_SIZE) |
216 case "NAME": | 208 case "NAME": |
217 return %_Call(NAMESubArray, this, begin, end); | 209 return %_Call(NAMESubArray, this, begin, end); |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
344 if (i in array) { | 336 if (i in array) { |
345 var element = array[i]; | 337 var element = array[i]; |
346 if (!%_Call(f, receiver, element, i, array)) return false; | 338 if (!%_Call(f, receiver, element, i, array)) return false; |
347 } | 339 } |
348 } | 340 } |
349 return true; | 341 return true; |
350 } | 342 } |
351 | 343 |
352 // ES6 draft 05-05-15, section 22.2.3.7 | 344 // ES6 draft 05-05-15, section 22.2.3.7 |
353 function TypedArrayEvery(f, receiver) { | 345 function TypedArrayEvery(f, receiver) { |
354 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 346 %ValidateTypedArray(this, "TypedArray.prototype.every"); |
adamk
2017/03/27 19:48:20
Hmm, again this is likely to be much more expensiv
Choongwoo Han
2017/03/28 09:50:58
Yes, it was too expensive than my expectation (2x
| |
355 | 347 |
356 var length = %_TypedArrayGetLength(this); | 348 var length = %_TypedArrayGetLength(this); |
357 | 349 |
358 return InnerTypedArrayEvery(f, receiver, this, length); | 350 return InnerTypedArrayEvery(f, receiver, this, length); |
359 } | 351 } |
360 %FunctionSetLength(TypedArrayEvery, 1); | 352 %FunctionSetLength(TypedArrayEvery, 1); |
361 | 353 |
362 function InnerTypedArrayForEach(f, receiver, array, length) { | 354 function InnerTypedArrayForEach(f, receiver, array, length) { |
363 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); | 355 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); |
364 | 356 |
365 if (IS_UNDEFINED(receiver)) { | 357 if (IS_UNDEFINED(receiver)) { |
366 for (var i = 0; i < length; i++) { | 358 for (var i = 0; i < length; i++) { |
367 if (i in array) { | 359 if (i in array) { |
368 var element = array[i]; | 360 var element = array[i]; |
369 f(element, i, array); | 361 f(element, i, array); |
370 } | 362 } |
371 } | 363 } |
372 } else { | 364 } else { |
373 for (var i = 0; i < length; i++) { | 365 for (var i = 0; i < length; i++) { |
374 if (i in array) { | 366 if (i in array) { |
375 var element = array[i]; | 367 var element = array[i]; |
376 %_Call(f, receiver, element, i, array); | 368 %_Call(f, receiver, element, i, array); |
377 } | 369 } |
378 } | 370 } |
379 } | 371 } |
380 } | 372 } |
381 | 373 |
382 // ES6 draft 08-24-14, section 22.2.3.12 | 374 // ES6 draft 08-24-14, section 22.2.3.12 |
383 function TypedArrayForEach(f, receiver) { | 375 function TypedArrayForEach(f, receiver) { |
384 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 376 %ValidateTypedArray(this, "TypedArray.prototype.forEach"); |
385 | 377 |
386 var length = %_TypedArrayGetLength(this); | 378 var length = %_TypedArrayGetLength(this); |
387 | 379 |
388 InnerTypedArrayForEach(f, receiver, this, length); | 380 InnerTypedArrayForEach(f, receiver, this, length); |
389 } | 381 } |
390 %FunctionSetLength(TypedArrayForEach, 1); | 382 %FunctionSetLength(TypedArrayForEach, 1); |
391 | 383 |
392 | 384 |
393 // ES6 draft 07-15-13, section 22.2.3.9 | 385 // ES6 draft 07-15-13, section 22.2.3.9 |
394 function TypedArrayFilter(f, thisArg) { | 386 function TypedArrayFilter(f, thisArg) { |
395 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 387 %ValidateTypedArray(this, "TypeArray.prototype.filter"); |
396 | 388 |
397 var length = %_TypedArrayGetLength(this); | 389 var length = %_TypedArrayGetLength(this); |
398 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); | 390 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); |
399 var result = new InternalArray(); | 391 var result = new InternalArray(); |
400 InnerArrayFilter(f, thisArg, this, length, result); | 392 InnerArrayFilter(f, thisArg, this, length, result); |
401 var captured = result.length; | 393 var captured = result.length; |
402 var output = TypedArraySpeciesCreate(this, captured); | 394 var output = TypedArraySpeciesCreate(this, captured); |
403 for (var i = 0; i < captured; i++) { | 395 for (var i = 0; i < captured; i++) { |
404 output[i] = result[i]; | 396 output[i] = result[i]; |
405 } | 397 } |
406 return output; | 398 return output; |
407 } | 399 } |
408 %FunctionSetLength(TypedArrayFilter, 1); | 400 %FunctionSetLength(TypedArrayFilter, 1); |
409 | 401 |
410 | 402 |
411 // ES6 draft 07-15-13, section 22.2.3.10 | 403 // ES6 draft 07-15-13, section 22.2.3.10 |
412 function TypedArrayFind(predicate, thisArg) { | 404 function TypedArrayFind(predicate, thisArg) { |
413 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 405 %ValidateTypedArray(this, "TypedArray.prototype.find"); |
414 | 406 |
415 var length = %_TypedArrayGetLength(this); | 407 var length = %_TypedArrayGetLength(this); |
416 | 408 |
417 return InnerArrayFind(predicate, thisArg, this, length); | 409 return InnerArrayFind(predicate, thisArg, this, length); |
418 } | 410 } |
419 %FunctionSetLength(TypedArrayFind, 1); | 411 %FunctionSetLength(TypedArrayFind, 1); |
420 | 412 |
421 | 413 |
422 // ES6 draft 07-15-13, section 22.2.3.11 | 414 // ES6 draft 07-15-13, section 22.2.3.11 |
423 function TypedArrayFindIndex(predicate, thisArg) { | 415 function TypedArrayFindIndex(predicate, thisArg) { |
424 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 416 %ValidateTypedArray(this, "TypedArray.prototype.findIndex"); |
425 | 417 |
426 var length = %_TypedArrayGetLength(this); | 418 var length = %_TypedArrayGetLength(this); |
427 | 419 |
428 return InnerArrayFindIndex(predicate, thisArg, this, length); | 420 return InnerArrayFindIndex(predicate, thisArg, this, length); |
429 } | 421 } |
430 %FunctionSetLength(TypedArrayFindIndex, 1); | 422 %FunctionSetLength(TypedArrayFindIndex, 1); |
431 | 423 |
432 | 424 |
433 // ES6 draft 05-18-15, section 22.2.3.25 | 425 // ES6 draft 05-18-15, section 22.2.3.25 |
434 function TypedArraySort(comparefn) { | 426 function TypedArraySort(comparefn) { |
435 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 427 %ValidateTypedArray(this, "TypedArray.prototype.sort"); |
436 | 428 |
437 var length = %_TypedArrayGetLength(this); | 429 var length = %_TypedArrayGetLength(this); |
438 | 430 |
439 if (IS_UNDEFINED(comparefn)) { | 431 if (IS_UNDEFINED(comparefn)) { |
440 return %TypedArraySortFast(this); | 432 return %TypedArraySortFast(this); |
441 } | 433 } |
442 | 434 |
443 return InnerArraySort(this, length, comparefn); | 435 return InnerArraySort(this, length, comparefn); |
444 } | 436 } |
445 | 437 |
446 | 438 |
447 // ES6 draft 07-15-13, section 22.2.3.18 | 439 // ES6 draft 07-15-13, section 22.2.3.18 |
448 function TypedArrayMap(f, thisArg) { | 440 function TypedArrayMap(f, thisArg) { |
449 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 441 %ValidateTypedArray(this, "TypedArray.prototype.map"); |
450 | 442 |
451 var length = %_TypedArrayGetLength(this); | 443 var length = %_TypedArrayGetLength(this); |
452 var result = TypedArraySpeciesCreate(this, length); | 444 var result = TypedArraySpeciesCreate(this, length); |
453 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); | 445 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); |
454 for (var i = 0; i < length; i++) { | 446 for (var i = 0; i < length; i++) { |
455 var element = this[i]; | 447 var element = this[i]; |
456 result[i] = %_Call(f, thisArg, element, i, this); | 448 result[i] = %_Call(f, thisArg, element, i, this); |
457 } | 449 } |
458 return result; | 450 return result; |
459 } | 451 } |
460 %FunctionSetLength(TypedArrayMap, 1); | 452 %FunctionSetLength(TypedArrayMap, 1); |
461 | 453 |
462 function InnerTypedArraySome(f, receiver, array, length) { | 454 function InnerTypedArraySome(f, receiver, array, length) { |
463 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); | 455 if (!IS_CALLABLE(f)) throw %make_type_error(kCalledNonCallable, f); |
464 | 456 |
465 for (var i = 0; i < length; i++) { | 457 for (var i = 0; i < length; i++) { |
466 if (i in array) { | 458 if (i in array) { |
467 var element = array[i]; | 459 var element = array[i]; |
468 if (%_Call(f, receiver, element, i, array)) return true; | 460 if (%_Call(f, receiver, element, i, array)) return true; |
469 } | 461 } |
470 } | 462 } |
471 return false; | 463 return false; |
472 } | 464 } |
473 | 465 |
474 // ES6 draft 05-05-15, section 22.2.3.24 | 466 // ES6 draft 05-05-15, section 22.2.3.24 |
475 function TypedArraySome(f, receiver) { | 467 function TypedArraySome(f, receiver) { |
476 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 468 %ValidateTypedArray(this, "TypedArray.prototype.some"); |
477 | 469 |
478 var length = %_TypedArrayGetLength(this); | 470 var length = %_TypedArrayGetLength(this); |
479 | 471 |
480 return InnerTypedArraySome(f, receiver, this, length); | 472 return InnerTypedArraySome(f, receiver, this, length); |
481 } | 473 } |
482 %FunctionSetLength(TypedArraySome, 1); | 474 %FunctionSetLength(TypedArraySome, 1); |
483 | 475 |
484 | 476 |
485 // ES6 section 22.2.3.27 | 477 // ES6 section 22.2.3.27 |
486 function TypedArrayToLocaleString() { | 478 function TypedArrayToLocaleString() { |
487 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 479 %ValidateTypedArray(this, "TypedArray.prototype.toLocaleString"); |
488 | 480 |
489 var length = %_TypedArrayGetLength(this); | 481 var length = %_TypedArrayGetLength(this); |
490 | 482 |
491 return InnerArrayToLocaleString(this, length); | 483 return InnerArrayToLocaleString(this, length); |
492 } | 484 } |
493 | 485 |
494 | 486 |
495 // ES6 section 22.2.3.14 | 487 // ES6 section 22.2.3.14 |
496 function TypedArrayJoin(separator) { | 488 function TypedArrayJoin(separator) { |
497 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 489 %ValidateTypedArray(this, "TypedArray.prototype.join"); |
498 | 490 |
499 var length = %_TypedArrayGetLength(this); | 491 var length = %_TypedArrayGetLength(this); |
500 | 492 |
501 return InnerArrayJoin(separator, this, length); | 493 return InnerArrayJoin(separator, this, length); |
502 } | 494 } |
503 | 495 |
504 function InnerTypedArrayReduce( | 496 function InnerTypedArrayReduce( |
505 callback, current, array, length, argumentsLength) { | 497 callback, current, array, length, argumentsLength) { |
506 if (!IS_CALLABLE(callback)) { | 498 if (!IS_CALLABLE(callback)) { |
507 throw %make_type_error(kCalledNonCallable, callback); | 499 throw %make_type_error(kCalledNonCallable, callback); |
(...skipping 14 matching lines...) Expand all Loading... | |
522 if (i in array) { | 514 if (i in array) { |
523 var element = array[i]; | 515 var element = array[i]; |
524 current = callback(current, element, i, array); | 516 current = callback(current, element, i, array); |
525 } | 517 } |
526 } | 518 } |
527 return current; | 519 return current; |
528 } | 520 } |
529 | 521 |
530 // ES6 draft 07-15-13, section 22.2.3.19 | 522 // ES6 draft 07-15-13, section 22.2.3.19 |
531 function TypedArrayReduce(callback, current) { | 523 function TypedArrayReduce(callback, current) { |
532 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 524 %ValidateTypedArray(this, "TypedArray.prototype.reduce"); |
533 | 525 |
534 var length = %_TypedArrayGetLength(this); | 526 var length = %_TypedArrayGetLength(this); |
535 return InnerTypedArrayReduce( | 527 return InnerTypedArrayReduce( |
536 callback, current, this, length, arguments.length); | 528 callback, current, this, length, arguments.length); |
537 } | 529 } |
538 %FunctionSetLength(TypedArrayReduce, 1); | 530 %FunctionSetLength(TypedArrayReduce, 1); |
539 | 531 |
540 function InnerArrayReduceRight(callback, current, array, length, | 532 function InnerArrayReduceRight(callback, current, array, length, |
541 argumentsLength) { | 533 argumentsLength) { |
542 if (!IS_CALLABLE(callback)) { | 534 if (!IS_CALLABLE(callback)) { |
(...skipping 15 matching lines...) Expand all Loading... | |
558 if (i in array) { | 550 if (i in array) { |
559 var element = array[i]; | 551 var element = array[i]; |
560 current = callback(current, element, i, array); | 552 current = callback(current, element, i, array); |
561 } | 553 } |
562 } | 554 } |
563 return current; | 555 return current; |
564 } | 556 } |
565 | 557 |
566 // ES6 draft 07-15-13, section 22.2.3.19 | 558 // ES6 draft 07-15-13, section 22.2.3.19 |
567 function TypedArrayReduceRight(callback, current) { | 559 function TypedArrayReduceRight(callback, current) { |
568 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 560 %ValidateTypedArray(this, "TypedArray.prototype.reduceRight"); |
569 | 561 |
570 var length = %_TypedArrayGetLength(this); | 562 var length = %_TypedArrayGetLength(this); |
571 return InnerArrayReduceRight(callback, current, this, length, | 563 return InnerArrayReduceRight(callback, current, this, length, |
572 arguments.length); | 564 arguments.length); |
573 } | 565 } |
574 %FunctionSetLength(TypedArrayReduceRight, 1); | 566 %FunctionSetLength(TypedArrayReduceRight, 1); |
575 | 567 |
576 | 568 |
577 function TypedArraySlice(start, end) { | 569 function TypedArraySlice(start, end) { |
578 if (!IS_TYPEDARRAY(this)) throw %make_type_error(kNotTypedArray); | 570 %ValidateTypedArray(this, "TypedArray.prototype.slice"); |
571 | |
579 var len = %_TypedArrayGetLength(this); | 572 var len = %_TypedArrayGetLength(this); |
580 | 573 |
581 var relativeStart = TO_INTEGER(start); | 574 var relativeStart = TO_INTEGER(start); |
582 | 575 |
583 var k; | 576 var k; |
584 if (relativeStart < 0) { | 577 if (relativeStart < 0) { |
585 k = MaxSimple(len + relativeStart, 0); | 578 k = MaxSimple(len + relativeStart, 0); |
586 } else { | 579 } else { |
587 k = MinSimple(relativeStart, len); | 580 k = MinSimple(relativeStart, len); |
588 } | 581 } |
(...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
723 %AddNamedProperty(GlobalNAME.prototype, | 716 %AddNamedProperty(GlobalNAME.prototype, |
724 "constructor", global.NAME, DONT_ENUM); | 717 "constructor", global.NAME, DONT_ENUM); |
725 %AddNamedProperty(GlobalNAME.prototype, | 718 %AddNamedProperty(GlobalNAME.prototype, |
726 "BYTES_PER_ELEMENT", ELEMENT_SIZE, | 719 "BYTES_PER_ELEMENT", ELEMENT_SIZE, |
727 READ_ONLY | DONT_ENUM | DONT_DELETE); | 720 READ_ONLY | DONT_ENUM | DONT_DELETE); |
728 endmacro | 721 endmacro |
729 | 722 |
730 TYPED_ARRAYS(SETUP_TYPED_ARRAY) | 723 TYPED_ARRAYS(SETUP_TYPED_ARRAY) |
731 | 724 |
732 }) | 725 }) |
OLD | NEW |