// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license. // This module is browser compatible. import { toText } from "./to_text.ts"; /** * Converts a * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON}-formatted * {@linkcode ReadableSteam} of strings or {@linkcode Uint8Array}s to an object. * Works the same as {@linkcode Response.json} and {@linkcode Request.json}, but * also extends to support streams of strings. * * @param stream A `ReadableStream` whose chunks compose a JSON. * @returns A promise that resolves to the parsed JSON. * * @example Usage with a stream of strings * ```ts * import { toJson } from "@std/streams/to-json"; * import { assertEquals } from "@std/assert"; * * const stream = ReadableStream.from([ * "[1, true", * ', [], {}, "hello', * '", null]', * ]); * assertEquals(await toJson(stream), [1, true, [], {}, "hello", null]); * ``` * * @example Usage with a stream of `Uint8Array`s * ```ts * import { toJson } from "@std/streams/to-json"; * import { assertEquals } from "@std/assert"; * * const stream = ReadableStream.from([ * "[1, true", * ', [], {}, "hello', * '", null]', * ]).pipeThrough(new TextEncoderStream()); * assertEquals(await toJson(stream), [1, true, [], {}, "hello", null]); * ``` */ export function toJson( stream: ReadableStream | ReadableStream, ): Promise { return toText(stream).then(JSON.parse); }