Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(897)

Unified Diff: runtime/lib/byte_array.dart

Issue 10379018: Revert "Revert "Implement {Int,Uint}{8,16,32,64} and Float{32,64} typed arrays."" (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: runtime/lib/byte_array.dart
diff --git a/runtime/lib/byte_array.dart b/runtime/lib/byte_array.dart
index 7a807d7aa246406e893ba9b1097b01ff29fa7a36..df48640e32f15118b38d1e9b24ad0f4c5805f81a 100644
--- a/runtime/lib/byte_array.dart
+++ b/runtime/lib/byte_array.dart
@@ -2,10 +2,10 @@
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
-interface ByteArray extends List default _InternalByteArray {
- ByteArray(int length);
+interface ByteArray {
+ int lengthInBytes();
- int get length();
+ ByteArray subByteArray([int start, int length]);
int getInt8(int byteOffset);
@@ -49,509 +49,2384 @@ interface ByteArray extends List default _InternalByteArray {
}
-class _ByteArrayBase {
+interface ByteArrayViewable {
+ int bytesPerElement();
- // Iterable interface
+ int lengthInBytes();
- Iterator iterator() {
- return new _ByteArrayIterator(this);
+ ByteArray asByteArray([int offsetInBytes, int lengthInBytes]);
+}
+
+
+interface Int8List extends List<int>, ByteArrayViewable
+ default _Int8ArrayFactory {
+ Int8List(int length);
+ Int8List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Uint8List extends List<int>, ByteArrayViewable
+ default _Uint8ArrayFactory {
+ Uint8List(int length);
+ Uint8List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Int16List extends List<int>, ByteArrayViewable
+ default _Int16ArrayFactory {
+ Int16List(int length);
+ Int16List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Uint16List extends List<int>, ByteArrayViewable
+ default _Uint16ArrayFactory {
+ Uint16List(int length);
+ Uint16List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Int32List extends List<int>, ByteArrayViewable
+ default _Int32ArrayFactory {
+ Int32List(int length);
+ Int32List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Uint32List extends List<int>, ByteArrayViewable
+ default _Uint32ArrayFactory {
+ Uint32List(int length);
+ Uint32List.view(ByteArray array, [int start, int length]);
+
+}
+
+
+interface Int64List extends List<int>, ByteArrayViewable
+ default _Int64ArrayFactory {
+ Int64List(int length);
+ Int64List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Uint64List extends List<int>, ByteArrayViewable
+ default _Uint64ArrayFactory {
+ Uint64List(int length);
+ Uint64List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Float32List extends List<double>, ByteArrayViewable
+ default _Float32ArrayFactory {
+ Float32List(int length);
+ Float32List.view(ByteArray array, [int start, int length]);
+}
+
+
+interface Float64List extends List<double>, ByteArrayViewable
+ default _Float64ArrayFactory {
+ Float64List(int length);
+ Float64List.view(ByteArray array, [int start, int length]);
+}
+
+
+class _Int8ArrayFactory {
+ factory Int8List(int length) {
+ return new _Int8Array(length);
+ }
+
+ factory Int8List.view(ByteArray array, [int start, int length]) {
+ return new _Int8ArrayView(array, start, length);
+ }
+}
+
+
+class _Uint8ArrayFactory {
+ factory Uint8List(int length) {
+ return new _Uint8Array(length);
+ }
+
+ factory Uint8List.view(ByteArray array, [int start, int length]) {
+ return new _Uint8ArrayView(array, start, length);
+ }
+}
+
+
+class _Int16ArrayFactory {
+ factory Int16List(int length) {
+ return new _Int16Array(length);
+ }
+
+ factory Int16List.view(ByteArray array, [int start, int length]) {
+ return new _Int16ArrayView(array, start, length);
+ }
+}
+
+
+class _Uint16ArrayFactory {
+ factory Uint16List(int length) {
+ return new _Uint16Array(length);
+ }
+
+ factory Uint16List.view(ByteArray array, [int start, int length]) {
+ return new _Uint16ArrayView(array, start, length);
+ }
+}
+
+
+class _Int32ArrayFactory {
+ factory Int32List(int length) {
+ return new _Int32Array(length);
+ }
+
+ factory Int32List.view(ByteArray array, [int start, int length]) {
+ return new _Int32ArrayView(array, start, length);
+ }
+}
+
+
+class _Uint32ArrayFactory {
+ factory Uint32List(int length) {
+ return new _Uint32Array(length);
}
- // Collection interface
+ factory Uint32List.view(ByteArray array, [int start, int length]) {
+ return new _Uint32ArrayView(array, start, length);
+ }
+}
+
+
+class _Int64ArrayFactory {
+ factory Int64List(int length) {
+ return new _Int64Array(length);
+ }
+
+ factory Int64List.view(ByteArray array, [int start, int length]) {
+ return new _Int64ArrayView(array, start, length);
+ }
+}
+
+
+class _Uint64ArrayFactory {
+ factory Uint64List(int length) {
+ return new _Uint64Array(length);
+ }
+
+ factory Uint64List.view(ByteArray array, [int start, int length]) {
+ return new _Uint64ArrayView(array, start, length);
+ }
+}
+
+
+class _Float32ArrayFactory {
+ factory Float32List(int length) {
+ return new _Float32Array(length);
+ }
+
+ factory Float32List.view(ByteArray array, [int start, int length]) {
+ return new _Float32ArrayView(array, start, length);
+ }
+}
+
+
+class _Float64ArrayFactory {
+ factory Float64List(int length) {
+ return new _Float64Array(length);
+ }
+
+ factory Float64List.view(ByteArray array, [int start, int length]) {
+ return new _Float64ArrayView(array, start, length);
+ }
+}
+
+
+abstract class _ByteArrayBase {
+ void add(value) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
+ }
+
+ void addLast(value) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
+ }
+
+ void addAll(Collection value) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
+ }
+
+ void clear() {
+ throw const UnsupportedOperationException(
+ "Cannot remove from a non-extendable array");
+ }
+
+ void insertRange(int start, int length, [initialValue]) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
+ }
int get length() {
return _length();
}
-
- bool every(bool f(int element)) {
- return Collections.every(this, f);
+
+ set length(newLength) {
+ throw const UnsupportedOperationException(
+ "Cannot resize a non-extendable array");
+ }
+
+ int removeLast() {
+ throw const UnsupportedOperationException(
+ "Cannot remove from a non-extendable array");
+ }
+
+ void removeRange(int start, int length) {
+ throw const UnsupportedOperationException(
+ "Cannot remove from a non-extendable array");
+ }
+
+ ByteArray asByteArray([int offsetInBytes = 0, int lengthInBytes]) {
+ if (lengthInBytes === null) {
+ lengthInBytes = this.lengthInBytes();
+ }
+ return new _ByteArrayView(this, offsetInBytes, lengthInBytes);
+ }
+
+ int _length() native "ByteArray_getLength";
+
+ void _setRange(int startInBytes, int lengthInBytes,
+ _ByteArrayBase from, int startFromInBytes)
+ native "ByteArray_setRange";
+
+ int _getInt8(int byteOffset) native "ByteArray_getInt8";
+ void _setInt8(int byteOffset, int value) native "ByteArray_setInt8";
+
+ int _getUint8(int byteOffset) native "ByteArray_getUint8";
+ void _setUint8(int byteOffset, int value) native "ByteArray_setUint8";
+
+ int _getInt16(int byteOffset) native "ByteArray_getInt16";
+ void _setInt16(int byteOffset, int value) native "ByteArray_setInt16";
+
+ int _getUint16(int byteOffset) native "ByteArray_getUint16";
+ void _setUint16(int byteOffset, int value) native "ByteArray_setUint16";
+
+ int _getInt32(int byteOffset) native "ByteArray_getInt32";
+ void _setInt32(int byteOffset, int value) native "ByteArray_setInt32";
+
+ int _getUint32(int byteOffset) native "ByteArray_getUint32";
+ void _setUint32(int byteOffset, int value) native "ByteArray_setUint32";
+
+ int _getInt64(int byteOffset) native "ByteArray_getInt64";
+ void _setInt64(int byteOffset, int value) native "ByteArray_setInt64";
+
+ int _getUint64(int byteOffset) native "ByteArray_getUint64";
+ void _setUint64(int byteOffset, int value) native "ByteArray_setUint64";
+
+ double _getFloat32(int byteOffset) native "ByteArray_getFloat32";
+ void _setFloat32(int byteOffset, double value) native "ByteArray_setFloat32";
+
+ double _getFloat64(int byteOffset) native "ByteArray_getFloat64";
+ void _setFloat64(int byteOffset, double value) native "ByteArray_setFloat64";
+}
+
+
+int _toInt(int value, int mask) {
+ value &= mask;
+ if (value > (mask >> 1)) value -= mask + 1;
+ return value;
+}
+
+int _toInt8(int value) {
+ return _toInt(value, 0xFF);
+}
+int _toUint8(int value) {
+ return value & 0xFF;
+}
+
+
+int _toInt16(int value) {
+ return _toInt(value, 0xFFFF);
+}
+int _toUint16(int value) {
+ return value & 0xFFFF;
+}
+
+
+int _toInt32(int value) {
+ return _toInt(value, 0xFFFFFFFF);
+}
+int _toUint32(int value) {
+ return value & 0xFFFFFFFF;
+}
+
+
+int _toInt64(int value) {
+ return _toInt(value, 0xFFFFFFFFFFFFFFFF);
+}
+int _toUint64(int value) {
+ return value & 0xFFFFFFFFFFFFFFFF;
+}
+
+
+void _rangeCheck(List a, int start, int length) {
+ if (length < 0) {
+ throw new IllegalArgumentException("negative length $length");
+ }
+ if (start < 0) {
+ throw new IndexOutOfRangeException("negative start $start");
+ }
+ if (start + length > a.length) {
+ throw new IndexOutOfRangeException(start + length);
+ }
+}
+
+
+class _Int8Array extends _ByteArrayBase implements Int8List {
+ factory _Int8Array(int length) {
+ return _new(length);
+ }
+
+ factory _Int8Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = array.lengthInBytes();
+ }
+ return new _Int8ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toInt8(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Int8Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 1;
+
+ static _Int8Array _new(int length) native "Int8Array_new";
+
+ int _getIndexed(int index) native "Int8Array_getIndexed";
+ void _setIndexed(int index, int value) native "Int8Array_setIndexed";
+}
+
+
+class _Uint8Array extends _ByteArrayBase implements Uint8List {
+ factory _Uint8Array(int length) {
+ return _new(length);
+ }
+
+ factory _Uint8Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = array.lengthInBytes();
+ }
+ return new _Uint8ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toUint8(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Uint8Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 1;
+
+ static _Uint8Array _new(int length) native "Uint8Array_new";
+
+ int _getIndexed(int index) native "Uint8Array_getIndexed";
+ void _setIndexed(int index, int value) native "Uint8Array_setIndexed";
+}
+
+
+class _Int16Array extends _ByteArrayBase implements Int16List {
+ factory _Int16Array(int length) {
+ return _new(length);
+ }
+
+ factory _Int16Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Int16ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toInt16(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Int16Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 2;
+
+ static _Int16Array _new(int length) native "Int16Array_new";
+
+ int _getIndexed(int index) native "Int16Array_getIndexed";
+ void _setIndexed(int index, int value) native "Int16Array_setIndexed";
+}
+
+
+class _Uint16Array extends _ByteArrayBase implements Uint16List {
+ factory _Uint16Array(int length) {
+ return _new(length);
+ }
+
+ factory _Uint16Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Uint16ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toUint16(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Uint16Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 2;
+
+ static _Uint16Array _new(int length) native "Uint16Array_new";
+
+ int _getIndexed(int index) native "Uint16Array_getIndexed";
+ void _setIndexed(int index, int value) native "Uint16Array_setIndexed";
+}
+
+
+class _Int32Array extends _ByteArrayBase implements Int32List {
+ factory _Int32Array(int length) {
+ return _new(length);
+ }
+
+ factory _Int32Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Int32ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toInt32(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Int32Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 4;
+
+ static _Int32Array _new(int length) native "Int32Array_new";
+
+ int _getIndexed(int index) native "Int32Array_getIndexed";
+ void _setIndexed(int index, int value) native "Int32Array_setIndexed";
+}
+
+
+class _Uint32Array extends _ByteArrayBase implements Uint32List {
+ factory _Uint32Array(int length) {
+ return _new(length);
+ }
+
+ factory _Uint32Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Uint32ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toUint32(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Uint32Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 4;
+
+ static _Uint32Array _new(int length) native "Uint32Array_new";
+
+ int _getIndexed(int index) native "Uint32Array_getIndexed";
+ void _setIndexed(int index, int value) native "Uint32Array_setIndexed";
+}
+
+
+class _Int64Array extends _ByteArrayBase implements Int64List {
+ factory _Int64Array(int length) {
+ return _new(length);
+ }
+
+ factory _Int64Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Int64ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toInt64(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Int64Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 8;
+
+ static _Int64Array _new(int length) native "Int64Array_new";
+
+ int _getIndexed(int index) native "Int64Array_getIndexed";
+ void _setIndexed(int index, int value) native "Int64Array_setIndexed";
+}
+
+
+class _Uint64Array extends _ByteArrayBase implements Uint64List {
+ factory _Uint64Array(int length) {
+ return _new(length);
+ }
+
+ factory _Uint64Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Uint64ArrayView(array, start, length);
+ }
+
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, int value) {
+ _setIndexed(index, _toUint64(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _Uint64Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 8;
+
+ static _Uint64Array _new(int length) native "Uint64Array_new";
+
+ int _getIndexed(int index) native "Uint64Array_getIndexed";
+ void _setIndexed(int index, int value) native "Uint64Array_setIndexed";
+}
+
+
+class _Float32Array extends _ByteArrayBase implements Float32List {
+ factory _Float32Array(int length) {
+ return _new(length);
+ }
+
+ factory _Float32Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Float32ArrayView(array, start, length);
+ }
+
+ double operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, double value) {
+ _setIndexed(index, value);
+ }
+
+ Iterator<double> iterator() {
+ return new _ByteArrayIterator<double>(this);
+ }
+
+ List<double> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<double> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<double> from, [int startFrom = 0]) {
+ if (from is _Float32Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 4;
+
+ static _Float32Array _new(int length) native "Float32Array_new";
+
+ double _getIndexed(int index) native "Float32Array_getIndexed";
+ void _setIndexed(int index, double value) native "Float32Array_setIndexed";
+}
+
+
+class _Float64Array extends _ByteArrayBase implements Float64List {
+ factory _Float64Array(int length) {
+ return _new(length);
+ }
+
+ factory _Float64Array.view(ByteArray array, [int start = 0, int length]) {
+ if (length === null) {
+ length = (array.lengthInBytes() - start) ~/ _BYTES_PER_ELEMENT;
+ }
+ return new _Float64ArrayView(array, start, length);
+ }
+
+ double operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ void operator[]=(int index, double value) {
+ _setIndexed(index, value);
+ }
+
+ Iterator<double> iterator() {
+ return new _ByteArrayIterator<double>(this);
+ }
+
+ List<double> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<double> result = _new(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<double> from, [int startFrom = 0]) {
+ if (from is _Float64Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 8;
+
+ static _Float64Array _new(int length) native "Float64Array_new";
+
+ double _getIndexed(int index) native "Float64Array_getIndexed";
+ void _setIndexed(int index, double value) native "Float64Array_setIndexed";
+}
+
+
+class _ExternalInt8Array extends _ByteArrayBase implements Int8List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toInt8(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int8List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalInt8Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 1;
+
+ int _getIndexed(int index) native "ExternalInt8Array_getIndexed";
+ void _setIndexed(int index, int value) native "ExternalInt8Array_setIndexed";
+}
+
+
+class _ExternalUint8Array extends _ByteArrayBase implements Uint8List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toUint8(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint8List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalUint8Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 1;
+
+ int _getIndexed(int index) native "ExternalUint8Array_getIndexed";
+ void _setIndexed(int index, int value) native "ExternalUint8Array_setIndexed";
+}
+
+
+class _ExternalInt16Array extends _ByteArrayBase implements Int16List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toInt16(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int16List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalInt16Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 2;
+
+ int _getIndexed(int index) native "ExternalInt16Array_getIndexed";
+ void _setIndexed(int index, int value) native "ExternalInt16Array_setIndexed";
+}
+
+
+class _ExternalUint16Array extends _ByteArrayBase implements Uint16List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toUint16(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint16List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalUint16Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 2;
+
+ int _getIndexed(int index)
+ native "ExternalUint16Array_getIndexed";
+ void _setIndexed(int index, int value)
+ native "ExternalUint16Array_setIndexed";
+}
+
+
+class _ExternalInt32Array extends _ByteArrayBase implements Int32List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toInt32(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int32List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalInt32Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 4;
+
+ int _getIndexed(int index)
+ native "ExternalInt32Array_getIndexed";
+ void _setIndexed(int index, int value)
+ native "ExternalInt32Array_setIndexed";
+}
+
+
+class _ExternalUint32Array extends _ByteArrayBase implements Uint32List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toUint32(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint32List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalUint32Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 4;
+
+ int _getIndexed(int index)
+ native "ExternalUint32Array_getIndexed";
+ void _setIndexed(int index, int value)
+ native "ExternalUint32Array_setIndexed";
+}
+
+
+class _ExternalInt64Array extends _ByteArrayBase implements Int64List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toInt64(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int64List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalInt64Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 8;
+
+ int _getIndexed(int index)
+ native "ExternalInt64Array_getIndexed";
+ void _setIndexed(int index, int value)
+ native "ExternalInt64Array_setIndexed";
+}
+
+
+class _ExternalUint64Array extends _ByteArrayBase implements Uint64List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, int value) {
+ _setIndexed(index, _toUint64(value));
+ }
+
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
+
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint64List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ if (from is _ExternalUint64Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 8;
+
+ int _getIndexed(int index)
+ native "ExternalUint64Array_getIndexed";
+ void _setIndexed(int index, int value)
+ native "ExternalUint64Array_setIndexed";
+}
+
+
+class _ExternalFloat32Array extends _ByteArrayBase implements Float32List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, double value) {
+ _setIndexed(index, value);
+ }
+
+ Iterator<double> iterator() {
+ return new _ByteArrayIterator<double>(this);
+ }
+
+ List<double> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<double> result = new Float32List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<double> from, [int startFrom = 0]) {
+ if (from is _ExternalFloat32Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 4;
+
+ double _getIndexed(int index)
+ native "ExternalFloat32Array_getIndexed";
+ void _setIndexed(int index, double value)
+ native "ExternalFloat32Array_setIndexed";
+}
+
+
+class _ExternalFloat64Array extends _ByteArrayBase implements Float64List {
+ int operator[](int index) {
+ return _getIndexed(index);
+ }
+
+ int operator[]=(int index, double value) {
+ _setIndexed(index, value);
+ }
+
+ Iterator<double> iterator() {
+ return new _ByteArrayIterator<double>(this);
+ }
+
+ List<double> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<double> result = new Float64List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
+
+ void setRange(int start, int length, List<double> from, [int startFrom = 0]) {
+ if (from is _ExternalFloat64Array) {
+ int startInBytes = start * _BYTES_PER_ELEMENT;
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ int startFromInBytes = startFrom * _BYTES_PER_ELEMENT;
+ _setRange(startInBytes, lengthInBytes, from, startFromInBytes);
+ } else {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
+ }
+
+ String toString() {
+ return Collections.collectionToString(this);
+ }
+
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length() * _BYTES_PER_ELEMENT;
+ }
+
+ static final int _BYTES_PER_ELEMENT = 8;
+
+ double _getIndexed(int index)
+ native "ExternalFloat64Array_getIndexed";
+ void _setIndexed(int index, double value)
+ native "ExternalFloat64Array_setIndexed";
+}
+
+
+class _ByteArrayIterator<E> implements Iterator<E> {
+ _ByteArrayIterator(_ByteArrayBase array)
+ : _array = array, _length = array.length, _pos = 0;
+
+ bool hasNext() {
+ return _length > _pos;
+ }
+
+ E next() {
+ if (!hasNext()) {
+ throw const NoMoreElementsException();
+ }
+ return _array[_pos++];
+ }
+
+ final List<E> _array;
+
+ final int _length;
+
+ int _pos;
+}
+
+
+class _ByteArrayView implements ByteArray {
+ _ByteArrayView(this._array, this._offset, this._length) {
+ }
+
+ int lengthInBytes() {
+ return _length;
+ }
+
+ ByteArray subByteArray([int start = 0, int length]) {
+ if (length === null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return new _ByteArrayView(_array, _offset + start, length);
+ }
+
+ int getInt8(int byteOffset) {
+ return _array._getInt8(_offset + byteOffset);
+ }
+ void setInt8(int byteOffset, int value) {
+ _array._setInt8(_offset + byteOffset, value);
+ }
+
+ int getUint8(int byteOffset) {
+ return _array._getUint8(_offset + byteOffset);
+ }
+ void setUint8(int byteOffset, int value) {
+ _array._setUint8(_offset + byteOffset, value);
+ }
+
+ int getInt16(int byteOffset) {
+ return _array._getInt16(_offset + byteOffset);
+ }
+ void setInt16(int byteOffset, int value) {
+ _array._setInt16(_offset + byteOffset, value);
+ }
+
+ int getUint16(int byteOffset) {
+ return _array._getUint16(_offset + byteOffset);
+ }
+ void setUint16(int byteOffset, int value) {
+ _array._setUint16(_offset + byteOffset, value);
+ }
+
+ int getInt32(int byteOffset) {
+ return _array._getInt32(_offset + byteOffset);
+ }
+ void setInt32(int byteOffset, int value) {
+ _array._setInt32(_offset + byteOffset, value);
+ }
+
+ int getUint32(int byteOffset) {
+ return _array._getUint32(_offset + byteOffset);
+ }
+ void setUint32(int byteOffset, int value) {
+ _array._setUint32(_offset + byteOffset, value);
+ }
+
+ int getInt64(int byteOffset) {
+ return _array._getInt64(_offset + byteOffset);
+ }
+ void setInt64(int byteOffset, int value) {
+ _array._setInt64(_offset + byteOffset, value);
}
- Collection map(f(int element)) {
- return Collections.map(this,
- new GrowableObjectArray.withCapacity(length),
- f);
+ int getUint64(int byteOffset) {
+ return _array._getUint64(_offset + byteOffset);
+ }
+ void setUint64(int byteOffset, int value) {
+ _array._setUint64(_offset + byteOffset, value);
}
- Collection filter(bool f(int element)) {
- return Collections.filter(this, new GrowableObjectArray(), f);
+ double getFloat32(int byteOffset) {
+ return _array._getFloat32(_offset + byteOffset);
+ }
+ void setFloat32(int byteOffset, double value) {
+ _array._setFloat32(_offset + byteOffset, value);
}
- void forEach(f(int element)) {
- Collections.forEach(this, f);
+ double getFloat64(int byteOffset) {
+ return _array._getFloat64(_offset + byteOffset);
+ }
+ void setFloat64(int byteOffset, double value) {
+ _array._setFloat64(_offset + byteOffset, value);
}
- bool isEmpty() {
- return this.length === 0;
+ final _ByteArrayBase _array;
+ final int _offset;
+ final int _length;
+}
+
+
+class _ByteArrayViewBase {
+ void add(value) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
}
- bool some(bool f(int element)) {
- return Collections.some(this, f);
+ void addLast(value) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
}
- // List interface
+ void addAll(Collection value) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
+ }
- int operator[](int index) {
- return getUint8(index);
+ void clear() {
+ throw const UnsupportedOperationException(
+ "Cannot remove from a non-extendable array");
}
- void operator[]=(int index, int value) {
- setUint8(index, value);
+ void insertRange(int start, int length, [initialValue]) {
+ throw const UnsupportedOperationException(
+ "Cannot add to a non-extendable array");
}
- void set length(int newLength) {
- throw const UnsupportedOperationException("Cannot add to a byte array");
+ set length(int newLength) {
+ throw const UnsupportedOperationException(
+ "Cannot resize a non-extendable array");
}
- void add(int element) {
- throw const UnsupportedOperationException("Cannot add to a byte array");
+ int removeLast() {
+ throw const UnsupportedOperationException(
+ "Cannot remove from a non-extendable array");
}
- void addLast(int element) {
- add(element);
+ void removeRange(int start, int length) {
+ throw const UnsupportedOperationException(
+ "Cannot remove from a non-extendable array");
}
+}
+
- void addAll(Collection elements) {
- throw const UnsupportedOperationException("Cannot add to a byte array");
+class _Int8ArrayView extends _ByteArrayViewBase implements Int8List {
+ _Int8ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- void sort(int compare(int a, b)) {
- DualPivotQuicksort.sort(this, compare);
+ get length() {
+ return _length;
}
- int indexOf(int element, [int start = 0]) {
- return Arrays.indexOf(this, element, start, this.length);
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getInt8(_offset + (index * _BYTES_PER_ELEMENT));
}
- int lastIndexOf(int element, [int start = null]) {
- if (start === null) start = length - 1;
- return Arrays.lastIndexOf(this, element, start);
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setInt8(_offset + (index * _BYTES_PER_ELEMENT), _toInt8(value));
}
- void clear() {
- throw const UnsupportedOperationException("Cannot clear a byte array");
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
}
- int removeLast() {
- throw const UnsupportedOperationException(
- "Cannot remove from a byte array");
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int8List(length);
+ result.setRange(0, length, this, start);
+ return result;
}
- int last() {
- return this[length - 1];
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
}
String toString() {
return Collections.collectionToString(this);
}
- void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
- if (length < 0) {
- throw new IllegalArgumentException("negative length $length");
- }
- if (from is ByteArray) {
- _setRange(start, length, from, startFrom);
- } else {
- Arrays.copy(from, startFrom, this, start, length);
- }
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
+
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
}
-
- List getRange(int start, int length) {
- if (length == 0) return [];
- Arrays.rangeCheck(this, start, length);
- ByteArray list = new ByteArray(length);
- list._setRange(0, length, this, start);
- return list;
+
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
}
- // Implementation
+ static final int _BYTES_PER_ELEMENT = 1;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
- static final int _UINT8_MAX = (1 << 8) - 1;
- static final int _UINT16_MAX = (1 << 16) - 1;
- static final int _UINT32_MAX = (1 << 32) - 1;
- static final int _UINT64_MAX = (1 << 64) - 1;
- int _toInt(int value, int mask) {
- int result = value & mask;
- return result > (mask >> 1) ? (result - mask) : result;
+class _Uint8ArrayView extends _ByteArrayViewBase implements Uint8List {
+ _Uint8ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- int _toInt8(int value) {
- return _toInt(value, _UINT8_MAX);
+ get length() {
+ return _length;
}
- int _toUint8(int value) {
- return value & _UINT8_MAX;
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getUint8(_offset + (index * _BYTES_PER_ELEMENT));
}
- int _toInt16(int value) {
- return _toInt(value, _UINT16_MAX);
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setUint8(_offset + (index * _BYTES_PER_ELEMENT), _toUint8(value));
}
- int _toUint16(int value) {
- return value & _UINT16_MAX;
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
}
- int _toInt32(int value) {
- return _toInt(value, _UINT32_MAX);
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint8List(length);
+ result.setRange(0, length, this, start);
+ return result;
}
- int _toUint32(int value) {
- return value & _UINT32_MAX;
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
}
- int _toInt64(int value) {
- return _toInt(value, _UINT64_MAX);
+ String toString() {
+ return Collections.collectionToString(this);
}
- int _toUint64(int value) {
- return value & _UINT64_MAX;
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
}
- int _length() native "ByteArray_getLength";
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
+ }
- void _setRange(int start, int length, ByteArray from, int startFrom)
- native "ByteArray_setRange";
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
+ }
+
+ static final int _BYTES_PER_ELEMENT = 1;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
}
-class _ByteArrayIterator implements Iterator {
- _ByteArrayIterator(List byteArray)
- : _byteArray = byteArray, _length = byteArray.length, _pos = 0 {
- assert(byteArray is ByteArray);
+class _Int16ArrayView extends _ByteArrayViewBase implements Int16List {
+ _Int16ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- bool hasNext() {
- return _length > _pos;
+ get length() {
+ return _length;
}
- int next() {
- if (!hasNext()) {
- throw const NoMoreElementsException();
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
}
- return _byteArray[_pos++];
+ return _array.getInt16(_offset + (index * _BYTES_PER_ELEMENT));
}
- final List _byteArray;
-
- final int _length;
-
- int _pos;
-}
-
-
-class _InternalByteArray extends _ByteArrayBase implements ByteArray {
- factory _InternalByteArray(int length) {
- return _allocate(length);
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setInt16(_offset + (index * _BYTES_PER_ELEMENT), _toInt16(value));
}
- // ByteArray interface
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
- int getInt8(int byteOffset) {
- return _getInt8(byteOffset);
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int16List(length);
+ result.setRange(0, length, this, start);
+ return result;
}
- void setInt8(int byteOffset, int value) {
- _setInt8(byteOffset, _toInt8(value));
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
}
- int getUint8(int byteOffset) {
- return _getUint8(byteOffset);
+ String toString() {
+ return Collections.collectionToString(this);
}
- void setUint8(int byteOffset, int value) {
- _setUint8(byteOffset, _toUint8(value));
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
}
- int getInt16(int byteOffset) {
- return _getInt16(byteOffset);
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
}
- void setInt16(int byteOffset, int value) {
- _setInt16(byteOffset, _toInt16(value));
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
}
- int getUint16(int byteOffset) {
- return _getInt16(byteOffset);
+ static final int _BYTES_PER_ELEMENT = 2;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
+
+
+class _Uint16ArrayView extends _ByteArrayViewBase implements Uint16List {
+ _Uint16ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- void setUint16(int byteOffset, int value) {
- _setUint16(byteOffset, _toUint16(value));
+ get length() {
+ return _length;
}
- int getInt32(int byteOffset) {
- return _getInt32(byteOffset);
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getUint16(_offset + (index * _BYTES_PER_ELEMENT));
}
- void setInt32(int byteOffset, int value) {
- _setInt32(byteOffset, _toInt32(value));
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setUint16(_offset + (index * _BYTES_PER_ELEMENT), _toUint16(value));
}
- int getUint32(int byteOffset) {
- return _getUint32(byteOffset);
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
}
- void setUint32(int byteOffset, int value) {
- _setUint32(byteOffset, _toUint32(value));
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint16List(length);
+ result.setRange(0, length, this, start);
+ return result;
}
- int getInt64(int byteOffset) {
- return _getInt64(byteOffset);
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
}
- void setInt64(int byteOffset, int value) {
- _setInt64(byteOffset, _toInt64(value));
+ String toString() {
+ return Collections.collectionToString(this);
}
- int getUint64(int byteOffset) {
- return _getUint64(byteOffset);
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
}
- void setUint64(int byteOffset, int value) {
- _setUint64(byteOffset, _toUint64(value));
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
}
- double getFloat32(int byteOffset) {
- return _getFloat32(byteOffset);
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
}
- void setFloat32(int byteOffset, double value) {
- _setFloat32(byteOffset, value);
+ static final int _BYTES_PER_ELEMENT = 2;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
+
+
+class _Int32ArrayView extends _ByteArrayViewBase implements Int32List {
+ _Int32ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- double getFloat64(int byteOffset) {
- return _getFloat64(byteOffset);
+ get length() {
+ return _length;
}
- void setFloat64(int byteOffset, double value) {
- _setFloat64(byteOffset, value);
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getInt32(_offset + (index * _BYTES_PER_ELEMENT));
}
- // Implementation
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setInt32(_offset + (index * _BYTES_PER_ELEMENT), _toInt32(value));
+ }
- static _InternalByteArray _allocate(int length)
- native "InternalByteArray_allocate";
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
- int _getInt8(int byteOffset)
- native "InternalByteArray_getInt8";
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int32List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
- void _setInt8(int byteOffset, int value)
- native "InternalByteArray_setInt8";
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
- int _getUint8(int byteOffset)
- native "InternalByteArray_getUint8";
+ String toString() {
+ return Collections.collectionToString(this);
+ }
- void _setUint8(int byteOffset, int value)
- native "InternalByteArray_setUint8";
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
- int _getInt16(int byteOffset)
- native "InternalByteArray_getInt16";
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
+ }
- void _setInt16(int byteOffset, int value)
- native "InternalByteArray_setInt16";
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
+ }
- int _getUint16(int byteOffset)
- native "InternalByteArray_getUint16";
+ static final int _BYTES_PER_ELEMENT = 4;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
- void _setUint16(int byteOffset, int value)
- native "InternalByteArray_setUint16";
- int _getInt32(int byteOffset)
- native "InternalByteArray_getInt32";
+class _Uint32ArrayView extends _ByteArrayViewBase implements Uint32List {
+ _Uint32ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
+ }
- void _setInt32(int byteOffset, int value)
- native "InternalByteArray_setInt32";
+ get length() {
+ return _length;
+ }
- int _getUint32(int byteOffset)
- native "InternalByteArray_getUint32";
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getUint32(_offset + (index * _BYTES_PER_ELEMENT));
+ }
- void _setUint32(int byteOffset, int value)
- native "InternalByteArray_setUint32";
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setUint32(_offset + (index * _BYTES_PER_ELEMENT), _toUint32(value));
+ }
- int _getInt64(int byteOffset)
- native "InternalByteArray_getInt64";
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
- void _setInt64(int byteOffset, int value)
- native "InternalByteArray_setInt64";
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint32List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
- int _getUint64(int byteOffset)
- native "InternalByteArray_getUint64";
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
- void _setUint64(int byteOffset, int value)
- native "InternalByteArray_setUint64";
+ String toString() {
+ return Collections.collectionToString(this);
+ }
- double _getFloat32(int byteOffset)
- native "InternalByteArray_getFloat32";
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
- void _setFloat32(int byteOffset, double value)
- native "InternalByteArray_setFloat32";
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
+ }
- double _getFloat64(int byteOffset)
- native "InternalByteArray_getFloat64";
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
+ }
- void _setFloat64(int byteOffset, double value)
- native "InternalByteArray_setFloat64";
+ static final int _BYTES_PER_ELEMENT = 4;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
}
-class _ExternalByteArray extends _ByteArrayBase implements ByteArray {
- // Collection interface
-
- int get length() {
- return _length();
+class _Int64ArrayView extends _ByteArrayViewBase implements Int64List {
+ _Int64ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- // List interface
+ get length() {
+ return _length;
+ }
int operator[](int index) {
- return _getUint8(index);
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getInt64(_offset + (index * _BYTES_PER_ELEMENT));
}
void operator[]=(int index, int value) {
- _setUint8(index, value);
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setInt64(_offset + (index * _BYTES_PER_ELEMENT), _toInt64(value));
}
- // ByteArray interface
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
+ }
- int getInt8(int byteOffset) {
- return _getInt8(byteOffset);
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Int64List(length);
+ result.setRange(0, length, this, start);
+ return result;
}
- void setInt8(int byteOffset, int value) {
- _setInt8(byteOffset, _toInt8(value));
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
}
- int getUint8(int byteOffset) {
- return _getUint8(byteOffset);
+ String toString() {
+ return Collections.collectionToString(this);
}
- void setUint8(int byteOffset, int value) {
- _setUint8(byteOffset, _toUint8(value));
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
}
- int getInt16(int byteOffset) {
- return _getInt16(byteOffset);
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
}
- void setInt16(int byteOffset, int value) {
- _setInt16(byteOffset, _toInt16(value));
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
}
- int getUint16(int byteOffset) {
- return _getInt16(byteOffset);
+ static final int _BYTES_PER_ELEMENT = 8;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
+
+
+class _Uint64ArrayView extends _ByteArrayViewBase implements Uint64List {
+ _Uint64ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- void setUint16(int byteOffset, int value) {
- _setUint16(byteOffset, _toUint16(value));
+ get length() {
+ return _length;
}
- int getInt32(int byteOffset) {
- return _getInt32(byteOffset);
+ int operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getUint64(_offset + (index * _BYTES_PER_ELEMENT));
}
- void setInt32(int byteOffset, int value) {
- _setInt32(byteOffset, _toInt32(value));
+ void operator[]=(int index, int value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setUint64(_offset + (index * _BYTES_PER_ELEMENT), _toUint64(value));
}
- int getUint32(int byteOffset) {
- return _getUint32(byteOffset);
+ Iterator<int> iterator() {
+ return new _ByteArrayIterator<int>(this);
}
- void setUint32(int byteOffset, int value) {
- _setUint32(byteOffset, _toUint32(value));
+ List<int> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<int> result = new Uint64List(length);
+ result.setRange(0, length, this, start);
+ return result;
}
- int getInt64(int byteOffset) {
- return _getInt64(byteOffset);
+ void setRange(int start, int length, List<int> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
}
- void setInt64(int byteOffset, int value) {
- _setInt64(byteOffset, _toInt64(value));
+ String toString() {
+ return Collections.collectionToString(this);
}
- int getUint64(int byteOffset) {
- return _getUint64(byteOffset);
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
}
- void setUint64(int byteOffset, int value) {
- _setUint64(byteOffset, _toUint64(value));
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
}
- double getFloat32(int byteOffset) {
- return _getFloat32(byteOffset);
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
}
- void setFloat32(int byteOffset, double value) {
- _setFloat32(byteOffset, value);
+ static final int _BYTES_PER_ELEMENT = 8;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
+
+
+class _Float32ArrayView extends _ByteArrayViewBase implements Float32List {
+ _Float32ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
}
- double getFloat64(int byteOffset) {
- return _getFloat64(byteOffset);
+ get length() {
+ return _length;
}
- void setFloat64(int byteOffset, double value) {
- _setFloat64(byteOffset, value);
+ double operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getFloat32(_offset + (index * _BYTES_PER_ELEMENT));
+ }
+
+ void operator[]=(int index, double value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setFloat32(_offset + (index * _BYTES_PER_ELEMENT), value);
}
- // Implementation
+ Iterator<double> iterator() {
+ return new _ByteArrayIterator<double>(this);
+ }
- int _getInt8(int byteOffset)
- native "ExternalByteArray_getInt8";
+ List<double> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<double> result = new Float32List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
- void _setInt8(int byteOffset, int value)
- native "ExternalByteArray_setInt8";
+ void setRange(int start, int length, List<double> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
- int _getUint8(int byteOffset)
- native "ExternalByteArray_getUint8";
+ String toString() {
+ return Collections.collectionToString(this);
+ }
- void _setUint8(int byteOffset, int value)
- native "ExternalByteArray_setUint8";
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
- int _getInt16(int byteOffset)
- native "ExternalByteArray_getInt16";
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
+ }
- void _setInt16(int byteOffset, int value)
- native "ExternalByteArray_setInt16";
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
+ }
- int _getUint16(int byteOffset)
- native "ExternalByteArray_getUint16";
+ static final int _BYTES_PER_ELEMENT = 4;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
+}
- void _setUint16(int byteOffset, int value)
- native "ExternalByteArray_setUint16";
- int _getInt32(int byteOffset)
- native "ExternalByteArray_getInt32";
+class _Float64ArrayView extends _ByteArrayViewBase implements Float64List {
+ _Float64ArrayView(ByteArray array, [int offsetInBytes = 0, int length])
+ : _array = array,
+ _offset = offsetInBytes,
+ _length = (length === null) ? (array.lengthInBytes() - offsetInBytes)
+ : length {
+ if (offsetInBytes < 0 || offsetInBytes >= array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(offsetInBytes);
+ }
+ int lengthInBytes = length * _BYTES_PER_ELEMENT;
+ if (length < 0 || (lengthInBytes + _offset) > array.lengthInBytes()) {
+ throw new IndexOutOfRangeException(length);
+ }
+ }
- void _setInt32(int byteOffset, int value)
- native "ExternalByteArray_setInt32";
+ get length() {
+ return _length;
+ }
- int _getUint32(int byteOffset)
- native "ExternalByteArray_getUint32";
+ double operator[](int index) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ return _array.getFloat64(_offset + (index * _BYTES_PER_ELEMENT));
+ }
- void _setUint32(int byteOffset, int value)
- native "ExternalByteArray_setUint32";
+ void operator[]=(int index, double value) {
+ if (index < 0 || index >= _length) {
+ throw new IndexOutOfRangeException(index);
+ }
+ _array.setFloat64(_offset + (index * _BYTES_PER_ELEMENT), value);
+ }
- int _getInt64(int byteOffset)
- native "ExternalByteArray_getInt64";
+ Iterator<double> iterator() {
+ return new _ByteArrayIterator<double>(this);
+ }
- void _setInt64(int byteOffset, int value)
- native "ExternalByteArray_setInt64";
+ List<double> getRange(int start, int length) {
+ _rangeCheck(this, start, length);
+ List<double> result = new Float64List(length);
+ result.setRange(0, length, this, start);
+ return result;
+ }
- int _getUint64(int byteOffset)
- native "ExternalByteArray_getUint64";
+ void setRange(int start, int length, List<double> from, [int startFrom = 0]) {
+ Arrays.copy(from, startFrom, this, start, length);
+ }
- void _setUint64(int byteOffset, int value)
- native "ExternalByteArray_setUint64";
+ String toString() {
+ return Collections.collectionToString(this);
+ }
- double _getFloat32(int byteOffset)
- native "ExternalByteArray_getFloat32";
+ int bytesPerElement() {
+ return _BYTES_PER_ELEMENT;
+ }
- void _setFloat32(int byteOffset, double value)
- native "ExternalByteArray_setFloat32";
+ int lengthInBytes() {
+ return _length * _BYTES_PER_ELEMENT;
+ }
- double _getFloat64(int byteOffset)
- native "ExternalByteArray_getFloat64";
+ ByteArray asByteArray([int start = 0, int length]) {
+ if (length == null) {
+ length = this.lengthInBytes();
+ }
+ _rangeCheck(start, length);
+ return _array.subByteArray(_offset + start, length);
+ }
- void _setFloat64(int byteOffset, double value)
- native "ExternalByteArray_setFloat64";
+ static final int _BYTES_PER_ELEMENT = 8;
+ final ByteArray _array;
+ final int _offset;
+ final int _length;
}

Powered by Google App Engine
This is Rietveld 408576698