This release is 4 versions behind 1.0.16 — the latest version of @std/streams. Jump to latest
Built and signed on GitHub ActionsBuilt and signed on GitHub Actions
Built and signed on GitHub Actions
Works with
•JSR Score100%•This package works with Cloudflare Workers, Node.js, Deno, Bun, Browsers




Downloads18,474/wk
•Published5 months ago (1.0.11)
Utilities for working with the Web Streams API
// Copyright 2018-2025 the Deno authors. MIT license. // This module is browser compatible. /** * Converts a {@linkcode ReadableSteam} of strings or {@linkcode Uint8Array}s * to a single string. Works the same as {@linkcode Response.text} and * {@linkcode Request.text}, but also extends to support streams of strings. * * @param stream A `ReadableStream` to convert into a `string`. * @returns A `Promise` that resolves to the `string`. * * @example Basic usage with a stream of strings * ```ts * import { toText } from "@std/streams/to-text"; * import { assertEquals } from "@std/assert"; * * const stream = ReadableStream.from(["Hello, ", "world!"]); * assertEquals(await toText(stream), "Hello, world!"); * ``` * * @example Basic usage with a stream of `Uint8Array`s * ```ts * import { toText } from "@std/streams/to-text"; * import { assertEquals } from "@std/assert"; * * const stream = ReadableStream.from(["Hello, ", "world!"]) * .pipeThrough(new TextEncoderStream()); * assertEquals(await toText(stream), "Hello, world!"); * ``` */ export async function toText( stream: ReadableStream<string> | ReadableStream<Uint8Array>, ): Promise<string> { const textDecoder = new TextDecoder(); const reader = stream.getReader(); let result = ""; while (true) { const { done, value } = await reader.read(); if (done) { break; } result += typeof value === "string" ? value : textDecoder.decode(value, { stream: true }); } result += textDecoder.decode(); return result; }