1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-11-25 15:29:32 -05:00

Add buffer size argument to copy (#4907)

This commit is contained in:
Marcos Casagrande 2020-04-26 22:25:24 +02:00 committed by GitHub
parent f7d1f82796
commit 26dfd3c110
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 75 additions and 3 deletions

View file

@ -70,9 +70,16 @@ export interface ReadWriteCloser extends Reader, Writer, Closer {}
// https://golang.org/pkg/io/#ReadWriteSeeker // https://golang.org/pkg/io/#ReadWriteSeeker
export interface ReadWriteSeeker extends Reader, Writer, Seeker {} export interface ReadWriteSeeker extends Reader, Writer, Seeker {}
export async function copy(src: Reader, dst: Writer): Promise<number> { export async function copy(
src: Reader,
dst: Writer,
options?: {
bufSize?: number;
}
): Promise<number> {
let n = 0; let n = 0;
const b = new Uint8Array(DEFAULT_BUFFER_SIZE); const bufSize = options?.bufSize ?? DEFAULT_BUFFER_SIZE;
const b = new Uint8Array(bufSize);
let gotEOF = false; let gotEOF = false;
while (gotEOF === false) { while (gotEOF === false) {
const result = await src.read(b); const result = await src.read(b);

View file

@ -572,8 +572,15 @@ declare namespace Deno {
* *
* @param src The source to copy from * @param src The source to copy from
* @param dst The destination to copy to * @param dst The destination to copy to
* @param options Can be used to tune size of the buffer. Default size is 32kB
*/ */
export function copy(src: Reader, dst: Writer): Promise<number>; export function copy(
src: Reader,
dst: Writer,
options?: {
bufSize?: number;
}
): Promise<number>;
/** Turns a Reader, `r`, into an async iterator. /** Turns a Reader, `r`, into an async iterator.
* *

57
cli/js/tests/io_test.ts Normal file
View file

@ -0,0 +1,57 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { unitTest, assertEquals } from "./test_util.ts";
const DEFAULT_BUF_SIZE = 32 * 1024;
type Spy = { calls: number };
function repeat(c: string, bytes: number): Uint8Array {
assertEquals(c.length, 1);
const ui8 = new Uint8Array(bytes);
ui8.fill(c.charCodeAt(0));
return ui8;
}
function spyRead(obj: Deno.Buffer): Spy {
const spy: Spy = {
calls: 0,
};
const orig = obj.read.bind(obj);
obj.read = (p: Uint8Array): Promise<number | Deno.EOF> => {
spy.calls++;
return orig(p);
};
return spy;
}
unitTest(async function copyWithDefaultBufferSize() {
const xBytes = repeat("b", DEFAULT_BUF_SIZE);
const reader = new Deno.Buffer(xBytes.buffer as ArrayBuffer);
const write = new Deno.Buffer();
const readSpy = spyRead(reader);
const n = await Deno.copy(reader, write);
assertEquals(n, xBytes.length);
assertEquals(write.length, xBytes.length);
assertEquals(readSpy.calls, 2); // read with DEFAULT_BUF_SIZE bytes + read with 0 bytes
});
unitTest(async function copyWithCustomBufferSize() {
const bufSize = 1024;
const xBytes = repeat("b", DEFAULT_BUF_SIZE);
const reader = new Deno.Buffer(xBytes.buffer as ArrayBuffer);
const write = new Deno.Buffer();
const readSpy = spyRead(reader);
const n = await Deno.copy(reader, write, { bufSize });
assertEquals(n, xBytes.length);
assertEquals(write.length, xBytes.length);
assertEquals(readSpy.calls, DEFAULT_BUF_SIZE / bufSize + 1);
});

View file

@ -31,6 +31,7 @@ import "./get_random_values_test.ts";
import "./globals_test.ts"; import "./globals_test.ts";
import "./headers_test.ts"; import "./headers_test.ts";
import "./internals_test.ts"; import "./internals_test.ts";
import "./io_test.ts";
import "./link_test.ts"; import "./link_test.ts";
import "./location_test.ts"; import "./location_test.ts";
import "./make_temp_test.ts"; import "./make_temp_test.ts";