2021-07-07 00:04:02 +00:00
|
|
|
import { DiskOptions, BlockDisk, ENCODING_BLOCK } from './types';
|
|
|
|
|
2021-01-03 23:00:40 +00:00
|
|
|
/**
|
|
|
|
* Returns a `Disk` object for a block volume with block-ordered data.
|
2021-07-07 00:04:02 +00:00
|
|
|
* @param options the disk image and options
|
2021-01-03 23:00:40 +00:00
|
|
|
*/
|
2021-07-07 00:04:02 +00:00
|
|
|
export default function createBlockDisk(options: DiskOptions): BlockDisk {
|
|
|
|
const { rawData, readOnly, name } = options;
|
|
|
|
|
|
|
|
if (!rawData) {
|
|
|
|
throw new Error('Requires rawData');
|
|
|
|
}
|
2020-01-02 19:11:04 +00:00
|
|
|
|
2021-07-07 00:04:02 +00:00
|
|
|
const blocks = [];
|
|
|
|
let offset = 0;
|
2020-01-02 19:11:04 +00:00
|
|
|
while (offset < rawData.byteLength) {
|
|
|
|
blocks.push(new Uint8Array(rawData.slice(offset, offset + 0x200)));
|
|
|
|
offset += 0x200;
|
|
|
|
}
|
|
|
|
|
2021-07-07 00:04:02 +00:00
|
|
|
const disk: BlockDisk = {
|
|
|
|
encoding: ENCODING_BLOCK,
|
2020-01-02 19:11:04 +00:00
|
|
|
blocks,
|
|
|
|
name,
|
|
|
|
readOnly,
|
|
|
|
};
|
|
|
|
|
|
|
|
return disk;
|
|
|
|
}
|