1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-10 16:11:13 -05:00

BREAKING CHANGE: change order of args in Deno.copy() (#4885)

This commit is contained in:
Bartek Iwańczuk 2020-04-25 00:09:14 +02:00 committed by GitHub
parent 833539fcaf
commit 0cb1bb98cc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
13 changed files with 18 additions and 19 deletions

View file

@ -70,8 +70,7 @@ 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 {}
// https://golang.org/pkg/io/#Copy export async function copy(src: Reader, dst: Writer): Promise<number> {
export async function copy(dst: Writer, src: Reader): Promise<number> {
let n = 0; let n = 0;
const b = new Uint8Array(DEFAULT_BUFFER_SIZE); const b = new Uint8Array(DEFAULT_BUFFER_SIZE);
let gotEOF = false; let gotEOF = false;

View file

@ -565,16 +565,16 @@ declare namespace Deno {
* *
* const source = await Deno.open("my_file.txt"); * const source = await Deno.open("my_file.txt");
* const buffer = new Deno.Buffer() * const buffer = new Deno.Buffer()
* const bytesCopied1 = await Deno.copy(Deno.stdout, source); * const bytesCopied1 = await Deno.copy(source, Deno.stdout);
* const bytesCopied2 = await Deno.copy(buffer, source); * const bytesCopied2 = await Deno.copy(source, buffer);
* *
* Because `copy()` is defined to read from `src` until `EOF`, it does not * Because `copy()` is defined to read from `src` until `EOF`, it does not
* treat an `EOF` from `read()` as an error to be reported. * treat an `EOF` from `read()` as an error to be reported.
* *
* @param dst The destination to copy to
* @param src The source to copy from * @param src The source to copy from
* @param dst The destination to copy to
*/ */
export function copy(dst: Writer, src: Reader): Promise<number>; export function copy(src: Reader, dst: Writer): Promise<number>;
/** Turns a Reader, `r`, into an async iterator. /** Turns a Reader, `r`, into an async iterator.
* *

View file

@ -18,7 +18,7 @@ unitTest({ perms: { read: true } }, async function filesCopyToStdout(): Promise<
const filename = "cli/tests/fixture.json"; const filename = "cli/tests/fixture.json";
const file = await Deno.open(filename); const file = await Deno.open(filename);
assert(file.rid > 2); assert(file.rid > 2);
const bytesWritten = await Deno.copy(Deno.stdout, file); const bytesWritten = await Deno.copy(file, Deno.stdout);
const fileSize = Deno.statSync(filename).size; const fileSize = Deno.statSync(filename).size;
assertEquals(bytesWritten, fileSize); assertEquals(bytesWritten, fileSize);
console.log("bytes written", bytesWritten); console.log("bytes written", bytesWritten);

View file

@ -4,7 +4,7 @@ async function main(): Promise<void> {
for (let i = 1; i < args.length; i++) { for (let i = 1; i < args.length; i++) {
const filename = args[i]; const filename = args[i];
const file = await open(filename); const file = await open(filename);
await copy(stdout, file); await copy(file, stdout);
} }
} }

View file

@ -470,7 +470,7 @@ export class Untar {
while (rest > 0) { while (rest > 0) {
await this.reader.readFull(this.block); await this.reader.readFull(this.block);
const arr = rest < recordSize ? this.block.subarray(0, rest) : this.block; const arr = rest < recordSize ? this.block.subarray(0, rest) : this.block;
await Deno.copy(writer, new Deno.Buffer(arr)); await Deno.copy(new Deno.Buffer(arr), writer);
rest -= recordSize; rest -= recordSize;
} }

View file

@ -30,8 +30,8 @@ Deno.test(async function createTarArchive(): Promise<void> {
await tar.append("dir/tar.ts", { filePath }); await tar.append("dir/tar.ts", { filePath });
// write tar data to a buffer // write tar data to a buffer
const writer = new Deno.Buffer(), const writer = new Deno.Buffer();
wrote = await Deno.copy(writer, tar.getReader()); const wrote = await Deno.copy(tar.getReader(), writer);
/** /**
* 3072 = 512 (header) + 512 (content) + 512 (header) + 512 (content) * 3072 = 512 (header) + 512 (content) + 512 (header) + 512 (content)

View file

@ -2,6 +2,6 @@
const filenames = Deno.args; const filenames = Deno.args;
for (const filename of filenames) { for (const filename of filenames) {
const file = await Deno.open(filename); const file = await Deno.open(filename);
await Deno.copy(Deno.stdout, file); await Deno.copy(file, Deno.stdout);
file.close(); file.close();
} }

View file

@ -3,7 +3,7 @@ const url_ = Deno.args[0];
const res = await fetch(url_); const res = await fetch(url_);
// TODO(ry) Re-enable streaming in this example. // TODO(ry) Re-enable streaming in this example.
// Originally we did: await Deno.copy(Deno.stdout, res.body); // Originally we did: await Deno.copy(res.body, Deno.stdout);
// But maybe more JS-y would be: res.pipeTo(Deno.stdout); // But maybe more JS-y would be: res.pipeTo(Deno.stdout);
const body = new Uint8Array(await res.arrayBuffer()); const body = new Uint8Array(await res.arrayBuffer());

View file

@ -273,7 +273,7 @@ export async function writeResponse(
const contentLength = headers.get("content-length"); const contentLength = headers.get("content-length");
assert(contentLength != null); assert(contentLength != null);
const bodyLength = parseInt(contentLength); const bodyLength = parseInt(contentLength);
const n = await Deno.copy(writer, r.body); const n = await Deno.copy(r.body, writer);
assert(n === bodyLength); assert(n === bodyLength);
} else { } else {
await writeChunkedBody(writer, r.body); await writeChunkedBody(writer, r.body);

View file

@ -33,6 +33,6 @@ test(async function ioMultiReader(): Promise<void> {
const n = await copyN(w, r, 4); const n = await copyN(w, r, 4);
assertEquals(n, 4); assertEquals(n, 4);
assertEquals(w.toString(), "abcd"); assertEquals(w.toString(), "abcd");
await copy(w, r); await copy(r, w);
assertEquals(w.toString(), "abcdef"); assertEquals(w.toString(), "abcdef");
}); });

View file

@ -9,6 +9,6 @@ test(async function ioStringWriter(): Promise<void> {
const r = new StringReader("0123456789"); const r = new StringReader("0123456789");
await copyN(w, r, 4); await copyN(w, r, 4);
assertEquals(w.toString(), "base0123"); assertEquals(w.toString(), "base0123");
await copy(w, r); await copy(r, w);
assertEquals(w.toString(), "base0123456789"); assertEquals(w.toString(), "base0123456789");
}); });

View file

@ -308,7 +308,7 @@ export class MultipartReader {
} }
// file // file
let formFile: FormFile | undefined; let formFile: FormFile | undefined;
const n = await copy(buf, p); const n = await copy(p, buf);
const contentType = p.headers.get("content-type"); const contentType = p.headers.get("content-type");
assert(contentType != null, "content-type must be set"); assert(contentType != null, "content-type must be set");
if (n > maxMemory) { if (n > maxMemory) {
@ -573,7 +573,7 @@ export class MultipartWriter {
file: Reader file: Reader
): Promise<void> { ): Promise<void> {
const f = await this.createFormFile(field, filename); const f = await this.createFormFile(field, filename);
await copy(f, file); await copy(file, f);
} }
private flush(): Promise<void> { private flush(): Promise<void> {

View file

@ -208,7 +208,7 @@ test({
assert(file.tempfile != null); assert(file.tempfile != null);
const f = await open(file.tempfile); const f = await open(file.tempfile);
const w = new StringWriter(); const w = new StringWriter();
await copy(w, f); await copy(f, w);
const json = JSON.parse(w.toString()); const json = JSON.parse(w.toString());
assertEquals(json["compilerOptions"]["target"], "es2018"); assertEquals(json["compilerOptions"]["target"], "es2018");
f.close(); f.close();