| Index: src/typedarray.js
|
| diff --git a/src/typedarray.js b/src/typedarray.js
|
| index 04c487f43ce70131252a736295fbf3598ed6f884..0d903550495be2a6d792d279b547e7229ebf4ce5 100644
|
| --- a/src/typedarray.js
|
| +++ b/src/typedarray.js
|
| @@ -37,7 +37,7 @@
|
|
|
| function CreateTypedArrayConstructor(name, elementSize, arrayId, constructor) {
|
| function ConstructByArrayBuffer(obj, buffer, byteOffset, length) {
|
| - var offset = IS_UNDEFINED(byteOffset) ? 0 : TO_POSITIVE_INTEGER(byteOffset);
|
| + var offset = ToPositiveInteger(byteOffset, "invalid_typed_array_length")
|
|
|
| if (offset % elementSize !== 0) {
|
| throw MakeRangeError("invalid_typed_array_alignment",
|
| @@ -58,7 +58,7 @@ function CreateTypedArrayConstructor(name, elementSize, arrayId, constructor) {
|
| newByteLength = bufferByteLength - offset;
|
| newLength = newByteLength / elementSize;
|
| } else {
|
| - var newLength = TO_POSITIVE_INTEGER(length);
|
| + var newLength = ToPositiveInteger(length, "invalid_typed_array_length");
|
| newByteLength = newLength * elementSize;
|
| }
|
| if (offset + newByteLength > bufferByteLength) {
|
| @@ -68,7 +68,7 @@ function CreateTypedArrayConstructor(name, elementSize, arrayId, constructor) {
|
| }
|
|
|
| function ConstructByLength(obj, length) {
|
| - var l = IS_UNDEFINED(length) ? 0 : TO_POSITIVE_INTEGER(length);
|
| + var l = ToPositiveInteger(length, "invalid_typed_array_length");
|
| var byteLength = l * elementSize;
|
| var buffer = new global.ArrayBuffer(byteLength);
|
| %TypedArrayInitialize(obj, arrayId, buffer, 0, byteLength);
|
| @@ -76,7 +76,7 @@ function CreateTypedArrayConstructor(name, elementSize, arrayId, constructor) {
|
|
|
| function ConstructByArrayLike(obj, arrayLike) {
|
| var length = arrayLike.length;
|
| - var l = IS_UNDEFINED(length) ? 0 : TO_POSITIVE_INTEGER(length);
|
| + var l = ToPositiveInteger(length, "invalid_typed_array_length");
|
| var byteLength = l * elementSize;
|
| var buffer = new $ArrayBuffer(byteLength);
|
| %TypedArrayInitialize(obj, arrayId, buffer, 0, byteLength);
|
| @@ -97,7 +97,7 @@ function CreateTypedArrayConstructor(name, elementSize, arrayId, constructor) {
|
| throw MakeTypeError("parameterless_typed_array_constr", [name]);
|
| }
|
| } else {
|
| - return new constructor(arg1, arg2, arg3);
|
| + throw MakeTypeError("constructor_not_function", [name])
|
| }
|
| }
|
| }
|
| @@ -146,7 +146,10 @@ function CreateSubArray(elementSize, constructor) {
|
| }
|
|
|
| function TypedArraySet(obj, offset) {
|
| - var intOffset = IS_UNDEFINED(offset) ? 0 : TO_POSITIVE_INTEGER(offset);
|
| + var intOffset = IS_UNDEFINED(offset) ? 0 : TO_INTEGER(offset);
|
| + if (intOffset < 0) {
|
| + throw MakeTypeError("typed_array_set_negative_offset");
|
| + }
|
| if (%TypedArraySetFastCases(this, obj, intOffset))
|
| return;
|
|
|
| @@ -197,3 +200,276 @@ SetupTypedArray(6, "Int32Array", global.Int32Array, 4);
|
| SetupTypedArray(7, "Float32Array", global.Float32Array, 4);
|
| SetupTypedArray(8, "Float64Array", global.Float64Array, 8);
|
| SetupTypedArray(9, "Uint8ClampedArray", global.Uint8ClampedArray, 1);
|
| +
|
| +
|
| +// --------------------------- DataView -----------------------------
|
| +
|
| +var $DataView = global.DataView;
|
| +
|
| +function DataViewConstructor(buffer, byteOffset, byteLength) { // length = 3
|
| + if (%_IsConstructCall()) {
|
| + if (!IS_ARRAYBUFFER(buffer)) {
|
| + throw MakeTypeError('data_view_not_array_buffer', []);
|
| + }
|
| + var bufferByteLength = %ArrayBufferGetByteLength(buffer);
|
| + var offset = ToPositiveInteger(byteOffset, 'invalid_data_view_offset');
|
| + if (offset > bufferByteLength) {
|
| + throw MakeRangeError('invalid_data_view_offset');
|
| + }
|
| + var length = IS_UNDEFINED(byteLength) ?
|
| + bufferByteLength - offset : TO_INTEGER(byteLength);
|
| + if (length < 0 || offset + length > bufferByteLength) {
|
| + throw new MakeRangeError('invalid_data_view_length');
|
| + }
|
| + %DataViewInitialize(this, buffer, offset, length);
|
| + } else {
|
| + throw MakeTypeError('constructor_not_function', ["DataView"]);
|
| + }
|
| +}
|
| +
|
| +function DataViewGetBuffer() {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.buffer', this]);
|
| + }
|
| + return %DataViewGetBuffer(this);
|
| +}
|
| +
|
| +function DataViewGetByteOffset() {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.byteOffset', this]);
|
| + }
|
| + return %DataViewGetByteOffset(this);
|
| +}
|
| +
|
| +function DataViewGetByteLength() {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.byteLength', this]);
|
| + }
|
| + return %DataViewGetByteLength(this);
|
| +}
|
| +
|
| +function ToPositiveDataViewOffset(offset) {
|
| + return ToPositiveInteger(offset, 'invalid_data_view_accessor_offset');
|
| +}
|
| +
|
| +function DataViewGetInt8(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getInt8', this]);
|
| + }
|
| + return %DataViewGetInt8(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetInt8(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setInt8', this]);
|
| + }
|
| + %DataViewSetInt8(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetUint8(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getUint8', this]);
|
| + }
|
| + return %DataViewGetUint8(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetUint8(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setUint8', this]);
|
| + }
|
| + %DataViewSetUint8(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetInt16(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getInt16', this]);
|
| + }
|
| + return %DataViewGetInt16(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetInt16(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setInt16', this]);
|
| + }
|
| + %DataViewSetInt16(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetUint16(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getUint16', this]);
|
| + }
|
| + return %DataViewGetUint16(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetUint16(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setUint16', this]);
|
| + }
|
| + %DataViewSetUint16(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetInt32(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getInt32', this]);
|
| + }
|
| + return %DataViewGetInt32(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetInt32(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setInt32', this]);
|
| + }
|
| + %DataViewSetInt32(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetUint32(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getUint32', this]);
|
| + }
|
| + return %DataViewGetUint32(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetUint32(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setUint32', this]);
|
| + }
|
| + %DataViewSetUint32(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetFloat32(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getFloat32', this]);
|
| + }
|
| + return %DataViewGetFloat32(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetFloat32(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setFloat32', this]);
|
| + }
|
| + %DataViewSetFloat32(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewGetFloat64(offset, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.getFloat64', this]);
|
| + }
|
| + offset = TO_INTEGER(offset);
|
| + if (offset < 0) {
|
| + throw MakeRangeError("invalid_data_view_accessor_offset");
|
| + }
|
| + return %DataViewGetFloat64(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function DataViewSetFloat64(offset, value, little_endian) {
|
| + if (!IS_DATAVIEW(this)) {
|
| + throw MakeTypeError('incompatible_method_reciever',
|
| + ['DataView.setFloat64', this]);
|
| + }
|
| + offset = TO_INTEGER(offset);
|
| + if (offset < 0) {
|
| + throw MakeRangeError("invalid_data_view_accessor_offset");
|
| + }
|
| + %DataViewSetFloat64(this,
|
| + ToPositiveDataViewOffset(offset),
|
| + TO_NUMBER_INLINE(value),
|
| + !!little_endian);
|
| +}
|
| +
|
| +function SetupDataView() {
|
| + %CheckIsBootstrapping();
|
| +
|
| + // Setup the DataView constructor.
|
| + %SetCode($DataView, DataViewConstructor);
|
| + %FunctionSetPrototype($DataView, new $Object);
|
| +
|
| + // Set up constructor property on the DataView prototype.
|
| + %SetProperty($DataView.prototype, "constructor", $DataView, DONT_ENUM);
|
| +
|
| + InstallGetter($DataView.prototype, "buffer", DataViewGetBuffer);
|
| + InstallGetter($DataView.prototype, "byteOffset", DataViewGetByteOffset);
|
| + InstallGetter($DataView.prototype, "byteLength", DataViewGetByteLength);
|
| +
|
| + InstallFunctions($DataView.prototype, DONT_ENUM, $Array(
|
| + "getInt8", DataViewGetInt8,
|
| + "setInt8", DataViewSetInt8,
|
| +
|
| + "getUint8", DataViewGetUint8,
|
| + "setUint8", DataViewSetUint8,
|
| +
|
| + "getInt16", DataViewGetInt16,
|
| + "setInt16", DataViewSetInt16,
|
| +
|
| + "getUint16", DataViewGetUint16,
|
| + "setUint16", DataViewSetUint16,
|
| +
|
| + "getInt32", DataViewGetInt32,
|
| + "setInt32", DataViewSetInt32,
|
| +
|
| + "getUint32", DataViewGetUint32,
|
| + "setUint32", DataViewSetUint32,
|
| +
|
| + "getFloat32", DataViewGetFloat32,
|
| + "setFloat32", DataViewSetFloat32,
|
| +
|
| + "getFloat64", DataViewGetFloat64,
|
| + "setFloat64", DataViewSetFloat64
|
| + ));
|
| +}
|
| +
|
| +SetupDataView();
|
|
|