From b56dae8120d43b9acd3d3ed4d40100ffab7b972a Mon Sep 17 00:00:00 2001 From: kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com> Date: Mon, 2 May 2022 14:05:18 +0100 Subject: [chore] Update all but bun libraries (#526) * update all but bun libraries Signed-off-by: kim * remove my personal build script changes Signed-off-by: kim --- .../github.com/tdewolff/parse/v2/buffer/writer.go | 28 ++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) (limited to 'vendor/github.com/tdewolff/parse/v2/buffer') diff --git a/vendor/github.com/tdewolff/parse/v2/buffer/writer.go b/vendor/github.com/tdewolff/parse/v2/buffer/writer.go index b3c9990d9..6c94201ff 100644 --- a/vendor/github.com/tdewolff/parse/v2/buffer/writer.go +++ b/vendor/github.com/tdewolff/parse/v2/buffer/writer.go @@ -1,14 +1,29 @@ package buffer +import ( + "io" +) + // Writer implements an io.Writer over a byte slice. type Writer struct { - buf []byte + buf []byte + err error + expand bool } // NewWriter returns a new Writer for a given byte slice. func NewWriter(buf []byte) *Writer { return &Writer{ - buf: buf, + buf: buf, + expand: true, + } +} + +// NewStaticWriter returns a new Writer for a given byte slice. It does not reallocate and expand the byte-slice. +func NewStaticWriter(buf []byte) *Writer { + return &Writer{ + buf: buf, + expand: false, } } @@ -17,6 +32,10 @@ func (w *Writer) Write(b []byte) (int, error) { n := len(b) end := len(w.buf) if end+n > cap(w.buf) { + if !w.expand { + w.err = io.EOF + return 0, io.EOF + } buf := make([]byte, end, 2*cap(w.buf)+n) copy(buf, w.buf) w.buf = buf @@ -39,3 +58,8 @@ func (w *Writer) Bytes() []byte { func (w *Writer) Reset() { w.buf = w.buf[:0] } + +// Close returns the last error. +func (w *Writer) Close() error { + return w.err +} -- cgit v1.2.3