// 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, ): Promise { 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; }