| Index: src/array.js
|
| ===================================================================
|
| --- src/array.js (revision 7676)
|
| +++ src/array.js (working copy)
|
| @@ -375,6 +375,11 @@
|
|
|
|
|
| function ArrayJoin(separator) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.join"]);
|
| + }
|
| +
|
| if (IS_UNDEFINED(separator)) {
|
| separator = ',';
|
| } else if (!IS_STRING(separator)) {
|
| @@ -391,6 +396,11 @@
|
| // Removes the last element from the array and returns it. See
|
| // ECMA-262, section 15.4.4.6.
|
| function ArrayPop() {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.pop"]);
|
| + }
|
| +
|
| var n = TO_UINT32(this.length);
|
| if (n == 0) {
|
| this.length = n;
|
| @@ -407,6 +417,11 @@
|
| // Appends the arguments to the end of the array and returns the new
|
| // length of the array. See ECMA-262, section 15.4.4.7.
|
| function ArrayPush() {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.push"]);
|
| + }
|
| +
|
| var n = TO_UINT32(this.length);
|
| var m = %_ArgumentsLength();
|
| for (var i = 0; i < m; i++) {
|
| @@ -418,6 +433,11 @@
|
|
|
|
|
| function ArrayConcat(arg1) { // length == 1
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.concat"]);
|
| + }
|
| +
|
| var arg_count = %_ArgumentsLength();
|
| var arrays = new InternalArray(1 + arg_count);
|
| arrays[0] = this;
|
| @@ -474,6 +494,11 @@
|
|
|
|
|
| function ArrayReverse() {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.reverse"]);
|
| + }
|
| +
|
| var j = TO_UINT32(this.length) - 1;
|
|
|
| if (UseSparseVariant(this, j, IS_ARRAY(this))) {
|
| @@ -505,6 +530,11 @@
|
|
|
|
|
| function ArrayShift() {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.shift"]);
|
| + }
|
| +
|
| var len = TO_UINT32(this.length);
|
|
|
| if (len === 0) {
|
| @@ -526,6 +556,11 @@
|
|
|
|
|
| function ArrayUnshift(arg1) { // length == 1
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.unshift"]);
|
| + }
|
| +
|
| var len = TO_UINT32(this.length);
|
| var num_arguments = %_ArgumentsLength();
|
|
|
| @@ -545,6 +580,11 @@
|
|
|
|
|
| function ArraySlice(start, end) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.slice"]);
|
| + }
|
| +
|
| var len = TO_UINT32(this.length);
|
| var start_i = TO_INTEGER(start);
|
| var end_i = len;
|
| @@ -582,6 +622,11 @@
|
|
|
|
|
| function ArraySplice(start, delete_count) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.splice"]);
|
| + }
|
| +
|
| var num_arguments = %_ArgumentsLength();
|
|
|
| var len = TO_UINT32(this.length);
|
| @@ -653,6 +698,11 @@
|
|
|
|
|
| function ArraySort(comparefn) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.sort"]);
|
| + }
|
| +
|
| // In-place QuickSort algorithm.
|
| // For short (length <= 22) arrays, insertion sort is used for efficiency.
|
|
|
| @@ -914,6 +964,11 @@
|
| // preserving the semantics, since the calls to the receiver function can add
|
| // or delete elements from the array.
|
| function ArrayFilter(f, receiver) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.filter"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(f)) {
|
| throw MakeTypeError('called_non_callable', [ f ]);
|
| }
|
| @@ -935,6 +990,11 @@
|
|
|
|
|
| function ArrayForEach(f, receiver) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.forEach"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(f)) {
|
| throw MakeTypeError('called_non_callable', [ f ]);
|
| }
|
| @@ -953,6 +1013,11 @@
|
| // Executes the function once for each element present in the
|
| // array until it finds one where callback returns true.
|
| function ArraySome(f, receiver) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.some"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(f)) {
|
| throw MakeTypeError('called_non_callable', [ f ]);
|
| }
|
| @@ -970,6 +1035,11 @@
|
|
|
|
|
| function ArrayEvery(f, receiver) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.every"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(f)) {
|
| throw MakeTypeError('called_non_callable', [ f ]);
|
| }
|
| @@ -986,6 +1056,11 @@
|
| }
|
|
|
| function ArrayMap(f, receiver) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.map"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(f)) {
|
| throw MakeTypeError('called_non_callable', [ f ]);
|
| }
|
| @@ -1006,6 +1081,11 @@
|
|
|
|
|
| function ArrayIndexOf(element, index) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.indexOf"]);
|
| + }
|
| +
|
| var length = TO_UINT32(this.length);
|
| if (length == 0) return -1;
|
| if (IS_UNDEFINED(index)) {
|
| @@ -1063,6 +1143,11 @@
|
|
|
|
|
| function ArrayLastIndexOf(element, index) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.lastIndexOf"]);
|
| + }
|
| +
|
| var length = TO_UINT32(this.length);
|
| if (length == 0) return -1;
|
| if (%_ArgumentsLength() < 2) {
|
| @@ -1116,6 +1201,11 @@
|
|
|
|
|
| function ArrayReduce(callback, current) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.reduce"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(callback)) {
|
| throw MakeTypeError('called_non_callable', [callback]);
|
| }
|
| @@ -1145,6 +1235,11 @@
|
| }
|
|
|
| function ArrayReduceRight(callback, current) {
|
| + if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) {
|
| + throw MakeTypeError("called_on_null_or_undefined",
|
| + ["Array.prototype.reduceRight"]);
|
| + }
|
| +
|
| if (!IS_FUNCTION(callback)) {
|
| throw MakeTypeError('called_non_callable', [callback]);
|
| }
|
|
|