Commit 1f35bb64 authored by Andrew Gerrand's avatar Andrew Gerrand

archive/zip: remove WriterOptions and replace with SetOffset method

Change-Id: I0a8b972c33e80c750ff1d63717177a5a3294a112
Reviewed-on: https://go-review.googlesource.com/7445Reviewed-by: default avatarRob Pike <r@golang.org>
Reviewed-by: default avatarGeert-Johan Riemer <gjr19912@gmail.com>
Reviewed-by: default avatarAndrew Gerrand <adg@golang.org>
parent 8a6eca43
...@@ -29,29 +29,20 @@ type header struct { ...@@ -29,29 +29,20 @@ type header struct {
offset uint64 offset uint64
} }
// WriterOptions contains configuration options for a zip.Writer.
type WriterOptions struct {
// Offset modifies the initial zip offset.
// This is useful when the zip is appended to other data such as a binary executable.
Offset int64
}
// NewWriter returns a new Writer writing a zip file to w. // NewWriter returns a new Writer writing a zip file to w.
func NewWriter(w io.Writer) *Writer { func NewWriter(w io.Writer) *Writer {
return NewWriterWithOptions(w, nil) return &Writer{cw: &countWriter{w: bufio.NewWriter(w)}}
} }
// NewWriterWithOptions returns a new Writer writing a zip file to w and uses the given options. // SetOffset sets the offset of the beginning of the zip data within the
func NewWriterWithOptions(w io.Writer, options *WriterOptions) *Writer { // underlying writer. It should be used when the zip data is appended to an
writer := &Writer{ // existing file, such as a binary executable.
cw: &countWriter{ // It must be called before any data is written.
w: bufio.NewWriter(w), func (w *Writer) SetOffset(n int64) {
}, if w.cw.count != 0 {
} panic("zip: SetOffset called after data was written")
if options != nil {
writer.cw.count = options.Offset
} }
return writer w.cw.count = n
} }
// Flush flushes any buffered data to the underlying writer. // Flush flushes any buffered data to the underlying writer.
......
...@@ -87,7 +87,7 @@ func TestWriter(t *testing.T) { ...@@ -87,7 +87,7 @@ func TestWriter(t *testing.T) {
} }
} }
func TestWriterOffsetOption(t *testing.T) { func TestWriterOffset(t *testing.T) {
largeData := make([]byte, 1<<17) largeData := make([]byte, 1<<17)
for i := range largeData { for i := range largeData {
largeData[i] = byte(rand.Int()) largeData[i] = byte(rand.Int())
...@@ -101,7 +101,8 @@ func TestWriterOffsetOption(t *testing.T) { ...@@ -101,7 +101,8 @@ func TestWriterOffsetOption(t *testing.T) {
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
existingData := []byte{1, 2, 3, 1, 2, 3, 1, 2, 3} existingData := []byte{1, 2, 3, 1, 2, 3, 1, 2, 3}
n, _ := buf.Write(existingData) n, _ := buf.Write(existingData)
w := NewWriterWithOptions(buf, &WriterOptions{Offset: int64(n)}) w := NewWriter(buf)
w.SetOffset(int64(n))
for _, wt := range writeTests { for _, wt := range writeTests {
testCreate(t, w, &wt) testCreate(t, w, &wt)
......
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