mirror of
https://github.com/denoland/deno.git
synced 2024-10-31 09:14:20 -04:00
d47147fb6a
This commit moves "deno_std/node" in "ext/node" crate. The code is transpiled and snapshotted during the build process. During the first pass a minimal amount of work was done to create the snapshot, a lot of code in "ext/node" depends on presence of "Deno" global. This code will be gradually fixed in the follow up PRs to migrate it to import relevant APIs from "internal:" modules. Currently the code from snapshot is not used in any way, and all Node/npm compatibility still uses code from "https://deno.land/std/node" (or from the location specified by "DENO_NODE_COMPAT_URL"). This will also be handled in a follow up PRs. --------- Co-authored-by: crowlkats <crowlkats@toaxl.com> Co-authored-by: Divy Srivastava <dj.srivastava23@gmail.com> Co-authored-by: Yoshiya Hinosawa <stibium121@gmail.com>
78 lines
1.8 KiB
JavaScript
78 lines
1.8 KiB
JavaScript
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
|
|
|
import { TextDecoder } from "internal:deno_web/08_text_encoding.js";
|
|
import { Buffer } from "internal:deno_node/polyfills/buffer.ts";
|
|
|
|
/**
|
|
* @typedef {import('../_global.d.ts').ReadableStream
|
|
* } ReadableStream
|
|
* @typedef {import('../_stream.d.ts')} Readable
|
|
*/
|
|
|
|
/**
|
|
* @param {AsyncIterable|ReadableStream|Readable} stream
|
|
* @returns {Promise<Blob>}
|
|
*/
|
|
async function blob(stream) {
|
|
const chunks = [];
|
|
for await (const chunk of stream) {
|
|
chunks.push(chunk);
|
|
}
|
|
return new Blob(chunks);
|
|
}
|
|
|
|
/**
|
|
* @param {AsyncIterable|ReadableStream|Readable} stream
|
|
* @returns {Promise<ArrayBuffer>}
|
|
*/
|
|
async function arrayBuffer(stream) {
|
|
const ret = await blob(stream);
|
|
return ret.arrayBuffer();
|
|
}
|
|
|
|
/**
|
|
* @param {AsyncIterable|ReadableStream|Readable} stream
|
|
* @returns {Promise<Buffer>}
|
|
*/
|
|
async function buffer(stream) {
|
|
return Buffer.from(await arrayBuffer(stream));
|
|
}
|
|
|
|
/**
|
|
* @param {AsyncIterable|ReadableStream|Readable} stream
|
|
* @returns {Promise<string>}
|
|
*/
|
|
async function text(stream) {
|
|
const dec = new TextDecoder();
|
|
let str = "";
|
|
for await (const chunk of stream) {
|
|
if (typeof chunk === "string") {
|
|
str += chunk;
|
|
} else {
|
|
str += dec.decode(chunk, { stream: true });
|
|
}
|
|
}
|
|
// Flush the streaming TextDecoder so that any pending
|
|
// incomplete multibyte characters are handled.
|
|
str += dec.decode(undefined, { stream: false });
|
|
return str;
|
|
}
|
|
|
|
/**
|
|
* @param {AsyncIterable|ReadableStream|Readable} stream
|
|
* @returns {Promise<any>}
|
|
*/
|
|
async function json(stream) {
|
|
const str = await text(stream);
|
|
return JSON.parse(str);
|
|
}
|
|
|
|
export default {
|
|
arrayBuffer,
|
|
blob,
|
|
buffer,
|
|
json,
|
|
text,
|
|
};
|
|
export { arrayBuffer, blob, buffer, json, text };
|