1a2f01efa6
Update the Go library to the 1.10beta1 release. Requires a few changes to the compiler for modifications to the map runtime code, and to handle some nowritebarrier cases in the runtime. Reviewed-on: https://go-review.googlesource.com/86455 gotools/: * Makefile.am (go_cmd_vet_files): New variable. (go_cmd_buildid_files, go_cmd_test2json_files): New variables. (s-zdefaultcc): Change from constants to functions. (noinst_PROGRAMS): Add vet, buildid, and test2json. (cgo$(EXEEXT)): Link against $(LIBGOTOOL). (vet$(EXEEXT)): New target. (buildid$(EXEEXT)): New target. (test2json$(EXEEXT)): New target. (install-exec-local): Install all $(noinst_PROGRAMS). (uninstall-local): Uninstasll all $(noinst_PROGRAMS). (check-go-tool): Depend on $(noinst_PROGRAMS). Copy down objabi.go. (check-runtime): Depend on $(noinst_PROGRAMS). (check-cgo-test, check-carchive-test): Likewise. (check-vet): New target. (check): Depend on check-vet. Look at cmd_vet-testlog. (.PHONY): Add check-vet. * Makefile.in: Rebuild. From-SVN: r256365
54 lines
1.5 KiB
Go
54 lines
1.5 KiB
Go
// Copyright 2010 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package cipher
|
|
|
|
import "io"
|
|
|
|
// The Stream* objects are so simple that all their members are public. Users
|
|
// can create them themselves.
|
|
|
|
// StreamReader wraps a Stream into an io.Reader. It calls XORKeyStream
|
|
// to process each slice of data which passes through.
|
|
type StreamReader struct {
|
|
S Stream
|
|
R io.Reader
|
|
}
|
|
|
|
func (r StreamReader) Read(dst []byte) (n int, err error) {
|
|
n, err = r.R.Read(dst)
|
|
r.S.XORKeyStream(dst[:n], dst[:n])
|
|
return
|
|
}
|
|
|
|
// StreamWriter wraps a Stream into an io.Writer. It calls XORKeyStream
|
|
// to process each slice of data which passes through. If any Write call
|
|
// returns short then the StreamWriter is out of sync and must be discarded.
|
|
// A StreamWriter has no internal buffering; Close does not need
|
|
// to be called to flush write data.
|
|
type StreamWriter struct {
|
|
S Stream
|
|
W io.Writer
|
|
Err error // unused
|
|
}
|
|
|
|
func (w StreamWriter) Write(src []byte) (n int, err error) {
|
|
c := make([]byte, len(src))
|
|
w.S.XORKeyStream(c, src)
|
|
n, err = w.W.Write(c)
|
|
if n != len(src) && err == nil { // should never happen
|
|
err = io.ErrShortWrite
|
|
}
|
|
return
|
|
}
|
|
|
|
// Close closes the underlying Writer and returns its Close return value, if the Writer
|
|
// is also an io.Closer. Otherwise it returns nil.
|
|
func (w StreamWriter) Close() error {
|
|
if c, ok := w.W.(io.Closer); ok {
|
|
return c.Close()
|
|
}
|
|
return nil
|
|
}
|