| 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;
|
| }
|
|
|