std/streams/to_array_buffer.ts

44 lines
1.2 KiB
TypeScript

// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
// This module is browser compatible.
import { concat } from "@std/bytes/concat";
/**
* Converts a {@linkcode ReadableStream} of {@linkcode Uint8Array}s to an
* {@linkcode ArrayBuffer}. Works the same as {@linkcode Response.arrayBuffer}.
*
* @param readableStream A `ReadableStream` of `Uint8Array`s to convert into an `ArrayBuffer`.
* @returns A promise that resolves with the `ArrayBuffer` containing all the data from the stream.
*
* @example Basic usage
* ```ts
* import { toArrayBuffer } from "@std/streams/to-array-buffer";
* import { assertEquals } from "@std/assert";
*
* const stream = ReadableStream.from([
* new Uint8Array([1, 2]),
* new Uint8Array([3, 4, 5]),
* ]);
* const buf = await toArrayBuffer(stream);
* assertEquals(buf.byteLength, 5);
* ```
*/
export async function toArrayBuffer(
readableStream: ReadableStream<Uint8Array>,
): Promise<ArrayBuffer> {
const reader = readableStream.getReader();
const chunks: Uint8Array[] = [];
while (true) {
const { done, value } = await reader.read();
if (done) {
break;
}
chunks.push(value);
}
return concat(chunks).buffer;
}