reverse the arguments to io.Copy so the destination is on the

left, like an assignment, like strcpy, etc.

R=rsc
CC=go-dev
http://go/go-review/1016011
This commit is contained in:
Rob Pike 2009-11-01 20:59:49 -08:00
Родитель 4e5296d4ba
Коммит 4d310f2434
19 изменённых файлов: 38 добавлений и 38 удалений

Просмотреть файл

@ -71,7 +71,7 @@ func exec(c *http.Conn, args []string) (status int) {
} }
var buf bytes.Buffer; var buf bytes.Buffer;
io.Copy(r, &buf); io.Copy(&buf, r);
wait, err := os.Wait(pid, 0); wait, err := os.Wait(pid, 0);
if err != nil { if err != nil {
os.Stderr.Write(buf.Bytes()); os.Stderr.Write(buf.Bytes());

Просмотреть файл

@ -34,7 +34,7 @@ var (
// // end of tar archive // // end of tar archive
// break // break
// } // }
// io.Copy(tr, data); // io.Copy(data, tr);
// } // }
type Reader struct { type Reader struct {
r io.Reader; r io.Reader;
@ -99,7 +99,7 @@ func (tr *Reader) skipUnread() {
if sr, ok := tr.r.(io.Seeker); ok { if sr, ok := tr.r.(io.Seeker); ok {
_, tr.err = sr.Seek(nr, 1); _, tr.err = sr.Seek(nr, 1);
} else { } else {
_, tr.err = io.Copyn(tr.r, ignoreWriter{}, nr); _, tr.err = io.Copyn(ignoreWriter{}, tr.r, nr);
} }
tr.nb, tr.pad = 0, 0; tr.nb, tr.pad = 0, 0;
} }

Просмотреть файл

@ -33,7 +33,7 @@ var (
// if err := tw.WriteHeader(hdr); err != nil { // if err := tw.WriteHeader(hdr); err != nil {
// // handle error // // handle error
// } // }
// io.Copy(data, tw); // io.Copy(tw, data);
// tw.Close(); // tw.Close();
type Writer struct { type Writer struct {
w io.Writer; w io.Writer;

Просмотреть файл

@ -293,7 +293,7 @@ func TestInflater(t *testing.T) {
t.Errorf("%s: got name %s", tt.name, gzip.Name); t.Errorf("%s: got name %s", tt.name, gzip.Name);
} }
b.Reset(); b.Reset();
n, err := io.Copy(gzip, b); n, err := io.Copy(b, gzip);
if err != tt.err { if err != tt.err {
t.Errorf("%s: io.Copy: %v want %v", tt.name, err, tt.err); t.Errorf("%s: io.Copy: %v want %v", tt.name, err, tt.err);
} }

Просмотреть файл

@ -80,7 +80,7 @@ func TestInflater(t *testing.T) {
} }
defer zlib.Close(); defer zlib.Close();
b.Reset(); b.Reset();
n, err := io.Copy(zlib, b); n, err := io.Copy(b, zlib);
if err != nil { if err != nil {
if err != tt.err { if err != tt.err {
t.Errorf("%s: io.Copy: %v want %v", tt.desc, err, tt.err); t.Errorf("%s: io.Copy: %v want %v", tt.desc, err, tt.err);

Просмотреть файл

@ -78,7 +78,7 @@ func TestCBC_AES(t *testing.T) {
var crypt bytes.Buffer; var crypt bytes.Buffer;
w := NewCBCEncrypter(c, tt.iv, &crypt); w := NewCBCEncrypter(c, tt.iv, &crypt);
var r io.Reader = bytes.NewBuffer(tt.in); var r io.Reader = bytes.NewBuffer(tt.in);
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(tt.in)) || err != nil { if n != int64(len(tt.in)) || err != nil {
t.Errorf("%s: CBCEncrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.in)); t.Errorf("%s: CBCEncrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.in));
} else if d := crypt.Bytes(); !same(tt.out, d) { } else if d := crypt.Bytes(); !same(tt.out, d) {
@ -88,7 +88,7 @@ func TestCBC_AES(t *testing.T) {
var plain bytes.Buffer; var plain bytes.Buffer;
r = NewCBCDecrypter(c, tt.iv, bytes.NewBuffer(tt.out)); r = NewCBCDecrypter(c, tt.iv, bytes.NewBuffer(tt.out));
w = &plain; w = &plain;
n, err = io.Copy(r, w); n, err = io.Copy(w, r);
if n != int64(len(tt.out)) || err != nil { if n != int64(len(tt.out)) || err != nil {
t.Errorf("%s: CBCDecrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.out)); t.Errorf("%s: CBCDecrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.out));
} else if d := plain.Bytes(); !same(tt.in, d) { } else if d := plain.Bytes(); !same(tt.in, d) {

Просмотреть файл

@ -287,7 +287,7 @@ func TestCFB_AES(t *testing.T) {
var crypt bytes.Buffer; var crypt bytes.Buffer;
w := NewCFBEncrypter(c, tt.s, tt.iv, &crypt); w := NewCFBEncrypter(c, tt.s, tt.iv, &crypt);
var r io.Reader = bytes.NewBuffer(tt.in); var r io.Reader = bytes.NewBuffer(tt.in);
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(tt.in)) || err != nil { if n != int64(len(tt.in)) || err != nil {
t.Errorf("%s: CFBEncrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.in)); t.Errorf("%s: CFBEncrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.in));
} else if d := crypt.Bytes(); !same(tt.out, d) { } else if d := crypt.Bytes(); !same(tt.out, d) {
@ -297,7 +297,7 @@ func TestCFB_AES(t *testing.T) {
var plain bytes.Buffer; var plain bytes.Buffer;
r = NewCFBDecrypter(c, tt.s, tt.iv, bytes.NewBuffer(tt.out)); r = NewCFBDecrypter(c, tt.s, tt.iv, bytes.NewBuffer(tt.out));
w = &plain; w = &plain;
n, err = io.Copy(r, w); n, err = io.Copy(w, r);
if n != int64(len(tt.out)) || err != nil { if n != int64(len(tt.out)) || err != nil {
t.Errorf("%s: CFBDecrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.out)); t.Errorf("%s: CFBDecrypter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.out));
} else if d := plain.Bytes(); !same(tt.in, d) { } else if d := plain.Bytes(); !same(tt.in, d) {

Просмотреть файл

@ -82,7 +82,7 @@ func TestCTR_AES(t *testing.T) {
in := tt.in[0 : len(tt.in)-j]; in := tt.in[0 : len(tt.in)-j];
w := NewCTRWriter(c, tt.iv, &crypt); w := NewCTRWriter(c, tt.iv, &crypt);
var r io.Reader = bytes.NewBuffer(in); var r io.Reader = bytes.NewBuffer(in);
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(in)) || err != nil { if n != int64(len(in)) || err != nil {
t.Errorf("%s/%d: CTRWriter io.Copy = %d, %v want %d, nil", test, len(in), n, err, len(in)); t.Errorf("%s/%d: CTRWriter io.Copy = %d, %v want %d, nil", test, len(in), n, err, len(in));
} else if d, out := crypt.Bytes(), tt.out[0:len(in)]; !same(out, d) { } else if d, out := crypt.Bytes(), tt.out[0:len(in)]; !same(out, d) {
@ -95,7 +95,7 @@ func TestCTR_AES(t *testing.T) {
out := tt.out[0 : len(tt.out)-j]; out := tt.out[0 : len(tt.out)-j];
r := NewCTRReader(c, tt.iv, bytes.NewBuffer(out)); r := NewCTRReader(c, tt.iv, bytes.NewBuffer(out));
w := &plain; w := &plain;
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(out)) || err != nil { if n != int64(len(out)) || err != nil {
t.Errorf("%s/%d: CTRReader io.Copy = %d, %v want %d, nil", test, len(out), n, err, len(out)); t.Errorf("%s/%d: CTRReader io.Copy = %d, %v want %d, nil", test, len(out), n, err, len(out));
} else if d, in := plain.Bytes(), tt.in[0:len(out)]; !same(in, d) { } else if d, in := plain.Bytes(), tt.in[0:len(out)]; !same(in, d) {

Просмотреть файл

@ -105,7 +105,7 @@ func TestEAXEncrypt_AES(t *testing.T) {
} }
b.Reset(); b.Reset();
enc := NewEAXEncrypter(c, tt.nonce, tt.header, 16, b); enc := NewEAXEncrypter(c, tt.nonce, tt.header, 16, b);
n, err := io.Copy(bytes.NewBuffer(tt.msg), enc); n, err := io.Copy(enc, bytes.NewBuffer(tt.msg));
if n != int64(len(tt.msg)) || err != nil { if n != int64(len(tt.msg)) || err != nil {
t.Fatalf("%s: io.Copy into encrypter: %d, %s", test, n, err); t.Fatalf("%s: io.Copy into encrypter: %d, %s", test, n, err);
} }
@ -129,7 +129,7 @@ func TestEAXDecrypt_AES(t *testing.T) {
} }
b.Reset(); b.Reset();
dec := NewEAXDecrypter(c, tt.nonce, tt.header, 16, bytes.NewBuffer(tt.cipher)); dec := NewEAXDecrypter(c, tt.nonce, tt.header, 16, bytes.NewBuffer(tt.cipher));
n, err := io.Copy(dec, b); n, err := io.Copy(b, dec);
if n != int64(len(tt.msg)) || err != nil { if n != int64(len(tt.msg)) || err != nil {
t.Fatalf("%s: io.Copy into decrypter: %d, %s", test, n, err); t.Fatalf("%s: io.Copy into decrypter: %d, %s", test, n, err);
} }

Просмотреть файл

@ -103,7 +103,7 @@ func TestECB_AES(t *testing.T) {
var crypt bytes.Buffer; var crypt bytes.Buffer;
w := NewECBEncrypter(c, &crypt); w := NewECBEncrypter(c, &crypt);
var r io.Reader = bytes.NewBuffer(tt.in); var r io.Reader = bytes.NewBuffer(tt.in);
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(tt.in)) || err != nil { if n != int64(len(tt.in)) || err != nil {
t.Errorf("%s: ECBReader io.Copy = %d, %v want %d, nil", test, n, err, len(tt.in)); t.Errorf("%s: ECBReader io.Copy = %d, %v want %d, nil", test, n, err, len(tt.in));
} else if d := crypt.Bytes(); !same(tt.out, d) { } else if d := crypt.Bytes(); !same(tt.out, d) {
@ -113,7 +113,7 @@ func TestECB_AES(t *testing.T) {
var plain bytes.Buffer; var plain bytes.Buffer;
r = NewECBDecrypter(c, bytes.NewBuffer(tt.out)); r = NewECBDecrypter(c, bytes.NewBuffer(tt.out));
w = &plain; w = &plain;
n, err = io.Copy(r, w); n, err = io.Copy(w, r);
if n != int64(len(tt.out)) || err != nil { if n != int64(len(tt.out)) || err != nil {
t.Errorf("%s: ECBWriter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.out)); t.Errorf("%s: ECBWriter io.Copy = %d, %v want %d, nil", test, n, err, len(tt.out));
} else if d := plain.Bytes(); !same(tt.in, d) { } else if d := plain.Bytes(); !same(tt.in, d) {

Просмотреть файл

@ -75,20 +75,20 @@ func TestECBEncrypter(t *testing.T) {
// copy plain into w in increasingly large chunks: 1, 1, 2, 4, 8, ... // copy plain into w in increasingly large chunks: 1, 1, 2, 4, 8, ...
// if frag != 0, move the 1 to the end to cause fragmentation. // if frag != 0, move the 1 to the end to cause fragmentation.
if frag == 0 { if frag == 0 {
_, err := io.Copyn(r, w, 1); _, err := io.Copyn(w, r, 1);
if err != nil { if err != nil {
t.Errorf("block=%d frag=0: first Copyn: %s", block, err); t.Errorf("block=%d frag=0: first Copyn: %s", block, err);
continue; continue;
} }
} }
for n := 1; n <= len(plain)/2; n *= 2 { for n := 1; n <= len(plain)/2; n *= 2 {
_, err := io.Copyn(r, w, int64(n)); _, err := io.Copyn(w, r, int64(n));
if err != nil { if err != nil {
t.Errorf("block=%d frag=%d: Copyn %d: %s", block, frag, n, err); t.Errorf("block=%d frag=%d: Copyn %d: %s", block, frag, n, err);
} }
} }
if frag != 0 { if frag != 0 {
_, err := io.Copyn(r, w, 1); _, err := io.Copyn(w, r, 1);
if err != nil { if err != nil {
t.Errorf("block=%d frag=1: last Copyn: %s", block, err); t.Errorf("block=%d frag=1: last Copyn: %s", block, err);
continue; continue;
@ -140,20 +140,20 @@ func testECBDecrypter(t *testing.T, maxio int) {
// read from crypt in increasingly large chunks: 1, 1, 2, 4, 8, ... // read from crypt in increasingly large chunks: 1, 1, 2, 4, 8, ...
// if frag == 1, move the 1 to the end to cause fragmentation. // if frag == 1, move the 1 to the end to cause fragmentation.
if frag == 0 { if frag == 0 {
_, err := io.Copyn(r, b, 1); _, err := io.Copyn(b, r, 1);
if err != nil { if err != nil {
t.Errorf("%s: first Copyn: %s", test, err); t.Errorf("%s: first Copyn: %s", test, err);
continue; continue;
} }
} }
for n := 1; n <= maxio/2; n *= 2 { for n := 1; n <= maxio/2; n *= 2 {
_, err := io.Copyn(r, b, int64(n)); _, err := io.Copyn(b, r, int64(n));
if err != nil { if err != nil {
t.Errorf("%s: Copyn %d: %s", test, n, err); t.Errorf("%s: Copyn %d: %s", test, n, err);
} }
} }
if frag != 0 { if frag != 0 {
_, err := io.Copyn(r, b, 1); _, err := io.Copyn(b, r, 1);
if err != nil { if err != nil {
t.Errorf("%s: last Copyn: %s", test, err); t.Errorf("%s: last Copyn: %s", test, err);
continue; continue;

Просмотреть файл

@ -80,7 +80,7 @@ func TestOFB_AES(t *testing.T) {
in := tt.in[0 : len(tt.in)-j]; in := tt.in[0 : len(tt.in)-j];
w := NewOFBWriter(c, tt.iv, &crypt); w := NewOFBWriter(c, tt.iv, &crypt);
var r io.Reader = bytes.NewBuffer(in); var r io.Reader = bytes.NewBuffer(in);
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(in)) || err != nil { if n != int64(len(in)) || err != nil {
t.Errorf("%s/%d: OFBWriter io.Copy = %d, %v want %d, nil", test, len(in), n, err, len(in)); t.Errorf("%s/%d: OFBWriter io.Copy = %d, %v want %d, nil", test, len(in), n, err, len(in));
} else if d, out := crypt.Bytes(), tt.out[0:len(in)]; !same(out, d) { } else if d, out := crypt.Bytes(), tt.out[0:len(in)]; !same(out, d) {
@ -93,7 +93,7 @@ func TestOFB_AES(t *testing.T) {
out := tt.out[0 : len(tt.out)-j]; out := tt.out[0 : len(tt.out)-j];
r := NewOFBReader(c, tt.iv, bytes.NewBuffer(out)); r := NewOFBReader(c, tt.iv, bytes.NewBuffer(out));
w := &plain; w := &plain;
n, err := io.Copy(r, w); n, err := io.Copy(w, r);
if n != int64(len(out)) || err != nil { if n != int64(len(out)) || err != nil {
t.Errorf("%s/%d: OFBReader io.Copy = %d, %v want %d, nil", test, len(out), n, err, len(out)); t.Errorf("%s/%d: OFBReader io.Copy = %d, %v want %d, nil", test, len(out), n, err, len(out));
} else if d, in := plain.Bytes(), tt.in[0:len(out)]; !same(in, d) { } else if d, in := plain.Bytes(), tt.in[0:len(out)]; !same(in, d) {

Просмотреть файл

@ -60,14 +60,14 @@ func testXorWriter(t *testing.T, maxio int) {
// copy plain into w in increasingly large chunks: 1, 1, 2, 4, 8, ... // copy plain into w in increasingly large chunks: 1, 1, 2, 4, 8, ...
// if frag != 0, move the 1 to the end to cause fragmentation. // if frag != 0, move the 1 to the end to cause fragmentation.
if frag == 0 { if frag == 0 {
_, err := io.Copyn(r, w, 1); _, err := io.Copyn(w, r, 1);
if err != nil { if err != nil {
t.Errorf("%s: first Copyn: %s", test, err); t.Errorf("%s: first Copyn: %s", test, err);
continue; continue;
} }
} }
for n := 1; n <= len(plain)/2; n *= 2 { for n := 1; n <= len(plain)/2; n *= 2 {
_, err := io.Copyn(r, w, int64(n)); _, err := io.Copyn(w, r, int64(n));
if err != nil { if err != nil {
t.Errorf("%s: Copyn %d: %s", test, n, err); t.Errorf("%s: Copyn %d: %s", test, n, err);
} }
@ -130,14 +130,14 @@ func testXorReader(t *testing.T, maxio int) {
// read from crypt in increasingly large chunks: 1, 1, 2, 4, 8, ... // read from crypt in increasingly large chunks: 1, 1, 2, 4, 8, ...
// if frag == 1, move the 1 to the end to cause fragmentation. // if frag == 1, move the 1 to the end to cause fragmentation.
if frag == 0 { if frag == 0 {
_, err := io.Copyn(r, b, 1); _, err := io.Copyn(b, r, 1);
if err != nil { if err != nil {
t.Errorf("%s: first Copyn: %s", test, err); t.Errorf("%s: first Copyn: %s", test, err);
continue; continue;
} }
} }
for n := 1; n <= maxio/2; n *= 2 { for n := 1; n <= maxio/2; n *= 2 {
_, err := io.Copyn(r, b, int64(n)); _, err := io.Copyn(b, r, int64(n));
if err != nil { if err != nil {
t.Errorf("%s: Copyn %d: %s", test, n, err); t.Errorf("%s: Copyn %d: %s", test, n, err);
} }

Просмотреть файл

@ -36,7 +36,7 @@ func readSource(filename string, src interface{}) ([]byte, os.Error) {
} }
case io.Reader: case io.Reader:
var buf bytes.Buffer; var buf bytes.Buffer;
_, err := io.Copy(s, &buf); _, err := io.Copy(&buf, s);
if err != nil { if err != nil {
return nil, err; return nil, err;
} }

Просмотреть файл

@ -151,7 +151,7 @@ func serveFileInternal(c *Conn, r *Request, name string, redirect bool) {
} }
c.Write(b); c.Write(b);
} }
io.Copy(f, c); io.Copy(c, f);
} }
// ServeFile replies to the request with the contents of the named file or directory. // ServeFile replies to the request with the contents of the named file or directory.

Просмотреть файл

@ -43,7 +43,7 @@ func (ctr *Counter) ServeHTTP(c *http.Conn, req *http.Request) {
ctr.n++; ctr.n++;
case "POST": case "POST":
buf := new(bytes.Buffer); buf := new(bytes.Buffer);
io.Copy(req.Body, buf); io.Copy(buf, req.Body);
body := buf.String(); body := buf.String();
if n, err := strconv.Atoi(body); err != nil { if n, err := strconv.Atoi(body); err != nil {
fmt.Fprintf(c, "bad POST: %v\nbody: [%v]\n", err, body); fmt.Fprintf(c, "bad POST: %v\nbody: [%v]\n", err, body);
@ -69,7 +69,7 @@ func FileServer(c *http.Conn, req *http.Request) {
fmt.Fprintf(c, "open %s: %v\n", path, err); fmt.Fprintf(c, "open %s: %v\n", path, err);
return; return;
} }
n, err1 := io.Copy(f, c); n, err1 := io.Copy(c, f);
fmt.Fprintf(c, "[%d bytes]\n", n); fmt.Fprintf(c, "[%d bytes]\n", n);
f.Close(); f.Close();
} }
@ -128,7 +128,7 @@ func DateServer(c *http.Conn, req *http.Request) {
fmt.Fprintf(c, "fork/exec: %s\n", err); fmt.Fprintf(c, "fork/exec: %s\n", err);
return; return;
} }
io.Copy(r, c); io.Copy(c, r);
wait, err := os.Wait(pid, 0); wait, err := os.Wait(pid, 0);
if err != nil { if err != nil {
fmt.Fprintf(c, "wait: %s\n", err); fmt.Fprintf(c, "wait: %s\n", err);

Просмотреть файл

@ -179,7 +179,7 @@ func ReadFull(r Reader, buf []byte) (n int, err os.Error) {
// Copyn copies n bytes (or until an error) from src to dst. // Copyn copies n bytes (or until an error) from src to dst.
// It returns the number of bytes copied and the error, if any. // It returns the number of bytes copied and the error, if any.
func Copyn(src Reader, dst Writer, n int64) (written int64, err os.Error) { func Copyn(dst Writer, src Reader, n int64) (written int64, err os.Error) {
buf := make([]byte, 32*1024); buf := make([]byte, 32*1024);
for written < n { for written < n {
l := len(buf); l := len(buf);
@ -212,7 +212,7 @@ func Copyn(src Reader, dst Writer, n int64) (written int64, err os.Error) {
// Copy copies from src to dst until either EOF is reached // Copy copies from src to dst until either EOF is reached
// on src or an error occurs. It returns the number of bytes // on src or an error occurs. It returns the number of bytes
// copied and the error, if any. // copied and the error, if any.
func Copy(src Reader, dst Writer) (written int64, err os.Error) { func Copy(dst Writer, src Reader) (written int64, err os.Error) {
buf := make([]byte, 32*1024); buf := make([]byte, 32*1024);
for { for {
nr, er := src.Read(buf); nr, er := src.Read(buf);

Просмотреть файл

@ -15,7 +15,7 @@ import (
// ReadAll reads from r until an error or EOF and returns the data it read. // ReadAll reads from r until an error or EOF and returns the data it read.
func ReadAll(r Reader) ([]byte, os.Error) { func ReadAll(r Reader) ([]byte, os.Error) {
var buf bytes.Buffer; var buf bytes.Buffer;
_, err := Copy(r, &buf); _, err := Copy(&buf, r);
return buf.Bytes(), err; return buf.Bytes(), err;
} }

Просмотреть файл

@ -325,7 +325,7 @@ func TestForkExec(t *testing.T) {
w.Close(); w.Close();
var b bytes.Buffer; var b bytes.Buffer;
io.Copy(r, &b); io.Copy(&b, r);
output := b.String(); output := b.String();
expect := "/\n"; expect := "/\n";
if output != expect { if output != expect {
@ -603,7 +603,7 @@ func run(t *testing.T, cmd []string) string {
w.Close(); w.Close();
var b bytes.Buffer; var b bytes.Buffer;
io.Copy(r, &b); io.Copy(&b, r);
Wait(pid, 0); Wait(pid, 0);
output := b.String(); output := b.String();
if n := len(output); n > 0 && output[n-1] == '\n' { if n := len(output); n > 0 && output[n-1] == '\n' {