Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Browse files

Merge branch 'gh-pages' of github.com:mathiasbynens/float.js into gh-…

…pages

* 'gh-pages' of github.com:mathiasbynens/float.js: (48 commits)
  typed arrays polyfill
  less vertical cellspacing
  some cellspacing
  no cellspacing
  css tomfoolery
  wow, I'm tired
  add border above bottom row
  styling
  fucking `return`
  oops, gotta convert that string to an array
  nicer tex-generation
  ok, it's working. optimizing mathjax now
  Hub
  wtf mathjax
  move float.js back up to head
  let's try 2.0
  just stabbing in the dark here
  good god please please please
  simpler math, for testing
  eliminate onload()
  ...
  • Loading branch information...
commit f5f021c746f044279258bc617a1db3dccba3fe31 2 parents 7bef05e + 5787ab5
@mathiasbynens mathiasbynens authored
Showing with 668 additions and 0 deletions.
  1. +1 −0  index.html
  2. +667 −0 typedarray.js
View
1  index.html
@@ -0,0 +1 @@
+<!DOCTYPE html>
View
667 typedarray.js
@@ -0,0 +1,667 @@
+/*
+ $LicenseInfo:firstyear=2010&license=mit$
+
+ Copyright (c) 2010, Linden Research, Inc.
+
+ Permission is hereby granted, free of charge, to any person obtaining a copy
+ of this software and associated documentation files (the "Software"), to deal
+ in the Software without restriction, including without limitation the rights
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ copies of the Software, and to permit persons to whom the Software is
+ furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ THE SOFTWARE.
+ $/LicenseInfo$
+ */
+
+// Original can be found at: https://bitbucket.org/lindenlab/llsd
+// Modifications by Joshua Bell inexorabletash@hotmail.com
+// * Restructure the creation of types and exporting to global namespace
+// * Allow no arguments to DataView constructor
+// * Work cross-frame with native arrays/shimmed DataView
+// * Corrected Object.defineProperty shim for IE8
+
+// ES3/ES5 implementation of the Krhonos TypedArray Working Draft (work in progress):
+// Ref: https://cvs.khronos.org/svn/repos/registry/trunk/public/webgl/doc/spec/TypedArray-spec.html
+// Date: 2011-02-01
+//
+// Variations:
+// * Float/Double -> Float32/Float64, per WebGL-Public mailing list conversations (post 5/17)
+// * Allows typed_array.get/set() as alias for subscripts (typed_array[])
+
+
+(function (global) {
+ "use strict";
+
+ var USE_NATIVE_IF_AVAILABLE = true;
+
+ // Approximations of internal ECMAScript conversion functions
+ var ECMAScript = (function () {
+ // Stash a copy in case other scripts modify these
+ var opts = Object.prototype.toString,
+ ophop = Object.prototype.hasOwnProperty;
+
+ return {
+ // Class returns internal [[Class]] property, used to avoid cross-frame instanceof issues:
+ Class: function(v) { return opts.call(v).replace(/^\[object *|\]$/g, ''); },
+ HasProperty: function(o, p) { return p in o; },
+ HasOwnProperty: function(o, p) { return ophop.call(o, p); },
+ IsCallable: function(o) { return typeof o === 'function'; },
+ ToInt32: function (v) { return v >> 0; },
+ ToUint32: function (v) { return v >>> 0; }
+ };
+ }());
+
+ // Create an INDEX_SIZE_ERR event - intentionally induces a DOM error if possible
+ function new_INDEX_SIZE_ERR() {
+ try {
+ if (document) {
+ // raises DOMException(INDEX_SIZE_ERR)
+ document.createTextNode("").splitText(1);
+ }
+ return new RangeError("INDEX_SIZE_ERR");
+ } catch (e) {
+ return e;
+ }
+ }
+
+ // ES5: lock down object properties
+ function configureProperties(obj) {
+ if (Object.getOwnPropertyNames && Object.defineProperty) {
+ var props = Object.getOwnPropertyNames(obj), i;
+ for (i = 0; i < props.length; i += 1) {
+ Object.defineProperty(obj, props[i], {
+ value: obj[props[i]],
+ writable: false,
+ enumerable: false,
+ configurable: false
+ });
+ }
+ }
+ }
+
+ // emulate ES5 getter/setter API using legacy APIs
+ // http://blogs.msdn.com/b/ie/archive/2010/09/07/transitioning-existing-code-to-the-es5-getter-setter-apis.aspx
+ // (second clause tests for Object.defineProperty() in IE<9 that only supports extending DOM prototypes, but
+ // note that IE<9 does not support __defineGetter__ or __defineSetter__ so it just renders the method harmless)
+ if (!Object.defineProperty ||
+ !(function () { try { Object.defineProperty({}, 'x', {}); return true; } catch (e) { return false; } } ())) {
+ Object.defineProperty = function (o, p, desc) {
+ if (!o === Object(o)) { throw new TypeError("Object.defineProperty called on non-object"); }
+ if (ECMAScript.HasProperty(desc, 'get') && Object.prototype.__defineGetter__) { Object.prototype.__defineGetter__.call(o, p, desc.get); }
+ if (ECMAScript.HasProperty(desc, 'set') && Object.prototype.__defineSetter__) { Object.prototype.__defineSetter__.call(o, p, desc.set); }
+ if (ECMAScript.HasProperty(desc, 'value')) { o[p] = desc.value; }
+ return o;
+ };
+ }
+
+ if (!Object.getOwnPropertyNames) {
+ Object.getOwnPropertyNames = function getOwnPropertyNames(o) {
+ if (o !== Object(o)) { throw new TypeError("Object.getOwnPropertyNames called on non-object"); }
+ var props = [], p;
+ for (p in o) {
+ if (ECMAScript.HasOwnProperty(o, p)) {
+ props.push(p);
+ }
+ }
+ return props;
+ };
+ }
+
+ // ES5: Make obj[index] an alias for obj._getter(index)/obj._setter(index, value)
+ // for index in 0 ... obj.length
+ function makeArrayAccessors(obj) {
+ if (!Object.defineProperty) { return; }
+
+ function makeArrayAccessor(index) {
+ Object.defineProperty(obj, index, {
+ 'get': function () { return obj._getter(index); },
+ 'set': function (v) { obj._setter(index, v); },
+ enumerable: true,
+ configurable: false
+ });
+ }
+
+ var i;
+ for (i = 0; i < obj.length; i += 1) {
+ makeArrayAccessor(i);
+ }
+ }
+
+ // Internal conversion functions:
+ // pack<Type>() - take a number (interpreted as Type), output a byte array
+ // unpack<Type>() - take a byte array, output a Type-like number
+
+ function as_signed(value, bits) { var s = 32 - bits; return (value << s) >> s; }
+ function as_unsigned(value, bits) { var s = 32 - bits; return (value << s) >>> s; }
+
+ function packInt8(n) { return [n & 0xff]; }
+ function unpackInt8(bytes) { return as_signed(bytes[0], 8); }
+
+ function packUint8(n) { return [n & 0xff]; }
+ function unpackUint8(bytes) { return as_unsigned(bytes[0], 8); }
+
+ function packInt16(n) { return [(n >> 8) & 0xff, n & 0xff]; }
+ function unpackInt16(bytes) { return as_signed(bytes[0] << 8 | bytes[1], 16); }
+
+ function packUint16(n) { return [(n >> 8) & 0xff, n & 0xff]; }
+ function unpackUint16(bytes) { return as_unsigned(bytes[0] << 8 | bytes[1], 16); }
+
+ function packInt32(n) { return [(n >> 24) & 0xff, (n >> 16) & 0xff, (n >> 8) & 0xff, n & 0xff]; }
+ function unpackInt32(bytes) { return as_signed(bytes[0] << 24 | bytes[1] << 16 | bytes[2] << 8 | bytes[3], 32); }
+
+ function packUint32(n) { return [(n >> 24) & 0xff, (n >> 16) & 0xff, (n >> 8) & 0xff, n & 0xff]; }
+ function unpackUint32(bytes) { return as_unsigned(bytes[0] << 24 | bytes[1] << 16 | bytes[2] << 8 | bytes[3], 32); }
+
+ function packIEEE754(v, ebits, fbits) {
+
+ var bias = (1 << (ebits - 1)) - 1,
+ s, e, f, ln,
+ i, bits, str, bytes;
+
+ // Compute sign, exponent, fraction
+ if (v !== v) {
+ // NaN
+ // http://dev.w3.org/2006/webapi/WebIDL/#es-type-mapping
+ e = (1 << bias) - 1; f = Math.pow(2, fbits - 1); s = 0;
+ } else if (v === Infinity || v === -Infinity) {
+ e = (1 << bias) - 1; f = 0; s = (v < 0) ? 1 : 0;
+ } else if (v === 0) {
+ e = 0; f = 0; s = (1 / v === -Infinity) ? 1 : 0;
+ } else {
+ s = v < 0;
+ v = Math.abs(v);
+
+ if (v >= Math.pow(2, 1 - bias)) {
+ // Normalized
+ ln = Math.min(Math.floor(Math.log(v) / Math.LN2), bias);
+ e = ln + bias;
+ f = Math.round(v * Math.pow(2, fbits - ln) - Math.pow(2, fbits));
+ } else {
+ // Denormalized
+ e = 0;
+ f = Math.round(v / Math.pow(2, 1 - bias - fbits));
+ }
+ }
+
+ // Pack sign, exponent, fraction
+ bits = [];
+ for (i = fbits; i; i -= 1) { bits.push(f % 2 ? 1 : 0); f = Math.floor(f / 2); }
+ for (i = ebits; i; i -= 1) { bits.push(e % 2 ? 1 : 0); e = Math.floor(e / 2); }
+ bits.push(s ? 1 : 0);
+ bits.reverse();
+ str = bits.join('');
+
+ // Bits to bytes
+ bytes = [];
+ while (str.length) {
+ bytes.push(parseInt(str.substring(0, 8), 2));
+ str = str.substring(8);
+ }
+ return bytes;
+ }
+
+ function unpackIEEE754(bytes, ebits, fbits) {
+
+ // Bytes to bits
+ var bits = [], i, j, b, str,
+ bias, s, e, f;
+
+ for (i = bytes.length; i; i -= 1) {
+ b = bytes[i - 1];
+ for (j = 8; j; j -= 1) {
+ bits.push(b % 2 ? 1 : 0); b = b >> 1;
+ }
+ }
+ bits.reverse();
+ str = bits.join('');
+
+ // Unpack sign, exponent, fraction
+ bias = (1 << (ebits - 1)) - 1;
+ s = parseInt(str.substring(0, 1), 2) ? -1 : 1;
+ e = parseInt(str.substring(1, 1 + ebits), 2);
+ f = parseInt(str.substring(1 + ebits), 2);
+
+ // Produce number
+ if (e === (1 << ebits) - 1) {
+ return f !== 0 ? NaN : s * Infinity;
+ } else if (e > 0) {
+ // Normalized
+ return s * Math.pow(2, e - bias) * (1 + f / Math.pow(2, fbits));
+ } else if (f !== 0) {
+ // Denormalized
+ return s * Math.pow(2, -(bias - 1)) * (f / Math.pow(2, fbits));
+ } else {
+ return s < 0 ? -0 : 0;
+ }
+ }
+
+ function unpackFloat64(b) { return unpackIEEE754(b, 11, 52); }
+ function packFloat64(v) { return packIEEE754(v, 11, 52); }
+ function unpackFloat32(b) { return unpackIEEE754(b, 8, 23); }
+ function packFloat32(v) { return packIEEE754(v, 8, 23); }
+
+
+ //
+ // 3 The ArrayBuffer Type
+ //
+
+ (function () {
+
+ /** @constructor */
+ var ArrayBuffer = function ArrayBuffer(length) {
+ length = ECMAScript.ToInt32(length);
+ if (length < 0) { throw new RangeError('ArrayBuffer size is not a small enough positive integer.'); }
+
+ this.byteLength = length;
+ this._bytes = [];
+ this._bytes.length = length;
+
+ var i;
+ for (i = 0; i < this.byteLength; i += 1) {
+ this._bytes[i] = 0;
+ }
+
+ configureProperties(this);
+ };
+
+
+ //
+ // 4 The ArrayBufferView Type
+ //
+
+ // NOTE: this constructor is not exported
+ /** @constructor */
+ var ArrayBufferView = function ArrayBufferView() {
+ //this.buffer = null;
+ //this.byteOffset = 0;
+ //this.byteLength = 0;
+ };
+
+ //
+ // 5 The Typed Array View Types
+ //
+
+ function makeTypedArrayConstructor(bytesPerElement, pack, unpack) {
+ // Each TypedArray type requires a distinct constructor instance with
+ // identical logic, which this produces.
+
+ var ctor;
+ ctor = function (buffer, byteOffset, length) {
+ var array, sequence, i, s;
+
+ if (!arguments.length || typeof arguments[0] === 'number') {
+ // Constructor(unsigned long length)
+ this.length = ECMAScript.ToInt32(arguments[0]);
+ if (length < 0) { throw new RangeError('ArrayBufferView size is not a small enough positive integer.'); }
+
+ this.byteLength = this.length * this.BYTES_PER_ELEMENT;
+ this.buffer = new ArrayBuffer(this.byteLength);
+ this.byteOffset = 0;
+ } else if (typeof arguments[0] === 'object' && arguments[0].constructor === ctor) {
+ // Constructor(TypedArray array)
+ array = arguments[0];
+
+ this.length = array.length;
+ this.byteLength = this.length * this.BYTES_PER_ELEMENT;
+ this.buffer = new ArrayBuffer(this.byteLength);
+ this.byteOffset = 0;
+
+ for (i = 0; i < this.length; i += 1) {
+ this._setter(i, array._getter(i));
+ }
+ } else if (typeof arguments[0] === 'object' &&
+ !(arguments[0] instanceof ArrayBuffer || ECMAScript.Class(arguments[0]) === 'ArrayBuffer')) {
+ // Constructor(sequence<type> array)
+ sequence = arguments[0];
+
+ this.length = ECMAScript.ToUint32(sequence.length);
+ this.byteLength = this.length * this.BYTES_PER_ELEMENT;
+ this.buffer = new ArrayBuffer(this.byteLength);
+ this.byteOffset = 0;
+
+ for (i = 0; i < this.length; i += 1) {
+ s = sequence[i];
+ this._setter(i, Number(s));
+ }
+ } else if (typeof arguments[0] === 'object' &&
+ (arguments[0] instanceof ArrayBuffer || ECMAScript.Class(arguments[0]) === 'ArrayBuffer')) {
+ // Constructor(ArrayBuffer buffer,
+ // optional unsigned long byteOffset, optional unsigned long length)
+ this.buffer = buffer;
+
+ this.byteOffset = ECMAScript.ToUint32(byteOffset);
+ if (this.byteOffset > this.buffer.byteLength) {
+ throw new_INDEX_SIZE_ERR(); // byteOffset out of range
+ }
+
+ if (this.byteOffset % this.BYTES_PER_ELEMENT) {
+ // The given byteOffset must be a multiple of the element
+ // size of the specific type, otherwise an exception is raised.
+ //throw new_INDEX_SIZE_ERR();
+ throw new RangeError("ArrayBuffer length minus the byteOffset is not a multiple of the element size.");
+ }
+
+ if (arguments.length < 3) {
+ this.byteLength = this.buffer.byteLength - this.byteOffset;
+
+ if (this.byteLength % this.BYTES_PER_ELEMENT) {
+ throw new_INDEX_SIZE_ERR(); // length of buffer minus byteOffset not a multiple of the element size
+ }
+ this.length = this.byteLength / this.BYTES_PER_ELEMENT;
+ } else {
+ this.length = ECMAScript.ToUint32(length);
+ this.byteLength = this.length * this.BYTES_PER_ELEMENT;
+ }
+
+ if ((this.byteOffset + this.byteLength) > this.buffer.byteLength) {
+ throw new_INDEX_SIZE_ERR(); // byteOffset and length reference an area beyond the end of the buffer
+ }
+ } else {
+ throw new TypeError("Unexpected argument type(s)");
+ }
+
+ this.constructor = ctor;
+
+ configureProperties(this);
+ makeArrayAccessors(this);
+ };
+
+ ctor.prototype = new ArrayBufferView();
+ ctor.prototype.BYTES_PER_ELEMENT = bytesPerElement;
+ ctor.prototype._pack = pack;
+ ctor.prototype._unpack = unpack;
+ ctor.BYTES_PER_ELEMENT = bytesPerElement;
+
+ // getter type (unsigned long index);
+ ctor.prototype._getter = function (index) {
+ if (arguments.length < 1) { throw new SyntaxError("Not enough arguments"); }
+
+ index = ECMAScript.ToUint32(index);
+ if (index >= this.length) {
+ //throw new_INDEX_SIZE_ERR(); // Array index out of range
+ return (void 0); // undefined
+ }
+
+ var bytes = [], i, o;
+ for (i = 0, o = this.byteOffset + index * this.BYTES_PER_ELEMENT;
+ i < this.BYTES_PER_ELEMENT;
+ i += 1, o += 1) {
+ bytes.push(this.buffer._bytes[o]);
+ }
+ return this._unpack(bytes);
+ };
+
+ // NONSTANDARD: convenience alias for getter: type get(unsigned long index);
+ ctor.prototype.get = ctor.prototype._getter;
+
+ // setter void (unsigned long index, type value);
+ ctor.prototype._setter = function (index, value) {
+ if (arguments.length < 2) { throw new SyntaxError("Not enough arguments"); }
+
+ index = ECMAScript.ToUint32(index);
+ if (index >= this.length) {
+ //throw new_INDEX_SIZE_ERR(); // Array index out of range
+ return;
+ }
+
+ var bytes = this._pack(value), i, o;
+ for (i = 0, o = this.byteOffset + index * this.BYTES_PER_ELEMENT;
+ i < this.BYTES_PER_ELEMENT;
+ i += 1, o += 1) {
+ this.buffer._bytes[o] = bytes[i];
+ }
+ };
+
+ // void set(TypedArray array, optional unsigned long offset);
+ // void set(sequence<type> array, optional unsigned long offset);
+ ctor.prototype.set = function (index, value) {
+ if (arguments.length < 1) { throw new SyntaxError("Not enough arguments"); }
+ var array, sequence, offset, len,
+ i, s, d,
+ byteOffset, byteLength, tmp;
+
+ if (typeof arguments[0] === 'object' && arguments[0].constructor === this.constructor) {
+ // void set(TypedArray array, optional unsigned long offset);
+ array = arguments[0];
+ offset = ECMAScript.ToUint32(arguments[1]);
+
+ if (offset + array.length > this.length) {
+ throw new_INDEX_SIZE_ERR(); // Offset plus length of array is out of range
+ }
+
+ byteOffset = this.byteOffset + offset * this.BYTES_PER_ELEMENT;
+ byteLength = array.length * this.BYTES_PER_ELEMENT;
+
+ if (array.buffer === this.buffer) {
+ tmp = [];
+ for (i = 0, s = array.byteOffset; i < byteLength; i += 1, s += 1) {
+ tmp[i] = array.buffer._bytes[s];
+ }
+ for (i = 0, d = byteOffset; i < byteLength; i += 1, d += 1) {
+ this.buffer._bytes[d] = tmp[i];
+ }
+ } else {
+ for (i = 0, s = array.byteOffset, d = byteOffset;
+ i < byteLength; i += 1, s += 1, d += 1) {
+ this.buffer._bytes[d] = array.buffer._bytes[s];
+ }
+ }
+ } else if (typeof arguments[0] === 'object' && typeof arguments[0].length !== 'undefined') {
+ // void set(sequence<type> array, optional unsigned long offset);
+ sequence = arguments[0];
+ len = ECMAScript.ToUint32(sequence.length);
+ offset = ECMAScript.ToUint32(arguments[1]);
+
+ if (offset + len > this.length) {
+ throw new_INDEX_SIZE_ERR(); // Offset plus length of array is out of range
+ }
+
+ for (i = 0; i < len; i += 1) {
+ s = sequence[i];
+ this._setter(offset + i, Number(s));
+ }
+ } else {
+ throw new TypeError("Unexpected argument type(s)");
+ }
+ };
+
+ // TypedArray subarray(long begin, optional long end);
+ ctor.prototype.subarray = function (start, end) {
+ function clamp(v, min, max) { return v < min ? min : v > max ? max : v; }
+
+ start = ECMAScript.ToInt32(start);
+ end = ECMAScript.ToInt32(end);
+
+ if (arguments.length < 1) { start = 0; }
+ if (arguments.length < 2) { end = this.length; }
+
+ if (start < 0) { start = this.length + start; }
+ if (end < 0) { end = this.length + end; }
+
+ start = clamp(start, 0, this.length);
+ end = clamp(end, 0, this.length);
+
+ var len = end - start;
+ if (len < 0) {
+ len = 0;
+ }
+
+ return new this.constructor(this.buffer, start * this.BYTES_PER_ELEMENT, len);
+ };
+
+ return ctor;
+ }
+
+ var Int8Array = makeTypedArrayConstructor(1, packInt8, unpackInt8);
+ var Uint8Array = makeTypedArrayConstructor(1, packUint8, unpackUint8);
+ var Int16Array = makeTypedArrayConstructor(2, packInt16, unpackInt16);
+ var Uint16Array = makeTypedArrayConstructor(2, packUint16, unpackUint16);
+ var Int32Array = makeTypedArrayConstructor(4, packInt32, unpackInt32);
+ var Uint32Array = makeTypedArrayConstructor(4, packUint32, unpackUint32);
+ var Float32Array = makeTypedArrayConstructor(4, packFloat32, unpackFloat32);
+ var Float64Array = makeTypedArrayConstructor(8, packFloat64, unpackFloat64);
+
+ if (USE_NATIVE_IF_AVAILABLE) {
+ global.ArrayBuffer = global.ArrayBuffer || ArrayBuffer;
+ global.Int8Array = global.Int8Array || Int8Array;
+ global.Uint8Array = global.Uint8Array || Uint8Array;
+ global.Int16Array = global.Int16Array || Int16Array;
+ global.Uint16Array = global.Uint16Array || Uint16Array;
+ global.Int32Array = global.Int32Array || Int32Array;
+ global.Uint32Array = global.Uint32Array || Uint32Array;
+ global.Float32Array = global.Float32Array || Float32Array;
+ global.Float64Array = global.Float64Array || Float64Array;
+ } else {
+ global.ArrayBuffer = ArrayBuffer;
+ global.Int8Array = Int8Array;
+ global.Uint8Array = Uint8Array;
+ global.Int16Array = Int16Array;
+ global.Uint16Array = Uint16Array;
+ global.Int32Array = Int32Array;
+ global.Uint32Array = Uint32Array;
+ global.Float32Array = Float32Array;
+ global.Float64Array = Float64Array;
+ }
+ } ());
+
+ //
+ // 6 The DataView View Type
+ //
+
+ (function () {
+ function r(array, index) {
+ return ECMAScript.IsCallable(array.get) ? array.get(index) : array[index];
+ }
+
+
+ var IS_BIG_ENDIAN = (function () {
+ var u16array = new Uint16Array([0x1234]),
+ u8array = new Uint8Array(u16array.buffer);
+ return r(u8array, 0) === 0x12;
+ } ());
+
+ // Constructor(ArrayBuffer buffer,
+ // optional unsigned long byteOffset,
+ // optional unsigned long byteLength)
+ /** @constructor */
+ var DataView = function DataView(buffer, byteOffset, byteLength) {
+ if (arguments.length === 0) {
+ buffer = new ArrayBuffer(0);
+ } else if (!(buffer instanceof ArrayBuffer || ECMAScript.Class(buffer) === 'ArrayBuffer')) {
+ throw new TypeError("TypeError");
+ }
+
+ this.buffer = buffer || new ArrayBuffer(0);
+
+ this.byteOffset = ECMAScript.ToUint32(byteOffset);
+ if (this.byteOffset > this.buffer.byteLength) {
+ throw new_INDEX_SIZE_ERR(); // byteOffset out of range
+ }
+
+ if (arguments.length < 3) {
+ this.byteLength = this.buffer.byteLength - this.byteOffset;
+ } else {
+ this.byteLength = ECMAScript.ToUint32(byteLength);
+ }
+
+ if ((this.byteOffset + this.byteLength) > this.buffer.byteLength) {
+ throw new_INDEX_SIZE_ERR(); // byteOffset and length reference an area beyond the end of the buffer
+ }
+
+ configureProperties(this);
+ };
+
+ // TODO: Reintroduce this to get correct hierarchy
+ //if (typeof ArrayBufferView === 'function') {
+ // DataView.prototype = new ArrayBufferView();
+ //}
+
+ function makeDataView_getter(arrayType) {
+ return function (byteOffset, littleEndian) {
+
+ byteOffset = ECMAScript.ToUint32(byteOffset);
+
+ if (byteOffset + arrayType.BYTES_PER_ELEMENT > this.byteLength) {
+ throw new_INDEX_SIZE_ERR(); // Array index out of range
+ }
+ byteOffset += this.byteOffset;
+
+ var uint8Array = new Uint8Array(this.buffer, byteOffset, arrayType.BYTES_PER_ELEMENT),
+ bytes = [], i;
+ for (i = 0; i < arrayType.BYTES_PER_ELEMENT; i += 1) {
+ bytes.push(r(uint8Array, i));
+ }
+
+ if (Boolean(littleEndian) === Boolean(IS_BIG_ENDIAN)) {
+ bytes.reverse();
+ }
+
+ return r(new arrayType(new Uint8Array(bytes).buffer), 0);
+ };
+ }
+
+ DataView.prototype.getUint8 = makeDataView_getter(Uint8Array);
+ DataView.prototype.getInt8 = makeDataView_getter(Int8Array);
+ DataView.prototype.getUint16 = makeDataView_getter(Uint16Array);
+ DataView.prototype.getInt16 = makeDataView_getter(Int16Array);
+ DataView.prototype.getUint32 = makeDataView_getter(Uint32Array);
+ DataView.prototype.getInt32 = makeDataView_getter(Int32Array);
+ DataView.prototype.getFloat32 = makeDataView_getter(Float32Array);
+ DataView.prototype.getFloat64 = makeDataView_getter(Float64Array);
+
+ function makeDataView_setter(arrayType) {
+ return function (byteOffset, value, littleEndian) {
+
+ byteOffset = ECMAScript.ToUint32(byteOffset);
+ if (byteOffset + arrayType.BYTES_PER_ELEMENT > this.byteLength) {
+ throw new_INDEX_SIZE_ERR(); // Array index out of range
+ }
+
+ // Get bytes
+ var typeArray = new arrayType([value]),
+ byteArray = new Uint8Array(typeArray.buffer),
+ bytes = [], i, byteView;
+
+ for (i = 0; i < arrayType.BYTES_PER_ELEMENT; i += 1) {
+ bytes.push(r(byteArray, i));
+ }
+
+ // Flip if necessary
+ if (Boolean(littleEndian) === Boolean(IS_BIG_ENDIAN)) {
+ bytes.reverse();
+ }
+
+ // Write them
+ byteView = new Uint8Array(this.buffer, byteOffset, arrayType.BYTES_PER_ELEMENT);
+ byteView.set(bytes);
+ };
+ }
+
+ DataView.prototype.setUint8 = makeDataView_setter(Uint8Array);
+ DataView.prototype.setInt8 = makeDataView_setter(Int8Array);
+ DataView.prototype.setUint16 = makeDataView_setter(Uint16Array);
+ DataView.prototype.setInt16 = makeDataView_setter(Int16Array);
+ DataView.prototype.setUint32 = makeDataView_setter(Uint32Array);
+ DataView.prototype.setInt32 = makeDataView_setter(Int32Array);
+ DataView.prototype.setFloat32 = makeDataView_setter(Float32Array);
+ DataView.prototype.setFloat64 = makeDataView_setter(Float64Array);
+
+ if (USE_NATIVE_IF_AVAILABLE) {
+ global.DataView = global.DataView || DataView;
+ } else {
+ global.DataView = DataView;
+ }
+
+ } ());
+
+} (this));
Please sign in to comment.
Something went wrong with that request. Please try again.