Commit b8519cd7 authored by Joe Tsai's avatar Joe Tsai Committed by Joe Tsai

archive/tar: simplify Flush

In Go1.0, Writer.Flush used to finish off the current file with zeros
(if it was not already finished) and then write the padding.

Since Go1.1, a regression was made (https://golang.org/cl/5777064) where it was
an error to call Flush if the current file was incomplete. Thus, Flush now only
writes out the final padding bytes, which arguably isn't very useful to anyone.
Since this has been the behavior of Flush for 9 releases of Go (1.1 to 1.9),
we should keep this behavior and just simplify the logic.

We also mark the method as deprecated since it serves no purpose.

Change-Id: I94610d942cb75cad495efd8cf799c1a275a21751
Reviewed-on: https://go-review.googlesource.com/54434
Run-TryBot: Joe Tsai <thebrokentoaster@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent d0264724
...@@ -45,26 +45,26 @@ type Writer struct { ...@@ -45,26 +45,26 @@ type Writer struct {
// NewWriter creates a new Writer writing to w. // NewWriter creates a new Writer writing to w.
func NewWriter(w io.Writer) *Writer { return &Writer{w: w} } func NewWriter(w io.Writer) *Writer { return &Writer{w: w} }
// Flush finishes writing the current file (optional). // Flush finishes writing the current file's block padding.
// The current file must be fully written before Flush can be called.
//
// Deprecated: This is unecessary as the next call to WriteHeader or Close
// will implicitly flush out the file's padding.
func (tw *Writer) Flush() error { func (tw *Writer) Flush() error {
if tw.nb > 0 { if tw.nb > 0 {
tw.err = fmt.Errorf("archive/tar: missed writing %d bytes", tw.nb) tw.err = fmt.Errorf("archive/tar: missed writing %d bytes", tw.nb)
return tw.err return tw.err
} }
tw.err = tw.writePadding()
return tw.err
}
n := tw.nb + tw.pad func (tw *Writer) writePadding() error {
for n > 0 && tw.err == nil { if _, err := tw.w.Write(zeroBlock[:tw.pad]); err != nil {
nr := n return err
if nr > blockSize {
nr = blockSize
}
var nw int
nw, tw.err = tw.w.Write(zeroBlock[0:nr])
n -= int64(nw)
} }
tw.nb = 0
tw.pad = 0 tw.pad = 0
return tw.err return nil
} }
var ( var (
...@@ -318,10 +318,7 @@ func (tw *Writer) writePAXHeader(hdr *Header, paxHeaders map[string]string) erro ...@@ -318,10 +318,7 @@ func (tw *Writer) writePAXHeader(hdr *Header, paxHeaders map[string]string) erro
if _, err := tw.Write(buf.Bytes()); err != nil { if _, err := tw.Write(buf.Bytes()); err != nil {
return err return err
} }
if err := tw.Flush(); err != nil { return tw.writePadding()
return err
}
return nil
} }
// Write writes to the current entry in the tar archive. // Write writes to the current entry in the tar archive.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment