2018-04-07 03:27:22 +02:00
|
|
|
import {
|
|
|
|
HEADER_SIZE,
|
|
|
|
MAX_BLENGTH,
|
2018-08-02 18:23:02 +02:00
|
|
|
allocateUnsafe
|
2018-04-07 03:27:22 +02:00
|
|
|
} from "./internal/arraybuffer";
|
2018-03-23 01:47:01 +01:00
|
|
|
|
2018-03-23 12:45:29 +01:00
|
|
|
@sealed
|
2018-03-23 01:47:01 +01:00
|
|
|
export class ArrayBuffer {
|
|
|
|
|
2018-04-07 03:27:22 +02:00
|
|
|
readonly byteLength: i32; // capped to [0, MAX_LENGTH]
|
2018-03-23 01:47:01 +01:00
|
|
|
|
2018-06-20 15:51:47 +02:00
|
|
|
constructor(length: i32, unsafe: bool = false) {
|
2018-04-07 03:27:22 +02:00
|
|
|
if (<u32>length > <u32>MAX_BLENGTH) throw new RangeError("Invalid array buffer length");
|
2018-08-02 18:23:02 +02:00
|
|
|
var buffer = allocateUnsafe(length);
|
2018-07-18 23:49:32 +02:00
|
|
|
if (!unsafe) memory.fill(changetype<usize>(buffer) + HEADER_SIZE, 0, <usize>length);
|
2018-04-07 03:27:22 +02:00
|
|
|
return buffer;
|
2018-03-23 01:47:01 +01:00
|
|
|
}
|
|
|
|
|
2018-04-07 03:27:22 +02:00
|
|
|
slice(begin: i32 = 0, end: i32 = MAX_BLENGTH): ArrayBuffer {
|
2018-03-23 01:47:01 +01:00
|
|
|
var len = this.byteLength;
|
|
|
|
if (begin < 0) begin = max(len + begin, 0);
|
|
|
|
else begin = min(begin, len);
|
|
|
|
if (end < 0) end = max(len + end, 0);
|
|
|
|
else end = min(end, len);
|
|
|
|
var newLen = max(end - begin, 0);
|
2018-08-02 18:23:02 +02:00
|
|
|
var buffer = allocateUnsafe(newLen);
|
2018-07-18 23:49:32 +02:00
|
|
|
memory.copy(changetype<usize>(buffer) + HEADER_SIZE, changetype<usize>(this) + HEADER_SIZE + begin, newLen);
|
2018-04-07 03:27:22 +02:00
|
|
|
return buffer;
|
2018-03-23 01:47:01 +01:00
|
|
|
}
|
|
|
|
}
|