std/io/string_writer.ts
Asher Gomez c80e2fd554
deprecation(io/unstable): deprecate StringWriter (#6026)
* deprecation(io/unstable): deprecate `StringWriter`

* update
2024-09-23 20:31:29 +09:00

125 lines
3.2 KiB
TypeScript

// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
// This module is browser compatible.
import type { Writer, WriterSync } from "./types.ts";
const decoder = new TextDecoder();
/**
* Writer utility for buffering string chunks.
*
* @example Usage
* ```ts
* import {
* copyN,
* StringReader,
* StringWriter,
* } from "@std/io";
* import { copy } from "@std/io/copy";
* import { assertEquals } from "@std/assert/equals";
*
* const w = new StringWriter("base");
* const r = new StringReader("0123456789");
* await copyN(r, w, 4); // copy 4 bytes
*
* assertEquals(w.toString(), "base0123");
*
* await copy(r, w); // copy all
* assertEquals(w.toString(), "base0123456789");
* ```
*
* @deprecated Write to a
* {@linkcode https://jsr.io/@std/streams/doc/buffer/~/Buffer | Buffer}'s
* `writable` property instead. This will be removed in 0.225.0.
*/
export class StringWriter implements Writer, WriterSync {
#chunks: Uint8Array[] = [];
#byteLength = 0;
#cache: string | undefined;
#base: string;
/**
* Construct a new instance.
*
* @param base The base string to write to the buffer.
*/
constructor(base = "") {
const c = new TextEncoder().encode(base);
this.#chunks.push(c);
this.#byteLength += c.byteLength;
this.#base = base;
}
/**
* Writes the bytes to the buffer asynchronously.
*
* @example Usage
* ```ts
* import { StringWriter } from "@std/io/string-writer";
* import { assertEquals } from "@std/assert/equals";
*
* const w = new StringWriter("base");
* await w.write(new TextEncoder().encode("0123"));
* assertEquals(w.toString(), "base0123");
* ```
*
* @param p The bytes to write to the buffer.
* @returns The number of bytes written to the buffer in total.
*/
write(p: Uint8Array): Promise<number> {
return Promise.resolve(this.writeSync(p));
}
/**
* Writes the bytes to the buffer synchronously.
*
* @example Usage
* ```ts
* import { StringWriter } from "@std/io/string-writer";
* import { assertEquals } from "@std/assert/equals";
*
* const w = new StringWriter("base");
* w.writeSync(new TextEncoder().encode("0123"));
* assertEquals(w.toString(), "base0123");
* ```
*
* @param p The bytes to write to the buffer.
* @returns The number of bytes written to the buffer in total.
*/
writeSync(p: Uint8Array): number {
this.#chunks.push(new Uint8Array(p));
this.#byteLength += p.byteLength;
this.#cache = undefined;
return p.byteLength;
}
/**
* Returns the string written to the buffer.
*
* @example Usage
* ```ts
* import { StringWriter } from "@std/io/string-writer";
* import { assertEquals } from "@std/assert/equals";
*
* const w = new StringWriter("base");
* await w.write(new TextEncoder().encode("0123"));
* assertEquals(w.toString(), "base0123");
* ```
*
* @returns the string written to the buffer.
*/
toString(): string {
if (this.#cache) {
return this.#cache;
}
const buf = new Uint8Array(this.#byteLength);
let offs = 0;
for (const chunk of this.#chunks) {
buf.set(chunk, offs);
offs += chunk.byteLength;
}
this.#cache = decoder.decode(buf);
return this.#cache;
}
}