mirror of
https://github.com/denoland/std.git
synced 2024-11-21 20:50:22 +00:00
9c3c53e65b
This commit improves docs of the streams module. Towards #3764 --------- Co-authored-by: Yoshiya Hinosawa <stibium121@gmail.com>
44 lines
1.2 KiB
TypeScript
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/assert-equals";
|
|
*
|
|
* 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;
|
|
}
|